/* ===== TOKENS ===== */
:root{
  --cream:#F8F3E8;
  --cream-2:#EFE7D5;
  --ink:#1B1F24;
  --ink-2:#3D434B;
  --muted:#6B7280;
  --navy:#0E3A6B;
  --navy-2:#0A2C56;
  --navy-deep:#0A1F3A;
  --orange:#E07A2E;
  --orange-2:#C76418;
  --black:#0B0B0E;
  --black-2:#101115;
  --line:rgba(11,11,14,.08);
  --line-light:rgba(255,255,255,.10);
  --green:#3FB28F;
  --yellow:#F2C94C;
  --pink:#E94D87;
  --purple:#A663C7;
  --olive:#8B9F76;
  --sky:#3C8AC9;
  --sand:#E5A78B;
  --moss:#2F5938;
  --umber:#5C5045;

  --font-display:"Bricolage Grotesque","Inter",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --radius-sm:8px;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(11,11,14,.05);
  --shadow:0 8px 24px rgba(11,30,70,.08), 0 2px 4px rgba(11,30,70,.04);
}

/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
code{font-family:var(--font-mono);font-size:.86em}
em{font-style:italic}
h1,h2,h3,h4,p{margin:0}
ul{margin:0;padding:0;list-style:none}

.container{max-width:1280px;margin:0 auto;padding:0 32px}
.container.narrow{max-width:880px}

/* ===== TYPOGRAPHY ===== */
.display{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:-.02em;
  line-height:1.04;
  color:var(--navy);
}
h1.display{font-size:clamp(2.6rem,5vw,4.4rem)}
h2.display{font-size:clamp(2rem,3.7vw,3rem)}
.hero h1.display em{
  color:var(--orange);
  font-style:italic;
  font-weight:700;
  letter-spacing:-.02em;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-mono);
  font-size:.78rem;letter-spacing:.18em;color:var(--orange);
  font-weight:600;
  margin:0 0 18px;
}
.eyebrow-line{display:inline-block;width:32px;height:2px;background:var(--orange);border-radius:2px}
.eyebrow-center{justify-content:center}

.lede{
  font-size:1.05rem;color:var(--ink-2);max-width:54ch;
  margin:22px 0 28px;
}
.section-sub{
  color:var(--ink-2);font-size:1.02rem;max-width:60ch;margin:14px auto 0;
}
.section-sub.italic{font-style:italic}
.section-sub.light{color:#cbd2dc}

/* ===== SECTION FRAMING ===== */
section{padding:96px 0}
.pillars{background:var(--cream)}
.about{background:var(--cream-2)}
.playground{background:var(--cream)}
.case-studies{background:var(--cream)}
.services{background:var(--cream-2)}
.values{background:var(--navy);color:#fff;padding:72px 0 80px}
.brief{background:var(--cream);padding:80px 0}
.contact{background:var(--cream)}

.section-head{text-align:center;margin:0 auto 56px;max-width:760px}
.section-head-left{text-align:left;max-width:none;margin-bottom:48px}

/* ===== NAV ===== */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(10px);
  background:rgba(248,243,232,.78);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 32px;gap:24px}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--navy)}
.brand-mark{
  width:34px;height:34px;border-radius:9px;
  background:var(--navy);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-weight:700;font-size:.78rem;letter-spacing:.04em;
}
.brand-name{font-family:var(--font-display);font-size:1.02rem;letter-spacing:-.01em}
.nav-links{display:flex;gap:30px}
.nav-links a{
  position:relative;font-size:.95rem;color:var(--ink-2);font-weight:500;
}
.nav-links a:hover{color:var(--navy)}
.nav-links a.is-active{color:var(--navy);font-weight:600}
.nav-links a.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-22px;height:2px;background:var(--orange);border-radius:2px;
}
.nav-actions{display:flex;align-items:center;gap:14px}

/* ===== BUTTONS, PILLS, TAGS ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:999px;font-weight:600;font-size:.92rem;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-2)}
.btn-orange{background:var(--orange);color:#fff}
.btn-orange:hover{background:var(--orange-2)}
.btn-outline-orange{border:1px solid rgba(224,122,46,.5);color:var(--orange);background:transparent}
.btn-outline-orange:hover{background:rgba(224,122,46,.08)}
.btn-outline-light{border:1px solid rgba(255,255,255,.25);color:#fff;background:transparent}
.btn-outline-light:hover{background:rgba(255,255,255,.06)}
.btn .ico{display:inline-block;font-size:.95em}

.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.6);border:1px solid var(--line);
  font-size:.82rem;color:var(--ink-2);font-family:var(--font-mono);
}
.pill-ghost{background:transparent}
.pill-ghost-dark{background:transparent;border-color:rgba(255,255,255,.15);color:#cbd2dc}
.pill code{color:inherit}

.tag{
  display:inline-flex;align-items:center;
  padding:5px 12px;border-radius:999px;
  border:1px solid var(--line);
  font-family:var(--font-mono);font-size:.74rem;color:var(--ink-2);
  background:#fff;
}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}

.dot{width:8px;height:8px;border-radius:50%;background:var(--orange);display:inline-block}
.dot-orange{background:var(--orange)}
.dot-yellow{background:var(--yellow)}
.dot-green{background:var(--green)}
.pulse{box-shadow:0 0 0 0 rgba(63,178,143,.6);animation:pulse 1.6s ease-out infinite}
@keyframes pulse{
  to{box-shadow:0 0 0 14px rgba(63,178,143,0)}
}

.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px;border-radius:999px;
  background:rgba(11,30,70,.55);color:#fff;
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;
  backdrop-filter:blur(4px);
}
.chip-q1{background:rgba(63,178,143,.2);color:#7be0bb;border:1px solid rgba(63,178,143,.35)}

/* ===== HERO ===== */
.hero{padding:64px 0 96px}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.hero-stage{min-height:520px}

/* ===== STAGES (matter.js canvases) ===== */
.stage{
  position:relative;
  background:var(--black);
  border-radius:var(--radius-lg);
  overflow:hidden;
  height:520px;
  border:1px solid #1c1d22;
  box-shadow:0 20px 60px rgba(8,15,30,.18);
}
.stage-wide{width:100%;height:560px}
.stage-canvas{width:100%;height:100%;display:block;background:transparent}
.stage-tag{
  position:absolute;display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:999px;
  background:#15161b;color:#cfd2d8;
  font-family:var(--font-mono);font-size:.74rem;
  border:1px solid #23252c;
  z-index:2;pointer-events:auto;
}
.stage-tag-tl{top:14px;left:14px}
.stage-tag-tr{top:14px;right:14px}
.stage-tag-br{bottom:14px;right:14px}
.stage-tag-yellow{background:var(--yellow);color:#3a2d00;border-color:#d8b13d}
.stage-tag-orangebox{background:#1a1106;color:var(--yellow);border-color:#3a2a10}

/* ===== CARDS GRID ===== */
.cards-3{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}

/* ===== CARD (generic) ===== */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:28px;display:flex;flex-direction:column;gap:14px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.card-top{display:flex;align-items:center;justify-content:space-between}
.card h3{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.card p{color:var(--ink-2)}
.num{font-family:var(--font-mono);color:var(--muted);font-size:.84rem;letter-spacing:.08em}

/* Icon tiles */
.ico-tile{
  width:42px;height:42px;border-radius:11px;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;
}
.ico-tile.big{width:48px;height:48px}
.ico-tile-navy{background:var(--navy)}
.ico-tile-orange{background:var(--orange)}
.ico-tile-dark{background:#15161b;color:var(--orange)}
.ico-tile-cream{background:#EFE7D5;color:var(--ink)}
.ico-tile-light{background:rgba(255,255,255,.95);color:var(--navy)}
.ico-tile-wa{background:#fff;color:var(--green)}

.pillar-card{padding:30px}
.pillar-card .tag-row{margin-top:auto;padding-top:6px}

/* ===== ABOUT ===== */
.prose{margin-top:24px;text-align:center;color:var(--ink-2);max-width:720px;margin-left:auto;margin-right:auto}
.prose p{margin-bottom:18px;font-size:1.04rem}
.signature{color:var(--muted);margin-top:8px}

/* ===== PLAYGROUND ===== */
.playground-headrow{
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;
}
.param-row{display:flex;gap:10px;flex-wrap:wrap}

/* ===== CASE STUDIES ===== */
.case-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.case-head .display{margin:0}
.case-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease;
}
.case-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.case-cover{
  position:relative;height:170px;background:var(--cover,#0E3A6B);
  padding:18px 20px;display:flex;align-items:flex-start;justify-content:space-between;
  color:#fff;
}
.case-cover .ico-tile{position:relative;z-index:1}
.case-cover .case-num{
  position:absolute;left:24px;bottom:18px;
  font-family:var(--font-mono);color:rgba(255,255,255,.85);font-size:.84rem;letter-spacing:.08em;
}
.case-cover .chip{position:absolute;top:18px;right:18px}
.case-cover-dark{background:var(--cover,#0A1F35)}
.featured-tag{color:var(--orange);font-family:var(--font-mono)}
.case-body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:12px;flex:1}
.case-body h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--ink)}
.case-body p{color:var(--ink-2);font-size:.96rem}
.case-link{
  margin-top:auto;display:flex;align-items:center;justify-content:space-between;
  color:var(--navy);font-weight:600;font-size:.95rem;border-top:1px solid var(--line);padding-top:14px;
}
.case-link:hover{color:var(--orange)}
.link-ext{color:var(--muted)}

/* CTA cell */
.cta-card{
  background:var(--cream-2);
  border:1px dashed rgba(11,30,70,.18);
  padding:30px;
  display:flex;flex-direction:column;gap:16px;justify-content:center;
}
.cta-card h3{font-family:var(--font-display);font-size:1.5rem;color:var(--ink)}
.cta-card .case-link{border-top:1px solid var(--line);margin-top:6px}

/* ===== SERVICES ===== */
.services-grid{align-items:stretch}
.service-card{padding:28px;display:flex;flex-direction:column;gap:14px}
.service-card-feature{
  background:var(--navy);color:#fff;border-color:transparent;
  box-shadow:0 24px 48px rgba(8,15,30,.22);
  transform:translateY(-8px);
}
.service-card-feature h3, .service-card-feature .num{color:#fff}
.service-card-feature p{color:#cfd6e0}
.service-card-feature .num{color:rgba(255,255,255,.55)}
.badge-popular{
  background:var(--orange);color:#fff;
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;
  padding:5px 10px;border-radius:6px;
}
.check-list{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--line);padding-top:16px;margin-top:4px}
.check-list li{position:relative;padding-left:26px;color:var(--ink-2);font-size:.95rem}
.check-list li::before{
  content:"";position:absolute;left:0;top:6px;width:14px;height:14px;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233FB28F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M4 12l5 5L20 6'/></svg>");
}
.check-list-light{border-top-color:rgba(255,255,255,.15)}
.check-list-light li{color:#dde3ee}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:14px;gap:12px;flex-wrap:wrap}
.best-for{color:var(--muted);font-size:.86rem}
.best-for em{color:var(--ink-2);font-weight:500}
.service-card-feature .best-for{color:#a8b3c2}
.service-card-feature .best-for em{color:#fff}
.link-arrow{color:var(--navy);font-weight:600;font-size:.92rem}
.link-arrow:hover{color:var(--orange)}
.link-arrow-orange{color:var(--orange)}

/* ===== VALUES (navy) ===== */
.values .cards-3{gap:20px}
.value-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-lg);
  padding:26px;display:flex;flex-direction:column;gap:14px;
}
.value-card h3{font-family:var(--font-display);font-size:1.3rem;color:#fff}
.value-card p{color:#c8cfd9;font-size:.95rem}
.value-card .num{color:rgba(255,255,255,.5)}
.avail-bar{
  margin-top:32px;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  padding:18px 22px;border-radius:var(--radius-lg);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);
}
.avail-bar .dot{width:10px;height:10px}
.avail-text{flex:1;min-width:240px}
.avail-text strong{font-family:var(--font-display);font-size:1.1rem;color:#fff;font-weight:700;margin-right:10px}
.avail-sub{color:#a8b3c2;font-size:.92rem;margin-top:2px}
.avail-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ===== BRIEF ===== */
.brief .stage{padding:0;height:auto;min-height:520px}
.brief-grid{
  display:grid;grid-template-columns:1.05fr 1.2fr;gap:24px;
  padding:80px 56px 60px;
}
.brief-title{color:#fff;line-height:1.05;font-size:clamp(1.8rem,3.4vw,2.8rem)}
.brief-title-2{color:#fff}
.brief-form{display:flex;background:#0d0e13;border:1px solid #25262d;border-radius:14px;overflow:hidden;margin-top:22px;max-width:520px}
.brief-form input{
  flex:1;padding:14px 16px;background:transparent;border:0;color:#cdd2da;
  font-family:var(--font-mono);font-size:.95rem;outline:none;
}
.brief-form input::placeholder{color:#5c606a}
.btn-drop{
  background:var(--yellow);color:#3a2d00;font-family:var(--font-mono);font-weight:700;letter-spacing:.08em;
  padding:0 20px;font-size:.85rem;
}
.btn-drop:hover{filter:brightness(.96)}
.brief-stage{position:relative;min-height:380px;border-radius:14px;overflow:hidden}
.brief-stage canvas{width:100%;height:100%}

.brief-divider{
  display:flex;align-items:center;gap:14px;margin:32px 0 18px;max-width:520px;
  color:#7a7e88;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;
}
.brief-divider::before,.brief-divider::after{content:"";flex:1;height:1px;background:rgba(255,255,255,.10)}
.real-form{display:grid;gap:14px;max-width:520px}
.real-field{display:grid;gap:6px}
.real-label{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;
  color:#8b8f99;text-transform:uppercase;
}
.real-form input,
.real-form textarea{
  width:100%;padding:12px 14px;background:#0d0e13;border:1px solid #25262d;
  border-radius:10px;color:#e6e8ee;font-family:var(--font-body);font-size:.95rem;
  outline:none;transition:border-color .15s ease, box-shadow .15s ease;
}
.real-form input::placeholder,
.real-form textarea::placeholder{color:#5c606a}
.real-form input:focus,
.real-form textarea:focus{
  border-color:var(--orange);box-shadow:0 0 0 3px rgba(224,122,46,.18);
}
.real-form textarea{resize:vertical;min-height:96px;line-height:1.5}
.btn-send{
  margin-top:4px;justify-self:start;padding:12px 22px;border-radius:10px;
  background:var(--orange);color:#fff;font-weight:600;font-size:.95rem;
  display:inline-flex;align-items:center;gap:8px;
  transition:filter .15s ease, transform .1s ease;
}
.btn-send:hover{filter:brightness(1.05)}
.btn-send:active{transform:translateY(1px)}
.real-note{
  margin:0;color:#6b6f78;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em;
}

/* ===== CONTACT ===== */
.contact-grid{align-items:stretch}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:28px;display:flex;flex-direction:column;gap:14px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.contact-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.contact-card h3{font-family:var(--font-display);font-size:1.4rem;color:var(--ink)}
.contact-card p{color:var(--ink-2);font-size:.96rem}
.contact-value{
  margin-top:auto;display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-radius:10px;background:#fff;border:1px solid var(--line);
}
.contact-wa{background:var(--green);color:#fff;border-color:transparent}
.contact-wa h3,.contact-wa p{color:#fff}
.contact-wa .contact-value{background:#fff;color:var(--ink)}
.contact-porto{background:#F4E4D7;border-color:transparent}
.porto-meta{margin-top:auto;display:flex;flex-direction:column;gap:6px;color:var(--ink-2);font-size:.92rem}

/* ===== FOOTER ===== */
.footer{
  background:var(--navy-deep);color:#cfd6e0;
  padding:64px 0 24px;
}
.footer-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:32px;padding-bottom:32px;
}
.brand-light{color:#fff}
.footer-brand .pill-ghost-dark{margin-top:14px;display:inline-flex}
.footer-sub{margin-top:18px;font-size:.92rem;color:#a8b3c2;line-height:1.7}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{
  width:36px;height:36px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  background:#0E3A6B;color:#fff;
}
.socials .social-wa{background:var(--green)}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-head{font-family:var(--font-mono);color:var(--orange);font-size:.78rem;letter-spacing:.14em;margin-bottom:6px}
.footer-col a{color:#cfd6e0;font-size:.94rem}
.footer-col a:hover{color:#fff}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  border-top:1px solid rgba(255,255,255,.10);
  padding-top:18px;color:#a8b3c2;font-size:.86rem;
}
.footer-bottom-right{display:flex;gap:18px;align-items:center}
.footer-bottom-right a{color:#a8b3c2}
.footer-bottom-right a:hover{color:#fff}
.powered{display:inline-flex;align-items:center;gap:6px}
.powered em{color:#fff;font-style:italic}

/* ===== RESPONSIVE ===== */
@media (max-width: 1080px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-stage{min-height:420px}
  .stage{height:420px}
  .cards-3{grid-template-columns:repeat(2,1fr)}
  .case-grid > .case-card:nth-child(6){grid-column:span 2}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr}
  .footer-brand{grid-column:1 / -1}
  .brief-grid{grid-template-columns:1fr;padding:48px 28px 40px}
  .brief-stage{min-height:300px}
  .nav-links{display:none}
  .service-card-feature{transform:none}
}
@media (max-width: 720px){
  section{padding:64px 0}
  .container{padding:0 20px}
  .nav-actions .pill{display:none}
  .cards-3{grid-template-columns:1fr;gap:16px}
  .case-grid > .case-card:nth-child(6){grid-column:auto}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .case-head{flex-direction:column;align-items:flex-start}
  .stage{height:360px}
  .hero-stage{min-height:360px}
  .avail-bar{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   ANIMATIONS & MICRO-INTERACTIONS
   ============================================================ */

/* ---- Scroll-reveal base ---- */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
  will-change:opacity, transform;
}
.reveal.in-view{opacity:1;transform:none}

.reveal-stagger > *{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .6s cubic-bezier(.2,.7,.2,1), transform .6s cubic-bezier(.2,.7,.2,1);
  will-change:opacity, transform;
}
.reveal-stagger.in-view > *{opacity:1;transform:none}
.reveal-stagger.in-view > *:nth-child(1){transition-delay:0ms}
.reveal-stagger.in-view > *:nth-child(2){transition-delay:90ms}
.reveal-stagger.in-view > *:nth-child(3){transition-delay:180ms}
.reveal-stagger.in-view > *:nth-child(4){transition-delay:270ms}
.reveal-stagger.in-view > *:nth-child(5){transition-delay:360ms}
.reveal-stagger.in-view > *:nth-child(6){transition-delay:450ms}

/* ---- Hero load-in (no JS needed, runs on first paint) ---- */
.hero .eyebrow,
.hero h1,
.hero .lede,
.hero-cta{
  animation:fadeUp .9s cubic-bezier(.2,.7,.2,1) both;
}
.hero h1   {animation-delay:.10s}
.hero .lede{animation-delay:.22s}
.hero-cta  {animation-delay:.34s}
.hero-stage{
  animation:fadeIn 1s cubic-bezier(.2,.7,.2,1) .15s both;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px)}
  to  {opacity:1;transform:none}
}
@keyframes fadeIn{
  from{opacity:0;transform:scale(.98)}
  to  {opacity:1;transform:none}
}

/* ---- Buttons: arrow shifts right on hover ---- */
.btn span[aria-hidden="true"],
.case-link span[aria-hidden="true"]:not(.link-ext),
.link-arrow span[aria-hidden="true"],
.footer-col a span[aria-hidden="true"]{
  display:inline-block;
  transition:transform .25s cubic-bezier(.2,.7,.2,1);
}
.btn:hover span[aria-hidden="true"],
.case-link:hover span[aria-hidden="true"]:not(.link-ext),
.link-arrow:hover span[aria-hidden="true"]{
  transform:translateX(4px);
}

/* Subtle button "depth" on hover */
.btn{box-shadow:0 0 0 rgba(0,0,0,0)}
.btn-primary:hover{box-shadow:0 8px 20px rgba(14,58,107,.28)}
.btn-orange:hover {box-shadow:0 8px 20px rgba(224,122,46,.30)}

/* ---- Nav: animated underline on hover ---- */
.nav-links a{position:relative}
.nav-links a:not(.is-active)::after{
  content:"";position:absolute;left:50%;right:50%;bottom:-22px;
  height:2px;background:var(--orange);border-radius:2px;
  transition:left .28s cubic-bezier(.2,.7,.2,1), right .28s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:not(.is-active):hover::after{left:0;right:0}

/* ---- Card lifts: deeper, smoother ---- */
.card,.case-card,.contact-card{
  transition:transform .35s cubic-bezier(.2,.7,.2,1),
             box-shadow .35s ease,
             border-color .25s ease;
}
.card:hover,.case-card:hover,.contact-card:hover{transform:translateY(-6px)}

/* Icon tile pop on card hover */
.card .ico-tile,
.value-card .ico-tile,
.contact-card .ico-tile,
.cta-card .ico-tile{
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
}
.card:hover .ico-tile,
.value-card:hover .ico-tile,
.contact-card:hover .ico-tile,
.cta-card:hover .ico-tile{
  transform:rotate(-6deg) scale(1.08);
}

/* Case-card cover icon scale */
.case-cover .ico-tile{transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.case-card:hover .case-cover .ico-tile{transform:scale(1.14) rotate(-4deg)}
.case-card h3{transition:color .25s ease}
.case-card:hover h3{color:var(--orange)}

/* Service feature: bigger lift + glow on hover */
.service-card-feature{
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease;
}
.service-card-feature:hover{
  transform:translateY(-14px);
  box-shadow:0 36px 72px rgba(8,15,30,.35), 0 0 0 1px rgba(224,122,46,.3);
}

/* ---- Tag / pill micro-bounce ---- */
.tag,.pill{
  transition:transform .2s ease, background .2s ease,
             color .2s ease, border-color .2s ease;
}
.tag:hover,.pill:hover{
  transform:translateY(-2px);
  border-color:rgba(14,58,107,.28);
  background:#fff;
}

/* ---- Brand mark gentle pulse on hover ---- */
.brand .brand-mark{transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.brand:hover .brand-mark{animation:pulseMark .7s cubic-bezier(.2,.7,.2,1)}
@keyframes pulseMark{
  0%  {transform:scale(1) rotate(0)}
  40% {transform:scale(1.08) rotate(-5deg)}
  100%{transform:scale(1) rotate(0)}
}

/* ---- Footer socials lift ---- */
.socials a{transition:transform .25s cubic-bezier(.2,.7,.2,1), background .2s ease}
.socials a:hover{transform:translateY(-3px)}
.footer-col a{transition:color .2s ease, transform .2s ease}
.footer-col a:hover{transform:translateX(2px)}

/* ---- Stage tag dot blink ---- */
.stage-tag .dot{animation:dotBlink 1.7s ease-in-out infinite}
@keyframes dotBlink{
  0%,100%{opacity:1}
  50%   {opacity:.35}
}

/* ---- Drop button shine sweep ---- */
.btn-drop{position:relative;overflow:hidden;isolation:isolate}
.btn-drop::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.55) 50%, transparent 70%);
  transform:translateX(-110%);
  transition:transform .7s cubic-bezier(.2,.7,.2,1);
}
.btn-drop:hover::after{transform:translateX(110%)}

/* ---- Availability bar dot extra glow ---- */
.avail-bar .dot.pulse{
  box-shadow:0 0 0 0 rgba(63,178,143,.6);
  animation:pulse 1.6s ease-out infinite, dotBlink 2.4s ease-in-out infinite;
}

/* ---- Stage hover: slight glow on the dark canvases ---- */
.stage{transition:box-shadow .35s ease}
.stage:hover{box-shadow:0 24px 70px rgba(8,15,30,.28)}

/* ---- Eyebrow line: extend on view ---- */
.in-view .eyebrow-line,
.reveal-stagger.in-view .eyebrow-line{
  animation:lineGrow .8s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes lineGrow{
  from{width:0;opacity:0}
  to  {width:32px;opacity:1}
}

/* ---- Section heads gradient hover sparkle on h2 (subtle) ---- */
.display{
  background-clip:text;
}

/* ---- Reduced motion: kill animations ---- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
  .reveal,.reveal-stagger > *{opacity:1;transform:none}
}
