:root{
  --bg-0:#06040d;
  --violet:#a779ff;
  --violet-soft:#c9aaff;
  --gold:#e7c873;
  --gold-soft:#f3e4b0;
  --text:#ece6f7;
  --text-dim:#a096bd;
  --line:rgba(167,121,255,.18);
  --radius:18px;
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-sans:'Manrope',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-sans);
  color:var(--text);
  background:
    radial-gradient(1300px 650px at 50% -12%, #341f63 0%, transparent 60%),
    radial-gradient(1000px 560px at 50% 112%, #1d1140 0%, transparent 55%),
    var(--bg-0);
  min-height:100vh;overflow-x:hidden;position:relative;
}

/* ================= ФОН ================= */
.stars,.shooting,.cards-bg,.fog,.vignette{position:fixed;inset:0;z-index:0;pointer-events:none}

.star{position:absolute;border-radius:50%;background:#fff;
  animation:twinkle var(--dur,4s) ease-in-out infinite;opacity:var(--op,.6)}
@keyframes twinkle{0%,100%{opacity:.12;transform:scale(.7)}50%{opacity:1;transform:scale(1.25)}}

/* падающие звёзды */
.shoot{position:absolute;width:120px;height:1.5px;
  background:linear-gradient(90deg,#fff,rgba(255,255,255,0));
  filter:drop-shadow(0 0 6px #fff);opacity:0;transform:rotate(18deg);
  animation:shoot 1.1s ease-out forwards}
@keyframes shoot{0%{opacity:0;transform:translate(0,0) rotate(18deg) scaleX(.2)}
  10%{opacity:1}100%{opacity:0;transform:translate(380px,120px) rotate(18deg) scaleX(1)}}

/* парящие карты Таро в фоне */
.tcard{position:absolute;width:54px;height:88px;border-radius:7px;
  background:linear-gradient(160deg,rgba(58,42,94,.5),rgba(20,13,40,.5));
  border:1px solid rgba(231,200,115,.28);opacity:.16;
  display:grid;place-items:center;font-size:22px;
  box-shadow:0 8px 30px rgba(0,0,0,.4),inset 0 0 14px rgba(167,121,255,.2);
  animation:cardFloat var(--cdur,22s) ease-in-out infinite;animation-delay:var(--cdelay,0s)}
@keyframes cardFloat{0%,100%{transform:translateY(0) rotate(var(--crot,-8deg))}
  50%{transform:translateY(-26px) rotate(calc(var(--crot,-8deg) * -1))}}

.fog{background:radial-gradient(650px 340px at 50% 58%, rgba(167,121,255,.12), transparent 70%);
  animation:fogPulse 9s ease-in-out infinite}
@keyframes fogPulse{0%,100%{opacity:.55}50%{opacity:1}}

.vignette{background:radial-gradient(120% 120% at 50% 40%, transparent 55%, rgba(3,1,8,.7) 100%)}

/* ================= СЦЕНА ================= */
.scene{position:relative;z-index:1;max-width:680px;margin:0 auto;
  padding:30px 20px 36px;display:flex;flex-direction:column;align-items:center;min-height:100vh}
.scene__head{text-align:center;margin-bottom:2px}
.title{font-family:var(--font-serif);font-weight:700;
  font-size:clamp(40px,8.5vw,68px);letter-spacing:.05em;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold) 55%,#b8902f);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 46px rgba(231,200,115,.3);
  animation:titleGlow 4s ease-in-out infinite}
@keyframes titleGlow{0%,100%{filter:drop-shadow(0 0 6px rgba(231,200,115,.2))}
  50%{filter:drop-shadow(0 0 18px rgba(231,200,115,.45))}}
.subtitle{font-family:var(--font-serif);font-style:italic;
  color:var(--text-dim);font-size:clamp(15px,3.6vw,20px);margin-top:0;letter-spacing:.02em}

/* ================= ПЕРСОНАЖ ================= */
.oracle{position:relative;width:min(330px,80vw);aspect-ratio:1/1;
  margin:8px 0 6px;display:grid;place-items:center;
  animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* магический круг */
.oracle__circle{position:absolute;inset:0;display:grid;place-items:center;z-index:-2}
.oracle__circle svg{width:108%;height:108%;overflow:visible}
.ring{fill:none;stroke:rgba(231,200,115,.32)}
.ring--out{stroke-width:1;stroke-dasharray:2 9;transform-origin:200px 200px;animation:spin 40s linear infinite}
.ring--mid{stroke:rgba(167,121,255,.4);stroke-width:1.2;stroke-dasharray:30 14;transform-origin:200px 200px;animation:spin 26s linear infinite reverse}
.ring--in{stroke:rgba(231,200,115,.25);stroke-width:1;transform-origin:200px 200px;animation:spin 60s linear infinite}
.ring__glyphs text{fill:rgba(201,170,255,.55);font-family:var(--font-serif);font-size:20px;
  filter:drop-shadow(0 0 5px rgba(167,121,255,.6))}
.oracle__circle{animation:circlePulse 5s ease-in-out infinite}
@keyframes circlePulse{0%,100%{opacity:.55}50%{opacity:.95}}
@keyframes spin{to{transform:rotate(360deg)}}

.oracle__aura{position:absolute;inset:6% 8% 4% 8%;z-index:-1;
  background:radial-gradient(closest-side, rgba(167,121,255,.4), transparent 72%);
  filter:blur(10px);animation:auraPulse 5s ease-in-out infinite}
@keyframes auraPulse{0%,100%{opacity:.5;transform:scale(.95)}50%{opacity:.95;transform:scale(1.05)}}

.oracle__fig{width:84%;height:84%;overflow:visible}

.eye{fill:var(--violet-soft);
  filter:drop-shadow(0 0 6px var(--violet)) drop-shadow(0 0 15px var(--violet));
  transform-box:fill-box;transform-origin:center;animation:blink 5.5s ease-in-out infinite}
@keyframes blink{0%,46%,54%,100%{transform:scaleY(1)}50%{transform:scaleY(.1)}}

.oracle__orb{filter:drop-shadow(0 0 18px rgba(167,121,255,.75));animation:orbGlow 4s ease-in-out infinite}
@keyframes orbGlow{0%,100%{filter:drop-shadow(0 0 14px rgba(167,121,255,.6))}50%{filter:drop-shadow(0 0 26px rgba(167,121,255,.95))}}
.oracle__orb-shine{animation:shineMove 6s ease-in-out infinite}
@keyframes shineMove{0%,100%{transform:translate(0,0)}50%{transform:translate(4px,3px)}}
.oracle__orb-ring{stroke:rgba(231,200,115,.6);stroke-width:2;
  stroke-dasharray:2 10;animation:orbRing 4s linear infinite;opacity:.6}
@keyframes orbRing{to{stroke-dashoffset:-120}}

/* пламя свечей */
.candle ellipse{transform-box:fill-box;transform-origin:center bottom;
  animation:flicker 1.6s ease-in-out infinite}
.candle--r ellipse{animation-delay:.5s}
@keyframes flicker{0%,100%{transform:scale(1) translateY(0);opacity:.95}
  50%{transform:scale(1.12,.9) translateY(-1px);opacity:1}}

/* искры */
.sparkles{position:absolute;inset:0;z-index:1;pointer-events:none}
.spark{position:absolute;width:4px;height:4px;border-radius:50%;
  background:var(--gold-soft);filter:drop-shadow(0 0 5px var(--gold));
  animation:rise var(--sdur,5s) linear infinite;animation-delay:var(--sdelay,0s);opacity:0}
@keyframes rise{0%{opacity:0;transform:translateY(20px) scale(.5)}
  20%{opacity:1}80%{opacity:.9}100%{opacity:0;transform:translateY(-70px) scale(1.1)}}

/* состояния */
.oracle[data-state="thinking"] .oracle__aura{animation-duration:1.6s}
.oracle[data-state="thinking"] .oracle__circle .ring--mid{animation-duration:6s}
.oracle[data-state="thinking"] .eye{animation:thinkEye 1.2s ease-in-out infinite}
@keyframes thinkEye{0%,100%{opacity:.6}50%{opacity:1;fill:var(--gold-soft)}}

.oracle[data-state="speaking"] .oracle__aura{animation:auraPulse 1.1s ease-in-out infinite;
  background:radial-gradient(closest-side, rgba(231,200,115,.42), transparent 72%)}
.oracle[data-state="speaking"] .eye{fill:var(--gold-soft);
  filter:drop-shadow(0 0 8px var(--gold)) drop-shadow(0 0 18px var(--gold))}
.oracle[data-state="speaking"] .oracle__orb{animation-duration:1.2s}
/* лёгкое «покачивание головой» при речи */
.oracle[data-state="speaking"] .oracle__fig{animation:talkSway 1.8s ease-in-out infinite}
@keyframes talkSway{0%,100%{transform:rotate(-0.8deg)}50%{transform:rotate(0.8deg)}}

/* ----- голосовые волны (Оракул «говорит») ----- */
.oracle__voice{position:absolute;left:50%;top:48.5%;transform:translateX(-50%);
  display:flex;gap:3.5px;align-items:center;height:22px;z-index:3;pointer-events:none;
  opacity:0;transition:opacity .35s}
.oracle[data-state="speaking"] .oracle__voice{opacity:1}
.oracle__voice span{width:3.5px;height:6px;border-radius:3px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  filter:drop-shadow(0 0 6px var(--gold));animation:voicebar .62s ease-in-out infinite}
.oracle__voice span:nth-child(2){animation-delay:.10s}
.oracle__voice span:nth-child(3){animation-delay:.20s}
.oracle__voice span:nth-child(4){animation-delay:.30s}
.oracle__voice span:nth-child(5){animation-delay:.40s}
@keyframes voicebar{0%,100%{height:5px;opacity:.6}50%{height:20px;opacity:1}}

/* ================= ЧАТ ================= */
.chat{width:100%;margin-top:12px;
  background:linear-gradient(180deg, rgba(24,16,48,.74), rgba(12,7,28,.74));
  border:1px solid var(--line);border-radius:var(--radius);backdrop-filter:blur(10px);
  box-shadow:0 24px 70px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.05);
  overflow:hidden;display:flex;flex-direction:column}
.chat__log{display:flex;flex-direction:column;gap:12px;padding:18px;
  max-height:42vh;min-height:120px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--violet) transparent}
.chat__log::-webkit-scrollbar{width:6px}
.chat__log::-webkit-scrollbar-thumb{background:var(--violet);border-radius:3px}

.msg{max-width:88%;padding:12px 15px;border-radius:14px;line-height:1.58;
  font-size:15.5px;white-space:pre-wrap;word-wrap:break-word;animation:msgIn .35s ease both}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg--oracle{align-self:flex-start;
  background:linear-gradient(180deg, rgba(64,46,104,.55), rgba(32,22,58,.55));
  border:1px solid var(--line);border-top-left-radius:4px}
.msg--user{align-self:flex-end;
  background:linear-gradient(180deg, rgba(231,200,115,.18), rgba(231,200,115,.08));
  border:1px solid rgba(231,200,115,.28);border-top-right-radius:4px}
.msg--error{align-self:center;color:#ff9b9b;background:rgba(120,20,30,.25);border:1px solid rgba(255,120,120,.3)}
/* акцент на вытянутых картах ⟪КАРТА⟫ */
.msg b,.msg strong{color:var(--gold-soft);font-weight:600}

.typing{display:inline-flex;gap:5px;align-items:center;padding:4px 2px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--violet-soft);animation:dot 1.2s infinite ease-in-out}
.typing span:nth-child(2){animation-delay:.18s}
.typing span:nth-child(3){animation-delay:.36s}
@keyframes dot{0%,80%,100%{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}

.chat__suggest{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 12px}
.chip{font-family:var(--font-sans);font-size:13.5px;color:var(--violet-soft);
  background:rgba(167,121,255,.08);border:1px solid var(--line);
  padding:7px 13px;border-radius:999px;cursor:pointer;transition:.2s}
.chip:hover{background:rgba(167,121,255,.22);color:#fff;transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(167,121,255,.25)}

.chat__form{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--line)}
.chat__input{flex:1;background:rgba(6,4,13,.6);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;color:var(--text);font-size:15.5px;font-family:var(--font-sans);outline:none;transition:.2s}
.chat__input:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(167,121,255,.15)}
.chat__input::placeholder{color:var(--text-dim)}
.chat__send{flex:none;width:48px;height:48px;border:none;border-radius:12px;cursor:pointer;
  color:#160f2e;display:grid;place-items:center;transition:.2s;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));box-shadow:0 6px 18px rgba(231,200,115,.3)}
.chat__send:hover{transform:translateY(-1px);filter:brightness(1.08)}
.chat__send:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ================= КАБИНЕТ (правый верх) ================= */
.account{position:fixed;top:14px;right:16px;z-index:30;display:flex;gap:8px;align-items:center}
.acc-btn{font-family:var(--font-sans);font-size:13.5px;color:var(--violet-soft);
  background:rgba(20,13,40,.7);border:1px solid var(--line);backdrop-filter:blur(8px);
  padding:8px 14px;border-radius:999px;cursor:pointer;transition:.2s;display:inline-flex;gap:7px;align-items:center}
.acc-btn:hover{background:rgba(167,121,255,.2);color:#fff;transform:translateY(-1px)}
.acc-btn--gold{color:#160f2e;background:linear-gradient(180deg,var(--gold-soft),var(--gold));border-color:transparent;font-weight:600}
.acc-panel{position:absolute;top:46px;right:0;min-width:230px;
  background:linear-gradient(180deg, rgba(28,19,54,.96), rgba(14,9,30,.96));
  border:1px solid var(--line);border-radius:14px;padding:16px;
  box-shadow:0 18px 50px rgba(0,0,0,.6);animation:msgIn .2s ease both}
.acc-panel__login{font-weight:600;color:#fff;word-break:break-all;margin-bottom:4px}
.acc-panel__sub{font-size:13px;color:var(--text-dim);margin-bottom:12px}
.acc-panel__sub b{color:var(--gold-soft)}
.acc-panel__logout{width:100%;font-size:13.5px;color:var(--violet-soft);
  background:rgba(167,121,255,.1);border:1px solid var(--line);padding:9px;border-radius:10px;cursor:pointer;transition:.2s}
.acc-panel__logout:hover{background:rgba(255,120,120,.15);color:#ffb3b3}
.badge-pro{font-size:11px;background:rgba(231,200,115,.18);color:var(--gold-soft);
  border:1px solid rgba(231,200,115,.3);padding:2px 8px;border-radius:999px}

/* ================= УВЕДОМЛЕНИЕ В ЧАТЕ ================= */
.notice{align-self:stretch;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg, rgba(231,200,115,.14), rgba(231,200,115,.05));
  border:1px solid rgba(231,200,115,.3);border-radius:14px;padding:13px 15px;animation:msgIn .35s ease both}
.notice__txt{font-size:14px;color:var(--gold-soft);flex:1;min-width:160px}
.notice__btn{font-size:13.5px;font-weight:600;color:#160f2e;border:none;cursor:pointer;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));padding:9px 16px;border-radius:999px;transition:.2s}
.notice__btn:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* ================= МОДАЛКА ================= */
.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:18px}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(4,2,10,.72);backdrop-filter:blur(6px);animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal__card{position:relative;width:min(420px,100%);
  background:linear-gradient(180deg, rgba(30,21,58,.98), rgba(13,8,28,.98));
  border:1px solid var(--line);border-radius:22px;padding:30px 26px 26px;text-align:center;
  box-shadow:0 30px 90px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05), 0 0 60px rgba(167,121,255,.18);
  animation:pop .3s cubic-bezier(.2,.9,.3,1.2) both}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
.modal__x{position:absolute;top:12px;right:14px;width:34px;height:34px;border:none;cursor:pointer;
  background:rgba(167,121,255,.1);color:var(--violet-soft);border-radius:50%;font-size:22px;line-height:1;transition:.2s}
.modal__x:hover{background:rgba(167,121,255,.25);color:#fff}
.modal__icon{font-size:42px;margin-bottom:8px;filter:drop-shadow(0 0 16px rgba(167,121,255,.6))}
.modal__title{font-family:var(--font-serif);font-weight:700;font-size:28px;color:#fff;margin-bottom:6px;letter-spacing:.02em}
.modal__lead{color:var(--text-dim);font-size:14.5px;line-height:1.5;margin-bottom:16px}
.modal__hint{color:var(--text-dim);font-size:12px;margin:12px 0;opacity:.8}
.modal__alt{margin-top:14px;font-size:13.5px;color:var(--text-dim)}
.modal__alt a{color:var(--violet-soft);text-decoration:none;border-bottom:1px dashed rgba(167,121,255,.5)}
.modal__alt a:hover{color:#fff}

.price{display:flex;align-items:baseline;justify-content:center;gap:6px;margin:6px 0 14px}
.price__num{font-family:var(--font-serif);font-weight:700;font-size:52px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.price__per{color:var(--text-dim);font-size:16px}

.benefits{list-style:none;text-align:left;margin:0 auto 20px;max-width:280px;display:flex;flex-direction:column;gap:9px}
.benefits li{color:var(--text);font-size:14.5px}

.pay-sum{color:var(--text);font-size:16px;margin-bottom:14px}
.pay-sum b{color:var(--gold-soft)}
.pay-card{background:linear-gradient(135deg,#3a2a6e,#1c1340);border:1px solid var(--line);
  border-radius:16px;padding:18px;text-align:left;margin:0 auto 6px;max-width:300px;box-shadow:0 12px 30px rgba(0,0,0,.4)}
.pay-card__chip{width:38px;height:28px;border-radius:6px;background:linear-gradient(135deg,var(--gold-soft),var(--gold));margin-bottom:18px}
.pay-card__num{font-family:var(--font-sans);letter-spacing:2px;color:#fff;font-size:17px;margin-bottom:12px}
.pay-card__row{display:flex;justify-content:space-between;color:var(--violet-soft);font-size:13px}

.btn{width:100%;border:none;cursor:pointer;font-family:var(--font-sans);font-weight:600;font-size:16px;
  padding:14px;border-radius:13px;transition:.2s}
.btn--gold{color:#160f2e;background:linear-gradient(180deg,var(--gold-soft),var(--gold));box-shadow:0 8px 24px rgba(231,200,115,.3)}
.btn--gold:hover{transform:translateY(-1px);filter:brightness(1.07)}
.btn:disabled{opacity:.6;cursor:wait;transform:none}

.auth-form{display:flex;flex-direction:column;gap:11px;text-align:left}
.field{background:rgba(6,4,13,.6);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;color:var(--text);font-size:15.5px;font-family:var(--font-sans);outline:none;transition:.2s}
.field:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(167,121,255,.15)}
.field::placeholder{color:var(--text-dim)}
.form-err{color:#ff9b9b;font-size:13px;min-height:0;margin:-2px 2px}
.form-err:not(:empty){min-height:18px}

/* ================= ПАНЕЛЬ ИНСТРУМЕНТОВ ЧАТА ================= */
.chat__tools{display:flex;align-items:center;gap:10px;padding:0 16px 12px;flex-wrap:wrap}
.spreads{display:flex;gap:6px;flex-wrap:wrap;flex:1}
.spread{font-family:var(--font-sans);font-size:12.5px;color:var(--text-dim);
  background:rgba(167,121,255,.06);border:1px solid var(--line);
  padding:6px 11px;border-radius:999px;cursor:pointer;transition:.2s}
.spread:hover{color:#fff;background:rgba(167,121,255,.16)}
.spread.is-active{color:#160f2e;background:linear-gradient(180deg,var(--violet-soft),var(--violet));border-color:transparent;font-weight:600}
.tts-btn{flex:none;width:38px;height:38px;border-radius:10px;cursor:pointer;font-size:17px;
  background:rgba(167,121,255,.08);border:1px solid var(--line);transition:.2s}
.tts-btn:hover{background:rgba(167,121,255,.2)}
.tts-btn[aria-pressed="true"]{background:linear-gradient(180deg,var(--gold-soft),var(--gold));border-color:transparent}

/* ================= КАРТЫ ТАРО (раздача) ================= */
.taro-deal{align-self:flex-start;display:flex;gap:12px;flex-wrap:wrap;margin:4px 0 6px;perspective:1100px}
.taro-card{width:92px;height:148px;border-radius:12px;position:relative;
  transform-style:preserve-3d;transition:transform .8s cubic-bezier(.2,.8,.3,1.05);
  transform:rotateY(0) translateY(16px);opacity:0;animation:cardIn .45s ease forwards}
@keyframes cardIn{to{opacity:1;transform:rotateY(0) translateY(0)}}
.taro-card.flipped{transform:rotateY(180deg) translateY(0)}
.taro-card__face{position:absolute;inset:0;border-radius:12px;backface-visibility:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;text-align:center;
  box-shadow:0 10px 26px rgba(0,0,0,.5)}

/* рубашка */
.taro-card__back{background:
    repeating-linear-gradient(45deg, rgba(231,200,115,.14) 0 7px, transparent 7px 14px),
    radial-gradient(circle at 50% 38%, #4a3680, #1c1340 75%);
  border:1.5px solid rgba(231,200,115,.5)}
.taro-card__back::after{content:"✶";font-size:34px;color:rgba(231,200,115,.85);
  filter:drop-shadow(0 0 10px rgba(231,200,115,.6))}

/* лицо */
.taro-card__front{transform:rotateY(180deg);
  background:radial-gradient(circle at 50% 30%, #2c2052, #130d28 80%);
  border:1.5px solid var(--gold);
  box-shadow:0 10px 26px rgba(0,0,0,.5), inset 0 0 0 3px rgba(231,200,115,.18), inset 0 0 22px rgba(167,121,255,.25)}
.taro-card__num{position:absolute;top:5px;left:0;right:0;font-family:var(--font-serif);
  font-weight:700;font-size:12px;letter-spacing:1px;color:var(--gold-soft);opacity:.95}
.taro-card__sym{font-size:40px;line-height:1;filter:drop-shadow(0 0 10px rgba(167,121,255,.8));margin:6px 0 7px}
.taro-card__name{font-family:var(--font-serif);font-weight:700;font-size:13px;line-height:1.12;
  color:var(--gold-soft);padding:0 2px;text-shadow:0 0 8px rgba(231,200,115,.25)}
.taro-card__rev{font-size:9.5px;margin-top:5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}
.taro-card__rev.is-rev{color:#ff9bb0}
.taro-card.reversed .taro-card__sym{transform:rotate(180deg)}

@media (max-width:480px){
  .scene{padding:18px 14px 26px}.chat__log{max-height:38vh}.oracle{width:78vw}
  .account{top:10px;right:10px}.modal__card{padding:26px 20px 22px}
  .modal__title{font-size:24px}.price__num{font-size:44px}
}
/* ================= ЮРИДИЧЕСКИЕ СТРАНИЦЫ ================= */
.legal{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:40px 22px 60px;line-height:1.65}
.legal__back{display:inline-block;margin-bottom:18px;color:var(--violet-soft);text-decoration:none;font-size:14px}
.legal__back:hover{color:#fff}
.legal h1{font-family:var(--font-serif);font-weight:700;font-size:clamp(26px,5vw,38px);color:#fff;margin-bottom:6px;line-height:1.2}
.legal h2{font-family:var(--font-serif);font-weight:600;font-size:21px;color:var(--gold-soft);margin:26px 0 8px}
.legal__upd{color:var(--text-dim);font-size:13px;margin-bottom:18px}
.legal p,.legal li{color:var(--text);font-size:15.5px}
.legal ul{margin:8px 0 8px 22px;display:flex;flex-direction:column;gap:6px}
.legal b{color:#fff}.legal em{color:var(--text-dim);font-style:italic}
.legal a{color:var(--violet-soft)}.legal a:hover{color:#fff}
.legal__foot{margin-top:34px;padding-top:18px;border-top:1px solid var(--line);font-size:14px}

/* ================= ЧЕКБОКС СОГЛАСИЯ ================= */
.consent{display:flex;gap:9px;align-items:flex-start;font-size:12.5px;color:var(--text-dim);line-height:1.45;text-align:left;cursor:pointer}
.consent input{margin-top:2px;width:16px;height:16px;flex:none;accent-color:var(--violet)}
.consent a{color:var(--violet-soft)}
.modal__foot-links{margin-top:14px;font-size:12px;color:var(--text-dim)}
.modal__foot-links a{color:var(--text-dim);text-decoration:underline}

/* ================= ФУТЕР САЙТА ================= */
.site-foot{width:100%;margin-top:22px;padding-top:18px;border-top:1px solid var(--line);text-align:center}
.site-foot__links{display:flex;gap:8px 18px;justify-content:center;flex-wrap:wrap;margin-bottom:8px}
.site-foot__links a{color:var(--violet-soft);text-decoration:none;font-size:13.5px;transition:.2s}
.site-foot__links a:hover{color:#fff}
.site-foot__org{color:var(--text-dim);font-size:12px}

/* ================= ПОЛИРОВКА ИНТЕРФЕЙСА ================= */
/* кабинет PRO — мягче и читаемее */
.acc-btn--gold{box-shadow:0 6px 20px rgba(231,200,115,.28)}
.acc-btn--gold .badge-pro{background:rgba(22,15,46,.22);color:#160f2e;border-color:rgba(22,15,46,.25);font-weight:700}
.acc-btn{box-shadow:0 4px 16px rgba(0,0,0,.3)}

/* карты — лёгкое свечение и отклик на наведение */
.taro-card{cursor:default}
.taro-card.flipped .taro-card__front{animation:cardGlow 3.4s ease-in-out infinite}
@keyframes cardGlow{0%,100%{box-shadow:0 10px 26px rgba(0,0,0,.5), inset 0 0 0 3px rgba(231,200,115,.18), inset 0 0 18px rgba(167,121,255,.22)}
  50%{box-shadow:0 12px 30px rgba(0,0,0,.55), inset 0 0 0 3px rgba(231,200,115,.32), inset 0 0 26px rgba(167,121,255,.4)}}
.taro-card:hover{filter:brightness(1.09) saturate(1.05)}

/* кнопка отправки — мягкая пульсация */
.chat__send{animation:sendPulse 3s ease-in-out infinite}
@keyframes sendPulse{0%,100%{box-shadow:0 6px 18px rgba(231,200,115,.3)}50%{box-shadow:0 6px 26px rgba(231,200,115,.55)}}

/* плавное появление сообщений чуть живее */
.msg{will-change:transform,opacity}
.msg--oracle{box-shadow:0 6px 20px rgba(0,0,0,.25)}

/* подсветка активного расклада */
.spread.is-active{box-shadow:0 4px 14px rgba(167,121,255,.4)}

/* мягкое свечение заголовка-кнопки чипов */
.chip:active,.spread:active{transform:scale(.96)}

@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important}}
