/* ===========================================================
   THE DMT ATLAS — brand system
   Display: Fraunces · UI/body: Inter
   Palette: deep void + gold + violet, category accents
   =========================================================== */
:root{
  --void:#06040e;
  --void2:#0a0719;
  --panel:#0c0920f2;
  --ink:#ece8ff;
  --muted:#9a92c7;
  --faint:#6c6597;
  --line:#211c3c;
  --line2:#312a55;
  --gold:#f3c969;
  --gold-deep:#caa24a;
  --accent:#b18cff;
  --c-entity:#b48cff;
  --c-realm:#56d6cd;
  --c-geometry:#7aa2ff;
  --c-theme:#ff8fb1;
  --c-phase:#f3c969;
  --c-source:#f4a85f;
  --shadow:0 18px 60px -20px rgba(0,0,0,.7);
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  background:var(--void);
  color:var(--ink);
  font-family:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3{margin:0;font-weight:600}

/* cosmic backdrop layer (gpt-image-2) + gradient + vignette */
#cosmos{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(1100px 760px at 72% -12%, rgba(60,38,120,.34), transparent 60%),
    radial-gradient(900px 700px at 12% 108%, rgba(20,90,96,.20), transparent 60%),
    url("assets/img/void_bg.png") center/cover no-repeat,
    var(--void);
  opacity:1;
}
#cosmos::after{ /* vignette to deepen edges */
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 120% at 50% 40%, transparent 55%, rgba(2,1,7,.72) 100%);
}

/* ---------- top bar ---------- */
#topbar{
  position:fixed;inset:0 0 auto 0;height:68px;z-index:30;
  display:flex;align-items:center;gap:18px;padding:0 20px;
  background:linear-gradient(180deg,#070514 0%,#070514d8 40%,#07051400 100%);
}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand .mark{color:var(--gold);font-size:20px;filter:drop-shadow(0 0 10px #f3c96977);animation:spin 80s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.titles h1{font-family:"Fraunces",Georgia,serif;font-size:21px;line-height:1;letter-spacing:.2px}
.tagline{margin:4px 0 0;font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw;letter-spacing:.2px}
.tabs{display:flex;gap:5px;margin-left:auto;background:#0e0a26;border:1px solid var(--line);border-radius:999px;padding:4px}
.tabs button{
  appearance:none;border:0;background:transparent;color:var(--muted);
  font:inherit;font-size:13px;padding:8px 16px;border-radius:999px;cursor:pointer;transition:.16s;letter-spacing:.2px;
}
.tabs button:hover{color:var(--ink)}
.tabs button.active{background:linear-gradient(180deg,#2c2256,#1a1540);color:#fff;box-shadow:0 0 0 1px #3a316b inset,0 0 18px -6px #b18cff66}
.ghost{
  appearance:none;background:transparent;border:1px solid var(--line2);color:var(--muted);
  font:inherit;font-size:12.5px;padding:9px 14px;border-radius:11px;cursor:pointer;transition:.16s;
}
.ghost:hover{color:var(--ink);border-color:var(--accent);box-shadow:0 0 18px -8px #b18cff88}

/* ---------- stage / canvas ---------- */
#stage{position:fixed;inset:0;z-index:5}
#canvas{position:absolute;inset:0;display:block;cursor:grab}
#canvas.grabbing{cursor:grabbing}
.hidden{display:none !important}

.hint{
  position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:20;
  font-size:12px;color:var(--muted);background:#0a0720cc;border:1px solid var(--line);
  padding:8px 16px;border-radius:999px;pointer-events:none;opacity:.92;letter-spacing:.2px;
  box-shadow:var(--shadow);
}
.legend{
  position:fixed;left:18px;bottom:18px;z-index:20;
  display:flex;flex-direction:column;gap:6px;
  background:#09061ecc;border:1px solid var(--line);border-radius:14px;padding:12px 14px;
  font-size:11.5px;color:var(--muted);box-shadow:var(--shadow);backdrop-filter:blur(4px);
}
.legend .row{display:flex;align-items:center;gap:9px}
.legend .dot{width:9px;height:9px;border-radius:50%;box-shadow:0 0 8px currentColor}

/* ---------- journey ---------- */
#journey{position:absolute;inset:68px 0 0 0;overflow-y:auto;padding:42px 22px 130px;scroll-behavior:smooth}
.journey-inner{max-width:780px;margin:0 auto}
.journey-intro{color:var(--muted);font-size:14.5px;margin:0 0 30px;text-align:center;line-height:1.7}
.phase{
  position:relative;padding:20px 20px 20px 62px;margin:0 0 16px;
  border:1px solid var(--line);border-radius:18px;
  background:linear-gradient(180deg,#0d0a24cc,#0a0820cc);box-shadow:var(--shadow);
}
.phase::before{
  content:attr(data-order);position:absolute;left:15px;top:20px;
  width:32px;height:32px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,#3a2d68,#15112f);color:var(--gold);
  font-family:"Fraunces",serif;font-size:14px;font-weight:600;border:1px solid #4a3f7e;
  box-shadow:0 0 16px -4px #f3c96955;
}
.phase:not(:last-child)::after{content:"";position:absolute;left:30px;top:58px;bottom:-16px;width:2px;background:linear-gradient(180deg,#4a3f7e,#4a3f7e00)}
.phase h3{font-family:"Fraunces",serif;margin:0 0 7px;font-size:18px;letter-spacing:.2px}
.phase p{margin:0 0 12px;color:#d4cef2;font-size:14px;line-height:1.62}
.chiprow{display:flex;flex-wrap:wrap;gap:7px}
.chip{
  font-size:11.5px;color:var(--ink);background:#181238;border:1px solid #2c2552;
  padding:5px 10px;border-radius:999px;cursor:pointer;transition:.13s;
}
.chip:hover{border-color:var(--accent);color:#fff;box-shadow:0 0 14px -6px #b18cffaa}
.chip .swatch{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:middle;box-shadow:0 0 6px currentColor}

/* ---------- dossier ---------- */
.dossier{
  position:fixed;top:68px;right:0;bottom:0;width:min(450px,94vw);z-index:40;
  background:var(--panel);backdrop-filter:blur(14px);border-left:1px solid var(--line2);
  transform:translateX(100%);transition:transform .3s cubic-bezier(.2,.7,.2,1);
  overflow-y:auto;padding:24px 24px 64px;box-shadow:-30px 0 80px -30px rgba(0,0,0,.8);
}
.dossier:not(.closed){transform:translateX(0)}
.dossier-close{position:absolute;top:13px;right:15px;appearance:none;background:transparent;border:0;color:var(--muted);font-size:25px;line-height:1;cursor:pointer;z-index:2}
.dossier-close:hover{color:#fff}
.d-type{display:inline-block;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:4px 11px;border-radius:999px;margin-bottom:12px;font-weight:600}
.d-name{font-family:"Fraunces",serif;font-size:25px;font-weight:600;line-height:1.12;margin:0 0 5px}
.d-aka{color:var(--muted);font-size:12.5px;margin:0 0 18px;font-style:italic}
.d-field{margin:0 0 14px}
.d-field .k{font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}
.d-field .v{font-size:13.5px;color:#ded9f6;line-height:1.58}
.d-section-h{font-family:"Fraunces",serif;font-size:13.5px;letter-spacing:.02em;color:var(--gold);margin:22px 0 11px;border-top:1px solid var(--line);padding-top:16px}
.quote{border-left:2px solid var(--gold-deep);padding:3px 0 3px 13px;margin:0 0 12px}
.quote .q{font-size:13px;color:#e9e5ff;line-height:1.56}
.quote .cite{font-size:11.5px;color:var(--muted);margin-top:5px}
.crosslinks{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
.muted{color:var(--muted)}
.src-item{font-size:12px;color:#cfc9f1;margin:0 0 8px;line-height:1.5}

/* ---------- about modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;background:#03020880;backdrop-filter:blur(6px);padding:18px}
.modal-card{position:relative;max-width:580px;width:100%;max-height:84vh;overflow:auto;background:linear-gradient(180deg,#0c0920,#080615);border:1px solid var(--line2);border-radius:22px;padding:30px;box-shadow:var(--shadow)}
.modal-card h2{font-family:"Fraunces",serif;font-size:23px;margin-bottom:14px}
.modal-card>p{font-size:14px;line-height:1.66;color:#d8d3f4}
.charter-list{margin:18px 0 4px;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.charter-list li{font-size:13px;line-height:1.56;color:#cfc9f1;padding-left:20px;position:relative}
.charter-list li::before{content:"✦";position:absolute;left:0;color:var(--gold);font-size:11px;top:3px}
.charter-list strong{color:var(--ink)}

/* ---------- intro splash (the chrysanthemum gateway) ---------- */
#intro{
  position:fixed;inset:0;z-index:80;display:grid;place-items:center;text-align:center;
  background:radial-gradient(120% 120% at 50% 42%, #0a0720 0%, #050309 70%, #030207 100%);
  transition:opacity .9s ease, visibility .9s;
}
#intro.gone{opacity:0;visibility:hidden;pointer-events:none}
#introFlower{
  position:absolute;width:min(88vmin,760px);height:auto;opacity:.82;
  mix-blend-mode:screen;
  filter:drop-shadow(0 0 70px #b06bff44);
  animation:spin 90s linear infinite;
  pointer-events:none;
}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}}
.intro-glow{position:absolute;width:min(60vmin,520px);height:min(60vmin,520px);border-radius:50%;background:radial-gradient(circle,#1a0f33aa,transparent 70%);animation:breathe 9s ease-in-out infinite}
.intro-content{position:relative;z-index:2;max-width:560px;padding:0 26px}
.intro-content::before{content:"";position:absolute;inset:-22% -32%;z-index:-1;background:radial-gradient(closest-side,rgba(5,3,12,.86),rgba(5,3,12,.5) 52%,transparent 78%);filter:blur(10px)}
.intro-kicker{font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;opacity:.85}
.intro-title{
  font-family:"Fraunces",serif;font-weight:600;font-size:clamp(40px,9vw,76px);line-height:.98;margin:0;
  background:linear-gradient(180deg,#fff 0%,#f3c969 60%,#caa24a 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px rgba(243,201,105,.18);
}
.intro-tag{font-size:clamp(14px,2.4vw,17px);color:#e7e2ff;margin:20px 0 0;line-height:1.5}
.intro-note{font-size:12.5px;color:var(--muted);margin:14px auto 0;max-width:440px;line-height:1.6}
.intro-note em{color:#cfc7f0;font-style:italic}
.enter{
  margin-top:30px;appearance:none;cursor:pointer;
  font-family:"Inter",sans-serif;font-size:14.5px;font-weight:600;letter-spacing:.3px;color:#1a1206;
  padding:14px 34px;border:0;border-radius:999px;
  background:linear-gradient(180deg,#f7d77f,#e7b54e);
  box-shadow:0 0 0 1px #f3c96944,0 14px 40px -12px #f3c96988;transition:.16s transform,.16s box-shadow;
}
.enter:hover{transform:translateY(-2px);box-shadow:0 0 0 1px #f3c96966,0 20px 50px -12px #f3c969aa}
.intro-stats{margin:24px 0 0;font-size:12px;color:var(--faint);letter-spacing:.16em;text-transform:uppercase}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .titles h1{font-size:19px}
  .tabs button{padding:8px 13px;font-size:12.5px}
}
@media (max-width:640px){
  #topbar{height:58px;padding:0 16px;gap:10px}
  .tagline{display:none}
  .brand .mark{font-size:18px}
  .titles h1{font-size:18px;white-space:nowrap}
  #aboutBtn{margin-left:auto;padding:8px 12px;font-size:12.5px}
  /* tabs become a bottom nav bar */
  .tabs{
    position:fixed;left:0;right:0;bottom:0;top:auto;margin:0;width:100%;z-index:35;
    border:0;border-top:1px solid var(--line2);border-radius:0;padding:0;gap:0;
    background:#0a0720f2;backdrop-filter:blur(10px);box-shadow:0 -10px 30px -12px rgba(0,0,0,.6);
  }
  .tabs button{flex:1;border-radius:0;padding:14px 6px;font-size:12.5px}
  .tabs button.active{background:linear-gradient(180deg,#241c48,#160f33);box-shadow:none;color:#fff;border-top:2px solid var(--gold)}
  .legend{display:none}
  .hint{display:none}
  #journey{inset:58px 0 56px 0;padding:26px 16px 40px}
  .phase{padding:18px 16px 18px 56px}
  /* dossier becomes a bottom sheet (above the bottom nav) */
  .dossier{
    top:auto;left:0;right:0;bottom:0;width:100%;max-height:82vh;z-index:46;
    border-left:0;border-top:1px solid var(--line2);
    border-radius:22px 22px 0 0;transform:translateY(100%);
    transition:transform .3s cubic-bezier(.2,.7,.2,1);padding:22px 20px 56px;
  }
  .dossier:not(.closed){transform:translateY(0)}
}

/* ===========================================================
   TOOL / CONTENT PAGES (Identify, Questions, etc.)
   =========================================================== */
body.page{overflow-y:auto;overflow-x:hidden;height:auto;min-height:100%}
.page-head{
  position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;background:linear-gradient(180deg,#070514,#070514cc 50%,#07051400);
}
.page-head .back{font-family:"Fraunces",serif;font-size:15px;color:var(--ink);text-decoration:none;letter-spacing:.2px}
.page-head .back:hover{color:var(--gold)}
.page-nav{display:flex;gap:6px;background:#0e0a26;border:1px solid var(--line);border-radius:999px;padding:4px}
.page-nav a{font-size:13px;color:var(--muted);text-decoration:none;padding:7px 15px;border-radius:999px;transition:.15s}
.page-nav a:hover{color:var(--ink)}
.page-nav a.on{background:linear-gradient(180deg,#2c2256,#1a1540);color:#fff;box-shadow:0 0 0 1px #3a316b inset}

.tool{position:relative;z-index:5;max-width:760px;margin:0 auto;padding:30px 22px 80px}
.tool-intro{text-align:center;margin-bottom:34px}
.tool-intro h1{font-family:"Fraunces",serif;font-weight:600;font-size:clamp(34px,7vw,56px);line-height:1.02;margin:6px 0 0;
  background:linear-gradient(180deg,#fff,#f3c969 70%,#caa24a);-webkit-background-clip:text;background-clip:text;color:transparent}
.lede{font-size:15.5px;color:#d8d3f4;line-height:1.65;max-width:600px;margin:18px auto 0}
.tiny-note{font-size:12.5px;color:var(--muted);line-height:1.6;max-width:560px;margin:14px auto 0}
.tiny-note strong{color:#cfc7f0}

.quiz{display:flex;flex-direction:column;gap:18px}
.qblock{border:1px solid var(--line);border-radius:18px;background:#0c0a22aa;padding:18px 18px 20px;margin:0}
.qblock legend{font-family:"Fraunces",serif;font-size:17px;color:var(--ink);padding:0 6px;margin-left:4px}
.opts{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:6px}
.opt{
  text-align:left;font:inherit;font-size:13.5px;color:#d4cef2;cursor:pointer;
  background:#15102f;border:1px solid #2a2450;border-radius:12px;padding:12px 13px;transition:.13s;
}
.opt:hover{border-color:var(--accent);color:#fff}
.opt.sel{background:linear-gradient(180deg,#2a2056,#1c1640);border-color:var(--accent);color:#fff;box-shadow:0 0 18px -7px #b18cffaa}

.quiz-actions{display:flex;gap:12px;justify-content:center;align-items:center;margin:28px 0 0;flex-wrap:wrap}
.quiz-actions .enter[disabled]{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}

.results{margin-top:14px}
.results:empty{margin:0}
.results-h{font-family:"Fraunces",serif;font-size:24px;text-align:center;margin:36px 0 4px}
.results-sub{text-align:center;color:var(--muted);font-size:13.5px;margin:0 0 22px}
.results-foot{margin-top:22px;text-align:center}
.match{border:1px solid var(--line2);border-radius:18px;background:linear-gradient(180deg,#0e0a26,#0a0820);padding:18px 20px;margin:0 0 14px;box-shadow:var(--shadow)}
.match-top{display:flex;align-items:center;gap:14px}
.match-rank{font-family:"Fraunces",serif;font-size:18px;font-weight:600;color:var(--gold);width:30px;height:30px;flex:0 0 auto;display:grid;place-items:center;border:1px solid #4a3f7e;border-radius:50%;background:radial-gradient(circle at 30% 30%,#3a2d68,#15112f)}
.match-top h3{font-family:"Fraunces",serif;font-size:19px;margin:0;line-height:1.1}
.match-type{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--c-entity)}
.match-bar{margin-left:auto;width:120px;height:7px;border-radius:999px;background:#1c1740;overflow:hidden;flex:0 0 auto}
.match-bar span{display:block;height:100%;background:linear-gradient(90deg,#b18cff,#f3c969)}
.match-purpose{font-size:14px;color:#ded9f6;line-height:1.6;margin:14px 0 8px}
.match-freq{font-size:12.5px;color:var(--muted);line-height:1.55;margin:0}
.match-freq strong{color:var(--accent);font-weight:600}
.match-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.match-src{font-size:11.5px;color:var(--muted)}
.match-link{font-size:13px;color:var(--gold);text-decoration:none;white-space:nowrap}
.match-link:hover{text-decoration:underline}

.page-foot{position:relative;z-index:5;max-width:760px;margin:0 auto;padding:24px 22px 50px;display:flex;flex-wrap:wrap;gap:8px 16px;justify-content:space-between;border-top:1px solid var(--line);color:var(--faint);font-size:12px}
.page-foot a{color:var(--muted);text-decoration:none}
.page-foot a:hover{color:var(--gold)}

/* index intro secondary link */
.intro-links{margin:18px 0 0}
.intro-links a{color:var(--accent);text-decoration:none;font-size:13.5px;letter-spacing:.2px}
.intro-links a:hover{color:#fff;text-shadow:0 0 18px #b18cff88}
.intro-links em{font-style:italic;color:var(--gold)}

/* support / content blocks (grounding + questions) */
.support{position:relative;z-index:5;margin:0 0 34px}
.block-h{font-family:"Fraunces",serif;font-size:21px;color:var(--ink);margin:0 0 16px}
.support.now .block-h{color:var(--gold)}
.res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:13px}
.res{border:1px solid var(--line);border-radius:16px;background:#0c0a22cc;padding:16px 17px 18px}
.res.urgent{border-color:#6e4a52;box-shadow:0 0 22px -10px #ff8fb155}
.res h3{font-family:"Fraunces",serif;font-size:16.5px;margin:0 0 7px}
.res-what{font-size:12.8px;color:#cfc9f1;line-height:1.55;margin:0 0 11px}
.res-contact{font-size:13.5px;color:var(--ink);line-height:1.5;margin:0 0 11px}
.res-contact strong{color:#fff}
.res-link{font-size:12.5px;color:var(--gold);text-decoration:none}
.res-link:hover{text-decoration:underline}
.faq{border:1px solid var(--line);border-radius:14px;background:#0c0a22aa;margin:0 0 10px;overflow:hidden}
.faq summary{cursor:pointer;padding:15px 18px;font-family:"Fraunces",serif;font-size:16px;color:var(--ink);list-style:none;display:flex;align-items:baseline}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";color:var(--gold);margin-right:11px;font-family:"Inter",sans-serif;font-weight:600}
.faq[open] summary::before{content:"–"}
.faq p{padding:0 18px 16px;margin:0;color:#d4cef2;font-size:14px;line-height:1.64}
.faq p a,.res-what a,.lede a,.prose a{color:var(--accent);text-decoration:none}
.faq p a:hover,.prose a:hover{text-decoration:underline}
.support.boundary{border:1px solid var(--line2);border-radius:18px;background:#0c0920aa;padding:20px 22px}
.prose{font-size:14.5px;color:#d8d3f4;line-height:1.7;margin:0 0 14px}
.prose strong{color:var(--ink)}
.prose .src{display:block;font-size:11.5px;color:var(--muted);margin-top:6px}
.stance{border-left:2px solid var(--gold-deep);padding:4px 0 4px 14px;margin:0 0 14px}
.stance h4{font-family:"Fraunces",serif;font-size:15px;margin:0 0 4px;color:var(--gold)}
.stance p{margin:0;font-size:13.6px;color:#d4cef2;line-height:1.6}

@media (max-width:560px){
  .opts{grid-template-columns:1fr}
  .match-bar{width:74px}
  .page-nav a{padding:7px 11px;font-size:12px}
  .page-nav{gap:3px}
}

