:root{
  --bg:#0e1116;
  --bg-2:#13171f;
  --ink:#eef0f3;
  --ink-soft:#aab2bf;
  --ink-dim:#6b7382;
  --line:#222936;
  --gold:#c9a96a;
  --gold-2:#e3c489;
  --accent:#3a4a5c;
  --max:1200px;
  --radius:14px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}

.container{max-width:var(--max);margin:0 auto;padding:0 28px}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(14,17,22,.65);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.nav.is-scrolled{border-color:var(--line);background:rgba(14,17,22,.85)}
.nav__inner{
  max-width:var(--max);margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand__mark{width:34px;height:34px;color:var(--gold)}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__text strong{font-family:'Fraunces',serif;font-weight:600;font-size:15px;letter-spacing:.02em}
.brand__text em{font-style:normal;font-size:11px;color:var(--ink-dim);letter-spacing:.18em;text-transform:uppercase}

.nav__links{display:flex;gap:28px}
.nav__links a{font-size:14px;color:var(--ink-soft);transition:color .2s}
.nav__links a:hover{color:var(--gold)}

.nav__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border:1px solid var(--gold);border-radius:999px;
  font-size:13px;color:var(--gold);font-weight:500;letter-spacing:.02em;
  transition:background .2s, color .2s;
}
.nav__cta:hover{background:var(--gold);color:#0e1116}
.dot{width:7px;height:7px;border-radius:50%;background:#41d971;box-shadow:0 0 0 4px rgba(65,217,113,.18);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;padding:160px 0 120px;
  display:flex;align-items:center;
  background:radial-gradient(ellipse at top right, rgba(201,169,106,.10), transparent 50%),
             radial-gradient(ellipse at bottom left, rgba(58,74,92,.18), transparent 55%),
             var(--bg);
  overflow:hidden;
}
.hero__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
  opacity:.35;
  pointer-events:none;
}
.hero__inner{position:relative;max-width:var(--max);margin:0 auto;padding:0 28px;width:100%}

.hero__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
  padding:8px 14px;border:1px solid var(--line);border-radius:999px;
  background:rgba(255,255,255,.02);
  margin-bottom:32px;
}
.pulse{width:7px;height:7px;border-radius:50%;background:#41d971;animation:pulse 1.6s infinite}

.hero__title{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:clamp(44px, 7.5vw, 96px);
  line-height:1.02;letter-spacing:-.02em;
  margin-bottom:28px;max-width:14ch;
}
.hero__title .word{display:inline-block;opacity:0;transform:translateY(40px)}
.hero__title .italic{font-style:italic;color:var(--gold)}

.hero__lede{
  font-size:clamp(17px, 1.4vw, 20px);color:var(--ink-soft);
  max-width:60ch;margin-bottom:40px;
  opacity:0;transform:translateY(20px);
}

.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:80px;opacity:0;transform:translateY(20px)}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;font-size:15px;font-weight:500;
  letter-spacing:.01em;transition:transform .25s var(--ease), background .2s, color .2s, box-shadow .25s;
  cursor:pointer;border:1px solid transparent;
}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn--primary{background:var(--gold);color:#0e1116}
.btn--primary:hover{background:var(--gold-2);box-shadow:0 14px 40px -10px rgba(201,169,106,.5)}
.btn--ghost{border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn--block{width:100%;justify-content:center}

.hero__stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  padding-top:40px;border-top:1px solid var(--line);
  opacity:0;transform:translateY(20px);
}
.stat{display:flex;flex-direction:column;gap:6px}
.stat__num{font-family:'Fraunces',serif;font-size:clamp(36px,4vw,52px);font-weight:500;color:var(--ink);line-height:1}
.stat__suffix{display:inline;font-family:'Fraunces',serif;font-size:clamp(20px,2vw,28px);color:var(--gold);margin-left:2px}
.stat__label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim)}

.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim);
}
.hero__scroll span{width:30px;height:1px;background:var(--ink-dim);position:relative;overflow:hidden}
.hero__scroll span::after{
  content:"";position:absolute;inset:0;background:var(--gold);
  transform:translateX(-100%);animation:slide 2.4s var(--ease) infinite;
}
@keyframes slide{50%{transform:translateX(0)}100%{transform:translateX(100%)}}

/* ---------- MARQUEE ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 0;overflow:hidden;background:var(--bg-2);
}
.marquee__track{
  display:flex;gap:42px;white-space:nowrap;
  font-family:'Fraunces',serif;font-style:italic;font-size:22px;color:var(--ink-soft);
  animation:marquee 40s linear infinite;
}
.marquee__track span{display:inline-block}
.marquee__track span:nth-child(even){color:var(--gold)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- SECTIONS ---------- */
.section{padding:120px 0;position:relative}
.section__head{max-width:760px;margin-bottom:64px}
.kicker{
  display:inline-block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.section__title{
  font-family:'Fraunces',serif;font-weight:500;
  font-size:clamp(32px,4.2vw,56px);line-height:1.05;letter-spacing:-.015em;
  margin-bottom:18px;
}
.section__sub{font-size:18px;color:var(--ink-soft);max-width:62ch}

/* ---------- PRACTICE ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{
  position:relative;padding:34px 28px 32px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  transition:transform .35s var(--ease), border-color .3s, background .3s;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%), rgba(201,169,106,.08), transparent 40%);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.card:hover{transform:translateY(-4px);border-color:var(--gold);background:#171c25}
.card:hover::before{opacity:1}
.card__num{font-family:'Fraunces',serif;font-size:13px;color:var(--gold);letter-spacing:.2em}
.card h3{font-family:'Fraunces',serif;font-weight:500;font-size:24px;margin:14px 0 10px}
.card p{color:var(--ink-soft);font-size:15px;margin-bottom:22px}
.card__link{font-size:13px;color:var(--gold);letter-spacing:.05em}

/* ---------- RESULTS (pinned) ---------- */
.results-pin{background:var(--bg-2);position:relative}
.results-pin__scroll{height:500vh;position:relative}
.results-pin__sticky{
  position:sticky;top:0;height:100vh;
  display:flex;align-items:center;
  overflow:hidden;padding:100px 0 40px;
}
.results-pin__sticky .section__head{margin-bottom:32px}

.results-pin__progress{
  display:flex;gap:10px;margin-bottom:32px;
}
.results-pin__progress span{
  width:54px;height:3px;background:var(--line);border-radius:2px;
  position:relative;overflow:hidden;transition:background .3s;
}
.results-pin__progress span.is-active{background:var(--gold)}
.results-pin__progress span.is-done{background:var(--gold);opacity:.5}

.results__list{
  list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
}
.result{
  position:relative;overflow:hidden;
  padding:32px 28px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  transition:transform .5s var(--ease), border-color .4s, box-shadow .4s;
  min-height:200px;
}
.result__tag{
  display:inline-block;padding:5px 12px;background:rgba(201,169,106,.12);color:var(--gold);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;border-radius:999px;margin-bottom:18px;
  position:relative;z-index:2;transition:opacity .4s;
}
.result h4{font-family:'Fraunces',serif;font-weight:500;font-size:22px;margin-bottom:10px;position:relative;z-index:2;transition:opacity .4s}
.result p{color:var(--ink-soft);font-size:15px;position:relative;z-index:2;transition:opacity .4s}

.result__overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:clamp(36px,5.5vw,72px);letter-spacing:-.02em;
  color:#0e1116;
  background:linear-gradient(135deg, rgba(227,196,137,.82), rgba(201,169,106,.82));
  backdrop-filter:blur(2px);
  opacity:0;transform:scale(.94);
  transition:opacity .55s var(--ease), transform .7s var(--ease);
  pointer-events:none;z-index:3;text-align:center;padding:0 16px;
}
.result.is-active{
  border-color:var(--gold);
  transform:translateY(-4px);
}
.result.is-active .result__overlay{opacity:1;transform:scale(1)}
.result.is-active .result__tag,
.result.is-active h4,
.result.is-active p{opacity:0}

/* Nav CTA synced flash — gentle fill, no glow */
.nav__cta.is-flash{
  background:var(--gold);
  color:#0e1116;
  border-color:var(--gold);
}

/* ---------- ABOUT ---------- */
.about__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:center}
.about__media{position:relative}
.about__portrait{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(150deg,#1a2230,#0e1116);border:1px solid var(--line);
}
.about__portrait-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold)}
.about__portrait-inner svg{width:80%;height:80%}
.about__badge{
  position:absolute;bottom:18px;right:18px;
  background:#0e1116;border:1px solid var(--gold);border-radius:10px;
  padding:12px 16px;display:flex;flex-direction:column;gap:2px;
}
.about__badge strong{font-family:'Fraunces',serif;color:var(--gold);font-size:18px}
.about__badge span{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.about__copy p{color:var(--ink-soft);margin-bottom:18px;max-width:60ch}
.about__bullets{list-style:none;margin-top:28px;border-top:1px solid var(--line);padding-top:24px}
.about__bullets li{padding:12px 0;color:var(--ink-soft);font-size:15px;border-bottom:1px solid var(--line);position:relative;padding-left:22px}
.about__bullets li::before{content:"◆";position:absolute;left:0;color:var(--gold);font-size:10px;top:16px}

/* ---------- PROCESS ---------- */
.steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:s}
.step{
  position:relative;padding:32px 24px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--bg-2);transition:transform .3s, border-color .3s;
}
.step:hover{transform:translateY(-3px);border-color:var(--gold)}
.step__num{font-family:'Fraunces',serif;font-size:42px;color:var(--gold);font-weight:500;line-height:1;display:block;margin-bottom:18px;font-style:italic}
.step h4{font-family:'Fraunces',serif;font-weight:500;font-size:20px;margin-bottom:10px}
.step p{color:var(--ink-soft);font-size:14px}

/* ---------- CONTACT ---------- */
.contact{background:var(--bg-2)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact__copy p{color:var(--ink-soft);max-width:46ch;margin-bottom:32px}
.contact__details{display:grid;grid-template-columns:1fr 1fr;gap:24px;border-top:1px solid var(--line);padding-top:28px}
.contact__details > div{display:flex;flex-direction:column;gap:6px}
.contact__details span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
.contact__details a,.contact__details address,.contact__details p{font-style:normal;color:var(--ink);font-size:16px}
.contact__details a:hover{color:var(--gold)}

.form{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:36px;display:flex;flex-direction:column;gap:18px;
}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label{display:flex;flex-direction:column;gap:8px}
.form label > span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
.form input,.form select,.form textarea{
  background:transparent;border:1px solid var(--line);color:var(--ink);
  padding:14px 16px;border-radius:10px;font-family:inherit;font-size:15px;
  transition:border-color .2s;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--gold)}
.form textarea{resize:vertical;min-height:96px}
.form__disclaimer{font-size:11px;color:var(--ink-dim);line-height:1.5}
.form__success{
  display:none;background:rgba(65,217,113,.1);border:1px solid rgba(65,217,113,.3);
  color:#41d971;padding:12px 16px;border-radius:10px;font-size:14px;
}

/* ---------- FOOTER ---------- */
.footer{border-top:1px solid var(--line);padding:80px 0 28px;background:var(--bg)}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px}
.footer__brand p{color:var(--ink-soft);margin-top:18px;max-width:38ch;font-size:14px}
.footer__col h5{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer__col a,.footer__col span{display:block;color:var(--ink-soft);font-size:14px;padding:6px 0;transition:color .2s}
.footer__col a:hover{color:var(--gold)}
.footer__legal{
  display:flex;justify-content:space-between;gap:20px;
  padding-top:24px;border-top:1px solid var(--line);
  font-size:12px;color:var(--ink-dim);flex-wrap:wrap;
}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(30px)}

/* ---------- RESPONSIVE ---------- */
@media (max-width:960px){
  .nav__links{display:none}
  .hero__stats{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr 1fr}
  .results__list{grid-template-columns:1fr}
  .about__grid,.contact__grid{grid-template-columns:1fr;gap:48px}
  .steps{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
  .section{padding:80px 0}
}
@media (max-width:560px){
  .cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .hero{padding:130px 0 80px}
  .hero__stats{grid-template-columns:1fr 1fr;gap:18px}
  .contact__details{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
}

/* ---------- L14 fallback banner ---------- */
.l14-banner{
  display:none;
  margin:0 0 20px;
  padding:14px 18px;
  background:rgba(201,169,106,.12);
  border:1px solid var(--gold);
  border-radius:var(--radius);
  color:var(--gold-2);
  font-size:14px;
  line-height:1.5;
}
.l14-banner.is-visible,
.l14-banner[hidden="false"]{display:block}
.l14-banner:not([hidden]){display:block}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1 !important;transform:none !important}
  .marquee__track{animation:none !important}
  .pulse,.dot{animation:none !important}
}

/* ---------- Extra small (360 audit) ---------- */
@media (max-width:380px){
  .container{padding:0 18px}
  .nav__inner{padding:14px 18px;gap:12px}
  .hero__title{font-size:clamp(34px,11vw,46px)}
}
