/* ===========================================================================
   It's in the Signs, shared styles for the /learn explainer pages.
   Tokens copied verbatim from index.html so the Learn pages match the site
   exactly. Self-contained: used ONLY by the /learn pages, so it cannot affect
   the homepage. (Homepage keeps its own inline styles untouched.)
   =========================================================================== */
:root{
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
/* LIGHT (parchment almanac) */
html[data-theme="light"]{
  --bg:radial-gradient(900px 500px at 10% -10%,rgba(224,184,78,.25),transparent 60%),radial-gradient(1000px 700px at 90% 0%,rgba(63,91,64,.18),transparent 58%),linear-gradient(180deg,#fbf6ea 0%,#f6f0e2 38%,#efe2c8 100%);
  --ink:#27231d; --muted:#61594c; --head:#283f2b; --gold:#b08433; --gold-soft:#d9b765;
  --card:rgba(251,247,236,.9); --card-2:#fff9e8; --line:#d6c6a6; --btn-ink:#30230b;
  --hero-ink:#283f2b; --star-op:0;
}
/* DARK (moonlit celestial) */
html[data-theme="dark"]{
  --bg:radial-gradient(900px 560px at 12% 0%,rgba(216,183,101,.18),transparent 62%),radial-gradient(1000px 680px at 90% 0%,rgba(47,90,61,.32),transparent 62%),linear-gradient(180deg,#050705 0%,#09100b 45%,#0b100c 100%);
  --ink:#fff7e6; --muted:#cdbd95; --head:#f4dfa3; --gold:#d8b765; --gold-soft:#f4dfa3;
  --card:rgba(24,34,26,.66); --card-2:rgba(255,246,219,.06); --line:rgba(216,183,101,.34); --btn-ink:#111307;
  --hero-ink:#fff7e6; --star-op:.5;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg) no-repeat;background-size:100% 100%;color:var(--ink);font-family:var(--sans);line-height:1.62;-webkit-font-smoothing:antialiased;min-height:100vh}
/* starfield (dark only) */
body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:var(--star-op);transition:opacity .4s ease;
  background:radial-gradient(1px 1px at 18% 21%,#fff 0,transparent 2px),radial-gradient(1px 1px at 34% 12%,#fff 0,transparent 2px),radial-gradient(1px 1px at 79% 20%,#fff 0,transparent 2px),radial-gradient(1px 1px at 91% 44%,#fff 0,transparent 2px),radial-gradient(1px 1px at 12% 68%,#fff 0,transparent 2px),radial-gradient(1px 1px at 48% 78%,#fff 0,transparent 2px),radial-gradient(1px 1px at 70% 60%,#fff 0,transparent 2px),radial-gradient(1px 1px at 57% 31%,#fff 0,transparent 2px),radial-gradient(1px 1px at 25% 45%,#fff 0,transparent 2px);}
a{color:inherit}
h1,h2,h3{font-family:var(--serif);font-weight:600;margin:0;letter-spacing:.2px}
p{margin:0}
.wrap{width:min(1140px,calc(100% - 40px));margin:0 auto}
.eyebrow{color:var(--gold);text-transform:uppercase;letter-spacing:3px;font-size:11px;font-weight:800}

/* ---------- NAV (matches homepage) ---------- */
.topnote{background:linear-gradient(90deg,transparent,rgba(176,132,51,.16),transparent);color:var(--head);text-align:center;padding:7px 14px;font-family:var(--serif);letter-spacing:2.4px;text-transform:uppercase;font-size:11.5px;border-bottom:1px solid var(--line)}
.nav{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:18px;padding:12px 20px;backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;font-family:var(--serif);color:var(--ink);font-size:19px;min-width:max-content}
.mark{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 35% 30%,var(--gold-soft),var(--gold) 50%,#60491d 92%);color:#0c0c08;box-shadow:0 0 22px rgba(216,183,101,.28)}
.navlinks{margin-left:auto;display:flex;gap:16px;align-items:center}
.navlinks a:not(.btn){font-size:13px;color:var(--muted);text-decoration:none}
.navlinks a:hover{color:var(--head)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 16px;border-radius:999px;border:1px solid var(--line);background:var(--card-2);color:var(--ink);text-decoration:none;font-family:var(--serif);font-size:15px;cursor:pointer;transition:.18s ease}
.btn:hover{transform:translateY(-1px);border-color:var(--gold-soft)}
.btn.gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:var(--btn-ink);border-color:var(--gold)}
.theme-toggle{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--card-2);color:var(--ink);cursor:pointer;font-size:18px;display:grid;place-items:center;transition:.18s ease}
.theme-toggle:hover{border-color:var(--gold-soft);transform:translateY(-1px)}

/* ---------- ARTICLE LAYOUT ---------- */
.crumbs{padding:22px 0 0}
.crumbs a{color:var(--muted);text-decoration:none;font-size:13px}
.crumbs a:hover{color:var(--head)}
.article{width:min(820px,calc(100% - 40px));margin:0 auto;padding:8px 0 10px}
.art-head{padding:26px 0 8px;border-bottom:1px solid var(--line);margin-bottom:30px}
.art-head h1{font-size:clamp(34px,5.4vw,58px);line-height:1.02;color:var(--hero-ink);margin-top:12px}
.lede{margin-top:18px;color:var(--muted);font-size:20px;line-height:1.55;max-width:62ch}
.prose{font-size:17px}
.prose h2{font-size:clamp(24px,3.4vw,32px);color:var(--head);margin:38px 0 12px;line-height:1.1}
.prose h3{font-size:20px;color:var(--head);margin:26px 0 8px}
.prose p{color:var(--ink);margin:0 0 16px}
.prose p.muted{color:var(--muted)}
.prose ul,.prose ol{margin:0 0 16px;padding-left:22px;color:var(--ink)}
.prose li{margin:7px 0}
.prose strong{color:var(--head)}
.prose em{color:var(--gold)}

/* pull-quote / callout */
.callout{border:1px solid var(--line);background:var(--card);border-radius:18px;padding:18px 22px;margin:24px 0;position:relative}
.callout .ct{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:7px}
.callout p{margin:0;color:var(--ink)}
.callout.lore{background:radial-gradient(420px 200px at 12% 0%,rgba(216,183,101,.14),transparent 70%),var(--card)}

/* the 12-sign table */
.signs{border:1px solid var(--line);border-radius:18px;overflow:hidden;margin:22px 0}
.signrow{display:grid;grid-template-columns:46px 1.1fr 1.4fr;gap:12px;align-items:center;padding:12px 16px;border-top:1px solid var(--line)}
.signrow:first-child{border-top:none}
.signrow:nth-child(odd){background:var(--card-2)}
.signrow .gly{font-family:"Segoe UI Symbol","Apple Symbols",var(--serif);font-size:22px;color:var(--gold);text-align:center;text-shadow:0 0 7px rgba(216,183,101,.4)}
.signrow .nm{font-family:var(--serif);font-size:17px;color:var(--head)}
.signrow .nm small{display:block;font-family:var(--sans);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:2px}
.signrow .bp{font-size:14.5px;color:var(--ink)}

/* ---------- INTERACTIVE BODY-MAP TOOL (man-of-signs page) ---------- */
/* Layout: two-column on desktop (figure left, detail panel right), stacked on
   mobile. Sits between the lede and the first article heading. */
.bodytool{border:1px solid var(--line);border-radius:22px;background:radial-gradient(620px 280px at 18% 0%,rgba(216,183,101,.13),transparent 70%),var(--card);padding:26px 26px 30px;margin:0 0 36px}
.bodytool-head{text-align:center;margin-bottom:22px}
.bodytool-head h2{font-size:clamp(24px,3.4vw,32px);color:var(--head);margin:8px 0 10px;line-height:1.1}
.bodytool-sub{color:var(--muted);font-size:16px;max-width:54ch;margin:0 auto}
.bodytool-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:30px;align-items:start}
.bodytool-figure{min-width:0}
.bodytool-hint{text-align:center;color:var(--muted);font-size:13px;letter-spacing:.3px;margin-top:14px;font-style:italic}

/* figure + medallion overlay (coords + dotted lines reused from the homepage) */
.bodymap-frame{position:relative;max-width:460px;margin:0 auto}
.illo{display:block;width:100%;height:auto;border-radius:18px}
html[data-theme="light"] .illo.dark{display:none}
html[data-theme="dark"] .illo.light{display:none}
.bm-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.bm-lines line{stroke:var(--gold);stroke-width:1;stroke-dasharray:1 3;opacity:.6;vector-effect:non-scaling-stroke;transition:opacity .2s ease,stroke-width .2s ease}
html[data-theme="light"] .bm-lines line{stroke:#7d5e25;opacity:.85}
.bm-lines line.sel{opacity:1;stroke-width:1.6;stroke-dasharray:none}
.bm-meds{position:absolute;inset:0}
/* gold zodiac glyphs in clean gold rings, transparent centers (no emoji squares) */
.bm-med{position:absolute;width:clamp(30px,7%,40px);aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;display:grid;place-items:center;border:1px solid var(--gold);color:var(--gold);font-family:"Segoe UI Symbol","Apple Symbols",var(--serif);font-size:16px;line-height:1;text-shadow:0 0 7px rgba(216,183,101,.55);font-variant-emoji:text;cursor:pointer;padding:0;transition:box-shadow .2s ease,transform .12s ease,background .2s ease}
html[data-theme="dark"] .bm-med{background:rgba(5,7,5,.30)}
html[data-theme="light"] .bm-med{background:rgba(255,250,240,.42)}
.bm-med:hover{transform:translate(-50%,-50%) scale(1.08)}
.bm-med:focus-visible{outline:none;box-shadow:0 0 0 3px var(--gold-soft),0 0 18px 3px rgba(216,183,101,.6)}
/* selected state: stronger antique-gold ring + glow (glyph keeps the same gold) */
.bm-med.selected{box-shadow:0 0 0 3px var(--gold),0 0 22px 5px rgba(216,183,101,.7);z-index:4;background:radial-gradient(circle,rgba(216,183,101,.34),rgba(216,183,101,.10))}
/* today = the Moon's current sign: a soft halo so it reads even when unselected */
.bm-med.today{box-shadow:0 0 0 3px rgba(216,183,101,.5),0 0 24px 5px rgba(216,183,101,.55);z-index:3}
.bm-med.today.selected{box-shadow:0 0 0 3px var(--gold),0 0 30px 7px rgba(216,183,101,.85);z-index:5}

/* detail panel (updates on selection; aria-live) */
.bodytool-panel{border:1px solid var(--line);border-radius:18px;background:var(--card-2);padding:22px 24px;min-height:100%}
.bp-today{display:inline-block;font-family:var(--serif);font-size:13px;letter-spacing:.3px;color:var(--btn-ink);background:linear-gradient(135deg,var(--gold-soft),var(--gold));border:1px solid var(--gold);border-radius:999px;padding:5px 14px;margin-bottom:14px}
.bp-title{display:flex;align-items:baseline;gap:10px;margin-bottom:4px}
.bp-name{font-family:var(--serif);font-size:28px;color:var(--head);line-height:1.1}
.bp-glyph{font-family:"Segoe UI Symbol","Apple Symbols",var(--serif);font-size:26px;color:var(--gold);text-shadow:0 0 8px rgba(216,183,101,.45);font-variant-emoji:text}
.bp-meta{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:14px}
.bp-ex{color:var(--ink);font-size:16px;margin:0 0 16px}
.bp-when{border-left:2px solid var(--gold-soft);padding:2px 0 2px 16px;margin:0 0 16px}
.bp-when-ct{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:6px}
.bp-when p{color:var(--ink);font-size:15px;margin:0}
.bp-disc{color:var(--muted);font-size:13px;font-style:italic;margin:0 0 16px}
.bp-cta{display:inline-block;color:var(--gold);text-decoration:none;font-family:var(--serif);font-size:16px}
.bp-cta:hover{color:var(--head);text-decoration:underline}

/* score-band legend (sign-index page) */
.bands{display:grid;gap:8px;margin:20px 0}
.bandrow{display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px 14px;background:var(--card)}
.bandrow .pill{font-family:var(--serif);font-size:13px;color:#fff;border-radius:999px;padding:4px 10px;text-align:center;white-space:nowrap}
.bandrow .bd{font-size:14.5px}
.bandrow .bd b{color:var(--head)}

/* simple input->output flow */
.flow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:18px 0}
.chip{border:1px solid var(--line);background:var(--card-2);border-radius:999px;padding:7px 13px;font-size:13px;color:var(--ink)}
.chip .x{color:var(--gold);font-weight:800}
.arrow{color:var(--gold);font-size:18px}
.result{border:1px solid var(--gold);background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:var(--btn-ink);border-radius:999px;padding:7px 15px;font-family:var(--serif);font-size:14px}

/* cross-links to the other learn pages */
.crosslinks{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:40px 0 8px}
.xl{border:1px solid var(--line);background:var(--card);border-radius:16px;padding:18px 20px;text-decoration:none;display:block;transition:.18s ease}
.xl:hover{border-color:var(--gold-soft);transform:translateY(-1px)}
.xl .xt{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:800}
.xl h3{font-size:20px;color:var(--head);margin:6px 0 4px}
.xl p{font-size:13.5px;color:var(--muted)}

/* end CTA */
.endcta{border:1px solid var(--line);border-radius:20px;background:radial-gradient(520px 240px at 50% 0%,rgba(216,183,101,.16),transparent 70%),var(--card);padding:28px;text-align:center;margin:34px 0 10px}
.endcta h2{font-size:28px;color:var(--head);margin-bottom:8px}
.endcta p{color:var(--muted);max-width:48ch;margin:0 auto 18px}

footer{border-top:1px solid var(--line);padding:30px 20px;text-align:center;color:var(--muted);margin-top:40px}
footer b{display:block;font-family:var(--serif);font-size:21px;color:var(--head);margin-bottom:4px}
.disclaimer{max-width:760px;margin:12px auto 0;font-size:11.5px;opacity:.85}
.src{font-size:11px;color:var(--muted);opacity:.8;margin-top:10px}

@media(max-width:760px){
  .crosslinks{grid-template-columns:1fr}
  .bodytool{padding:20px 16px 24px}
  .bodytool-grid{grid-template-columns:1fr;gap:22px}
  .bm-med{width:clamp(34px,9%,44px);font-size:17px}
  .signrow{grid-template-columns:38px 1fr;grid-template-areas:"g n" "g b"}
  .signrow .gly{grid-area:g}.signrow .nm{grid-area:n}.signrow .bp{grid-area:b}
  .navlinks a:not(.btn):not(.theme-link){display:none}
}
