/* V7 CMS — style.css | Full site styles */

/* ══ FONT FACES (injected inline for critical, full here as fallback) ══ */
/* Defined inline in index.php head via fontFaces variable */

/* ══ SECTION BASE ══════════════════════════════════════════════ */
.section-inner{max-width:1280px;margin:0 auto;padding:0 3rem;width:100%}
.section-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem 1rem;border-radius:50px;background:rgba(0,194,209,.08);border:1px solid rgba(0,194,209,.18);color:var(--accent);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.2rem}
.section-title{font-family:var(--font-heading);font-weight:800;font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.15;margin-bottom:1rem;text-align:center}
.section-desc{font-size:1rem;color:var(--text-muted);line-height:1.7;max-width:620px;margin:0 auto 2.5rem;text-align:center}

/* ══ PATTERNS ══════════════════════════════════════════════════ */
.mesh-square{position:relative}
.mesh-square::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(0,194,209,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(0,194,209,.07) 1px,transparent 1px);background-size:55px 55px;-webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%);mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%)}
.mesh-diagonal{position:relative}
.mesh-diagonal::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 54px,rgba(0,194,209,.05) 54px,rgba(0,194,209,.05) 55px),repeating-linear-gradient(-45deg,transparent,transparent 54px,rgba(0,194,209,.05) 54px,rgba(0,194,209,.05) 55px);-webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%);mask-image:radial-gradient(ellipse 90% 80% at 50% 50%,black 30%,transparent 75%)}
.glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}
.glow-cyan{background:rgba(0,194,209,.055)}
.glow-orange{background:rgba(240,132,42,.04)}
.sep{height:1px;background:linear-gradient(90deg,transparent 5%,rgba(0,194,209,.1) 30%,rgba(240,132,42,.08) 70%,transparent 95%)}

/* ══ BUTTONS ═══════════════════════════════════════════════════ */
.btn-main{background:linear-gradient(135deg,var(--accent2),color-mix(in srgb,var(--accent2) 85%,black));color:#fff;padding:.9rem 2rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:.9rem;transition:all .3s;box-shadow:0 8px 32px rgba(240,132,42,.25);display:inline-flex;align-items:center;gap:.5rem;border:none;cursor:pointer;font-family:var(--font-body)}
.btn-main:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(240,132,42,.35)}
.btn-ghost{border:2px solid rgba(255,255,255,.15);color:var(--text);padding:.9rem 2rem;border-radius:50px;text-decoration:none;font-weight:500;font-size:.9rem;transition:all .3s;display:inline-flex;align-items:center;gap:.5rem}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ══ HERO ═══════════════════════════════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding:8rem 3rem 4rem;overflow:hidden;contain:layout style}
.hero-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;width:100%;gap:4rem}
.hero-content{flex:1;max-width:580px;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem 1.1rem;border-radius:50px;background:rgba(0,194,209,.08);border:1px solid rgba(0,194,209,.2);color:var(--accent);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.8rem;animation:fadeUp .7s ease-out}
.hero-badge .dot{width:7px;height:7px;background:var(--accent);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero h1{font-family:var(--font-heading);font-weight:800;font-size:clamp(2.2rem,4.5vw,3.5rem);line-height:1.1;margin-bottom:1.3rem;animation:fadeUp .8s ease-out .1s both}
.hero h1 .grad{background:linear-gradient(135deg,var(--accent),var(--secondary,#1a6fb5));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.05rem;font-weight:500;color:rgba(255,255,255,.85);margin-bottom:.8rem;animation:fadeUp .8s ease-out .15s both}
.hero-desc{font-size:.95rem;color:var(--text-muted);line-height:1.7;margin-bottom:2.2rem;animation:fadeUp .8s ease-out .2s both}
.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .8s ease-out .3s both}

/* Bento */
.hero-bento{flex:1;max-width:560px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:200px 200px;gap:.8rem;position:relative;z-index:1;animation:fadeRight 1s ease-out .4s both}
.hero-bento .bento-main{grid-row:1/3;border-radius:20px;overflow:hidden;position:relative}
.hero-bento .bento-main img,.hero-bento .bento-sm img{width:100%;height:100%;object-fit:cover}
.hero-bento .bento-sm{border-radius:16px;overflow:hidden;position:relative}
.bento-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.5),transparent 50%)}
.bento-label{position:absolute;bottom:.8rem;left:.8rem;font-size:.68rem;font-weight:600;color:#fff;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);padding:.25rem .65rem;border-radius:8px}
.hero-float{position:absolute;z-index:10;background:rgba(13,26,45,.85);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.7rem 1rem;display:flex;align-items:center;gap:.6rem;animation:float 4s ease-in-out infinite;box-shadow:0 8px 32px rgba(0,0,0,.3)}
.hero-float-1{top:10px;right:-15px}
.hero-float-2{bottom:15px;left:-15px;animation-delay:1.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.float-icon.cyan{background:rgba(0,194,209,.15)}
.float-icon.orange{background:rgba(240,132,42,.15)}
.float-num{font-family:var(--font-heading);font-weight:800;font-size:1.1rem;line-height:1}
.float-label{font-size:.63rem;color:var(--text-muted);margin-top:.1rem}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ══ SERVICES ═══════════════════════════════════════════════════ */
.services{padding:6rem 0;background:var(--secondary)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}
.service-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:1.8rem;transition:all .3s;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,194,209,.04),transparent);opacity:0;transition:opacity .3s}
.service-card:hover{border-color:rgba(0,194,209,.25);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.2)}
.service-card:hover::before{opacity:1}
.service-icon{font-size:2rem;margin-bottom:1rem;display:block}
.service-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.6rem}
.service-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6}
.services-note{text-align:center;font-size:.95rem;color:var(--text-muted)}
.services-note a{color:var(--accent);text-decoration:none;font-weight:600}
.services-note a:hover{text-decoration:underline}

/* ══ ABOUT ══════════════════════════════════════════════════════ */
.about{padding:6rem 0;background:var(--primary);position:relative;overflow:hidden}
.about-inner{display:flex;align-items:center;gap:5rem}
.about-image{flex:1;max-width:480px}
.about-image img{width:100%;border-radius:20px;box-shadow:0 32px 80px rgba(0,0,0,.4)}
.about-content{flex:1}
.about-text{font-size:1rem;color:var(--text-muted);line-height:1.8;margin-bottom:1rem}
.about-checks{list-style:none;margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}
.about-checks li{display:flex;align-items:center;gap:.75rem;font-size:.95rem}
.check-icon{width:22px;height:22px;background:rgba(0,194,209,.12);border:1px solid rgba(0,194,209,.3);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--accent);flex-shrink:0}

/* ══ BEFORE AFTER ═══════════════════════════════════════════════ */
.before-after{padding:6rem 0;background:var(--secondary)}
.ba-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}
.ba-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden}
.ba-images{display:flex;align-items:stretch;gap:0}
.ba-side{flex:1;position:relative;display:flex;flex-direction:column}
.ba-side img{width:100%;height:180px;object-fit:cover}
.ba-label{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.3rem .7rem;border-radius:0 0 6px 0;position:absolute;top:0;left:0}
.ba-label.before{background:rgba(239,68,68,.85);color:#fff}
.ba-label.after{background:rgba(16,185,129,.85);color:#fff}
.ba-arrow{display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--accent);padding:0 .5rem;background:rgba(0,194,209,.06)}
.ba-info{padding:1.2rem}
.ba-info h3{font-size:1rem;font-weight:700;margin-bottom:.4rem}
.ba-info p{font-size:.88rem;color:var(--text-muted);line-height:1.6}

/* ══ TESTIMONIALS ═══════════════════════════════════════════════ */
.testimonials{padding:6rem 0;background:var(--primary)}
.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.test-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:1.8rem;transition:transform .3s}
.test-card:hover{transform:translateY(-4px)}
.test-stars{color:var(--accent2);font-size:1rem;margin-bottom:.8rem;letter-spacing:.1em}
.test-text{font-size:.95rem;color:var(--text-muted);line-height:1.7;margin-bottom:1.2rem;font-style:italic}
.test-author{display:flex;align-items:center;gap:.75rem}
.test-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(0,194,209,.2)}
.test-avatar-placeholder{width:44px;height:44px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff;flex-shrink:0}
.test-name{font-size:.9rem;font-weight:700}
.test-role{font-size:.8rem;color:var(--text-muted)}

/* ══ SERVICE AREA ═══════════════════════════════════════════════ */
.service-area{padding:6rem 0;background:var(--secondary);text-align:center}
.area-badge{display:inline-block;background:rgba(0,194,209,.08);border:1px solid rgba(0,194,209,.2);color:var(--accent);padding:.5rem 1.2rem;border-radius:50px;font-size:.85rem;font-weight:600;margin-bottom:2rem}
.map-embed{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}

/* ══ BANNER ROTATIVO ════════════════════════════════════════════ */
.banner-rotativo{position:relative;overflow:hidden;background:var(--primary)}
.carousel{position:relative;width:100%;aspect-ratio:16/6;min-height:280px}
.carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .6s ease}
.carousel-slide.active{opacity:1;z-index:1}
.carousel-slide img{width:100%;height:100%;object-fit:cover}
.carousel-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,22,40,.7) 30%,transparent 70%);display:flex;align-items:center}
.carousel-content{padding:3rem 4rem;max-width:580px}
.carousel-content h3{font-family:var(--font-heading);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:800;margin-bottom:.8rem}
.carousel-content p{font-size:1rem;color:rgba(255,255,255,.8);margin-bottom:1.5rem}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(0,0,0,.4);color:#fff;border:none;border-radius:50%;width:46px;height:46px;font-size:1.5rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}
.carousel-btn:hover{background:rgba(0,0,0,.7)}
.carousel-btn.prev{left:1.5rem}
.carousel-btn.next{right:1.5rem}
.carousel-dots{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:10}
.carousel-dots .dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:all .3s;padding:0}
.carousel-dots .dot.active{background:#fff;width:24px;border-radius:4px}

/* ══ CONTACT ════════════════════════════════════════════════════ */
.contact{padding:6rem 0;background:var(--primary);position:relative;overflow:hidden}
.contact-inner{display:flex;gap:5rem;align-items:flex-start}
.contact-info{flex:1}
.contact-desc{font-size:1rem;color:var(--text-muted);line-height:1.7;margin-bottom:2rem}
.contact-items{display:flex;flex-direction:column;gap:1rem}
.contact-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:12px;text-decoration:none;color:var(--text);transition:border-color .2s}
.contact-item:hover{border-color:rgba(0,194,209,.3)}
.contact-item-icon{font-size:1.4rem;flex-shrink:0}
.contact-item-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.contact-item-value{font-size:.95rem;font-weight:600;margin-top:.1rem}
.contact-form-wrap{flex:1}
.contact-form-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:20px;padding:2.5rem}
.contact-form-card h3{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;margin-bottom:.4rem}
.contact-form-card p{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem}
.contact-form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.8rem 1rem;color:var(--text);font-size:.95rem;font-family:var(--font-body);transition:border-color .2s;width:100%}
.form-group input:focus,.form-group select,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.form-group select option{background:var(--primary)}
.form-group textarea{resize:vertical;min-height:100px}
.form-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:#6EE7B7;padding:1rem;border-radius:10px;font-size:.95rem;margin-bottom:1rem}
.form-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#FCA5A5;padding:1rem;border-radius:10px;font-size:.95rem;margin-bottom:1rem}

/* ══ FOOTER ═════════════════════════════════════════════════════ */
.footer{background:var(--secondary);padding:4rem 0 2rem;position:relative}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand img{margin-bottom:1rem}
.footer-logo{filter:brightness(1.2)}
.footer-brand p{font-size:.9rem;color:var(--text-muted);line-height:1.7;margin-bottom:1.2rem}
.footer-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem}
.footer-badge{font-size:.75rem;font-weight:600;color:var(--text-muted);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:.3rem .7rem;border-radius:50px}
.footer-social{display:flex;gap:.75rem}
.footer-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .2s;text-decoration:none}
.footer-social a:hover{background:rgba(0,194,209,.12);border-color:rgba(0,194,209,.3);color:var(--accent)}
.footer-col h4{font-size:.9rem;font-weight:700;margin-bottom:1rem;color:rgba(255,255,255,.9)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col li,.footer-col a{font-size:.88rem;color:var(--text-muted);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.footer-bottom p{font-size:.8rem;color:var(--text-muted)}
.footer-bottom a{color:var(--accent);text-decoration:none}

/* ══ WHATSAPP FLOAT ═════════════════════════════════════════════ */
.whatsapp-float{position:fixed;bottom:2rem;right:2rem;width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(37,211,102,.35);z-index:999;transition:all .3s;color:#fff;text-decoration:none}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 14px 40px rgba(37,211,102,.45)}

/* ══ NAV ════════════════════════════════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.2rem 3rem;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:rgba(10,22,40,.82);border-bottom:1px solid rgba(255,255,255,.04)}
.nav-logo{height:80px;width:auto}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{color:rgba(255,255,255,.6);text-decoration:none;font-size:.88rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width .3s}
.nav-links a:hover{color:var(--text)}.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--accent2);color:#fff;padding:.65rem 1.5rem;border-radius:50px;text-decoration:none;font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;transition:all .3s;border:2px solid var(--accent2)}
.nav-cta:hover{background:transparent;color:var(--accent2)}
.mobile-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer;padding:4px}
.nav-links.open{display:flex!important}

/* ══ MOBILE ═════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-inner{flex-direction:column;gap:3rem;padding-top:2rem}
  .hero-bento{max-width:100%;width:100%}
  .hero-content{max-width:100%;text-align:center}
  .hero-buttons{justify-content:center}
  .about-inner{flex-direction:column;gap:2.5rem}
  .about-image{max-width:100%}
  .contact-inner{flex-direction:column;gap:2.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:768px){
  .section-inner{padding:0 1.5rem}
  .hero{padding:7rem 1.5rem 3rem}
  nav{padding:.2rem 1.5rem}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(10,22,40,.97);flex-direction:column;padding:1rem;gap:.5rem;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-links a{font-size:1rem;padding:.75rem 1rem;border-radius:8px}
  .mobile-toggle{display:block}
  .hero-bento{grid-template-rows:180px 180px}
  .hero-float-1{right:-5px}.hero-float-2{left:-5px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:.25rem}
  .carousel-content{padding:2rem}
  .ba-grid{grid-template-columns:1fr}
  .services,.about,.before-after,.testimonials,.service-area,.contact{padding:4rem 0}
}
@media(max-width:480px){
  .hero h1{font-size:2rem}
  .hero-bento{display:none}
}
