/* ======================================================================
   KANONU SOLUTIONS — DESIGN SYSTEM (multi-page)
   ====================================================================== */

:root{
  --ink:#07131F;
  --ink-2:#0B1E30;
  --ink-3:#112E48;
  --paper:#F6EFE1;
  --cream:#FBF6EC;
  --line:rgba(246,239,225,0.12);
  --line-2:rgba(246,239,225,0.08);
  --gold:#D9B56A;
  --gold-2:#E9C982;
  --gold-3:#9B7A35;
  --text:#E9DFCB;
  --text-dim:#9FA9B6;
  --mist:rgba(246,239,225,0.78);
  --radius:18px;
  --max:1320px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--ink);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
@media (hover:hover) and (min-width:900px){ body{ cursor:none } }

/* Film grain */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:1000;
  opacity:.055;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='matrix' values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.scroll-bar{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:1001;
  background:linear-gradient(90deg,var(--gold-2),var(--gold));
  transition:width .08s linear;
}

.cursor{
  position:fixed;top:0;left:0;width:28px;height:28px;
  border:1px solid rgba(217,181,106,.6);border-radius:50%;
  transform:translate(-50%,-50%);pointer-events:none;z-index:1002;
  transition:width .22s var(--ease),height .22s var(--ease),border-color .22s var(--ease),background .22s var(--ease);
  mix-blend-mode:difference;
}
.cursor.active{width:56px;height:56px;background:rgba(217,181,106,.14);border-color:rgba(217,181,106,.9)}
@media (hover:none),(max-width:900px){ .cursor{display:none} }

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- TYPE ---------- */
h1,h2,h3,h4{
  font-family:'Fraunces',Georgia,'Times New Roman',serif;
  font-weight:400;color:var(--cream);letter-spacing:-0.015em;line-height:1.02;margin:0;
}
h1{font-size:clamp(2.6rem,7vw,6.4rem);font-weight:300}
h2{font-size:clamp(2rem,5vw,4.2rem);font-weight:400;line-height:1.05}
h3{font-size:clamp(1.3rem,1.8vw,1.7rem);font-weight:500;line-height:1.15}
h4{font-size:clamp(1.05rem,1.3vw,1.2rem);font-weight:500}
p{margin:0}
em{font-family:'Fraunces',serif;font-style:italic;font-weight:300}
.kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.72rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-2);
}
.kicker::before{content:"";width:28px;height:1px;background:var(--gold);display:block;opacity:.7}

/* Page container (used inside nav, footer etc.) */
section{position:relative;padding:clamp(72px,10vw,160px) 0}
section > *:not(.orb):not(.grain){max-width:var(--max);margin-left:auto;margin-right:auto;padding-left:clamp(22px,4vw,56px);padding-right:clamp(22px,4vw,56px)}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:22px 0;transition:background .4s var(--ease),border-color .4s var(--ease),padding .3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.stuck{
  background:rgba(7,19,31,.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  padding:14px 0;border-bottom-color:var(--line);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;color:var(--cream)}
.brand img{width:34px;height:34px;display:block}
.brand span{font-family:'Fraunces',serif;font-weight:400;font-size:1.05rem;letter-spacing:.01em}
.brand span b{font-weight:600}
.nav ul{display:flex;gap:28px;list-style:none;margin:0;padding:0;align-items:center}
.nav ul a{
  font-size:.88rem;font-weight:500;color:var(--mist);
  position:relative;padding:6px 0;transition:color .2s var(--ease);
}
.nav ul a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);
  transition:width .4s var(--ease);
}
.nav ul a:hover{color:var(--cream)}
.nav ul a:hover::after,.nav ul a.active::after{width:100%}
.nav ul a.active{color:var(--cream)}
.nav ul a.btn::after{display:none}
.nav-toggle{
  display:none;background:none;border:1px solid var(--line);border-radius:999px;
  color:var(--cream);padding:8px 14px;font-size:1.1rem;cursor:pointer;
}
@media (max-width:880px){
  .nav ul{display:none}
  .nav-toggle{display:inline-flex}
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-weight:500;font-size:.9rem;letter-spacing:.01em;
  cursor:pointer;border:1px solid transparent;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),transform .25s var(--ease);
  will-change:transform;
}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-2)}
.btn-primary{background:var(--gold);color:#1B1205;border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-2);border-color:var(--gold-2)}
.btn.big{padding:18px 28px;font-size:.95rem}

/* ---------- BREADCRUMB ---------- */
.breadcrumb{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);
  margin-bottom:28px;
}
.breadcrumb a{color:var(--mist);transition:color .3s var(--ease)}
.breadcrumb a:hover{color:var(--gold-2)}
.breadcrumb span:not(.sep){color:var(--cream)}

/* ---------- HERO (home) ---------- */
.hero{
  min-height:100vh;padding-top:120px;padding-bottom:80px;
  display:flex;align-items:center;overflow:hidden;position:relative;
}
.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);width:100%;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.72rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-2);margin-bottom:clamp(32px,6vw,72px);
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(217,181,106,.18);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(217,181,106,.18)}50%{box-shadow:0 0 0 10px rgba(217,181,106,0)}}

.hero-title{
  font-family:'Fraunces',Georgia,serif;font-weight:300;line-height:.98;letter-spacing:-0.03em;
  color:var(--cream);font-size:clamp(2.8rem,10vw,9rem);
}
.hero-title .line{display:block;overflow:hidden}
.hero-title .gold{color:var(--gold-2);font-style:italic;font-weight:300}
.rise{display:inline-block;transform:translateY(110%);opacity:0;animation:rise 1.1s var(--ease) forwards;animation-delay:var(--d,0s)}
@keyframes rise{to{transform:translateY(0);opacity:1}}

.hero-sub{
  margin-top:clamp(36px,5vw,56px);max-width:60ch;
  font-size:clamp(1.05rem,1.3vw,1.2rem);color:var(--mist);line-height:1.6;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:clamp(28px,4vw,44px)}
.hero-meta{
  display:grid;grid-template-columns:repeat(3,auto);gap:clamp(28px,5vw,72px);
  margin-top:clamp(60px,9vw,110px);padding-top:30px;border-top:1px solid var(--line);
}
@media (max-width:700px){.hero-meta{grid-template-columns:1fr 1fr}}
.hero-meta > div{display:flex;flex-direction:column;gap:6px}
.hero-meta b{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(1.3rem,2vw,1.7rem);color:var(--cream);letter-spacing:-0.01em}
.hero-meta span{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim)}

.orb{position:absolute;pointer-events:none;filter:blur(70px);opacity:.55;z-index:1;will-change:transform}
.orb-a{width:520px;height:520px;left:-120px;top:10%;
  background:radial-gradient(circle,rgba(217,181,106,.45),transparent 60%);
  animation:drift 22s var(--ease-soft) infinite alternate;}
.orb-b{width:620px;height:620px;right:-160px;bottom:-100px;
  background:radial-gradient(circle,rgba(17,46,72,1),transparent 65%);
  animation:drift2 28s var(--ease-soft) infinite alternate;}
@keyframes drift{0%{transform:translate(0,0) scale(1)}100%{transform:translate(60px,-40px) scale(1.08)}}
@keyframes drift2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-40px,30px) scale(1.06)}}

.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);width:22px;height:38px;border:1px solid var(--line);border-radius:999px;display:flex;justify-content:center;padding-top:8px;z-index:3}
.scroll-hint span{width:2px;height:8px;background:var(--gold);border-radius:2px;animation:scrollDot 1.8s var(--ease) infinite}
@keyframes scrollDot{0%{transform:translateY(0);opacity:1}100%{transform:translateY(14px);opacity:0}}

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero{
  padding-top:clamp(140px,15vw,220px);padding-bottom:clamp(50px,7vw,100px);
  position:relative;overflow:hidden;
}
.page-hero .breadcrumb,
.page-hero .kicker,
.page-hero .page-title,
.page-hero .page-sub,
.page-hero .hero-ctas{
  position:relative;z-index:2;max-width:var(--max);margin-left:auto;margin-right:auto;
  padding-left:clamp(22px,4vw,56px);padding-right:clamp(22px,4vw,56px);
}
.page-title{
  font-family:'Fraunces',serif;font-weight:300;line-height:1;letter-spacing:-0.03em;
  font-size:clamp(2.6rem,8vw,6.4rem);color:var(--cream);margin-top:16px;
}
.page-title .line{display:block;overflow:hidden}
.page-title .gold{color:var(--gold-2);font-style:italic;font-weight:300}
.page-sub{
  margin-top:clamp(28px,4vw,44px);max-width:58ch;color:var(--mist);
  font-size:clamp(1.05rem,1.3vw,1.2rem);line-height:1.6;
}

/* ---------- MARQUEE ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:26px 0;overflow:hidden;white-space:nowrap;
  background:linear-gradient(180deg,rgba(11,30,48,.4),rgba(7,19,31,.4));
}
.marquee > .marquee-track{max-width:none;padding:0}
.marquee-track{display:inline-flex;align-items:center;gap:28px;animation:marq 42s linear infinite;will-change:transform;padding-left:28px}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(1.4rem,2.4vw,2rem);color:var(--cream);opacity:.9;
}
.marquee-track span:nth-child(even){color:var(--gold);opacity:.6}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- SECTION HEAD ---------- */
.section-head{margin-bottom:clamp(48px,7vw,96px);max-width:var(--max)}
.section-head .kicker{margin-bottom:20px}
.section-head h2{margin-top:0}
.section-head .lede{color:var(--mist);max-width:60ch;margin-top:22px;font-size:1.05rem}

/* ---------- SERVICE ROWS (home) ---------- */
.srow{
  display:grid;grid-template-columns:.2fr 2fr .2fr;gap:40px;align-items:center;
  padding:44px 0;border-top:1px solid var(--line);
  position:relative;overflow:hidden;transition:background .5s var(--ease);
}
.srow:last-of-type{border-bottom:1px solid var(--line)}
.srow::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:0;
  background:linear-gradient(90deg,rgba(217,181,106,.08),transparent);
  transition:width .6s var(--ease);pointer-events:none;
}
.srow:hover::before{width:100%}
.srow-num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--gold-2);font-size:1rem;letter-spacing:.08em;
}
.srow-body h3{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(1.6rem,3vw,2.8rem);line-height:1.04;color:var(--cream)}
.srow-body p{color:var(--mist);margin-top:14px;max-width:56ch}
.srow-arrow{
  font-family:'Fraunces',serif;font-size:2rem;color:var(--gold-2);
  transition:transform .5s var(--ease);justify-self:end;
}
.srow:hover .srow-arrow{transform:translateX(10px)}
@media (max-width:800px){
  .srow{grid-template-columns:1fr;gap:12px}
  .srow-arrow{justify-self:start;font-size:1.4rem}
}

.chips{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:22px 0 0}
.chips li{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 12px;border:1px solid var(--line);border-radius:999px;color:var(--text-dim);
}
.chips.big li{font-size:.82rem;padding:8px 16px}

/* ---------- SHOWCASE / TILT CARD ---------- */
.showcase{
  background:radial-gradient(700px 380px at 80% 10%,rgba(217,181,106,.12),transparent 60%),linear-gradient(180deg,#0B1E30 0%,#07131F 100%);
}
.show-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,80px);align-items:center;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:960px){.show-grid{grid-template-columns:1fr}}
.show-copy .kicker{margin-bottom:18px}
.show-copy p{color:var(--mist);margin-top:18px;max-width:56ch}
.show-title{font-family:'Fraunces',serif;font-weight:300;font-style:italic;font-size:clamp(2rem,4vw,3.4rem);line-height:1.1;color:var(--cream);margin:18px 0}
.tilt-wrap{perspective:1500px}
.tilt-card{
  position:relative;border-radius:24px;overflow:hidden;
  background:linear-gradient(160deg,#0F2A43 0%,#072137 100%);
  border:1px solid var(--line);
  padding:44px;min-height:420px;transform-style:preserve-3d;
  transition:transform .4s var(--ease);
}
.tilt-card .tilt-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(500px 300px at var(--mx,50%) var(--my,10%),rgba(217,181,106,.22),transparent 60%);
}
.tilt-inner{position:relative;z-index:2;display:flex;flex-direction:column;height:100%;gap:28px}
.tilt-quote{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(1.3rem,2vw,1.7rem);color:var(--cream);line-height:1.25;flex:1}
.tilt-sign{display:flex;align-items:center;gap:16px;padding-top:18px;border-top:1px solid var(--line)}
.tilt-sign > div{display:flex;flex-direction:column}
.tilt-sign b{color:var(--cream);font-weight:500}
.tilt-sign span{color:var(--text-dim);font-size:.82rem;letter-spacing:.08em}

/* ---------- PHASES / PROCESS ---------- */
.phases{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(5,1fr);gap:16px;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:1000px){.phases{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.phases{grid-template-columns:1fr}}
.phase{
  padding:28px 24px;border:1px solid var(--line);border-radius:20px;
  background:rgba(11,30,48,.45);transition:transform .5s var(--ease),border-color .5s var(--ease);
}
.phase:hover{transform:translateY(-4px);border-color:rgba(217,181,106,.35)}
.phase b{
  display:inline-block;font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--gold-2);font-size:1.1rem;margin-bottom:18px;
}
.phase h4{color:var(--cream);margin-bottom:10px}
.phase p{color:var(--mist);font-size:.95rem}

/* ---------- DELIVERABLES GRID ---------- */
.deliv-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:960px){.deliv-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.deliv-grid{grid-template-columns:1fr}}
.deliv{
  padding:32px;border:1px solid var(--line);border-radius:20px;
  background:rgba(11,30,48,.45);transition:transform .5s var(--ease),border-color .5s var(--ease);
}
.deliv:hover{transform:translateY(-4px);border-color:rgba(217,181,106,.35)}
.deliv-num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  color:var(--gold-2);font-size:1.1rem;margin-bottom:18px;
}
.deliv h4{color:var(--cream);margin-bottom:12px}
.deliv p{color:var(--mist);font-size:.95rem;line-height:1.55}

/* ---------- TIER SECTIONS ---------- */
.tier-section{
  padding:clamp(60px,8vw,110px) 0;border-top:1px solid var(--line);
  position:relative;
}
.tier-section.featured{
  background:radial-gradient(800px 400px at 50% 0%,rgba(217,181,106,.10),transparent 70%);
}
.tier-head{
  max-width:var(--max);margin:0 auto 40px;padding:0 clamp(22px,4vw,56px);
}
.tier-tag{
  display:inline-block;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-2);margin-bottom:14px;padding:8px 14px;border:1px solid rgba(217,181,106,.35);
  border-radius:999px;
}
.tier-head h2{margin-bottom:18px}
.tier-price{display:flex;flex-wrap:wrap;align-items:baseline;gap:18px;margin-bottom:20px}
.tier-price .num{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(1.6rem,2.6vw,2.2rem);color:var(--gold-2)}
.tier-price .dur{color:var(--text-dim);font-size:.86rem;letter-spacing:.12em;text-transform:uppercase}
.tier-desc{color:var(--mist);max-width:66ch;font-size:1.05rem;line-height:1.6}
.tier-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(30px,5vw,72px);
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:960px){.tier-grid{grid-template-columns:1fr}}
.tier-col .kicker{margin-bottom:16px}
.tier-col p{color:var(--mist);line-height:1.65}
.tier-col p b{color:var(--cream);font-weight:500}
ul.check{list-style:none;padding:0;margin:0}
ul.check li{
  position:relative;padding:12px 0 12px 28px;border-top:1px dashed var(--line-2);
  color:var(--text);font-size:.96rem;line-height:1.5;
}
ul.check li:first-child{border-top:none}
ul.check li::before{
  content:"";position:absolute;left:0;top:18px;width:14px;height:1px;background:var(--gold);
}

/* ---------- TIER TEASER GRID (on home + services) ---------- */
.tier-teaser-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:1000px){.tier-teaser-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.tier-teaser-grid{grid-template-columns:1fr}}
.tier-teaser{
  display:block;padding:28px 26px;border:1px solid var(--line);border-radius:20px;
  background:rgba(11,30,48,.5);transition:transform .4s var(--ease),border-color .4s var(--ease);
  color:inherit;
}
.tier-teaser:hover{transform:translateY(-4px);border-color:rgba(217,181,106,.45)}
.tier-teaser .kicker{margin-bottom:12px}
.tier-teaser h4{font-family:'Fraunces',serif;font-weight:500;font-size:1.4rem;color:var(--gold-2);margin-bottom:10px}
.tier-teaser p{color:var(--mist);font-size:.92rem;line-height:1.5}

/* ---------- COMPARE ---------- */
.compare{
  border:1px solid var(--line);border-radius:24px;overflow:hidden;
  max-width:var(--max);margin:0 auto;padding:0;
}
.compare-row{
  display:grid;grid-template-columns:2fr 1fr;gap:20px;
  padding:22px 30px;border-top:1px solid var(--line);align-items:center;
  transition:background .3s var(--ease);
}
.compare-row:first-child{border-top:none}
.compare-row:hover{background:rgba(17,46,72,.35)}
.compare-problem{color:var(--cream);font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(1.05rem,1.5vw,1.25rem)}
.compare-tier{
  justify-self:end;color:var(--gold-2);font-weight:500;font-size:.86rem;letter-spacing:.14em;
  text-transform:uppercase;padding:10px 18px;border:1px solid rgba(217,181,106,.3);border-radius:999px;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.compare-tier:hover{border-color:var(--gold-2);background:rgba(217,181,106,.1)}
@media (max-width:700px){
  .compare-row{grid-template-columns:1fr}
  .compare-tier{justify-self:start}
}

/* ---------- FAQ ---------- */
.faq{
  border-top:1px solid var(--line);
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
.faq details{border-bottom:1px solid var(--line);padding:24px 0;cursor:pointer}
.faq summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:'Fraunces',serif;font-weight:400;font-size:clamp(1.1rem,1.5vw,1.3rem);color:var(--cream);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:'Fraunces',serif;color:var(--gold-2);font-size:1.6rem;
  transition:transform .4s var(--ease);flex-shrink:0;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding-top:18px;max-width:72ch;color:var(--mist);line-height:1.7;font-size:1rem;animation:fadeUp .4s var(--ease)}
.faq details p a{color:var(--gold-2);border-bottom:1px solid rgba(217,181,106,.3)}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ---------- FIT (for-whom / not-for) ---------- */
.fit{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:800px){.fit{grid-template-columns:1fr}}
.fit-col{border:1px solid var(--line);border-radius:20px;padding:36px;background:rgba(11,30,48,.45)}
.fit-col h4{
  font-family:'Inter',sans-serif;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-2);margin-bottom:22px;display:inline-flex;align-items:center;gap:10px;font-weight:500;
}
.fit-col h4::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);display:inline-block}
.fit-col.not h4{color:#C7A6A6}.fit-col.not h4::before{background:#C7A6A6}
.fit-col ul{list-style:none;padding:0;margin:0}
.fit-col li{padding:14px 0;border-top:1px dashed var(--line-2);color:var(--text);line-height:1.55}
.fit-col li:first-child{border-top:none}

/* ---------- RELATED ---------- */
.related{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:800px){.related{grid-template-columns:1fr}}
.related-card{
  display:block;padding:36px 34px;border:1px solid var(--line);border-radius:20px;
  background:rgba(17,46,72,.4);transition:transform .45s var(--ease),border-color .45s var(--ease),background .45s var(--ease);
  color:inherit;position:relative;
}
.related-card:hover{transform:translateY(-4px);border-color:rgba(217,181,106,.45);background:rgba(17,46,72,.6)}
.related-card .kicker{margin-bottom:14px}
.related-card h3{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(1.4rem,2.2vw,1.9rem);color:var(--cream);margin-bottom:10px}
.related-card p{color:var(--mist);margin-bottom:22px;max-width:52ch}
.related-card .arrow{
  display:inline-flex;align-items:center;gap:10px;color:var(--gold-2);
  font-family:'Fraunces',serif;font-size:1.5rem;transition:transform .4s var(--ease);
}
.related-card:hover .arrow{transform:translateX(8px)}

/* ---------- WHY GRID ---------- */
.why-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:1000px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.why-grid{grid-template-columns:1fr}}
.why{
  padding:28px;border:1px solid var(--line);border-radius:20px;
  background:rgba(11,30,48,.4);transition:border-color .4s var(--ease),transform .4s var(--ease);
}
.why:hover{border-color:rgba(217,181,106,.35);transform:translateY(-4px)}
.why h4{color:var(--cream);margin-bottom:10px}
.why p{color:var(--mist);font-size:.95rem}

/* ---------- CONTACT BAND ---------- */
.contact-band{
  background:linear-gradient(180deg,rgba(217,181,106,.06),transparent 80%),linear-gradient(180deg,#0B1E30 0%,#07131F 100%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.cb-inner{
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:900px){.cb-inner{grid-template-columns:1fr}}
.cb-inner .kicker{margin-bottom:16px}
.cb-inner h2{font-size:clamp(1.8rem,3.6vw,3rem)}
.cb-actions{display:flex;flex-wrap:wrap;gap:12px;justify-self:end}
@media (max-width:900px){.cb-actions{justify-self:start}}

/* ---------- FORMS ---------- */
.form-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px 28px;
  max-width:920px;margin:0 auto;padding:0 clamp(22px,4vw,56px);
}
@media (max-width:700px){.form-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1 / -1}
.field label{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);font-weight:500}
.field input,.field textarea,.field select{
  background:rgba(11,30,48,.6);border:1px solid var(--line);border-radius:14px;
  color:var(--cream);padding:14px 16px;font-family:inherit;font-size:1rem;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--gold);background:rgba(11,30,48,.85);
}
.field textarea{resize:vertical;min-height:140px}
.chk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:700px){.chk-grid{grid-template-columns:repeat(2,1fr)}}
.chk{position:relative;cursor:pointer}
.chk input{position:absolute;opacity:0;pointer-events:none}
.chk span{
  display:block;padding:12px 16px;border:1px solid var(--line);border-radius:999px;
  text-align:center;font-size:.86rem;color:var(--mist);transition:all .3s var(--ease);
}
.chk:hover span{border-color:rgba(217,181,106,.4);color:var(--cream)}
.chk input:checked + span{
  background:rgba(217,181,106,.12);border-color:var(--gold);color:var(--gold-2);
}
.form-actions{
  grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center;gap:20px;
  margin-top:10px;padding-top:24px;border-top:1px solid var(--line);
}
.form-actions .note{color:var(--text-dim);font-size:.86rem}
@media (max-width:700px){.form-actions{flex-direction:column;align-items:flex-start}}

/* ---------- EMPTY STATE ---------- */
.empty{
  border:1px dashed var(--line);border-radius:24px;padding:clamp(44px,7vw,88px);
  text-align:center;background:rgba(11,30,48,.35);
  max-width:var(--max);margin:0 auto;
}
.empty h3{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--cream);margin-bottom:14px}
.empty p{max-width:54ch;margin:0 auto 26px;color:var(--mist)}

/* ---------- FOOTER ---------- */
.foot{padding:60px 0 40px;border-top:1px solid var(--line);background:var(--ink);margin-top:40px}
.foot-inner{
  max-width:var(--max);margin:0 auto;padding:0 clamp(22px,4vw,56px);
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;align-items:start;
}
@media (max-width:900px){.foot-inner{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.foot-inner{grid-template-columns:1fr}}
.foot-brand{display:flex;align-items:center;gap:14px}
.foot-brand img{width:40px;height:40px}
.foot-brand > div{display:flex;flex-direction:column;gap:6px}
.foot-brand b{color:var(--cream);font-family:'Fraunces',serif;font-weight:500;font-size:1.05rem}
.foot-brand span{color:var(--text-dim);font-size:.84rem}
.foot-col{display:flex;flex-direction:column;gap:10px}
.foot-col .kicker{margin-bottom:12px}
.foot-col a,.foot-col span{color:var(--mist);font-size:.94rem;transition:color .3s var(--ease)}
.foot-col a:hover{color:var(--gold-2)}
.foot-bottom{
  max-width:var(--max);margin:30px auto 0;padding:24px clamp(22px,4vw,56px) 0;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:.82rem;color:var(--text-dim);
}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
  .rise{opacity:1;transform:none;animation:none}
}
