/* ==========================================================================
   NIGHTNOTE — night-pages skin
   Re-skins the inner content pages (dream-meaning hub, articles, legal) into
   the "night" aesthetic of night.html, reusing the existing class names so no
   content/markup has to change. Load this INSTEAD of site.css + sections.css
   (keep app-ui.css for the .dream-art tiles).
   ========================================================================== */

:root {
  --void: #08020a;
  --ember: #ff6a1f;
  --ember-soft: #ff8a3c;
  --amber: #ffab5e;
  --gold: #ffd9a8;

  --text: #fff4ec;
  --text-soft: rgba(255,244,236,0.72);
  --text-faint: rgba(255,244,236,0.46);
  --text-dim: rgba(255,244,236,0.28);

  --glass: rgba(255,150,90,0.06);
  --glass-strong: rgba(255,150,90,0.10);
  --line: rgba(255,255,255,0.14);
  --line-2: rgba(255,255,255,0.26);

  --gutter: clamp(20px, 5vw, 64px);
  --maxw: 1100px;
  --r: 22px;

  --display: "Hanken Grotesk", system-ui, sans-serif;
  --serif: "Fraunces", Georgia, serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;
  --system: -apple-system, BlinkMacSystemFont, "SF Pro Text", system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body { font-family: var(--body); color: var(--text); background: var(--void); line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
::selection { background: rgba(255,120,50,0.34); color: #fff; }

/* sky backdrop (re-uses the .atmosphere + .grain divs already in markup) */
.atmosphere { position: fixed; inset: 0; z-index: -3;
  background:
    radial-gradient(120% 70% at 50% -8%, #2a0a10 0%, transparent 55%),
    radial-gradient(120% 80% at 50% 120%, #1a0606 0%, transparent 50%),
    #0a0306; }
.atmosphere::after { content: ""; position: absolute; inset: 0; opacity: .55; pointer-events: none;
  background-image:
    radial-gradient(1.2px 1.2px at 12% 14%, #fff, transparent),
    radial-gradient(1px 1px at 24% 36%, rgba(255,235,215,0.8), transparent),
    radial-gradient(1.3px 1.3px at 38% 20%, #fff, transparent),
    radial-gradient(1px 1px at 52% 48%, rgba(255,225,200,0.8), transparent),
    radial-gradient(1px 1px at 64% 26%, #fff, transparent),
    radial-gradient(1.2px 1.2px at 76% 58%, rgba(255,220,190,0.9), transparent),
    radial-gradient(1px 1px at 84% 22%, #fff, transparent),
    radial-gradient(1px 1px at 30% 70%, #fff, transparent),
    radial-gradient(1.1px 1.1px at 58% 80%, rgba(255,230,205,0.8), transparent); }
.grain { position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ----- Layout ----- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { position: relative; padding-block: clamp(56px, 8vw, 110px); }
.section--tight { padding-block: clamp(40px, 6vw, 80px); }
.center { text-align: center; } .mx-auto { margin-inline: auto; }
.maxw-680 { max-width: 680px; } .maxw-prose { max-width: 62ch; }
.row { display: flex; align-items: center; } .wrap-flex { flex-wrap: wrap; }
.gap-10{gap:10px}.gap-14{gap:14px}.gap-16{gap:16px}.gap-24{gap:24px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-40{margin-top:40px}
.grid { display: grid; gap: clamp(16px, 2vw, 24px); }
.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width: 940px){ .cols-3,.cols-4{grid-template-columns:repeat(2,1fr)} }
@media (max-width: 600px){ .cols-2,.cols-3,.cols-4{grid-template-columns:1fr} }

/* ----- Type ----- */
h1,h2,h3 { font-family: var(--display); font-weight: 700; line-height: 1.05; letter-spacing: -0.025em; text-wrap: balance; }
.display { font-family: var(--display); font-weight: 700; letter-spacing: -0.035em; line-height: 0.98; font-size: clamp(2.4rem, 6vw, 4.6rem); }
.h2 { font-size: clamp(1.9rem, 4vw, 3rem); letter-spacing: -0.03em; }
.h3 { font-size: clamp(1.25rem, 2.2vw, 1.6rem); }
.serif-em, .swash { font-family: var(--serif); font-style: italic; font-weight: 400; letter-spacing: 0; }
.gradient-text { background: linear-gradient(96deg, #ffe1bf, #ff8a3c 50%, #ff6a1f); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lede { font-size: clamp(1.05rem, 1.7vw, 1.35rem); color: var(--text-soft); line-height: 1.6; text-wrap: pretty; }
.muted { color: var(--text-soft); } .kicker { font-size: 0.9rem; color: var(--text-faint); }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; font-family: var(--system); font-size: 0.76rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--amber); }
.eyebrow::before { content: ""; width: 16px; height: 1px; background: linear-gradient(90deg, transparent, var(--amber)); }

/* ----- Glass / panels ----- */
.glass { position: relative; background: var(--glass); border: 1px solid var(--line); border-radius: var(--r); backdrop-filter: blur(16px); box-shadow: inset 0 1px 0 var(--line-2), 0 30px 60px -34px rgba(0,0,0,0.8); }
.glass--strong { background: var(--glass-strong); border-color: var(--line-2); }
.glass-pad { padding: clamp(22px, 3vw, 34px); }
.chip { display: inline-flex; align-items: center; gap: 9px; padding: 9px 15px; border-radius: 999px; background: rgba(255,255,255,0.05); border: 1px solid var(--line); font-size: 0.88rem; color: var(--text-soft); backdrop-filter: blur(8px); }
.badge-pro { font-size: 0.64rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 9px; border-radius: 999px; background: rgba(255,171,94,0.16); border: 1px solid rgba(255,171,94,0.4); color: var(--gold); }

/* ----- Buttons ----- */
.btn { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; font-size: 1rem; padding: 14px 22px; border-radius: 999px; transition: transform .25s, box-shadow .25s, background .25s, border-color .25s; }
.btn-store, .btn-ember { color: #1a0500; background: linear-gradient(180deg, #ffb066, #ff8a3c 55%, #ff6a1f); box-shadow: 0 14px 34px -14px rgba(255,110,40,0.7), inset 0 1px 0 rgba(255,255,255,0.5); padding: 12px 20px; }
.btn-store:hover, .btn-ember:hover { transform: translateY(-2px); }
.btn-store .apple, .btn-ember .apple { width: 20px; height: 20px; fill: #1a0500; }
.btn-store .store-txt { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.05; }
.btn-store .store-txt small { font-size: 0.62rem; font-weight: 600; letter-spacing: 0.04em; opacity: 0.72; }
.btn-store .store-txt b { font-size: 1.04rem; font-weight: 700; }
.btn-ghost { color: var(--text); background: rgba(255,255,255,0.05); border: 1px solid var(--line); backdrop-filter: blur(10px); }
.btn-ghost:hover { background: rgba(255,255,255,0.1); border-color: var(--line-2); transform: translateY(-2px); }
.btn-sm { padding: 10px 16px; font-size: 0.9rem; }

/* ----- Header / nav ----- */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 100; display: flex; justify-content: center; padding: 14px var(--gutter); transition: background .35s, backdrop-filter .35s, border-color .35s, padding .35s; border-bottom: 1px solid transparent; }
.site-header.scrolled { background: rgba(10,3,6,0.72); backdrop-filter: blur(16px); border-bottom-color: var(--line); padding-block: 11px; }
.nav { width: 100%; max-width: var(--maxw); display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--display); font-weight: 700; font-size: 1.12rem; letter-spacing: 0.02em; }
.brand .mark { width: 26px; height: 26px; }
.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a { font-size: 0.92rem; color: var(--text-soft); transition: color .2s; }
.nav-links a:hover { color: var(--amber); }
.nav-cta { display: flex; align-items: center; gap: 12px; }
.nav-toggle { display: none; width: 42px; height: 42px; border-radius: 12px; border: 1px solid var(--line); background: rgba(255,255,255,0.05); align-items: center; justify-content: center; }
.nav-toggle svg { width: 20px; stroke: var(--text); }
@media (max-width: 860px) { .nav-links { display: none; } .nav-toggle { display: inline-flex; } .nav-cta .btn-store .store-txt small { display: none; } }
.mobile-menu { position: fixed; inset: 0; z-index: 99; display: none; flex-direction: column; padding: 90px var(--gutter) 40px; background: rgba(8,2,8,0.94); backdrop-filter: blur(20px); }
.mobile-menu.open { display: flex; }
.mobile-menu a { font-family: var(--display); font-size: 1.6rem; font-weight: 600; padding: 16px 0; border-bottom: 1px solid var(--line); }
.float-cta { position: fixed; left: 50%; transform: translateX(-50%); bottom: 18px; z-index: 95; display: none; opacity: 0; transition: opacity .4s; }
.float-cta.show { opacity: 1; }
@media (max-width: 860px) { .float-cta { display: inline-flex; } }

/* ----- Reveal ----- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none} }

/* ----- Article ----- */
.article-hero { padding-top: clamp(120px, 15vh, 160px); padding-bottom: 0; }
.crumbs { font-size: 0.9rem; color: var(--text-faint); display: inline-flex; gap: 8px; flex-wrap: wrap; }
.crumbs a { color: var(--text-soft); } .crumbs a:hover { color: var(--amber); }
.article-meta { display: flex; gap: 18px; flex-wrap: wrap; color: var(--text-faint); font-size: 0.9rem; margin-top: 22px; }
.article-meta span { display: inline-flex; align-items: center; gap: 7px; }
.article-banner { position: relative; height: clamp(220px, 34vw, 360px); border-radius: 28px; overflow: hidden; margin-top: 30px; display: flex; align-items: flex-end; border: 1px solid var(--line); }
.article-banner__tag { position: relative; z-index: 2; margin: 26px; }

.prose { max-width: 720px; margin-inline: auto; }
.prose > * + * { margin-top: 1.1em; }
.prose h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); margin-top: 1.6em; letter-spacing: -0.025em; }
.prose h3 { font-size: 1.25rem; margin-top: 1.4em; }
.prose p, .prose li { font-size: clamp(1.05rem, 1.5vw, 1.18rem); line-height: 1.72; color: var(--text-soft); text-wrap: pretty; }
.prose strong { color: var(--text); font-weight: 600; }
.prose em { font-family: var(--serif); font-style: italic; font-size: 1.05em; color: var(--text); }
.prose ul { padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: 12px; }
.prose ul li { position: relative; padding-left: 30px; }
.prose ul li::before { content: ""; position: absolute; left: 6px; top: 0.62em; width: 7px; height: 7px; border-radius: 50%; background: linear-gradient(180deg, #ff8a3c, #ff6a1f); }
.prose .lead { font-size: clamp(1.2rem, 1.9vw, 1.4rem); color: var(--text); line-height: 1.6; }
.pull { font-family: var(--serif); font-style: italic; font-size: clamp(1.5rem, 3vw, 2rem); line-height: 1.35; color: var(--text); border-left: 2px solid var(--amber); padding: 6px 0 6px 26px; margin: 1.6em 0; }
.symbol-tags { display: flex; flex-wrap: wrap; gap: 10px; }
.symbol-tags .sym { font-size: 0.95rem; padding: 9px 16px; border-radius: 999px; background: rgba(255,255,255,0.06); border: 1px solid var(--line); }
.app-inline { margin: 2.2em 0; padding: clamp(22px, 3vw, 32px); display: flex; align-items: center; gap: 22px; flex-wrap: wrap; justify-content: space-between; }
.app-inline p { margin: 0; max-width: 44ch; } .app-inline .h3 { font-family: var(--display); }

/* FAQ */
.faq { max-width: 720px; margin-inline: auto; }
.faq details { border-bottom: 1px solid var(--line); padding: 6px 0; }
.faq summary { list-style: none; cursor: pointer; padding: 20px 4px; font-family: var(--display); font-weight: 600; font-size: 1.18rem; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .plus { width: 26px; height: 26px; flex: none; position: relative; }
.faq summary .plus::before, .faq summary .plus::after { content: ""; position: absolute; background: var(--amber); border-radius: 2px; }
.faq summary .plus::before { left: 0; top: 12px; width: 26px; height: 2px; }
.faq summary .plus::after { left: 12px; top: 0; width: 2px; height: 26px; transition: transform .3s, opacity .3s; }
.faq details[open] summary .plus::after { transform: rotate(90deg); opacity: 0; }
.faq details[open] summary .plus::before { background: var(--text-faint); }
.faq .faq-body { padding: 0 4px 22px; color: var(--text-soft); font-size: 1.05rem; line-height: 1.65; }
.faq .faq-body a { color: var(--amber); }

/* meaning cards / hub */
.related-grid, .meaning-grid, .theme-grid { position: relative; z-index: 1; }
.meaning-card { display: flex; flex-direction: column; overflow: hidden; transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s; border-radius: var(--r); }
.meaning-card:hover { transform: translateY(-4px); border-color: var(--line-2); }
.meaning-art { height: 120px; }
.meaning-card__body { padding: 18px 20px 22px; }
.meaning-card__body .muted { display: block; margin-top: 6px; font-size: 0.92rem; }
.meaning-card--more { align-items: flex-start; justify-content: center; gap: 8px; padding: 26px; background: rgba(255,255,255,0.04); }
.hub-hero { padding-top: clamp(120px, 16vh, 170px); }
.meaning-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.search-faux { display: flex; align-items: center; gap: 12px; padding: 17px 22px; border-radius: 999px; background: rgba(255,255,255,0.05); border: 1px solid var(--line); backdrop-filter: blur(12px); color: var(--text-faint); font-size: clamp(0.95rem, 1.6vw, 1.15rem); max-width: 640px; }
.search-faux .type-cursor { color: var(--text); border-right: 2px solid var(--amber); padding-right: 2px; animation: caret 1.1s step-end infinite; }
@keyframes caret { 50% { border-color: transparent; } }
@media (prefers-reduced-motion: reduce) { .type-cursor { animation: none; } }
.theme-pill { display: flex; flex-direction: column; gap: 4px; padding: 20px 22px; border-radius: var(--r); transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s; }
.theme-pill:hover { transform: translateY(-3px); border-color: var(--line-2); }
.theme-pill span { font-family: var(--display); font-weight: 600; font-size: 1.12rem; }
.theme-pill small { color: var(--text-faint); font-size: 0.86rem; }
.hub-cta { display: grid; grid-template-columns: 1fr auto; gap: clamp(20px, 4vw, 48px); align-items: center; position: relative; overflow: hidden; padding: clamp(28px, 4vw, 52px); }
@media (max-width: 760px) { .hub-cta { grid-template-columns: 1fr; } }

/* glows used inline become soft ember blooms */
.glow { position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none; z-index: 0; }
.glow--ember { background: radial-gradient(circle, rgba(255,106,31,0.28), transparent 70%); }
.glow--rust  { background: radial-gradient(circle, rgba(122,26,0,0.4), transparent 70%); }
.glow--amber { background: radial-gradient(circle, rgba(255,171,94,0.2), transparent 70%); }

/* ----- Footer ----- */
.site-footer { position: relative; border-top: 1px solid var(--line); padding-block: clamp(56px, 7vw, 88px) 40px; z-index: 1; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.footer-col h4 { font-family: var(--system); font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--amber); margin-bottom: 16px; font-weight: 700; }
.footer-col a { display: block; color: var(--text-soft); font-size: 0.95rem; padding: 7px 0; transition: color .2s; }
.footer-col a:hover { color: var(--text); }
.footer-brand p { color: var(--text-faint); max-width: 30ch; margin-top: 14px; font-size: 0.95rem; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; margin-top: 56px; padding-top: 26px; border-top: 1px solid var(--line); color: var(--text-dim); font-size: 0.88rem; }
@media (max-width: 760px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 30px; } .footer-brand { grid-column: 1 / -1; } }

/* ----- Minimal night chrome (matches index.html) ----- */
.brand-mark { position: fixed; top: clamp(18px,3vw,30px); left: var(--gutter); z-index: 60; display: inline-flex; align-items: center; gap: 10px; font-family: var(--display); font-weight: 700; font-size: 1.02rem; letter-spacing: 0.04em; color: var(--text); mix-blend-mode: difference; }
.brand-mark svg { width: 22px; height: 22px; }
.get-app { position: fixed; top: clamp(16px,3vw,26px); right: var(--gutter); z-index: 60; display: inline-flex; align-items: center; gap: 9px; padding: 11px 18px; white-space: nowrap; border-radius: 999px; background: rgba(10,4,4,0.5); border: 1px solid var(--line); backdrop-filter: blur(14px); font-size: 0.9rem; font-weight: 600; color: var(--text); transition: background .25s, border-color .25s, transform .25s; }
.get-app:hover { background: rgba(255,120,50,0.16); border-color: var(--line-2); transform: translateY(-1px); }
.get-app .apple { width: 16px; height: 16px; fill: var(--text); }
@media (max-width: 620px) { .get-app { top: auto; bottom: 16px; left: 50%; right: auto; transform: translateX(-50%); } .get-app:hover { transform: translateX(-50%) translateY(-1px); } }

.footer-min { padding: clamp(40px,6vw,70px) var(--gutter) 40px; border-top: 1px solid var(--line); position: relative; z-index: 2; }
.footer-min__inner { max-width: 1100px; margin-inline: auto; display: flex; flex-wrap: wrap; justify-content: space-between; gap: 24px; align-items: center; }
.footer-min .brand-mark { position: static; mix-blend-mode: normal; }
.footer-min__links { display: flex; flex-wrap: wrap; gap: 20px; }
.footer-min__links a { color: var(--text-faint); font-size: 0.92rem; transition: color .2s; }
.footer-min__links a:hover { color: var(--text); }
.footer-min__legal { color: var(--text-dim); font-size: 0.84rem; }
