/* ============================================================
   Mozart — base.css
   Structural + component CSS for the sales page. Everything is
   token-driven (colors_and_type.css). The six "directions" live
   in directions.css and re-skin the page by overriding tokens
   plus a handful of targeted layout rules.
   ============================================================ */

body { margin: 0; background: var(--chalk); color: var(--ink); }

/* Narrower, centered container with breathing room on the sides */
.wrap { max-width: 1080px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 700px) { .wrap { padding: 0 20px; } }

.centered { text-align: center; max-width: 720px; margin: 0 auto; }
.centered h2.h, .centered p.body, .centered p.lead { margin-left: auto; margin-right: auto; }

/* ---------- The written wordmark ----------------------------
   Container is theme-neutral here; directions.css owns the look.
   ----------------------------------------------------------- */
.word { text-decoration: none; color: inherit; border: none; display: inline-flex; align-items: baseline; }
.wm-text { font-family: var(--font-display); font-style: italic; letter-spacing: -0.02em; }

/* ============================ HEADER ======================== */
.mz-hdr-min { background: var(--chalk); border-bottom: 1px solid var(--rule); padding: 18px 0; position: sticky; top: 0; z-index: 10; backdrop-filter: blur(6px); }
.mz-hdr-min .row { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.mz-hdr-min .word { font-size: 22px; }
.mz-hdr-min nav { display: flex; align-items: center; gap: 28px; opacity: 0; visibility: hidden; transform: translateY(-2px); pointer-events: none; transition: opacity 300ms var(--ease-out-soft), transform 300ms var(--ease-out-soft), visibility 300ms; }
.mz-hdr-min.show-nav nav { opacity: 1; visibility: visible; transform: none; pointer-events: auto; }
.mz-hdr-min nav a { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); border: none; }
.mz-hdr-min nav a:hover { color: var(--terracotta-deep); }
.mz-hdr-min .cta { padding: 10px 18px; background: var(--terracotta); color: var(--chalk); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; white-space: nowrap; text-decoration: none; border: 1px solid var(--terracotta-deep); border-radius: var(--radius-2); }
.mz-hdr-min .cta:hover { background: var(--terracotta-deep); }
.mz-hdr-min .hamburger { display: none; align-items: center; justify-content: center; min-width: 44px; min-height: 44px; background: none; border: 1px solid var(--rule); border-radius: var(--radius-2); padding: 8px 10px; cursor: pointer; color: var(--ink); }
.mz-hdr-min .hamburger:hover { border-color: var(--terracotta); color: var(--terracotta-deep); }
.mz-hdr-min .hamburger span { display: block; width: 18px; height: 1.5px; background: currentColor; margin: 3px 0; transition: transform 200ms, opacity 200ms; }
.mz-hdr-min .hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.mz-hdr-min .hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.mz-hdr-min .hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }
.mz-hdr-min .panel { display: none; }

/* ============================ HERO ========================== */
.hero { background: var(--chalk); color: var(--ink); padding: 48px 0 72px; min-height: calc(78vh - 70px); display: flex; align-items: center; position: relative; overflow: hidden; }
.hero .wrap { position: relative; z-index: 1; width: 100%; }
.hero-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; gap: 40px; } .hero { min-height: 0; padding: 64px 0 80px; } }
.hero .tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terracotta-deep); margin-bottom: 22px; }
.hero h1 { font-family: var(--font-display); font-style: italic; font-size: clamp(36px, 4.6vw, 60px); line-height: 1.06; letter-spacing: -0.022em; color: var(--ink); margin: 0 0 24px; max-width: 100%; overflow-wrap: break-word; }
.hero h1 em { color: var(--terracotta); font-style: italic; }
.hero h1 .accent-word { color: var(--terracotta); }
.hero .sub { font-family: var(--font-sans); font-size: 18px; line-height: 1.55; color: var(--fg-2); max-width: 44ch; margin: 0 0 28px; }
.hero .sub strong { color: var(--ink); font-weight: 600; }
.hero .ctas { display: flex; gap: 16px; margin-top: 28px; }
.hero .ctas .primary { display: inline-flex; align-items: center; gap: 10px; padding: 16px 26px; background: var(--terracotta); color: var(--chalk); font-family: var(--font-sans); font-weight: 500; font-size: 15px; border: 1px solid var(--terracotta-deep); border-radius: var(--radius-2); text-decoration: none; box-shadow: inset 0 1px 0 rgba(255,252,240,0.18); }
.hero .ctas .primary:hover { background: var(--terracotta-deep); }
.hero .ctas .primary .arrow { font-family: var(--font-mono); font-size: 14px; }

/* Hero visual — pixel mozart + vinyl, tilted */
.hero-visual { position: relative; aspect-ratio: 1 / 1; max-width: 480px; margin: 0 auto; transform: rotate(-3deg); }
.hero-visual .vinyl {
  position: absolute; top: 50%; right: -24%; transform: translateY(-50%);
  width: 94%; height: 94%; border-radius: 50%;
  background:
    radial-gradient(circle at center, var(--terracotta-deep) 0%, var(--terracotta-deep) 17%, rgba(138,61,30,0) 17.5%, rgba(138,61,30,0) 100%),
    repeating-radial-gradient(circle at center, transparent 0, transparent 4px, rgba(255,255,255,0.11) 4px, rgba(255,255,255,0.11) 5px),
    radial-gradient(circle at 28% 28%, rgba(255,255,255,0.07) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(circle at center, #1f1a16 0%, #14110d 60%, #0a0805 100%);
  border: 1px solid #000;
  box-shadow: 0 24px 48px -12px rgba(0,0,0,0.6), inset 0 0 80px rgba(0,0,0,0.55);
}
.hero-visual .vinyl::before {
  content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 34%; height: 34%; border-radius: 50%; background: var(--terracotta);
  box-shadow: 0 0 0 1px var(--terracotta-deep), inset 0 0 0 1px rgba(255,255,255,0.18), inset 0 0 30px rgba(138,61,30,0.4);
}
.hero-visual .vinyl::after {
  content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 3.5%; height: 3.5%; border-radius: 50%; background: var(--cabinet-deep);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.4); z-index: 2;
}
.hero-visual .sleeve {
  position: relative; z-index: 1; width: 88%; aspect-ratio: 1/1;
  background:
    repeating-linear-gradient(0deg, rgba(26,22,18,0.022) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(26,22,18,0.018) 0 1px, transparent 1px 4px),
    var(--paper);
  border: 1px solid var(--ink); padding: 20px;
  box-shadow: 0 32px 64px -24px rgba(0,0,0,0.4), 0 1px 0 rgba(0,0,0,0.08), inset 0 0 0 1px var(--paper), inset 0 0 0 2px rgba(26,22,18,0.08);
}
.hero-visual .sleeve::before { content: ""; position: absolute; top: 9px; left: 9px; width: 5px; height: 5px; border-radius: 50%; background: var(--ink); opacity: 0.35; }
.hero-visual .sleeve::after { content: ""; position: absolute; bottom: 9px; right: 9px; width: 5px; height: 5px; border-radius: 50%; background: var(--ink); opacity: 0.35; }
.hero-visual .sleeve .nameplate { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terracotta-deep); margin-bottom: 12px; }
.hero-visual .sleeve .portrait { width: 100%; aspect-ratio: 1/1; background: radial-gradient(circle at center, var(--chalk) 0%, var(--paper) 60%); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-visual .sleeve .portrait img { width: 78%; height: 78%; object-fit: contain; image-rendering: pixelated; image-rendering: -moz-crisp-edges; }
.hero-visual .sleeve .caption { margin-top: -52px; padding-bottom: 14px; padding-left: 8px; position: relative; z-index: 2; }
.hero-visual .sleeve .caption .agent { font-family: var(--font-display); font-style: italic; font-size: 26px; color: var(--ink); line-height: 0.9; }
.hero-visual .sleeve .caption .orchestration { font-family: var(--font-display); font-style: italic; font-size: 26px; color: var(--terracotta); line-height: 0.9; padding-left: 28px; }
.hero-visual .sleeve .footer-mono { display: flex; justify-content: space-between; align-items: center; font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--stone); margin-top: 8px; padding-top: 6px; border-top: 1px solid rgba(26,22,18,0.12); }
.hero-visual .sleeve .footer-mono .left { display: flex; gap: 10px; color: var(--steel); }

/* ============================ SECTIONS ====================== */
section.band { padding: 96px 0; border-top: 1px solid var(--rule); }
section.band.tight { padding: 64px 0; }
section.band.cabinet { background: var(--cabinet); color: var(--chalk); border: 0; }
.secnum { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terracotta-deep); margin-bottom: 18px; }
section.band.cabinet .secnum { color: var(--terracotta-glow); }
h2.h { font-family: var(--font-display); font-style: italic; font-size: clamp(36px, 4.4vw, 60px); line-height: 1.04; letter-spacing: -0.024em; margin: 0 0 24px; text-wrap: balance; max-width: 22ch; }
h3.h { font-family: var(--font-display); font-style: italic; font-size: clamp(24px, 2.6vw, 32px); line-height: 1.1; margin: 0 0 14px; }
p.lead { font-family: var(--font-display); font-style: italic; font-size: 22px; line-height: 1.55; max-width: 58ch; color: var(--fg-2); margin: 0 0 18px; }
section.band.cabinet p.lead { color: var(--chalk-deep); }
p.body { font-family: var(--font-sans); font-size: 17px; line-height: 1.65; max-width: 64ch; margin: 0 0 16px; color: var(--fg-2); }
p.body strong { color: var(--ink); font-weight: 600; }
section.band.cabinet p.body { color: var(--chalk-deep); }
section.band.cabinet p.body strong { color: var(--chalk); }
.pull { font-family: var(--font-display); font-style: italic; font-size: clamp(28px, 3.2vw, 40px); line-height: 1.18; color: var(--terracotta-deep); border-left: 2px solid var(--terracotta); padding-left: 22px; margin: 28px 0; max-width: 28ch; }
section.band.cabinet .pull { color: var(--terracotta-glow); border-left-color: var(--terracotta); }

/* MIT + RAND stat band */
.stat-band { display: grid; grid-template-columns: 280px 1fr; gap: 56px; align-items: start; }
@media (max-width: 800px) { .stat-band { grid-template-columns: 1fr; gap: 28px; } }
.stat-stack { display: flex; flex-direction: column; gap: 16px; }
.stat-card { padding: 26px 24px; background: var(--paper); border: 1px solid var(--rule); border-radius: var(--radius-2); position: relative; }
.stat-card::before { content: ""; position: absolute; top: 12px; left: 12px; width: 8px; height: 8px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, var(--steel-soft), var(--steel-deep)); }
.stat-big { font-family: var(--font-display); font-style: italic; font-size: clamp(60px, 7vw, 88px); line-height: 0.92; color: var(--terracotta-deep); margin: 0; }
.stat-of { font-family: var(--font-sans); font-size: 13px; line-height: 1.5; color: var(--fg-2); margin: 10px 0 14px; }
.stat-of strong { color: var(--ink); font-weight: 600; }
.stat-cap { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-3); padding-top: 12px; border-top: 1px solid var(--rule); }
.stat-cap a { color: var(--terracotta-deep); border-bottom: none; }
.stat-cap a:hover { color: var(--terracotta); }
.fail-list { list-style: none; padding: 0; margin: 24px 0 0; }
.fail-list li { font-family: var(--font-sans); font-size: 17px; line-height: 1.55; padding: 12px 0 12px 40px; border-bottom: 1px solid var(--rule); color: var(--fg-2); position: relative; }
.fail-list li::before { content: ""; position: absolute; left: 0; top: 22px; width: 16px; height: 1px; background: var(--steel); }
.fail-list li:last-child { border-bottom: 0; }

/* Manifesto principles */
.principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; margin-top: 56px; }
.principles .p { padding: 28px; background: var(--paper); border: 1px solid var(--hairline); border-radius: var(--radius-2); position: relative; }
.principles .p::before, .principles .p::after { content: ""; position: absolute; width: 6px; height: 6px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, var(--steel-soft), var(--steel-deep)); }
.principles .p::before { top: 8px; left: 8px; }
.principles .p::after { top: 8px; right: 8px; }
.principles .p .pnum { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--terracotta-deep); margin-bottom: 12px; }
.principles .p h4 { font-family: var(--font-display); font-style: italic; font-size: 26px; line-height: 1.1; margin: 0 0 14px; }
.principles .p p { font-family: var(--font-sans); font-size: 15px; line-height: 1.6; color: var(--fg-2); margin: 0; }
.principles .p p strong { color: var(--ink); }
@media (max-width: 900px) { .principles { grid-template-columns: 1fr; } }

/* Four levels */
.levels { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 48px; }
.levels .lvl {
  padding: 28px 20px; border: 1px solid var(--rule); background: var(--paper); position: relative; cursor: pointer;
  transition: transform 280ms cubic-bezier(0.22,0.61,0.36,1), border-color 220ms ease-out, background-color 220ms ease-out, box-shadow 280ms ease-out;
  will-change: transform;
}
.levels .lvl:hover { transform: translateY(-6px) rotate(-0.8deg); border-color: var(--terracotta); background: var(--chalk); box-shadow: 0 16px 32px -12px rgba(25,22,18,0.22), 0 1px 0 rgba(0,0,0,0.04); }
.levels .lvl:nth-child(even):hover { transform: translateY(-6px) rotate(0.8deg); }
.levels .lvl.now { background: var(--chalk-deep); }
.levels .lvl.target { border: 1px solid var(--terracotta); }
.levels .lvl.target::after { content: ""; position: absolute; top: 12px; right: 12px; width: 8px; height: 8px; border-radius: 50%; background: var(--terracotta); box-shadow: 0 0 12px rgba(181,81,42,0.6); }
.levels .lvl.target:hover::after { box-shadow: 0 0 18px rgba(181,81,42,0.85); }
.levels .lvl .lnum { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--terracotta-deep); margin-bottom: 8px; text-transform: uppercase; }
.levels .lvl h5 { font-family: var(--font-display); font-style: italic; font-size: 22px; margin: 0 0 8px; }
.levels .lvl p { font-family: var(--font-sans); font-size: 13px; line-height: 1.5; color: var(--fg-2); margin: 0 0 12px; }
.levels .lvl .where { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--terracotta-deep); }
@media (max-width: 1000px) { .levels { grid-template-columns: repeat(2, 1fr); } }

/* Workflows-not-roles */
.roles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin: 48px 0; }
.role-card { padding: 28px; background: var(--paper); border: 1px solid var(--hairline); border-radius: var(--radius-2); }
.role-card h4 { font-family: var(--font-display); font-style: italic; font-size: 22px; margin: 0 0 6px; }
.role-card .count { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--terracotta-deep); text-transform: uppercase; margin-bottom: 16px; }
.role-card ul { list-style: none; padding: 0; margin: 0; }
.role-card li { font-family: var(--font-sans); font-size: 14px; line-height: 1.6; padding: 4px 0 4px 14px; color: var(--fg-2); position: relative; }
.role-card li::before { content: "·"; position: absolute; left: 0; color: var(--steel); }
section.band.cabinet .role-card { background: var(--cabinet-2); border-color: rgba(242,239,228,0.14); }
section.band.cabinet .role-card h4 { color: var(--chalk); }
section.band.cabinet .role-card .count { color: var(--terracotta-glow); }
section.band.cabinet .role-card li { color: var(--chalk-deep); }
section.band.cabinet .role-card li::before { color: var(--terracotta-glow); }
@media (max-width: 800px) { .roles { grid-template-columns: 1fr; } }

/* Testimonials */
.testi-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 36px; margin-top: 48px; }
.testi { padding: 32px; background: var(--paper); border: 1px solid var(--hairline); border-radius: var(--radius-2); position: relative; }
.testi .who { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.testi .porthole { width: 56px; height: 56px; border-radius: 50%; border: 1px solid var(--rule); box-shadow: none; overflow: hidden; flex: 0 0 56px; background: var(--cabinet); display: flex; align-items: center; justify-content: center; }
.testi .porthole img { width: 100%; height: 100%; object-fit: cover; image-rendering: auto; }
.testi .who .meta { display: flex; flex-direction: column; gap: 2px; }
.testi .who .meta .name { font-family: var(--font-display); font-style: italic; font-size: 18px; }
.testi .who .meta .role { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3); }
.testi .quote { font-family: var(--font-display); font-style: italic; font-size: 20px; line-height: 1.45; color: var(--ink); margin: 0 0 16px; }
@media (max-width: 800px) { .testi-grid { grid-template-columns: 1fr; } }

/* Monogram avatar (placeholder for headshots) */
.monogram { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-weight: 500; font-size: 18px; letter-spacing: 0.04em; color: var(--chalk); background:
  radial-gradient(circle at 32% 28%, var(--terracotta-glow) 0%, rgba(210,106,61,0) 55%),
  linear-gradient(155deg, var(--cabinet-2) 0%, var(--cabinet-deep) 100%); }

/* Who this is for */
.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; margin-top: 48px; }
.fit { padding: 32px; border: 1px solid var(--rule); }
.fit.good { border-color: var(--terracotta); }
.fit .lbl { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 14px; }
.fit.good .lbl { color: var(--terracotta-deep); }
.fit.bad .lbl { color: var(--stone); }
.fit h3 { font-family: var(--font-display); font-style: italic; font-size: 24px; margin: 0 0 16px; }
.fit ul { list-style: none; padding: 0; margin: 0; }
.fit li { font-family: var(--font-sans); font-size: 15px; line-height: 1.55; padding: 10px 0 10px 26px; position: relative; color: var(--fg-2); border-bottom: 1px solid var(--rule); }
.fit li:last-child { border-bottom: 0; }
.fit.good li::before { content: ""; position: absolute; left: 0; top: 16px; width: 14px; height: 1px; background: var(--terracotta); }
.fit.bad li::before { content: ""; position: absolute; left: 0; top: 12px; width: 10px; height: 10px; border: 1px solid var(--stone); transform: rotate(45deg); }
@media (max-width: 800px) { .fit-grid { grid-template-columns: 1fr; gap: 32px; } }

/* Pricing */
.pricing { display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; margin-top: 48px; align-items: start; }
.plan { padding: 36px; background: var(--paper); border: 1px solid var(--hairline); border-radius: var(--radius-2); position: relative; }
.plan.feature { background: var(--cabinet); color: var(--chalk); border-color: var(--steel-deep); padding: 48px; }
.plan.feature::before, .plan.feature::after, .plan.feature .bl, .plan.feature .br { content: ""; position: absolute; width: 8px; height: 8px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, var(--steel-soft), var(--steel-deep)); }
.plan.feature::before { top: 10px; left: 10px; } .plan.feature::after { top: 10px; right: 10px; }
.plan.feature .bl { bottom: 10px; left: 10px; } .plan.feature .br { bottom: 10px; right: 10px; }
.plan .ribbon { position: absolute; top: -14px; right: 24px; background: var(--terracotta); color: var(--chalk); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; padding: 6px 12px; border-radius: var(--radius-1); }
.plan .pname { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 12px; }
.plan.feature .pname { color: var(--terracotta-glow); }
.plan .price { font-family: var(--font-display); font-style: italic; font-size: 52px; line-height: 1; margin: 0 0 4px; }
.plan.feature .price { color: var(--chalk); }
.plan .price small { font-family: var(--font-sans); font-style: normal; font-size: 17px; color: var(--fg-3); }
.plan.feature .price small { color: var(--chalk-deep); }
.plan .setup { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; color: var(--fg-3); margin: 6px 0 24px; }
.plan.feature .setup { color: var(--chalk-deep); }
.plan .setup .strike { text-decoration: line-through; color: var(--stone); margin-right: 8px; }
.plan.feature .setup .strike { color: var(--stone-2); }
.plan .setup .waived { color: var(--terracotta); font-weight: 600; }
.plan.feature .setup .waived { color: var(--terracotta-glow); }
.plan .subprice { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--fg-3); text-transform: uppercase; margin: 0 0 22px; }
.plan.feature .subprice { color: var(--chalk-deep); }
.plan .install-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); margin: 0 0 14px; padding-top: 14px; border-top: 1px solid var(--rule); }
.plan.feature .install-label { color: var(--chalk-deep); border-top-color: rgba(242,239,228,0.15); }
.plan .btn { display: block; text-align: center; padding: 14px 18px; font-family: var(--font-sans); font-weight: 500; font-size: 15px; text-decoration: none; border-radius: var(--radius-2); margin-bottom: 24px; }
.plan.feature .btn { background: var(--terracotta); color: var(--chalk); border: 1px solid var(--terracotta-deep); }
.plan.feature .btn:hover { background: var(--terracotta-deep); }
.plan .btn.outline { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.plan .btn.outline:hover { background: var(--ink); color: var(--chalk); }
.plan ul.inc { list-style: none; padding: 0; margin: 0; }
.plan ul.inc li { font-family: var(--font-sans); font-size: 14px; line-height: 1.5; padding: 8px 0 8px 18px; color: var(--fg-2); position: relative; }
.plan.feature ul.inc li { color: var(--chalk-deep); }
.plan ul.inc li::before { content: "·"; position: absolute; left: 0; color: var(--terracotta-deep); font-weight: 700; }
.plan.feature ul.inc li::before { color: var(--terracotta-glow); }
.plan ul.inc li strong { color: var(--ink); }
.plan.feature ul.inc li strong { color: var(--chalk); }
@media (max-width: 800px) { .pricing { grid-template-columns: 1fr; } }
.strategy-line { font-family: var(--font-sans); font-size: 15px; color: var(--fg-2); text-align: center; margin: 40px auto 0; max-width: 56ch; }
.strategy-line a { color: var(--terracotta-deep); text-decoration: none; border-bottom: 1px solid var(--terracotta); transition: color 160ms ease, border-color 160ms ease; }
.strategy-line a:hover { color: var(--terracotta); border-bottom-color: var(--terracotta-deep); }

/* FAQ */
.faq { max-width: 760px; margin: 48px auto 0; }
.faq details { border-bottom: 1px solid var(--rule); padding: 22px 0; }
.faq details summary { font-family: var(--font-sans); font-weight: 500; font-size: 18px; cursor: pointer; list-style: none; position: relative; display: flex; align-items: center; min-height: 32px; padding-right: 36px; color: var(--ink); }
.faq details summary::-webkit-details-marker { display: none; }
.faq details summary::after { content: "+"; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-family: var(--font-mono); font-size: 22px; color: var(--terracotta-deep); transition: transform 200ms ease; }
.faq details[open] summary::after { content: "−"; top: 50%; transform: translateY(-50%); }
.faq details p { font-family: var(--font-sans); font-size: 16px; line-height: 1.65; color: var(--fg-2); margin: 14px 0 0; max-width: 64ch; }
.faq details p strong { color: var(--ink); }
.faq details.mo-faq summary { display: flex; align-items: center; gap: 14px; }
.faq details.mo-faq summary::before { content: ""; width: 32px; height: 32px; border-radius: 50%; background-image: url('/assets/mozart-pixel-32.png'); background-size: cover; border: 2px solid var(--steel); image-rendering: pixelated; flex: 0 0 32px; }

/* Final CTA */
.final-cta { background: var(--cabinet); color: var(--chalk); padding: 96px 0; text-align: center; }
.final-cta h2 { font-family: var(--font-display); font-style: italic; font-size: clamp(36px, 5vw, 64px); line-height: 1.05; margin: 0 0 32px; color: var(--chalk); }
.final-cta h2 em { color: var(--terracotta-glow); }
.final-cta h2 .accent-word { color: var(--terracotta-glow); }
.final-cta .btn { display: inline-flex; align-items: center; gap: 12px; padding: 18px 32px; background: var(--terracotta); color: var(--chalk); font-family: var(--font-sans); font-weight: 500; font-size: 17px; text-decoration: none; border-radius: var(--radius-2); border: 1px solid var(--terracotta-deep); box-shadow: inset 0 1px 0 rgba(255,252,240,0.18); }
.final-cta .btn:hover { background: var(--terracotta-deep); }
.final-cta .stamp { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--chalk-deep); margin-top: 28px; }

/* Footer */
footer.mz-foot { background: var(--cabinet); color: var(--chalk-deep); padding: 48px 0 64px; border-top: 1px solid var(--steel-deep); }
footer.mz-foot .row { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 24px; align-items: center; }
footer.mz-foot .word { font-size: 24px; color: var(--chalk); }
footer.mz-foot .meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--stone); }
footer.mz-foot .meta a { color: var(--chalk-deep); border: none; }

/* Reframe strip — subtle ground shift from the hero */
.reframe { background: var(--chalk-deep); }
.reframe .lead { margin-bottom: 0; }

/* Meet Mozart — the anatomy / equation row */
.anatomy { display: flex; align-items: stretch; justify-content: center; gap: 8px; margin-top: 56px; flex-wrap: nowrap; }
.anatomy .tile { flex: 1 1 0; min-width: 0; display: flex; flex-direction: column; align-items: center; text-align: center; padding: 32px 16px; background: var(--paper); border: 1px solid var(--hairline); border-radius: var(--radius-2); }
.anatomy .tile.result { border-color: var(--terracotta); }
.anatomy .ico { width: 96px; height: 96px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; background: var(--chalk); border: 1px solid var(--rule); color: var(--terracotta-deep); overflow: hidden; }
.anatomy .tile.result .ico { color: var(--terracotta); border-color: var(--terracotta); }
.anatomy .ico svg { width: 52px; height: 52px; }
.anatomy .ico.mozart { border: 3px solid var(--steel); box-shadow: 0 0 0 1px var(--ink), 0 0 0 5px var(--steel-deep); background: var(--cabinet); }
.anatomy .ico.mozart img { width: 100%; height: 100%; object-fit: cover; image-rendering: pixelated; }
.anatomy .t-name { font-family: var(--font-display); font-style: italic; font-size: 22px; line-height: 1.1; margin-bottom: 6px; color: var(--ink); }
.anatomy .t-sub { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-3); }
.anatomy .op { flex: 0 0 auto; display: flex; align-items: center; justify-content: center; padding: 0 6px; font-family: var(--font-display); font-style: italic; font-size: clamp(28px, 3vw, 44px); color: var(--terracotta); }
@media (max-width: 820px) {
  .anatomy { flex-direction: column; align-items: stretch; gap: 6px; margin-top: 36px; }
  .anatomy .tile { flex-direction: row; gap: 18px; text-align: left; padding: 18px 20px; align-items: center; }
  .anatomy .ico { width: 60px; height: 60px; margin-bottom: 0; flex: 0 0 60px; }
  .anatomy .ico svg { width: 32px; height: 32px; }
  .anatomy .op { padding: 2px 0; font-size: 26px; }
}

/* Vinyl spin (toggled from Tweaks) */
@keyframes mz-record-spin { from { transform: translateY(-50%) rotate(0deg); } to { transform: translateY(-50%) rotate(360deg); } }
.mz-spin .hero-visual .vinyl { animation: mz-record-spin 8s linear infinite; }
@media (prefers-reduced-motion: reduce) { .mz-spin .hero-visual .vinyl { animation: none; } }

/* Utility */
.mono { font-family: var(--font-mono); }
.quiet { color: var(--fg-3); }
.mt-7 { margin-top: 48px; } .mt-5 { margin-top: 24px; }

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 700px) {
  .mz-hdr-min .hamburger { display: block; }
  .mz-hdr-min > .row > nav, .mz-hdr-min > .row > .cta { display: none; }
  .mz-hdr-min .row { gap: 12px; }
  .mz-hdr-min .panel { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--chalk); border-bottom: 1px solid var(--rule); padding: 12px 20px 18px; flex-direction: column; gap: 4px; box-shadow: 0 12px 24px -16px rgba(0,0,0,0.18); }
  .mz-hdr-min .panel[data-open="true"] { display: flex; }
  .mz-hdr-min .panel a { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-2); padding: 14px 4px; border-bottom: 1px solid var(--rule); margin: 0; text-decoration: none; }
  .mz-hdr-min .panel a:last-of-type { border-bottom: 0; }
  .mz-hdr-min .panel .cta { display: inline-block; margin-top: 12px; padding: 14px 18px; background: var(--terracotta); color: var(--chalk); border: 1px solid var(--terracotta-deep); border-radius: var(--radius-2); text-align: center; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; }
  section.band { padding: 56px 0; }
  section.band.tight { padding: 40px 0; }
  .final-cta { padding: 64px 0; }
  .hero h1 { font-size: clamp(34px, 9vw, 44px); }
  .hero .sub { font-size: 16px; }
  h2.h { font-size: clamp(28px, 8vw, 36px); }
  h3.h { font-size: clamp(22px, 6vw, 26px); }
  p.lead { font-size: 18px; }
  p.body { font-size: 16px; }
  .stat-big { font-size: clamp(56px, 16vw, 72px); }
  .pull { font-size: clamp(22px, 6.5vw, 28px); padding-left: 16px; margin: 22px 0; }
  .hero { padding: 32px 0 48px; }
  .hero-visual { max-width: 320px; }
  .hero .ctas .primary { padding: 14px 22px; font-size: 14px; width: 100%; justify-content: center; }
  .levels { grid-template-columns: 1fr; gap: 12px; margin-top: 32px; }
  .levels .lvl { padding: 22px 18px; }
  .levels .lvl:hover { transform: none; }
  .principles { gap: 16px; margin-top: 32px; }
  .principles .p { padding: 22px 18px; }
  .roles { gap: 16px; margin: 32px 0; }
  .role-card { padding: 22px 18px; }
  .stat-card { padding: 22px 18px; }
  .testi-grid { gap: 16px; margin-top: 32px; }
  .testi { padding: 24px 20px; }
  .testi .quote { font-size: 17px; line-height: 1.5; }
  .testi .porthole { width: 48px; height: 48px; flex: 0 0 48px; }
  .fit-grid { gap: 20px; margin-top: 32px; }
  .fit { padding: 22px 18px; }
  .pricing { gap: 18px; margin-top: 32px; }
  .plan { padding: 24px 22px; }
  .plan.feature { padding: 28px 22px; }
  .plan .price { font-size: 40px; }
  .plan.feature .ribbon { right: 18px; top: -12px; font-size: 9px; padding: 5px 10px; }
  .faq { margin-top: 32px; }
  .faq details { padding: 14px 0; }
  .faq details summary { font-size: 16px; padding: 6px 30px 6px 0; min-height: 44px; }
  .final-cta h2 { font-size: clamp(30px, 9vw, 42px); margin: 0 0 24px; }
  .final-cta .btn { padding: 16px 24px; font-size: 15px; }
  footer.mz-foot { padding: 32px 0 40px; }
  footer.mz-foot .row { flex-direction: column; align-items: flex-start; gap: 12px; }
}
