/* ============================================================
   CherryHora — Cherry the Oracle  ·  shared design system
   Bright · cute · friendly  ·  royal blue + gold + cherry
   ============================================================ */

/* ---- Tweakable design tokens (overridden by tweaks.js) ---- */
:root{
  --h: 258;                 /* primary hue, driven by Tweaks  */
  --blue:        oklch(0.60 0.22 var(--h));
  --blue-bright: oklch(0.66 0.20 var(--h));
  --blue-deep:   oklch(0.45 0.18 var(--h));
  --navy:        oklch(0.30 0.13 var(--h));
  --ink:         oklch(0.32 0.10 var(--h));
  --muted:       oklch(0.55 0.05 var(--h));
  --line:        oklch(0.90 0.04 var(--h));
  --soft:        oklch(0.97 0.02 var(--h));

  --gold:  #ffc24b;
  --gold-deep:#f0a526;
  --pink:  #ff7bb0;
  --green: #2fcf85;
  --violet:#8f74ff;
  --cherry:#e8344e;

  /* page background — swapped by data-bg */
  --bg-a:#f4f8ff;
  --bg-b:#eaf2ff;
  --bg-c:#ffffff;
  --page-text: var(--ink);
  --card-bg:#ffffff;
  --card-soft: color-mix(in oklab, var(--soft), #fff 40%);

  --radius:26px;
  --radius-lg:34px;
  --radius-sm:16px;
  --shadow:0 24px 60px -22px oklch(0.45 0.15 var(--h) / .35);
  --shadow-sm:0 12px 30px -16px oklch(0.45 0.15 var(--h) / .30);
  --ring: oklch(0.60 0.22 var(--h) / .35);

  --font-head:'Mitr', system-ui, sans-serif;
  --font-brand:'Fredoka', 'Mitr', system-ui, sans-serif;
  --font-body:'Noto Sans Thai','Mitr', system-ui, sans-serif;

  --mascot-scale:1;
}

/* ---- Background intensity modes ---- */
html[data-bg="light"]{ --bg-a:#fdfdff; --bg-b:#f4f8ff; --bg-c:#ffffff; }
html[data-bg="soft"]{  --bg-a:#f1f6ff; --bg-b:#e7f0ff; --bg-c:#fbfdff; }
html[data-bg="deep"]{
  --bg-a:oklch(0.30 0.12 var(--h));
  --bg-b:oklch(0.22 0.11 var(--h));
  --bg-c:oklch(0.34 0.12 var(--h));
  --page-text:#eaf1ff;
  --ink:#eef3ff;
  --muted:#a9bbe6;
  --line:oklch(0.45 0.08 var(--h));
  --soft:oklch(0.38 0.10 var(--h));
  --card-bg:oklch(0.39 0.10 var(--h));
  --card-soft:oklch(0.35 0.09 var(--h));
  --shadow:0 24px 60px -22px #00071f88;
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--font-body);
  color:var(--page-text);
  background:
    radial-gradient(1100px 540px at 82% -8%, oklch(0.66 0.20 var(--h) / .18), transparent 60%),
    radial-gradient(900px 480px at 8% 4%, #fff6, transparent 55%),
    linear-gradient(178deg, var(--bg-a) 0%, var(--bg-b) 46%, var(--bg-c) 100%);
  background-attachment:fixed;
  min-height:100vh;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.12;margin:0;color:var(--ink)}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* sparkle utility dots */
.stars{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.stars::before,.stars::after{
  content:"";position:absolute;inset:-10%;
  background-image:
    radial-gradient(2px 2px at 20% 30%, #fff, transparent),
    radial-gradient(1.5px 1.5px at 70% 20%, var(--gold), transparent),
    radial-gradient(2px 2px at 85% 65%, #fff, transparent),
    radial-gradient(1.5px 1.5px at 35% 80%, var(--gold), transparent),
    radial-gradient(2px 2px at 55% 50%, #fff, transparent),
    radial-gradient(1.5px 1.5px at 12% 60%, #fff, transparent);
  background-size:520px 520px;opacity:.7;
  animation:twinkle 5s ease-in-out infinite;
}
.stars::after{background-position:260px 130px;animation-delay:1.6s;opacity:.5}
@keyframes twinkle{0%,100%{opacity:.35}50%{opacity:.85}}

/* ============================ NAV ============================ */
.nav-wrap{position:sticky;top:0;z-index:60}
.nav{
  display:flex;align-items:center;gap:22px;
  height:74px;margin:14px auto;max-width:1280px;
  padding:0 24px;border-radius:22px;
  background:color-mix(in oklab, var(--card-bg), transparent 12%);
  backdrop-filter:blur(18px) saturate(1.2);
  border:1px solid color-mix(in oklab,var(--line),transparent 20%);
  box-shadow:var(--shadow-sm);
}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-brand)}
.brand .mark{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--blue-bright),var(--blue-deep));
  box-shadow:0 8px 18px -6px var(--ring);position:relative;flex:none;
}
.brand .mark::after{content:"";position:absolute;width:17px;height:17px;border-radius:50%;
  background:#fff;right:9px;top:12px;box-shadow:-6px 0 0 -1px var(--blue-deep)}
.brand .mark .cap{position:absolute;top:-5px;left:50%;transform:translateX(-50%);font-size:13px}
.brand b{font-size:21px;font-weight:600;letter-spacing:.2px;color:var(--ink);line-height:1}
.brand small{display:block;font-family:var(--font-body);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blue);font-weight:600;margin-top:2px}
.brand-logo{
  width:auto;
  height:42px;
  max-width:min(360px, 30vw);
  object-fit:contain;
}
.menu{display:flex;gap:6px;margin-left:8px;flex:1}
.menu a{padding:9px 13px;border-radius:12px;font-size:14.5px;font-weight:500;color:var(--muted);
  font-family:var(--font-head);transition:.18s;white-space:nowrap}
.menu a:hover{color:var(--blue);background:color-mix(in oklab,var(--blue),transparent 90%)}
.menu a.active{color:var(--blue);background:color-mix(in oklab,var(--blue),transparent 88%)}
.nav-actions{display:flex;align-items:center;gap:10px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;
  font-family:var(--font-head);font-weight:500;font-size:15px;border-radius:14px;
  padding:12px 20px;border:1.5px solid var(--line);background:var(--card-bg);color:var(--ink);
  transition:.2s;white-space:nowrap}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn.primary{border-color:transparent;color:#fff;
  background:linear-gradient(135deg,var(--blue-bright),var(--blue-deep));
  box-shadow:0 14px 30px -12px var(--ring)}
.btn.gold{border-color:transparent;color:#5a3b00;
  background:linear-gradient(135deg,#ffd97a,var(--gold-deep))}
.btn.ghost{background:color-mix(in oklab,var(--card-bg),transparent 35%)}
.btn.lg{padding:15px 26px;font-size:16.5px}
.btn.round{width:46px;height:46px;padding:0;border-radius:50%}
.icon-btn{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  border:1.5px solid var(--line);background:color-mix(in oklab,var(--card-bg),transparent 30%);color:var(--blue)}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);
  font-size:12.5px;font-weight:500;letter-spacing:.04em;color:var(--blue);
  background:color-mix(in oklab,var(--blue),transparent 88%);
  border:1px solid color-mix(in oklab,var(--blue),transparent 78%);
  padding:7px 15px;border-radius:999px}

/* ============================ HERO ========================== */
.hero{position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;
  padding:34px 0 26px}
.hero h1{font-family:var(--font-brand);font-weight:600;font-size:clamp(52px,7vw,104px);
  letter-spacing:-.01em;line-height:.92;
  background:linear-gradient(135deg,var(--blue-deep),var(--blue-bright));
  -webkit-background-clip:text;background-clip:text;color:transparent;margin:14px 0 2px}
.hero .sub{font-family:var(--font-brand);font-size:clamp(24px,3vw,40px);color:var(--blue);
  font-weight:500;display:flex;align-items:center;gap:12px}
.hero .sub::before,.hero .sub::after{content:"✦";color:var(--gold);font-size:.6em}
.hero .lead{font-size:18px;color:var(--muted);max-width:30em;margin:16px 0 0;line-height:1.7}
.hero .lead b{color:var(--ink);font-weight:600}
.trust{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 26px}
.trust .pill{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:16px;
  background:color-mix(in oklab,var(--card-bg),transparent 25%);
  border:1px solid color-mix(in oklab,var(--line),transparent 25%)}
.trust .pill .ic{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;flex:none;
  background:color-mix(in oklab,var(--blue),transparent 86%);color:var(--blue);font-size:16px}
.trust .pill b{font-size:13.5px;font-family:var(--font-head);font-weight:500;color:var(--ink);display:block;line-height:1.2}
.trust .pill small{font-size:11.5px;color:var(--muted)}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px}

/* mascot stage */
.stage{position:relative;min-height:520px;display:grid;place-items:center}
.zwheel{position:absolute;width:min(560px,92%);aspect-ratio:1;border-radius:50%;
  border:1.5px dashed color-mix(in oklab,var(--blue),transparent 55%);
  background:radial-gradient(circle, transparent 58%, color-mix(in oklab,var(--blue),transparent 92%) 72%, transparent 73%);
  animation:spin 90s linear infinite}
.zwheel.inner{width:min(420px,70%);border-style:solid;border-color:color-mix(in oklab,var(--gold),transparent 70%);
  animation:spin 60s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.zglyph{position:absolute;font-size:20px;color:color-mix(in oklab,var(--blue),transparent 40%);opacity:.8}
.orb-glow{position:absolute;bottom:6%;left:14%;width:190px;height:190px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%, #fff,var(--gold) 30%, var(--blue) 75%, transparent 78%);
  filter:blur(8px);opacity:.55;animation:pulse 4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.08);opacity:.75}}
.mascot{position:relative;z-index:2;width:min(540px,90%);
  transform:scale(var(--mascot-scale));transform-origin:bottom center;
  filter:drop-shadow(0 30px 50px oklch(0.45 0.15 var(--h) / .35));
  animation:float 6s ease-in-out infinite;
  -webkit-mask-image:radial-gradient(120% 120% at 50% 42%, #000 72%, transparent 96%);
          mask-image:radial-gradient(120% 120% at 50% 42%, #000 72%, transparent 96%)}
@keyframes float{0%,100%{transform:scale(var(--mascot-scale)) translateY(0)}50%{transform:scale(var(--mascot-scale)) translateY(-14px)}}
.tarot-float{position:absolute;z-index:3;width:96px;border-radius:12px;
  box-shadow:var(--shadow);animation:float 5s ease-in-out infinite}
.tarot-float.a{top:8%;left:2%;rotate:-14deg;animation-delay:.4s}
.tarot-float.b{top:24%;right:0%;rotate:13deg;animation-delay:1.2s}

/* floating mini info card on hero */
.float-card{position:absolute;z-index:4;right:2%;bottom:10%;width:220px;padding:16px 18px;
  border-radius:20px;background:color-mix(in oklab,var(--card-bg),transparent 8%);
  backdrop-filter:blur(10px);border:1px solid color-mix(in oklab,var(--line),transparent 20%);
  box-shadow:var(--shadow)}
.float-card .ft{display:flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:500;
  color:var(--blue);font-size:13px}
.float-card .day{font-size:11px;color:var(--muted);margin:2px 0 8px}
.float-card p{margin:0;font-size:12.5px;color:var(--ink);line-height:1.55}

/* ====================== SECTION SHELL ======================= */
.section{padding:46px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px}
.section-head>div:first-child{flex:1;min-width:0}
.section-head h2{font-size:clamp(26px,3vw,38px)}
.section-head .k{font-family:var(--font-head);color:var(--blue);font-size:13px;font-weight:500;
  display:flex;align-items:center;gap:7px}
.section-head .more{font-family:var(--font-head);color:var(--blue);font-weight:500;font-size:14px}
.section-head .more:hover{text-decoration:underline}

/* zodiac strip */
.zstrip{display:grid;grid-template-columns:repeat(12,1fr);gap:10px}
.zchip{display:flex;flex-direction:column;align-items:center;gap:3px;padding:14px 6px;cursor:pointer;
  border-radius:18px;background:var(--card-bg);border:1.5px solid var(--line);transition:.18s;text-align:center}
.zchip:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:var(--shadow-sm)}
.zchip.active{background:linear-gradient(150deg,var(--blue-bright),var(--blue-deep));border-color:transparent;color:#fff}
.zchip.active .gly,.zchip.active small{color:#fff}
.zchip .gly{font-size:26px;color:var(--blue);line-height:1}
.zchip b{font-family:var(--font-head);font-weight:500;font-size:13px}
.zchip small{font-size:9.5px;color:var(--muted);line-height:1.2}

/* glass / cards */
.card{background:var(--card-bg);border:1.5px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:22px}
.panel{background:var(--card-bg);border:1.5px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px}
.card-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title h3{font-size:19px;display:flex;align-items:center;gap:8px}
.card-title a{font-family:var(--font-head);font-size:13px;color:var(--blue);font-weight:500}

/* dashboard grid */
.dash{display:grid;grid-template-columns:1.5fr 1.15fr 1fr;gap:20px;align-items:start}

/* fortune cards */
.fortunes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.fortune{border-radius:20px;padding:18px 16px;background:var(--card-soft);
  border:1.5px solid var(--line);text-align:center}
.fortune .big{width:52px;height:52px;border-radius:15px;margin:0 auto 10px;display:grid;place-items:center;
  font-size:24px;background:#fff;box-shadow:var(--shadow-sm)}
.fortune h4{font-family:var(--font-head);font-weight:500;font-size:15px;margin-bottom:2px}
.fortune .stars-rate{color:var(--gold);font-size:12px;letter-spacing:1px}
.fortune p{font-size:12px;color:var(--muted);margin:8px 0 12px;min-height:48px;line-height:1.5}
.bar{height:8px;border-radius:99px;background:color-mix(in oklab,var(--line),transparent 10%);overflow:hidden}
.bar > span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--blue-bright),var(--blue));
  transition:width 1s cubic-bezier(.2,.8,.2,1)}
.fortune .pct{font-family:var(--font-head);font-size:12px;color:var(--blue);font-weight:500;
  display:flex;justify-content:space-between;margin-bottom:5px}

/* mini zodiac grid */
.zgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.mini-z{display:flex;flex-direction:column;align-items:center;gap:3px;padding:11px 4px;cursor:pointer;
  border-radius:14px;background:var(--card-soft);border:1.5px solid var(--line);transition:.16s}
.mini-z:hover{border-color:var(--blue);transform:translateY(-3px)}
.mini-z .gly{font-size:21px;color:var(--blue)}
.mini-z small{font-size:10px;color:var(--muted)}
.mini-z b{font-size:11px;font-family:var(--font-head);font-weight:500}

/* lucky + tarot insight column */
.stack{display:grid;gap:20px}
.lucky-row{display:flex;gap:14px}
.lucky{flex:1;border-radius:18px;padding:16px;background:var(--card-soft);border:1.5px solid var(--line)}
.lucky .lt{font-family:var(--font-head);font-size:12px;color:var(--blue);font-weight:500;
  display:flex;align-items:center;gap:6px;margin-bottom:10px}
.swatch{width:26px;height:26px;border-radius:8px;border:2px solid #fff;box-shadow:var(--shadow-sm)}
.lucky .val{font-family:var(--font-brand);font-size:22px;color:var(--ink);font-weight:600}
.dots{display:flex;gap:5px;margin-top:9px}
.dots i{width:13px;height:13px;border-radius:50%;display:block}
.lucky-num{font-family:var(--font-brand);font-size:40px;color:var(--blue);font-weight:600;line-height:1}
.lucky-num .alt{display:flex;gap:6px;margin-top:8px}
.lucky-num .alt span{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;
  font-size:12px;font-family:var(--font-head);background:#fff;border:1.5px solid var(--line);color:var(--muted)}

.tarot-insight{display:flex;gap:14px;align-items:center}
.tarot-insight .mini-card{width:84px;flex:none}

/* testimonials */
.quote{display:flex;gap:14px;align-items:flex-start}
.quote .rate{color:var(--gold);letter-spacing:2px;font-size:14px}
.quote p{font-size:14.5px;color:var(--ink);margin:6px 0 14px;line-height:1.6}
.quote .who{display:flex;align-items:center;gap:10px}
.avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;object-position:50% 18%;
  border:2px solid #fff;box-shadow:var(--shadow-sm)}
.quote .who b{font-family:var(--font-head);font-weight:500;font-size:13.5px}
.quote .who small{font-size:11.5px;color:var(--green)}

/* stat strip */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  border-radius:var(--radius);padding:26px;
  background:linear-gradient(135deg,color-mix(in oklab,var(--blue),transparent 90%),color-mix(in oklab,var(--gold),transparent 92%));
  border:1.5px solid var(--line)}
.stat{display:flex;align-items:center;gap:13px}
.stat .si{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;flex:none;
  background:#fff;color:var(--blue);font-size:20px;box-shadow:var(--shadow-sm)}
.stat b{font-family:var(--font-brand);font-size:21px;color:var(--ink);display:block;line-height:1.1}
.stat small{font-size:12px;color:var(--muted)}

/* CTA band */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:46px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  background:linear-gradient(130deg,var(--blue-deep),var(--blue-bright));color:#fff}
.cta-band h2{color:#fff;font-size:clamp(26px,3vw,38px)}
.cta-band p{color:#dce8ff;margin:8px 0 0;max-width:40em}
.cta-band .mascot-mini{position:absolute;right:-10px;bottom:-30px;width:230px;opacity:.92;
  -webkit-mask-image:radial-gradient(100% 100% at 50% 40%,#000 70%,transparent 92%);
          mask-image:radial-gradient(100% 100% at 50% 40%,#000 70%,transparent 92%)}

/* ======================== TAROT page ======================== */
.tcard{position:relative;border-radius:18px;aspect-ratio:5/8;cursor:pointer;background:none}
.tcard .flip{position:relative;width:100%;height:100%}
.tcard.flipping .flip{animation:flipswing .56s ease}
@keyframes flipswing{0%{transform:perspective(800px) scaleX(1)}48%{transform:perspective(800px) scaleX(.04)}100%{transform:perspective(800px) scaleX(1)}}
.tface{position:absolute;inset:0;border-radius:18px;box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;opacity:0}
.tback{opacity:1}
.tcard.flipped .tback{opacity:0}
.tcard.flipped .tfront{opacity:1}
.tback{
  background:
    linear-gradient(180deg, #ffffff08, #00000014),
    url("img/cardtaro-v2.png") center/cover no-repeat;
  overflow:hidden}
.tback .seal{display:none}
.tfront{flex-direction:column;justify-content:space-between;
  padding:14px 10px;text-align:center;color:#fff;
  background:linear-gradient(180deg, oklch(0.34 0.12 var(--h)), oklch(0.24 0.13 var(--h)))}
.tfront .num{font-family:var(--font-brand);font-size:13px;color:var(--gold);letter-spacing:2px}
.tfront .sym{font-size:46px;line-height:1;filter:drop-shadow(0 4px 10px #0008);margin:6px 0}
.tfront .nm{font-family:var(--font-head);font-weight:500;font-size:16px}
.tfront .nm small{display:block;font-family:var(--font-body);font-size:11px;color:#cdd8ff;font-weight:400}

/* ===================== compatibility ======================== */
.love-calc{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:end}
.sel-field label{font-family:var(--font-head);font-size:13px;color:var(--blue);font-weight:500;display:block;margin-bottom:7px}
.sel-field select{width:100%;padding:13px 15px;border-radius:14px;border:1.5px solid var(--line);
  background:var(--card-bg);color:var(--ink);font-family:var(--font-body);font-size:15px;cursor:pointer}
.love-heart{font-size:30px;color:var(--pink);padding-bottom:8px;animation:pulse 2.4s ease-in-out infinite}
.match-ring{--p:0;width:150px;height:150px;border-radius:50%;display:grid;place-items:center;margin:6px auto;
  background:conic-gradient(var(--pink) calc(var(--p)*1%), color-mix(in oklab,var(--line),transparent 20%) 0);
  transition:--p 1.2s ease}
.match-ring .inner{width:120px;height:120px;border-radius:50%;background:var(--card-bg);display:grid;place-items:center}
.match-ring b{font-family:var(--font-brand);font-size:38px;color:var(--pink)}
@property --p{syntax:'<number>';inherits:false;initial-value:0}

/* ========================= FOOTER =========================== */
.footer{margin-top:40px;background:linear-gradient(160deg,var(--navy),var(--blue-deep));color:#dce6ff}
.footer .wrap{padding:46px 28px 26px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.4fr;gap:30px}
.footer h4{color:#fff;font-size:15px;margin-bottom:14px;font-weight:500}
.footer a{display:block;color:#b9c8f0;font-size:13.5px;padding:4px 0;transition:.15s}
.footer a:hover{color:#fff;padding-left:4px}
.footer .brand b{color:#fff}
.footer .brand small{color:#9fb4ef}
.footer .brand-logo{
  height:50px;
  max-width:100%;
  border-radius:14px;
  box-shadow:0 12px 28px -16px #000b;
}
.footer .desc{font-size:13px;color:#a9bbe6;margin:14px 0 0;line-height:1.7;max-width:24em}
.socials{display:flex;gap:10px;margin-top:8px}
.socials a{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:#ffffff18;color:#fff}
.socials a:hover{background:var(--gold);color:var(--navy);padding-left:0}
.newsletter{display:flex;gap:8px;margin-top:12px}
.newsletter input{flex:1;padding:12px 15px;border-radius:13px;border:1px solid #ffffff2e;background:#ffffff14;color:#fff;font-family:var(--font-body)}
.newsletter input::placeholder{color:#9fb4ef}
.foot-base{border-top:1px solid #ffffff1f;margin-top:30px;padding-top:18px;text-align:center;font-size:12px;color:#8ea4dd}

/* toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,40px);z-index:200;
  background:var(--navy);color:#fff;padding:13px 22px;border-radius:14px;box-shadow:var(--shadow);
  font-family:var(--font-head);font-size:14px;opacity:0;transition:.35s;pointer-events:none}
.toast.show{transform:translate(-50%,0);opacity:1}

/* page header (sub pages) */
.page-hero{position:relative;overflow:hidden;padding:30px 0 10px}
.page-hero .ph-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:20px;align-items:center}
.page-hero h1{font-family:var(--font-brand);font-size:clamp(38px,5vw,68px);
  background:linear-gradient(135deg,var(--blue-deep),var(--blue-bright));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero .ph-mascot{width:min(300px,80%);margin-left:auto;
  -webkit-mask-image:radial-gradient(110% 110% at 50% 40%,#000 70%,transparent 94%);
          mask-image:radial-gradient(110% 110% at 50% 40%,#000 70%,transparent 94%)}

/* reading result panel */
.reading{display:grid;grid-template-columns:.85fr 1.15fr;gap:24px;align-items:start}
.reading .big-sign{text-align:center;padding:30px 20px;border-radius:var(--radius);
  background:linear-gradient(160deg,color-mix(in oklab,var(--blue),transparent 88%),transparent);
  border:1.5px solid var(--line)}
.reading .big-sign .glyph{font-size:74px;color:var(--blue);line-height:1}
.reading .big-sign h2{font-size:30px;margin-top:6px}
.reading .big-sign .date{color:var(--muted);font-size:13px}
.score-ring{--p:0;width:120px;height:120px;border-radius:50%;display:grid;place-items:center;margin:16px auto 4px;
  background:conic-gradient(var(--blue) calc(var(--p)*1%), color-mix(in oklab,var(--line),transparent 20%) 0)}
.score-ring .inner{width:96px;height:96px;border-radius:50%;background:var(--card-bg);display:grid;place-items:center}
.score-ring b{font-family:var(--font-brand);font-size:30px;color:var(--blue)}

/* ===================== TWEAKS PANEL ========================= */
#tweaks{position:fixed;right:18px;bottom:18px;z-index:300;width:300px;display:none;
  background:var(--card-bg);border:1.5px solid var(--line);border-radius:22px;
  box-shadow:0 30px 70px -20px #0006;font-family:var(--font-body);overflow:hidden}
#tweaks.open{display:block}
#tweaks .tw-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;
  background:linear-gradient(135deg,var(--blue-bright),var(--blue-deep));color:#fff}
#tweaks .tw-head b{font-family:var(--font-head);font-weight:500;font-size:16px;display:flex;align-items:center;gap:8px}
#tweaks .tw-head button{background:#ffffff28;border:none;color:#fff;width:28px;height:28px;border-radius:9px;cursor:pointer;font-size:15px}
#tweaks .tw-body{padding:16px 18px;max-height:70vh;overflow:auto}
.tw-group{margin-bottom:18px}
.tw-group > label{font-family:var(--font-head);font-weight:500;font-size:13px;color:var(--ink);display:block;margin-bottom:9px}
.tw-swatches{display:flex;gap:9px}
.tw-swatches button{width:34px;height:34px;border-radius:11px;border:2.5px solid transparent;cursor:pointer;transition:.15s}
.tw-swatches button.on{border-color:var(--ink);transform:scale(1.08)}
.tw-seg{display:flex;gap:6px;background:var(--soft);padding:5px;border-radius:13px}
.tw-seg button{flex:1;padding:9px 6px;border:none;background:none;border-radius:9px;cursor:pointer;
  font-family:var(--font-head);font-size:12.5px;font-weight:500;color:var(--muted)}
.tw-seg button.on{background:var(--card-bg);color:var(--blue);box-shadow:var(--shadow-sm)}
.tw-range{width:100%;accent-color:var(--blue)}
.tw-val{float:right;font-family:var(--font-head);color:var(--blue);font-size:12px}

/* ====================== RESPONSIVE ========================== */
@media(max-width:1080px){
  .menu{display:none}
  [data-menu-toggle]{display:grid!important}
  .hero-grid{grid-template-columns:1fr;gap:10px}
  .stage{min-height:430px;order:-1}
  .dash{grid-template-columns:1fr}
  .zstrip{grid-template-columns:repeat(6,1fr)}
  .reading{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .page-hero .ph-grid{grid-template-columns:1fr}
  .page-hero .ph-mascot{display:none}
}
@media(max-width:680px){
  .wrap{padding:0 16px}
  .nav{margin:10px;padding:0 14px;gap:12px}
  .brand small{display:none}
  .brand-logo{height:36px;max-width:210px}
  .nav .hide-sm{display:none}
  .fortunes{grid-template-columns:1fr 1fr}
  .zgrid{grid-template-columns:repeat(4,1fr)}
  .zstrip{grid-template-columns:repeat(4,1fr)}
  .stat-strip{grid-template-columns:1fr 1fr}
  .lucky-row{flex-direction:column}
  .footer-grid{grid-template-columns:1fr 1fr}
  .love-calc{grid-template-columns:1fr;gap:12px}
  .love-heart{display:none}
  .cta-band{padding:30px}
  .cta-band .mascot-mini{display:none}
  .hero .lead{font-size:16px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
}
