/* ===================== Матрица Судьбы · «Ночной люкс» ===================== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Manrope:wght@200;300;400;500;600;700&display=swap');

:root{
  --bg:#080b22;
  --bg2:#0c1130;
  --ink:#eceaff;
  --muted:#9aa0cc;
  --muted-2:#6f76a3;
  --gold:#e9c884;
  --gold-2:#f5dca0;
  --gold-deep:#b88a3c;
  --line:rgba(233,200,132,.16);
  --line-cool:rgba(150,165,235,.12);
  --card:rgba(255,255,255,.028);
  --card-hover:rgba(255,255,255,.05);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;
  --r:18px;
  --maxw:760px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);font-weight:300;color:var(--ink);line-height:1.72;
  background:
    radial-gradient(1100px 620px at 50% -8%, #1b2150 0%, transparent 62%),
    radial-gradient(900px 700px at 88% 12%, #221a47 0%, transparent 60%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg2) 60%,#080a1e 100%);
  background-attachment:fixed;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  letter-spacing:.1px;
}
::selection{background:var(--gold);color:#10122c}

/* анимированное звёздное небо (canvas, рисуется в assets/sky.js) */
.sky{position:fixed;inset:0;z-index:0;pointer-events:none;display:block}

.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wide{max-width:1000px}

/* ---------- header ---------- */
header.top{position:relative;z-index:3;display:flex;align-items:center;justify-content:space-between;max-width:1000px;margin:0 auto;padding:30px 24px 8px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-size:22px;font-weight:500;letter-spacing:.4px}
.brand .glyph{color:var(--gold);display:grid;place-items:center;filter:drop-shadow(0 0 10px rgba(233,200,132,.4))}
.brand b{color:var(--gold);font-weight:600}
nav.tabs{display:flex;gap:4px;background:rgba(255,255,255,.04);border:1px solid var(--line-cool);padding:4px;border-radius:999px;backdrop-filter:blur(10px)}
nav.tabs button{font-family:var(--sans);font-size:13.5px;font-weight:500;color:var(--muted);background:none;border:0;padding:9px 18px;border-radius:999px;cursor:pointer;transition:.25s}
nav.tabs button.active{color:#15122c;background:linear-gradient(135deg,var(--gold-2),var(--gold));box-shadow:0 6px 20px -8px rgba(233,200,132,.6)}
nav.tabs button:not(.active):hover{color:var(--ink)}

section.view{display:none}
section.view.active{display:block;animation:fade .6s both}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- hero ---------- */
.hero{text-align:center;padding:54px 0 30px}
.kicker{display:inline-block;font-size:11.5px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.kicker::before,.kicker::after{content:"";display:inline-block;width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--gold));vertical-align:middle;margin:0 12px}
.kicker::after{background:linear-gradient(90deg,var(--gold),transparent)}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,7vw,68px);line-height:1.04;margin:0 0 18px;letter-spacing:.5px}
.hero h1 em{font-style:italic;color:var(--gold-2)}
.hero p.lead{color:var(--muted);max-width:540px;margin:0 auto;font-size:16.5px;font-weight:300}

/* ---------- date form ---------- */
.calc-form{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:flex-end;margin:38px auto 0;max-width:560px}
.field{display:flex;flex-direction:column;gap:8px;text-align:left}
.field label{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);padding-left:3px}
.field input,.field select{
  font-family:var(--sans);font-weight:400;font-size:16px;color:var(--ink);
  background:rgba(10,12,34,.6);border:1px solid var(--line-cool);border-radius:13px;
  padding:14px 16px;min-width:92px;outline:none;transition:.25s;
}
.field.year input{min-width:120px}.field.month select{min-width:150px}
.field input::placeholder{color:var(--muted-2)}
.field input:focus,.field select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(233,200,132,.12)}
.field select{appearance:none;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 19px) center,calc(100% - 14px) center;background-size:5px 5px;background-repeat:no-repeat;padding-right:38px}
.btn{
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.2px;color:#15122c;cursor:pointer;border:0;
  background:linear-gradient(135deg,var(--gold-2),var(--gold));padding:15px 30px;border-radius:13px;
  box-shadow:0 12px 34px -12px rgba(233,200,132,.65);transition:.25s;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(233,200,132,.8)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--gold);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:rgba(233,200,132,.07);transform:none}
.btn.lg{padding:17px 40px;font-size:16px}
.trust{text-align:center;color:var(--muted-2);font-size:12.5px;margin-top:18px;letter-spacing:.02em}

/* ---------- result ---------- */
.result{display:none;margin-top:20px}
.result.show{display:block}
.sep{width:100%;max-width:200px;height:1px;margin:64px auto;background:linear-gradient(90deg,transparent,var(--line),transparent);position:relative}
.sep::after{content:"✦";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg2);padding:0 14px;color:var(--gold);font-size:12px}

.eyebrow{text-align:center;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin:0 0 8px}
.sec-title{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4.5vw,40px);text-align:center;margin:0 0 8px;letter-spacing:.4px}
.sec-sub{text-align:center;color:var(--muted);max-width:480px;margin:0 auto 30px;font-size:15px}

/* central arcana — focal */
.core{text-align:center;animation:fade .7s both}
.core .who{color:var(--muted-2);font-size:13px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:26px}
.medallion{position:relative;width:172px;height:172px;margin:0 auto 24px;display:grid;place-items:center}
.medallion .ring1,.medallion .ring2{position:absolute;inset:0;border-radius:50%;border:1px solid var(--line)}
.medallion .ring2{inset:14px;border-color:rgba(233,200,132,.28)}
.medallion .disc{width:118px;height:118px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 38%,#fbeec4,#e9c884 55%,#b3852f);
  box-shadow:0 18px 50px -14px rgba(233,200,132,.55),inset 0 -8px 22px rgba(120,80,20,.4);
  font-family:var(--serif);font-weight:600;font-size:60px;color:#241606;line-height:1}
.medallion .spark{position:absolute;inset:-12px;border-radius:50%;background:radial-gradient(circle,rgba(233,200,132,.35),transparent 62%);filter:blur(6px);z-index:-1;animation:pulse 4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.55;transform:scale(1)}50%{opacity:.9;transform:scale(1.06)}}
.core h2{font-family:var(--serif);font-weight:500;font-size:clamp(34px,6vw,52px);margin:0;letter-spacing:.5px}
.core .tarot{color:var(--muted-2);font-size:12.5px;letter-spacing:.16em;margin-top:4px}
.core .kw{color:var(--gold);font-size:15px;margin-top:14px;font-weight:500}
.core .ess{color:#d6d3f2;max-width:560px;margin:18px auto 0;font-size:16px;line-height:1.78;font-weight:300}

/* octagram block */
.octa-wrap{margin-top:10px;text-align:center}
.octagram{width:100%;max-width:440px;height:auto;display:block;margin:8px auto 4px;overflow:visible}
.oct-ring{fill:none;stroke:var(--line-cool);stroke-width:1}
.oct-ring.faint{stroke:rgba(150,165,235,.06)}
.oct-line{stroke:rgba(233,200,132,.22);stroke-width:1}
.oct-line.spoke{stroke:rgba(150,165,235,.10)}
.oct-node{cursor:pointer;outline:none}
.node-circle{fill:rgba(18,20,46,.9);stroke:var(--gold);stroke-opacity:.45;stroke-width:1.2;transition:.22s}
.node-halo{fill:url(#coreGrad);opacity:.18;filter:url(#soft)}
.oct-node.main .node-circle{fill:url(#coreGrad);stroke:var(--gold-2);stroke-opacity:.9;stroke-width:1.5}
.node-num{fill:var(--gold-2);font-family:var(--serif);font-weight:600;font-size:25px;text-anchor:middle;dominant-baseline:central}
.oct-node.main .node-num{fill:#241606;font-size:36px}
.oct-node:hover .node-circle,.oct-node:focus .node-circle,.oct-node.active .node-circle{stroke-opacity:1;stroke-width:1.8;filter:drop-shadow(0 0 8px rgba(233,200,132,.6))}
.oct-node.active .node-circle{stroke:var(--gold-2)}
.octa-cap{color:var(--muted-2);font-size:12.5px;margin-top:6px}

/* small reading popover under octagram */
.reading{max-width:560px;margin:18px auto 0;background:var(--card);border:1px solid var(--line-cool);border-radius:var(--r);padding:18px 22px;text-align:left;display:none}
.reading.show{display:block;animation:fade .4s both}
.reading .rh{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.reading .rn{width:40px;height:40px;border-radius:11px;flex:none;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:20px;color:#241606;background:radial-gradient(circle at 50% 38%,#fbeec4,#e9c884 60%,#b3852f)}
.reading .rt{font-family:var(--serif);font-size:21px;line-height:1.1}
.reading .rt small{display:block;font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-top:3px}
.reading p{margin:8px 0 0;font-size:14.5px;color:#d2cff0}
.reading .meaning{color:var(--muted);font-size:13.5px;border-left:2px solid var(--line);padding-left:12px;margin-top:10px}

/* free cards (3 карты) */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
@media(max-width:640px){.cards3{grid-template-columns:1fr}}
.fcard{background:var(--card);border:1px solid var(--line-cool);border-radius:var(--r);padding:22px 20px;transition:.25s;text-align:center}
.fcard:hover{background:var(--card-hover);border-color:var(--line)}
.fcard .fnum{font-family:var(--serif);font-size:34px;color:var(--gold-2);line-height:1}
.fcard .flabel{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);margin-top:10px}
.fcard .fname{font-family:var(--serif);font-size:21px;margin-top:2px}
.fcard .ftext{color:var(--muted);font-size:13.5px;margin-top:10px;line-height:1.6}

/* ---------- paywall ---------- */
.paywall{position:relative;margin-top:8px;border-radius:24px;overflow:hidden;border:1px solid var(--line);background:linear-gradient(180deg,rgba(233,200,132,.05),rgba(255,255,255,.02))}
.paywall .blurred{position:absolute;inset:0;z-index:0;filter:blur(7px);opacity:.5;pointer-events:none;padding:26px;display:grid;grid-template-columns:1fr 1fr;gap:12px;mask-image:linear-gradient(180deg,#000 0%,#000 30%,transparent 92%)}
.paywall .blurred .bb{background:rgba(255,255,255,.06);border-radius:14px;height:78px}
.paywall .pcontent{position:relative;z-index:1;padding:46px 34px;text-align:center}
.pw-lock{width:56px;height:56px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;background:radial-gradient(circle at 50% 38%,#fbeec4,#e9c884 60%,#b3852f);box-shadow:0 12px 34px -10px rgba(233,200,132,.6)}
.paywall h3{font-family:var(--serif);font-weight:500;font-size:clamp(26px,4vw,34px);margin:0 0 8px;letter-spacing:.4px}
.paywall .psub{color:var(--muted);max-width:440px;margin:0 auto 22px;font-size:15px}
.pw-list{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;max-width:520px;margin:0 auto 28px;text-align:left}
@media(max-width:560px){.pw-list{grid-template-columns:1fr}.paywall .pcontent{padding:40px 22px}}
.pw-list li{list-style:none;display:flex;align-items:flex-start;gap:10px;color:#d6d3f2;font-size:14px}
.pw-list li::before{content:"✦";color:var(--gold);font-size:11px;margin-top:4px;flex:none}
.pw-price{color:var(--muted-2);font-size:13px;margin-top:16px}
.pw-price b{color:var(--gold-2);font-family:var(--serif);font-size:22px;font-weight:600}

/* premium revealed sections */
.premium{display:none}
.premium.show{display:block;animation:fade .6s both}
.unlocked-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);border:1px solid var(--line);border-radius:999px;padding:7px 16px;margin:0 auto 6px}

/* zone grid (premium) */
.zgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:13px;margin-top:6px}
.zone{background:var(--card);border:1px solid var(--line-cool);border-radius:16px;padding:18px;cursor:pointer;transition:.25s}
.zone:hover{background:var(--card-hover);border-color:var(--gold);transform:translateY(-2px)}
.zone .zhead{display:flex;align-items:center;gap:13px}
.zone .znum{width:46px;height:46px;border-radius:13px;flex:none;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:22px;color:#241606;background:radial-gradient(circle at 50% 38%,#fbeec4,#e9c884 60%,#b3852f)}
.zone .zlabel{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.zone .zname{font-family:var(--serif);font-size:20px;line-height:1.1;margin-top:1px}
.zone .zkw{color:var(--muted);font-size:13px;margin-top:11px}

.purpose{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-top:6px}
@media(max-width:640px){.purpose{grid-template-columns:1fr}}
.purpose .zone{text-align:center}.purpose .zhead{flex-direction:column;gap:10px}

/* chakras */
.chakras{display:grid;gap:8px;margin-top:6px}
.chakra{display:flex;align-items:center;gap:15px;background:var(--card);border:1px solid var(--line-cool);border-radius:14px;padding:12px 18px;cursor:pointer;transition:.22s}
.chakra:hover{background:var(--card-hover);border-color:var(--gold)}
.chakra .cdot{width:13px;height:13px;border-radius:50%;flex:none}
.chakra .cn{font-family:var(--serif);font-size:17px;min-width:150px}
.chakra .cn small{display:block;color:var(--muted-2);font-family:var(--sans);font-size:11px;letter-spacing:.04em}
.chakra .cz{color:var(--muted);font-size:13px;flex:1}
.chakra .cv{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--gold-2);width:34px;text-align:center;flex:none}
.chakra .ca{color:var(--muted);font-size:13px;min-width:104px;text-align:right;font-family:var(--serif);font-size:16px}
@media(max-width:600px){.chakra .cz,.chakra .ca{display:none}.chakra .cn{min-width:0;flex:1}}

/* ---------- эмблемы арканов ---------- */
.arc-art{display:block}
.arc-art .glyph{filter:drop-shadow(0 0 5px currentColor)}
.arc-art-roman{fill:currentColor;stroke:none;font-family:var(--serif);font-size:9px;opacity:.65;letter-spacing:.04em}

/* герой: большая эмблема главного аркана + бейдж-номер */
.hero-arcana{position:relative;width:230px;height:230px;margin:6px auto 22px;display:grid;place-items:center;animation:floaty 7s ease-in-out infinite}
.hero-arcana .ha-art{filter:drop-shadow(0 14px 40px rgba(233,200,132,.28))}
.hero-arcana .ha-spark{position:absolute;width:170px;height:170px;border-radius:50%;background:radial-gradient(circle,currentColor,transparent 62%);opacity:.16;filter:blur(14px);animation:pulse 5s ease-in-out infinite}
.hero-arcana .ha-num{position:absolute;right:18px;bottom:16px;min-width:46px;height:46px;padding:0 6px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:26px;color:#241606;
  background:radial-gradient(circle at 50% 38%,#fbeec4,#e9c884 60%,#b3852f);box-shadow:0 10px 26px -8px rgba(233,200,132,.7)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ---------- коды судьбы ---------- */
.code-card{background:var(--card);border:1px solid var(--line-cool);border-radius:20px;padding:22px;margin-top:14px;transition:.25s}
.code-card:hover{border-color:var(--line)}
.code-card.solo{max-width:600px;margin:0 auto;text-align:center}
.code-emblems{display:flex;align-items:flex-start;justify-content:center;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.code-em{background:none;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;transition:.2s;width:92px}
.code-em:hover{transform:translateY(-3px)}
.code-em .ce-num{font-family:var(--serif);font-size:16px;color:var(--gold-2);margin-top:2px}
.code-em .ce-nm{font-size:11px;color:var(--muted);line-height:1.1;text-align:center}
.code-sep{color:var(--gold);opacity:.5;font-size:18px;align-self:center;margin-top:24px}
.code-title{font-family:var(--serif);font-size:22px;text-align:center;letter-spacing:.3px}
.code-seq{text-align:center;color:var(--gold);font-size:12px;letter-spacing:.16em;margin-top:4px}
.code-meaning{color:var(--muted);font-size:14px;text-align:center;max-width:520px;margin:10px auto 0;line-height:1.65}

/* возраст-тизер (бесплатно) */
.age-teaser{display:flex;align-items:center;gap:18px;max-width:560px;margin:18px auto 0;
  background:linear-gradient(135deg,rgba(233,200,132,.08),var(--card));border:1px solid var(--line);border-radius:20px;padding:18px 22px;cursor:pointer;transition:.25s;text-align:left}
.age-teaser:hover{transform:translateY(-2px);border-color:var(--gold)}
.age-teaser .age-em{flex:none;filter:drop-shadow(0 0 8px currentColor)}
.age-teaser .age-lab{color:var(--muted);font-size:13px}
.age-teaser .age-big{font-family:var(--serif);font-size:24px;margin:2px 0 4px}
.age-teaser .age-hint{color:var(--gold);font-size:12px}
@media(max-width:520px){.age-teaser{flex-direction:column;text-align:center}}

/* возрастная линия (премиум) */
.ageline{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:11px;margin-top:6px}
.age-node{background:var(--card);border:1px solid var(--line-cool);border-radius:15px;padding:14px 8px;cursor:pointer;transition:.22s;
  display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--gold);font-family:var(--sans)}
.age-node:hover{background:var(--card-hover);border-color:var(--gold);transform:translateY(-3px)}
.age-node.cur{border-color:var(--gold);background:linear-gradient(135deg,rgba(233,200,132,.12),transparent);box-shadow:0 0 0 1px var(--gold) inset}
.age-node .age-yr{font-size:13px;color:var(--ink);font-weight:600}.age-node .age-yr small{color:var(--muted-2);font-weight:400}
.age-node .age-em{filter:drop-shadow(0 0 5px currentColor)}
.age-node .age-nm{font-size:12px;color:var(--muted);text-align:center;line-height:1.2;font-family:var(--serif)}

/* эмблема в модалке и карточках библиотеки */
.m-emblem{text-align:center;margin:-6px 0 4px}
.m-emblem .arc-art{margin:0 auto}
.arc-card-em{color:inherit;margin:0 auto 6px;width:76px}
.arc-card .arc-card-em .arc-art{margin:0 auto}

/* ---------- library ---------- */
.lib-search{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:34px 0 30px}
.lib-search input{font-family:var(--sans);font-size:15px;color:var(--ink);background:rgba(10,12,34,.6);border:1px solid var(--line-cool);border-radius:13px;padding:14px 18px;width:min(380px,82vw);outline:none}
.lib-search input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(233,200,132,.12)}
.arc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:13px}
.arc-card{background:var(--card);border:1px solid var(--line-cool);border-radius:16px;padding:22px 14px;cursor:pointer;transition:.25s;text-align:center}
.arc-card:hover{background:var(--card-hover);border-color:var(--gold);transform:translateY(-3px)}
.arc-card .acn{font-family:var(--serif);font-size:40px;color:var(--gold-2);line-height:1}
.arc-card .acname{font-family:var(--serif);font-size:19px;margin-top:6px}
.arc-card .ackw{color:var(--muted-2);font-size:11.5px;margin-top:6px;line-height:1.4}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(5,6,18,.78);backdrop-filter:blur(7px)}
.modal.show{display:flex;animation:fade .25s both}
.modal-box{background:linear-gradient(180deg,#121634,#0c0f28);border:1px solid var(--line);border-radius:24px;max-width:600px;width:100%;max-height:88vh;overflow:auto;padding:34px;position:relative;box-shadow:0 50px 120px -30px #000}
.modal-box::-webkit-scrollbar{width:7px}.modal-box::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.modal-close{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line-cool);background:rgba(0,0,0,.25);color:var(--muted);font-size:18px;cursor:pointer;transition:.2s;line-height:1}
.modal-close:hover{color:var(--ink);border-color:var(--gold)}
.m-head{display:flex;align-items:center;gap:18px;margin-bottom:4px}
.m-num{width:66px;height:66px;border-radius:17px;flex:none;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:34px;color:#241606;background:radial-gradient(circle at 50% 38%,#fbeec4,#e9c884 60%,#b3852f);box-shadow:0 14px 36px -12px rgba(233,200,132,.6)}
.m-head h2{font-family:var(--serif);font-weight:500;font-size:30px;margin:0;letter-spacing:.4px}
.m-tarot{color:var(--muted-2);font-size:12px;letter-spacing:.1em;margin-top:2px}
.m-kw{color:var(--gold);font-weight:500;font-size:13.5px;margin-top:3px}
.m-note{color:var(--gold-2);font-size:12.5px;margin-top:6px;font-style:italic}
.m-ess{font-size:15.5px;color:#e0ddf7;margin:18px 0;line-height:1.75;font-weight:300}
.pm{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0}
@media(max-width:520px){.pm{grid-template-columns:1fr}.modal-box{padding:26px 20px}}
.pm div{border-radius:13px;padding:13px 15px;font-size:13.5px;line-height:1.55}
.pm .plus{background:rgba(140,220,170,.06);border:1px solid rgba(140,220,170,.18)}
.pm .minus{background:rgba(235,140,150,.05);border:1px solid rgba(235,140,150,.16)}
.pm .ph{font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:5px}
.pm .plus .ph{color:#8fd8a8}.pm .minus .ph{color:#e69aa6}
.facets{display:grid;gap:9px;margin-top:4px}
.facet{background:var(--card);border:1px solid var(--line-cool);border-radius:13px;padding:13px 16px}
.facet .ft{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.facet .fv{font-size:14px;color:#ddd9f5;line-height:1.6}

/* locked facets inside modal */
.facets.locked{position:relative}
.facets.locked .facet{filter:blur(4px);opacity:.6;user-select:none}
.locked-cta{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:linear-gradient(180deg,transparent,rgba(12,15,40,.85) 40%);border-radius:13px}
.locked-cta p{color:var(--muted);font-size:13.5px;margin:0;text-align:center;max-width:300px}

/* unlock modal */
.unlock-box{text-align:center}
.unlock-box .pw-lock{margin-bottom:20px}
.tiers{display:grid;gap:12px;margin:22px 0}
.tier{border:1px solid var(--line);border-radius:16px;padding:18px 20px;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:.2s;cursor:pointer;background:var(--card)}
.tier:hover{border-color:var(--gold);background:var(--card-hover)}
.tier.best{border-color:var(--gold);background:linear-gradient(135deg,rgba(233,200,132,.08),transparent)}
.tier .tname{font-family:var(--serif);font-size:20px}
.tier .tdesc{color:var(--muted);font-size:12.5px;margin-top:2px}
.tier .tprice{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--gold-2);white-space:nowrap}
.tier .tbadge{display:inline-block;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:#241606;background:var(--gold);border-radius:6px;padding:2px 7px;margin-left:8px;vertical-align:middle}
/* донат-карточка Monobank */
.donate-card{border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,rgba(233,200,132,.08),transparent);padding:22px;margin:22px 0 6px;text-align:center}
.donate-amount{font-family:var(--serif);font-weight:600;font-size:30px;color:var(--gold-2)}
.donate-sub{color:var(--muted);font-size:13.5px;margin:4px 0 16px;max-width:340px;margin-left:auto;margin-right:auto}
.donate-btn{display:inline-flex;align-items:center;text-decoration:none}
.promo-label{color:var(--muted);font-size:13px;margin:18px 0 8px}
.promo-fallback{margin-top:16px}
.promo-fallback summary{color:var(--muted-2);font-size:12.5px;cursor:pointer;list-style:none;text-decoration:underline;text-underline-offset:3px}
.promo-fallback summary::-webkit-details-marker{display:none}
.promo-fallback[open] summary{margin-bottom:10px;color:var(--muted)}
.promo{display:flex;gap:8px;margin-top:8px;justify-content:center}
.promo input{font-family:var(--sans);font-size:14px;color:var(--ink);background:rgba(10,12,34,.6);border:1px solid var(--line-cool);border-radius:11px;padding:12px 14px;width:190px;outline:none;text-align:center;letter-spacing:.1em}
.promo input:focus{border-color:var(--gold)}
.promo-hint{color:var(--muted-2);font-size:12px;margin-top:14px}
.promo-err{color:#e69aa6;font-size:12.5px;min-height:16px;margin-top:6px}

/* ---------- вкусные микро-анимации (только transform/opacity) ---------- */
@keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.core{animation:riseIn .7s both}
.cards3 .fcard{animation:riseIn .6s both}
.cards3 .fcard:nth-child(2){animation-delay:.09s}
.cards3 .fcard:nth-child(3){animation-delay:.18s}
.zgrid .zone,.purpose .zone{animation:riseIn .55s both}
.zgrid .zone:nth-child(2){animation-delay:.07s}
.zgrid .zone:nth-child(3){animation-delay:.14s}
.zgrid .zone:nth-child(4){animation-delay:.21s}
.purpose .zone:nth-child(2){animation-delay:.08s}
.purpose .zone:nth-child(3){animation-delay:.16s}
.chakra{animation:riseIn .5s both}
.chakra:nth-child(2){animation-delay:.05s}.chakra:nth-child(3){animation-delay:.10s}
.chakra:nth-child(4){animation-delay:.15s}.chakra:nth-child(5){animation-delay:.20s}
.chakra:nth-child(6){animation-delay:.25s}.chakra:nth-child(7){animation-delay:.30s}

/* лёгкий блик по золотым кнопкам при наведении */
.btn{position:relative;overflow:hidden}
.btn::after{content:"";position:absolute;top:0;left:-60%;width:38%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);
  transform:skewX(-18deg);opacity:0;pointer-events:none}
.btn:hover::after{animation:sheen .85s ease}
@keyframes sheen{0%{left:-60%;opacity:0}25%{opacity:.85}100%{left:130%;opacity:0}}

/* бережём слабые устройства и тех, кто отключил анимации */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .medallion .spark{animation:none}
}

/* ---------- footer ---------- */
footer{text-align:center;color:var(--muted-2);font-size:13px;padding:70px 24px 50px;position:relative;z-index:1}
footer .brand{justify-content:center;margin-bottom:10px}
footer a{color:var(--gold);text-decoration:none}
.disclaimer{max-width:600px;margin:14px auto 0;font-size:11.5px;opacity:.65;line-height:1.6}
