/* Landing Page UI Kit — component styles
   Tokens come from ../../colors_and_type.css */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--hs-cream);color:var(--fg1)}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
.section{padding:96px 0}
.center{text-align:center}
.eyebrow{display:inline-block;margin-bottom:18px}
.lead-center{max-width:680px;margin:0 auto}

/* ---------- buttons ---------- */
.btn{font-family:var(--font-sans);font-weight:600;font-size:1rem;border:0;border-radius:var(--r-pill);
     padding:16px 30px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;
     transition:all .25s var(--ease);text-decoration:none;line-height:1}
.btn i{font-size:1.15em}
.btn-primary{background:var(--hs-blue);color:#fff}
.btn-primary:hover{background:var(--hs-blue-deep);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-primary:active{transform:scale(.98)}
.btn-wa{background:var(--hs-whatsapp);color:#fff}
.btn-wa:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-ghost{background:transparent;color:var(--hs-blue-ink);border:1.5px solid var(--hs-greige)}
.btn-ghost:hover{border-color:var(--hs-blue);color:var(--hs-blue)}
.btn-lg{padding:19px 38px;font-size:1.08rem}

/* ---------- badge / availability ---------- */
.badge{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-sans);font-weight:600;
       font-size:.85rem;padding:10px 18px;border-radius:var(--r-pill);background:var(--hs-blue-wash);
       color:var(--hs-blue-ink);border:1px solid var(--hs-blue-light)}
.dot{width:9px;height:9px;border-radius:50%;background:var(--hs-green);position:relative;flex:none}
.dot::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:2px solid var(--hs-green);opacity:.4;animation:pulse 1.8s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.6}100%{transform:scale(1.6);opacity:0}}
@media (prefers-reduced-motion:reduce){.dot::after{animation:none}}

.tag{font-family:var(--font-sans);font-weight:700;font-size:.64rem;letter-spacing:.12em;
     text-transform:uppercase;padding:6px 12px;border-radius:var(--r-pill);background:var(--hs-blue);color:#fff}

/* ---------- floating WhatsApp ---------- */
.wa-float{position:fixed;right:26px;bottom:26px;z-index:80;width:62px;height:62px;border-radius:50%;
          background:var(--hs-whatsapp);color:#fff;display:flex;align-items:center;justify-content:center;
          font-size:2rem;text-decoration:none;border:0;cursor:pointer;
          box-shadow:0 10px 28px rgba(37,151,108,.42);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.wa-float:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 16px 36px rgba(37,151,108,.5)}
.wa-float::before{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--hs-whatsapp);
          opacity:.5;animation:wa-pulse 2.4s ease-out infinite}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}
@media (prefers-reduced-motion:reduce){.wa-float::before{animation:none}}

/* ---------- reveal animation initial state (gated so print/reduced-motion show content) ---------- */
html.gsap-ready [data-reveal]{opacity:0}
@media (prefers-reduced-motion:reduce){html.gsap-ready [data-reveal]{opacity:1 !important}}

/* ---------- equipamentos (Dobra 7) ---------- */
.equip-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-top:48px}
.equip-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.equip-item{display:flex;align-items:flex-start;gap:18px;padding:18px 20px;border-radius:var(--r-md);
            background:#fff;border:1px solid var(--line-soft);box-shadow:var(--shadow-xs);
            transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.equip-item:hover{transform:translateX(4px);box-shadow:var(--shadow-sm)}
.equip-ic{flex:none;width:46px;height:46px;border-radius:var(--r-sm);background:var(--hs-blue-wash);
          display:flex;align-items:center;justify-content:center;color:var(--hs-blue);font-size:1.35rem}
.equip-txt{font-family:var(--font-sans);font-size:1rem;line-height:1.45;color:var(--fg1);padding-top:2px}
.equip-txt strong{font-weight:700;color:var(--hs-blue-ink)}
.equip-photo{width:100%;aspect-ratio:4/5;max-height:560px;background:var(--hs-blue-wash);border-radius:var(--r-diag);
             overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md)}
.equip-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- navbar (transparent over dark hero → cream on scroll) ---------- */
.nav{position:sticky;top:0;z-index:50;background:transparent;border-bottom:1px solid transparent;
     transition:background .35s var(--ease),border-color .35s,box-shadow .35s}
.nav.scrolled{background:rgba(249,244,235,.9);backdrop-filter:blur(12px);border-color:var(--line-soft);box-shadow:var(--shadow-xs)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:88px}
.nav-logo{height:52px;width:auto;display:block}
.nav-cta{background:#fff;color:var(--hs-blue-ink)}
.cta-short{display:none}
.nav-cta:hover{background:var(--hs-cream);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.nav.scrolled .nav-cta{background:var(--hs-blue);color:#fff}
.nav.scrolled .nav-cta:hover{background:var(--hs-blue-deep)}

/* ---------- hero (bold deep-teal block, rounded bottom, floats on cream) ---------- */
.hero{position:relative;overflow:hidden;background:var(--hs-blue-ink);color:#fff;
      margin-top:-88px;padding:150px 0 88px;border-radius:0 0 48px 48px}
.hero::before{content:"";position:absolute;top:-30%;right:-12%;width:620px;height:620px;border-radius:50%;
      background:radial-gradient(circle,rgba(175,203,211,.16),transparent 68%);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero h1{margin:26px 0 0;color:#fff;line-height:1.12}
.hero h1 em{color:var(--hs-blue-light)}
.hero .hs-lead{margin:30px 0 36px;max-width:520px;color:rgba(255,255,255,.78)}
.hero .badge{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22);color:#fff}
.hero-cred{display:flex;align-items:center;gap:10px;margin-top:30px;padding-top:26px;
           border-top:1px solid rgba(255,255,255,.16);font-family:var(--font-sans);font-size:.9rem;color:rgba(255,255,255,.7)}
.hero-cred i{color:var(--hs-blue-light);font-size:1.2rem}
.photo{position:relative;width:100%;aspect-ratio:4/5;background:var(--hs-blue-wash);
       border-radius:var(--r-diag);overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg)}
.photo.alt{border-radius:64px 0}
.photo img{width:100%;height:100%;object-fit:cover;display:block}
.ph-label{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--hs-blue);opacity:.55}
.ph-label i{font-size:3rem}
.ph-label span{font-family:var(--font-sans);font-size:.8rem;letter-spacing:.04em}

/* ---------- cards / grids ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:54px}
.card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:30px;
      box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);position:relative}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card-ic{width:54px;height:54px;border-radius:var(--r-md);background:var(--hs-blue-wash);display:flex;
         align-items:center;justify-content:center;color:var(--hs-blue);font-size:1.6rem;margin-bottom:20px}
.card h3{margin:0 0 10px}
.card p{margin:0;color:var(--fg2);font-size:.95rem}
.card-meta{margin-top:18px;font-family:var(--font-sans);font-size:.82rem;color:var(--hs-taupe);
           display:flex;align-items:center;gap:7px}
.card.feat{border-color:var(--hs-blue);box-shadow:var(--shadow-md)}
.card.feat .card-ic{background:var(--hs-blue);color:#fff}
.card .tag{position:absolute;top:22px;right:22px}
.card ul{margin:8px 0 0;padding-left:18px;color:var(--fg2);font-size:.95rem;line-height:1.8}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center;margin-top:48px}
.quote{font-family:var(--font-display);font-size:clamp(1.5rem,2.4vw,2.05rem);line-height:1.32;
       color:var(--hs-blue-ink);font-weight:500}
.quote-author{margin-top:18px;font-family:var(--font-sans);font-size:.95rem;color:var(--hs-taupe);font-weight:600}
.float-quote{position:absolute;left:22px;bottom:22px;right:22px;background:rgba(255,255,255,.82);
             backdrop-filter:blur(8px);border-radius:var(--r-md);padding:16px 18px;font-family:var(--font-sans);
             font-size:.88rem;color:var(--hs-blue-ink);box-shadow:var(--shadow-sm);font-style:italic}
.creds{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:36px}
.creds h4{margin:0 0 12px;font-family:var(--font-sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;
          text-transform:uppercase;color:var(--hs-taupe);display:flex;align-items:center;gap:8px}
.creds h4 i{color:var(--hs-blue);font-size:1.1rem}
.creds li,.creds p{font-family:var(--font-sans);font-size:.92rem;color:var(--fg1);line-height:1.55;margin:0}
.creds ul{margin:0;padding-left:16px}

/* ---------- faq ---------- */
.faq{max-width:760px;margin:48px auto 0}
.faq-item{border-bottom:1px solid var(--line-soft)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 0;cursor:pointer;
       font-family:var(--font-display);font-size:1.32rem;color:var(--hs-blue-ink);font-weight:500}
.faq-q i{color:var(--hs-blue);font-size:1.25rem;flex:none;transition:transform .3s}
.faq-a{overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 0 24px;color:var(--fg2);font-family:var(--font-sans);font-size:1rem;line-height:1.65;max-width:660px}

/* ---------- mito banner ---------- */
.mito{background:var(--hs-blue-ink);border-radius:var(--r-lg);padding:48px 52px;margin-top:30px;
      display:grid;grid-template-columns:1fr auto;gap:36px;align-items:center}
.mito-myth{color:var(--fg2-on-dark);font-family:var(--font-display);font-size:1.5rem;font-style:italic;margin:0 0 16px}
.mito-myth .x{color:#E08B7E;font-style:normal;font-family:var(--font-sans);font-size:.7rem;font-weight:700;
              letter-spacing:.14em;text-transform:uppercase;display:block;margin-bottom:8px}
.mito-truth{color:var(--fg-on-dark);font-family:var(--font-sans);font-size:1.02rem;line-height:1.6;margin:0}
.mito-truth .v{color:var(--hs-green);font-weight:700;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
               display:block;margin-bottom:8px}

/* ---------- final cta ---------- */
.final{background:var(--hs-blue-wash);text-align:center}
.final h2{margin:0 0 20px}
.final .hs-lead{margin:0 auto 36px;max-width:600px}
.final-phone{margin-top:26px;font-family:var(--font-sans);font-size:.95rem;color:var(--fg2)}

/* ---------- footer ---------- */
.footer{background:var(--hs-blue-ink);color:var(--fg-on-dark);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px}
.footer-logo{height:42px;margin-bottom:20px}
.footer p{color:var(--fg2-on-dark);font-size:.92rem;line-height:1.6;max-width:340px}
.footer h5{font-family:var(--font-sans);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
           color:var(--fg2-on-dark);margin:0 0 18px}
.footer-list{display:flex;flex-direction:column;gap:12px;font-family:var(--font-sans);font-size:.92rem;color:var(--fg-on-dark)}
.footer-list a{color:var(--fg-on-dark)}
.footer-bar{margin-top:64px;border-top:1px solid rgba(255,255,255,.12);padding:26px 0;
            display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--fg2-on-dark)}

/* section header */
.sec-head{text-align:center;max-width:680px;margin:0 auto}
.sec-head .hs-lead{margin-top:18px}

.btn-light{background:#fff;color:var(--hs-blue-ink)}
.btn-light:hover{background:var(--hs-cream);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* ---------- before/after cases (Dobra 5) ---------- */
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:54px}
.case{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.case-head{display:flex;align-items:center;justify-content:space-between;padding:22px 26px}
.case-head h3{margin:0}
.case-badge{font-family:var(--font-sans);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
            color:var(--hs-blue);background:var(--hs-blue-wash);padding:6px 12px;border-radius:var(--r-pill)}
.case-figure{position:relative;background:#1a2326}
.case-figure img{width:100%;display:block;object-fit:cover}
.case-tags{position:absolute;inset:0;pointer-events:none}
.case-tags span{position:absolute;left:14px;font-family:var(--font-sans);font-size:.66rem;font-weight:700;
                letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(46,58,61,.72);
                backdrop-filter:blur(4px);padding:5px 11px;border-radius:var(--r-pill)}
.case-tags .t-antes{top:14px}
.case-tags .t-depois{bottom:14px}
.case p{padding:20px 26px;margin:0;color:var(--fg2);font-size:.94rem}

/* ---------- testimonials carousel (Dobra 6) ---------- */
.testi{position:relative}
.testi-track{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:54px 4px 12px;
             scrollbar-width:none;-webkit-overflow-scrolling:touch}
.testi-track::-webkit-scrollbar{display:none}
.testi-card{flex:0 0 286px;scroll-snap-align:center;background:#fff;border:1px solid var(--line-soft);
            border-radius:22px;padding:12px;box-shadow:var(--shadow-md)}
.testi-shot{width:100%;border-radius:14px;overflow:hidden;background:#111}
.testi-shot img{width:100%;height:auto;display:block}
.testi-name{padding:14px 8px 6px;font-family:var(--font-sans);font-size:.86rem;font-weight:700;color:var(--fg1);
            display:flex;align-items:center;gap:8px}
.testi-name i{color:#C13584}
.testi-nav{display:flex;justify-content:center;gap:14px;margin-top:28px}
.testi-btn{width:54px;height:54px;border-radius:50%;border:1.5px solid var(--hs-greige);background:#fff;
           color:var(--hs-blue-ink);font-size:1.3rem;display:flex;align-items:center;justify-content:center;
           cursor:pointer;transition:all .25s var(--ease)}
.testi-btn:hover{border-color:var(--hs-blue);color:var(--hs-blue);background:var(--hs-blue-wash)}

@media (max-width:880px){
  .cases-grid,.testi-card{grid-template-columns:1fr}
  .hero-grid,.about-grid,.mito{grid-template-columns:1fr}
  .grid-3,.grid-4,.creds,.footer-grid{grid-template-columns:1fr 1fr}
  .photo{max-width:440px}
}
@media (max-width:760px){
  .grid-3,.grid-4,.creds{grid-template-columns:1fr}
}
@media (max-width:600px){
  .cta-full{display:none}
  .cta-short{display:inline}
  .nav-logo{height:38px}
  .wrap{padding-left:20px;padding-right:20px}
  .equip-grid{grid-template-columns:1fr;gap:32px}
  .btn{justify-content:center;text-align:center}
  .footer-grid{grid-template-columns:1fr;text-align:center;gap:38px}
  .footer p{max-width:none;margin-left:auto;margin-right:auto}
  .footer-logo{display:block;margin-left:auto;margin-right:auto}
  .footer-list{align-items:center}
  .footer-bar{flex-direction:column;gap:14px;text-align:center}
}
