/* =====================================================================
   TWO COOL · SHARED STYLES
   Loaded by every page. Page-specific styles go inline in each page.
   ===================================================================== */

/* ---------- FONT FACES ---------- */
@font-face{font-family:'Happy Times';src:url('../fonts/HappyTimes-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Happy Times';src:url('../fonts/HappyTimes-Italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Happy Times';src:url('../fonts/HappyTimes-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Apfel Grotezk';src:url('../fonts/ApfelGrotezk-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Apfel Grotezk';src:url('../fonts/ApfelGrotezk-Mittel.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Apfel Grotezk';src:url('../fonts/ApfelGrotezk-Satt.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Apfel Grotezk';src:url('../fonts/ApfelGrotezk-Fett.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Apfel Brukt';src:url('../fonts/ApfelGrotezk-Brukt.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}

/* ---------- TOKENS ---------- */
:root{
  --cream:#F4EEE0; --parchment:#F9F5E9;
  --sand:#EDE7D8; --sand-2:#DFD8C6;
  --ink:#1C1B1A; --ink-soft:#4A4948;
  --pistachio:#C8DA93; --pistachio-deep:#A6BE6A; --pistachio-soft:#E4EDCB;
  --lilac:#D4B8E8; --lilac-soft:#EDE0F4;
  --apricot:#E89B6F; --apricot-soft:#F4C9B0;
  --ash:#8A8682; --ash-soft:#B5B0A8;
  --line:#D8D2C4; --line-soft:#E8E2D4;
  --serif:'Happy Times', Georgia, serif;
  --sans:'Apfel Grotezk', system-ui, sans-serif;
  --brukt:'Apfel Brukt', 'Apfel Grotezk', sans-serif;
}

/* ---------- RESET + BASE ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{touch-action:manipulation;scroll-behavior:auto;-webkit-text-size-adjust:100%}
html,body{background:var(--cream);color:var(--ink)}
body{
  font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.5;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;font-feature-settings:"kern";
  overflow-x:hidden;
}
@media (hover: hover){ body{cursor:none} }
a{color:inherit;text-decoration:none}
img,video,svg{max-width:100%;display:block}
button{font-family:inherit;background:none;border:none;color:inherit;cursor:inherit}
a,button,[role=button]{-webkit-tap-highlight-color:rgba(199,93,44,0.15);-webkit-touch-callout:none}
*:focus-visible{outline:2px solid var(--pistachio-deep);outline-offset:3px;border-radius:2px}
::selection{background:var(--pistachio);color:var(--ink)}
.tabular{font-variant-numeric:tabular-nums}
input,textarea,select{font:inherit;color:inherit;-webkit-appearance:none;border-radius:0}
/* iOS: prevent zoom on input focus */
@media (max-width: 760px){
  input,textarea,select{font-size:16px !important}
}
section[id]{scroll-margin-top:80px}
/* Skip link */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--ink);color:var(--cream);
  padding:12px 18px;border-radius:6px;
  font-family:var(--sans);font-size:14px;
  z-index:9999;
}
.skip-link:focus{left:8px;top:8px}

/* Noise grain */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:210;
  opacity:.045;mix-blend-mode:multiply;
  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'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ---------- CURSOR ---------- */
.cursor-dot,.cursor-ring{position:fixed;left:0;top:0;pointer-events:none;z-index:9999;border-radius:50%;mix-blend-mode:difference;will-change:transform}
.cursor-dot{width:6px;height:6px;background:var(--cream);transform:translate(-50%,-50%)}
.cursor-ring{width:32px;height:32px;border:1px solid var(--cream);transform:translate(-50%,-50%);transition:width .25s cubic-bezier(.22,1,.36,1),height .25s cubic-bezier(.22,1,.36,1),background .25s ease}
.cursor-ring.hover{width:54px;height:54px;background:rgba(200,218,147,0.18)}
@media (hover: none){.cursor-dot,.cursor-ring{display:none}}

/* ---------- CURTAIN ---------- */
.curtain{position:fixed;inset:0;z-index:500;background:var(--ink);pointer-events:none;transform-origin:top;display:none}
body.js-ready .curtain{display:block}

/* ---------- NAV ---------- */
nav.tc-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 36px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  transition:background .3s ease, border-color .3s ease;
}
nav.tc-nav.scrolled{
  background:rgba(244,238,224,0.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid rgba(0,0,0,0.05);
}
nav.tc-nav[data-on-dark].scrolled{
  background:rgba(28,27,26,0.72);
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.brand-mark{display:inline-flex;align-items:center;line-height:0}
.brand-mark img{height:36px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-family:var(--sans);font-weight:400;font-size:14px;letter-spacing:-0.005em;color:var(--ink);position:relative;padding:6px 0}
nav.tc-nav[data-on-dark] .nav-links a{color:var(--cream)}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1px;background:currentColor;
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.nav-links a:hover::after,.nav-links a.current::after{transform:scaleX(1)}

/* MOBILE MENU TRIGGER (hidden by default; shown on small screens) */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  align-items:center;justify-content:center;
  background:transparent;border:none;cursor:pointer;
  padding:0;margin:0;
  color:inherit;
}
.nav-toggle .bars{display:block;width:22px;height:14px;position:relative}
.nav-toggle .bars::before,
.nav-toggle .bars::after{
  content:"";position:absolute;left:0;right:0;height:1.5px;
  background:var(--ink);
  transition:transform .35s cubic-bezier(.65,0,.35,1), top .25s ease;
}
.nav-toggle .bars::before{top:3px}
.nav-toggle .bars::after{top:9px}
nav.tc-nav[data-on-dark] .nav-toggle .bars::before,
nav.tc-nav[data-on-dark] .nav-toggle .bars::after{background:var(--cream)}
body.menu-open .nav-toggle .bars::before{top:6px;transform:rotate(45deg)}
body.menu-open .nav-toggle .bars::after{top:6px;transform:rotate(-45deg)}
body.menu-open .nav-toggle .bars::before,
body.menu-open .nav-toggle .bars::after{background:var(--cream)}

/* MOBILE MENU PANEL (slides down) */
.nav-panel{
  position:fixed;inset:0;
  background:var(--ink);
  color:var(--cream);
  z-index:90;
  display:flex;flex-direction:column;
  padding:88px 24px 32px;
  transform:translateY(-100%);
  transition:transform .55s cubic-bezier(.7,0,.2,1);
  visibility:hidden;
}
body.menu-open .nav-panel{transform:translateY(0);visibility:visible}
.nav-panel-links{
  display:flex;flex-direction:column;gap:4px;
  margin-top:24px;
  border-top:1px solid rgba(255,255,255,0.12);
}
.nav-panel-links a{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding:20px 4px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  color:var(--cream);
  font-family:var(--serif);font-size:32px;line-height:1;letter-spacing:-0.015em;
}
.nav-panel-links a em{font-style:italic;color:var(--pistachio)}
.nav-panel-links a .num{
  font-family:var(--brukt);font-size:11px;color:var(--ash-soft);
  font-style:normal;
}
.nav-panel-links a.current{color:var(--pistachio);position:relative;padding-left:18px}
.nav-panel-links a.current::before{
  content:"";position:absolute;
  left:0;top:50%;
  width:6px;height:6px;border-radius:50%;
  background:var(--pistachio);
  transform:translateY(-50%);
  box-shadow:0 0 12px rgba(200,218,147,0.5);
}
.nav-panel-links a.current .num{color:var(--pistachio)}
.nav-panel-foot{
  margin-top:auto;padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.12);
  font-family:var(--brukt);font-size:12px;color:var(--ash-soft);line-height:1.6;
}
.nav-panel-foot a{color:var(--cream);border-bottom:1px solid var(--ash-soft);padding-bottom:1px}
.nav-right{display:flex;align-items:center;gap:18px}
.sound-toggle{display:inline-flex;align-items:center;gap:8px;font-family:var(--brukt);font-size:12px;color:var(--ink-soft)}
nav.tc-nav[data-on-dark] .sound-toggle{color:var(--ash-soft)}
.sound-dot{width:8px;height:8px;border-radius:50%;background:var(--ash-soft);transition:background .3s ease}
.sound-toggle.on .sound-dot{background:var(--pistachio-deep)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;padding:11px 18px;
  background:var(--ink);color:var(--cream);border-radius:999px;
  font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:-0.005em;
  position:relative;overflow:hidden;
  transition:transform .18s cubic-bezier(.22,1,.36,1);
}
nav.tc-nav[data-on-dark] .nav-cta{background:var(--cream);color:var(--ink)}
.nav-cta::before{
  content:"";position:absolute;inset:0;background:var(--pistachio);
  transform:translateY(101%);transition:transform .35s cubic-bezier(.65,0,.35,1);z-index:0;
}
.nav-cta > *{position:relative;z-index:1}
.nav-cta:hover::before{transform:translateY(0)}
.nav-cta:hover{color:var(--ink)}
.nav-cta .arrow{display:inline-block;transition:transform .25s cubic-bezier(.22,1,.36,1)}
.nav-cta:hover .arrow{transform:translateX(3px)}

/* ---------- SECTION SCAFFOLDING ---------- */
.section{padding:140px 36px}
.section-inner{max-width:1280px;margin:0 auto}
.section-marker{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--brukt);font-size:13px;color:var(--ash);
  margin-bottom:48px;
}
.section-marker .line{display:inline-block;width:0;height:1px;background:var(--ink)}
.section-marker.in-view .line{width:42px;transition:width .55s cubic-bezier(.22,1,.36,1)}
.section-marker .word{letter-spacing:-0.005em}

/* ---------- REVEAL UTILITIES ---------- */
.reveal{opacity:1;transform:translateY(0)}
body.js-ready .reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .9s cubic-bezier(.22,1,.36,1),
             transform .9s cubic-bezier(.22,1,.36,1);
}
body.js-ready .reveal.in{opacity:1;transform:translateY(0)}

/* ---------- MARQUEE ---------- */
.marquee{
  background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 0;overflow:hidden;position:relative;
}
.marquee-track{
  display:flex;gap:48px;white-space:nowrap;
  font-family:var(--serif);font-size:32px;font-style:italic;color:var(--ink);
  will-change:transform;
}
.marquee-track > span{display:inline-flex;gap:48px;align-items:center;flex-shrink:0}
.marquee-track .star{display:inline-block;color:var(--pistachio-deep);font-size:18px;font-style:normal;font-family:var(--sans)}

/* ---------- QUOTE BLOCK ---------- */
.quote{background:var(--ink);color:var(--cream);padding:160px 36px;position:relative;overflow:hidden}
.quote-inner{max-width:920px;margin:0 auto;position:relative}
.quote::before{
  content:"\201C";position:absolute;
  font-family:var(--serif);font-size:clamp(120px, 14vw, 220px);line-height:1;
  top:80px;left:max(40px, calc(50vw - 540px));
  color:var(--lilac);opacity:.4;pointer-events:none;
}
.quote blockquote{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(28px, 3.8vw, 52px);line-height:1.2;letter-spacing:-0.015em;
  color:var(--cream);position:relative;padding-top:40px;
}
.quote blockquote em.h{font-style:italic;color:var(--pistachio)}
.quote cite{
  display:block;margin-top:36px;
  font-family:var(--brukt);font-size:13px;color:var(--ash-soft);
  font-style:normal;letter-spacing:-0.005em;
}
.quote cite::before{
  content:"";display:inline-block;
  width:24px;height:1px;background:var(--ash-soft);
  vertical-align:middle;margin-right:12px;
}

/* ---------- CTA SECTION ---------- */
.cta{background:var(--pistachio);color:var(--ink);padding:140px 36px;position:relative;overflow:hidden}
.cta-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.cta-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--brukt);font-size:13px;color:var(--ink);opacity:.7;
  margin-bottom:40px;
}
.cta-eyebrow .line{width:42px;height:1px;background:var(--ink)}
.cta h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(48px, 8vw, 128px);line-height:0.96;letter-spacing:-0.025em;
  margin-bottom:60px;
}
.cta h2 em{font-style:italic}
.cta h2 .underline{display:inline-block;border-bottom:3px solid var(--ink);padding-bottom:2px}
.cta-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding-top:48px;border-top:1px solid rgba(28,27,26,0.18)}
.cta-cell .cta-label{font-family:var(--brukt);font-size:12px;color:var(--ink);opacity:.7;margin-bottom:10px}
.cta-cell a{font-family:var(--serif);font-size:24px;border-bottom:1px solid var(--ink);padding-bottom:2px}
.cta-cell a:hover{color:var(--ink);background:rgba(255,255,255,0.18)}
.cta-cell em{font-style:italic}

/* ---------- FOOTER ---------- */
footer.tc-foot{background:var(--ink);color:var(--cream);padding:80px 36px 60px}
.foot-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;gap:48px;align-items:center}
.foot-mark img{height:48px;width:auto;display:block;margin:0 auto}
.foot-left,.foot-right{font-family:var(--brukt);font-size:13px;color:var(--ash-soft)}
.foot-right{text-align:right}
.foot-right a{color:var(--cream);border-bottom:1px solid var(--ash-soft);padding-bottom:1px}
.foot-signature{
  margin-top:48px;text-align:center;
  font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ash-soft);
}

/* ---------- RESPONSIVE BASE ---------- */
@media (max-width: 1024px){
  .section{padding:100px 28px}
  .cta-row{grid-template-columns:1fr;gap:32px}
}
@media (max-width: 760px){
  .nav-links,.sound-toggle{display:none}
  .nav-toggle{display:inline-flex}
  /* On mobile, the nav is denser — give it a stronger background even before scroll
     so text doesn't bleed through and stay readable. */
  nav.tc-nav{
    background:rgba(244,238,224,0.92);
    backdrop-filter:saturate(140%) blur(12px);
    -webkit-backdrop-filter:saturate(140%) blur(12px);
  }
  nav.tc-nav[data-on-dark]{
    background:rgba(28,27,26,0.88);
  }
}
@media (max-width: 640px){
  nav.tc-nav{padding:14px 18px}
  .section{padding:80px 20px}
  .marquee-track{font-size:24px;gap:32px}
  .marquee-track > span{gap:32px}
  .quote{padding:100px 20px}
  .quote::before{font-size:80px;top:40px;left:20px}
  .cta{padding:100px 20px}
  .cta h2{font-size:42px}
  footer.tc-foot{padding:60px 20px 40px}
  .foot-inner{grid-template-columns:1fr;text-align:center;gap:24px}
  .foot-right{text-align:center}
  .foot-mark img{margin:0 auto}
}

/* ---------- REDUCED MOTION ---------- */
@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;
  }
  .reveal{opacity:1 !important;transform:none !important}
}

/* =====================================================================
   EMPHASIS DEVICES — hand-underline mark for non-italic emphasis.
   Used 1-2 places per page to vary rhythm.
   ===================================================================== */
.u-mark{
  position:relative;
  display:inline-block;
  color:inherit;
  white-space:nowrap;
}
.u-mark::after{
  content:"";
  position:absolute;
  left:-2%;right:-2%;
  bottom:-0.08em;
  height:0.18em;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12' preserveAspectRatio='none'><path d='M 4 8 C 30 3, 70 11, 110 5 C 150 0, 180 9, 196 6' fill='none' stroke='%23A6BE6A' stroke-width='2.2' stroke-linecap='round'/></svg>");
  background-size:100% 100%;
  background-repeat:no-repeat;
  pointer-events:none;
}
.services .u-mark::after,
.hero .u-mark::after,
.quote .u-mark::after,
.site-foot .u-mark::after,
.tc-foot .u-mark::after{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12' preserveAspectRatio='none'><path d='M 4 8 C 30 3, 70 11, 110 5 C 150 0, 180 9, 196 6' fill='none' stroke='%23C8DA93' stroke-width='2.2' stroke-linecap='round'/></svg>");
}
