:root{
  /* ═══ ULTRAVIOLET DARK SPACE THEME (default) ═══ */
  --bg:#0A0118;--bg2:#130028;--bg3:#1C0040;--bg4:#27005A;
  --border:rgba(176,64,255,.22);--border2:rgba(176,64,255,.42);
  --gold:#B040FF;--gold2:#E0A0FF;--glow:rgba(176,64,255,.22);--gdim:#7B00D4;
  --ind:#818CF8;--ind2:#A3B3F7;--iglow:rgba(129,140,248,.14);
  --pur:#C084FC;--pur2:#DDD6FE;--teal:#A78BFA;--rose:#F472B6;--grn:#C084FC;
  --tx:#F5F0FF;--tx2:#C9A8FF;--tx3:#8B6BAE;
  --fn:"Noto Sans Thai","Inter","SF Pro Text",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --fh:"Noto Sans Thai","Inter",-apple-system,sans-serif;
  --fl:"Georgia","Times New Roman",serif;
  --r1:10px;--r2:14px;--r3:18px;
}
/* ═══ LIGHT MODE ═══ */
body.light-mode{
  --bg:#F4F0FF;--bg2:#EDE6FF;--bg3:#E2D9FF;--bg4:#D5C8FF;
  --border:rgba(120,40,200,.18);--border2:rgba(120,40,200,.35);
  --gold:#7B00D4;--gold2:#5A00A8;--glow:rgba(120,40,200,.15);--gdim:#9D4FE8;
  --ind:#4F46E5;--ind2:#3730A3;--iglow:rgba(79,70,229,.1);
  --pur:#7C3AED;--pur2:#5B21B6;--teal:#6D28D9;--rose:#DB2777;--grn:#7C3AED;
  --tx:#1A0040;--tx2:#3B0080;--tx3:#6B21A8;
}
body.light-mode #app{background:var(--bg);box-shadow:0 0 80px rgba(120,40,200,.12)}
body.light-mode .card{background:linear-gradient(135deg,rgba(240,234,255,.97),rgba(250,247,255,.95));box-shadow:0 2px 12px rgba(120,40,200,.08)}
body.light-mode .jcard{background:rgba(225,210,255,.75);border-color:rgba(120,40,200,.25)}
body.light-mode .plan{background:rgba(230,220,255,.85)}
body.light-mode .sht{color:#1A0040!important}
body.light-mode .il{color:#3B0080!important}
body.light-mode .fpend{background:rgba(120,40,200,.12);color:#5B21B6!important;border-color:rgba(120,40,200,.3)}
body.light-mode .fdone{background:rgba(100,70,200,.12);color:#4C1D95!important;border-color:rgba(100,70,200,.3)}
body.light-mode .fdue{background:rgba(109,40,217,.12);color:#5B21B6!important;border-color:rgba(109,40,217,.3)}
body.light-mode .tb{background:rgba(237,230,255,.95)}
body.light-mode .bnav{background:rgba(244,240,255,.95)}
body.light-mode .sb::-webkit-scrollbar-thumb{background:rgba(120,40,200,.25)}
body.light-mode .btn.bg{box-shadow:0 4px 24px rgba(120,40,200,.3)}
body.light-mode .sc{background:var(--bg)}
body.light-mode .modal-sheet{background:linear-gradient(135deg,#EDE6FF,#E2D9FF)}
body.light-mode #star-field{opacity:.3}
body.light-mode input,body.light-mode select,body.light-mode textarea{background:rgba(200,180,255,.3) !important;color:var(--tx) !important}
body.light-mode .qopt{background:rgba(200,180,255,.4);color:var(--tx2)}
body.light-mode .jcard{background:rgba(210,195,255,.5)}
html,body{height:100%;margin:0}
body{min-height:100vh;background:var(--bg);font-family:var(--fn);color:var(--tx);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
#app{width:100%;max-width:430px;min-height:100vh;height:100vh;margin:0 auto;background:var(--bg);position:relative;overflow:hidden;box-shadow:0 0 80px rgba(176,64,255,.15)}

/* ═══ TABLET RESPONSIVE ═══ */
@media (min-width:600px){
  html,body{height:100%;overflow:hidden}
  body{background:#07001A;display:flex;align-items:center;justify-content:center;padding:0}
  #app{width:390px!important;max-width:390px!important;height:100vh;max-height:100vh;border-radius:0;box-shadow:0 0 60px rgba(176,64,255,.2);overflow:hidden;flex-shrink:0}
  #star-field{display:none}
}
@media (min-width:900px){
  body{background:radial-gradient(ellipse at center,#1A0038 0%,#07001A 70%)}
  #app{width:420px!important;max-width:420px!important;height:95vh;max-height:900px;border-radius:24px;box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 0 1px rgba(176,64,255,.25),0 0 80px rgba(176,64,255,.15)}
}
/* ═══ TABLET 12" — iPad Pro 12.9" / Surface Pro (1024px+) ═══ */
@media (min-width:1024px){
  body{background:radial-gradient(ellipse at 50% 40%,#1C003E 0%,#07001A 65%);display:grid;grid-template-columns:1fr 440px 1fr;align-items:center;min-height:100vh}
  #app{grid-column:2;width:440px!important;max-width:440px!important;height:92vh;max-height:960px;border-radius:28px;box-shadow:0 40px 100px rgba(0,0,0,.7),0 0 0 1px rgba(176,64,255,.3),0 0 120px rgba(176,64,255,.18);margin:0 auto}
  /* Decorative side panels */
  body::before,body::after{content:'';position:fixed;top:0;bottom:0;width:calc((100vw - 440px) / 2 - 40px);pointer-events:none}
  body::before{left:20px;background:radial-gradient(ellipse at right center,rgba(176,64,255,.06) 0%,transparent 70%)}
  body::after{right:20px;background:radial-gradient(ellipse at left center,rgba(99,102,241,.05) 0%,transparent 70%)}
}
.sc{position:absolute;inset:0;display:flex;flex-direction:column;background:var(--bg);visibility:hidden!important;opacity:0!important;transition:opacity .2s;overflow:hidden;z-index:1!important;max-width:100%;pointer-events:none!important}
.sc.on{visibility:visible!important;opacity:1!important;z-index:2!important;pointer-events:all!important}
/* ซ่อน sc-land ทันทีตั้งแต่ CSS paint — ปลดล็อคเฉพาะเมื่อ JS พร้อมและไม่มี profile */
body:not(.av-ready) #sc-land.on{visibility:hidden!important;opacity:0!important;pointer-events:none!important}
/* sc-dash ไม่ต้อง fade-in — โชว์ทันทีไม่มี transition */
#sc-dash.on{transition:none!important}
#sc-quiz{background:radial-gradient(ellipse at 30% 15%,rgba(176,64,255,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 75%,rgba(99,102,241,.09) 0%,transparent 50%),var(--bg)}
.sb{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:90px;overscroll-behavior-y:contain;touch-action:pan-y;min-height:0}
.sb::-webkit-scrollbar{display:none}
.tb{display:flex;align-items:center;padding:14px 18px;background:rgba(19,0,40,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);gap:10px;min-height:56px;flex-shrink:0}
.bk-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:rgba(176,64,255,.08);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--tx2)}
.tb-t{flex:1;font-weight:600;font-size:16px;color:var(--tx)}
.tb-act{padding:8px 16px;border-radius:20px;border:none;background:var(--gold);color:#fff;font-size:13px;font-weight:700;cursor:pointer}
.bnav{display:flex;background:rgba(13,0,32,.92);backdrop-filter:blur(16px);border-top:1px solid var(--border);flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,4px);width:100%}
.bni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;cursor:pointer;border:none;background:none;gap:2px;position:relative;transition:all .15s}
.bni span:first-child{font-size:20px;line-height:1;transition:transform .15s;color:var(--tx2)}
.bni span:last-child{font-size:10px;font-weight:500;color:var(--tx3);transition:color .15s}
.bni.on span:last-child{color:var(--gold);font-weight:700}
.bni.on span:first-child{transform:scale(1.15)}
.bni.on{background:rgba(176,64,255,.08);border-radius:12px}
/* Input error state */
.if-err{border-color:var(--rose)!important;box-shadow:0 0 0 2px rgba(251,113,133,.2)!important;animation:shake .3s ease}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
/* Tooltip สำหรับปุ่ม icon */
.has-tip{position:relative}
.has-tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:rgba(20,0,50,.95);color:var(--tx);font-size:11px;white-space:nowrap;padding:5px 9px;border-radius:8px;border:1px solid var(--border);pointer-events:none;opacity:0;transition:opacity .2s;z-index:200}
.has-tip:hover::after,.has-tip:focus::after{opacity:1}

/* ═══ CARD — with star glow effect ═══ */
.card{background:linear-gradient(135deg,rgba(28,0,64,.9),rgba(39,0,90,.7));border-radius:var(--r3);padding:20px;border:1px solid var(--border);position:relative;overflow:hidden}
.card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(176,64,255,.06) 0%,transparent 50%,rgba(224,160,255,.04) 100%);pointer-events:none;border-radius:inherit}
/* Shooting star trail on cards */
.card::before{content:'';position:absolute;top:-40px;right:-40px;width:80px;height:1px;background:linear-gradient(90deg,transparent,rgba(176,64,255,.8),rgba(224,160,255,.4),transparent);transform:rotate(-45deg);animation:star-trail var(--star-dur,7s) linear infinite;animation-delay:var(--star-del,0s);opacity:0}
@keyframes star-trail{0%{top:-40px;right:-40px;opacity:0}10%{opacity:.8}40%{opacity:.4}80%{top:120%;right:120%;opacity:0}100%{top:120%;right:120%;opacity:0}}

.cg{border-color:rgba(176,64,255,.5)!important;box-shadow:0 0 30px rgba(176,64,255,.15),0 0 60px rgba(176,64,255,.06)}
.ci{border-color:rgba(129,140,248,.4)!important;box-shadow:0 0 20px var(--iglow)}
.cp{border-color:rgba(192,132,252,.4)!important}
.ct{border-color:rgba(167,139,250,.3)!important;background:rgba(167,139,250,.04)}

/* ═══ BUTTONS ═══ */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 20px;border-radius:var(--r3);border:none;cursor:pointer;font-weight:600;font-size:16px;width:100%;transition:all .15s;position:relative;overflow:hidden}
.btn:active{opacity:.85;transform:scale(.98)}
/* Shimmer sweep on buttons */
.btn::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transform:skewX(-15deg);animation:btn-shine 4s ease-in-out infinite}
@keyframes btn-shine{0%,70%,100%{left:-100%}40%{left:130%}}
.bg{background:linear-gradient(135deg,#B040FF,#7B00D4);color:#fff;box-shadow:0 4px 24px rgba(176,64,255,.4)}
.bo{background:transparent;border:1px solid var(--gold);color:var(--gold)}
.bgh{background:rgba(176,64,255,.1);color:var(--tx2);font-size:14px;border:1px solid var(--border)}
.bi{background:linear-gradient(135deg,#6366F1,#818CF8);color:#fff}
.bt{background:linear-gradient(135deg,#7B00D4,#A855F7);color:#fff}
.bd{background:rgba(244,114,182,.1);border:1px solid rgba(244,114,182,.3);color:var(--rose)}
.bsm{padding:10px 18px;font-size:14px;width:auto;border-radius:var(--r2)}
.ig{margin-bottom:14px}
.il{font-size:13px;font-weight:500;color:var(--tx2);margin-bottom:7px;display:block}
.if{width:100%;padding:13px 15px;border:1px solid var(--border);border-radius:var(--r2);font-size:16px;color:var(--tx);background:rgba(28,0,64,.6);outline:none;font-family:var(--fn);transition:border-color .15s;box-sizing:border-box;max-width:100%}
.if:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,64,255,.1)}
.if::placeholder{color:var(--tx3)}
textarea.if{resize:none}
#toast{position:absolute;top:20px;left:50%;transform:translateX(-50%);pointer-events:none;background:linear-gradient(135deg,#1C0040,#27005A);border:1px solid var(--border2);color:var(--tx);padding:10px 20px;border-radius:20px;font-size:13px;font-weight:500;white-space:nowrap;z-index:999;opacity:0;transition:opacity .2s;pointer-events:none;max-width:90vw;box-shadow:0 4px 24px rgba(176,64,255,.3)}
#toast.toast-success{background:linear-gradient(135deg,#052E16,#064E3B);border-color:rgba(52,211,153,.4);box-shadow:0 4px 24px rgba(52,211,153,.25)}
#toast.toast-error{background:linear-gradient(135deg,#450A0A,#7F1D1D);border-color:rgba(248,113,113,.4);box-shadow:0 4px 24px rgba(248,113,113,.25)}
#toast.toast-warn{background:linear-gradient(135deg,#1C0040,#27005A);border-color:var(--border2);box-shadow:0 4px 24px rgba(176,64,255,.3)}
#toast.toast-info{background:linear-gradient(135deg,#0C1445,#1E3A8A);border-color:rgba(99,102,241,.4);box-shadow:0 4px 24px rgba(99,102,241,.25)}
#toast.on{opacity:1}
.dv{height:1px;background:var(--border);margin:14px 0}
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sht{font-size:15px;font-weight:600;color:var(--tx)}
.shl{font-size:13px;color:var(--gold);cursor:pointer;font-weight:500}

/* ═══ LOGO ═══ */
.logo-m{display:flex;align-items:center;gap:10px}
.logo-i{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#1C0040,#4B0082);border:1px solid rgba(176,64,255,.5);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 0 16px rgba(176,64,255,.3)}
.logo-i svg{width:26px;height:26px}
.logo-t{font-family:var(--fl);font-weight:700;font-size:19px;background:linear-gradient(135deg,#E0A0FF,#B040FF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:1px}
.logo-s{font-size:10px;color:var(--tx3);letter-spacing:1.5px;text-transform:uppercase;margin-top:-2px}
.mtag{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;background:rgba(176,64,255,.12);border:1px solid rgba(176,64,255,.3);font-size:12px;color:var(--gold2);font-weight:600}
.arc{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;background:linear-gradient(135deg,rgba(176,64,255,.18),rgba(129,140,248,.1));border:1px solid rgba(176,64,255,.35);font-size:13px;color:var(--pur2);font-weight:700}
.cbar{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-bottom:12px}
.cfill{height:100%;border-radius:2px}

/* ═══ QUIZ OPTIONS ═══ */
.qopt{background:rgba(28,0,64,.7);border:1px solid var(--border);border-radius:var(--r2);padding:14px 15px;margin-bottom:9px;cursor:pointer;font-size:14px;color:var(--tx2);transition:all .15s;display:flex;align-items:center;gap:11px}
.qopt:hover{border-color:rgba(176,64,255,.4);background:rgba(176,64,255,.06)}
.qopt.sel{border-color:var(--gold);background:rgba(176,64,255,.12);color:var(--tx);box-shadow:0 0 16px rgba(176,64,255,.15)}
.qdot{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0}
.qopt.sel .qdot{border-color:var(--gold);background:var(--gold);box-shadow:0 0 8px var(--gold)}
.step-row{display:flex;gap:4px;margin-bottom:20px}
.sdot{flex:1;height:3px;border-radius:2px;background:var(--bg4)}
.sdot.on{background:linear-gradient(90deg,var(--gold),var(--gold2))}
.sdot.dn{background:var(--gdim)}

/* ═══ PLANS & JOURNAL ═══ */
.plan{background:rgba(28,0,64,.8);border-radius:var(--r3);padding:20px;border:1px solid var(--border);cursor:pointer;transition:all .15s;position:relative}
.plan.sel{border-color:var(--gold)!important;box-shadow:0 0 30px rgba(176,64,255,.2)}
.plan.hot::before{content:"ยอดนิยม";position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;font-size:11px;font-weight:700;padding:3px 12px;border-radius:10px}
.orb{position:absolute;border-radius:50%;pointer-events:none;opacity:.08}
.jcard{background:rgba(28,0,64,.7);border-radius:var(--r2);padding:15px;border:1px solid var(--border);cursor:pointer;margin-bottom:9px;transition:border-color .15s}
.jcard:hover{border-color:rgba(176,64,255,.4)}
.jdue{border-color:rgba(167,139,250,.45)!important;background:rgba(167,139,250,.04)}
.empty{text-align:center;padding:40px 20px}
.emj{font-size:46px;margin-bottom:13px;opacity:.4}
.emt{font-size:15px;font-weight:600;color:var(--tx2);margin-bottom:7px}
.emd{font-size:13px;color:var(--tx3);line-height:1.6}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.sb::-webkit-scrollbar{width:6px}
.sb::-webkit-scrollbar-thumb{background:rgba(176,64,255,.3);border-radius:10px}
.sb::-webkit-scrollbar-track{background:transparent}
.chip{padding:9px 6px;border-radius:var(--r1);border:1px solid var(--border);background:rgba(28,0,64,.5);cursor:pointer;text-align:center;font-size:12px;color:var(--tx3);transition:all .15s;line-height:1.4;flex:1}
.chip.sel{border-color:var(--gold);background:rgba(176,64,255,.12);color:var(--gold)}
.fpill{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;white-space:nowrap}
.fdue{background:rgba(167,139,250,.15);color:var(--teal);border:1px solid rgba(167,139,250,.3)}
.fpend{background:var(--bg4);color:var(--tx3);border:1px solid var(--border)}
.fdone{background:rgba(192,132,252,.12);color:var(--grn);border:1px solid rgba(192,132,252,.25)}
.tli{display:flex;gap:13px;align-items:flex-start;padding:11px 0}
.tld{width:10px;height:10px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:4px;box-shadow:0 0 8px var(--gold)}
.tld.tp{background:var(--tx3);box-shadow:none}
.tld.td{background:var(--grn)!important;box-shadow:0 0 6px var(--grn)!important}

/* ═══ REFLECTION LAYERS ═══ */
.rl{border-radius:var(--r2);padding:14px 15px;margin-bottom:9px;border:1px solid;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none}
.rl-i{background:rgba(176,64,255,.06);border-color:rgba(176,64,255,.25)}
.rl-m{background:rgba(129,140,248,.05);border-color:rgba(129,140,248,.2)}
.rl-e{background:rgba(192,132,252,.05);border-color:rgba(192,132,252,.2)}
.rl-q{background:rgba(167,139,250,.05);border-color:rgba(167,139,250,.2)}
.rl-a{background:rgba(192,132,252,.05);border-color:rgba(192,132,252,.2)}
.rl-j{background:rgba(244,114,182,.05);border-color:rgba(244,114,182,.2)}
.rll{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px}
.rlt{font-size:14px;color:var(--tx2);line-height:1.65}
.rli .rll{color:var(--gold)}
.rlm .rll{color:var(--ind2)}
.rle .rll{color:var(--pur2)}
.rlq .rll{color:var(--teal)}
.rla .rll{color:var(--grn)}
.rlj .rll{color:var(--rose)}
.refq{background:linear-gradient(135deg,rgba(176,64,255,.08),rgba(129,140,248,.06));border:1px solid rgba(176,64,255,.2);border-radius:var(--r2);padding:15px;margin-bottom:9px;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none}
.refql{font-size:10px;color:var(--pur2);font-weight:700;letter-spacing:1.5px;margin-bottom:7px}
.refqt{font-size:14px;color:var(--tx);line-height:1.7;font-style:italic}
.acti{display:flex;gap:9px;align-items:flex-start;padding:9px 12px;background:rgba(192,132,252,.06);border-radius:var(--r1);border-left:2px solid var(--grn);margin-bottom:7px}
.wq{background:rgba(28,0,64,.7);border:1px solid var(--border);border-radius:var(--r2);padding:15px;margin-bottom:11px}
.wql{font-size:12px;color:var(--gold);font-weight:600;margin-bottom:7px}
.theme-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--border)}
.theme-row:last-child{border-bottom:none}
.tph{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--border)}
.tph:last-child{border-bottom:none}
.tphd{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}
.alert-b{border-radius:var(--r2);padding:13px 15px;display:flex;gap:11px;align-items:center;cursor:pointer;margin-bottom:13px;border:1px solid rgba(167,139,250,.3);background:rgba(167,139,250,.06)}
.lock-ov{background:linear-gradient(180deg,transparent,var(--bg3) 55%);position:absolute;bottom:0;left:0;right:0;padding:22px 20px;display:flex;flex-direction:column;align-items:center;gap:11px}
.emotion-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.emo-btn{background:rgba(28,0,64,.6);border:1px solid var(--border);border-radius:var(--r2);padding:18px 10px;cursor:pointer;text-align:center;font-size:28px;transition:all .15s}
.emo-btn:active,.emo-btn.sel{border-color:var(--gold);background:rgba(176,64,255,.12);box-shadow:0 0 16px rgba(176,64,255,.2)}
.stat-row{display:flex;justify-content:space-between;gap:10px;margin-bottom:14px}
.stat-box{flex:1;background:rgba(28,0,64,.7);border:1px solid var(--border);border-radius:var(--r2);padding:14px;text-align:center}
.stat-num{font-size:24px;font-weight:700;color:var(--gold);margin-bottom:3px;text-shadow:0 0 12px rgba(176,64,255,.4)}
.stat-lbl{font-size:11px;color:var(--tx3)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:50;display:flex;align-items:flex-end;opacity:0;visibility:hidden;transition:all .25s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal-sheet{background:linear-gradient(135deg,#130028,#1C0040);border-radius:var(--r3) var(--r3) 0 0;padding:24px 20px;width:100%;max-width:430px;margin:0 auto;transform:translateY(30px);transition:transform .25s;border:1px solid var(--border);border-bottom:none}
.modal-overlay.open .modal-sheet{transform:translateY(0)}

/* ═══ STAR / METEOR ANIMATIONS ═══ */
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes bounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-5px)}}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
@keyframes star-trail{0%{top:-40px;right:-40px;opacity:0}10%{opacity:.9}50%{opacity:.4}80%,100%{top:140%;right:140%;opacity:0}}
@keyframes btn-shine{0%,70%,100%{left:-100%}40%{left:130%}}
@keyframes float-star{0%,100%{transform:translateY(0) scale(1);opacity:.6}50%{transform:translateY(-6px) scale(1.1);opacity:1}}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 12px rgba(176,64,255,.2)}50%{box-shadow:0 0 28px rgba(176,64,255,.45),0 0 50px rgba(176,64,255,.1)}}
@keyframes orbit{from{transform:rotate(0deg) translateX(12px) rotate(0deg)}to{transform:rotate(360deg) translateX(12px) rotate(-360deg)}}

/* Random star delays for cards */
.card:nth-child(odd){--star-dur:9s;--star-del:1s}
.card:nth-child(even){--star-dur:11s;--star-del:4s}
.card:nth-child(3n){--star-dur:7s;--star-del:2s}

.skel{background:rgba(176,64,255,.12);border-radius:var(--r1);animation:pulse 1.5s infinite}
/* ═══ SHOOTING STARS BACKGROUND ═══ */
#star-field{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
@keyframes shoot-star{
  0%{transform:translate(0,0) rotate(-35deg);opacity:0}
  8%{opacity:1}
  60%{opacity:.5}
  100%{transform:translate(280px,280px) rotate(-35deg);opacity:0}
}
@keyframes twinkle{0%,100%{opacity:.2;transform:scale(1)}50%{opacity:.8;transform:scale(1.3)}}
.ss{position:absolute;border-radius:50%;animation:shoot-star linear infinite;opacity:0}
.ts{position:absolute;border-radius:50%;background:rgba(224,160,255,.6);animation:twinkle ease-in-out infinite}

@media (prefers-reduced-motion: reduce){
  .ss,.ts{animation:none!important;opacity:.3!important}
  .btn::before{animation:none!important}
  .card::before{animation:none!important}
}
@media (max-width:430px) and (pointer:coarse){
  /* ลด star count บน low-end mobile — ควบคุมผ่าน JS */
}


/* ─── VERA MASCOT ANIMATIONS ─── */
@keyframes vera-float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.02)}}
@keyframes vera-talk{0%,100%{opacity:0}50%{opacity:1}}
@keyframes vera-bounce{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.vera-mascot{position:relative;display:inline-block}
.vera-mascot img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 20px rgba(176,64,255,.5))}
.vera-idle{animation:vera-float 3s ease-in-out infinite}
.vera-talking .v-mouth-close{display:none}
.vera-talking .v-mouth-open{display:block!important}
.vera-idle .v-mouth-close{display:block}
.vera-idle .v-mouth-open{display:none}
.vera-frame{position:absolute;inset:0}
