/* =========================================================
   SoberCoach.to — shared stylesheet
   Design language carried over from the phase build,
   recoloured to a warm-charcoal base with a warm amber accent
   that harmonises with the gold/terracotta hero illustration.

   To re-skin the accent, change the four --accent* / --glow
   tokens below, the favicon.svg colours, and the inline header
   mark uses these tokens automatically.
   Alternates considered:
     sage / green  --accent:#74A892  --accent-br:#98C9B2  --glow:rgba(116,168,146,.26)
     blue-violet   --accent:#8B7CF5  --accent-br:#A99CFF  --glow:rgba(139,124,245,.26)
   ========================================================= */

:root{
  --bg:#0c0c0e;
  --bg-2:#131316;
  --bg-3:#17171b;
  --line:rgba(232,232,228,.08);
  --line-2:rgba(232,232,228,.15);
  --text:#ECEAE4;
  --dim:#9b9b97;
  --faint:#66665f;

  --accent:#C99A5B;       /* warm amber / gold */
  --accent-br:#E0B879;    /* brighter, for links + hover */
  --glow:rgba(201,154,91,.24);

  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;

  --maxw:1080px;
  --pad:40px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
/* faint film grain, same trick as phase */
body::before{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.022;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
a{color:inherit}
img,svg{display:block}
em{font-style:normal;color:var(--text)}

/* skip link for keyboard users */
.skip{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--accent);color:#0c0c0e;padding:10px 16px;border-radius:0 0 8px 0;
  font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:1px;
}
.skip:focus{left:0}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:60;
  background:rgba(12,12,14,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  box-shadow:0 12px 40px -24px var(--glow);
}
header::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 46% 220% at 50% -34%,var(--glow),transparent 70%);
  opacity:.6;
}
.nav{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.logo .mark{width:22px;height:22px;flex-shrink:0}
.logo .word{font-weight:700;font-size:17px;letter-spacing:-.02em}
.logo .word b{color:var(--accent-br);font-weight:700}

.navlinks{display:flex;align-items:center;gap:26px;font-family:var(--mono);font-size:12px;
  text-transform:uppercase;letter-spacing:1.4px;color:var(--dim)}
.navlinks a{text-decoration:none;transition:color .15s}
.navlinks a:hover,.navlinks a:focus-visible{color:var(--text)}

/* services dropdown */
.navdrop{position:relative}
.navdrop>button{
  font:inherit;text-transform:inherit;letter-spacing:inherit;color:inherit;
  background:none;border:0;padding:0;cursor:pointer;
  display:flex;align-items:center;gap:6px;transition:color .15s;
}
.navdrop>button:hover,.navdrop.open>button{color:var(--text)}
.navdrop .caret{width:0;height:0;border-left:3.5px solid transparent;border-right:3.5px solid transparent;
  border-top:4px solid currentColor;transition:transform .16s}
.navdrop.open .caret{transform:rotate(180deg)}
.dropmenu{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-6px);
  min-width:230px;background:rgba(17,17,21,.98);backdrop-filter:blur(14px);
  border:1px solid var(--line-2);border-radius:12px;padding:7px;
  box-shadow:0 24px 50px -20px rgba(0,0,0,.7);
  opacity:0;visibility:hidden;transition:opacity .16s,transform .16s,visibility 0s .16s;
}
.navdrop.open .dropmenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);transition:opacity .16s,transform .16s}
.dropmenu a{
  display:block;padding:10px 13px;border-radius:8px;text-decoration:none;
  font-family:var(--sans);font-size:14px;letter-spacing:0;text-transform:none;color:var(--dim);
  transition:background .14s,color .14s;
}
.dropmenu a small{display:block;font-size:12px;color:var(--faint);margin-top:1px}
.dropmenu a:hover{background:var(--bg-2);color:var(--text)}

/* header cta button */
.nav .btn-sm{
  font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:1.2px;
  padding:9px 16px;border-radius:8px;text-decoration:none;
  background:var(--accent);color:#0c0c0e;font-weight:500;transition:background .16s,box-shadow .16s;
}
.nav .btn-sm:hover{background:var(--accent-br);box-shadow:0 0 22px var(--glow)}

/* mobile menu toggle */
.menutoggle{display:none;background:none;border:0;cursor:pointer;width:34px;height:34px;
  align-items:center;justify-content:center;color:var(--text)}
.menutoggle span{display:block;width:19px;height:1.6px;background:currentColor;position:relative;transition:transform .2s,opacity .2s}
.menutoggle span::before,.menutoggle span::after{content:"";position:absolute;left:0;width:19px;height:1.6px;background:currentColor;transition:transform .2s}
.menutoggle span::before{top:-6px}.menutoggle span::after{top:6px}
.menutoggle.open span{transform:rotate(45deg)}
.menutoggle.open span::before{transform:rotate(90deg) translateX(-6px)}
.menutoggle.open span::after{opacity:0}

@media(max-width:820px){
  .menutoggle{display:flex}
  .navlinks{
    position:fixed;left:0;top:66px;width:100%;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(13,13,17,.98);backdrop-filter:blur(16px);
    border-bottom:1px solid var(--line-2);padding:10px var(--pad) 22px;
    clip-path:inset(0 0 100% 0);opacity:0;visibility:hidden;
    transition:clip-path .3s cubic-bezier(.16,1,.3,1),opacity .2s,visibility 0s .3s;
  }
  .navlinks.open{clip-path:inset(0 0 0 0);opacity:1;visibility:visible;transition:clip-path .36s cubic-bezier(.16,1,.3,1),opacity .2s}
  .navlinks>a,.navdrop{border-bottom:1px solid var(--line);padding:15px 0}
  .navdrop{padding:0}
  .navdrop>button{padding:15px 0;width:100%}
  .navdrop .caret{margin-left:auto}
  .dropmenu{position:static;transform:none;opacity:1;visibility:visible;min-width:0;
    background:none;border:0;box-shadow:none;padding:0 0 10px 12px;
    max-height:0;overflow:hidden;transition:max-height .26s ease}
  .navdrop.open .dropmenu{max-height:240px;transform:none}
  .nav .btn-sm{margin-top:16px;text-align:center}
}

/* ---------- hero ---------- */
.hero{
  position:relative;padding:96px 0 64px;border-top:none;
}
.hero::before{
  content:"";position:absolute;left:50%;top:6%;width:min(720px,92vw);height:440px;
  transform:translateX(-50%);pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 60% 60% at 50% 40%,var(--glow),transparent 72%);
  opacity:.7;filter:blur(8px);
}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:54px;align-items:center}
.hero.center .hero-grid{grid-template-columns:1fr;text-align:center;max-width:760px;margin:0 auto;gap:34px}
.hero.center .herobody{margin-left:auto;margin-right:auto}
.eyebrow{
  font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:2px;
  color:var(--accent);margin-bottom:20px;
}
.hero h1{
  font-weight:600;font-size:clamp(2.4rem,5.4vw,4rem);line-height:1.05;letter-spacing:-.03em;
  max-width:14em;
}
.hero.center h1{margin-inline:auto}
.herobody{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--dim);max-width:34em;margin-top:22px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px}
.hero.center .hero-cta{justify-content:center}
@media(max-width:820px){
  .hero{padding:60px 0 44px}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero h1{max-width:none}
  .hero .art-slot{max-width:380px;margin:0 auto;order:-1}
}

/* ---------- SVG art slot ----------
   Drop final artwork in by replacing the <svg>/<img> inside .art-slot.
   data-label sets the caption; --ratio sets the box shape. */
.art-slot{
  position:relative;width:100%;aspect-ratio:var(--ratio,1/1);
  border:1px dashed var(--line-2);border-radius:16px;background:
    linear-gradient(var(--bg-2),var(--bg-2)) padding-box,
    radial-gradient(120% 120% at 70% 20%,var(--glow),transparent 60%) border-box;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.art-slot::after{
  content:attr(data-label);position:absolute;
  font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--faint);
}
.art-slot>svg,.art-slot>img{position:relative;width:100%;height:100%;object-fit:contain}
.art-slot.has-art{border:none;background:none}
.art-slot.has-art::after{display:none}
.art-slot.icon{aspect-ratio:1/1;width:54px;border-radius:12px}
.art-slot.icon::after{content:"";}

/* ---------- section scaffolding ---------- */
.section{padding:84px 0;border-top:1px solid var(--line)}
.section.tight{padding:64px 0}
.seclabel{
  font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:2px;
  color:var(--faint);display:flex;align-items:center;gap:14px;margin-bottom:34px;
}
.seclabel b{font-weight:500;color:var(--accent)}
.seclabel::after{content:"";flex:1;height:1px;background:var(--line)}
h2{font-weight:600;font-size:clamp(1.85rem,3.4vw,2.6rem);line-height:1.1;letter-spacing:-.025em}
.lead{font-size:1.12rem;color:var(--text);max-width:38em;margin-top:18px}
.section p{color:var(--dim);max-width:40em}
.section p+p{margin-top:15px}

/* two-column prose */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}
.split .body p:first-child{color:var(--text);font-size:1.08rem}
.pull{margin-top:24px;padding:4px 0 4px 20px;border-left:2px solid var(--accent);
  font-size:1.12rem;line-height:1.45;color:var(--text)}
@media(max-width:740px){.split{grid-template-columns:1fr;gap:26px}}

/* ---------- service cards ---------- */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{
  display:flex;flex-direction:column;padding:26px 24px 28px;text-decoration:none;color:inherit;
  border:1px solid var(--line);border-radius:14px;background:var(--bg-2);
  transition:border-color .16s,transform .16s,background .16s;
}
.card:hover{border-color:var(--accent);transform:translateY(-3px);background:var(--bg-3)}
.card .kick{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent)}
.card h3{font-weight:600;font-size:1.18rem;letter-spacing:-.01em;margin:16px 0 9px}
.card p{font-size:14.5px;line-height:1.55;color:var(--dim);flex:1}
.card .go{margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:var(--accent-br);display:inline-flex;align-items:center;gap:7px;transition:gap .16s}
.card:hover .go{gap:12px}
@media(max-width:820px){.cards-3{grid-template-columns:1fr}}

/* ---------- process (real sequence -> numbered) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:step}
.step{padding:24px 22px;border:1px solid var(--line);border-radius:13px;background:var(--bg-2)}
.step .n{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:1.5px}
.step h4{font-weight:600;font-size:1.02rem;margin:12px 0 7px;letter-spacing:-.01em}
.step p{font-size:13.5px;line-height:1.5;color:var(--dim)}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}

/* ---------- pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tier{position:relative;padding:28px 24px 26px;border:1px solid var(--line);border-radius:14px;background:var(--bg-2);
  transition:border-color .16s,background .16s}
.tier:hover{border-color:var(--line-2);background:var(--bg-3)}
.tier.featured{border-color:var(--accent);background:var(--bg-3)}
.tier .tag{position:absolute;top:-1px;right:18px;transform:translateY(-50%);
  font-family:var(--mono);font-size:9.5px;letter-spacing:1.5px;text-transform:uppercase;
  color:#0c0c0e;background:var(--accent);padding:3px 9px;border-radius:5px}
.tier .cadence{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent)}
.tier .price{font-weight:600;font-size:1.9rem;letter-spacing:-.02em;margin:12px 0 2px}
.tier .price small{font-size:.9rem;color:var(--faint);font-weight:400;letter-spacing:0}
.tier .price .from{font-size:.78rem;color:var(--faint);display:block;font-weight:400;letter-spacing:1px;
  text-transform:uppercase;font-family:var(--mono);margin-bottom:4px}
.tier p{font-size:13.5px;line-height:1.55;color:var(--dim);margin-top:10px}
.tier ul{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:9px}
.tier li{font-size:13.5px;color:var(--dim);padding-left:20px;position:relative;line-height:1.45}
.tier li::before{content:"";position:absolute;left:0;top:.62em;width:7px;height:7px;border-radius:50%;
  border:1.4px solid var(--accent)}
@media(max-width:880px){.tiers{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.tiers{grid-template-columns:1fr}}

/* ---------- about / coach ---------- */
.coach{display:grid;grid-template-columns:.78fr 1.22fr;gap:48px;align-items:center}
.coach .portrait{--ratio:4/5}
.coach .meta{font-family:var(--mono);font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
@media(max-width:740px){.coach{grid-template-columns:1fr;gap:30px}}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:1.3px;
  padding:14px 26px;border-radius:9px;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;transition:all .16s;border:1px solid transparent;
}
.btn-primary{background:var(--accent);color:#0c0c0e;font-weight:500}
.btn-primary:hover{background:var(--accent-br);box-shadow:0 0 26px var(--glow)}
.btn-ghost{border-color:var(--line-2);color:var(--text);background:transparent}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-br)}

/* ---------- consult cta band ---------- */
.cta-band{position:relative;border:1px solid var(--line-2);border-radius:18px;
  padding:48px;background:var(--bg-2);overflow:hidden}
.cta-band::before{content:"";position:absolute;right:-80px;top:-120px;width:380px;height:380px;
  background:radial-gradient(circle,var(--glow),transparent 65%);pointer-events:none}
.cta-band .inner{position:relative;z-index:1;max-width:34em}
.cta-band h2{margin-bottom:14px}
.cta-band p{color:var(--dim);margin-bottom:26px}
@media(max-width:560px){.cta-band{padding:32px 26px}}

/* ---------- form ---------- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:640px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--dim)}
.field label .req{color:var(--accent)}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:15px;color:var(--text);
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;
  padding:13px 15px;transition:border-color .15s,box-shadow .15s;width:100%;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.55}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6'><path d='M1 1l4 4 4-4' stroke='%23E0B879' stroke-width='1.4' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 15px center}
.honey{position:absolute;left:-9999px;opacity:0}
.form-actions{grid-column:1/-1;display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:4px}
.formnote{font-size:13px;color:var(--faint);grid-column:1/-1;line-height:1.5}
.formstatus{grid-column:1/-1;font-size:14.5px;padding:14px 16px;border-radius:10px;display:none}
.formstatus.ok{display:block;background:rgba(201,154,91,.12);border:1px solid var(--accent);color:var(--accent-br)}
.formstatus.err{display:block;background:rgba(220,120,120,.1);border:1px solid #c97a7a;color:#e6a0a0}
@media(max-width:560px){.form{grid-template-columns:1fr}}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:46px 0 38px;margin-top:20px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:36px}
.foot-top .word{font-weight:700;font-size:16px;letter-spacing:-.02em}
.foot-top .word b{color:var(--accent-br)}
.foot-top p{font-size:14px;color:var(--dim);max-width:28em;margin-top:12px}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
.foot-col a{display:block;text-decoration:none;color:var(--dim);font-size:14px;margin-bottom:10px;transition:color .14s}
.foot-col a:hover{color:var(--text)}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--faint)}
@media(max-width:740px){.foot-top{grid-template-columns:1fr 1fr}.foot-top .brand{grid-column:1/-1}}
@media(max-width:480px){.foot-top{grid-template-columns:1fr}}

/* ---------- reveal on scroll ---------- */
.rv{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* focus visibility floor */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--accent-br);outline-offset:2px;border-radius:4px}
