/* Kutlama Atolye :: design system */

:root{
  --bg:#fbf7f1;
  --bg-soft:#f5ecde;
  --bg-dark:#1b1224;
  --ink:#1a1329;
  --ink-soft:#3f3253;
  --ink-mute:#665973;
  --brand:#6a1b4d;
  --brand-dark:#4d1138;
  --brand-soft:#8a3a6f;
  --accent:#c29047;
  --accent-deep:#9e732e;
  --accent-soft:#e3c487;
  --line:#e6dcc8;
  --line-strong:#cfbf9f;
  --card:#ffffff;
  --danger:#a02534;
  --danger-bg:#fbe7ea;
  --success:#1e6b47;
  --success-bg:#e5f2ec;
  --info-bg:#f3ecde;
  --focus:#c29047;

  --header-h:72px;
  --scrollbar-w:0px;

  --radius-sm:6px;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(26,19,41,.06),0 2px 6px rgba(26,19,41,.04);
  --shadow:0 8px 24px rgba(26,19,41,.08),0 2px 6px rgba(26,19,41,.05);
  --shadow-lg:0 24px 60px rgba(26,19,41,.14);

  --container:1180px;
  --container-narrow:880px;

  --s-1:4px;
  --s-2:8px;
  --s-3:12px;
  --s-4:16px;
  --s-5:24px;
  --s-6:32px;
  --s-7:48px;
  --s-8:64px;
  --s-9:96px;

  --font-ui:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-display:Georgia,"Times New Roman",Cambria,serif;

  --ease-smooth:cubic-bezier(.2,.7,.2,1);
  --ease-warm:cubic-bezier(.33,1.2,.3,1);
  --ease-out:cubic-bezier(.22,.7,.2,1);
  --ease-silk:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;max-width:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-ui);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
  max-width:100%;
}

img,svg,video{display:block;max-width:100%;height:auto}
a{color:var(--brand)}
a:hover{text-decoration:underline;text-underline-offset:3px}

:focus{outline:none}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:4px}

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ink);
  letter-spacing:-.01em;
  line-height:1.2;
  margin:0 0 var(--s-4);
  font-weight:600;
}
h1{font-size:clamp(2rem,4.2vw,3.2rem)}
h2{font-size:clamp(1.6rem,3vw,2.25rem)}
h3{font-size:clamp(1.15rem,1.7vw,1.35rem)}
h4{font-size:1rem;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute)}
p{margin:0 0 var(--s-4)}
small{font-size:.875rem;color:var(--ink-mute)}

/* Scroll offset for anchor links under sticky header */
section[id],article[id],div[id^="bolum-"]{scroll-margin-top:calc(var(--header-h) + 16px)}

/* Fieldset reset */
fieldset{margin:0;padding:0;border:0;min-inline-size:0}
legend{padding:0}

/* Container */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--s-5)}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 var(--s-5)}
@media (max-width:960px){
  .site-header .container{padding-inline:1.25rem}
}

/* Skip link */
.skip-link{
  position:absolute;top:var(--s-4);left:var(--s-4);z-index:1200;
  background:var(--ink);color:#fff;
  padding:10px 16px;border-radius:var(--radius-sm);
  transform:translateY(calc(-100% - 24px));
  opacity:0;pointer-events:none;
  transition:transform 220ms var(--ease-smooth),opacity 200ms var(--ease-smooth);
  font-weight:500;font-size:.94rem;text-decoration:none;
}
.skip-link:focus,.skip-link:focus-visible{
  transform:translateY(0);opacity:1;pointer-events:auto;
}

/* Scroll lock */
body.is-locked{overflow:hidden;padding-right:var(--scrollbar-w)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:transparent;
  border-bottom:1px solid var(--line);
  isolation:isolate;
}
.site-header::before{
  content:"";position:absolute;inset:0;
  background:rgba(251,247,241,.9);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  backdrop-filter:saturate(140%) blur(10px);
  z-index:-1;pointer-events:none;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--s-5);min-height:var(--header-h);
}
.brand{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-size:1.2rem;color:var(--ink);font-weight:600;
  text-decoration:none;transition:transform 220ms var(--ease-smooth),color 220ms var(--ease-smooth);
}
.brand:hover{text-decoration:none;transform:translateY(-1px);color:var(--brand)}
.brand-mark{
  width:36px;height:36px;border-radius:50%;
  position:relative;
  background:radial-gradient(circle at 32% 30%,var(--accent-soft),var(--brand) 72%);
  box-shadow:inset 0 0 0 2px #fff,0 2px 8px rgba(106,27,77,.18);
  transition:transform 380ms var(--ease-warm),box-shadow 380ms var(--ease-smooth);
}
.brand-mark::after{
  content:"";position:absolute;inset:7px;border-radius:50%;
  background:radial-gradient(circle at 60% 40%,rgba(255,255,255,.9),rgba(255,255,255,0) 58%);
  pointer-events:none;
}
.brand:hover .brand-mark{
  transform:rotate(-10deg) scale(1.08);
  box-shadow:inset 0 0 0 2px #fff,0 8px 22px rgba(106,27,77,.35);
}

/* Desktop nav */
.nav{display:flex;align-items:center;gap:var(--s-5)}
.nav-list{
  display:flex;align-items:center;gap:var(--s-5);
  list-style:none;margin:0;padding:0;
}
@media (min-width:961px) and (max-width:1080px){
  .nav-list{gap:16px}
  .nav-list a{font-size:.9rem}
}
.nav-list a{
  color:var(--ink-soft);font-weight:500;font-size:.96rem;
  text-decoration:none;position:relative;padding:6px 0;display:inline-block;
  transition:color 220ms var(--ease-smooth);
}
.nav-list a::after{
  content:"";position:absolute;left:50%;right:50%;bottom:0;height:2px;
  background:var(--brand);border-radius:2px;
  transition:left 300ms var(--ease-smooth),right 300ms var(--ease-smooth);
}
.nav-list a:hover,
.nav-list a.is-active,
.nav-list a[aria-current="page"]{color:var(--brand);text-decoration:none}
.nav-list a:hover::after,
.nav-list a.is-active::after,
.nav-list a[aria-current="page"]::after{left:0;right:0}

/* Hamburger */
.nav-toggle{
  display:none;position:relative;z-index:60;
  width:44px;height:44px;padding:10px;
  background:transparent;border:1px solid var(--line-strong);
  border-radius:999px;cursor:pointer;
  transition:background-color 220ms var(--ease-smooth),border-color 220ms var(--ease-smooth),box-shadow 220ms var(--ease-smooth);
}
.nav-toggle .bar{
  display:block;width:20px;height:2px;margin:0 auto;
  background:var(--ink);border-radius:2px;
  transition:transform 340ms var(--ease-smooth),opacity 200ms var(--ease-smooth),background-color 220ms var(--ease-smooth);
}
.nav-toggle .bar:nth-child(1){transform:translateY(-5px)}
.nav-toggle .bar:nth-child(2){margin-top:3px;margin-bottom:3px}
.nav-toggle .bar:nth-child(3){transform:translateY(5px)}
.nav-toggle[aria-expanded="true"]{
  background:#fff;border-color:var(--accent);
  box-shadow:0 2px 8px rgba(194,144,71,.18);
}
.nav-toggle[aria-expanded="true"] .bar{background:var(--accent-deep)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

@media (max-width:960px){
  .nav-toggle{display:block}
  .brand,.nav-toggle{position:relative;z-index:62}
  .nav{
    position:fixed;inset:0;z-index:40;
    background:rgba(251,247,241,.98);
    -webkit-backdrop-filter:saturate(140%) blur(14px);
    backdrop-filter:saturate(140%) blur(14px);
    padding:calc(var(--header-h) + var(--s-5)) var(--s-5) var(--s-6);
    display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;
    opacity:0;pointer-events:none;
    transform:translateY(-8px);
    transition:opacity 280ms var(--ease-smooth),transform 280ms var(--ease-smooth);
    overflow-y:auto;overscroll-behavior:contain;
  }
  .nav.is-open{opacity:1;pointer-events:auto;transform:none}
  .nav-list{
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    gap:0;margin:0;padding:0;
  }
  .nav-list li{border-bottom:1px solid var(--line)}
  .nav-list a{
    display:block;padding:18px 4px;font-size:1.15rem;
    font-family:var(--font-display);color:var(--ink);
  }
  .nav-list a::after{display:none}
  .nav-list a.is-active,
  .nav-list a[aria-current="page"]{color:var(--brand)}
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:48px;padding:0 26px;border-radius:999px;
  font:inherit;font-weight:600;line-height:1;
  cursor:pointer;border:1px solid transparent;white-space:nowrap;
  text-decoration:none;position:relative;isolation:isolate;overflow:hidden;
  transition:color 260ms var(--ease-smooth),border-color 260ms var(--ease-smooth),transform 260ms var(--ease-smooth),box-shadow 260ms var(--ease-smooth);
  background:transparent;
}
.btn:hover{text-decoration:none}
.btn-sm{min-height:38px;padding:0 18px;font-size:.9rem}

.btn.btn-primary,
a.btn.btn-primary{
  background-color:var(--brand);
  background-image:linear-gradient(180deg,var(--brand-soft),var(--brand));
  color:#fff;
}
.btn.btn-primary::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background-image:linear-gradient(180deg,#a74a82,var(--brand-dark));
  opacity:0;pointer-events:none;z-index:-1;
  transition:opacity 320ms var(--ease-smooth);
}
.btn.btn-primary:hover::before,
.btn.btn-primary:focus-visible::before{opacity:1}
.btn.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:
    0 0 0 4px rgba(194,144,71,.25),
    0 14px 36px rgba(106,27,77,.35);
}

.btn.btn-strong,
a.btn.btn-strong{
  background-color:var(--ink);
  background-image:linear-gradient(180deg,#2b1e3a,var(--ink));
  color:#fff;
}
.btn.btn-strong::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background-image:linear-gradient(180deg,#3b2a4c,#1a1329);
  opacity:0;pointer-events:none;z-index:-1;
  transition:opacity 320ms var(--ease-smooth);
}
.btn.btn-strong:hover::before,
.btn.btn-strong:focus-visible::before{opacity:1}
.btn.btn-strong:hover{
  transform:translateY(-1px);
  box-shadow:
    0 0 0 4px rgba(255,255,255,.18),
    0 14px 36px rgba(26,19,41,.3);
}

.btn.btn-ghost{
  background:transparent;color:var(--ink);border-color:var(--line-strong);
}
.btn.btn-ghost:hover{
  border-color:var(--ink);background:var(--bg-soft);transform:translateY(-1px);
}

.btn-link{
  background:transparent;border:0;color:var(--brand);padding:0;
  font:inherit;font-weight:600;cursor:pointer;
  text-decoration:underline;text-underline-offset:3px;
}
.btn-link:hover{color:var(--brand-dark)}

@media (prefers-reduced-motion:reduce){
  .btn,.btn::before,.brand,.brand-mark{transition:none}
  .btn:hover{transform:none}
}

/* Hero */
.hero{
  position:relative;overflow:hidden;
  padding:var(--s-9) 0 var(--s-8);
  background:
    radial-gradient(1100px 420px at 80% -10%,rgba(194,144,71,.2),transparent 60%),
    radial-gradient(800px 380px at 10% 10%,rgba(106,27,77,.08),transparent 60%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%);
}
.hero-inner{position:relative;z-index:1}
.hero-grid{
  display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:var(--s-8);align-items:center;
}
.hero-kicker{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--line-strong);
  padding:6px 14px;border-radius:999px;
  font-size:.86rem;color:var(--ink-soft);margin-bottom:var(--s-5);
}
.hero-kicker .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--brand);box-shadow:0 0 10px rgba(106,27,77,.35);
}
.hero h1 span.hilite{
  background:linear-gradient(180deg,transparent 62%,rgba(194,144,71,.38) 62%);
  padding:0 .08em;
}
.hero-lead{font-size:1.12rem;color:var(--ink-soft);max-width:560px}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-top:var(--s-5)}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:var(--s-5);
  margin-top:var(--s-6);padding-top:var(--s-5);
  border-top:1px solid var(--line);color:var(--ink-mute);font-size:.92rem;
}
.hero-meta strong{color:var(--ink);font-family:var(--font-display);font-weight:600;display:block;font-size:1.4rem;margin-bottom:2px}

.hero-media{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#fff 0%,var(--bg-soft) 100%);
  border:1px solid var(--line);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.hero-media img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.02);
  transition:transform 800ms var(--ease-smooth),filter 800ms var(--ease-smooth);
}
.hero-media .sparkle{
  position:absolute;width:10px;height:10px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 18px var(--accent-soft);
  z-index:2;pointer-events:none;
}
.hero-media .sparkle.s1{top:14%;right:16%}
.hero-media .sparkle.s2{top:44%;right:52%;background:var(--brand-soft)}
.hero-media .sparkle.s3{top:70%;right:18%}

@keyframes ka-sparkle{0%,100%{transform:scale(.8);opacity:.55}50%{transform:scale(1.25);opacity:1}}
body.is-loaded .hero-media .sparkle{animation:ka-sparkle 3.4s infinite var(--ease-smooth)}
body.is-loaded .hero-media .sparkle.s1{animation-delay:.1s}
body.is-loaded .hero-media .sparkle.s2{animation-delay:.8s}
body.is-loaded .hero-media .sparkle.s3{animation-delay:1.4s}

@media (max-width:860px){
  .hero{padding:var(--s-7) 0 var(--s-7)}
  .hero-grid{grid-template-columns:minmax(0,1fr);gap:var(--s-6)}
  .hero-media{aspect-ratio:4/3;order:-1}
}

/* Intro bloom for hero */
body:not(.is-loaded) [data-intro]{opacity:0}
@keyframes ka-bloom{
  0%{opacity:0;transform:translateY(22px)}
  100%{opacity:1;transform:none}
}
body.is-loaded [data-intro]{animation:ka-bloom 1100ms var(--ease-silk) both}
body.is-loaded [data-intro="2"]{animation-delay:120ms}
body.is-loaded [data-intro="3"]{animation-delay:240ms}
body.is-loaded [data-intro="4"]{animation-delay:360ms}
body.is-loaded [data-intro="5"]{animation-delay:480ms}
body.is-loaded [data-intro="6"]{animation-delay:320ms}

/* Sections */
.section{padding:var(--s-9) 0;position:relative;overflow:hidden}
.section-tight{padding:var(--s-8) 0;position:relative;overflow:hidden}
.section-alt{background:var(--bg-soft)}
.section-head{max-width:720px;margin:0 auto var(--s-7);text-align:center;position:relative;z-index:1}
.section-head.left{margin-left:0;text-align:left}
.section-head .eyebrow{
  display:inline-block;font-size:.84rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand);margin-bottom:var(--s-3);font-weight:600;
}
.section-head p{color:var(--ink-soft)}
@media (max-width:640px){.section{padding:var(--s-7) 0}}

/* Feature grid */
.feature-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-5);
  position:relative;z-index:1;
}
.feature{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s-6);box-shadow:var(--shadow-sm);
  transition:transform 320ms var(--ease-smooth),box-shadow 320ms var(--ease-smooth),border-color 320ms var(--ease-smooth);
  min-width:0;
}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.feature h3{margin-bottom:var(--s-2)}
.feature p{color:var(--ink-soft);margin:0}
.feature .num{
  display:inline-block;font-family:var(--font-display);font-size:1.4rem;color:var(--brand);
  border-bottom:2px solid var(--accent-soft);padding-bottom:2px;margin-bottom:var(--s-3);
}
@media (prefers-reduced-motion:reduce){.feature{transition:none}.feature:hover{transform:none}}
@media (max-width:860px){.feature-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
@media (max-width:560px){.feature-grid{grid-template-columns:minmax(0,1fr)}}

/* Packages */
.packages{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-5);
  position:relative;z-index:1;
}
.package{
  position:relative;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:var(--s-6);
  display:flex;flex-direction:column;gap:var(--s-4);
  box-shadow:var(--shadow-sm);min-width:0;
}
.package.is-featured{
  border-color:var(--brand-soft);
  box-shadow:0 18px 48px rgba(106,27,77,.15);
  background:linear-gradient(180deg,#fff 0%,#fff9f2 100%);
}
.package .tag{
  position:absolute;top:-14px;right:20px;
  background:var(--brand);color:#fff;padding:6px 14px;border-radius:999px;
  font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
}
.package h3{margin-bottom:4px}
.package .range{font-family:var(--font-display);font-size:1.55rem;color:var(--ink);margin:0}
.package .range small{display:block;color:var(--ink-mute);font-size:.82rem;margin-top:2px;font-family:var(--font-ui)}
.package .desc{color:var(--ink-soft);margin:0}
.package ul{list-style:none;padding:0;margin:0 0 var(--s-4);border-top:1px solid var(--line);padding-top:var(--s-4)}
.package ul li{
  position:relative;padding:8px 0 8px 32px;color:var(--ink-soft);font-size:.96rem;
  border-bottom:1px dashed var(--line);
}
.package ul li:last-child{border-bottom:none}
/* Thematic marker (candle / confetti dot) */
.package ul li::before{
  content:"";position:absolute;left:6px;top:14px;
  width:10px;height:16px;border-radius:6px 6px 4px 4px;
  background:linear-gradient(180deg,var(--accent) 0%,var(--brand) 100%);
  box-shadow:inset 0 -2px 0 rgba(255,255,255,.2),0 4px 10px rgba(106,27,77,.22);
  transform-origin:center bottom;
  transition:transform 340ms var(--ease-warm),filter 340ms var(--ease-smooth);
}
.package ul li::after{
  content:"";position:absolute;left:8px;top:8px;
  width:6px;height:7px;border-radius:50% 50% 40% 40%;
  background:radial-gradient(circle at 40% 35%,#fff6d9 0%,var(--accent-soft) 60%,transparent 90%);
  transition:transform 340ms var(--ease-warm),filter 340ms var(--ease-smooth);
}
.package ul li:hover::before{transform:rotate(-6deg) scale(1.04);filter:saturate(1.2)}
.package ul li:hover::after{transform:translateY(-1px) scale(1.1)}
.package .btn{align-self:flex-start;margin-top:auto}
@media (max-width:860px){.packages{grid-template-columns:minmax(0,1fr);gap:var(--s-6)}}

/* Process timeline */
.process{
  position:relative;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:var(--s-4);
  list-style:none;padding:0;margin:0;z-index:1;
}
.process::before{
  content:"";position:absolute;left:0;right:0;top:28px;height:2px;
  background:linear-gradient(90deg,var(--accent-soft),var(--brand-soft));
}
.step{
  position:relative;padding:var(--s-5) var(--s-3) 0;text-align:left;min-width:0;
  overflow:visible;isolation:isolate;
}
.step::before{
  content:attr(data-num);
  position:absolute;top:-30px;right:-4px;
  font-family:var(--font-display);font-weight:700;line-height:.9;
  font-size:clamp(4.6rem,7.6vw,7.4rem);
  letter-spacing:-0.09em;
  color:transparent;
  background:linear-gradient(135deg,var(--accent-soft) 0%,var(--brand-soft) 55%,var(--brand) 100%);
  -webkit-background-clip:text;background-clip:text;
  opacity:.14;
  pointer-events:none;z-index:0;
  transform:rotate(-8deg);
  transition:opacity 520ms var(--ease-smooth),transform 720ms var(--ease-warm);
}
.step.is-active::before{opacity:.32;transform:rotate(-5deg) translateY(-3px) scale(1.06)}
.step .num{
  width:68px;height:68px;border-radius:50%;
  background:#fff;border:2.5px solid var(--brand);
  color:var(--brand);
  display:grid;place-items:center;
  font-family:var(--font-display);font-size:1.45rem;font-weight:700;
  letter-spacing:-0.02em;
  margin:0 0 var(--s-4);position:relative;z-index:2;
  transition:transform 440ms var(--ease-warm),
             background-color 360ms var(--ease-smooth),
             background-image 360ms var(--ease-smooth),
             color 360ms var(--ease-smooth),
             border-color 360ms var(--ease-smooth),
             box-shadow 520ms var(--ease-silk);
}
.step .num::after{
  content:"";position:absolute;inset:-7px;border-radius:50%;
  border:2px solid var(--brand);
  opacity:0;transform:scale(.9);pointer-events:none;
  transition:opacity 420ms var(--ease-smooth);
}
.step.is-active .num::after{opacity:.4;animation:ka-step-ring 2.4s ease-out infinite}
@keyframes ka-step-ring{
  0%  {transform:scale(1);opacity:.45}
  100%{transform:scale(1.6);opacity:0}
}
.step h3{font-size:1.02rem;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;position:relative;z-index:2}
.step p{font-size:.92rem;color:var(--ink-soft);margin:0;position:relative;z-index:2}

/* Staggered reveal of individual steps */
.process .step{opacity:0;transform:translateY(28px);transition:opacity 900ms var(--ease-silk),transform 900ms var(--ease-silk)}
.process.is-visible .step{opacity:1;transform:none}
.process.is-visible .step:nth-child(1){transition-delay:40ms}
.process.is-visible .step:nth-child(2){transition-delay:140ms}
.process.is-visible .step:nth-child(3){transition-delay:240ms}
.process.is-visible .step:nth-child(4){transition-delay:340ms}
.process.is-visible .step:nth-child(5){transition-delay:440ms}
.process.is-visible .step:nth-child(6){transition-delay:540ms}
/* Let only steps animate; keep parent list always visible */
ol.process[data-reveal]{opacity:1;transform:none;transition:none}
@media (max-width:1100px){
  .process{grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-6) var(--s-5)}
  .process::before{display:none}
  .step{padding:var(--s-5) var(--s-2) 0}
  .step::before{font-size:clamp(3.8rem,9vw,5.8rem);top:-22px}
}
@media (max-width:720px){
  .process{grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--s-5) var(--s-4)}
  .step{padding:var(--s-4) var(--s-2) 0}
  .step .num{width:58px;height:58px;font-size:1.2rem;margin-bottom:var(--s-3)}
  .step::before{font-size:clamp(3.2rem,14vw,5rem);top:-18px;right:0}
}
@media (max-width:460px){
  .process{grid-template-columns:minmax(0,1fr);gap:var(--s-5)}
  .step{padding:var(--s-3) 0 0}
  .step .num{width:54px;height:54px;font-size:1.12rem;margin-bottom:var(--s-2)}
  .step::before{font-size:4.4rem;top:-14px}
}

/* Calculator */
.calc{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:var(--s-7);display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:var(--s-7);
  box-shadow:var(--shadow);position:relative;z-index:1;
}
.calc fieldset{margin:0 0 var(--s-5)}
.calc legend{
  font-family:var(--font-ui);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink-mute);margin-bottom:var(--s-3);font-weight:600;
}
.calc .slider-wrap{display:flex;align-items:center;gap:var(--s-4)}
.calc input[type=range]{flex:1;accent-color:var(--brand);min-width:0}
.calc .slider-val{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);min-width:88px;text-align:right}
.pkg-opts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.pkg-opt{position:relative;min-width:0}
.pkg-opt input{position:absolute;opacity:0;pointer-events:none}
.pkg-opt label{
  display:block;padding:12px 10px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  text-align:center;cursor:pointer;font-weight:500;font-size:.94rem;
  transition:border-color 220ms var(--ease-smooth),background-color 220ms var(--ease-smooth),color 220ms var(--ease-smooth);
  background:#fff;min-height:44px;
}
.pkg-opt input:checked + label{border-color:var(--brand);background:rgba(106,27,77,.06);color:var(--brand)}
.pkg-opt input:focus-visible + label{outline:3px solid var(--focus);outline-offset:2px}

/* Switch toggle */
.switch{
  --sw-w:48px;--sw-h:28px;--sw-pad:3px;
  --sw-knob:calc(var(--sw-h) - var(--sw-pad) * 2);
  display:inline-flex;align-items:center;gap:12px;cursor:pointer;
  padding:10px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:#fff;width:100%;min-height:48px;
}
.switch-wrap{
  position:relative;display:inline-block;
  width:var(--sw-w);height:var(--sw-h);
  flex:0 0 var(--sw-w);
}
.switch-wrap input{
  position:absolute;inset:0;width:100%;height:100%;
  opacity:0;margin:0;cursor:pointer;z-index:2;
}
.switch-track{
  position:absolute;inset:0;border-radius:999px;background:#d4cfc4;
  transition:background-color 320ms var(--ease-smooth);
}
.switch-knob{
  position:absolute;top:var(--sw-pad);left:var(--sw-pad);
  width:var(--sw-knob);height:var(--sw-knob);
  border-radius:50%;background:#fff;
  box-shadow:0 1px 3px rgba(26,19,41,.2);
  pointer-events:none;z-index:1;
  transition:transform 360ms var(--ease-warm);
}
.switch-wrap input:checked ~ .switch-track{background:var(--brand)}
.switch-wrap input:checked ~ .switch-knob{transform:translateX(calc(var(--sw-w) - var(--sw-knob) - var(--sw-pad) * 2))}
.switch-label{flex:1;min-width:0;color:var(--ink-soft);font-size:.94rem;overflow-wrap:anywhere}

.calc-result{
  background:linear-gradient(180deg,var(--bg-soft),#fff);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s-6);display:flex;flex-direction:column;min-width:0;
}
.calc-result .eyebrow{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:var(--s-3)}
.calc-result .range{font-family:var(--font-display);font-size:2rem;line-height:1.2;margin:0 0 var(--s-3);color:var(--ink)}
.calc-result .note{font-size:.88rem;color:var(--ink-mute);margin:0 0 var(--s-5)}
.calc-result .btn{align-self:flex-start}
@media (max-width:860px){
  .calc{grid-template-columns:minmax(0,1fr);padding:var(--s-5)}
  .pkg-opts{grid-template-columns:minmax(0,1fr)}
}

/* Price ranges */
.prices{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--s-4);
  position:relative;z-index:1;
}
.price{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:var(--s-5);
  display:flex;flex-direction:column;gap:6px;min-width:0;
}
.price .label{font-size:.92rem;color:var(--ink-mute)}
.price .value{font-family:var(--font-display);font-size:1.4rem;color:var(--ink)}
.price .hint{font-size:.86rem;color:var(--ink-soft)}
@media (max-width:640px){.prices{grid-template-columns:minmax(0,1fr)}}

.disclaimer{
  margin-top:var(--s-5);padding:var(--s-4) var(--s-5);
  background:#fff;border:1px dashed var(--line-strong);border-radius:var(--radius-sm);
  color:var(--ink-soft);font-size:.92rem;position:relative;z-index:1;
}

/* FAQ (accordion) */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;
}
.faq-q{
  width:100%;text-align:left;
  padding:var(--s-4) var(--s-5);background:transparent;border:0;
  font:inherit;font-weight:600;color:var(--ink);cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:var(--s-4);
  min-height:48px;
}
.faq-icon{
  position:relative;width:14px;height:14px;flex-shrink:0;
}
.faq-icon::before,.faq-icon::after{
  content:"";position:absolute;background:var(--ink);
  top:50%;left:0;width:100%;height:2px;border-radius:2px;
  transform:translateY(-50%);
  transition:transform 320ms var(--ease-smooth),background-color 220ms var(--ease-smooth);
}
.faq-icon::after{transform:translateY(-50%) rotate(90deg)}
.faq-item.is-open .faq-q{color:var(--brand)}
.faq-item.is-open .faq-icon::before,
.faq-item.is-open .faq-icon::after{background:var(--brand)}
.faq-item.is-open .faq-icon::after{transform:translateY(-50%) scaleX(0)}

.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows 380ms var(--ease-smooth)}
.faq-a-inner{overflow:hidden;min-height:0}
.faq-a-inner .answer{padding:0 var(--s-5) var(--s-5);color:var(--ink-soft)}
.faq-a-inner .answer p{margin:0 0 var(--s-3)}
.faq-a-inner .answer p:last-child{margin:0}
.faq-item.is-open .faq-a{grid-template-rows:1fr}

/* CTA band */
.cta-band{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);
  color:#fff;padding:var(--s-8) 0;text-align:center;
}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.88);max-width:620px;margin:0 auto var(--s-5)}
.cta-band .btn.btn-primary,
.cta-band a.btn.btn-primary{
  background-color:#fff;background-image:linear-gradient(180deg,#fff,#fbf7f1);color:var(--brand);
}
.cta-band .btn.btn-primary::before{background-image:linear-gradient(180deg,#fff,#e8d9c3)}

/* Form */
.form-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:var(--s-7);box-shadow:var(--shadow);
}
.form-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--s-4)}
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field.full{grid-column:1 / -1}
.form .field > label,
.field > label{font-size:.92rem;color:var(--ink);font-weight:500}
.field .hint{font-size:.82rem;color:var(--ink-mute)}
.field input,.field textarea,.field select{
  font:inherit;padding:12px 14px;border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);
  background:#fff;color:var(--ink);min-width:0;
  transition:border-color 220ms var(--ease-smooth),box-shadow 220ms var(--ease-smooth);
}
.field input:focus,
.field textarea:focus,
.field select:focus,
.field input:focus-visible,
.field textarea:focus-visible,
.field select:focus-visible{
  outline:none;
  border-color:var(--brand);
  box-shadow:0 0 0 1px var(--brand);
}
.field textarea{min-height:140px;resize:vertical}
.consent{
  display:flex;gap:10px;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);
  margin:var(--s-3) 0;min-height:44px;padding:6px 0;
}
.consent input{margin-top:4px;accent-color:var(--brand);width:18px;height:18px;flex-shrink:0}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

.form-status{
  max-height:0;opacity:0;padding:0;overflow:hidden;transform:translateY(-4px);
  border-left:3px solid transparent;border-radius:var(--radius-sm);
  transition:max-height 320ms var(--ease-smooth),opacity 240ms var(--ease-smooth),padding 320ms var(--ease-smooth),transform 260ms var(--ease-smooth),background-color 220ms var(--ease-smooth),color 220ms var(--ease-smooth),border-color 220ms var(--ease-smooth);
  margin-top:var(--s-3);
}
.form-status:not(:empty){
  max-height:8em;opacity:1;transform:none;
  padding:var(--s-3) var(--s-4);
  background:var(--info-bg);color:var(--ink);border-left-color:var(--accent);
}
.form-status.is-ok{background:var(--success-bg);color:var(--success);border-left-color:var(--success)}
.form-status.is-err{background:var(--danger-bg);color:var(--danger);border-left-color:var(--danger)}

.form-aside{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s-6);
}
.form-aside h3{margin-top:0}
.form-aside ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.form-aside li{color:var(--ink-soft);font-size:.94rem;padding-left:24px;position:relative}
.form-aside li::before{
  content:"";position:absolute;left:0;top:7px;
  width:8px;height:12px;border-radius:4px 4px 3px 3px;
  background:linear-gradient(180deg,var(--accent),var(--brand));
}

.form-grid label:not(.consent):not(.switch){display:block}
.form-note{margin-top:var(--s-4);color:var(--ink-mute);font-size:.86rem}

@media (min-width:961px){.form-aside{position:sticky;top:calc(var(--header-h) + var(--s-4))}}
@media (max-width:640px){
  .form-card{padding:var(--s-5)}
  .form-grid{grid-template-columns:minmax(0,1fr)}
}

/* Contact layout */
.contact-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:var(--s-7)}
.contact-card{
  background:var(--bg-soft);border-radius:var(--radius-lg);padding:var(--s-6);
  border:1px solid var(--line);min-width:0;
}
.channels{display:grid;grid-template-columns:minmax(0,1fr);gap:var(--s-4);margin:0}
.channel{display:flex;align-items:flex-start;gap:14px;padding:var(--s-3) 0;border-bottom:1px solid var(--line);min-width:0}
.channel:last-child{border-bottom:none}
.channel-icon{
  flex:0 0 36px;width:36px;height:36px;border-radius:10px;
  background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--brand);
}
.channel-icon svg{width:18px;height:18px}
.channel > div{flex:1;min-width:0}
.channel dt{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px}
.channel dd{margin:0;color:var(--ink);font-weight:500;overflow-wrap:anywhere;word-break:break-word;max-width:100%}
.channel a{color:var(--ink);text-decoration:none}
.channel a:hover{color:var(--brand);text-decoration:underline}
@media (max-width:860px){.contact-grid{grid-template-columns:minmax(0,1fr)}}

/* Long-form pages */
.page-hero{
  padding:var(--s-7) 0 var(--s-6);
  border-bottom:1px solid var(--line);
  background:var(--bg-soft);
  position:relative;overflow:hidden;
}
.page-hero .eyebrow{
  display:inline-block;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand);font-weight:600;margin-bottom:var(--s-3);
}
.prose{max-width:780px;margin:0 auto;padding:var(--s-7) var(--s-5)}
.prose h2{margin-top:var(--s-7)}
.prose h3{margin-top:var(--s-5)}
.prose ul,.prose ol{padding-left:1.2rem;margin:0 0 var(--s-4);color:var(--ink-soft)}
.prose li{margin-bottom:8px}
.prose p{color:var(--ink-soft)}
.prose .lead{font-size:1.12rem;color:var(--ink);margin-bottom:var(--s-5)}
.prose a:not(.btn):not(.btn-link){
  color:var(--brand);text-decoration:none;
  background-image:linear-gradient(var(--brand),var(--brand));
  background-position:50% 100%;
  background-size:0% 1.5px;
  background-repeat:no-repeat;
  transition:background-size 320ms var(--ease-smooth),background-position 320ms var(--ease-smooth);
}
.prose a:not(.btn):not(.btn-link):hover{
  background-size:100% 1.5px;background-position:0% 100%;
}
.prose blockquote{
  border-left:3px solid var(--accent);padding:var(--s-3) var(--s-5);
  margin:var(--s-5) 0;background:var(--bg-soft);color:var(--ink-soft);font-style:italic;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.toc{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s-5);margin:0 0 var(--s-6);
}
.toc h4{margin-bottom:var(--s-3)}
.toc ol{margin:0;padding-left:1.2rem;color:var(--ink-soft)}
.toc li{margin-bottom:4px}

/* Sitemap card grid */
.sitemap-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-5);margin:0 0 var(--s-6);
  list-style:none;padding:0;
}
.sitemap-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s-5);display:flex;flex-direction:column;gap:8px;min-width:0;
  transition:transform 300ms var(--ease-smooth),box-shadow 300ms var(--ease-smooth),border-color 300ms var(--ease-smooth);
}
.sitemap-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.sitemap-card h3{margin:0;font-size:1.05rem}
.sitemap-card h3 a{color:var(--ink);text-decoration:none}
.sitemap-card h3 a:hover{color:var(--brand)}
.sitemap-card p{margin:0;font-size:.9rem;color:var(--ink-soft)}
.sitemap-group-title{
  font-family:var(--font-display);margin:var(--s-6) 0 var(--s-4);font-size:1.5rem;
}
@media (max-width:860px){.sitemap-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
@media (max-width:560px){.sitemap-grid{grid-template-columns:minmax(0,1fr)}}

/* 404 */
.nf{padding:var(--s-9) 0;text-align:center}
.nf .code{font-family:var(--font-display);font-size:clamp(4rem,12vw,7rem);color:var(--brand);margin:0;line-height:1}
.nf p{max-width:520px;margin:var(--s-3) auto var(--s-5);color:var(--ink-soft)}
.nf .actions{display:flex;gap:var(--s-3);justify-content:center;flex-wrap:wrap}

/* Footer */
.site-footer{
  background:var(--bg-dark);color:#dcd0b8;padding:var(--s-8) 0 var(--s-5);
  margin-top:0;
}
.site-footer a{color:#f0e2c5}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-grid{
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
  gap:var(--s-6);margin-bottom:var(--s-6);
}
.footer-grid > div{min-width:0}
.footer-grid h4{color:#fff;margin-bottom:var(--s-3)}
.footer-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:.94rem}
.footer-grid > div > .brand{color:#fff;margin-bottom:var(--s-3)}
.footer-grid > div > .brand:hover{color:#fff;text-decoration:none;transform:translateY(-1px)}
.footer-about{color:rgba(240,226,197,.78);font-size:.94rem;max-width:380px}
.footer-bottom{
  border-top:1px solid rgba(240,226,197,.18);padding-top:var(--s-4);
  text-align:center;font-size:.86rem;color:rgba(240,226,197,.65);
}
.footer-bottom p{margin:0}
@media (max-width:860px){.footer-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
@media (max-width:520px){.footer-grid{grid-template-columns:minmax(0,1fr)}}

/* Cookie banner */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:1000;
  background:#fff;border:1px solid var(--line-strong);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:var(--s-5);max-width:760px;margin:0 auto;
  opacity:0;transform:translateY(10px) scale(.98);
  transition:opacity 280ms var(--ease-smooth),transform 280ms var(--ease-smooth);
}
.cookie-banner[hidden]{display:none !important}
.cookie-banner.is-visible{opacity:1;transform:none}
.cookie-banner h3{margin:0 0 var(--s-2);font-size:1.1rem}
.cookie-banner p{margin:0 0 var(--s-4);color:var(--ink-soft);font-size:.94rem}
.cookie-actions{display:flex;flex-wrap:wrap;gap:10px}
.cookie-actions .btn{flex:1;min-width:150px}

.cookie-modal{
  position:fixed;inset:0;background:rgba(26,19,41,.55);z-index:1050;
  display:flex;align-items:center;justify-content:center;padding:16px;
  opacity:0;transform:scale(.98);
  transition:opacity 260ms var(--ease-smooth),transform 260ms var(--ease-smooth);
}
.cookie-modal[hidden]{display:none !important}
.cookie-modal.is-visible{opacity:1;transform:none}
.cookie-modal-inner{
  background:#fff;border-radius:var(--radius);max-width:560px;width:100%;
  padding:var(--s-6);box-shadow:var(--shadow-lg);max-height:90vh;overflow:auto;
}
.cookie-modal h3{margin-top:0}
.cookie-row{
  display:flex;justify-content:space-between;align-items:flex-start;gap:var(--s-4);
  padding:var(--s-4) 0;border-bottom:1px solid var(--line);
}
.cookie-row:last-of-type{border-bottom:none}
.cookie-row > div{flex:1;min-width:0}
.cookie-row h4{margin:0 0 4px;font-family:var(--font-display);font-size:1rem;color:var(--ink);text-transform:none;letter-spacing:0}
.cookie-row p{font-size:.88rem;color:var(--ink-soft);margin:0}
.cookie-modal-actions{
  display:flex;gap:10px;flex-wrap:wrap;margin-top:var(--s-5);justify-content:flex-end;
}

/* Reveal (scroll) */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 900ms var(--ease-silk),transform 1000ms var(--ease-silk)}
[data-reveal].is-visible{opacity:1;transform:none}

/* Utility */
.text-center{text-align:center}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* Cookie close (X) button */
.cookie-banner{padding-right:calc(var(--s-5) + 40px)}
.cookie-modal-inner{position:relative}
.cookie-close{
  position:absolute;top:8px;right:8px;z-index:2;
  width:36px;height:36px;padding:0;border-radius:50%;
  background:transparent;border:0;
  color:var(--ink-soft);cursor:pointer;
  display:grid;place-items:center;
  transition:background-color 180ms var(--ease-smooth),color 180ms var(--ease-smooth),transform 160ms var(--ease-smooth);
}
.cookie-close::before,
.cookie-close::after{
  content:"";grid-area:1/1;
  width:18px;height:2px;background:currentColor;border-radius:2px;
}
.cookie-close::before{transform:rotate(45deg)}
.cookie-close::after{transform:rotate(-45deg)}
.cookie-close:hover{background:var(--bg-soft);color:var(--ink)}
.cookie-close:active{transform:scale(.94)}

/* ===== Toast / Push notification ===== */
.toaster{
  position:fixed;top:calc(var(--header-h) + 16px);right:16px;
  display:flex;flex-direction:column;gap:10px;
  z-index:1100;pointer-events:none;
  width:min(380px,calc(100vw - 32px));
}
.toast{
  pointer-events:auto;position:relative;
  background:#fff;border:1px solid var(--line-strong);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:14px 44px 14px 60px;
  min-height:64px;
  font-size:.94rem;color:var(--ink);
  opacity:0;transform:translateX(24px) scale(.96);
  transition:opacity 360ms var(--ease-warm),transform 360ms var(--ease-warm);
  overflow:hidden;isolation:isolate;
}
.toast.is-visible{opacity:1;transform:none}
.toast.is-leaving{opacity:0;transform:translateX(24px) scale(.96)}
.toast::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--accent),var(--brand));
  z-index:1;
}
.toast-icon{
  position:absolute;left:14px;top:14px;width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(180deg,var(--brand-soft),var(--brand));
  box-shadow:0 4px 12px rgba(106,27,77,.25);
}
.toast-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.toast-title{font-weight:600;font-family:var(--font-display);font-size:1rem;line-height:1.25;margin:0 0 2px;color:var(--ink)}
.toast-text{color:var(--ink-soft);font-size:.9rem;line-height:1.4;margin:0}
.toast-close{
  position:absolute;top:6px;right:6px;width:30px;height:30px;padding:0;border-radius:50%;
  background:transparent;border:0;color:var(--ink-mute);cursor:pointer;
  display:grid;place-items:center;
  transition:background-color 180ms var(--ease-smooth),color 180ms var(--ease-smooth);
}
.toast-close::before,
.toast-close::after{
  content:"";grid-area:1/1;
  width:14px;height:2px;background:currentColor;border-radius:2px;
}
.toast-close::before{transform:rotate(45deg)}
.toast-close::after{transform:rotate(-45deg)}
.toast-close:hover{background:var(--bg-soft);color:var(--ink)}
.toast-bar{
  position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:linear-gradient(90deg,var(--accent-soft),var(--brand));
  transform-origin:left center;transform:scaleX(1);
  animation:ka-toast-bar var(--ka-toast-life,5000ms) linear forwards;
}
.toast.is-paused .toast-bar{animation-play-state:paused}
@keyframes ka-toast-bar{from{transform:scaleX(1)}to{transform:scaleX(0)}}

.toast.is-success::before{background:linear-gradient(180deg,#3ea17c,var(--success))}
.toast.is-success .toast-icon{background:linear-gradient(180deg,#3ea17c,var(--success));box-shadow:0 4px 12px rgba(30,107,71,.25)}
.toast.is-success .toast-bar{background:linear-gradient(90deg,#9cd3b7,var(--success))}

.toast.is-error::before{background:linear-gradient(180deg,#c84a5a,var(--danger))}
.toast.is-error .toast-icon{background:linear-gradient(180deg,#c84a5a,var(--danger));box-shadow:0 4px 12px rgba(160,37,52,.25)}
.toast.is-error .toast-bar{background:linear-gradient(90deg,#e9a4ac,var(--danger))}

@media (max-width:520px){
  .toaster{left:16px;right:16px;width:auto}
  .toast{transform:translateY(-16px) scale(.96)}
  .toast.is-leaving{transform:translateY(-16px) scale(.96)}
}

/* ===== Scroll progress bar ===== */
.scroll-progress{
  position:fixed;left:0;top:0;height:3px;width:100%;z-index:1200;
  pointer-events:none;background:transparent;
}
.scroll-progress::before{
  content:"";display:block;height:100%;
  width:var(--ka-scroll-x,0%);
  background:linear-gradient(90deg,var(--accent),var(--brand-soft) 55%,var(--brand));
  box-shadow:0 0 14px rgba(194,144,71,.55);
}

/* ===== Hero floating balloons + cursor glow ===== */
.hero{--ka-cx:50%;--ka-cy:50%}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(300px circle at var(--ka-cx) var(--ka-cy),rgba(194,144,71,.22),transparent 60%);
  opacity:0;transition:opacity 360ms var(--ease-smooth);
}
.hero.is-pointing::after{opacity:1}
.hero-float{
  position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
}
.hero-float .balloon{
  position:absolute;width:34px;height:42px;border-radius:50% 50% 48% 48%;
  background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.72),var(--brand-soft) 68%,var(--brand-dark));
  filter:drop-shadow(0 6px 14px rgba(106,27,77,.22));
  left:var(--x,10%);bottom:-80px;opacity:0;
  animation:ka-balloon-rise var(--dur,22s) linear var(--delay,0s) infinite;
}
.hero-float .balloon::after{
  content:"";position:absolute;left:50%;top:100%;width:1px;height:62px;
  background:linear-gradient(180deg,rgba(106,27,77,.45),transparent);
  transform:translateX(-50%);
}
.hero-float .balloon.b-accent{background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.85),var(--accent-soft) 58%,var(--accent-deep))}
.hero-float .balloon.b-pink{background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.85),#f5cfe2 58%,var(--brand))}
@keyframes ka-balloon-rise{
  0%{transform:translate3d(0,0,0) rotate(-3deg);opacity:0}
  10%{opacity:.75}
  50%{transform:translate3d(22px,-55vh,0) rotate(3deg)}
  90%{opacity:.55}
  100%{transform:translate3d(-14px,-120vh,0) rotate(-2deg);opacity:0}
}

/* ===== Button click ripple ===== */
.btn{position:relative}
.btn .ripple{
  position:absolute;border-radius:50%;
  width:var(--ka-r,220px);height:var(--ka-r,220px);
  left:var(--ka-rx,50%);top:var(--ka-ry,50%);
  transform:translate(-50%,-50%) scale(0);
  background:radial-gradient(circle,rgba(255,255,255,.55),rgba(255,255,255,0) 68%);
  pointer-events:none;z-index:0;
  animation:ka-ripple 650ms var(--ease-out) forwards;
}
.btn-ghost .ripple,
.btn-link .ripple{background:radial-gradient(circle,rgba(106,27,77,.2),rgba(106,27,77,0) 68%)}
@keyframes ka-ripple{
  0%{transform:translate(-50%,-50%) scale(0);opacity:.7}
  100%{transform:translate(-50%,-50%) scale(2.8);opacity:0}
}

/* ===== Magnetic button state ===== */
.btn.is-magnetic{will-change:transform}

/* ===== Featured package tilt ===== */
.package.is-featured{
  transform-style:preserve-3d;will-change:transform;
  transition:transform 380ms var(--ease-warm),box-shadow 380ms var(--ease-smooth);
}
.package.is-featured .tag{transform:translateZ(22px)}
.package.is-featured.is-tilting{transition:transform 120ms linear,box-shadow 380ms var(--ease-smooth)}

/* ===== Confetti burst layer ===== */
.confetti-layer{
  position:fixed;inset:0;pointer-events:none;z-index:1090;overflow:hidden;
}
.confetti-piece{
  position:absolute;top:var(--y,50%);left:var(--x,50%);
  width:10px;height:14px;border-radius:2px;
  background:var(--c,var(--brand));
  will-change:transform,opacity;
  animation:ka-confetti var(--dur,2200ms) cubic-bezier(.2,.7,.3,1) forwards;
}
.confetti-piece.round{border-radius:50%;width:10px;height:10px}
.confetti-piece.strip{width:5px;height:18px}
@keyframes ka-confetti{
  0%{transform:translate(-50%,-50%) rotate(0);opacity:1}
  15%{opacity:1}
  100%{transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,400px))) rotate(var(--rot,540deg));opacity:0}
}

/* ===== Header scrolled state ===== */
.site-header{transition:box-shadow 300ms var(--ease-smooth)}
.site-header::before{transition:background-color 300ms var(--ease-smooth)}
.site-header .header-inner{transition:min-height 360ms var(--ease-smooth)}
.site-header.is-scrolled{box-shadow:0 8px 26px rgba(26,19,41,.08)}
.site-header.is-scrolled::before{
  background:rgba(251,247,241,.97);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
}
.site-header.is-scrolled .header-inner{min-height:62px}

/* ===== Hero H1 shimmer sweep across highlight ===== */
.hero h1 span.hilite{position:relative;display:inline-block;isolation:isolate}
.hero h1 span.hilite::after{
  content:"";position:absolute;inset:auto 0 0 0;height:38%;pointer-events:none;
  background:linear-gradient(110deg,transparent 22%,rgba(255,248,228,.8) 50%,transparent 78%);
  transform:translateX(-140%) skewX(-18deg);
  filter:blur(2px);
}
body.is-loaded .hero h1 span.hilite::after{
  animation:ka-shimmer 4.4s 1.4s cubic-bezier(.22,.7,.2,1) infinite;
}
@keyframes ka-shimmer{
  0%{transform:translateX(-140%) skewX(-18deg)}
  42%,100%{transform:translateX(160%) skewX(-18deg)}
}

/* ===== Hero starfield ===== */
.hero-stars{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-stars .star{
  position:absolute;width:4px;height:4px;border-radius:50%;
  background:radial-gradient(circle,#fff 0%,#fff 38%,rgba(255,255,255,0) 72%);
  box-shadow:0 0 10px rgba(255,236,205,.7);
  left:var(--x,50%);top:var(--y,50%);
  opacity:0;transform:scale(.6);
  animation:ka-star var(--dur,3.4s) var(--delay,0s) ease-in-out infinite;
}
.hero-stars .star.gold{
  background:radial-gradient(circle,#fff5d7 0%,var(--accent-soft) 45%,rgba(194,144,71,0) 75%);
  box-shadow:0 0 12px rgba(194,144,71,.7);
}
@keyframes ka-star{
  0%,100%{opacity:0;transform:scale(.6)}
  50%{opacity:.95;transform:scale(1.15)}
}

/* ===== Hero cursor sparkle trail ===== */
.spark-trail{
  position:absolute;width:9px;height:9px;border-radius:50%;
  left:var(--x);top:var(--y);pointer-events:none;
  background:radial-gradient(circle,#fff8e4 0%,var(--accent) 55%,rgba(194,144,71,0) 80%);
  box-shadow:0 0 12px rgba(194,144,71,.8);
  mix-blend-mode:screen;z-index:3;
  animation:ka-spark 900ms cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes ka-spark{
  0%{transform:translate(-50%,-50%) scale(.3);opacity:.95}
  28%{transform:translate(-50%,-50%) scale(1.25);opacity:1}
  100%{transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,-34px))) scale(.1);opacity:0}
}

/* ===== Hero media parallax tilt wrap ===== */
.hero-media{will-change:transform;transform-style:preserve-3d}
.hero-media img{transform-origin:50% 55%}

/* ===== Featured package pulsing halo ===== */
.package.is-featured{
  animation:ka-halo 4.2s ease-in-out infinite;
}
@keyframes ka-halo{
  0%,100%{box-shadow:0 18px 48px rgba(106,27,77,.15),0 0 0 0 rgba(194,144,71,0)}
  50%{box-shadow:0 26px 64px rgba(106,27,77,.24),0 0 0 12px rgba(194,144,71,.13)}
}

/* ===== Ribbon tag shine on featured package ===== */
.package .tag{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);
  position:absolute;overflow:hidden;isolation:isolate;
}
.package .tag::after{
  content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  animation:ka-tag-shine 5.2s ease-in-out infinite;
  pointer-events:none;
}
@keyframes ka-tag-shine{
  0%,100%{left:-130%}
  42%,58%{left:240%}
}

/* ===== Card spotlight follow (packages, features, prices, sitemap) ===== */
.package,.feature,.price,.sitemap-card{position:relative}
.package::after,.feature::after,.price::after,.sitemap-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(260px circle at var(--ka-px,50%) var(--ka-py,50%),rgba(194,144,71,.16),transparent 55%);
  opacity:0;transition:opacity 360ms var(--ease-smooth);
}
.package:hover::after,.feature:hover::after,.price:hover::after,.sitemap-card:hover::after{opacity:1}

/* ===== Process timeline animated progress + active steps ===== */
.process{position:relative}
.process::after{
  content:"";position:absolute;left:0;top:28px;height:2px;
  width:var(--ka-progress,0%);
  background:linear-gradient(90deg,var(--brand) 0%,var(--accent-deep) 100%);
  box-shadow:0 0 12px rgba(194,144,71,.55);
  transition:width 480ms var(--ease-smooth);
  z-index:0;
}
@media (max-width:1100px){.process::after{display:none}}
.step.is-active .num{
  transform:scale(1.08);
  background-image:linear-gradient(135deg,var(--brand-soft) 0%,var(--brand) 100%);
  background-color:var(--brand);
  color:#fff;border-color:transparent;
  box-shadow:0 16px 40px rgba(106,27,77,.4);
}

/* ===== Hero-meta counter pop + marker line ===== */
.hero-meta > div{position:relative;padding-left:14px}
.hero-meta > div::before{
  content:"";position:absolute;left:0;top:4px;bottom:4px;width:2px;
  background:linear-gradient(180deg,var(--accent),var(--brand));border-radius:2px;
  transform:scaleY(0);transform-origin:top center;
  transition:transform 720ms var(--ease-warm) 360ms;
}
body.is-loaded .hero-meta > div::before{transform:scaleY(1)}
.hero-meta strong{display:inline-block}
.hero-meta strong.is-counted{animation:ka-pop 620ms var(--ease-warm)}
@keyframes ka-pop{
  0%{transform:scale(.94)}
  55%{transform:scale(1.08)}
  100%{transform:scale(1)}
}

/* ===== Section-head eyebrow slide-in ===== */
.section-head .eyebrow{
  display:inline-block;transform:translateX(-12px);opacity:0;
  transition:transform 720ms var(--ease-warm) 120ms,opacity 600ms var(--ease-smooth) 120ms;
}
.section-head.is-visible .eyebrow{transform:none;opacity:1}

/* ===== FAQ refinements ===== */
.faq-item{
  position:relative;
  transition:border-color 320ms var(--ease-smooth),box-shadow 320ms var(--ease-smooth),transform 320ms var(--ease-smooth);
}
.faq-item:hover{border-color:var(--line-strong);box-shadow:0 8px 20px rgba(26,19,41,.06)}
.faq-item.is-open{border-color:var(--brand-soft);box-shadow:0 12px 30px rgba(106,27,77,.12)}
.faq-a-inner .answer{opacity:0;transform:translateY(-4px);transition:opacity 300ms var(--ease-smooth) 140ms,transform 360ms var(--ease-warm) 120ms}
.faq-item.is-open .answer{opacity:1;transform:none}

/* ===== Calculator result bump ===== */
.calc-result .range{transition:transform 420ms var(--ease-warm),color 320ms var(--ease-smooth)}
.calc-result .range.is-bumped{transform:scale(1.045);color:var(--brand)}

/* ===== CTA band diagonal sweep + ambient lights ===== */
.cta-band{position:relative;overflow:hidden;isolation:isolate}
.cta-band::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(620px circle at 18% 20%,rgba(255,255,255,.16),transparent 55%),
    radial-gradient(520px circle at 82% 88%,rgba(194,144,71,.24),transparent 60%);
}
.cta-band::after{
  content:"";position:absolute;top:-40%;left:-40%;width:60%;height:180%;z-index:0;pointer-events:none;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.16) 50%,transparent 70%);
  transform:rotate(10deg) translateX(-40%);
  animation:ka-cta-sweep 7.2s cubic-bezier(.2,.7,.2,1) infinite;
}
.cta-band > .container{position:relative;z-index:1}
@keyframes ka-cta-sweep{
  0%{transform:rotate(10deg) translateX(-40%)}
  55%,100%{transform:rotate(10deg) translateX(260%)}
}

/* ===== Hero-kicker dot breathing glow ===== */
.hero-kicker .dot{animation:ka-dot-pulse 2.6s ease-in-out infinite}
@keyframes ka-dot-pulse{
  0%,100%{box-shadow:0 0 10px rgba(106,27,77,.35)}
  50%{box-shadow:0 0 18px rgba(106,27,77,.65),0 0 0 4px rgba(106,27,77,.08)}
}

/* ===== Brand mark idle tilt breathing ===== */
body.is-loaded .brand-mark{animation:ka-mark-breathe 6s ease-in-out infinite}
@keyframes ka-mark-breathe{
  0%,100%{transform:rotate(0) scale(1)}
  50%{transform:rotate(3deg) scale(1.04)}
}
.brand:hover .brand-mark{animation:none}

/* ===== Reveal direction variants ===== */
[data-reveal="left"]{transform:translate3d(-28px,0,0)}
[data-reveal="right"]{transform:translate3d(28px,0,0)}
[data-reveal="scale"]{transform:scale(.96)}
[data-reveal="left"].is-visible,
[data-reveal="right"].is-visible,
[data-reveal="scale"].is-visible{transform:none}

/* ===== Gentle page fade-in (no loader, just a soft entrance) ===== */
body{opacity:.001;transition:opacity 760ms var(--ease-silk)}
body.is-loaded{opacity:1}

/* ===== Hero H1 word-by-word reveal ===== */
.hero h1 .hw{
  display:inline-block;
  transform:translateY(1.1em);
  opacity:0;
  filter:blur(10px);
  will-change:transform,opacity,filter;
}
body.is-loaded .hero h1 .hw{
  animation:ka-word-in 1200ms var(--ease-silk) calc(var(--i,0) * 70ms + 200ms) both;
}
@keyframes ka-word-in{
  0%  {transform:translateY(.75em);opacity:0;filter:blur(6px)}
  60% {opacity:1;filter:blur(0)}
  100%{transform:translateY(0);opacity:1;filter:blur(0)}
}

/* ===== Hero image clip-path reveal ===== */
body:not(.is-loaded) .hero-media{clip-path:inset(8% 14% 14% 10% round var(--radius-lg))}
body.is-loaded .hero-media{
  clip-path:inset(0 round var(--radius-lg));
  transition:clip-path 1700ms var(--ease-silk) 200ms,
             transform 900ms var(--ease-smooth),
             filter 900ms var(--ease-smooth);
}

/* ===== Scroll hint bouncing chevron ===== */
.scroll-hint{
  position:absolute;left:50%;bottom:14px;z-index:2;
  width:44px;height:44px;padding:0;border-radius:50%;
  background:#fff;border:1px solid var(--line);
  box-shadow:0 10px 26px rgba(26,19,41,.08);
  color:var(--brand);cursor:pointer;
  display:grid;place-items:center;
  opacity:0;transform:translateX(-50%) translateY(16px);
  transition:opacity 420ms var(--ease-smooth),transform 520ms var(--ease-warm);
}
body.is-loaded .scroll-hint{
  opacity:1;transform:translateX(-50%) translateY(0);
  transition-delay:900ms,900ms;
}
.scroll-hint::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(106,27,77,.28);
  animation:ka-hint-ring 2.2s ease-out infinite;
}
.scroll-hint svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.scroll-hint .chev{animation:ka-hint-bounce 1.8s ease-in-out infinite}
.scroll-hint.is-gone{opacity:0 !important;transform:translateX(-50%) translateY(28px);pointer-events:none}
@keyframes ka-hint-bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(4px)}
}
@keyframes ka-hint-ring{
  0%{transform:scale(.8);opacity:.6}
  100%{transform:scale(1.5);opacity:0}
}
@media (max-width:860px){.scroll-hint{display:none}}

/* Reduced motion kill switch */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
  [data-reveal]{opacity:1 !important;transform:none !important}
  body:not(.is-loaded) [data-intro]{opacity:1 !important}
  .hero-media .sparkle{display:none !important}
  .scroll-progress,.hero-float,.confetti-layer,.toast-bar,.btn .ripple,
  .hero-stars,.spark-trail,.package .tag::after,.cta-band::after{display:none !important}
  .hero::after,.hero h1 span.hilite::after{display:none !important}
  .package.is-featured,.hero-kicker .dot,.brand-mark{animation:none !important}
  .hero h1 .hw{transform:none !important;opacity:1 !important;filter:none !important;animation:none !important}
  body:not(.is-loaded) .hero-media{clip-path:none !important}
  .scroll-hint{animation:none !important}
  .scroll-hint .chev,.scroll-hint::after{animation:none !important}
  body{opacity:1 !important}
}
