/* =========================================================
   ASSESS THE MESS. Shared site styles (Light theme)
   Palette: white / black / Atlassian-blue
   ========================================================= */
:root{
  --bg:            #FFFFFF;
  --bg-2:          #F7F8FA;
  --bg-3:          #F3F5F9;
  --panel:         #FFFFFF;
  --panel-2:       #FAFBFD;
  --line:          rgba(9,15,30,0.08);
  --line-strong:   rgba(9,15,30,0.14);
  --text:          #0A0B0F;
  --text-dim:      #4A5260;
  --text-muted:    #7B8494;
  --blue:          #2684FF;
  --blue-2:        #0052CC;
  --blue-3:        #0747A6;
  --blue-tint:     #E9F2FF;
  --blue-glow:     rgba(38,132,255,.28);
  --radius:        18px;
  --radius-sm:     12px;
  --ease:          cubic-bezier(.22,.61,.36,1);
  --container:     1200px;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
html{
  background:var(--bg);color:var(--text);
  scroll-behavior:smooth;
  scroll-padding-top:70px;
}
html,body{font-family:'Inter','SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.55;overflow-x:hidden;}
body{font-weight:400;letter-spacing:-0.01em;background:var(--bg);color:var(--text);}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
}
a{color:inherit;text-decoration:none;}
img,svg{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--blue);color:#fff;}

.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4vw,40px);}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:all .4s var(--ease);
  background:transparent;border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,0.78);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line);
  padding:12px 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:44px;position:relative;}

/* HVIT CONSULTING logo - bold wordmark + tracked subtitle */
.brand{
  display:inline-flex;align-items:center;gap:11px;text-decoration:none;
  user-select:none;transition:opacity .2s var(--ease);
  flex:0 0 auto;
}
.brand:hover{opacity:.8;}
.brand-h{
  font-family:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight:800;font-size:19px;letter-spacing:-0.02em;
  color:var(--text);line-height:1;
}
.brand-divider{
  width:1px;height:17px;background:var(--line-strong);
  display:inline-block;flex:0 0 auto;
}
.brand-sub{
  font-family:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight:300;font-size:11px;letter-spacing:0.22em;
  color:var(--text-muted);line-height:1;text-transform:uppercase;
  white-space:nowrap;
}
@media (max-width:520px){
  .brand-h{font-size:17px;}
  .brand-sub{font-size:10px;letter-spacing:0.18em;}
  .brand-divider{height:14px;}
}
@media (max-width:380px){
  .brand-sub{display:none;}
  .brand-divider{display:none;}
}
.nav-links{display:flex;gap:32px;align-items:center;}
.nav-links a{
  position:relative;
  font-size:14px;font-weight:500;
  color:var(--text-dim);
  padding:4px 0;
  transition:color .25s var(--ease), transform .25s var(--ease);
}
/* Animated underline - grows from the left on hover, persists for active page */
.nav-links a::after{
  content:"";
  position:absolute;left:0;bottom:-2px;
  width:100%;height:2px;
  background:linear-gradient(90deg, var(--blue) 0%, var(--blue-2) 100%);
  border-radius:2px;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .3s var(--ease);
}
.nav-links a:hover{color:var(--text);transform:translateY(-1px);}
.nav-links a:hover::after{transform:scaleX(1);}
/* Active (current) page - stays highlighted */
.nav-links a.active{color:var(--text);font-weight:600;}
.nav-links a.active::after{transform:scaleX(1);}

.nav-link-soon{
  display:inline-flex;align-items:center;gap:7px;
  font-size:14px;font-weight:500;
  color:var(--text-dim);
  transition:color .25s var(--ease), transform .25s var(--ease);
}
/* Override the generic underline - Products link is anchored by the "Soon" badge instead */
.nav-links a.nav-link-soon::after{display:none;}
.nav-link-soon:hover{color:var(--text);transform:translateY(-1px);}
.nav-link-soon.active{color:var(--text);font-weight:600;}
.nav-link-soon:hover .soon-badge,
.nav-link-soon.active .soon-badge{
  background:rgba(38,132,255,.18);
  border-color:rgba(38,132,255,.35);
  color:var(--blue);
}
.nav-link-soon .soon-badge{
  transition:background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
}
.nav-link-soon .soon-badge{
  font-size:9.5px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--blue-2);
  background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.2);
  padding:2px 6px;border-radius:4px;
  line-height:1;
}
/* Universal: center the nav-links absolutely so brand/contact widths don't shift them */
@media (min-width:861px){
  .nav-links{
    position:absolute;left:50%;top:50%;
    transform:translate(-50%,-50%);
  }
}

/* Top-right "Questions first? Contact us" - replaces the old Get Started CTA */
.nav-contact{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13.5px;font-weight:500;
  color:var(--text-dim);
  background:none;border:0;padding:0;cursor:pointer;
  font-family:inherit;letter-spacing:-0.005em;
  transition:color .25s var(--ease), transform .25s var(--ease);
  flex:0 0 auto;
  text-decoration:none;
}
.nav-contact .nav-contact-q{color:var(--text-muted);font-weight:400;}
.nav-contact .nav-contact-cta{
  color:var(--blue-2);font-weight:600;
  border-bottom:1px solid transparent;
  transition:border-color .2s var(--ease), color .2s var(--ease);
}
.nav-contact:hover .nav-contact-cta{color:var(--blue);border-color:var(--blue);}
.nav-contact svg{width:12px;height:12px;color:var(--blue-2);transition:transform .2s var(--ease), color .2s var(--ease);}
.nav-contact:hover svg{transform:translateX(2px);color:var(--blue);}

.nav-toggle{display:none;width:36px;height:36px;align-items:center;justify-content:center;}
.nav-toggle span{width:20px;height:1.5px;background:var(--text);display:block;position:relative;transition:.3s var(--ease);}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;width:100%;height:1.5px;background:var(--text);transition:.3s var(--ease);}
.nav-toggle span::before{top:-6px;}
.nav-toggle span::after{top:6px;}
@media (max-width:860px){
  .nav-links{display:none;}
  .nav-toggle{display:flex;}
  .nav-contact{display:none;}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px 0 80px;
  display:flex;align-items:center;
  overflow:hidden;
  isolation:isolate;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 650px at 15% 5%, rgba(38,132,255,0.14), transparent 60%),
    radial-gradient(900px 600px at 95% 90%, rgba(0,82,204,0.10), transparent 60%),
    radial-gradient(600px 400px at 50% 50%, rgba(38,132,255,0.05), transparent 70%);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(9,15,30,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(9,15,30,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center, #000 40%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 40%, transparent 75%);
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;width:100%;}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:50px;}}

h1.display{
  font-size:clamp(44px, 7vw, 92px);
  line-height:1.02;letter-spacing:-0.035em;font-weight:800;
  margin-bottom:26px;color:var(--text);
}
h1.display .accent{
  background:linear-gradient(135deg, #2684FF 0%, #0052CC 60%, #0747A6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p.lead{
  font-size:clamp(17px, 1.35vw, 20px);
  color:var(--text-dim);max-width:560px;margin-bottom:40px;line-height:1.6;
}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:999px;
  font-size:15px;font-weight:600;letter-spacing:-0.01em;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  position:relative;white-space:nowrap;
}
.btn svg{width:16px;height:16px;transition:transform .2s var(--ease);}
.btn:hover svg{transform:translateX(3px);}
.btn-primary{
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);
  color:#fff;
  box-shadow:0 10px 28px var(--blue-glow), inset 0 1px 0 rgba(255,255,255,.28);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px var(--blue-glow), inset 0 1px 0 rgba(255,255,255,.35);}
.btn-secondary{
  background:#fff;color:var(--text);
  border:1px solid var(--line-strong);
  box-shadow:0 1px 2px rgba(9,15,30,.04);
}
.btn-secondary:hover{border-color:rgba(9,15,30,0.22);transform:translateY(-2px);box-shadow:0 6px 16px rgba(9,15,30,.06);}
.btn.btn-with-badge{padding-right:14px;}
.btn.btn-with-badge .soon-badge{
  font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--blue-2);background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.22);
  padding:3px 8px;border-radius:5px;line-height:1;white-space:nowrap;
}
.btn.btn-with-badge:hover .soon-badge{background:rgba(38,132,255,.16);}

/* Hero actions wrapper - sizes to widest child so every row (cta, trust strip, contact link) lines up centered */
.hero-actions{width:fit-content;max-width:100%;}
.hero-actions .cta-row{justify-content:center;}
.hero-actions .payment-trust{align-self:center;}
@media (max-width:960px){.hero-actions{margin-left:auto;margin-right:auto;}}

/* Quiet inline contact link - sits under the hero CTA row */
.contact-inline{
  margin-top:18px;
  font-size:14.5px;color:var(--text-muted);
  display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;
}
.link-quiet{
  display:inline-flex;align-items:center;gap:4px;
  background:none;border:0;padding:0;cursor:pointer;
  font:inherit;font-weight:600;color:var(--blue-2);
  letter-spacing:-0.01em;
  transition:color .2s var(--ease);
}
.link-quiet svg{width:13px;height:13px;transition:transform .2s var(--ease);}
.link-quiet:hover{color:var(--blue);}
.link-quiet:hover svg{transform:translateX(3px);}

/* Hero visual: professional navy consulting dashboard */
.hero-visual{
  position:relative;aspect-ratio:1/1.12;max-width:625px;margin-left:auto;
  perspective:1600px;
}
.orb{
  position:absolute;inset:0;
  background:radial-gradient(circle at 50% 40%, rgba(38,104,200,.18), rgba(10,30,60,.04) 55%, transparent 75%);
  filter:blur(50px);opacity:.6;animation:float 10s var(--ease) infinite;
}
@keyframes float{0%,100%{transform:translate(0,0);}50%{transform:translate(8px,-14px);}}

.panel-card{
  position:relative;
  border-radius:20px;
  background:linear-gradient(180deg, #0F2240 0%, #081425 100%);
  border:1px solid rgba(255,255,255,0.06);
  padding:30px 28px;
  box-shadow:
    0 30px 60px -20px rgba(9,15,30,0.24),
    0 50px 110px -30px rgba(9,15,30,0.30),
    inset 0 1px 0 rgba(255,255,255,.04);
  color:#E6EDF7;
  transform:rotateX(4deg) rotateY(-6deg);
  transition:transform .6s var(--ease);
}
.hero-visual:hover .panel-card{transform:rotateX(1deg) rotateY(-2deg);}

.panel-head{margin-bottom:22px;}
.panel-head-top{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px;}
.panel-title{font-size:12px;color:#F0F4FA;font-weight:700;letter-spacing:.12em;text-transform:uppercase;}
.panel-period{font-size:11px;color:#7D8A9F;letter-spacing:.01em;white-space:nowrap;}
.panel-period .current{color:#A8B3C4;}
.panel-indicators{display:flex;gap:8px;flex-wrap:wrap;}
.indicator{
  display:inline-flex;align-items:center;gap:6px;
  font-size:10.5px;color:#C9D2DF;
  background:rgba(76,220,140,.06);
  border:1px solid rgba(76,220,140,.22);
  border-radius:6px;padding:4px 9px;
  font-weight:500;letter-spacing:.02em;
}
.indicator svg{width:12px;height:12px;color:#4CDC8C;flex:0 0 auto;}
.indicator b{color:#F0F4FA;font-weight:700;letter-spacing:.04em;}

/* MTTR block */
.stat-block{margin-bottom:22px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.05);}
.stat-label{font-size:11px;color:#7D8A9F;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;font-weight:600;}
.stat-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.baseline{font-size:13px;color:#7D8A9F;font-weight:500;}
.baseline b{color:#C9D2DF;font-weight:600;}
.arrow-sm-svg{width:16px;height:16px;color:#6B7484;flex:0 0 auto;}
.arrow-down-green{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:10px;
  background:rgba(76,220,140,.12);
  border:1px solid rgba(76,220,140,.32);
}
.arrow-down-green svg{width:22px;height:22px;color:#4CDC8C;}
.current-value{font-size:34px;font-weight:700;color:#F0F4FA;letter-spacing:-0.025em;line-height:1;}
.improvement{
  margin-top:12px;display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;color:#4CDC8C;letter-spacing:.02em;
}
.improvement svg{width:10px;height:10px;color:#4CDC8C;}
.improvement .sub{color:#7D8A9F;font-weight:500;}

/* Chart */
.chart-wrap{margin-bottom:22px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.05);}
.chart-cap{font-size:11px;color:#7D8A9F;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;font-weight:600;}
.bars{display:flex;align-items:flex-end;gap:8px;height:92px;}
.bar{flex:1;position:relative;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;}
.bar .col{width:100%;height:var(--h);background:#1F3A5F;border-radius:2px 2px 0 0;animation:grow 1.2s var(--ease) both;}
.bar span{font-size:10px;color:#7D8A9F;margin-top:8px;letter-spacing:.06em;font-weight:600;}
.bar.active .col{background:#3B82F6;}
.bar.active span{color:#E6EDF7;}
.bar:nth-child(1) .col{animation-delay:.10s;}
.bar:nth-child(2) .col{animation-delay:.18s;}
.bar:nth-child(3) .col{animation-delay:.26s;}
.bar:nth-child(4) .col{animation-delay:.34s;}
.bar:nth-child(5) .col{animation-delay:.42s;}
.bar:nth-child(6) .col{animation-delay:.50s;}
.bar:nth-child(7) .col{animation-delay:.58s;}
@keyframes grow{from{height:0;opacity:0;}}

/* Process list */
.process-title{font-size:11px;color:#7D8A9F;letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:10px;}
.mini-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;font-size:13px;}
.mini-row .k{color:#C9D2DF;display:flex;align-items:center;gap:9px;font-weight:500;}
.mini-row .v{color:#F0F4FA;font-weight:600;font-variant-numeric:tabular-nums;}
.mini-row .v .v-sub{color:#7D8A9F;font-weight:500;margin-left:3px;}
.check{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;color:#4CDC8C;flex:0 0 auto;}
.check svg{width:14px;height:14px;}

/* Recent context log */
.recent-context{
  margin-top:16px;padding-top:14px;
  border-top:1px solid rgba(255,255,255,.05);
  font-size:11px;color:#7D8A9F;letter-spacing:.02em;
  display:flex;align-items:center;gap:8px;
}
.recent-context .dot-blue{width:5px;height:5px;border-radius:50%;background:#3B82F6;flex:0 0 auto;}
.recent-context b{color:#C9D2DF;font-weight:600;}

/* ---------- SECTIONS ---------- */
section.block{padding:120px 0;position:relative;}
@media (max-width:760px){section.block{padding:80px 0;}}
.section-head{max-width:760px;margin:0 auto 70px;text-align:center;}
.section-tag{
  display:inline-block;font-size:12px;color:var(--blue-2);font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px;
}
h2{
  font-size:clamp(32px,4.4vw,56px);
  line-height:1.06;letter-spacing:-0.03em;font-weight:700;
  margin-bottom:18px;color:var(--text);
}
.section-head p{font-size:clamp(16px,1.15vw,18px);color:var(--text-dim);line-height:1.6;}

/* ---------- PROBLEM / PAIN ---------- */
.pain{background:linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);}
.pain-wrap{
  border-radius:28px;padding:clamp(36px,5vw,72px);
  background:
    radial-gradient(800px 400px at 20% 0%, rgba(38,132,255,.10), transparent 60%),
    #fff;
  border:1px solid var(--line);
  position:relative;overflow:hidden;
  box-shadow:0 10px 30px -10px rgba(9,15,30,.06);
}
.pain-wrap::before{
  content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  width:40%;height:1px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
}
.pain-content{max-width:780px;margin:0 auto;text-align:center;}
.pain-content h2{margin-bottom:24px;}
.pain-content p{font-size:clamp(17px,1.3vw,19px);color:var(--text-dim);line-height:1.7;}
.pain-content .highlight{color:var(--text);font-weight:500;}

/* ---------- CAPABILITIES GRID ---------- */
.caps-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:960px){.caps-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:620px){.caps-grid{grid-template-columns:1fr;}}
/* Sequential cascade: card 1 to 2 to 3 to 4 to 5 to 6 */
.caps-grid .cap.reveal{transition-delay:0s;}
.caps-grid .cap.reveal:nth-child(2){transition-delay:.12s;}
.caps-grid .cap.reveal:nth-child(3){transition-delay:.24s;}
.caps-grid .cap.reveal:nth-child(4){transition-delay:.36s;}
.caps-grid .cap.reveal:nth-child(5){transition-delay:.48s;}
.caps-grid .cap.reveal:nth-child(6){transition-delay:.60s;}

/* Section wrapper - light gray band that houses the 3x2 service grid */
.services-block{background:var(--bg-2);}

.cap{
  position:relative;padding:32px 32px 40px;border-radius:18px;
  background:#fff;
  border:1px solid var(--line);
  transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
  overflow:hidden;outline:none;cursor:default;
  display:flex;flex-direction:column;gap:10px;
  box-shadow:0 1px 2px rgba(9,15,30,.02);
}
.cap::before{
  content:"";position:absolute;inset:0;border-radius:18px;pointer-events:none;
  background:radial-gradient(480px 260px at 80% -20%, rgba(38,132,255,.07), transparent 60%);
  opacity:0;transition:opacity .5s var(--ease);
}
.cap-icon{
  width:40px;height:40px;border-radius:10px;
  background:transparent;
  border:1px solid var(--line-strong);
  display:grid;place-items:center;
  color:var(--text);
  transition:transform .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease), background .4s var(--ease);
  margin-bottom:8px;
}
.cap-icon svg{width:19px;height:19px;stroke-width:1.75;}
.cap-audience{
  display:inline-flex;align-items:center;gap:7px;
  font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-muted);
  margin:0;
}
.cap-audience::before{
  content:"";width:4px;height:4px;border-radius:50%;
  background:var(--blue);
  transition:transform .4s var(--ease);
}
.cap h3{
  font-size:18.5px;font-weight:700;letter-spacing:-0.015em;
  margin:0;color:var(--text);line-height:1.25;
}
.cap p{
  font-size:14px;color:var(--text-dim);line-height:1.6;
  margin:4px 0 0;flex:1;
}
.cap-accent{
  position:absolute;left:32px;right:32px;bottom:24px;height:1px;
  background:var(--line);overflow:hidden;pointer-events:none;
}
.cap-accent::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, var(--blue) 0%, var(--blue-2) 100%);
  transform:scaleX(0);transform-origin:left center;
  transition:transform .55s var(--ease);
}
.cap:hover,.cap:focus-visible{
  transform:translateY(-3px);
  border-color:rgba(38,132,255,.3);
  box-shadow:0 22px 44px -24px rgba(9,15,30,.16);
}
.cap:hover::before,.cap:focus-visible::before{opacity:1;}
.cap:hover .cap-icon,.cap:focus-visible .cap-icon{
  border-color:var(--blue);color:var(--blue);
  background:rgba(38,132,255,.05);
  transform:translateY(-1px);
}
.cap:hover .cap-audience::before,.cap:focus-visible .cap-audience::before{transform:scale(1.6);}
.cap:hover .cap-accent::after,.cap:focus-visible .cap-accent::after{transform:scaleX(1);}

/* Featured card - soft blue border + subtle glow + Focus pill */
.cap--featured{
  border-color:rgba(38,132,255,.35);
  box-shadow:
    0 0 0 1px rgba(38,132,255,.08),
    0 18px 40px -24px rgba(38,132,255,.22),
    0 1px 2px rgba(9,15,30,.03);
}
.cap--featured::before{opacity:1;}
.cap--featured .cap-icon{
  border-color:rgba(38,132,255,.45);
  color:var(--blue-2);
  background:var(--blue-tint);
}
.cap--featured .cap-accent{background:rgba(38,132,255,.18);}
.cap--featured:hover,.cap--featured:focus-visible{
  border-color:rgba(38,132,255,.55);
  box-shadow:
    0 0 0 1px rgba(38,132,255,.12),
    0 26px 52px -24px rgba(38,132,255,.28),
    0 1px 2px rgba(9,15,30,.04);
}
.cap-focus-pill{
  position:absolute;top:20px;right:20px;
  display:inline-flex;align-items:center;
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-2);background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.22);
  padding:4px 9px;border-radius:999px;line-height:1;
}

/* ---------- HOW IT WORKS ---------- */
.how{background:var(--bg-2);}
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  counter-reset:step;
  position:relative;
}
@media (max-width:860px){.steps{grid-template-columns:1fr;}}
.steps::before{
  content:"";position:absolute;top:40px;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(38,132,255,.4),transparent);
  z-index:0;
}
@media (max-width:860px){.steps::before{display:none;}}
.step{
  position:relative;z-index:1;
  padding:32px 28px;border-radius:20px;
  background:#fff;border:1px solid var(--line);
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
  box-shadow:0 1px 2px rgba(9,15,30,.03);
}
.step:hover{transform:translateY(-3px);border-color:rgba(38,132,255,.35);box-shadow:0 20px 40px -20px rgba(9,15,30,.14);}
.step-num{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  display:grid;place-items:center;
  font-size:20px;font-weight:700;color:#fff;
  margin-bottom:22px;
  box-shadow:0 8px 22px var(--blue-glow), inset 0 1px 0 rgba(255,255,255,.3);
}
.step h3{font-size:19px;font-weight:600;letter-spacing:-0.01em;margin-bottom:10px;color:var(--text);}
.step p{font-size:14.5px;color:var(--text-dim);line-height:1.6;}
.step ul{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:8px;}
.step ul li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--text-dim);}
.step ul li svg{flex-shrink:0;margin-top:4px;width:14px;height:14px;color:var(--blue-2);}

/* ---------- AUDIENCE ---------- */
.audience-grid{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;
}
@media (max-width:1060px){.audience-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:760px){.audience-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:460px){.audience-grid{grid-template-columns:1fr;}}
.audience-card{
  position:relative;overflow:hidden;
  height:210px;border-radius:16px;
  background:#fff;border:1px solid var(--line);
  cursor:pointer;outline:none;
  transition:border-color .35s var(--ease), box-shadow .35s var(--ease), transform .35s var(--ease);
  box-shadow:0 1px 2px rgba(9,15,30,.03);
}
.audience-card:hover,.audience-card:focus-visible{
  transform:translateY(-4px);
  border-color:rgba(38,132,255,.4);
  box-shadow:0 20px 40px -20px rgba(9,15,30,.14);
}
.audience-face{
  position:absolute;inset:0;
  padding:24px 22px;
  display:flex;flex-direction:column;
  transition:transform .55s var(--ease), opacity .35s var(--ease);
  will-change:transform;
}
.audience-face--front{
  align-items:center;justify-content:center;text-align:center;
  transform:translateX(0);opacity:1;
}
.audience-face--back{
  align-items:flex-start;justify-content:center;text-align:left;
  transform:translateX(100%);opacity:0;
}
.audience-card:hover .audience-face--front,
.audience-card:focus-within .audience-face--front{
  transform:translateX(-100%);opacity:0;
  transition-delay:0s;
}
.audience-card:hover .audience-face--back,
.audience-card:focus-within .audience-face--back{
  transform:translateX(0);opacity:1;
  transition-delay:.08s;
}
.audience-icon{
  width:48px;height:48px;margin:0 auto 16px;border-radius:12px;
  background:var(--blue-tint);display:grid;place-items:center;color:var(--blue-2);
}
.audience-icon svg{width:24px;height:24px;}
.audience-card h4{font-size:15px;font-weight:600;letter-spacing:-0.01em;color:var(--text);}
.audience-face--back .pain{
  font-size:13px;font-weight:600;color:var(--text);line-height:1.4;
  letter-spacing:-0.005em;margin-bottom:10px;
}
.audience-face--back .outcome{
  font-size:12.5px;color:var(--text-dim);line-height:1.55;
}
.audience-face--back .accent-bar{
  width:24px;height:3px;border-radius:2px;background:var(--blue-2);margin-bottom:12px;
}
@media (prefers-reduced-motion: reduce){
  .audience-face{transition:opacity .2s linear !important;transform:none !important;}
  .audience-face--back{opacity:0;}
  .audience-card:hover .audience-face--front,
  .audience-card:focus-within .audience-face--front{opacity:0;}
  .audience-card:hover .audience-face--back,
  .audience-card:focus-within .audience-face--back{opacity:1;}
}

/* ---------- WHY / TRUST ---------- */
.why-wrap{
  border-radius:28px;overflow:hidden;
  background:
    radial-gradient(700px 350px at 80% 0%, rgba(38,132,255,.12), transparent 60%),
    #fff;
  border:1px solid var(--line);
  padding:clamp(40px,5vw,72px);
  text-align:center;
  position:relative;
  box-shadow:0 10px 30px -10px rgba(9,15,30,.06);
}
.why-inner{max-width:780px;margin:0 auto;}
.why-inner h2{margin-bottom:18px;}
.why-inner p{color:var(--text-dim);font-size:clamp(16px,1.2vw,18px);line-height:1.7;margin-bottom:14px;}
.why-inner strong{color:var(--text);font-weight:600;}
.why-inner .cta-row{justify-content:center;margin-top:30px;}

/* ---------- CTA FINAL ---------- */
.cta-final{padding:120px 0 100px;text-align:center;position:relative;overflow:hidden;}
.cta-final::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(700px 400px at 50% 0%, rgba(38,132,255,.14), transparent 65%),
    radial-gradient(500px 300px at 50% 100%, rgba(0,82,204,.10), transparent 65%);
}
.cta-final::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(9,15,30,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(9,15,30,.04) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
}
.cta-final h2{max-width:800px;margin:0 auto 20px;font-size:clamp(36px,5.5vw,68px);}
.cta-final p{max-width:560px;margin:0 auto 14px;color:var(--text-dim);font-size:18px;}
.price-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;
  background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.25);
  color:var(--blue-2);font-size:14px;font-weight:600;letter-spacing:-0.01em;
  margin:10px auto 36px;
}
.price-badge .euro{
  font-size:16px;font-weight:700;color:var(--blue-2);
}
.price-badge .sep{width:4px;height:4px;border-radius:50%;background:rgba(0,82,204,.35);}
.cta-final .cta-row{justify-content:center;}
.contact-note{
  margin-top:28px;font-size:13.5px;color:var(--text-muted);
  display:inline-flex;align-items:center;gap:8px;
}
.contact-note a{color:var(--text-dim);border-bottom:1px solid var(--line-strong);padding-bottom:1px;}
.contact-note a:hover{color:var(--blue-2);border-color:var(--blue-2);}

/* ---------- FOOTER ---------- */
footer{
  border-top:1px solid var(--line);
  padding:50px 0 36px;
  background:var(--bg);
}
.foot-row{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:18px;text-align:center;}
.foot-meta{display:flex;gap:24px;font-size:13px;color:var(--text-muted);flex-wrap:wrap;justify-content:center;}
.foot-meta a:hover{color:var(--text);}
.foot-copy{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;font-size:13px;color:var(--text-muted);}
.brand--foot{gap:9px;}
.brand--foot .brand-h{font-size:14.5px;}
.brand--foot .brand-divider{height:13px;}
.brand--foot .brand-sub{font-size:9px;letter-spacing:0.2em;}

/* ---------- REVEAL ANIM ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease), transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.1s;}
.reveal.d2{transition-delay:.2s;}
.reveal.d3{transition-delay:.3s;}
.reveal.d4{transition-delay:.4s;}

/* ---------- CONTACT MODAL ---------- */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(9,15,30,0.45);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);
}
.modal-overlay.open{opacity:1;pointer-events:auto;}
.modal{
  background:#fff;border-radius:22px;
  max-width:540px;width:100%;max-height:92vh;overflow-y:auto;
  padding:clamp(28px,4vw,40px);position:relative;
  box-shadow:0 40px 100px -20px rgba(9,15,30,0.45), 0 0 0 1px var(--line);
  transform:scale(.95) translateY(20px);
  transition:transform .35s var(--ease);
}
.modal-overlay.open .modal{transform:scale(1) translateY(0);}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;
  background:var(--bg-2);border:1px solid var(--line);
  display:grid;place-items:center;
  color:var(--text-muted);
  transition:background .2s var(--ease), color .2s var(--ease), transform .2s var(--ease);
}
.modal-close:hover{background:var(--bg-3);color:var(--text);transform:rotate(90deg);}
.modal-close svg{width:16px;height:16px;}

/* Modal brand mark (header) */
.modal-brand{
  margin-bottom:22px;padding-bottom:18px;padding-right:40px;
  border-bottom:1px solid var(--line);
}
.brand--modal{display:inline-flex;align-items:center;gap:10px;}
.brand--modal .brand-h{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;font-weight:800;font-size:16px;letter-spacing:-0.02em;color:var(--text);line-height:1;}
.brand--modal .brand-divider{width:1px;height:14px;background:var(--line-strong);display:inline-block;}
.brand--modal .brand-sub{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;font-weight:300;font-size:10px;letter-spacing:0.22em;color:var(--text-muted);line-height:1;text-transform:uppercase;}

/* Multi-step visibility */
.modal-step{display:none;}
.modal .modal-step--choose{display:block;}
.modal.filled .modal-step--choose{display:none;}
.modal.filled .modal-step--form{display:block;}
.modal.sent .modal-step{display:none;}

.modal-header{margin-bottom:22px;padding-right:20px;}
.modal-header .tag-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;
  background:var(--blue-tint);color:var(--blue-2);
  font-size:12px;font-weight:600;letter-spacing:-0.01em;
  margin-bottom:14px;
}
.modal-header .tag-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--blue);}
.modal-header h3{font-size:24px;font-weight:700;letter-spacing:-0.025em;color:var(--text);margin-bottom:6px;line-height:1.2;}
.modal-header p{font-size:14.5px;color:var(--text-dim);line-height:1.5;}

/* Destination chooser cards */
.dest-grid{display:flex;flex-direction:column;gap:10px;}
.dest-card{
  position:relative;display:grid;
  grid-template-columns:42px 1fr auto;
  grid-template-rows:auto auto;
  grid-template-areas:"icon label arrow" "icon desc arrow";
  column-gap:16px;row-gap:4px;align-items:center;
  padding:18px 20px;border-radius:14px;
  background:#fff;border:1px solid var(--line);
  text-align:left;cursor:pointer;font-family:inherit;
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
}
.dest-card:hover,.dest-card:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(38,132,255,.35);
  box-shadow:0 18px 36px -22px rgba(9,15,30,.16);
  outline:none;
}
.dest-icon{
  grid-area:icon;width:42px;height:42px;border-radius:10px;
  border:1px solid var(--line-strong);
  display:grid;place-items:center;color:var(--text);
  transition:border-color .3s var(--ease), color .3s var(--ease), background .3s var(--ease);
}
.dest-icon svg{width:18px;height:18px;}
.dest-card:hover .dest-icon,.dest-card:focus-visible .dest-icon{
  border-color:var(--blue);color:var(--blue);background:rgba(38,132,255,.06);
}
.dest-label{
  grid-area:label;align-self:end;
  font-size:16px;font-weight:700;color:var(--text);letter-spacing:-0.01em;line-height:1.15;
}
.dest-desc{
  grid-area:desc;align-self:start;
  font-size:13px;color:var(--text-dim);line-height:1.55;margin:0;
}
.dest-arrow{
  grid-area:arrow;color:var(--text-muted);display:inline-flex;
  transition:transform .3s var(--ease), color .3s var(--ease);
}
.dest-arrow svg{width:18px;height:18px;}
.dest-card:hover .dest-arrow,.dest-card:focus-visible .dest-arrow{
  color:var(--blue);transform:translateX(3px);
}
@media (max-width:480px){
  .dest-card{padding:16px 14px;column-gap:12px;grid-template-columns:38px 1fr auto;}
  .dest-icon{width:38px;height:38px;}
}

/* Destination pill bar (form step) */
.modal-dest-bar{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:18px;padding:10px 14px;
  border-radius:10px;background:var(--bg-2);
  border:1px solid var(--line);
}
.dest-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;color:var(--text-muted);font-weight:500;letter-spacing:-0.005em;
}
.dest-pill strong{color:var(--text);font-weight:600;}
.dest-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--blue);}
.dest-change{
  display:inline-flex;align-items:center;gap:4px;
  font-size:12.5px;font-weight:500;color:var(--blue-2);
  background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;
  transition:background .2s var(--ease);font-family:inherit;
}
.dest-change:hover{background:rgba(38,132,255,.08);}
.dest-change svg{width:12px;height:12px;}
.field{margin-bottom:16px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media (max-width:480px){.field-row{grid-template-columns:1fr;}}
.field label{
  display:block;font-size:13px;font-weight:500;
  color:var(--text);margin-bottom:6px;letter-spacing:-0.005em;
}
.field label .optional{color:var(--text-muted);font-weight:400;font-size:12px;margin-left:4px;}
.field input,
.field textarea{
  width:100%;padding:12px 14px;border-radius:10px;
  border:1px solid var(--line-strong);background:#fff;
  color:var(--text);font-size:14.5px;font-family:inherit;line-height:1.5;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
  letter-spacing:-0.005em;
}
.field input::placeholder,
.field textarea::placeholder{color:var(--text-muted);}
.field input:focus,
.field textarea:focus{
  outline:none;border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(38,132,255,0.14);
}
.field textarea{resize:vertical;min-height:130px;}
.modal-actions{
  display:flex;gap:10px;margin-top:24px;justify-content:flex-end;align-items:center;
}
.modal-actions .btn{padding:12px 22px;font-size:14.5px;}
.modal-actions .send-hint{
  font-size:12px;color:var(--text-muted);margin-right:auto;line-height:1.4;max-width:200px;
}
@media (max-width:560px){
  .modal-actions{flex-direction:column-reverse;gap:10px;}
  .modal-actions .btn{width:100%;justify-content:center;}
  .modal-actions .send-hint{margin:0;text-align:center;max-width:none;}
}
/* Success state */
.modal-success{
  display:none;padding:20px 0 10px;text-align:center;
}
.modal.sent .modal-success{display:block;}
.modal-success .icon{
  width:56px;height:56px;margin:0 auto 18px;border-radius:50%;
  background:rgba(38,132,255,.12);border:1px solid rgba(38,132,255,.25);
  display:grid;place-items:center;color:var(--blue-2);
  animation:pop .4s var(--ease) both;
}
@keyframes pop{from{transform:scale(.4);opacity:0;}}
.modal-success .icon svg{width:26px;height:26px;}
.modal-success h4{font-size:20px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-0.02em;}
.modal-success p{font-size:14.5px;color:var(--text-dim);line-height:1.55;max-width:360px;margin:0 auto 20px;}
body.modal-open{overflow:hidden;}

/* ---------- BACK TO TOP ---------- */
.to-top{
  position:fixed;right:24px;bottom:24px;z-index:90;
  width:46px;height:46px;border-radius:50%;
  background:var(--text);color:#fff;
  display:grid;place-items:center;
  border:1px solid var(--text);
  box-shadow:0 8px 24px rgba(9,15,30,.18), 0 2px 6px rgba(9,15,30,.08);
  cursor:pointer;
  opacity:0;pointer-events:none;transform:translateY(10px) scale(.9);
  transition:opacity .25s var(--ease), transform .25s var(--ease), background .2s var(--ease);
}
.to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);}
.to-top:hover{background:var(--blue-2);border-color:var(--blue-2);}
.to-top svg{width:18px;height:18px;stroke-width:2.6;}
@media (max-width:560px){
  .to-top{right:16px;bottom:16px;width:42px;height:42px;}
}

/* ---------- MOBILE MENU ---------- */
.mobile-menu{
  position:fixed;inset:0;z-index:99;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:32px;opacity:0;pointer-events:none;transition:opacity .3s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto;}
.mobile-menu a{font-size:22px;font-weight:500;color:var(--text);transition:color .2s var(--ease), transform .2s var(--ease);}
.mobile-menu a:hover{color:var(--blue);transform:translateX(4px);}
.mobile-menu a.active{
  color:var(--blue);font-weight:700;
  position:relative;padding-left:14px;
}
.mobile-menu a.active::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:4px;height:22px;border-radius:2px;
  background:linear-gradient(180deg, var(--blue) 0%, var(--blue-2) 100%);
}
.mobile-menu .nav-link-soon{font-size:22px;font-weight:500;color:var(--text-muted);}
.mobile-menu .nav-link-soon .soon-badge{font-size:11px;}
.mobile-menu .btn{margin-top:12px;}

/* ---------- HOME PAGE : PATH CARDS ---------- */
.paths{padding:60px 0 120px;}
.paths-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:28px;
}
@media (max-width:860px){.paths-grid{grid-template-columns:1fr;}}
.path-card{
  position:relative;overflow:hidden;
  padding:clamp(32px,4vw,48px);
  border-radius:24px;
  background:#fff;border:1px solid var(--line);
  transition:transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease);
  box-shadow:0 1px 2px rgba(9,15,30,.03);
  display:flex;flex-direction:column;
}
.path-card:hover{
  transform:translateY(-4px);
  border-color:rgba(38,132,255,.35);
  box-shadow:0 24px 48px -20px rgba(9,15,30,.18);
}
.path-card .path-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:18px;
}
.path-card h3{
  font-size:clamp(26px,2.6vw,34px);font-weight:700;
  letter-spacing:-0.025em;color:var(--text);line-height:1.1;
}
.path-card .soon-badge{
  font-size:10px;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--blue-2);background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.22);
  padding:4px 9px;border-radius:5px;
  line-height:1;white-space:nowrap;
}
.path-card .path-tag{
  font-size:13px;color:var(--blue-2);font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;
}
.path-card p{
  font-size:15.5px;color:var(--text-dim);line-height:1.6;margin-bottom:22px;
}
.path-card ul{
  list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:28px;
}
.path-card ul li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14px;color:var(--text-dim);line-height:1.5;
}
.path-card ul li svg{
  flex-shrink:0;margin-top:4px;width:14px;height:14px;color:var(--blue-2);
}
.path-card .path-cta{margin-top:auto;}
.path-card.path-card--muted{
  background:var(--bg-2);
}
.path-card.path-card--muted .path-tag{color:var(--text-muted);}

/* ---------- COMING SOON HERO ---------- */
.soon-hero{
  position:relative;min-height:100vh;
  padding:160px 0 100px;
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;isolation:isolate;
}
.soon-hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(900px 500px at 50% 20%, rgba(38,132,255,0.14), transparent 60%),
    radial-gradient(700px 400px at 50% 90%, rgba(0,82,204,0.08), transparent 60%);
}
.soon-hero::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(9,15,30,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(9,15,30,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center, #000 35%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 35%, transparent 75%);
}
.soon-hero .soon-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  background:var(--blue-tint);color:var(--blue-2);
  font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid rgba(38,132,255,.25);margin-bottom:24px;
}
.soon-hero .soon-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--blue);}
.soon-hero h1{
  font-size:clamp(40px,6.5vw,80px);
  line-height:1.04;letter-spacing:-0.035em;font-weight:800;
  max-width:840px;margin:0 auto 24px;
}
.soon-hero h1 .accent{
  background:linear-gradient(135deg, #2684FF 0%, #0052CC 60%, #0747A6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.soon-hero p.lead{
  font-size:clamp(17px,1.3vw,20px);color:var(--text-dim);
  max-width:620px;margin:0 auto 36px;line-height:1.6;
}

/* ---------- BEFORE / AFTER SLIDER ---------- */
.ba-slider{
  --pos:50%;
  position:relative;
  display:grid;
  user-select:none;-webkit-user-select:none;
  touch-action:none;outline:none;
  border-radius:20px;
}
.ba-slider:focus-visible{box-shadow:0 0 0 3px rgba(38,132,255,.28);}
.ba-panel{
  grid-area:1 / 1;min-width:0;
}
.ba-panel .panel-card{
  transform:none;
  transition:none;
}
.ba-after{z-index:1;}
.ba-before{
  z-index:2;
  clip-path:inset(0 calc(100% - var(--pos)) 0 0);
  -webkit-clip-path:inset(0 calc(100% - var(--pos)) 0 0);
}

/* Corner labels */
.ba-label{
  position:absolute;top:14px;z-index:5;
  padding:5px 10px;border-radius:999px;
  font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  line-height:1;pointer-events:none;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:.92;
}
.ba-label--before{
  left:14px;
  background:rgba(255,70,90,.18);color:#FFA7B4;
  border:1px solid rgba(255,120,140,.35);
}
.ba-label--after{
  right:14px;
  background:rgba(76,220,140,.14);color:#78E8A8;
  border:1px solid rgba(76,220,140,.32);
}

/* Divider handle */
.ba-divider{
  position:absolute;top:0;bottom:0;left:var(--pos);
  width:2px;z-index:6;
  transform:translateX(-50%);
  pointer-events:none;
}
.ba-line{
  position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(255,255,255,.1) 0%,
    rgba(255,255,255,.9) 18%,
    rgba(255,255,255,.9) 82%,
    rgba(255,255,255,.1) 100%);
  box-shadow:0 0 14px rgba(38,132,255,.5);
}
.ba-grip{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);
  color:#fff;
  border:2px solid rgba(255,255,255,.95);
  box-shadow:0 10px 28px rgba(9,15,30,.35), 0 0 0 4px rgba(38,132,255,.22), inset 0 1px 0 rgba(255,255,255,.35);
  display:flex;align-items:center;justify-content:center;gap:1px;
  cursor:ew-resize;pointer-events:auto;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.ba-grip:hover,.ba-grip:focus-visible{
  transform:translate(-50%,-50%) scale(1.08);
  box-shadow:0 14px 32px rgba(9,15,30,.4), 0 0 0 6px rgba(38,132,255,.25), inset 0 1px 0 rgba(255,255,255,.4);
  outline:none;
}
.ba-grip svg{width:14px;height:14px;}
.ba-slider.dragging .ba-grip{transform:translate(-50%,-50%) scale(1.12);}
.ba-slider.dragging{cursor:ew-resize;}

/* Disable hover-tilt when the slider is present */
.hero-visual:hover .ba-slider .panel-card{transform:none;}

/* BAD panel variant (red accents) */
.panel-card--bad{
  background:linear-gradient(180deg, #2A0F1A 0%, #1A0810 100%);
  border:1px solid rgba(255,80,100,0.08);
}
.panel-card--bad::after{
  background:linear-gradient(135deg, rgba(255,80,100,.12) 0%, transparent 50%);
}
.panel-card--bad .indicator{
  background:rgba(255,70,90,0.08);
  border:1px solid rgba(255,70,90,0.18);
  color:#E8D4D8;
}
.panel-card--bad .indicator svg{color:#FF6B80;}
.panel-card--bad .indicator b{color:#FFE3E8;}
.panel-card--bad .indicator--bad svg{color:#FF6B80;}
.panel-card--bad .stat-block{border-color:rgba(255,80,100,.06);}
.panel-card--bad .chart-wrap{border-color:rgba(255,80,100,.06);}
.arrow-up-red{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,70,90,.14);border:1px solid rgba(255,70,90,.22);
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
}
.arrow-up-red svg{width:22px;height:22px;color:#FF6B80;}
.current-value--bad{color:#FF8A9A !important;}
/* Match the dimensions of .improvement exactly so stacked panels align row-for-row */
.improvement--bad{
  margin-top:12px;display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;color:#FF6B80;letter-spacing:.02em;
}
.improvement--bad svg{width:10px;height:10px;color:#FF6B80;}
.improvement--bad .sub{color:#9B6B75;font-weight:500;}
.bars--bad .bar .col{background:#5C1F2D;}
.bars--bad .bar.active .col{background:#FF4D66;}
.bars--bad .bar.active span{color:#FFDDE3;}
.panel-card--bad .check--bad{color:#FF6B80;}
.panel-card--bad .v--bad{color:#FF8A9A;}
.panel-card--bad .recent-context{
  background:rgba(255,70,90,0.05);
  border:1px solid rgba(255,70,90,0.12);
  color:#E8D4D8;
}
.panel-card--bad .recent-context b{color:#FFE3E8;}
.dot-red{width:5px;height:5px;border-radius:50%;background:#FF4D66;flex:0 0 auto;}

@media (max-width:620px){
  .ba-grip{width:38px;height:38px;}
  .ba-grip svg{width:12px;height:12px;}
  .ba-label{font-size:9px;padding:4px 8px;top:10px;}
  .ba-label--before{left:10px;}
  .ba-label--after{right:10px;}
}

/* ---------- COMPACT PAGE (consulting) ---------- */
.page-consulting section.block{padding:72px 0;}
@media (max-width:760px){.page-consulting section.block{padding:52px 0;}}
.page-consulting .section-head{margin:0 auto 40px;max-width:720px;}
.page-consulting .section-head h2{font-size:clamp(28px,3.6vw,40px);margin-bottom:8px;}
.page-consulting .section-head p{font-size:14.5px;}
.page-consulting .caps-grid{gap:18px;}
.page-consulting .cap{padding:28px 28px 36px;}
.page-consulting .cap-icon{width:38px;height:38px;margin-bottom:6px;}
.page-consulting .cap-icon svg{width:18px;height:18px;}
.page-consulting .cap h3{font-size:17.5px;}
.page-consulting .cap-accent{left:28px;right:28px;bottom:20px;}
.page-consulting .cap-focus-pill{top:18px;right:18px;font-size:9.5px;padding:3px 8px;}
.page-consulting .steps{gap:18px;}
.page-consulting .step{padding:26px 24px;}
.page-consulting .step-num{width:48px;height:48px;font-size:18px;margin-bottom:16px;}
.page-consulting .step h3{font-size:17.5px;margin-bottom:8px;}
.page-consulting .audience-grid{gap:12px;}
.page-consulting .audience-card{height:168px;}
.page-consulting .audience-icon{width:40px;height:40px;margin-bottom:12px;}
.page-consulting .audience-icon svg{width:20px;height:20px;}
.page-consulting .audience-card h4{font-size:15.5px;}
.page-consulting .cta-final{padding:76px 0 64px;}
.page-consulting .cta-final h2{font-size:clamp(30px,4.2vw,50px);margin-bottom:14px;}
.page-consulting .cta-final p{font-size:16px;margin-bottom:12px;}

/* Shorter slim hero when on compact consulting page */
.page-consulting .hero.hero-slim{padding:130px 0 56px;}
@media (max-width:720px){.page-consulting .hero.hero-slim{padding:115px 0 40px;}}

/* ---------- SLIM HERO (consulting page) ---------- */
.hero.hero-slim{
  min-height:auto;
  padding:160px 0 90px;
  display:block;
}
.hero.hero-slim .hero-slim-inner{
  max-width:820px;margin:0 auto;text-align:center;
}
.hero.hero-slim .section-tag{margin-bottom:22px;}
.hero.hero-slim h1.display{
  font-size:clamp(38px,5.4vw,64px);
  line-height:1.05;letter-spacing:-0.035em;font-weight:800;
  margin-bottom:22px;
}
.hero.hero-slim p.lead{
  font-size:clamp(17px,1.25vw,19px);color:var(--text-dim);
  max-width:640px;margin:0 auto 32px;line-height:1.65;
}
.hero.hero-slim .cta-row{justify-content:center;}
@media (max-width:720px){
  .hero.hero-slim{padding:130px 0 70px;}
}
.soon-hero .cta-row{justify-content:center;}

/* =========================================================
   PAYMENT TRUST STRIP - Apple-style: no container, monochromatic
   marks, refined typography, restrained color
   ========================================================= */
.payment-trust{
  margin-top:24px;
  display:flex;flex-direction:column;align-items:center;
  gap:14px;
}
.payment-trust .trust-line{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12.5px;font-weight:400;letter-spacing:-0.005em;
  color:var(--text-muted);
}
.payment-trust .trust-line .lock-icon{
  width:11px;height:11px;color:var(--text-muted);
  stroke-width:1.7;flex:none;
}
.payment-trust .trust-line strong{
  color:var(--text);font-weight:500;letter-spacing:-0.01em;
}
.payment-trust .trust-marks{
  display:inline-flex;align-items:center;gap:24px;
}
.trust-mark{
  display:inline-flex;align-items:center;line-height:1;
  color:#6E6E73;
  transition:color .25s var(--ease), transform .25s var(--ease);
}
.trust-mark:hover{color:var(--text);transform:translateY(-1px);}
.trust-mark--visa{
  font-size:13px;font-weight:900;font-style:italic;letter-spacing:0.04em;
}
.trust-mark--mc svg{
  width:26px;height:16px;fill:currentColor;display:block;
}
.trust-mark--amex{
  font-size:11px;font-weight:800;letter-spacing:0.14em;
}
.trust-mark--applepay{gap:3px;}
.trust-mark--applepay svg{width:11px;height:13px;fill:currentColor;display:block;}
.trust-mark--applepay .pay-text{
  font-size:12px;font-weight:600;font-style:italic;letter-spacing:-0.02em;
}

/* Slightly tighter inside the home hero column */
.hero-actions .payment-trust{margin-top:18px;gap:11px;}
.hero-actions .payment-trust .trust-line{font-size:12px;}
.hero-actions .payment-trust .trust-marks{gap:22px;}

@media (max-width:520px){
  .payment-trust .trust-marks{gap:20px;}
  .payment-trust .trust-line{font-size:12px;}
}

/* =========================================================
   ABOUT PAGE
   ========================================================= */

/* Mission - centered prose block */
.mission .mission-inner{
  max-width:820px;margin:0 auto;text-align:center;
}
.mission .mission-inner .section-tag{margin-bottom:20px;}
.mission .mission-inner h2{
  font-size:clamp(28px,3.8vw,42px);
  line-height:1.15;letter-spacing:-0.02em;font-weight:700;
  margin-bottom:22px;
}
.mission .mission-inner .lead-callout{
  font-size:clamp(18px,1.4vw,21px);
  line-height:1.55;color:var(--text);font-weight:600;
  letter-spacing:-0.015em;
  padding:22px 0;margin:6px 0 24px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;
}
.mission .mission-inner .lead-callout::before{
  content:"";
  position:absolute;left:50%;top:-1px;transform:translateX(-50%);
  width:60px;height:2px;
  background:linear-gradient(90deg, var(--blue) 0%, var(--blue-2) 100%);
  border-radius:2px;
}
.mission .mission-inner p:not(.lead-callout){
  font-size:17px;line-height:1.75;color:var(--text-dim);
  max-width:680px;margin:0 auto;
}

/* 4-up principles grid - tightens the caps-grid from 3 to 4 columns on desktop */
.caps-grid--four{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
@media (max-width:1100px){.caps-grid--four{grid-template-columns:repeat(2, 1fr);}}
@media (max-width:620px){.caps-grid--four{grid-template-columns:1fr;}}

/* Credentials grid */
.credentials .cred-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));
  gap:16px;
  max-width:1100px;margin:0 auto;
}
.cred-card{
  position:relative;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:14px;
  padding:24px 22px 22px;
  overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
  cursor:default;
}
.cred-card::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%), rgba(38,132,255,.10), transparent 60%);
  opacity:0;transition:opacity .3s var(--ease);
  pointer-events:none;
}
.cred-card:hover,
.cred-card:focus-visible{
  transform:translateY(-3px);
  border-color:rgba(38,132,255,.35);
  box-shadow:0 18px 38px -20px rgba(38,132,255,.28);
  outline:none;
}
.cred-card:hover::before,
.cred-card:focus-visible::before{opacity:1;}
.cred-code{
  display:inline-flex;align-items:center;gap:7px;
  font-size:10.5px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--blue-2);background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.22);
  padding:5px 10px;border-radius:999px;line-height:1;
  margin-bottom:16px;
  position:relative;z-index:1;
}
.cred-code .cred-dot{
  width:5px;height:5px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 8px rgba(38,132,255,.6);
  animation:credPulse 2.4s ease-in-out infinite;
}
@keyframes credPulse{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:.5;transform:scale(1.15);}
}
.cred-card h4{
  font-size:16.5px;font-weight:600;margin:0 0 6px;
  letter-spacing:-0.01em;color:var(--text);
  position:relative;z-index:1;
}
.cred-card .cred-full{
  font-size:13.5px;line-height:1.6;color:var(--text-muted);
  margin:0;position:relative;z-index:1;
}

/* Page-scoped compression for About - keeps scroll tight */
.page-about section.block{padding:80px 0;}
@media (max-width:760px){.page-about section.block{padding:56px 0;}}
.page-about .section-head{margin:0 auto 44px;max-width:720px;}
.page-about .section-head h2{font-size:clamp(28px,3.6vw,40px);margin-bottom:8px;}
.page-about .section-head p{font-size:14.5px;}
.page-about .cap{padding:22px 22px 20px;}
.page-about .cap-icon{width:40px;height:40px;margin-bottom:14px;}
.page-about .cap-icon svg{width:20px;height:20px;}
.page-about .cap h3{font-size:16.5px;}
.page-about .cap p{font-size:13.5px;}
.page-about .cta-final{padding:76px 0 64px;}
.page-about .cta-final h2{font-size:clamp(30px,4.2vw,50px);margin-bottom:14px;}
.page-about .cta-final p{font-size:16px;margin-bottom:12px;}
.page-about .hero.hero-slim{padding:130px 0 56px;}
@media (max-width:720px){.page-about .hero.hero-slim{padding:115px 0 40px;}}

/* =========================================================
   ABOUT - SINGLE-VIEWPORT LAYOUT
   Collapses hero + philosophy + paths into one screen.
   ========================================================= */
.about-single{
  min-height:100vh;
  padding:120px 0 60px;
  display:flex;align-items:center;
  position:relative;isolation:isolate;overflow:hidden;
}
.about-single::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 650px at 15% 0%, rgba(38,132,255,0.11), transparent 60%),
    radial-gradient(900px 600px at 95% 100%, rgba(0,82,204,0.08), transparent 60%);
}
.about-single::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(9,15,30,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(9,15,30,.04) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center, #000 40%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 40%, transparent 75%);
}
.about-single .container{width:100%;}
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
@media (max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:44px;}
  .about-single{padding:110px 0 60px;}
}
.about-intro .section-tag{margin-bottom:18px;}
.about-intro h1{
  font-size:clamp(34px,4.4vw,54px);
  line-height:1.05;letter-spacing:-0.03em;font-weight:800;
  margin-bottom:20px;
}
.about-intro h1 .accent{
  background:linear-gradient(135deg, #2684FF 0%, #0052CC 60%, #0747A6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.about-intro p.lead{
  font-size:clamp(15.5px,1.15vw,17px);
  color:var(--text-dim);line-height:1.65;margin-bottom:16px;
}
.about-intro p.lead strong{color:var(--text);font-weight:600;}
/* Brand signature at the bottom of the about intro - large brand mark as a visual anchor */
.about-signature{
  display:flex;align-items:center;gap:18px;
  margin:28px 0 0;padding-top:22px;
  border-top:1px solid var(--line);
}
.brand--signature{
  display:inline-flex;align-items:center;gap:14px;
  flex-shrink:0;
}
.brand--signature .brand-h{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:800;font-size:30px;letter-spacing:-0.02em;
  color:var(--text);line-height:1;
  background:linear-gradient(135deg, var(--text) 0%, #2D3548 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.brand--signature .brand-divider{
  width:1px;height:24px;background:var(--line-strong);display:inline-block;
}
.brand--signature .brand-sub{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:300;font-size:13px;letter-spacing:0.28em;
  color:var(--text-muted);line-height:1;text-transform:uppercase;
}
.about-signature-line{
  flex:1;height:1px;
  background:linear-gradient(90deg, var(--line) 0%, transparent 100%);
}
@media (max-width:640px){
  .about-signature{gap:12px;margin-top:22px;padding-top:18px;}
  .brand--signature .brand-h{font-size:24px;}
  .brand--signature .brand-divider{height:19px;}
  .brand--signature .brand-sub{font-size:11px;letter-spacing:0.24em;}
}

.about-aside{
  display:flex;flex-direction:column;gap:18px;
}
.about-card{
  position:relative;overflow:hidden;
  padding:26px 26px 24px;
  border-radius:18px;
  background:#fff;border:1px solid var(--line);
  box-shadow:0 1px 2px rgba(9,15,30,.03);
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
  display:block;color:inherit;text-decoration:none;
}
.about-card:hover{
  transform:translateY(-3px);
  border-color:rgba(38,132,255,.35);
  box-shadow:0 20px 40px -20px rgba(9,15,30,.14);
}
.about-card-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:10px;
}
.about-card-tag{
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue-2);
}
.about-card .soon-badge{
  font-size:9.5px;font-weight:700;letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--blue-2);background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.22);
  padding:3px 7px;border-radius:4px;line-height:1;
}
.about-card h3{
  font-size:20px;font-weight:700;letter-spacing:-0.02em;color:var(--text);
  margin-bottom:6px;line-height:1.15;
}
.about-card p{
  font-size:14px;color:var(--text-dim);line-height:1.55;margin-bottom:12px;
}
.about-card-arrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13.5px;font-weight:600;color:var(--blue-2);
  transition:gap .25s var(--ease);
}
.about-card:hover .about-card-arrow{gap:10px;}
.about-card-arrow svg{width:14px;height:14px;}
.about-card.about-card--muted{background:var(--bg-2);}
.about-card.about-card--muted .about-card-tag{color:var(--text-muted);}

/* =========================================================
   MONTHLY RETAINER PRICING CARD - modernized
   Linear / Stripe inspired: Flagship pill, big price anchor,
   2-column feature grid with title + one-liner, integrated
   trust footer bar inside the card
   ========================================================= */
.retainer-card{
  max-width:640px;margin:24px auto 32px;
  padding:0;border-radius:22px;
  background:#fff;border:1px solid var(--line);
  box-shadow:
    0 1px 2px rgba(9,15,30,.03),
    0 30px 60px -30px rgba(9,15,30,.14);
  text-align:left;position:relative;overflow:hidden;
}
.retainer-card::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(600px 260px at 0% -10%, rgba(38,132,255,.08), transparent 55%),
    radial-gradient(500px 240px at 100% 0%, rgba(0,82,204,.06), transparent 60%);
}

.retainer-top{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
  padding:22px 28px 0;
}
.retainer-badge{
  display:inline-flex;align-items:center;gap:7px;
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue-2);background:var(--blue-tint);
  border:1px solid rgba(38,132,255,.22);
  padding:5px 11px;border-radius:999px;line-height:1;
}
.retainer-badge-dot{
  width:5px;height:5px;border-radius:50%;background:var(--blue);
  box-shadow:0 0 0 3px rgba(38,132,255,.18);
}
.retainer-meta{
  font-size:12px;color:var(--text-muted);letter-spacing:-0.005em;font-weight:500;
}

.retainer-price-block{
  position:relative;
  padding:20px 28px 22px;
  border-bottom:1px solid var(--line);
}
.retainer-label{
  display:block;
  font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:10px;
}
.retainer-price-row{
  display:flex;align-items:baseline;gap:8px;
}
.retainer-price{
  display:inline-flex;align-items:baseline;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  font-variant-numeric:tabular-nums;
  color:var(--text);line-height:.95;
}
.retainer-currency{
  font-size:28px;font-weight:600;letter-spacing:-0.01em;
  color:var(--text-dim);margin-right:2px;
  transform:translateY(-6px);
}
.retainer-amount{
  font-size:56px;font-weight:800;letter-spacing:-0.035em;
  background:linear-gradient(180deg, var(--text) 0%, #1F2633 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.retainer-per{
  font-size:15px;font-weight:500;color:var(--text-muted);
  letter-spacing:-0.005em;
}

.retainer-features{
  list-style:none;margin:0;
  padding:22px 28px 24px;
  display:grid;grid-template-columns:1fr 1fr;gap:16px 24px;
}
.retainer-features li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14px;color:var(--text-dim);line-height:1.5;
}
.retainer-features li .retainer-check{
  flex-shrink:0;margin-top:2px;width:16px;height:16px;
  color:var(--blue-2);padding:2px;
  border-radius:999px;background:var(--blue-tint);
  box-sizing:border-box;
}
.retainer-features li > div{display:flex;flex-direction:column;gap:2px;}
.retainer-features li strong{
  color:var(--text);font-weight:600;font-size:14.5px;letter-spacing:-0.005em;
}
.retainer-features li span{
  color:var(--text-muted);font-size:13px;line-height:1.5;
}

.retainer-foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;flex-wrap:wrap;
  padding:14px 28px;
  background:var(--bg-2);
  border-top:1px solid var(--line);
}
.retainer-foot-line{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12.5px;color:var(--text-muted);font-weight:500;letter-spacing:-0.005em;
}
.retainer-foot-line .lock-icon{
  width:12px;height:12px;color:var(--text-muted);stroke-width:1.8;flex:none;
}
.retainer-foot-line strong{color:var(--text);font-weight:600;letter-spacing:-0.01em;}
.retainer-foot-marks{
  display:inline-flex;align-items:center;gap:18px;
}
.retainer-foot-marks .trust-mark{
  color:#8A92A0;
}

@media (max-width:600px){
  .retainer-card{max-width:100%;}
  .retainer-top{padding:18px 20px 0;}
  .retainer-price-block{padding:16px 20px 18px;}
  .retainer-features{padding:18px 20px 20px;grid-template-columns:1fr;gap:14px;}
  .retainer-foot{padding:12px 20px;flex-direction:column;align-items:flex-start;gap:10px;}
  .retainer-amount{font-size:44px;}
  .retainer-currency{font-size:22px;transform:translateY(-4px);}
}
