/* ═══════════════════════════════════════════════════
   METHOD CO. — Quiet Empire design system
   Warm editorial palette · display serif · no mono
   Dark + light both tuned as first-class themes
   ═══════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}

/* ── DEFAULT: DARK ─── warm near-black, paper cream ink */
:root{
  --bg:#16151230;           /* placeholder; overwritten below */
  --maxw:1320px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* type stacks */
  --serif:'Fraunces','Playfair Display',Georgia,serif;
  --sans:'Inter','Helvetica Neue',Arial,sans-serif;
}

/* DARK (default) */
html{
  --bg:#16151230;
}
html[data-theme="dark"], html:not([data-theme]){
  --bg:#15120e;              /* warm black */
  --bg-alt:#1b1813;
  --bg-soft:#221e18;
  --ink:#f3ede0;             /* warm cream text */
  --ink-dim:#b4ac9d;
  --ink-faint:#7a7264;
  --line:rgba(243,237,224,0.10);
  --line-strong:rgba(243,237,224,0.22);
  --line-hair:rgba(243,237,224,0.06);
  --accent:#d4a574;          /* warm sepia */
  --accent-ink:#15120e;
  --paper:#f3ede0;
  --paper-ink:#15120e;
  --grain-opacity:.035;
}

/* LIGHT — cream paper */
html[data-theme="light"]{
  --bg:#f5f0e6;              /* warm cream */
  --bg-alt:#ece5d7;
  --bg-soft:#e3dcc9;
  --ink:#1a1712;             /* warm forest-ink */
  --ink-dim:#564f41;
  --ink-faint:#8a8272;
  --line:rgba(26,23,18,0.12);
  --line-strong:rgba(26,23,18,0.26);
  --line-hair:rgba(26,23,18,0.06);
  --accent:#a06a3a;          /* deeper ochre for contrast */
  --accent-ink:#f5f0e6;
  --paper:#15120e;
  --paper-ink:#f3ede0;
  --grain-opacity:.045;
}

html,body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-weight:400;line-height:1.55;
  letter-spacing:-.005em;
  transition:background-color .7s var(--ease),color .7s var(--ease);
}
html{overflow-x:clip}
body{overflow-x:clip}
body{padding-top:64px}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--accent);color:var(--accent-ink)}

/* Subtle paper grain — ties the whole site together */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .9 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:var(--grain-opacity);mix-blend-mode:overlay;
}

/* ─── TYPE ────────────────────────────────────── */
.eyebrow{
  font-family:var(--sans);font-size:12px;font-weight:500;
  letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint);
}
.lead{font-size:18px;line-height:1.55;color:var(--ink-dim);max-width:58ch}
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.022em}

/* ─── NAV — quiet editorial ─────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:64px;background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line-hair);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;height:100%;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:40px;
  padding:0 28px;
}
.nav-logo{
  display:flex;align-items:center;gap:12px;
  font-family:var(--serif);font-size:20px;font-weight:500;letter-spacing:-.02em;
}
.nav-logo svg{width:22px;height:22px;color:var(--ink)}
.nav-links{display:flex;gap:2px;justify-content:center;align-items:center}
.nav-links a{
  font-family:var(--sans);font-size:14px;font-weight:400;
  color:var(--ink-dim);padding:8px 14px;border-radius:100px;
  transition:color .25s,background-color .25s;
}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-cta{
  font-size:13.5px!important;padding:9px 18px!important;
  color:var(--bg)!important;background:var(--ink);
  border-radius:100px;font-weight:500!important;
  transition:transform .3s,background-color .3s;
}
.nav-cta:hover{background:var(--accent);color:var(--accent-ink)!important;transform:translateY(-1px)}
.theme-toggle{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);color:var(--ink-dim);
  transition:all .35s;
}
.theme-toggle:hover{color:var(--ink);border-color:var(--line-strong);transform:rotate(-15deg)}
.nav-toggle{display:none;width:36px;height:36px;flex-direction:column;justify-content:center;gap:5px;align-items:center;border:1px solid var(--line);border-radius:50%;position:relative;z-index:101}
.nav-toggle span{display:block;height:1.5px;width:15px;background:var(--ink);transition:transform .3s var(--ease),opacity .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media(max-width:920px){
  .nav-inner{padding:0 18px;gap:12px}
  .nav-links{
    position:fixed;top:64px;left:0;right:0;
    height:calc(100vh - 64px);height:calc(100dvh - 64px);
    background:var(--bg);flex-direction:column;gap:0;padding:8px 24px 40px;
    border-top:1px solid var(--line);
    transform:translateY(-110vh);transition:transform .45s var(--ease);
    justify-content:flex-start;align-items:stretch;
    z-index:99;overflow-y:auto;pointer-events:none;visibility:hidden;
  }
  .nav-links.open{transform:none;pointer-events:auto;visibility:visible}
  .nav-links a{padding:22px 12px;font-size:22px;border-bottom:1px solid var(--line-hair);font-family:var(--serif);border-radius:0}
  .nav-toggle{display:flex}
  .nav-cta{display:none}
  body.nav-open{overflow:hidden}
}
@media(max-width:480px){
  .nav-inner{padding:0 14px;gap:8px}
  .nav-logo span{font-size:17px}
  .nav-logo svg{width:20px;height:20px}
  .nav-right{gap:6px}
  .theme-toggle{width:34px;height:34px}
  .nav-toggle{width:34px;height:34px}
}

/* ─── HERO ─ single viewport, parallax without extra scroll ─── */
.hero{
  position:relative;min-height:calc(100vh - 64px);  /* exactly one viewport, no dead space */
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse 80% 50% at 50% 40%, color-mix(in srgb,var(--accent) 9%,transparent) 0%, transparent 65%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-alt) 100%);
}
.hero-pin{
  position:relative;width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
}
/* soft aura behind hero title to prevent pure-dark voids when parallaxing */
.hero-pin::before{
  content:'';position:absolute;top:50%;left:50%;width:min(80vw,900px);aspect-ratio:1;
  transform:translate(-50%,-50%);pointer-events:none;z-index:0;
  background:radial-gradient(circle, color-mix(in srgb,var(--accent) 10%,transparent) 0%, transparent 60%);
}
/* ambient ring for depth */
.hero-pin::after{
  content:'';position:absolute;top:50%;left:50%;width:min(62vw,740px);aspect-ratio:1;
  transform:translate(-50%,-50%);pointer-events:none;z-index:0;
  border:1px solid color-mix(in srgb,var(--accent) 18%,transparent);border-radius:50%;
  opacity:.4;
}
.hero-content{
  max-width:var(--maxw);width:100%;
  padding:0 40px;position:relative;z-index:2;text-align:center;
}
.hero-eyebrow{
  opacity:0;transform:translateY(20px);
  transition:opacity 1.2s var(--ease-out) .2s,transform 1.2s var(--ease-out) .2s;
  display:inline-block;padding:6px 16px;border:1px solid var(--line);border-radius:100px;
  background:color-mix(in srgb,var(--bg-alt) 60%,transparent);
}
.hero.in .hero-eyebrow{opacity:1;transform:none}

.hero-title{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(56px,11vw,168px);line-height:.95;letter-spacing:-.035em;
  margin:32px 0;color:var(--ink);
}
.hero-title .word{display:inline-block;overflow:hidden;vertical-align:bottom;padding:0 .04em}
.hero-title .word > span{display:inline-block;transform:translateY(105%);transition:transform 1.4s var(--ease-out)}
.hero.in .hero-title .word > span{transform:none}
.hero-title .word:nth-child(2) > span{transition-delay:.1s}
.hero-title .word:nth-child(3) > span{transition-delay:.2s}
.hero-title .word:nth-child(4) > span{transition-delay:.3s}
.hero-title .word:nth-child(5) > span{transition-delay:.4s}
.hero-title .accent{color:var(--accent);font-style:italic;font-weight:350}

.hero-sub{
  font-size:19px;line-height:1.5;color:var(--ink-dim);max-width:44ch;margin:24px auto 0;
  opacity:0;transform:translateY(20px);
  transition:opacity 1.2s var(--ease-out) .7s,transform 1.2s var(--ease-out) .7s;
}
.hero.in .hero-sub{opacity:1;transform:none}

.hero-cta-row{
  margin-top:44px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);
  transition:opacity 1.2s var(--ease-out) .9s,transform 1.2s var(--ease-out) .9s;
}
.hero.in .hero-cta-row{opacity:1;transform:none}

/* hero frame marks (super subtle) */
.hero-frame{
  position:absolute;inset:32px;pointer-events:none;z-index:1;
  border:1px solid var(--line-hair);
}
.hero-mark{
  position:absolute;font-family:var(--sans);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-faint);z-index:2;
}
.hero-mark.tl{top:52px;left:52px}
.hero-mark.tr{top:52px;right:52px;text-align:right}
.hero-mark.bl{bottom:52px;left:52px}
.hero-mark.br{bottom:52px;right:52px;text-align:right}

.hero-scroll-cue{
  position:absolute;bottom:48px;left:50%;transform:translateX(-50%);
  font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);display:flex;flex-direction:column;align-items:center;gap:10px;
  opacity:0;transition:opacity 1.2s var(--ease-out) 1.4s;
}
.hero.in .hero-scroll-cue{opacity:1}
.hero-scroll-cue::after{
  content:'';width:1px;height:40px;background:var(--line-strong);
  animation:scrollHint 2.2s ease-in-out infinite;transform-origin:top;
}
@keyframes scrollHint{0%,100%{transform:scaleY(0);opacity:0}50%{transform:scaleY(1);opacity:1}}

@media(max-width:760px){
  .hero-frame{inset:10px}
  /* hide cosmetic corner marks on mobile — the eyebrow + content already cover these */
  .hero-mark{display:none}
  .hero-scroll-cue{bottom:28px;font-size:10px}
  .hero-scroll-cue::after{height:24px}
}

/* ─── BUTTONS ─────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;border-radius:100px;
  font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:-.005em;
  border:1px solid transparent;cursor:pointer;
  transition:all .35s var(--ease);
}
.btn-fill{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-fill:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);transform:translateY(-1px)}
.btn-ghost{border-color:var(--line-strong);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--bg);transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-accent:hover{background:var(--ink);border-color:var(--ink);color:var(--bg);transform:translateY(-1px)}
.btn .arr{transition:transform .35s}
.btn:hover .arr{transform:translateX(4px)}

/* ─── SECTION BASE ────────────────────────────── */
section{position:relative}
.section{padding:160px 0;position:relative}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative}

/* Hairline thread — editorial signature */
.thread{
  position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--line-hair);
  pointer-events:none;transform-origin:top;
}
.section-header{text-align:center;max-width:820px;margin:0 auto 120px}
.section-header .eyebrow{margin-bottom:24px}
.section-header h2{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(40px,6vw,88px);line-height:1.02;letter-spacing:-.03em;
  margin-bottom:24px;
}
.section-header h2 .accent{color:var(--accent);font-style:italic;font-weight:350}
.section-header .lead{margin:0 auto}

/* ─── SCROLLYTELLING SCENE (pinned manifesto) ─── */
.scene{
  position:relative;height:320vh;     /* 4 lines, ~80vh per line */
  background:
    radial-gradient(ellipse 80% 40% at 50% 50%, color-mix(in srgb,var(--accent) 6%,transparent) 0%, transparent 65%),
    linear-gradient(180deg, color-mix(in srgb,var(--ink) 3%,transparent) 0%, transparent 20%, transparent 80%, color-mix(in srgb,var(--ink) 3%,transparent) 100%);
}
.scene-pin{
  position:sticky;top:64px;height:calc(100vh - 64px);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  border-top:1px solid var(--line-hair);
  border-bottom:1px solid var(--line-hair);
}
/* ambient rings behind scene — rotate + scale with scroll progress */
.scene{--scene-p:0}
.scene-pin::before{
  content:'';position:absolute;top:50%;left:50%;
  width:min(74vw,860px);aspect-ratio:1;
  transform:translate(-50%,-50%) rotate(calc(var(--scene-p,0) * 180deg)) scale(calc(.85 + var(--scene-p,0) * .3));
  border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);
  border-radius:50%;opacity:.42;pointer-events:none;z-index:0;
  transition:opacity .4s ease;
}
.scene-pin::after{
  content:'';position:absolute;top:50%;left:50%;
  width:min(48vw,540px);aspect-ratio:1;
  transform:translate(-50%,-50%) rotate(calc(var(--scene-p,0) * -240deg));
  border:1px solid color-mix(in srgb,var(--accent) 22%,transparent);
  border-radius:50%;opacity:.28;pointer-events:none;z-index:0;
}
.scene-lines{z-index:1}
.scene-lines{
  max-width:1100px;padding:0 40px;position:relative;text-align:center;
}
.scene-line{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:350;
  font-size:clamp(36px,6.2vw,92px);line-height:1.05;letter-spacing:-.028em;
  color:var(--ink);
  opacity:0;transform:translateY(30px);visibility:hidden;
  transition:opacity .55s var(--ease-out),transform .55s var(--ease-out),visibility 0s linear .55s;
  padding:0 20px;pointer-events:none;
}
.scene-line.active{opacity:1;transform:none;visibility:visible;pointer-events:auto;
  transition:opacity .55s var(--ease-out),transform .55s var(--ease-out),visibility 0s linear 0s;
}
.scene-line .accent{color:var(--accent);font-style:italic}
.scene-line .mute{color:var(--ink-faint);font-weight:300}
.scene-line:first-of-type{position:relative}   /* keep layout height */
.scene-counter{
  position:absolute;bottom:48px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;
}
.scene-counter .dot{
  width:20px;height:2px;background:var(--line-strong);border-radius:2px;
  transition:background-color .45s,width .45s;
}
.scene-counter .dot.active{background:var(--accent);width:36px}

/* ─── BRANDS: pinned list + preview (Kering-esque) ─── */
.brands{
  position:relative;padding:160px 0;
  border-top:1px solid var(--line-hair);
}
.brands-inner{
  display:grid;grid-template-columns:1fr 1.1fr;gap:80px;
  max-width:var(--maxw);margin:0 auto;padding:0 28px;
  align-items:flex-start;
}
.brands-list{display:flex;flex-direction:column;gap:4px;position:relative}
.brand-row{
  position:relative;display:flex;flex-direction:column;gap:10px;
  padding:32px 0;
  border-bottom:1px solid var(--line-hair);
  cursor:pointer;text-decoration:none;color:inherit;
  transition:padding-left .5s var(--ease);
}
.brand-row:first-child{border-top:1px solid var(--line-hair)}
.brand-row:hover{padding-left:20px}
.brand-row .meta-top{
  display:flex;align-items:center;gap:14px;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);
}
.brand-row .meta-top .num{color:var(--ink-dim)}
.brand-row .name{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(40px,5.4vw,82px);line-height:1;letter-spacing:-.03em;
  color:var(--ink);
  transition:color .45s var(--ease);
  display:flex;align-items:baseline;gap:20px;
}
.brand-row .name .arr{
  font-family:var(--sans);font-size:14px;letter-spacing:0;text-transform:none;
  color:var(--ink-faint);opacity:0;transform:translateX(-12px);
  transition:opacity .45s var(--ease),transform .45s var(--ease),color .3s;
}
.brand-row:hover .name{color:var(--accent)}
.brand-row:hover .name .arr{opacity:1;transform:none;color:var(--accent)}
.brand-row .tag{
  font-size:14px;color:var(--ink-dim);max-width:50ch;line-height:1.5;
}

/* preview pane (sticky on right) */
.brands-preview-wrap{position:sticky;top:140px;height:520px}
.brand-preview{
  position:absolute;inset:0;
  border-radius:4px;overflow:hidden;
  border:1px solid var(--line);
  background:var(--bg-alt);
  opacity:0;transform:scale(.97) translateY(10px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
  display:flex;align-items:center;justify-content:center;
}
.brand-preview.active{opacity:1;transform:none;z-index:2}
.brand-preview-label{
  position:absolute;bottom:28px;left:28px;right:28px;
  display:flex;justify-content:space-between;align-items:end;gap:20px;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);z-index:3;
}
.brand-preview-label .serif{font-family:var(--serif);font-size:24px;letter-spacing:-.02em;text-transform:none;color:var(--ink)}
.brand-preview-corner{
  position:absolute;top:28px;left:28px;right:28px;
  display:flex;justify-content:space-between;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);z-index:3;
}
/* visuals — abstract monogram scenes (not photos) */
.preview-scene{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.preview-scene svg{width:46%;color:var(--ink);opacity:.92}
.preview-scene.bg-a{background:linear-gradient(145deg,var(--bg-alt),var(--bg-soft))}
.preview-scene.bg-b{background:linear-gradient(145deg,var(--bg-soft),var(--bg-alt))}
.preview-scene.bg-c{background:radial-gradient(circle at 30% 30%,var(--bg-soft),var(--bg-alt))}
.preview-scene.bg-d{background:radial-gradient(circle at 70% 70%,var(--bg-soft),var(--bg-alt))}
.preview-scene.bg-e{background:linear-gradient(35deg,var(--bg-alt),var(--bg-soft) 60%,var(--bg-alt))}
.preview-rings{position:absolute;inset:0;pointer-events:none}
.preview-rings::before,.preview-rings::after{
  content:'';position:absolute;border-radius:50%;border:1px solid var(--line);
}
.preview-rings::before{top:-20%;left:-10%;width:60%;aspect-ratio:1}
.preview-rings::after{bottom:-15%;right:-5%;width:45%;aspect-ratio:1;border-color:var(--accent);opacity:.4}

@media(max-width:900px){
  .brands-inner{grid-template-columns:1fr;gap:40px}
  .brands-preview-wrap{display:none}
  .brand-row:hover{padding-left:0}
}

/* ─── PRINCIPLES — horizontal rail (gallery) ──── */
.principles-rail-wrap{
  position:relative;overflow:hidden;padding:0 0 140px;
}
.principles-rail{
  display:flex;gap:24px;padding:0 28px;
  overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.principles-rail::-webkit-scrollbar{display:none}
.principle-card{
  flex:0 0 clamp(300px,30vw,440px);
  scroll-snap-align:start;
  padding:56px 40px;
  background:var(--bg-alt);
  border:1px solid var(--line);
  border-radius:4px;
  min-height:480px;
  display:flex;flex-direction:column;gap:24px;
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease),border-color .3s;
}
.principle-card:hover{transform:translateY(-6px);border-color:var(--line-strong)}
.principle-card .roman{
  font-family:var(--serif);font-weight:350;font-size:72px;line-height:1;
  color:var(--accent);letter-spacing:-.02em;font-style:italic;
}
.principle-card h3{
  font-family:var(--serif);font-weight:350;
  font-size:32px;line-height:1.08;letter-spacing:-.022em;
  max-width:16ch;color:var(--ink);
}
.principle-card p{
  color:var(--ink-dim);font-size:15.5px;line-height:1.6;max-width:34ch;margin-top:auto;
}
.principle-card .tag{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);
}

/* ─── FOUNDER ─────────────────────────────────── */
.founder{padding:180px 0;border-top:1px solid var(--line-hair)}
.founder-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:100px;align-items:center;
}
.founder-text .eyebrow{margin-bottom:24px}
.founder-text h2{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(36px,5vw,76px);line-height:1.02;letter-spacing:-.03em;margin-bottom:32px;
}
.founder-text h2 .accent{color:var(--accent);font-style:italic}
.founder-text p{color:var(--ink-dim);font-size:17px;line-height:1.68;margin-bottom:18px;max-width:50ch}
.founder-card{
  position:relative;aspect-ratio:4/5;
  border:1px solid var(--line);border-radius:4px;
  background:var(--bg-alt);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.founder-card .mono{
  width:52%;color:var(--ink);opacity:.9;z-index:2;
  filter:drop-shadow(0 2px 20px rgba(0,0,0,.2));
}
.founder-card .halo{
  position:absolute;top:10%;left:10%;right:10%;bottom:10%;
  border-radius:50%;
  background:radial-gradient(circle,var(--accent) 0%,transparent 65%);
  opacity:.22;filter:blur(40px);
}
.founder-card .corner-label{
  position:absolute;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);z-index:10;
  background:color-mix(in srgb,var(--bg-alt) 78%,transparent);
  padding:4px 8px;border-radius:2px;backdrop-filter:blur(4px);
}
.founder-card .corner-label.tl{top:24px;left:24px}
.founder-card .corner-label.br{bottom:24px;right:24px}
.founder-cta{margin-top:40px;display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:900px){.founder-inner{grid-template-columns:1fr;gap:56px}}

/* ─── CONTACT — paper inversion ──────────────── */
.contact{
  padding:180px 40px;background:var(--paper);color:var(--paper-ink);
  position:relative;overflow:hidden;
}
.contact .ink-accent{color:var(--accent)}
.contact-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
.contact .eyebrow{color:color-mix(in srgb,var(--paper-ink) 55%,transparent)}
.contact h2{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(52px,8vw,132px);line-height:.98;letter-spacing:-.035em;margin:24px 0 48px;
  max-width:16ch;
}
.contact h2 .accent{color:var(--accent);font-style:italic;font-weight:350}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  padding-top:48px;border-top:1px solid color-mix(in srgb,var(--paper-ink) 18%,transparent);
}
.contact-grid .col .lbl{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:color-mix(in srgb,var(--paper-ink) 50%,transparent);margin-bottom:12px;
}
.contact-grid .col .val{font-size:19px;color:var(--paper-ink)}
.contact-grid .col a.val{
  border-bottom:1px solid color-mix(in srgb,var(--paper-ink) 30%,transparent);
  padding-bottom:3px;transition:color .25s,border-color .25s;
}
.contact-grid .col a.val:hover{color:var(--accent);border-color:var(--accent)}
.contact-grid .col p{color:color-mix(in srgb,var(--paper-ink) 70%,transparent);font-size:15px;line-height:1.6;max-width:36ch}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:40px}}

/* ─── FOOTER ──────────────────────────────────── */
.footer{
  background:var(--bg);color:var(--ink-dim);
  border-top:1px solid var(--line-hair);padding:100px 28px 32px;
}
.footer-inner{max-width:var(--maxw);margin:0 auto}
.footer-top{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:64px;border-bottom:1px solid var(--line-hair);
}
.footer-brand .nav-logo{font-size:22px}
.footer-brand svg{width:24px;height:24px;color:var(--ink);margin-right:12px}
.footer-brand p{font-size:14px;color:var(--ink-dim);line-height:1.65;max-width:32ch;margin-top:20px}
.footer-col h4{
  font-size:12px;text-transform:uppercase;letter-spacing:.22em;
  color:var(--ink);margin-bottom:20px;font-weight:500;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:11px}
.footer-col a{font-size:14px;color:var(--ink-dim);transition:color .25s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{
  display:flex;justify-content:space-between;padding-top:32px;
  font-size:12px;letter-spacing:.12em;color:var(--ink-faint);flex-wrap:wrap;gap:16px;
}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:span 2}}

/* ─── REVEAL / MOTION ─────────────────────────── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal-slow{transition:opacity 1.6s var(--ease-out),transform 1.6s var(--ease-out)}
.stagger > *{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.stagger.in > *{opacity:1;transform:none}
.stagger.in > *:nth-child(1){transition-delay:0ms}
.stagger.in > *:nth-child(2){transition-delay:90ms}
.stagger.in > *:nth-child(3){transition-delay:180ms}
.stagger.in > *:nth-child(4){transition-delay:270ms}
.stagger.in > *:nth-child(5){transition-delay:360ms}
.stagger.in > *:nth-child(6){transition-delay:450ms}

/* ─── SUB-BRAND PAGES ─────────────────────────── */
.sub-hero{
  padding:120px 28px 100px;position:relative;
  border-bottom:1px solid var(--line-hair);text-align:center;
}
.sub-hero .num{
  display:inline-block;margin-bottom:28px;
  font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint);
  padding:6px 16px;border:1px solid var(--line);border-radius:100px;
}
.sub-hero h1{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(52px,10vw,160px);line-height:.95;letter-spacing:-.04em;
  max-width:18ch;margin:0 auto;
}
.sub-hero h1 .accent{color:var(--accent);font-style:italic;font-weight:350}
.sub-hero .lede{
  max-width:60ch;margin:40px auto 0;color:var(--ink-dim);
  font-size:18px;line-height:1.6;
}
.sub-hero .actions{margin-top:44px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Catalog — product grid */
.catalog{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
  max-width:var(--maxw);margin:0 auto;padding:0 28px;
}
.cat-item{
  grid-column:span 4;
  padding:40px 32px;
  background:var(--bg-alt);
  border:1px solid var(--line);border-radius:4px;
  display:flex;flex-direction:column;gap:18px;
  text-decoration:none;color:inherit;
  min-height:340px;position:relative;
  transition:transform .45s var(--ease),border-color .3s,background-color .3s;
}
.cat-item:hover{transform:translateY(-6px);border-color:var(--line-strong);background:var(--bg-soft)}
.cat-item.span-6{grid-column:span 6}
.cat-item.span-8{grid-column:span 8}
.cat-item.span-12{grid-column:span 12}
.cat-item .top-row{display:flex;justify-content:space-between;align-items:center}
.cat-item .top-row .tag{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);
}
.cat-item .top-row .num{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);
}
.cat-item h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(24px,2.4vw,32px);line-height:1.1;letter-spacing:-.02em;
  color:var(--ink);
}
.cat-item p{color:var(--ink-dim);font-size:15px;line-height:1.6;max-width:40ch}
.cat-item .bottom{
  margin-top:auto;display:flex;justify-content:space-between;align-items:baseline;
  padding-top:24px;border-top:1px solid var(--line-hair);
}
.cat-item .price{font-family:var(--serif);font-size:20px;letter-spacing:-.01em;color:var(--ink)}
.cat-item .price .strike{color:var(--ink-faint);text-decoration:line-through;margin-right:10px;font-size:15px}
.cat-item .cta{
  font-size:13.5px;color:var(--ink-dim);display:flex;align-items:center;gap:8px;
  transition:color .25s,transform .3s;
}
.cat-item:hover .cta{color:var(--accent);transform:translateX(4px)}

@media(max-width:960px){
  .cat-item,.cat-item.span-6,.cat-item.span-8,.cat-item.span-12{grid-column:span 6}
}
@media(max-width:640px){
  .cat-item,.cat-item.span-6,.cat-item.span-8,.cat-item.span-12{grid-column:span 12;min-height:auto}
}

.section-title{
  text-align:center;max-width:820px;margin:0 auto 80px;
}
.section-title .eyebrow{margin-bottom:20px}
.section-title h2{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(36px,5.5vw,72px);line-height:1.02;letter-spacing:-.03em;
}

/* Back link */
.back{
  position:fixed;top:84px;left:28px;z-index:50;
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:var(--ink-dim);
  padding:9px 18px;background:color-mix(in srgb,var(--bg-alt) 80%,transparent);
  border:1px solid var(--line);border-radius:100px;
  backdrop-filter:blur(10px);transition:all .3s;
}
.back:hover{color:var(--accent);border-color:var(--line-strong);transform:translateX(-3px)}

/* ─── PRODUCT DETAIL PAGE ─────────────────────── */
.detail{
  min-height:calc(100vh - 64px);
  display:grid;grid-template-columns:1fr 1fr;
}
.detail-viz{
  background:var(--bg-alt);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;padding:80px 40px;
  border-right:1px solid var(--line);
}
.detail-viz .halo{
  position:absolute;top:20%;left:20%;right:20%;bottom:20%;border-radius:50%;
  background:radial-gradient(circle,var(--accent) 0%,transparent 70%);
  opacity:.2;filter:blur(50px);
}
.detail-viz .mark{width:60%;color:var(--ink);opacity:.88;z-index:2;position:relative}
.detail-viz .corner{
  position:absolute;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);z-index:3;
}
.detail-viz .tl{top:40px;left:40px}
.detail-viz .tr{top:40px;right:40px;text-align:right}
.detail-viz .bl{bottom:40px;left:40px}
.detail-viz .br{bottom:40px;right:40px;text-align:right}
.detail-info{padding:100px 60px;display:flex;flex-direction:column;justify-content:center;gap:28px;max-width:640px}
.detail-info .eyebrow{margin-bottom:0}
.detail-info h1{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(40px,5.5vw,76px);line-height:.98;letter-spacing:-.035em;
}
.detail-info h1 .accent{color:var(--accent);font-style:italic}
.detail-info .price{
  font-family:var(--serif);font-size:28px;color:var(--ink);letter-spacing:-.01em;
  display:flex;align-items:baseline;gap:14px;
}
.detail-info .price .strike{color:var(--ink-faint);text-decoration:line-through;font-size:20px}
.detail-info .price .note{font-family:var(--sans);font-size:13px;color:var(--ink-faint);letter-spacing:.02em}
.detail-info .desc{color:var(--ink-dim);font-size:17px;line-height:1.65;max-width:48ch}
.detail-info .specs{
  border-top:1px solid var(--line-hair);padding-top:28px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px 32px;
}
.detail-info .specs .spec{display:flex;flex-direction:column;gap:4px}
.detail-info .specs .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint)}
.detail-info .specs .val{font-size:14.5px;color:var(--ink)}
.detail-info .buy{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
@media(max-width:900px){
  .detail{grid-template-columns:1fr}
  .detail-viz{border-right:none;border-bottom:1px solid var(--line);min-height:480px}
  .detail-info{padding:60px 28px}
}

/* ─── IMAGERY ─ clean, quiet, fade-in on load ─── */
.detail-viz{padding:0}
.detail-viz .cover-wrap{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  padding:56px;z-index:2;
}
.detail-viz .cover{
  max-width:100%;max-height:100%;object-fit:contain;
  border-radius:6px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.55), 0 10px 30px -10px rgba(0,0,0,.35);
  opacity:0;transform:translateY(18px) scale(.985);
  transition:opacity 1.1s var(--ease-out) .15s,transform 1.1s var(--ease-out) .15s;
}
.detail-viz .cover.in{opacity:1;transform:none}
.detail-viz .mark{opacity:.06}  /* keep SVG as faint watermark behind image */
[data-theme="light"] .detail-viz .cover{
  box-shadow:0 20px 60px -20px rgba(80,60,40,.25), 0 8px 20px -8px rgba(80,60,40,.18);
}

/* Catalog row thumbnails (optional — small, quiet) */
.cat-item .cat-thumb{
  display:block;width:100%;aspect-ratio:5/3;overflow:hidden;
  border-radius:3px;margin:-8px 0 18px;
  background:var(--bg-soft);
  border:1px solid var(--line-hair);
}
.cat-item .cat-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease-out),filter .6s var(--ease);
  filter:saturate(.92);
}
.cat-item:hover .cat-thumb img{transform:scale(1.04);filter:saturate(1.05)}

/* Sub-hero ambient image backdrop (for leaf pages like HVAC/Tutoring) */
.sub-hero.has-bg{position:relative;overflow:hidden;isolation:isolate}
.sub-hero.has-bg .sub-hero-bg{
  position:absolute;inset:0;z-index:-1;
  background-position:center;background-size:cover;
  opacity:0;transform:scale(1.04);
  transition:opacity 1.6s var(--ease-out),transform 2.2s var(--ease-out);
}
.sub-hero.has-bg.in .sub-hero-bg{opacity:.16;transform:scale(1);filter:saturate(.55)}
.sub-hero.has-bg--quiet.in .sub-hero-bg{opacity:.08;filter:saturate(.3) blur(4px)}
.sub-hero.has-bg::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,var(--bg) 0%,transparent 35%,transparent 65%,var(--bg) 100%),
    radial-gradient(ellipse at center,transparent 0%,rgba(21,18,14,.45) 100%);
  pointer-events:none;
}
[data-theme="light"] .sub-hero.has-bg::after{
  background:
    linear-gradient(180deg,var(--bg) 0%,transparent 35%,transparent 65%,var(--bg) 100%),
    radial-gradient(ellipse at center,transparent 0%,rgba(245,240,230,.55) 100%);
}
[data-theme="light"] .sub-hero.has-bg.in .sub-hero-bg{opacity:.14}

/* Media page — YouTube thumbnail grid */
.media-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  max-width:var(--maxw);margin:0 auto;padding:0 28px;
}
.media-grid a, .media-grid .media-tile{
  display:block;aspect-ratio:16/9;overflow:hidden;
  border:1px solid var(--line-hair);border-radius:3px;
  background:var(--bg-alt);position:relative;
  transition:border-color .35s,transform .5s var(--ease),opacity .8s var(--ease-out);
  opacity:0;transform:translateY(10px);
}
.media-grid a.in, .media-grid .media-tile.in{opacity:1;transform:none}
.media-grid a:hover{border-color:var(--accent);transform:translateY(-3px)}
.media-grid img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease-out),filter .6s var(--ease);
  filter:saturate(.9);
}
.media-grid a:hover img{transform:scale(1.05);filter:saturate(1.05)}
.media-grid .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:rgba(245,240,230,.85);pointer-events:none;
  opacity:0;transition:opacity .35s;
}
.media-grid a:hover .play{opacity:1}
.media-grid .play svg{width:44px;height:44px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
@media(max-width:900px){.media-grid{grid-template-columns:repeat(2,1fr);padding:0 20px}}
@media(max-width:540px){.media-grid{grid-template-columns:1fr;gap:12px}}

/* Wedding gallery — tighter catalog thumbnails */
.cat-item.wedding-item .cat-thumb{aspect-ratio:1/1}

/* Responsive tweaks for cover on mobile */
@media(max-width:900px){
  .detail-viz .cover-wrap{padding:40px}
}
@media(max-width:640px){
  .detail-viz{min-height:360px}
  .detail-viz .cover-wrap{padding:32px}
}

/* Utility */
.center{text-align:center}
.divider{height:1px;background:var(--line);margin:0}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal,.stagger>*{opacity:1!important;transform:none!important}
  .scene-line{position:absolute;opacity:1!important;transform:none!important}
  .scene-line:not(.active){opacity:0!important}
  html{scroll-behavior:auto}
}
