:root {
  color-scheme: light;
  --paper: #f0e7d8;
  --paper-2: #fbf5ec;
  --ink: #171512;
  --muted: rgba(23, 21, 18, .68);
  --faint: rgba(23, 21, 18, .46);
  --line: rgba(23, 21, 18, .14);
  --dark: #151412;
  --cream: #fff8ed;
  --brass: #b68645;
  --moss: #5e6651;
  --shadow: 0 28px 80px rgba(51, 40, 25, .2);
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --serif: ui-serif, Georgia, "Times New Roman", serif;
  font-family: var(--sans);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  padding-bottom: 70px;
  color: var(--ink);
  background: radial-gradient(circle at 18% 0%, rgba(182,134,69,.16), transparent 34rem), linear-gradient(180deg, var(--paper-2), var(--paper));
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.grain { position: fixed; inset: 0; pointer-events: none; z-index: 30; opacity: .13; mix-blend-mode: multiply; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.38'/%3E%3C/svg%3E"); }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
main { overflow: hidden; }

.hero, .image-led, .feature-strip, .scene-grid, .ritual, .kit, .final-cta { width: min(1220px, calc(100% - 36px)); margin: 0 auto; }
.hero {
  min-height: 100dvh;
  display: grid;
  grid-template-columns: minmax(330px, .82fr) minmax(460px, 1.18fr);
  gap: clamp(30px, 5vw, 74px);
  align-items: center;
  padding: clamp(28px, 5vw, 70px) 0 clamp(54px, 7vw, 96px);
}
.brandline { margin: 0 0 clamp(48px, 9vh, 96px); color: var(--faint); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; }
.overline { margin: 0 0 14px; color: var(--moss); font-size: 11px; font-weight: 720; letter-spacing: .18em; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1 {
  max-width: 680px;
  margin-bottom: 20px;
  font-family: var(--serif);
  font-size: clamp(46px, 6.7vw, 92px);
  font-weight: 430;
  line-height: .96;
  letter-spacing: -0.045em;
  text-wrap: balance;
}
h2 {
  margin-bottom: 18px;
  font-family: var(--serif);
  font-size: clamp(34px, 5vw, 68px);
  font-weight: 430;
  line-height: 1.02;
  letter-spacing: -0.04em;
  text-wrap: balance;
}
h3 { margin-bottom: 8px; font-family: var(--serif); font-size: clamp(22px, 2.2vw, 31px); font-weight: 430; line-height: 1.05; letter-spacing: -0.025em; }
p { color: var(--muted); font-size: 17px; line-height: 1.62; }
.hero-lede { max-width: 560px; margin-bottom: 24px; font-size: clamp(18px, 1.7vw, 22px); line-height: 1.48; }

.lead-form { display: grid; grid-template-columns: minmax(230px, 1fr) auto; gap: 8px; width: min(100%, 610px); padding: 7px; border: 1px solid rgba(23,21,18,.13); background: rgba(255,248,237,.74); box-shadow: 0 16px 42px rgba(51,40,25,.12); }
.lead-form input { min-height: 52px; width: 100%; border: 0; outline: 0; padding: 0 15px; color: var(--ink); background: rgba(255,255,255,.78); font: inherit; }
.lead-form input:focus { box-shadow: inset 0 0 0 2px var(--brass); }
.lead-form button { min-height: 52px; border: 0; padding: 0 20px; color: var(--cream); background: var(--dark); cursor: pointer; font-weight: 700; white-space: nowrap; transition: transform .16s ease, background .16s ease; }
.lead-form button:hover, .lead-form button:focus-visible { transform: translateY(-1px); background: #000; }
.lead-form button[disabled] { opacity: .68; cursor: wait; }
.form-note { grid-column: 1 / -1; margin: 0 7px 2px; color: var(--faint); font-size: 12px; line-height: 1.3; }
.form-note.is-success { color: #34713b; }
.form-note.is-error { color: #9d3e2e; }
.trap { position: absolute !important; left: -9999px !important; }
.proof-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.proof-pills span { padding: 7px 10px; border: 1px solid var(--line); color: var(--muted); background: rgba(255,248,237,.44); font-size: 13px; }

.hero-visual { position: relative; min-height: 620px; }
.hero-photo { position: absolute; inset: 0 0 90px 0; margin: 0; border: 1px solid rgba(23,21,18,.12); background: rgba(255,248,237,.48); box-shadow: var(--shadow); transform: rotate(1deg); }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.95) contrast(.98); }
.motion-card { position: absolute; left: clamp(18px, 3vw, 42px); right: clamp(18px, 3vw, 42px); bottom: 0; padding: 16px; color: var(--cream); background: rgba(21,20,18,.92); box-shadow: 0 26px 70px rgba(0,0,0,.28); backdrop-filter: blur(12px); }
.motion-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; font-size: 11px; font-weight: 760; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,248,237,.72); }
.motion-head i { position: relative; width: 90px; height: 2px; overflow: hidden; background: rgba(255,248,237,.2); }
.motion-head i::after { content: ""; position: absolute; inset: 0; background: var(--brass); transform-origin: left; animation: progress 5.2s linear infinite; }
.motion-stage { position: relative; height: 210px; overflow: hidden; background: linear-gradient(135deg, #5e564a, #e5d7c4 50%, #b8aa98); }
.notebook-slab { position: absolute; width: 58%; height: 74%; left: 8%; bottom: 10%; background: linear-gradient(90deg, #69604f 0 46%, #f6eee1 46%); box-shadow: 0 22px 44px rgba(0,0,0,.28); animation: movePage 5.2s ease-in-out infinite; }
.page-sheet { position: absolute; right: 8%; top: 10%; width: 38%; height: 80%; padding: 18px 13px; background: #fff9ef; color: #2b2823; box-shadow: 0 8px 18px rgba(0,0,0,.18); }
.page-sheet b { display: block; margin-bottom: 22px; font-family: var(--serif); font-weight: 500; }
.page-sheet em { display: block; height: 8px; margin: 13px 0; background: rgba(43,40,35,.62); }
.page-sheet em:nth-child(3) { width: 76%; }
.fade-line { width: 62%; animation: eraseLine 5.2s ease-in-out infinite; }
.desk-pin { position: absolute; right: 13%; top: 14%; width: 25%; height: 72%; border: 1px solid rgba(255,248,237,.35); opacity: .55; }
.wipe { position: absolute; right: 42%; top: 54%; width: 64px; height: 18px; background: rgba(255,248,237,.76); transform: rotate(-11deg); animation: wipeMove 5.2s ease-in-out infinite; }
.motion-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; margin-top: 8px; color: rgba(255,248,237,.68); font-size: 12px; }
.motion-steps span { padding: 7px 0; text-align: center; background: rgba(255,248,237,.08); }
@keyframes progress { 0% { transform: scaleX(0); } 100% { transform: scaleX(1); } }
@keyframes movePage { 0%, 42% { transform: translateX(0); } 58%, 100% { transform: translateX(68%); } }
@keyframes eraseLine { 0%, 62% { opacity: 1; } 78%, 100% { opacity: .08; } }
@keyframes wipeMove { 0%, 55% { transform: translateX(-60px) rotate(-11deg); opacity: 0; } 68% { opacity: 1; } 86%, 100% { transform: translateX(28px) rotate(-11deg); opacity: 0; } }

.image-led { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(30px, 6vw, 82px); align-items: center; padding: clamp(56px, 9vw, 120px) 0; }
.image-led figure, .scene-grid figure, .kit figure { margin: 0; border: 1px solid rgba(23,21,18,.12); background: rgba(255,248,237,.46); box-shadow: var(--shadow); }
.image-led img { aspect-ratio: 3/2; width: 100%; object-fit: cover; }
.image-led p:last-child { max-width: 580px; font-size: clamp(18px, 1.9vw, 23px); }
.feature-strip { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.feature-strip article { padding: clamp(24px, 4vw, 42px); border-right: 1px solid var(--line); }
.feature-strip article:last-child { border-right: 0; }
.feature-strip span { display: block; margin-bottom: 10px; font-family: var(--serif); font-size: clamp(24px, 2.6vw, 36px); letter-spacing: -.03em; }
.feature-strip p { margin: 0; font-size: 15px; }

.scene-grid { display: grid; grid-template-columns: 1.12fr .88fr; gap: clamp(18px, 3vw, 34px); padding: clamp(64px, 9vw, 120px) 0; }
.section-intro { grid-column: 1 / -1; max-width: 820px; }
.scene-grid figure { position: relative; overflow: hidden; }
.scene-grid img { width: 100%; height: 100%; object-fit: cover; }
.scene-large { grid-row: span 2; min-height: 680px; }
.scene-grid figure:not(.scene-large) { min-height: 322px; }
figcaption { position: absolute; left: 14px; right: 14px; bottom: 14px; padding: 11px 13px; color: var(--cream); background: rgba(21,20,18,.72); backdrop-filter: blur(10px); font-size: 13px; }

.ritual { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(30px, 5vw, 70px); align-items: start; padding: clamp(52px, 8vw, 100px) 0; }
.ritual ol { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; padding: 0; margin: 0; list-style: none; border-top: 1px solid var(--line); }
.ritual li { padding: clamp(22px, 3vw, 34px); border-bottom: 1px solid var(--line); }
.ritual span { display: block; margin-bottom: 22px; color: var(--brass); font-size: 12px; font-weight: 760; letter-spacing: .14em; }
.ritual p { margin: 0; }

.kit { display: grid; grid-template-columns: .82fr 1fr; gap: clamp(30px, 6vw, 82px); align-items: center; padding: clamp(56px, 8vw, 110px) 0; }
.kit img { aspect-ratio: 1; width: 100%; object-fit: cover; }
.kit ul { padding: 0; margin: 26px 0 0; list-style: none; border-top: 1px solid var(--line); }
.kit li { display: grid; grid-template-columns: 150px 1fr; gap: 20px; padding: 18px 0; border-bottom: 1px solid var(--line); }
.kit strong { font-family: var(--serif); font-size: 20px; font-weight: 430; }
.kit span { color: var(--muted); line-height: 1.55; }

.final-cta { margin-top: clamp(30px, 5vw, 70px); margin-bottom: clamp(60px, 8vw, 110px); padding: clamp(34px, 6vw, 72px); color: var(--cream); background: radial-gradient(circle at 85% 0%, rgba(182,134,69,.24), transparent 26rem), var(--dark); box-shadow: var(--shadow); }
.final-cta h2, .final-cta p { color: inherit; }
.final-cta p { max-width: 680px; color: rgba(255,248,237,.72); }
.final-cta .overline { color: #d8b777; }
.final-cta .lead-form { background: rgba(255,248,237,.1); border-color: rgba(255,248,237,.16); box-shadow: none; }
.final-cta .lead-form input { background: rgba(255,248,237,.92); }
.final-cta .lead-form button { color: var(--dark); background: var(--cream); }
.final-cta small { display: block; max-width: 680px; margin-top: 18px; color: rgba(255,248,237,.55); line-height: 1.5; }

.sticky-lead { position: fixed; left: 50%; bottom: 10px; z-index: 60; transform: translateX(-50%); width: min(760px, calc(100% - 20px)); padding: 6px; background: rgba(21,20,18,.92); box-shadow: 0 20px 70px rgba(0,0,0,.36); backdrop-filter: blur(16px) saturate(140%); }
.sticky-form { grid-template-columns: minmax(0, 1fr) 92px; width: 100%; padding: 0; border: 0; background: transparent; box-shadow: none; }
.sticky-form input, .sticky-form button { min-height: 44px; }
.sticky-form button { padding: 0 12px; color: var(--dark); background: var(--cream); }
.sticky-form .form-note { display: none; }
.footer { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; padding: 28px clamp(18px, 4vw, 56px) 96px; color: var(--faint); font-size: 12px; }

@media (max-width: 980px) {
  .hero, .image-led, .scene-grid, .ritual, .kit { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .brandline { margin-bottom: 36px; }
  .hero-visual { min-height: 560px; }
  .feature-strip { grid-template-columns: 1fr; }
  .feature-strip article { border-right: 0; border-bottom: 1px solid var(--line); }
  .feature-strip article:last-child { border-bottom: 0; }
  .scene-large, .scene-grid figure:not(.scene-large) { min-height: auto; }
  .scene-grid figure { aspect-ratio: 4/3; }
  .scene-grid figure:nth-of-type(2) { aspect-ratio: 3/4; }
}
@media (max-width: 640px) {
  body { padding-bottom: 66px; }
  .hero, .image-led, .feature-strip, .scene-grid, .ritual, .kit, .final-cta { width: min(100% - 24px, 1220px); }
  h1 { font-size: clamp(42px, 12.8vw, 62px); letter-spacing: -.035em; }
  h2 { font-size: clamp(32px, 10vw, 48px); letter-spacing: -.03em; }
  .lead-form, .sticky-form { grid-template-columns: 1fr 82px; }
  .hero-form { grid-template-columns: 1fr; }
  .hero-form button { width: 100%; }
  .hero-visual { min-height: 480px; }
  .hero-photo { bottom: 112px; }
  .motion-card { left: 8px; right: 8px; padding: 10px; }
  .motion-stage { height: 160px; }
  .ritual ol { grid-template-columns: 1fr; }
  .kit li { grid-template-columns: 1fr; gap: 4px; }
  .footer { padding-bottom: 90px; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 1ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition: none !important; }
}
