/* ============================================================
   Kosma Connect — premium, hand-built styles
   Palette: warm ink + cream + champagne gold. Classical/editorial.
   ============================================================ */

:root{
  --ink:#15110A;
  --ink-2:#211B11;
  --ink-soft:#2C2417;
  --cream:#F6F0E4;
  --paper:#FBF8F1;
  --paper-2:#F2EADA;
  --gold:#C29A4E;
  --gold-deep:#A07B33;
  --gold-soft:#E2CD9C;
  --muted:#6E654F;
  --muted-2:#8A8068;
  --line:rgba(21,17,10,.12);
  --line-light:rgba(246,240,228,.16);

  --serif:"Cormorant Garamond", "Hoefler Text", Garamond, "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

  --maxw:1180px;
  --gutter:clamp(22px, 5vw, 64px);
  --section-y:clamp(72px, 11vw, 148px);
  --radius:2px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1, "liga" 1;
}
/* faint paper grain — premium tactile feel, no stock imagery */
body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:9999;
  opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

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

/* ---------- typography ----------
   Modular scale from 17px base, ratio ~1.333 (perfect fourth):
   body 17px → small 0.82rem → label 0.72rem
   h3 → 1.5–1.7rem → h2 → 2.05–3.4rem → h1 → 2.7–5.1rem
   Optical tracking corrections applied per size tier.
   Line-height differentiated: display 1.0, heading 1.06–1.08, body 1.65
*/
h1,h2,h3{font-family:var(--serif);font-weight:500;margin:0}
h1{
  font-size:clamp(2.7rem, 6.4vw, 5.1rem);
  line-height:1.0;
  letter-spacing:-0.025em; /* optical tightening at display size */
}
h2{
  font-size:clamp(2.05rem, 4.4vw, 3.4rem);
  line-height:1.06;
  letter-spacing:-0.015em; /* tighten at heading scale */
}
h3{
  font-size:clamp(1.35rem, 2.2vw, 1.7rem);
  line-height:1.18; /* looser — subhead needs breathing room */
  letter-spacing:0em;
}
p{margin:0 0 1.1em}
.lead{font-size:clamp(1.12rem,1.7vw,1.34rem);color:var(--muted);line-height:1.62}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.32em; /* correct: small caps need wide tracking */
  text-transform:uppercase;
  font-weight:600;
  color:var(--gold-deep);
  margin:0 0 1.1rem;
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{
  content:"";width:26px;height:1px;background:var(--gold);display:inline-block;
  flex-shrink:0;
}
.eyebrow.center::before{display:none}

.serif-accent{font-family:var(--serif);font-style:italic;color:var(--gold-deep)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
section{padding:var(--section-y) 0}
/* Short decorative rule — deliberate mark, not a structural divider */
.rule{
  height:1px;background:var(--gold);border:0;margin:0 auto;
  width:clamp(48px,8vw,80px);
  display:block;
  opacity:.45;
}

/* ---------- buttons ---------- */
.btn{
  /* CTA color = near-ink on gold, or ink border reverse. Gold reserved for accents only.
     btn--on-dark (hero/offer dark sections): ink fill with cream text — high contrast, not decorative gold */
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-size:.86rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  padding:1.05em 1.9em;border-radius:var(--radius);
  cursor:pointer;transition:background .28s var(--ease), color .28s var(--ease),
    border-color .28s var(--ease), transform .18s var(--ease), box-shadow .18s var(--ease);
  position:relative;
  border:1px solid var(--ink);background:var(--ink);color:var(--cream);
}
.btn:hover{background:transparent;color:var(--ink);transform:translateY(-1px)}
.btn:active{transform:scale(.98);box-shadow:none} /* physical press feel */

/* Gold-bordered ghost variant — nav and secondary use */
.btn--gold{
  background:transparent;
  border-color:var(--gold-deep);
  color:var(--gold-deep);
}
.btn--gold:hover{background:var(--gold-deep);color:var(--cream);transform:translateY(-1px)}
.btn--gold:active{transform:scale(.98)}

.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);background:transparent;color:var(--ink)}

/* On-dark sections: ink fill, cream text — high contrast, unmistakably actionable */
.btn--on-dark{
  background:var(--cream);
  border-color:var(--cream);
  color:var(--ink);
}
.btn--on-dark:hover{background:transparent;color:var(--cream);transform:translateY(-1px)}
.btn--on-dark:active{transform:scale(.98)}

.textlink{
  font-weight:600;font-size:.86rem;letter-spacing:.12em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.5em;color:var(--ink);
}
.textlink .arr{transition:transform .35s var(--ease);color:var(--gold-deep)}
.textlink:hover .arr{transform:translateX(5px)}
.textlink--gold{color:var(--gold-deep)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.15rem var(--gutter);
  transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s var(--ease),border-color .4s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(251,248,241,.86);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  padding-top:.7rem;padding-bottom:.7rem;
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{width:34px;height:34px}
.brand .name{
  font-family:var(--serif);font-size:1.34rem;font-weight:600;letter-spacing:.02em;
  color:var(--cream);transition:color .4s var(--ease);
}
.brand .name b{font-weight:600}
.brand .name .c{color:var(--gold)}
.nav.scrolled .brand .name{color:var(--ink)}
.nav.scrolled .brand .name .c{color:var(--gold-deep)}
.nav-links{display:flex;align-items:center;gap:2.1rem}
.nav-links a:not(.btn){
  font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;
  color:rgba(246,240,228,.82);transition:color .3s var(--ease);
  position:relative;padding-bottom:3px;
}
.nav.scrolled .nav-links a:not(.btn){color:var(--ink-soft)}
/* Underline grows from left — tasteful hover, not a flash */
.nav-links a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--gold);transition:width .3s var(--ease);
}
.nav-links a:not(.btn):hover::after{width:100%}
.nav .btn{padding:.7em 1.3em}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--ink);margin:5px 0;transition:.3s}

/* ---------- hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 90% at 85% -10%, #221B10 0%, transparent 55%),
    linear-gradient(165deg,#17130B 0%,#100D07 100%);
  color:var(--cream);
  padding-top:clamp(140px,18vh,210px);
  padding-bottom:var(--section-y);
}
.hero .wrap{position:relative;z-index:2}
.hero-emblem{
  position:absolute;z-index:1;top:50%;right:-6%;transform:translateY(-50%);
  width:min(680px,62vw);opacity:.06;pointer-events:none;
}
/* Hero layout: left-aligned editorial grid — content in left ~75%, right is negative space */
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:2rem;max-width:820px}
.hero .eyebrow{color:var(--gold-soft)}
.hero .eyebrow::before{background:var(--gold)}
.hero h1{color:var(--cream)}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .lead{color:rgba(246,240,228,.78);max-width:48ch;margin-top:1.4rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.3rem;align-items:center}
.hero-trust{
  margin-top:2.6rem;display:flex;flex-wrap:wrap;gap:1.4rem 2rem;
  font-size:.8rem;letter-spacing:.06em;color:rgba(246,240,228,.6);
  border-top:1px solid var(--line-light);padding-top:1.6rem;max-width:680px;
}
.hero-trust span{display:inline-flex;align-items:center;gap:.55rem}
.hero-trust span::before{content:"";width:5px;height:5px;background:var(--gold);transform:rotate(45deg);flex-shrink:0}

/* ---------- section heads ---------- */
.sec-head{max-width:62ch}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head .lead{margin-top:1.1rem}

/* ---------- problem / quote band ---------- */
.statement{background:var(--paper-2)}
.statement .big{
  font-family:var(--serif);font-size:clamp(1.7rem,3.3vw,2.7rem);line-height:1.26;
  max-width:24ch;font-weight:500;
  letter-spacing:-0.01em;
}
.statement .big em{font-style:italic;color:var(--gold-deep)}
/* Asymmetric split: quote heavier on left */
.statement-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.statement-grid p{color:var(--muted)}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,3rem);margin-top:clamp(2.5rem,5vw,4rem)}
.step{position:relative;padding-top:2rem;border-top:1px solid var(--line)}
/* Large near-transparent background numeral — editorial, not a badge */
.step-num-bg{
  font-family:var(--serif);font-style:italic;
  font-size:6.5rem;
  line-height:1;
  color:var(--gold);
  opacity:.08;
  position:absolute;
  top:0.5rem;right:0;
  pointer-events:none;
  user-select:none;
  letter-spacing:-0.04em;
  font-feature-settings:"lnum" 1;
}
/* Visible label — small, gold, positioned above h3 */
.step .num{
  font-family:var(--serif);font-style:italic;font-size:.92rem;color:var(--gold-deep);
  display:block;margin-bottom:.65rem;letter-spacing:.04em;
}
.step h3{margin-bottom:.5rem}
.step p{color:var(--muted);font-size:1rem;margin:0}

/* ---------- offer ledger (dark) ---------- */
.offer{background:linear-gradient(165deg,#17130B,#100D07);color:var(--cream)}
.offer .eyebrow{color:var(--gold-soft)}
.offer .eyebrow::before{background:var(--gold)}
.offer h2{color:var(--cream)}
.offer .lead{color:rgba(246,240,228,.72)}
.ledger{margin-top:clamp(2.2rem,4vw,3.4rem);border-top:1px solid var(--line-light)}
.ledger-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1rem,3vw,2.5rem);align-items:baseline;
  padding:1.7rem 0;border-bottom:1px solid var(--line-light);
}
.ledger-row .k{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:1.15rem;min-width:2.2ch}
.ledger-row .t h3{color:var(--cream);margin-bottom:.25rem}
.ledger-row .t p{margin:0;color:rgba(246,240,228,.62);font-size:.98rem}
.ledger-row .v{
  font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.3rem);color:var(--gold);white-space:nowrap;text-align:right;
}
.ledger-row .v small{display:block;font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(246,240,228,.45);margin-top:.2rem}

.offer-cta{margin-top:clamp(2.4rem,4vw,3.4rem);display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}
.offer-cta-note{font-size:.85rem;letter-spacing:.04em;color:rgba(246,240,228,.55)}

/* ---------- sticky mobile CTA ---------- */
.mobile-cta{
  display:none;
  position:fixed;left:16px;right:16px;bottom:16px;z-index:90;
  text-align:center;padding:1.05em 1.5em;border-radius:4px;
  background:var(--ink);color:var(--cream);
  font-size:.84rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  box-shadow:0 8px 30px rgba(21,17,10,.32);
  transform:translateY(140%);transition:transform .45s var(--ease);
  border:1px solid var(--ink);
}
.mobile-cta:active{transform:scale(.98) translateY(0)}
.mobile-cta.show{transform:none}

/* ---------- services / bench ---------- */
/* Slight asymmetry: services column slightly narrower than bench card */
.bench-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,6vw,5rem);align-items:start}
.svc-list{list-style:none;margin:1.6rem 0 0;padding:0}
.svc-list li{
  padding:1.15rem 0;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:start;
}
.svc-list li .mk{color:var(--gold-deep);font-family:var(--serif);font-style:italic;font-size:1.05rem;line-height:1.5}
.svc-list li b{font-weight:600}
.svc-list li span.d{display:block;color:var(--muted);font-size:.97rem}
.bench-card{
  background:var(--ink);color:var(--cream);padding:clamp(2rem,4vw,3.2rem);border-radius:var(--radius);
  position:relative;overflow:hidden;
}
.bench-card .emb{position:absolute;right:-30px;bottom:-30px;width:200px;opacity:.08}
.bench-card .eyebrow{color:var(--gold-soft)}
.bench-card .eyebrow::before{background:var(--gold)}
.bench-card .stat{font-family:var(--serif);font-size:clamp(2.6rem,5vw,3.6rem);color:var(--gold);line-height:1;letter-spacing:-0.02em}
.bench-card p{color:rgba(246,240,228,.7);position:relative;z-index:2}

/* ---------- who we serve ---------- */
.serve-tags{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem}
.serve-tags span{
  border:1px solid var(--line);padding:.55em 1.05em;border-radius:40px;
  font-size:.85rem;color:var(--ink-soft);letter-spacing:.02em;
  transition:border-color .25s var(--ease), color .25s var(--ease);
}
.serve-tags span:hover{border-color:var(--gold);color:var(--ink)}

/* ---------- FAQ ---------- */
.faq{background:var(--paper-2)}
.faq-list{margin-top:clamp(2rem,4vw,3rem);border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  font-family:var(--serif);font-size:clamp(1.2rem,2vw,1.5rem);color:var(--ink);font-weight:500;
  transition:color .25s var(--ease);
}
.faq-q:hover{color:var(--gold-deep)}
.faq-q .pm{flex:none;width:22px;height:22px;position:relative;flex-shrink:0}
.faq-q .pm::before,.faq-q .pm::after{
  content:"";position:absolute;background:var(--gold-deep);transition:transform .35s var(--ease), opacity .35s var(--ease);
}
.faq-q .pm::before{top:50%;left:0;width:100%;height:1.5px;transform:translateY(-50%)}
.faq-q .pm::after{left:50%;top:0;height:100%;width:1.5px;transform:translateX(-50%)}
.faq-item[open] .pm::after{transform:translateX(-50%) scaleY(0);opacity:0}
.faq-a{overflow:hidden;color:var(--muted);max-width:74ch;padding-bottom:0;
  max-height:0;transition:max-height .4s var(--ease),padding .4s var(--ease);}
.faq-item[open] .faq-a{padding-bottom:1.6rem}
.faq-a p{margin:0}

/* ---------- candidate strip ---------- */
.candidate{background:var(--ink);color:var(--cream);text-align:center}
.candidate .eyebrow{color:var(--gold-soft);justify-content:center}
.candidate .eyebrow::before{display:none}
.candidate h2{color:var(--cream);max-width:18ch;margin:0 auto;letter-spacing:-0.015em}
.candidate p{color:rgba(246,240,228,.7);max-width:52ch;margin:1.1rem auto 2rem}

/* ---------- contact / form ---------- */
/* Slightly heavier on the form side — the key action */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.contact-aside .lead{margin-top:1.1rem}
.contact-meta{margin-top:2.2rem;border-top:1px solid var(--line);padding-top:1.6rem}
.contact-meta div{display:flex;gap:.8rem;align-items:baseline;margin-bottom:.7rem;font-size:.97rem;color:var(--muted)}
.contact-meta .lbl{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);min-width:74px}

form{display:grid;gap:1.3rem}
.field{display:grid;gap:.5rem}
.field label{
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
  transition:color .25s var(--ease);
}
.field:focus-within label{color:var(--gold-deep)}  /* label tints gold on focus */
.field input,.field textarea,.field select{
  font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:var(--paper);border:0;border-bottom:1.5px solid var(--line);
  padding:.7rem 0;transition:border-color .3s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;
  border-color:var(--gold-deep);
}
.field textarea{resize:vertical;min-height:90px}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.form-note{font-size:.82rem;color:var(--muted-2);margin:0}
.form-msg{font-size:.95rem;padding:1rem 1.2rem;border-radius:var(--radius);display:none}
.form-msg.ok{display:block;background:#1c2a1c;color:#cfe6c6}
.form-msg.err{display:block;background:#2c1a16;color:#f0c9c0}

/* ---------- footer ---------- */
.footer{background:#0E0B06;color:rgba(246,240,228,.6);padding:clamp(3rem,6vw,5rem) 0 2.2rem}
.footer-top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.footer .brand .name{color:var(--cream)}
.footer-blurb{max-width:34ch;margin-top:1rem;font-size:.95rem;line-height:1.6}
.footer-cols{display:flex;gap:clamp(2rem,5vw,4.5rem);flex-wrap:wrap}
.footer-col h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 1rem;font-weight:600}
.footer-col a{display:block;margin-bottom:.6rem;font-size:.92rem;color:rgba(246,240,228,.6);transition:color .25s}
.footer-col a:hover{color:var(--gold-soft)}
.footer-bottom{
  margin-top:clamp(2.5rem,5vw,4rem);padding-top:1.7rem;border-top:1px solid var(--line-light);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:rgba(246,240,228,.4);
}

/* ---------- reveal animation ---------- */
/* translateY only 16px — subtle, not a dramatic bounce */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:880px){
  .statement-grid,.bench-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .steps{grid-template-columns:1fr;gap:0}
  .step{padding:1.6rem 0}
  .ledger-row{grid-template-columns:auto 1fr;row-gap:.4rem}
  .ledger-row .v{grid-column:1/-1;text-align:left;margin-top:.4rem}
}
@media (max-width:760px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);
    background:var(--ink);flex-direction:column;align-items:flex-start;justify-content:center;
    padding:2rem var(--gutter);gap:1.6rem;transform:translateX(100%);transition:transform .4s var(--ease);
  }
  .nav-links.open{transform:none}
  .nav-links a:not(.btn){color:var(--cream);font-size:1rem}
  .nav-toggle{display:block;z-index:101}
  .nav.menu-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav.menu-open .nav-toggle span:nth-child(2){opacity:0}
  .nav.menu-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  .field--row{grid-template-columns:1fr}
  .mobile-cta{display:block}
  body{padding-bottom:0}
  /* Hide large background step numeral on mobile — too much visual noise at small size */
  .step-num-bg{display:none}
}
