/* SNAK INK Mini App — токены и библиотека из дизайн-спеки (snak-ink-live.html) */
:root{
  --bg:#08080c; --ink:#f5f3f0; --dim:#a09ca8; --faint:#5f5c68;
  --rose:#cf2440; --amber:#d2a55e; --ice:#5cb8ff;
  --fd:'Unbounded',sans-serif; --fb:'Manrope',sans-serif; --fm:'JetBrains Mono',monospace;
  --spring:cubic-bezier(.3,1.4,.35,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--fb);overflow:hidden;-webkit-tap-highlight-color:transparent}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}

#app{position:fixed;inset:0;overflow:hidden}
.screen{position:absolute;inset:0;display:none;flex-direction:column;overflow:hidden}
.screen.on{display:flex}
.scroll{flex:1;overflow-y:auto;scrollbar-width:none;padding-bottom:120px;position:relative;z-index:5}
.scroll::-webkit-scrollbar{display:none}

/* атмосфера */
.atmo{position:absolute;inset:-6%;pointer-events:none;background:radial-gradient(90% 55% at 50% 12%,#2a2830 0%,#141218 55%,var(--bg) 85%)}
.atmo.dark{background:radial-gradient(90% 55% at 50% 10%,#17131c 0%,var(--bg) 75%)}
.glow{position:absolute;border-radius:50%;filter:blur(80px)}
.glow.wine{width:340px;height:340px;background:var(--rose);opacity:.12;top:-8%;right:-20%;animation:drift 18s ease-in-out infinite alternate}
.glow.icecap{width:280px;height:280px;background:var(--ice);opacity:.07;bottom:6%;left:-24%;animation:drift 22s ease-in-out infinite alternate-reverse}
.glow.gold{background:var(--amber)}
@keyframes drift{to{transform:translate(-40px,50px) scale(1.12)}}

/* ── слоёная 2.5D-система (из спеки, как есть) ── */
.layer{position:absolute;inset:-6%;will-change:transform}
.layer.ui{inset:0}
.figwrap{position:absolute;left:50%;transform:translateX(-50%);aspect-ratio:736/943;pointer-events:none}
.figwrap img{width:100%;height:100%;display:block;
  -webkit-mask-image:linear-gradient(180deg,#000 58%,rgba(0,0,0,.45) 78%,transparent 96%);
  mask-image:linear-gradient(180deg,#000 58%,rgba(0,0,0,.45) 78%,transparent 96%)}
.fig-back img{filter:blur(10px) brightness(.35) saturate(.7);transform:scale(1.07)}
.fig-main img{filter:brightness(.97) contrast(1.03)}
.breath{animation:breath 4.2s ease-in-out infinite;transform-origin:50% 42%;will-change:transform}
@keyframes breath{0%,100%{transform:scale(1)}50%{transform:scale(1.008)}}
.chest{position:absolute;inset:0;animation:chestbreath 4.2s ease-in-out infinite;transform-origin:50% 41%;will-change:transform}
.chest img{position:absolute;inset:0;width:100%;height:100%;
  -webkit-mask-image:radial-gradient(28% 19% at 50% 49%,#000 40%,transparent 74%)!important;
  mask-image:radial-gradient(28% 19% at 50% 49%,#000 40%,transparent 74%)!important;
  filter:brightness(.97) contrast(1.03)}
@keyframes chestbreath{0%,100%{transform:scale(1) skewY(0deg)}50%{transform:scale(1.018,1.032) skewY(.4deg) translateY(1px)}}
.rim{position:absolute;inset:0;background:radial-gradient(38% 52% at 71% 42%,rgba(92,184,255,.16),transparent 68%);mix-blend-mode:screen}
.warm{position:absolute;inset:0;background:radial-gradient(42% 40% at 26% 72%,rgba(207,36,64,.12),transparent 70%);mix-blend-mode:screen}
.glint{position:absolute;width:10px;height:10px;border-radius:50%;filter:blur(1.5px);mix-blend-mode:screen;animation:twinkle 5.5s ease-in-out infinite}
.glint.a{left:43.2%;top:18.2%;background:var(--amber)}
.glint.i{left:57.4%;top:18.8%;background:var(--ice);animation-delay:2.7s}
@keyframes twinkle{0%,86%,100%{opacity:0;transform:scale(.4)}90%{opacity:.9;transform:scale(1)}94%{opacity:.2;transform:scale(.6)}}
/* передние пряди из того же арта */
.front{pointer-events:none}
.hairclip{position:absolute;left:50%;transform:translateX(-50%);aspect-ratio:736/943;transform-origin:50% 20%;will-change:transform}
.hairclip img{width:100%;height:100%;display:block;filter:blur(2.2px) brightness(.9)}
.hc-l{animation:hsway 10s ease-in-out infinite alternate}
.hc-r{animation:hsway 13s ease-in-out infinite alternate-reverse}
.hc-l img{-webkit-mask-image:radial-gradient(24% 34% at 15% 26%,#000 42%,transparent 70%);mask-image:radial-gradient(24% 34% at 15% 26%,#000 42%,transparent 70%)}
.hc-r img{-webkit-mask-image:radial-gradient(26% 40% at 86% 30%,#000 42%,transparent 70%);mask-image:radial-gradient(26% 40% at 86% 30%,#000 42%,transparent 70%)}
@keyframes hsway{from{transform:translateX(-50%) rotate(-.5deg)}to{transform:translateX(calc(-50% + 7px)) rotate(.6deg)}}
.screen.touched .hc-l{transition:transform .9s var(--spring);transform:translateX(calc(-50% + 12px)) rotate(1.4deg)}
.screen.touched .hc-r{transition:transform .9s var(--spring);transform:translateX(calc(-50% - 12px)) rotate(-1.4deg)}

/* H0 сплэш */
.splash-ui{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:118px;z-index:5}
.wordmark{font-family:var(--fd);font-weight:900;font-size:52px;line-height:.95;letter-spacing:-1px;text-align:center;text-shadow:0 6px 40px rgba(0,0,0,.8)}
.wordmark span{color:var(--rose)}
.plat{font-family:var(--fm);font-size:9.5px;letter-spacing:.44em;color:var(--dim);margin-top:12px}
.manifest{font-family:var(--fd);font-weight:300;font-size:12.5px;letter-spacing:.08em;color:var(--dim);margin-top:20px}
.searchline{margin-top:26px;display:flex;align-items:center;gap:10px;background:rgba(10,10,14,.5);border:1px solid rgba(255,255,255,.13);border-radius:99px;padding:14px 20px;width:272px;font-family:var(--fm);font-size:13px;color:var(--dim);backdrop-filter:blur(16px)}
.searchline svg{width:15px;height:15px;color:var(--faint);flex:none}
.words{height:18px;overflow:hidden;flex:1}
.words ul{list-style:none;animation:cycle 12s steps(8) infinite}
.words li{height:18px;line-height:18px;color:var(--ink)}
.words li::after{content:"▍";color:var(--rose);animation:blink 1s infinite}
@keyframes cycle{to{transform:translateY(-144px)}}
@keyframes blink{50%{opacity:0}}
.loadline{position:absolute;left:50%;bottom:52px;transform:translateX(-50%);width:240px;height:24px;z-index:20}
.loadline path{stroke:var(--rose);stroke-width:2;fill:none;stroke-linecap:round;stroke-dasharray:260;stroke-dashoffset:260;animation:draw 2.6s cubic-bezier(.4,0,.2,1) infinite;filter:drop-shadow(0 0 6px rgba(207,36,64,.6))}
@keyframes draw{0%{stroke-dashoffset:260;opacity:0}12%{opacity:1}70%{stroke-dashoffset:0;opacity:1}100%{stroke-dashoffset:0;opacity:0}}

/* типовые блоки */
.c3top{padding:26px 24px 8px;position:relative;z-index:5}
.c3top .bk{font-family:var(--fm);font-size:10px;letter-spacing:.2em;color:var(--faint)}
.c3top h1{font-family:var(--fd);font-weight:900;font-size:34px;letter-spacing:-.5px;margin-top:12px;line-height:1.05}
.c3top h1 span{color:var(--rose)}
.c3top p{color:var(--dim);font-size:13px;line-height:1.6;margin-top:10px}
.btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:18px;border:none;border-radius:22px;background:linear-gradient(180deg,#c2203e,#8e1129);color:#fff;font-weight:700;font-size:14.5px;letter-spacing:.02em;cursor:pointer;box-shadow:0 24px 50px -14px rgba(207,36,64,.6),inset 0 1px 0 rgba(255,255,255,.18);transition:transform .3s var(--spring);font-family:var(--fb)}
.btn:active{transform:scale(.97)}
.btn.dis{opacity:.32;pointer-events:none}
.btn.ghost{background:rgba(255,255,255,.06);box-shadow:none;border:1px solid rgba(255,255,255,.12)}
.btnA{background:linear-gradient(180deg,#caa05c,#8a6528)!important;color:#160d02!important;box-shadow:0 18px 40px -12px rgba(210,165,94,.5),inset 0 1px 0 rgba(255,255,255,.3)!important}
.cta{position:absolute;left:22px;right:22px;bottom:26px;z-index:9;display:flex;gap:8px;flex-direction:column}
.flabel{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:16px 24px 8px;display:block;position:relative;z-index:5}
.input{margin:0 22px;padding:16px;border-radius:20px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);font-size:13.5px;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:5;color:var(--ink)}
.input .mono{font-family:var(--fm)}
.input .ph{color:var(--faint)}
textarea.input,input.input{width:calc(100% - 44px);display:block;outline:none;font-family:var(--fb)}
textarea.input{min-height:74px;resize:none;line-height:1.5}
input.input::placeholder,textarea.input::placeholder{color:var(--faint)}
.card2{margin:12px 22px;padding:15px 17px;border-radius:22px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);font-size:12px;color:var(--dim);line-height:1.55;position:relative;z-index:5}
.card2 b{color:var(--ink)}
.card2.gold{border-color:rgba(210,165,94,.35)}
.card2.dashed{border-style:dashed;text-align:center}
.quiet{opacity:.6}
.frow{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;color:var(--dim)}
.frow b{font-family:var(--fm);color:var(--ink);font-weight:600}
.frow.total b{color:var(--rose);font-size:15px}

/* календарь */
.month{display:flex;justify-content:space-between;align-items:center;padding:16px 24px 10px;font-family:var(--fd);font-weight:800;font-size:16px;letter-spacing:.04em;position:relative;z-index:5}
.mbtn{width:36px;height:36px;border-radius:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:15px;cursor:pointer}
.dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:0 22px;font-family:var(--fm);font-size:9px;color:var(--faint);text-align:center;position:relative;z-index:5}
.days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:6px 22px;position:relative;z-index:5}
.day{aspect-ratio:1;border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13.5px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.06);cursor:pointer}
.day.off{opacity:.14;background:none;border:none;pointer-events:none}
.day.free{animation:warmpulse 3.8s ease-in-out infinite}
.day.free:nth-child(3n){animation-delay:1.2s}.day.free:nth-child(3n+1){animation-delay:2.3s}
@keyframes warmpulse{0%,100%{box-shadow:inset 0 0 0 rgba(255,240,225,0)}50%{box-shadow:inset 0 0 16px rgba(255,238,222,.09),0 0 10px rgba(255,238,222,.04)}}
.day.busy{color:var(--faint);text-decoration:line-through;background:none;border-color:rgba(255,255,255,.03);pointer-events:none}
.day.sel{border-color:rgba(207,36,64,.6);color:#fff;position:relative}
.day.sel::after{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--rose);box-shadow:0 0 12px var(--rose)}
.slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px 22px;position:relative;z-index:5}
.slot{padding:14px 0;text-align:center;border-radius:16px;font-family:var(--fm);font-size:13px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);cursor:pointer}
.slot.busy{opacity:.2;text-decoration:line-through;pointer-events:none}
.slot.sel{border-color:rgba(207,36,64,.7);color:#fff;box-shadow:0 0 24px rgba(207,36,64,.22)}
.day,.slot,.chip,.niche,.opt{transition:all .25s var(--spring)}

/* галерея C1 */
.c1head{height:400px;position:relative;display:flex;flex-direction:column;justify-content:flex-end;padding:0 22px 8px;pointer-events:none;z-index:5;
  background:linear-gradient(180deg,transparent 34%,rgba(8,8,12,.38) 52%,rgba(8,8,12,.8) 72%,var(--bg) 96%)}
.c1head h1{font-family:var(--fd);font-weight:900;font-size:44px;line-height:.95;letter-spacing:-1.5px;text-shadow:0 6px 40px rgba(0,0,0,.85)}
.c1head h1 span{color:var(--rose)}
.c1head .live{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;color:#7ee2b8;margin-top:12px}
.c1head .live::before{content:"";width:6px;height:6px;border-radius:50%;background:#7ee2b8;box-shadow:0 0 10px #7ee2b8;animation:breathdot 2.4s ease-in-out infinite}
@keyframes breathdot{50%{opacity:.4}}
.c1head .tagl{font-family:var(--fd);font-weight:300;font-size:12.5px;color:var(--dim);margin-top:8px;letter-spacing:.05em}
.sheet{position:relative;background:var(--bg);padding:20px 0 140px;min-height:400px;z-index:5}
.chips{display:flex;gap:8px;overflow-x:auto;padding:0 22px 18px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none;padding:10px 18px;border-radius:99px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);font-size:12.5px;font-weight:700;color:var(--dim);backdrop-filter:blur(8px);cursor:pointer}
.chip.on{background:var(--ink);color:#0b0b0f;border-color:var(--ink)}
.masonry{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 22px}
.gcard{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#101016;cursor:pointer;aspect-ratio:3/4;
  transition:transform .5s var(--spring),box-shadow .5s,opacity .5s;transform:translateY(26px);opacity:0}
.gcard.in{transform:none;opacity:1}
.gcard:active{transform:scale(1.03);box-shadow:0 0 0 1px rgba(92,184,255,.5),0 18px 50px rgba(0,0,0,.6)}
.gcard:nth-child(odd){border-radius:32px 32px 32px 14px}
.gcard:nth-child(even){border-radius:32px 32px 14px 32px}
.gcard img{width:100%;height:100%;object-fit:cover;display:block}
.gcard .tag{position:absolute;left:12px;top:12px;background:rgba(8,8,12,.6);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:99px;padding:5px 13px;font-family:var(--fd);font-weight:700;font-size:8px;letter-spacing:.16em;text-transform:uppercase}
.empty-note{padding:40px 22px;text-align:center;color:var(--faint);font-size:13px}

/* боди-мэп C3b */
.bodyscene{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}
.manq{position:absolute;inset:0;margin:auto;height:92%;max-width:96%;object-fit:contain;z-index:2;
  filter:brightness(.92) contrast(1.04);
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 10%,#000 82%,transparent 99%);mask-image:linear-gradient(180deg,transparent 0,#000 10%,#000 82%,transparent 99%)}
.manrim{position:absolute;inset:0;z-index:3;pointer-events:none;background:radial-gradient(30% 50% at 72% 45%,rgba(92,184,255,.14),transparent 70%);mix-blend-mode:screen}
.pinlayer{position:absolute;inset:0;z-index:4;pointer-events:none}
.pinX{position:absolute;left:0;right:0;border-top:1.2px dashed rgba(207,36,64,.5)}
.pinY{position:absolute;top:0;bottom:0;border-left:1.2px dashed rgba(207,36,64,.5)}
.pin{position:absolute;width:13px;height:13px;margin:-8px 0 0 -8px;border-radius:50%;background:#fff;border:4px solid var(--rose);animation:pinbeat 1.2s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 24px rgba(207,36,64,.6)}
.pin::after{content:"";position:absolute;inset:-10px;border-radius:50%;border:2px solid var(--rose);animation:ringout 1.2s cubic-bezier(.4,0,.2,1) infinite}
@keyframes pinbeat{0%,100%{transform:scale(1)}14%{transform:scale(1.15)}28%{transform:scale(1)}42%{transform:scale(1.1)}56%{transform:scale(1)}}
@keyframes ringout{0%{opacity:.8;transform:scale(.55)}70%,100%{opacity:0;transform:scale(1.6)}}
.flip{position:absolute;top:24px;right:22px;display:flex;gap:4px;background:rgba(10,10,14,.6);border:1px solid rgba(255,255,255,.12);border-radius:99px;padding:3px;z-index:8;backdrop-filter:blur(10px)}
.flip span{padding:6px 14px;border-radius:99px;font-size:10.5px;font-weight:800;color:var(--dim);cursor:pointer}
.flip span.on{background:var(--ink);color:#0b0b0f}
.zoneplate{position:absolute;left:22px;bottom:104px;display:flex;align-items:center;gap:9px;background:rgba(10,10,14,.72);backdrop-filter:blur(14px);border:1px solid rgba(207,36,64,.4);border-radius:99px;padding:10px 17px;font-size:12.5px;font-weight:700;z-index:8;transition:border-color .4s,color .4s}
.zoneplate i{width:7px;height:7px;border-radius:50%;background:var(--rose)}
.zoneplate small{color:var(--faint);font-family:var(--fm);font-size:9px;margin-left:3px}
.zoneplate.empty{border-color:rgba(255,255,255,.12);border-style:dashed;color:var(--faint)}
.hintchip{position:absolute;top:27px;left:70px;z-index:8;font-family:var(--fm);font-size:9px;letter-spacing:.16em;color:var(--faint);background:rgba(10,10,14,.55);border:1px solid rgba(255,255,255,.1);border-radius:99px;padding:7px 12px;backdrop-filter:blur(8px);max-width:calc(100% - 220px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:opacity .4s}
.hintchip.gone{opacity:0}

/* роль-карточки / хаб / ниши */
.rolecard{display:flex;gap:14px;align-items:center;margin:0 22px 10px;padding:17px;border-radius:26px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);backdrop-filter:blur(12px);position:relative;z-index:5;cursor:pointer}
.rolecard.hi{border-color:rgba(207,36,64,.5);box-shadow:0 12px 40px rgba(207,36,64,.15)}
.rolecard b{font-size:14px;display:block}
.rolecard small{color:var(--dim);font-size:11.5px;display:block;margin-top:3px;line-height:1.45}
.ric{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;flex:none}
.ric svg{width:19px;height:19px}
.niches{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 22px;position:relative;z-index:5}
.niche{padding:14px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);font-weight:700;font-size:12.5px;color:var(--dim);cursor:pointer;text-align:center}
.niche.sel{color:var(--ink);border-color:rgba(207,36,64,.55);box-shadow:0 0 24px rgba(207,36,64,.14)}
.wstat{display:flex;gap:18px;margin-top:12px;font-family:var(--fm);font-size:10.5px;color:var(--dim)}
.wstat b{display:block;color:var(--amber);font-size:15px;margin-bottom:2px}
.linkrow{margin:10px 22px;display:flex;align-items:center;gap:8px;padding:13px 15px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);font-family:var(--fm);font-size:10.5px;color:var(--dim);position:relative;z-index:5;overflow:hidden}
.linkrow span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.linkrow b{margin-left:auto;color:var(--amber);flex:none;font-weight:600;cursor:pointer}

/* админка */
.admS .bk,.admS .flabel{color:var(--amber)}
.admS .c3top h1 span{color:var(--amber)}
.srow{display:flex;align-items:center;gap:12px;margin:0 22px 8px;padding:13px 15px;border-radius:20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);position:relative;z-index:5}
.srow .t{font-family:var(--fm);font-size:13px;color:var(--ink);width:46px;flex:none}
.srow .w{flex:1;font-size:12.5px;font-weight:700}
.srow .w small{display:block;font-weight:500;color:var(--dim);font-size:10.5px;margin-top:2px}
.srow .st{font-size:9px;font-weight:800;padding:5px 10px;border-radius:99px;border:1px solid rgba(255,255,255,.14);letter-spacing:.06em;flex:none}
.srow.wait{border-color:rgba(210,165,94,.4)}
.srow.wait .st{color:var(--amber);border-color:rgba(210,165,94,.5)}
.st.ok2{color:#7ee2b8}
.pgrid2{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 22px;position:relative;z-index:5}
.pcell2{aspect-ratio:1;border-radius:20px;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.08);background:#101016}
.pcell2 img{width:100%;height:100%;object-fit:cover}
.pcell2 .del{position:absolute;top:6px;right:6px;width:20px;height:20px;border-radius:50%;background:rgba(8,8,12,.75);color:var(--rose);font-size:10px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.15);z-index:2;cursor:pointer}
.pcell2.add{border:1.5px dashed rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:var(--amber);font-size:24px;background:none;cursor:pointer}
.statgrid{padding:0 22px;display:flex;gap:8px;position:relative;z-index:5}
.statgrid .card2{margin:0;flex:1;text-align:center}

/* опции */
.optrow{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 22px;position:relative;z-index:5}
.optrow.o3{grid-template-columns:1fr 1fr 1fr}
.opt{padding:13px 0;text-align:center;border-radius:16px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.07);font-weight:700;font-size:12px;color:var(--dim);cursor:pointer}
.opt.sel{color:var(--ink);border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.07)}

/* калькулятор C4 / аналитика A5 */
.pricebig{font-family:var(--fm);font-weight:600;font-size:58px;letter-spacing:-2px;text-align:center;position:relative;z-index:5;color:var(--ink)}
.pricebig small{font-size:26px;color:var(--rose)}
.roll{display:inline-block;height:1em;overflow:hidden;vertical-align:top}
.roll i{display:block;font-style:normal;transition:transform .8s var(--spring);line-height:1}
.track2{margin:16px 26px 4px;height:5px;border-radius:99px;background:rgba(255,255,255,.08);position:relative;z-index:5;cursor:pointer;touch-action:none}
.track2 .fill{position:absolute;left:0;top:0;bottom:0;width:38%;border-radius:99px;background:linear-gradient(90deg,rgba(207,36,64,.5),var(--rose));box-shadow:0 0 14px rgba(207,36,64,.5);pointer-events:none}
.track2 .knob{position:absolute;left:38%;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.6),0 0 18px rgba(207,36,64,.45);pointer-events:none;transition:left .05s linear}
.ticks{display:flex;justify-content:space-between;margin:10px 28px 0;font-family:var(--fm);font-size:9px;color:var(--faint);position:relative;z-index:5}
.gcard.hero{grid-column:1/-1;border-radius:40px 40px 18px 40px;aspect-ratio:4/3}
.moneybig{font-family:var(--fm);font-weight:600;font-size:44px;letter-spacing:-1.5px;text-align:center;position:relative;z-index:5;color:var(--amber);text-shadow:0 0 40px rgba(210,165,94,.25)}
.moneybig small{font-size:20px;color:var(--dim)}
.chartbox{margin:10px 22px;position:relative;z-index:5}
.chartbox svg{width:100%;height:auto;display:block}
.chline{fill:none;stroke:var(--amber);stroke-width:2;stroke-linecap:round;stroke-dasharray:600;stroke-dashoffset:600;animation:chdraw 2.2s cubic-bezier(.4,0,.2,1) forwards}
@keyframes chdraw{to{stroke-dashoffset:0}}
.chdot{fill:var(--rose);animation:pinbeat 1.2s cubic-bezier(.4,0,.2,1) infinite}
.payrow{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:12px;color:var(--dim)}
.payrow:last-child{border:none}
.payrow .pt{font-family:var(--fm);font-size:10px;color:var(--faint);width:74px;flex:none}
.payrow .pw{flex:1}
.payrow b{font-family:var(--fm);color:var(--amber);font-weight:600;flex:none}

/* рулетка C5 */
.wheelbox{position:relative;width:296px;height:296px;margin:10px auto 0;z-index:5}
.wheel2{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.22);
  background:conic-gradient(rgba(207,36,64,.8) 0 45deg,rgba(255,255,255,.05) 45deg 90deg,rgba(255,255,255,.13) 90deg 135deg,rgba(255,255,255,.04) 135deg 180deg,rgba(207,36,64,.45) 180deg 225deg,rgba(255,255,255,.05) 225deg 270deg,rgba(255,255,255,.11) 270deg 315deg,rgba(255,255,255,.04) 315deg 360deg);
  box-shadow:inset 0 0 60px rgba(0,0,0,.6),0 30px 90px rgba(207,36,64,.16);transition:transform 4.4s cubic-bezier(.15,.9,.28,1.12);will-change:transform;cursor:pointer}
.wheel2 .lbl{position:absolute;font-size:9px;font-weight:800;letter-spacing:.1em;color:#fff}
.blick{position:absolute;inset:0;border-radius:50%;pointer-events:none;
  background:conic-gradient(from 0deg,transparent 0 6%,rgba(255,255,255,.35) 9%,transparent 14% 100%);
  -webkit-mask:radial-gradient(closest-side,transparent 86%,#000 89%);mask:radial-gradient(closest-side,transparent 86%,#000 89%);
  animation:blickspin 6s linear infinite}
@keyframes blickspin{to{transform:rotate(360deg)}}
.wcenter{position:absolute;inset:27%;border-radius:50%;overflow:hidden;border:1px solid rgba(255,255,255,.3);box-shadow:0 0 0 10px rgba(8,8,12,.78);pointer-events:none}
.wcenter img{width:100%;height:170%;object-fit:cover;object-position:50% 6%}
.wpin{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:16px solid #fff;filter:drop-shadow(0 3px 8px rgba(0,0,0,.7));z-index:6}
.spinres{opacity:0;transform:translateY(8px);transition:opacity .6s var(--spring),transform .6s var(--spring)}
.spinres.show{opacity:1;transform:none}

/* подписка A6 */
.tier{margin:0 22px 10px;padding:15px 17px;border-radius:26px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);position:relative;z-index:5;overflow:hidden}
.tier .tn{font-family:var(--fd);font-weight:800;font-size:15px;letter-spacing:.06em}
.tier .tp{font-family:var(--fm);font-size:19px;margin-top:5px}
.tier .tp small{font-size:11px;color:var(--faint)}
.tier ul{list-style:none;margin-top:10px;font-size:11.5px;color:var(--dim);line-height:1.8}
.tier li::before{content:"✓";color:#7ee2b8;margin-right:9px;font-weight:800}
.tier li.no{opacity:.35}
.tier li.no::before{content:"—";color:var(--faint)}
.tier.pro{border-color:rgba(207,36,64,.5);box-shadow:0 16px 50px rgba(207,36,64,.14)}
.tier.pro .tn{color:var(--rose)}
.tier.max{border-color:rgba(210,165,94,.55);box-shadow:0 16px 50px rgba(210,165,94,.16)}
.tier.max .tn{color:var(--amber)}
.tier .badge{position:absolute;top:14px;right:16px;font-family:var(--fm);font-size:8px;letter-spacing:.2em;padding:5px 10px;border-radius:99px;border:1px solid rgba(255,255,255,.2);color:var(--dim)}
.tier.pro .badge{color:var(--rose);border-color:rgba(207,36,64,.5)}
.tier.max .badge{color:var(--amber);border-color:rgba(210,165,94,.5)}

/* фото-карусель профиля (эскорт и сервисные ниши) */
.carousel{display:flex;gap:10px;overflow-x:auto;padding:2px 22px 16px;scroll-snap-type:x mandatory;scrollbar-width:none;position:relative;z-index:5}
.carousel::-webkit-scrollbar{display:none}
.carousel .ph{flex:none;width:210px;aspect-ratio:3/4;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.12);scroll-snap-align:center;background:#101016;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.carousel .ph img{width:100%;height:100%;object-fit:cover}

/* статусы записей клиента */
.stbadge{font-size:9px;font-weight:800;padding:5px 10px;border-radius:99px;border:1px solid rgba(255,255,255,.14);letter-spacing:.06em}
.stbadge.ok{color:#7ee2b8;border-color:rgba(126,226,184,.4)}
.stbadge.warn{color:var(--amber);border-color:rgba(210,165,94,.5)}
.stbadge.bad{color:var(--rose);border-color:rgba(207,36,64,.5)}

/* таймер холда */
.holdtimer{font-family:var(--fm);font-size:34px;text-align:center;letter-spacing:2px;color:var(--ink);position:relative;z-index:5;margin-top:6px}
.holdtimer.late{color:var(--rose)}

/* профиль мастера P0 */
.profcover{position:absolute;inset:0 0 auto 0;height:300px;background-size:cover;background-position:center 20%;
  -webkit-mask-image:linear-gradient(180deg,#000 30%,transparent 96%);mask-image:linear-gradient(180deg,#000 30%,transparent 96%);
  filter:brightness(.8) saturate(1.05);z-index:1}
.profhead{padding:86px 24px 22px;position:relative;z-index:5;text-align:left}
.profava{width:76px;height:76px;border-radius:50%;background:#17141c center/cover;border:2px solid rgba(255,255,255,.25);box-shadow:0 12px 40px rgba(0,0,0,.6);margin-bottom:14px}
#s-profile .back{top:16px}
#s-profile .profhead{padding-top:110px}
.profhead h1{font-family:var(--fd);font-weight:900;font-size:32px;letter-spacing:-1px;line-height:1;text-shadow:0 6px 40px rgba(0,0,0,.8)}
.profmeta{display:flex;align-items:center;gap:14px;margin-top:10px}
.profmeta > span:first-child{font-family:var(--fm);font-size:9.5px;letter-spacing:.24em;color:var(--dim)}
.proftag{font-family:var(--fd);font-weight:300;font-size:12.5px;color:var(--dim);margin-top:8px;letter-spacing:.05em}
.swatches{display:flex;gap:10px;padding:4px 0;position:relative;z-index:5;flex-wrap:wrap}
.swatch{width:34px;height:34px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .3s var(--spring);position:relative}
.swatch.sel{border-color:#fff;transform:scale(1.12)}
.swatch.lock::after{content:"🔒";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:13px;background:rgba(8,8,12,.55);border-radius:50%}
/* эксклюзив-скины профиля (MAX) */
.skin-neon #prof-name{background:linear-gradient(90deg,#5cb8ff,#b558e0 55%,#ff5c8a);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 18px rgba(181,88,224,.45))}
.skin-neon .rolecard.hi{box-shadow:0 0 34px rgba(181,88,224,.28);border-color:rgba(181,88,224,.55)}
.skin-royal #prof-name{background:linear-gradient(90deg,#f6e2b3,#d2a55e 50%,#8a6528);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 18px rgba(210,165,94,.4))}
.skin-royal .rolecard.hi{box-shadow:0 0 34px rgba(210,165,94,.3);border-color:rgba(210,165,94,.6)}
.tgl{width:44px;height:26px;border-radius:99px;background:linear-gradient(180deg,#caa05c,#8a6528);position:relative;flex:none;border:1px solid rgba(255,255,255,.25);cursor:pointer;transition:opacity .3s}
.tgl::after{content:"";position:absolute;top:2px;right:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.4);transition:all .3s var(--spring)}
.tgl.off{background:rgba(255,255,255,.08)}
.tgl.off::after{right:auto;left:3px;background:#888}
/* нижний таб-бар админки (из полного макета) */
.nav{position:absolute;left:0;right:0;bottom:0;display:flex;border-top:1px solid rgba(255,255,255,.09);background:rgba(10,10,14,.72);backdrop-filter:blur(20px);padding:10px 8px calc(14px + env(safe-area-inset-bottom));z-index:9}
.nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;font-size:9.5px;font-weight:700;color:var(--faint);text-decoration:none;letter-spacing:.06em;transition:color .2s;cursor:pointer}
.nav a.on{color:var(--ink)}
.nav a.on svg{filter:drop-shadow(0 0 8px rgba(210,165,94,.8));color:var(--amber)}
.nav svg{width:21px;height:21px}
.setrow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:13px;color:var(--ink)}
.setrow:last-child{border:none}
.setrow small{display:block;color:var(--faint);font-size:10.5px;margin-top:3px;font-weight:500}
.setrow .val{font-family:var(--fm);color:var(--ink);font-weight:600;flex:none;font-size:12px;cursor:pointer}
.badge2{background:var(--amber);color:#170e02;font-size:10px;font-weight:800;border-radius:99px;padding:2px 8px;box-shadow:0 0 16px rgba(210,165,94,.5)}
.setval{width:86px;padding:8px 10px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:var(--ink);font-size:13px;text-align:right;outline:none;font-family:var(--fm)}
.setval:focus{border-color:rgba(210,165,94,.55)}
.setunit{font-family:var(--fm);font-size:11px;color:var(--faint);width:22px;flex:none}
.status{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:#7ee2b8;font-weight:700}
.status::before{content:"";width:6px;height:6px;border-radius:50%;background:#7ee2b8;box-shadow:0 0 8px #7ee2b8}
.legend{display:flex;gap:16px;padding:12px 22px;font-size:10.5px;color:var(--dim);flex-wrap:wrap;position:relative;z-index:5}
.legend i{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:6px}
.day.doff{background:repeating-linear-gradient(45deg,transparent 0 5px,rgba(255,255,255,.05) 5px 10px);color:var(--faint)}

/* тосты */
#toast{position:fixed;left:22px;right:22px;bottom:30px;z-index:99;padding:14px 18px;border-radius:18px;background:rgba(16,16,22,.92);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(16px);font-size:13px;text-align:center;opacity:0;transform:translateY(16px);transition:all .4s var(--spring);pointer-events:none}
#toast.show{opacity:1;transform:none}
.back{position:absolute;top:24px;left:22px;z-index:9;width:38px;height:38px;border-radius:14px;background:rgba(10,10,14,.6);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:var(--dim);cursor:pointer;backdrop-filter:blur(10px)}
.rise2{opacity:0;transform:translateY(22px);transition:transform .7s var(--spring),opacity .7s}
.rise2.in{opacity:1;transform:none}
