/* site.css — Quave shared design system.
   Structure and components follow the proven layout of other SenSym products (consistent
   site header/nav/footer, hero + promises grid, supporter pill, guide cards) while the SKIN
   stays Quave's own: planetarium dark, light/optics motif, amplitude bars as the hero.
   Used by every public page. textContent-only pages; this file is styling only. */

:root {
  --void: #05060f;
  --void2: #0a0e22;
  --panel: rgba(16, 22, 48, 0.72);
  --panel-solid: #101630;
  --line: rgba(120, 150, 255, 0.16);
  --ink: #e8ecff;
  --dim: #8a93c4;
  --beam: #7fd4ff;   /* primary light-beam cyan */
  --beam2: #b98cff;  /* secondary violet */
  --warm: #ffb56b;   /* supporter / warm accent */
  --warm2: #ff8f5a;
  --warn: #ffd27f;
  --ok: #8affc1;
  --err: #ff9d9d;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --shadow: 0 1px 2px rgba(0, 0, 0, .35), 0 8px 22px rgba(0, 0, 0, .35);
  --glow: 0 0 26px rgba(127, 212, 255, 0.28);
  --beam-grad: linear-gradient(90deg, var(--beam), var(--beam2));
  --warm-grad: linear-gradient(180deg, var(--warm), var(--warm2));
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font: 15px/1.6 var(--sans);
  color: var(--ink);
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(120, 90, 220, 0.20), transparent 60%),
    radial-gradient(900px 600px at 8% 108%, rgba(40, 160, 220, 0.16), transparent 60%),
    var(--void);
  background-attachment: fixed;
}
/* faint starfield */
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; opacity: 0.5; z-index: 0;
  background-image:
    radial-gradient(1px 1px at 20% 30%, #fff, transparent), radial-gradient(1px 1px at 70% 60%, #cfe, transparent),
    radial-gradient(1px 1px at 40% 80%, #fff, transparent), radial-gradient(1px 1px at 85% 20%, #dcf, transparent),
    radial-gradient(1px 1px at 55% 15%, #fff, transparent), radial-gradient(1px 1px at 12% 66%, #fff, transparent),
    radial-gradient(1px 1px at 92% 78%, #cfe, transparent);
  background-repeat: no-repeat;
}
a { color: var(--beam); }
main { position: relative; z-index: 1; }

/* ---- accessibility ---- */
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 50;
  background: var(--beam); color: var(--void); padding: 8px 14px; border-radius: 0 0 8px 0; font-weight: 700;
}
.skip-link:focus { left: 0; }

/* ---- site header (every page) ---- */
.site-header {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  padding: 12px 22px; border-bottom: 1px solid var(--line); position: relative; z-index: 2;
  background: linear-gradient(180deg, rgba(10, 14, 34, 0.92), rgba(10, 14, 34, 0.55));
}
.brand { display: inline-flex; align-items: center; gap: 9px; font-size: 19px; font-weight: 800; letter-spacing: 0.4px; color: var(--ink); text-decoration: none; white-space: nowrap; }
.brand b { color: var(--beam); }
.brand:hover { text-decoration: none; }
/* the "prism" equivalent: a tiny beam splitting into two phases */
.beammark { display: inline-block; width: 15px; height: 15px; border-radius: 4px; background: linear-gradient(135deg, var(--beam), var(--beam2)); box-shadow: 0 0 0 3px rgba(127, 212, 255, 0.14); }
.brand .tag { font-weight: 400; font-size: 12px; color: var(--dim); margin-left: 4px; }

.site-header nav { margin-left: auto; display: flex; gap: 4px 16px; align-items: center; flex-wrap: wrap; font-size: 13.5px; }
.site-header nav a { color: var(--dim); text-decoration: none; padding: 5px 2px; transition: color .15s; }
.site-header nav a:hover { color: var(--beam); }
.site-header nav a[aria-current="page"] { color: var(--ink); font-weight: 600; }
.site-header nav a.nav-studio {
  color: var(--void); background: var(--beam-grad); border-radius: 999px; padding: 6px 14px; font-weight: 700;
}
.site-header nav a.nav-studio:hover { filter: brightness(1.1); color: var(--void); }
/* supporter pill — warm, heart-led, mirrors the sibling sites so families recognize it */
.site-header nav a.nav-donate {
  background: var(--warm-grad); color: #3a1c05; font-weight: 700; padding: 6px 14px; border-radius: 999px;
  box-shadow: 0 2px 10px rgba(255, 143, 90, .30);
  transition: transform .12s, box-shadow .12s;
}
.site-header nav a.nav-donate::before { content: "\2665"; margin-right: 6px; color: #7c2d05; }
.site-header nav a.nav-donate:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(255, 143, 90, .45); color: #3a1c05; }

/* ---- buttons ---- */
.btn {
  font: inherit; font-size: 15px; font-weight: 700; text-decoration: none; display: inline-block;
  border: 1px solid transparent; border-radius: 999px; padding: 11px 20px; cursor: pointer;
  color: var(--void); background: var(--beam-grad); box-shadow: var(--glow);
  transition: transform .12s, filter .12s;
}
.btn:hover { transform: translateY(-1px); filter: brightness(1.08); }
.btn.ghost { color: var(--ink); background: transparent; border-color: var(--line); box-shadow: none; }
.btn.ghost:hover { border-color: var(--beam); }
.btn.warm { color: #3a1c05; background: var(--warm-grad); box-shadow: 0 2px 12px rgba(255, 143, 90, .35); }
.btn.small { font-size: 13px; padding: 7px 15px; }
.btn:disabled, .btn.is-disabled { opacity: .55; cursor: not-allowed; pointer-events: none; }

/* ---- hero (home + simple pages) ---- */
.hero { max-width: 880px; margin: 0 auto; padding: 52px 24px 20px; text-align: center; }
.hero h1 {
  font-size: 40px; line-height: 1.12; letter-spacing: -0.5px; margin: 0 0 14px;
  background: var(--beam-grad); -webkit-background-clip: text; background-clip: text;
  color: var(--beam); -webkit-text-fill-color: transparent;
}
@media (max-width: 520px) { .hero h1 { font-size: 31px; } }
.hero .lede { font-size: 17.5px; color: var(--ink); max-width: 640px; margin: 0 auto 10px; line-height: 1.6; }
.hero .sub { font-size: 14px; color: var(--dim); max-width: 620px; margin: 0 auto 24px; line-height: 1.6; }
.cta { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ---- promises grid ---- */
.promises {
  max-width: 980px; margin: 26px auto; padding: 0 24px;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px;
}
.promise {
  position: relative; overflow: hidden; background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px; box-shadow: var(--shadow); backdrop-filter: blur(6px);
}
.promise::before, .panelstripe::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--beam-grad);
}
.promise h3 { margin: 0 0 6px; font-size: 15px; }
.promise p { margin: 0; color: var(--dim); font-size: 13.5px; }

/* ---- generic blocks / sections ---- */
.block { max-width: 980px; margin: 0 auto; padding: 30px 24px; }
.block.center { text-align: center; }
.kicker { color: var(--beam2); font-size: 12px; letter-spacing: 1.4px; text-transform: uppercase; margin: 0 0 8px; }
h2.blocktitle { margin: 0 0 6px; font-size: 25px; }
.blockintro { color: var(--dim); font-size: 15px; max-width: 74ch; line-height: 1.6; margin: 0 0 18px; }
.block.center .blockintro { margin-left: auto; margin-right: auto; }

/* ---- cards (gallery demos, features) ---- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 16px; }
.app-card {
  position: relative; overflow: hidden; display: flex; flex-direction: column; gap: 8px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 16px;
  box-shadow: var(--shadow); backdrop-filter: blur(6px); transition: transform .12s, box-shadow .12s;
}
.app-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--beam-grad); }
.app-card:hover { transform: translateY(-2px); }
.app-card h3 { margin: 0; font-size: 16px; }
.app-card p { margin: 0; color: var(--dim); font-size: 13.5px; flex: 1; }
.app-card .meta { font-size: 12px; color: var(--dim); display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.app-card .tag { background: rgba(127, 212, 255, 0.10); color: var(--beam); border: 1px solid var(--line); border-radius: 20px; padding: 2px 9px; font-weight: 600; text-transform: capitalize; }

/* ---- steps (journey) ---- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 860px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .steps { grid-template-columns: 1fr; } }
.step { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 16px; }
.step .n { font-family: var(--mono); font-size: 12px; color: var(--void); background: var(--beam-grad); border-radius: 999px; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; font-weight: 700; }
.step h3 { margin: 10px 0 6px; font-size: 15px; }
.step p { margin: 0; color: var(--dim); font-size: 13px; }
.step code { font-family: var(--mono); font-size: 12px; color: var(--beam); }

/* ---- guide cards (Studio helper) ---- */
.guide-card { border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; margin: 0 0 10px; background: var(--panel); }
.guide-card h3 { margin: 0 0 4px; font-size: 14px; }
.guide-card p { margin: 0 0 8px; font-size: 13px; color: var(--ink); line-height: 1.5; }
.guide-snippet {
  display: block; font: 12.5px/1.5 var(--mono); background: rgba(0, 0, 0, 0.30);
  border: 1px solid var(--line); border-radius: 6px; padding: 6px 8px; margin: 0 0 8px;
  white-space: pre-wrap; color: var(--ink);
}
.guide-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.guide-insert { font: inherit; font-size: 12.5px; padding: 5px 10px; border: 1px solid var(--beam); border-radius: 7px; background: var(--beam); color: var(--void); font-weight: 700; cursor: pointer; }
.guide-insert:hover { filter: brightness(1.1); }
.guide-link { font-size: 12.5px; padding: 5px 10px; border: 1px solid var(--line); border-radius: 7px; background: rgba(127, 212, 255, 0.06); color: var(--ink); text-decoration: none; }
.guide-link:hover { border-color: var(--beam); }

/* ---- supporter presets (donate page) ---- */
.preset-row { display: flex; gap: 10px; flex-wrap: wrap; margin: 14px 0 6px; }
.preset-row .btn { min-width: 64px; text-align: center; padding: 9px 14px; font-size: 14px; }
.preset-row .btn.chosen { outline: 3px solid var(--warm); outline-offset: 1px; }
.custom-row { display: flex; gap: 10px; align-items: center; margin: 10px 0 16px; }
.custom-row input {
  width: 96px; padding: 8px; font: inherit; color: var(--ink); background: rgba(0, 0, 0, 0.3);
  border: 1px solid var(--line); border-radius: 8px;
}
.donate-card { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: 12px; padding: 20px 22px; margin: 18px 0; background: var(--panel); box-shadow: var(--shadow); }
.donate-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--warm-grad); }
.donate-status { min-height: 20px; margin-top: 8px; font-size: 14px; color: var(--dim); }
.donate-status.err { color: var(--err); }
.donate-soon { color: var(--warn); font-size: 14px; }

/* ---- crumb (back home from inner pages) ---- */
.crumb { max-width: 980px; margin: 0 auto; padding: 12px 24px 0; font-size: 13px; color: var(--dim); }
.crumb a { color: var(--beam); text-decoration: none; }
.crumb a:hover { text-decoration: underline; }

/* ---- footer (every page) ---- */
.footer-links { margin-top: 26px; padding: 0 24px; text-align: center; font-size: 13px; position: relative; z-index: 1; }
.footer-links a { color: var(--dim); text-decoration: none; margin: 0 10px; white-space: nowrap; }
.footer-links a:hover { color: var(--beam); text-decoration: underline; }
.footer-links a.donate { color: var(--warm); font-weight: 600; }
.site-footer {
  padding: 20px 24px 36px; margin-top: 12px; color: var(--dim); font-size: 12.5px; text-align: center;
  border-top: 1px solid var(--line); position: relative; z-index: 1;
  background: linear-gradient(180deg, rgba(16, 22, 48, 0), rgba(16, 22, 48, 0.5));
}
