/* ==========================================================================
   Vilnalin · Aura Nail Energy — visual system
   Spiritual beauty · aura glow · iridescent · glassmorphism
   3 mood themes via [data-theme]: dawn (default) · twilight · pearl
   ========================================================================== */

:root{
  /* brand carry-over */
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"IBM Plex Sans Thai", -apple-system, BlinkMacSystemFont, sans-serif;
  --rose:#A9726B; --rose-deep:#8F5D55;
  --col:440px;

  /* glow / stardust strength (driven by Tweaks) */
  --glow-mul:1;
  --dust-op:.7;
  --radius:26px;

  /* per-aura vars (set by JS on result) */
  --c1:#8C6CD8; --c2:#A98FE6; --c3:#CDB8F0; --c4:#EDE6FA;
  --glow:#8C6CD8; --aura-ink:#2E1F5A;
}

/* ---------- THEME: DAWN (default) — airy cream→blush→lavender ---------- */
:root,[data-theme="dawn"]{
  --bg:#FAF6F2;
  --bg-a:#F3DCE6;  /* blush */
  --bg-b:#E4DCF2;  /* lavender */
  --bg-c:#FBEBDD;  /* warm cream */
  --ink:#2A2420;
  --muted:#8B7F76;
  --faint:#B6ABA1;
  --line:rgba(42,36,32,.12);
  --line-soft:rgba(42,36,32,.07);
  --card-bg:rgba(255,253,252,.66);
  --card-line:rgba(255,255,255,.7);
  --card-text:#2A2420;
  --card-muted:#8B7F76;
  --panel:rgba(255,255,255,.5);
  --glass-blur:22px;
  --shadow:0 26px 60px -34px rgba(70,50,80,.5);
}

/* ---------- THEME: TWILIGHT — deep dusk, glowing, mystical ---------- */
[data-theme="twilight"]{
  --bg:#171327;
  --bg-a:#3A2A5E;
  --bg-b:#23314F;
  --bg-c:#4A2247;
  --ink:#EDE7F5;
  --muted:#A99FC2;
  --faint:#776E92;
  --line:rgba(255,255,255,.13);
  --line-soft:rgba(255,255,255,.07);
  --card-bg:rgba(40,32,60,.5);
  --card-line:rgba(255,255,255,.14);
  --card-text:#F2ECFA;
  --card-muted:#B6ACCB;
  --panel:rgba(255,255,255,.06);
  --glass-blur:26px;
  --shadow:0 30px 70px -30px rgba(0,0,0,.7);
  --dust-op:.95;
}

/* ---------- THEME: PEARL — near-white iridescent minimal ---------- */
[data-theme="pearl"]{
  --bg:#F4F3F6;
  --bg-a:#EAF0F6;
  --bg-b:#F3E9F1;
  --bg-c:#EDF2EF;
  --ink:#3A3742;
  --muted:#8E8A98;
  --faint:#BCB8C6;
  --line:rgba(58,55,66,.1);
  --line-soft:rgba(58,55,66,.05);
  --card-bg:rgba(255,255,255,.72);
  --card-line:rgba(255,255,255,.9);
  --card-text:#3A3742;
  --card-muted:#888494;
  --panel:rgba(255,255,255,.62);
  --glass-blur:30px;
  --shadow:0 24px 56px -32px rgba(120,110,140,.5);
  --dust-op:.5;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  transition:background .8s ease, color .6s ease;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit}

/* phone frame on wide screens */
.frame{position:relative;width:100%;max-width:var(--col);margin-inline:auto;min-height:100svh;min-height:100vh;overflow:hidden;isolation:isolate}
@media (min-width:560px){
  body{background:#1a1622}
  [data-theme="dawn"] body{background:#2a2333}
  .frame{box-shadow:0 40px 100px -40px rgba(0,0,0,.6)}
}

/* ===================== AMBIENT BACKGROUND ===================== */
.aura-bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none;background:var(--bg);transition:background .8s ease}
.aura-bg .blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:calc(.85*var(--glow-mul));mix-blend-mode:normal;transition:background 1s ease}
[data-theme="twilight"] .aura-bg .blob{mix-blend-mode:screen;opacity:calc(.6*var(--glow-mul));filter:blur(70px)}
.blob.b1{width:62vw;max-width:340px;aspect-ratio:1;background:var(--bg-a);top:-6%;left:-12%;animation:drift1 22s ease-in-out infinite}
.blob.b2{width:70vw;max-width:380px;aspect-ratio:1;background:var(--bg-b);top:30%;right:-22%;animation:drift2 27s ease-in-out infinite}
.blob.b3{width:58vw;max-width:320px;aspect-ratio:1;background:var(--bg-c);bottom:-8%;left:-6%;animation:drift3 25s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(18px,26px) scale(1.12)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-26px,18px) scale(1.08)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(22px,-20px) scale(1.1)}}

.stardust{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:var(--dust-op);transition:opacity .6s ease}
.star{position:absolute;border-radius:50%;background:#fff;box-shadow:0 0 6px rgba(255,255,255,.9);animation:twinkle var(--tw,4s) ease-in-out infinite;animation-delay:var(--dl,0s)}
[data-theme="dawn"] .star{background:#fff;box-shadow:0 0 6px rgba(255,240,250,.95)}
[data-theme="pearl"] .star{background:#cfc6dc;box-shadow:0 0 5px rgba(200,190,220,.8)}
@keyframes twinkle{0%,100%{opacity:.15;transform:scale(.7)}50%{opacity:1;transform:scale(1)}}

/* ===================== TOP BAR ===================== */
.topbar{position:relative;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:18px 20px 6px;max-width:var(--col);margin-inline:auto}
.tb-back{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 20px -10px rgba(70,50,80,.4);transition:transform .2s ease}
.tb-back svg{width:19px;height:19px;display:block;transform:translateX(-1px)}
.tb-back.show{opacity:1;pointer-events:auto}
.tb-back:active{transform:scale(.92)}
.wordmark{font-family:var(--serif);font-size:23px;font-weight:600;letter-spacing:.02em;line-height:1;color:var(--ink);text-decoration:none}
.wordmark .dot{color:var(--rose)}
.tb-saved{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);border-radius:30px;padding:8px 13px;background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:border-color .2s ease,color .2s ease}
.tb-saved:active{transform:scale(.96)}
.tb-saved .cnt{font-weight:600;color:var(--ink)}

/* in-app theme switch (sun / moon / pearl) */
.tb-right{display:flex;align-items:center;gap:8px;min-width:0}
.theme-switch{display:flex;align-items:center;gap:2px;padding:3px;border-radius:30px;
  border:1px solid var(--line);background:var(--panel);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.th-opt{width:30px;height:30px;flex:none;border:none;background:none;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--muted);padding:0;
  transition:background .22s ease,color .22s ease,transform .15s ease,box-shadow .22s ease}
.th-opt svg{width:16px;height:16px;display:block}
.th-opt:active{transform:scale(.88)}
@media (hover:hover){.th-opt:hover{color:var(--ink)}}
.th-opt[aria-checked="true"]{background:var(--rose);color:#fff;
  box-shadow:0 5px 13px -4px color-mix(in srgb, var(--rose) 80%, transparent)}
@media (hover:hover){.th-opt[aria-checked="true"]:hover{color:#fff}}
@media (max-width:400px){
  .tb-saved span:not(.cnt){display:none}
  .tb-saved{padding:8px 11px}
}

/* ===================== SCREENS ===================== */
.screen{display:none;position:relative;z-index:10;flex-direction:column;min-height:calc(100svh - 64px);padding:8px 22px calc(92px + env(safe-area-inset-bottom))}
.screen.active{display:flex;animation:scrIn .6s cubic-bezier(.22,.68,.18,1)}
/* translate-only entrance: end-state is the natural style, so content is always
   visible even if rAF is paused (preview capture) and the anim sticks at frame 0 */
@keyframes scrIn{from{transform:translateY(16px)}to{transform:none}}
/* smooth in-page scrolling (motion-safe) */
@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}

.eyebrow{font-size:11px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--rose);white-space:nowrap}
.h-display{font-family:var(--serif);font-style:italic;font-weight:500;letter-spacing:-.01em;line-height:1.02}

/* ===================== INTRO ===================== */
.intro{align-items:center;text-align:center;justify-content:center;gap:0}
.orb-wrap{position:relative;width:230px;height:230px;margin:6px auto 4px;display:flex;align-items:center;justify-content:center}
.orb-halo{position:absolute;inset:-38%;border-radius:50%;
  background:radial-gradient(circle at 50% 44%, rgba(255,150,195,.72), rgba(168,138,236,.5) 42%, rgba(150,140,230,.16) 64%, transparent 76%);
  filter:blur(26px);animation:halo 6s ease-in-out infinite;opacity:var(--glow-mul)}
@keyframes halo{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.1);opacity:1}}
/* backdrop disc: gives the orb a body + a defining edge against ANY theme bg
   (edge is toned rose so it never dissolves into a near-white pearl background) */
.orb-wrap::before{content:"";position:absolute;width:204px;height:204px;border-radius:50%;
  background:radial-gradient(circle at 50% 40%, #ffffff 0%, color-mix(in srgb, var(--bg) 55%, #fff) 50%, color-mix(in srgb, var(--rose) 30%, var(--bg)) 100%);
  box-shadow:0 26px 64px -26px rgba(150,110,190,.55), 0 0 0 1px color-mix(in srgb, var(--rose) 32%, transparent);
  z-index:0}
.orb{position:relative;width:200px;height:200px;border-radius:50%;overflow:hidden;z-index:1;
  box-shadow:0 22px 60px -24px rgba(150,120,190,.5), inset 0 0 0 1px rgba(255,255,255,.45), inset 0 -18px 36px -16px rgba(150,110,180,.4);
  -webkit-mask:radial-gradient(circle at 50% 50%, #000 84%, rgba(0,0,0,.88) 93%, transparent 100%);
  mask:radial-gradient(circle at 50% 50%, #000 84%, rgba(0,0,0,.88) 93%, transparent 100%)}
.orb::after{content:"";position:absolute;inset:0;border-radius:50%;pointer-events:none;z-index:2;
  background:radial-gradient(58% 52% at 42% 32%, rgba(255,255,255,.55), transparent 56%);
  mix-blend-mode:screen;opacity:.7}
.orb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%;transform:scale(1.3);filter:saturate(1.4) brightness(1.02)}
.orb video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%;transform:scale(1.3);filter:saturate(1.55) brightness(1.05) contrast(1.05);mix-blend-mode:lighten;
  pointer-events:none /* TikTok/IG WebView: กัน native player overlay เปิด full-screen player */}
/* Hide native media controls overlay บน orb video — TikTok/IG/FB WebView + Safari iOS */
.orb video::-webkit-media-controls,
.orb video::-webkit-media-controls-panel,
.orb video::-webkit-media-controls-overlay-play-button,
.orb video::-webkit-media-controls-start-playback-button,
.orb video::-webkit-media-controls-enclosure{
  display:none !important;
  -webkit-appearance:none !important;
  opacity:0 !important;
  pointer-events:none !important;
}
.orb-ring{position:absolute;inset:-14px;border-radius:50%;border:1px solid color-mix(in srgb, var(--rose) 34%, transparent);z-index:1;
  -webkit-mask:radial-gradient(circle, transparent 70%, #000 72%);mask:radial-gradient(circle, transparent 70%, #000 72%);animation:spin 40s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.intro .eyebrow{margin-top:14px}
.intro h1{font-family:var(--sans);font-style:normal;font-weight:600;font-size:clamp(30px,8.6vw,38px);line-height:1.12;letter-spacing:0;margin-top:12px;text-wrap:balance}
.intro .sub{margin-top:14px;font-size:15px;font-weight:300;color:var(--muted);max-width:24em;text-wrap:pretty}

.path-grid{display:flex;flex-direction:column;gap:14px;width:100%;margin-top:26px}
.path{position:relative;overflow:hidden;display:flex;align-items:center;gap:16px;text-align:left;width:100%;
  background:var(--card-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--card-line);border-radius:22px;padding:18px 18px;min-height:88px;cursor:pointer;
  box-shadow:var(--shadow);
  transition:transform .26s cubic-bezier(.34,1.4,.64,1),box-shadow .32s ease,border-color .3s ease}
.path.is-quiz{--g1:#E07A9B;--g2:#F0B47E}
.path.is-zodiac{--g1:#7E63CF;--g2:#C99BD8}
/* gradient hairline border */
.path::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;z-index:0;
  background:linear-gradient(135deg,var(--g1),transparent 48%,var(--g2));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  opacity:.45;transition:opacity .32s ease}
/* breathing aura bloom on the icon side */
.path::after{content:"";position:absolute;left:-8%;top:50%;width:128px;height:128px;transform:translateY(-50%);
  border-radius:50%;background:radial-gradient(circle,var(--g1),transparent 64%);
  filter:blur(28px);opacity:.3;pointer-events:none;z-index:0;animation:pathGlow 5.5s ease-in-out infinite}
@keyframes pathGlow{0%,100%{opacity:.22;transform:translateY(-50%) scale(1)}50%{opacity:.4;transform:translateY(-50%) scale(1.14)}}
.path:hover{transform:translateY(-2px);box-shadow:0 32px 64px -32px color-mix(in srgb,var(--g1) 70%,rgba(80,60,120,.6))}
.path:hover::before{opacity:.95}
.path:active{transform:scale(.985)}
.path-wm{position:absolute;right:-4px;bottom:-22px;font-size:104px;line-height:1;color:var(--g2);
  opacity:.08;transform:rotate(-12deg);pointer-events:none;z-index:0}
.path-ic{width:54px;height:54px;flex:none;border-radius:16px;display:flex;align-items:center;justify-content:center;
  font-size:25px;color:#fff;position:relative;overflow:hidden;z-index:1;
  box-shadow:0 12px 26px -10px var(--g1);animation:icFloat 4.5s ease-in-out infinite}
@keyframes icFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.path-ic.zo{background:linear-gradient(135deg,#7E63CF,#C99BD8)}
.path-ic.qz{background:linear-gradient(135deg,#E07A9B,#F0B47E)}
.path-ic::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.6),transparent 55%)}
.path-tx{flex:1;min-width:0;position:relative;z-index:1}
.path-tx .t{display:block;font-size:17px;font-weight:600;color:var(--card-text);letter-spacing:-.01em}
.path-tx .s{display:block;font-size:12.5px;font-weight:300;color:var(--card-muted);margin-top:4px;line-height:1.45;text-wrap:pretty}
.path-arw{flex:none;position:relative;z-index:1;width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:16px;
  background:color-mix(in srgb,var(--g1) 13%,transparent);color:var(--g1);
  transition:transform .26s ease,background .26s ease}
.path:hover .path-arw{transform:translateX(3px);background:color-mix(in srgb,var(--g1) 22%,transparent)}

.disclaimer{margin-top:22px;font-size:11px;line-height:1.6;color:var(--faint);max-width:26em;text-wrap:pretty;font-weight:300}
.intro .disclaimer{text-align:center;margin-inline:auto}

/* ===================== SECTION HEAD (zodiac/quiz) ===================== */
.sec-head{text-align:center;margin:6px 0 20px}
.sec-head h2{font-family:var(--sans);font-style:normal;font-weight:600;font-size:27px;line-height:1.14;margin-top:8px}
.sec-head .s{font-size:13px;font-weight:300;color:var(--muted);margin-top:8px;text-wrap:pretty}

/* ===================== ZODIAC GRID ===================== */
.zodiac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
.zod{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center;
  background:var(--card-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--card-line);border-radius:18px;padding:14px 6px 11px;cursor:pointer;
  box-shadow:0 14px 34px -28px rgba(70,50,80,.6);transition:transform .2s cubic-bezier(.34,1.4,.64,1),border-color .25s ease}
.zod:active{transform:scale(.95)}
.zod .glyph{font-size:28px;line-height:1;color:var(--card-text);
  background:linear-gradient(135deg,var(--c1),var(--c3));-webkit-background-clip:text;background-clip:text}
.zod .th{font-size:14px;font-weight:600;color:var(--card-text);margin-top:5px}
.zod .el{font-size:10px;font-weight:400;color:var(--card-muted);letter-spacing:.02em;white-space:nowrap}
.zod .rg{font-size:9px;font-weight:300;color:var(--faint);margin-top:1px;white-space:nowrap}
/* element accent dot */
.zod .glyph{position:relative}
.zod[data-el="ไฟ"] .glyph{background:linear-gradient(135deg,#E8442B,#FFB454);-webkit-background-clip:text;background-clip:text;color:transparent}
.zod[data-el="ดิน"] .glyph{background:linear-gradient(135deg,#7E8C5E,#D8C9B0);-webkit-background-clip:text;background-clip:text;color:transparent}
.zod[data-el="ลม"] .glyph{background:linear-gradient(135deg,#7E63CF,#8CEBC0);-webkit-background-clip:text;background-clip:text;color:transparent}
.zod[data-el="น้ำ"] .glyph{background:linear-gradient(135deg,#4FB8B0,#9FB2CC);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===================== QUIZ ===================== */
.quiz{justify-content:flex-start}
.q-prog{display:flex;align-items:center;gap:8px;margin:4px 0 18px}
.q-prog .bar{flex:1;height:4px;border-radius:4px;background:var(--line);overflow:hidden}
.q-prog .bar i{display:block;height:100%;border-radius:4px;width:0;background:linear-gradient(90deg,var(--rose),#C99BD8);transition:width .5s cubic-bezier(.22,.68,.18,1)}
.q-prog .num{font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.q-stage{flex:1}
.q-cap{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--rose);text-align:center}
.q-text{font-family:var(--sans);font-style:normal;font-weight:600;font-size:23px;line-height:1.32;text-align:center;margin:10px auto 22px;max-width:16em;text-wrap:balance}
.opts{display:flex;flex-direction:column;gap:9px}
.opt{display:flex;align-items:center;gap:13px;width:100%;text-align:left;
  background:var(--card-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--card-line);border-radius:15px;padding:14px 16px;cursor:pointer;color:var(--card-text);
  box-shadow:0 12px 30px -28px rgba(70,50,80,.5);transition:transform .15s ease,border-color .2s ease,background .2s ease}
.opt:active{transform:scale(.985)}
.opt.on{border-color:var(--rose);background:color-mix(in srgb,var(--rose) 12%,var(--card-bg))}
.opt .dot{width:22px;height:22px;flex:none;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;transition:all .2s ease}
.opt.on .dot{background:var(--rose);border-color:var(--rose)}
.opt .otx{flex:1;font-size:14.5px;font-weight:400;line-height:1.4;text-wrap:pretty}
.opt .sw{display:flex;gap:0;flex:none;border-radius:30px;overflow:hidden;box-shadow:0 2px 8px -2px rgba(0,0,0,.3)}
.opt .sw span{width:16px;height:24px}
.q-nav{display:flex;gap:10px;margin-top:18px}

/* ===================== BUTTONS ===================== */
.a-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:54px;padding:0 24px;border-radius:40px;border:none;
  font-family:var(--sans);font-size:15.5px;font-weight:500;letter-spacing:.01em;cursor:pointer;
  transition:transform .2s ease,background .25s ease,border-color .25s ease,color .2s ease}
.a-btn:active{transform:scale(.97)}
.a-btn.primary{flex:1;color:#fff;background:linear-gradient(120deg,var(--rose),#C5917F);box-shadow:0 16px 34px -14px rgba(169,114,107,.75)}
.a-btn.primary:hover{filter:brightness(1.04)}
.a-btn.ghost{flex:1;color:var(--ink);background:var(--panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line)}
.a-btn.ghost:hover{border-color:var(--ink)}
.a-btn.aura{background:linear-gradient(120deg,var(--c1),var(--c2));color:#fff;box-shadow:0 18px 40px -16px var(--glow)}
.a-btn.block{width:100%}
.a-link{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:46px;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;background:none;border:none}
.a-link:hover{color:var(--ink)}

/* ===================== RESULT REVEAL OVERLAY ===================== */
.reveal{position:fixed;inset:0;z-index:120;display:none;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  background:var(--bg);max-width:var(--col);margin-inline:auto}
.reveal.show{display:flex;animation:scrIn .4s ease}
.reveal.out{animation:revOut .5s ease forwards}
@keyframes revOut{to{opacity:0;visibility:hidden}}
.reveal .orb-wrap{width:200px;height:200px;animation:orbThrob 1.6s ease-in-out infinite}
@keyframes orbThrob{0%,100%{transform:scale(.96)}50%{transform:scale(1.05)}}
.reveal .rv-tx{font-family:var(--sans);font-style:normal;font-weight:500;font-size:18px;color:var(--ink);letter-spacing:.01em;animation:fadePulse 1.8s ease-in-out infinite}
@keyframes fadePulse{0%,100%{opacity:.55}50%{opacity:1}}
.reveal .rv-sub{font-size:12px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;margin-top:-14px}

/* ===================== RESULT CARD ===================== */
.result{padding-top:4px}
.res-glow{position:fixed;top:0;left:50%;transform:translateX(-50%);width:var(--col);max-width:var(--col);height:60vh;z-index:5;pointer-events:none;
  background:radial-gradient(120% 70% at 50% 0%, color-mix(in srgb,var(--glow) 60%,transparent), transparent 62%);
  opacity:calc(.9*var(--glow-mul));transition:opacity .6s ease}
.res-card{position:relative;z-index:10;background:var(--card-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.2);backdrop-filter:blur(var(--glass-blur)) saturate(1.2);
  border:1px solid var(--card-line);border-radius:var(--radius);padding:26px 22px 24px;box-shadow:var(--shadow);overflow:hidden}
.res-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,color-mix(in srgb,var(--c2) 70%,white),transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.7}
.res-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.res-eyebrow{font-size:10.5px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--card-muted)}
.el-chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.04em;color:#fff;
  padding:5px 12px;border-radius:30px;background:linear-gradient(120deg,var(--c1),var(--c2))}
.el-chip .d{width:5px;height:5px;border-radius:50%;background:#fff}

.res-name{font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(32px,9vw,40px);line-height:1;letter-spacing:-.01em;margin-top:14px;
  background:linear-gradient(120deg,var(--c1),var(--c2));-webkit-background-clip:text;background-clip:text;color:transparent}
[data-theme="twilight"] .res-name{background:linear-gradient(120deg,var(--c2),var(--c3));-webkit-background-clip:text;background-clip:text;color:transparent}
.res-thai{font-size:15px;font-weight:500;color:var(--card-text);margin-top:4px}
.res-theme{font-size:12.5px;font-weight:300;color:var(--card-muted);margin-top:4px;letter-spacing:.01em}

/* nail visual */
.nail-stage{position:relative;margin:22px auto 6px;width:100%;display:flex;align-items:flex-end;justify-content:center}
.nail-aura{position:absolute;inset:-6% -2% -14%;border-radius:50%;
  background:radial-gradient(60% 55% at 50% 50%, color-mix(in srgb,var(--glow) 75%,transparent), transparent 70%);
  filter:blur(18px);opacity:calc(.85*var(--glow-mul));animation:halo 5s ease-in-out infinite}
.nail-set{position:relative;display:flex;align-items:flex-end;gap:9px;padding:14px 4px}
.nail{position:relative;width:34px;border-radius:50% 50% 30% 30%/70% 70% 14% 14%;overflow:hidden;
  box-shadow:0 8px 18px -8px rgba(40,20,50,.45), 0 0 0 1px rgba(255,255,255,.25) inset}
.nail.n1{height:74px}.nail.n2{height:90px}.nail.n3{height:98px}.nail.n4{height:88px}.nail.n5{height:68px}
.nail::after{content:"";position:absolute;left:14%;top:6%;width:34%;height:50%;border-radius:50%;
  background:linear-gradient(160deg,rgba(255,255,255,.85),rgba(255,255,255,0) 70%);filter:blur(1px)}

/* —— finishes —— */
.nail[data-finish="gradient"],.nail[data-finish="earth"]{background:linear-gradient(165deg,var(--c1),var(--c2) 45%,var(--c3))}
.nail[data-finish="catEye"]{background:linear-gradient(160deg,var(--c1),var(--c3))}
.nail[data-finish="catEye"]::before{content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 38%,color-mix(in srgb,var(--c4) 92%,white) 49%,transparent 60%);mix-blend-mode:screen}
.nail[data-finish="pearl"]{background:linear-gradient(160deg,var(--c2),var(--c4) 50%,var(--c1))}
.nail[data-finish="pearl"]::before{content:"";position:absolute;inset:0;opacity:.7;
  background:conic-gradient(from 120deg at 40% 30%,#ffd9ec,#d9e7ff,#e3ffe9,#fff0d9,#ffd9ec);mix-blend-mode:soft-light}
.nail[data-finish="blur"]{background:radial-gradient(70% 60% at 50% 35%,var(--c3),var(--c1) 90%)}
.nail[data-finish="blur"]::before{content:"";position:absolute;inset:0;
  background:radial-gradient(50% 40% at 50% 30%,color-mix(in srgb,var(--c4) 90%,white),transparent 70%);filter:blur(3px)}
.nail[data-finish="jelly"]{background:linear-gradient(165deg,var(--c1),var(--c3));opacity:.96}
.nail[data-finish="jelly"]::before{content:"";position:absolute;inset:0;opacity:.55;
  background:linear-gradient(140deg,#ff9be3,#9bd4ff,#9bffd0,#fff79b);mix-blend-mode:screen}
.nail[data-finish="galaxy"]{background:linear-gradient(165deg,var(--c1),var(--c2) 55%,#1a1140)}
.nail[data-finish="galaxy"]::before{content:"";position:absolute;inset:0;opacity:.9;
  background:radial-gradient(1px 1px at 30% 25%,#fff,transparent),radial-gradient(1px 1px at 65% 45%,#fff,transparent),radial-gradient(1.5px 1.5px at 45% 70%,#ffe9b0,transparent),radial-gradient(1px 1px at 78% 78%,#fff,transparent),radial-gradient(1px 1px at 20% 60%,#cdb8f0,transparent)}
.nail[data-finish="metallic"]{background:linear-gradient(160deg,var(--c1),var(--c3) 60%,var(--c2))}
.nail[data-finish="metallic"]::before{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,color-mix(in srgb,var(--c4) 85%,white) 50%,transparent 66%);mix-blend-mode:screen;opacity:.9}
.nail[data-finish="glass"]{background:linear-gradient(160deg,color-mix(in srgb,var(--c2) 80%,white),var(--c3) 60%,var(--c1));opacity:.92}
.nail[data-finish="glass"]::before{content:"";position:absolute;inset:0;opacity:.6;
  background:linear-gradient(135deg,rgba(255,255,255,.7),transparent 45%,rgba(255,255,255,.4))}

.nail-note{text-align:center;font-size:10.5px;color:var(--faint);font-weight:300;margin-top:2px;letter-spacing:.02em}

/* palette + finish chips */
.res-meta{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.meta-row .ml{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--card-muted);margin-bottom:7px}
.pal{display:flex;align-items:center;gap:9px}
.pal .sw{width:30px;height:30px;border-radius:50%;box-shadow:0 4px 10px -3px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.4) inset}
.pal .pt{font-size:13px;color:var(--card-text);font-weight:400}
.fin{font-size:13.5px;color:var(--card-text);font-weight:400;line-height:1.5;text-wrap:pretty}

.res-desc{font-size:14px;line-height:1.72;color:var(--card-text);font-weight:300;margin-top:18px;text-wrap:pretty;
  padding-top:18px;border-top:1px solid var(--line-soft)}

.affirm{position:relative;margin-top:18px;padding:18px 18px 18px 22px;border-radius:18px;overflow:hidden;
  background:linear-gradient(135deg,color-mix(in srgb,var(--c1) 16%,var(--card-bg)),color-mix(in srgb,var(--c2) 10%,var(--card-bg)))}
.affirm::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(var(--c1),var(--c2))}
.affirm .al{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--card-muted);margin-bottom:6px}
.affirm .aq{font-family:var(--sans);font-style:normal;font-weight:500;font-size:16px;line-height:1.5;color:var(--card-text);text-wrap:pretty}

.res-disc{margin-top:16px;font-size:10.5px;line-height:1.6;color:var(--faint);font-weight:300;text-align:center;text-wrap:pretty}

.res-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.res-actions .row2{display:flex;gap:10px}
.mini-row{display:flex;gap:8px;justify-content:center;margin-top:4px;flex-wrap:wrap}
.mini{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:var(--muted);
  border:1px solid var(--line);border-radius:30px;padding:9px 15px;background:var(--panel);cursor:pointer;transition:border-color .2s ease,color .2s ease}
.mini:active{transform:scale(.96)}
.mini:hover{color:var(--ink);border-color:var(--ink)}

/* nearby tones reveal */
.nearby{display:none;margin-top:14px;gap:8px}
.nearby.show{display:flex}
.nearby .nb{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;border-radius:14px;
  background:var(--panel);border:1px solid var(--line);cursor:pointer;transition:transform .18s ease,border-color .2s ease}
.nearby .nb:active{transform:scale(.96)}
.nearby .nb .swc{width:30px;height:30px;border-radius:50%;box-shadow:0 0 0 1px rgba(255,255,255,.4) inset}
.nearby .nb .nbn{font-size:11px;font-weight:500;color:var(--card-text);text-align:center;line-height:1.2}

/* ===================== SAVED SHEET ===================== */
.sheet-scrim{position:fixed;inset:0;z-index:200;background:rgba(20,12,28,.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .3s ease;max-width:var(--col);margin-inline:auto}
.sheet-scrim.show{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:210;max-width:var(--col);margin-inline:auto;
  background:var(--bg);border-radius:26px 26px 0 0;border:1px solid var(--line);border-bottom:none;
  padding:8px 20px calc(26px + env(safe-area-inset-bottom));max-height:82vh;display:flex;flex-direction:column;
  transform:translateY(110%);transition:transform .42s cubic-bezier(.22,.68,.18,1);box-shadow:0 -16px 50px -16px rgba(0,0,0,.4)}
.sheet.show{transform:none}
.sheet-grip{width:40px;height:4px;border-radius:4px;background:var(--line);margin:10px auto 14px}
.sheet h3{font-family:var(--sans);font-style:normal;font-weight:600;font-size:21px;text-align:center;margin-bottom:4px}
.sheet .sh-s{font-size:12px;color:var(--muted);text-align:center;margin-bottom:18px;font-weight:300}
.saved-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto}
.saved-item{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:var(--card-bg);cursor:pointer;transition:border-color .2s ease}
.saved-item:active{transform:scale(.99)}
.saved-chip{width:46px;height:46px;flex:none;border-radius:13px;box-shadow:0 0 0 1px rgba(255,255,255,.35) inset}
.saved-tx{flex:1;min-width:0}
.saved-tx .st{font-size:15px;font-weight:600;color:var(--card-text)}
.saved-tx .ss{font-size:11.5px;color:var(--card-muted);font-weight:300;margin-top:1px}
.saved-tx .sd{font-size:10.5px;color:var(--faint);margin-top:2px}
.saved-del{flex:none;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:none;color:var(--faint);font-size:15px;cursor:pointer}
.saved-empty{text-align:center;color:var(--muted);font-size:13px;font-weight:300;padding:30px 10px}
.saved-empty .se-ic{font-size:30px;margin-bottom:10px;opacity:.5}

/* toast */
.toast{position:fixed;left:50%;bottom:calc(30px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(20px);z-index:300;
  background:rgba(30,22,38,.92);color:#fff;font-size:13.5px;font-weight:500;padding:12px 20px;border-radius:30px;
  box-shadow:0 14px 34px -12px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* footer flourish */
.flourish{text-align:center;font-family:var(--serif);font-style:italic;color:var(--faint);font-size:13px;letter-spacing:.1em;padding:8px 0 18px;position:relative;z-index:10}

/* ===================== BOTTOM TAB BAR (app nav) ===================== */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;justify-content:center;pointer-events:none}
.tabbar-inner{width:100%;max-width:var(--col);margin-inline:auto;display:flex;align-items:stretch;gap:2px;
  padding:7px 8px calc(7px + env(safe-area-inset-bottom));
  background:color-mix(in srgb, var(--bg) 84%, transparent);
  -webkit-backdrop-filter:saturate(1.3) blur(20px);backdrop-filter:saturate(1.3) blur(20px);
  border:1px solid var(--line);border-bottom:none;border-radius:24px 24px 0 0;
  box-shadow:0 -10px 34px -16px rgba(40,28,52,.4);pointer-events:auto}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  min-height:50px;border-radius:15px;border:none;background:transparent;cursor:pointer;
  color:var(--faint);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.01em;
  transition:color .2s ease, background .2s ease, transform .15s ease}
.tab svg{width:23px;height:23px;display:block;stroke-width:1.6}
.tab .tab-l{line-height:1;white-space:nowrap}
.tab:active{transform:scale(.95)}
.tab.is-active{color:var(--rose);background:color-mix(in srgb, var(--rose) 13%, transparent)}
.tab.is-active svg{stroke-width:2.1}
.tab.is-chat{color:var(--rose)}
.tab.is-chat svg{stroke-width:1.85}

@media (prefers-reduced-motion:reduce){
  .blob,.star,.orb-halo,.orb-ring,.nail-aura,.reveal .orb-wrap,.reveal .rv-tx{animation:none!important}
  .screen.active{animation:none}
}
[data-motion="off"] .blob,
[data-motion="off"] .star,
[data-motion="off"] .orb-halo,
[data-motion="off"] .orb-ring,
[data-motion="off"] .orb video,
[data-motion="off"] .nail-aura,
[data-motion="off"] .reveal .orb-wrap,
[data-motion="off"] .reveal .rv-tx{animation:none!important}

/* ===================== ZODIAC AURA CARDS ===================== */
.za-head{text-align:center;margin:6px 0 2px}
.za-head .eyebrow{display:inline-block}
.za-head h2{font-family:var(--sans);font-style:normal;font-weight:600;font-size:29px;line-height:1.16;letter-spacing:0;margin-top:8px}
.za-head .s{font-size:13px;font-weight:300;color:var(--muted);margin:10px auto 0;max-width:28em;text-wrap:pretty}

.za-carousel{display:flex;gap:0;align-items:flex-start;margin-top:20px;overflow-x:auto;scroll-snap-type:x mandatory;cursor:grab;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
  padding:18px 0 6px;padding-inline:calc(50% - 139px)}
.za-carousel::-webkit-scrollbar{display:none}
.za-carousel.za-grabbing{cursor:grabbing;scroll-snap-type:none}
.za-card img{-webkit-user-drag:none;user-select:none}

.za-card{flex:0 0 auto;display:block;width:278px;max-width:72vw;scroll-snap-align:center;margin-inline:8px;
  background:none;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent;
  transform:scale(.85);opacity:.55;
  transition:transform .42s cubic-bezier(.22,.68,.18,1),opacity .42s ease}
.za-card.is-active{transform:scale(1);opacity:1}
.za-card-frame{display:block;position:relative;aspect-ratio:3/4;border-radius:24px;overflow:hidden;
  background:linear-gradient(160deg,var(--za-c1,#caa6b2),var(--za-c2,#e8cdd6));
  box-shadow:0 16px 40px -22px rgba(40,28,55,.55)}
.za-card.is-active .za-card-frame{box-shadow:0 26px 64px -20px var(--za-glow,rgba(40,28,55,.6)),0 0 0 1px rgba(255,255,255,.55)}
/* tap-to-reveal micro-interaction: bloom + glint before the sheet rises */
.za-card.revealing .za-card-frame{animation:zaReveal .56s cubic-bezier(.34,1.56,.64,1)}
@keyframes zaReveal{
  0%{transform:scale(1);box-shadow:0 26px 64px -20px var(--za-glow),0 0 0 1px rgba(255,255,255,.55)}
  42%{transform:scale(1.05);box-shadow:0 32px 88px -14px var(--za-glow),0 0 0 3px rgba(255,255,255,.85),0 0 46px 9px var(--za-glow)}
  100%{transform:scale(1);box-shadow:0 26px 64px -20px var(--za-glow),0 0 0 1px rgba(255,255,255,.55)}}
.za-card-frame::before{content:"";position:absolute;inset:0;z-index:3;border-radius:inherit;pointer-events:none;opacity:0;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.6) 48%,transparent 64%);transform:translateX(-120%)}
.za-card.revealing .za-card-frame::before{animation:zaGlint .6s ease-out}
@keyframes zaGlint{0%{opacity:0;transform:translateX(-120%)}28%{opacity:1}100%{opacity:0;transform:translateX(120%)}}
.za-card-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 30%;
  opacity:0;transition:opacity .55s ease}
.za-card-frame img.loaded{opacity:1}
.za-skel{position:absolute;inset:0;background-image:linear-gradient(110deg,rgba(255,255,255,0) 32%,rgba(255,255,255,.34) 50%,rgba(255,255,255,0) 68%);
  background-size:220% 100%;animation:zaSkel 1.5s linear infinite}
.za-card-frame img.loaded + .za-skel{display:none}
@keyframes zaSkel{0%{background-position:140% 0}100%{background-position:-140% 0}}
.za-card-frame::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  box-shadow:inset 0 -40px 50px -28px rgba(20,12,30,.42)}
.za-label{display:block;text-align:center;margin-top:13px}
.za-label .th{font-family:var(--sans);font-style:normal;font-weight:600;font-size:17px;color:var(--ink);line-height:1.1}
.za-label .en{display:block;font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--za-accent,var(--rose));margin-top:5px}

.za-dots{display:flex;justify-content:center;gap:5px;margin-top:18px;flex-wrap:wrap;max-width:240px;margin-inline:auto}
.za-dot{width:6px;height:6px;border-radius:50%;background:var(--line);transition:width .3s ease,background .3s ease}
.za-dot.on{width:18px;border-radius:6px;background:var(--rose)}
.za-hint{text-align:center;font-size:12px;color:var(--faint);font-weight:300;margin-top:14px}

/* —— result bottom sheet —— */
.za-scrim{position:fixed;inset:0;z-index:220;background:rgba(20,12,28,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity .32s ease;max-width:var(--col);margin-inline:auto}
.za-scrim.show{opacity:1;pointer-events:auto}
.za-sheet{position:fixed;left:0;right:0;bottom:0;z-index:230;max-width:var(--col);margin-inline:auto;
  background:var(--bg);border-radius:28px 28px 0 0;border:1px solid var(--line);border-bottom:none;
  max-height:94svh;max-height:94vh;display:flex;flex-direction:column;
  transform:translateY(101%);transition:transform .46s cubic-bezier(.22,.68,.18,1);
  box-shadow:0 -20px 60px -18px rgba(20,12,30,.5)}
.za-sheet.show{transform:none}
.za-sheet-grip{width:42px;height:5px;border-radius:3px;background:var(--line);margin:10px auto 0;flex:none}
.za-sheet-close{position:absolute;top:14px;right:16px;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);
  background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--ink);font-size:19px;line-height:1;cursor:pointer;z-index:3;
  display:flex;align-items:center;justify-content:center;transition:transform .15s ease}
.za-sheet-close:active{transform:scale(.9)}
.za-sheet-body{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:10px 22px calc(26px + env(safe-area-inset-bottom))}

.za-res-glow{position:absolute;top:0;left:50%;transform:translateX(-50%);width:100%;height:340px;pointer-events:none;z-index:0;
  background:radial-gradient(120% 80% at 50% 0%,color-mix(in srgb,var(--za-glow) 55%,transparent),transparent 64%);opacity:calc(.95*var(--glow-mul))}
.za-res-img{position:relative;z-index:1;width:208px;margin:8px auto 0;aspect-ratio:3/4;border-radius:22px;overflow:hidden;
  box-shadow:0 24px 56px -22px var(--za-glow),0 0 0 1px rgba(255,255,255,.5);
  animation:zaPop .52s .06s cubic-bezier(.34,1.56,.64,1) both}
@keyframes zaPop{0%{transform:scale(.84) translateY(8px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
[data-motion="off"] .za-res-img{animation:none}
.za-res-img img{width:100%;height:100%;object-fit:cover}
.za-res-head{position:relative;z-index:1;text-align:center;margin-top:18px}
.za-res-el{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.04em;color:#fff;
  padding:5px 13px;border-radius:30px;background:var(--za-accent)}
.za-res-el .d{width:5px;height:5px;border-radius:50%;background:#fff}
.za-res-name{font-family:var(--serif);font-style:italic;font-weight:600;font-size:32px;line-height:1.02;letter-spacing:-.01em;margin-top:12px;color:var(--ink)}
.za-res-thai{font-size:15px;font-weight:500;color:var(--card-text);margin-top:5px}
.za-affirm .q{font-family:var(--sans);font-style:normal;font-weight:500;font-size:16px;line-height:1.5;color:var(--card-text);text-wrap:pretty}
.za-res-concept{font-size:13px;font-weight:500;color:var(--za-accent);margin-top:8px;letter-spacing:.01em}

.za-res-meta{margin-top:22px;border-top:1px solid var(--line-soft)}
.za-meta-row{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line-soft)}
.za-meta-l{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--card-muted);width:92px;flex:none;padding-top:5px}
.za-meta-c{flex:1;min-width:0}
.za-pal{display:flex;align-items:center;gap:8px}
.za-pal .sw{width:26px;height:26px;border-radius:50%;flex:none;box-shadow:0 3px 9px -3px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.45) inset}
.za-pal .pt{font-size:12.5px;color:var(--card-text);font-weight:300;line-height:1.4;text-wrap:pretty}
.za-styles{display:flex;gap:7px;flex-wrap:wrap}
.za-chip{font-size:12px;font-weight:500;color:var(--card-text);background:var(--panel);border:1px solid var(--line);border-radius:30px;padding:6px 12px}

.za-res-desc{font-size:14px;line-height:1.72;color:var(--card-text);font-weight:300;margin-top:18px;text-wrap:pretty}
.za-affirm{position:relative;margin-top:18px;padding:16px 18px 16px 22px;border-radius:18px;overflow:hidden;
  background:linear-gradient(135deg,color-mix(in srgb,var(--za-glow) 18%,var(--card-bg)),var(--card-bg))}
.za-affirm::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--za-accent)}
.za-affirm .l{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--card-muted);margin-bottom:6px}
.za-affirm .q-x{display:none}

.za-actions{margin-top:22px;display:flex;flex-direction:column;gap:10px}
.za-actions .row{display:flex;gap:10px}
.za-btn{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;border-radius:26px;width:100%;
  font-family:var(--sans);font-size:15px;font-weight:600;letter-spacing:.01em;cursor:pointer;border:1px solid transparent;
  transition:transform .2s ease,filter .2s ease,border-color .2s ease}
.za-btn:active{transform:scale(.97)}
.za-btn.primary{color:#fff;background:var(--za-accent);box-shadow:0 16px 36px -14px var(--za-glow)}
.za-btn.primary:hover{filter:brightness(1.05)}
.za-btn.ghost{flex:1;background:var(--panel);border-color:var(--line);color:var(--ink)}
.za-btn.ghost.on{border-color:var(--za-accent);color:var(--za-accent)}
.za-btn.text{background:none;color:var(--muted);height:44px;font-weight:500}
.za-disc{margin-top:14px;font-size:10.5px;line-height:1.6;color:var(--faint);font-weight:300;text-align:center;text-wrap:pretty}

@media (prefers-reduced-motion:reduce){
  .za-skel{animation:none!important}
  .za-card{transition:none}
}
