/* ============================================================
   IRON PROTOCOL v0.5 — mobile-first
   Base = 375–430px; desktop overrides at @media(min-width:761px)
============================================================ */
:root{
  --void:#04060d;
  --panel:rgba(10,14,24,.84);
  --panel-solid:#0a0f1c;
  --line:rgba(148,170,196,.10);
  --line-cyan:rgba(94,231,255,.35);
  --cyan:#5ee7ff;
  --violet:#8b5cf6;
  --blood:#ff3d68;
  --gold:#ffc857;
  --green:#6fe0a8;
  --txt:#cfe3f0;
  --mut:#5d7287;
  --font-d:'Chakra Petch',sans-serif;
  --font-n:'Rajdhani',sans-serif;
  --font-b:'Inter',sans-serif;
  --font-j:'Yu Gothic','Meiryo',sans-serif;
  --top-h:52px;
  --tab-h:60px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
::selection{background:rgba(94,231,255,.22)}
html,body{height:100%;overflow-x:hidden}
body{background:var(--void);color:var(--txt);font-family:var(--font-b);cursor:auto}
button,select{font-family:var(--font-d);cursor:pointer}
input,textarea{cursor:text}
.hidden{display:none!important}
#cursor-dot,#cursor-ring{display:none}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(94,231,255,.15);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:rgba(94,231,255,.35)}

/* ============ ATMOSPHERE ============ */
#fx{position:fixed;inset:0;z-index:0;pointer-events:none}
#grid-bg{
  position:fixed;inset:-2px;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(94,231,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(94,231,255,.022) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000 20%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000 20%,transparent 80%);
}
#vignette{
  position:fixed;inset:0;z-index:40;pointer-events:none;
  background:radial-gradient(ellipse 100% 100% at 50% 50%,transparent 40%,rgba(2,3,8,.82));
}

/* ============ SHARED ============ */
.panel{
  position:relative;background:var(--panel);border:1px solid var(--line);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}
.panel.corner::before,.panel.corner::after{
  content:'';position:absolute;width:16px;height:16px;pointer-events:none;z-index:2;
}
.panel.corner::before{top:0;left:0;border-top:2px solid var(--line-cyan);border-left:2px solid var(--line-cyan)}
.panel.corner::after{bottom:0;right:0;border-bottom:2px solid var(--line-cyan);border-right:2px solid var(--line-cyan)}

.p-title{
  font-family:var(--font-d);font-size:10px;font-weight:600;letter-spacing:.28em;color:var(--mut);
  padding:11px 15px;border-bottom:1px solid var(--line);
}
.p-section{
  font-family:var(--font-d);font-size:9px;font-weight:600;letter-spacing:.3em;color:var(--mut);
  margin:18px 0 9px;display:flex;align-items:center;gap:10px;
}
.p-section::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent)}

/* bars */
.bar{position:relative;height:14px;background:rgba(3,6,12,.9);border:1px solid var(--line);overflow:hidden;
  clip-path:polygon(5px 0,100% 0,calc(100% - 5px) 100%,0 100%)}
.bar .fill{position:absolute;inset:0;width:0%;transition:width .7s cubic-bezier(.2,.8,.2,1)}
.bar .ghost-fill{position:absolute;inset:0;width:0%;background:rgba(255,200,87,.38);transition:width 1.2s ease .35s}
.bar .bartext{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-n);font-weight:600;font-size:11px;letter-spacing:.06em;color:#fff;text-shadow:0 1px 3px #000;z-index:2}
.bar.xp .fill{background:linear-gradient(90deg,#1b4d8c,var(--cyan))}
.bar.hp .fill{background:linear-gradient(90deg,rgba(0,0,0,.85),var(--zone-c,var(--blood)))}
.bar.hp.big{height:22px}
.bar.hp.big .bartext{font-size:12px}
.bar .fill::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.26) 50%,transparent 70%);
  background-size:200% 100%;animation:shine 2.6s linear infinite;
}
@keyframes shine{from{background-position:200% 0}to{background-position:-200% 0}}

/* buttons */
.ghost-btn{
  background:transparent;border:1px solid var(--line-cyan);color:var(--cyan);
  font-size:12px;font-weight:600;letter-spacing:.26em;padding:13px 26px;
  position:relative;overflow:hidden;transition:all .2s;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
}
.ghost-btn:hover,.ghost-btn:active{background:rgba(94,231,255,.09);box-shadow:0 0 18px rgba(94,231,255,.18)}
.ghost-btn.small{padding:7px 13px;font-size:9px;letter-spacing:.18em;color:var(--mut);border-color:var(--line)}
.ghost-btn.small:hover{color:var(--cyan)}
.ghost-btn.red{border-color:var(--blood);color:var(--blood)}
.ghost-btn.red:hover,.ghost-btn.red:active{background:rgba(255,61,104,.09);box-shadow:0 0 18px rgba(255,61,104,.18)}
.cta-btn{
  position:relative;border:1px solid var(--cyan);color:#031018;
  background:linear-gradient(180deg,var(--cyan),#2fa8c9);
  font-size:12px;font-weight:700;letter-spacing:.22em;padding:14px 32px;overflow:hidden;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  transition:box-shadow .2s,opacity .2s;
}
.cta-btn span{position:relative;z-index:1}
.cta-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.48) 50%,transparent 65%);
  transform:translateX(-110%);transition:transform .5s ease;
}
.cta-btn:hover::before,.cta-btn:active::before{transform:translateX(110%)}
.cta-btn:hover,.cta-btn:active{box-shadow:0 0 22px rgba(94,231,255,.32)}
.cta-btn:disabled{opacity:.2;box-shadow:none}
.cta-btn.red{border-color:var(--blood);background:linear-gradient(180deg,var(--blood),#b81f47);color:#fff}
.cta-btn.red:hover,.cta-btn.red:active{box-shadow:0 0 22px rgba(255,61,104,.32)}

/* ============ KEYFRAMES ============ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.28}}
@keyframes breath{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.015)}}
@keyframes aurapulse{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}
@keyframes rot{to{transform:rotate(360deg)}}
@keyframes eyeflicker{0%,87%,91%,100%{opacity:1}89%{opacity:.22}}
@keyframes scanmove{from{background-position:0 -160px}to{background-position:0 320px}}

/* ============ BOOT ============ */
#boot{
  position:fixed;inset:0;z-index:30;
  display:flex;flex-direction:column;align-items:center;gap:22px;
  background:var(--void);
  overflow-y:auto;overflow-x:hidden;
  padding:26px 18px 56px;
  scroll-behavior:smooth;
}
#glitch-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:5}
#mono-wrap{width:100%;max-width:680px;display:flex;flex-direction:column;gap:22px}
#mono-lines{font-family:var(--font-b);font-size:18px;line-height:2;color:#dcebf7;min-height:40px}
#mono-lines .mline{opacity:0;margin-bottom:7px}
#sys-lines{
  font-family:var(--font-d);font-size:11px;line-height:2.1;letter-spacing:.12em;
  color:rgba(94,231,255,.72);white-space:pre-wrap;border-left:2px solid rgba(94,231,255,.25);padding-left:15px;
}
#wren-boot{display:flex;flex-direction:column;gap:9px}
#wren-boot .wb-msg{
  padding:12px 14px;background:rgba(3,6,12,.7);border:1px solid var(--line);border-left:2px solid var(--cyan);
  font-size:13.5px;line-height:1.78;color:#b9cede;opacity:0;
}
#wren-boot .wb-tag{font-family:var(--font-d);font-size:7.5px;letter-spacing:.28em;color:var(--mut);display:block;margin-bottom:4px}
#boot-logo{text-align:center;opacity:0;width:100%;max-width:680px}
.bl-jp{font-family:var(--font-j);font-weight:300;font-size:15px;letter-spacing:1.2em;color:var(--blood);margin-bottom:14px;text-indent:1.2em}
#boot-logo h1{font-family:var(--font-d);font-weight:700;font-size:clamp(38px,10vw,84px);letter-spacing:.16em;line-height:1}
#boot-logo .iron{color:#eaf6ff;text-shadow:0 0 28px rgba(94,231,255,.52)}
#boot-logo .proto{color:transparent;-webkit-text-stroke:1.5px var(--cyan)}
.bl-sub{margin-top:14px;font-family:var(--font-d);font-size:10px;letter-spacing:.5em;color:var(--mut)}
#boot-enter{opacity:0;width:100%;max-width:440px}

/* ============ SELECT ============ */
#select{position:relative;z-index:2;padding:28px 16px 90px;min-height:100vh}
.sel-head{text-align:center;margin-bottom:28px}
.sel-jp{font-family:var(--font-j);font-weight:300;letter-spacing:1em;color:var(--blood);font-size:13px;margin-bottom:9px;text-indent:1em}
.sel-head h2{font-family:var(--font-d);font-size:26px;letter-spacing:.22em;color:#eaf6ff;text-shadow:0 0 22px rgba(94,231,255,.25)}
.sel-head p{margin:11px auto 0;font-size:13px;line-height:1.8;color:#8aa0b5}
#class-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:28px}
.class-card{
  position:relative;height:210px;overflow:hidden;
  border:1px solid var(--line);background:var(--panel-solid);
  clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);
  transition:border-color .3s;
}
.class-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;
  filter:saturate(.55) brightness(.58);transition:filter .4s,transform .4s;
}
.class-card .glare{
  position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity .3s;
  background:radial-gradient(circle 300px at var(--mx,50%) var(--my,50%),rgba(255,255,255,.1),transparent 60%);
}
.class-card:hover .glare{opacity:1}
.class-card:hover img,.class-card.selected img{filter:saturate(1.02) brightness(.88);transform:scale(1.04)}
.class-card .cc-info{
  position:absolute;left:0;right:0;bottom:0;z-index:3;padding:56px 16px 15px;
  background:linear-gradient(transparent,rgba(3,5,11,.97) 58%);
}
.class-card .cc-jp{font-family:var(--font-j);font-size:11px;color:var(--ac,#5ee7ff);letter-spacing:.5em;opacity:.85}
.class-card .cc-name{font-family:var(--font-d);font-weight:700;font-size:17px;letter-spacing:.1em;color:#fff;margin:2px 0 1px}
.class-card .cc-role{font-family:var(--font-d);font-size:9px;letter-spacing:.28em;color:var(--ac,#5ee7ff);margin-bottom:6px}
.class-card .cc-proto{font-family:var(--font-d);font-size:8px;letter-spacing:.18em;color:rgba(255,255,255,.38);margin-bottom:5px}
.class-card .cc-desc{font-size:12px;line-height:1.55;color:#8aa0b5}
.class-card.selected{border-color:var(--ac,#5ee7ff);box-shadow:0 0 28px var(--acg,rgba(94,231,255,.22))}
.class-card .cc-pick{
  position:absolute;top:10px;right:12px;z-index:4;font-family:var(--font-d);font-size:8px;
  letter-spacing:.26em;color:var(--ac,#5ee7ff);border:1px solid var(--ac,#5ee7ff);
  padding:3px 8px;opacity:0;transform:translateY(-4px);transition:all .28s;
}
.class-card.selected .cc-pick{opacity:1;transform:none}
.sel-foot{display:flex;flex-direction:column;gap:10px}
#player-name{
  width:100%;padding:14px 16px;background:rgba(3,6,12,.8);border:1px solid var(--line);
  color:var(--txt);font-size:16px;letter-spacing:.1em;text-align:center;font-weight:600;font-family:var(--font-d);
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
}
#player-name:focus{outline:none;border-color:var(--cyan)}
#start-btn{width:100%}

/* ============ SETUP ============ */
#setup{position:relative;z-index:2;padding:26px 16px 90px;min-height:100vh}
#setup-grid{display:grid;grid-template-columns:1fr;gap:11px;margin:22px 0 13px}
.setup-card{padding:15px 16px 13px}
.su-title{font-family:var(--font-d);font-weight:700;font-size:13px;letter-spacing:.2em;color:#eaf6ff}
.su-sub{font-size:11.5px;color:var(--mut);margin:3px 0 9px}
.su-opts{display:flex;flex-direction:column;gap:7px}
.su-opt{
  text-align:left;padding:11px 13px;background:rgba(94,231,255,.03);border:1px solid var(--line);
  color:var(--txt);transition:all .18s;clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);min-height:44px;
}
.su-opt:hover,.su-opt:active{border-color:var(--line-cyan);background:rgba(94,231,255,.07)}
.su-opt.on{border-color:var(--cyan);background:rgba(94,231,255,.1);box-shadow:0 0 14px rgba(94,231,255,.1)}
.su-opt b{display:block;font-family:var(--font-d);font-size:13px;letter-spacing:.08em;color:#fff}
.su-opt span{display:block;font-size:11px;color:var(--mut);margin-top:1px}
.su-opt.on b{color:var(--cyan)}
.setup-row{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:9px}
.setup-field label{display:block;font-family:var(--font-d);font-size:9px;letter-spacing:.22em;color:var(--mut);margin-bottom:6px}
.setup-field input{width:100%;padding:12px 12px;background:rgba(3,6,12,.6);border:1px solid var(--line);color:#fff;font-family:var(--font-n);font-size:16px}
.setup-field input:focus{outline:none;border-color:var(--cyan)}
.seg{display:flex;gap:7px}
.seg button{flex:1;padding:12px;background:rgba(3,6,12,.6);border:1px solid var(--line);color:var(--mut);font-family:var(--font-d);letter-spacing:.2em;transition:all .18s;min-height:44px}
.seg button.on{border-color:var(--cyan);background:rgba(94,231,255,.1);color:var(--cyan)}
.seg.multi{flex-wrap:wrap}
.seg.multi button{flex:0 0 calc(33.33% - 5px);letter-spacing:.1em;font-size:9px;padding:9px 6px}
.seg.multi button.on{border-color:#a06fff;background:rgba(160,111,255,.12);color:#c9a8ff}
/* setup-group: full-width block used for weak groups */
.setup-group{padding:15px 16px 13px;background:rgba(3,6,12,.6);border:1px solid var(--line)}
.setup-group .sg-label{font-family:var(--font-d);font-weight:700;font-size:11px;letter-spacing:.22em;color:#eaf6ff;margin-bottom:3px}
.setup-group .sg-sub{font-size:11.5px;color:var(--mut);margin-bottom:10px}
#setup-btn{width:100%}

/* ============ PROLOGUE ============ */
#prologue{
  position:relative;z-index:2;min-height:100vh;
  display:flex;align-items:flex-start;justify-content:center;
  padding:32px 16px 72px;
}
#pro-box{width:100%;max-width:640px}
.pro-head{
  display:flex;align-items:center;gap:9px;font-family:var(--font-d);font-size:9px;
  letter-spacing:.32em;color:var(--mut);margin-bottom:26px;
}
.pro-dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 2.6s infinite}
#pro-question{font-family:var(--font-b);font-size:18px;line-height:1.75;color:#dcebf7;min-height:90px;white-space:pre-line}
#pro-inputrow{margin-top:22px;display:flex;flex-direction:column;gap:12px}
#pro-input{
  width:100%;padding:13px;background:rgba(3,6,12,.85);border:1px solid var(--line);
  color:var(--txt);font-size:16px;line-height:1.65;font-family:var(--font-b);resize:none;
}
#pro-input:focus{outline:none;border-color:var(--cyan)}
#pro-inputrow .cta-btn{align-self:flex-end}

/* ============ GAME — APP SHELL (mobile-only) ============ */
#game{position:relative;z-index:2;height:100dvh;overflow:hidden}

/* TOPBAR */
#topbar{
  display:flex;align-items:center;gap:7px;padding:0 9px;
  height:var(--top-h);border-bottom:1px solid var(--line);
  background:rgba(4,7,14,.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  position:fixed;top:0;left:0;right:0;z-index:20;
}
/* avatar → otwiera szufladę POSTAĆ */
#char-btn{
  display:flex;align-items:center;gap:5px;padding:2px 6px 2px 2px;flex-shrink:0;
  background:rgba(94,231,255,.05);border:1px solid var(--line);
  clip-path:polygon(5px 0,100% 0,calc(100% - 5px) 100%,0 100%);transition:border-color .18s;
}
#char-btn:active,#char-btn:hover{border-color:var(--line-cyan)}
#tb-portrait{
  width:32px;height:32px;object-fit:cover;object-position:top;
  border:1px solid var(--ac,#5ee7ff);flex-shrink:0;background:#06090f;
}
.tb-lv{font-family:var(--font-d);font-weight:700;font-size:7px;letter-spacing:.08em;color:var(--mut);line-height:1.1;text-align:center}
.tb-lv b{display:block;font-family:var(--font-n);font-size:15px;color:var(--gold);letter-spacing:0;margin-top:1px}
body.has-points #char-btn{border-color:var(--gold);box-shadow:0 0 12px rgba(255,200,87,.25);animation:pulse 2.4s infinite}

/* WREN → otwiera szufladę czatu */
#wren-btn{
  width:38px;height:38px;flex-shrink:0;position:relative;
  border:1px solid var(--line-cyan);background:rgba(94,231,255,.05);
  clip-path:polygon(6px 0,100% 0,calc(100% - 6px) 100%,0 100%);transition:all .18s;
}
#wren-btn:active,#wren-btn:hover{background:rgba(94,231,255,.12)}
#wren-btn .wb-dot{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:9px;height:9px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);
  animation:pulse 2.6s infinite;
}
#wren-btn.has-unread .wb-dot{background:var(--gold);box-shadow:0 0 12px var(--gold)}

/* TABS — fixed bottom bar on mobile */
#tabs{
  position:fixed;bottom:0;left:0;right:0;z-index:20;
  display:flex;height:calc(var(--tab-h) + env(safe-area-inset-bottom,0px));
  padding-bottom:env(safe-area-inset-bottom,0px);
  background:rgba(4,7,14,.96);border-top:1px solid rgba(94,231,255,.12);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.tab{
  flex:1;padding:5px 2px 8px;border:none;background:transparent;
  color:var(--mut);font-size:8px;font-weight:600;letter-spacing:.14em;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  transition:all .18s;clip-path:none;position:relative;
}
.tab::before{
  font-family:var(--font-j);font-size:18px;line-height:1;display:block;
}
.tab[data-view="walka"]::before{content:'鍛'}
.tab[data-view="kuznia"]::before{content:'目'}
.tab[data-view="cytadela"]::before{content:'塔'}
.tab[data-view="ekwipunek"]::before{content:'剣'}
.tab[data-view="sojusznicy"]::before{content:'仲'}
.tab[data-view="archiwum"]::before{content:'書'}
/* 6 tabs — compress slightly */
#tabs .tab{font-size:7px;letter-spacing:.08em}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--cyan)}
.tab.active::after{
  content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--cyan);
  box-shadow:0 0 8px var(--cyan);
}

#resources{display:flex;gap:9px;margin:0 auto 0 4px;min-width:0;overflow:hidden}
.res{display:flex;flex-direction:column;align-items:center;line-height:1.05;min-width:0}
.res .lbl{font-family:var(--font-d);font-size:6.5px;letter-spacing:.12em;color:var(--mut);white-space:nowrap}
.res .val{font-family:var(--font-n);font-weight:700;font-size:15px;color:var(--txt);white-space:nowrap}
.res.gold .val{color:var(--gold)}
.res.violet .val{color:var(--cyan);font-size:12px;margin-top:1px}
.res.red .val{color:var(--blood)}
.res.zh{flex-shrink:1}
.res.zh .val{font-size:11px;color:var(--cyan);letter-spacing:.02em;margin-top:2px}
.res.zh .val.late{color:var(--blood);animation:pulse 1.6s infinite}
#snd-btn{
  width:34px;height:34px;border:1px solid var(--line);background:transparent;color:var(--mut);
  font-family:var(--font-j);font-size:12px;transition:all .18s;flex-shrink:0;
  clip-path:polygon(6px 0,100% 0,calc(100% - 6px) 100%,0 100%);
}
#snd-btn:hover{color:var(--cyan);border-color:var(--line-cyan)}
#snd-btn.off{color:#314357}

/* LAYOUT — obszar treści dokładnie między paskami; każdy widok przewija się sam */
#layout{
  position:fixed;top:var(--top-h);bottom:calc(var(--tab-h) + env(safe-area-inset-bottom,0px));left:0;right:0;z-index:1;
  overflow:hidden;
}
#stage{height:100%;width:100%;min-width:0}

/* ============ CHAR PANEL (szuflada) ============ */
#portrait-wrap{
  width:100%;height:230px;margin:0 0 12px;position:relative;overflow:hidden;
  border:1px solid var(--line);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}
#portrait{width:100%;height:100%;object-fit:cover;object-position:top;filter:saturate(.95)}
#portrait-wrap .scan{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(rgba(94,231,255,0) 0%,rgba(94,231,255,.07) 50%,rgba(94,231,255,0) 100%);
  background-size:100% 160px;background-repeat:no-repeat;animation:scanmove 5s linear infinite;
}
#class-seal{
  position:absolute;top:8px;right:9px;z-index:2;font-family:var(--font-j);font-size:20px;
  color:var(--ac,#5ee7ff);border:1px solid var(--ac,#5ee7ff);width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;background:rgba(3,5,11,.6);
}
#char-tag{position:absolute;left:12px;bottom:11px;z-index:2}
#char-tag b{display:block;font-family:var(--font-d);font-size:18px;letter-spacing:.07em;color:#fff;text-shadow:0 2px 8px #000}
#char-tag span{font-family:var(--font-d);font-size:9px;letter-spacing:.2em;color:var(--ac,#5ee7ff)}
.lvl-row{display:flex;gap:11px;align-items:center;padding:0 0 12px}
.lvl-badge{
  font-family:var(--font-n);font-weight:700;font-size:11px;color:#031018;
  background:linear-gradient(180deg,var(--gold),#d99e2b);padding:7px 11px;flex-shrink:0;
  clip-path:polygon(5px 0,100% 0,calc(100% - 5px) 100%,0 100%);
}
.lvl-badge b{font-size:17px;margin-left:2px}
.xp-wrap{flex:1;min-width:0}
.xp-info{display:flex;justify-content:space-between;font-family:var(--font-n);font-size:11px;color:var(--mut);letter-spacing:.06em;margin-bottom:4px}
#sp-banner{
  display:none;margin:0 0 11px;padding:9px;text-align:center;
  font-family:var(--font-d);font-size:9px;letter-spacing:.2em;color:var(--gold);
  border:1px dashed rgba(255,200,87,.35);animation:pulse 2s infinite;
}
body.has-points #sp-banner{display:block}
#stats{margin-bottom:4px;border:1px solid var(--line);background:rgba(3,6,12,.4)}
.statrow{display:flex;align-items:center;gap:8px;padding:11px 13px;border-top:1px solid var(--line)}
.statrow:first-child{border-top:none}
.statrow .sname{flex:1;font-family:var(--font-d);font-size:11px;letter-spacing:.13em;color:var(--mut)}
.statrow .sbonus{font-family:var(--font-n);font-size:11px;color:#52a870}
.statrow .sval{font-family:var(--font-n);font-weight:700;font-size:17px;color:var(--txt);min-width:24px;text-align:right}
.statrow .plus{
  width:24px;height:24px;border:1px solid var(--gold);background:rgba(255,200,87,.1);color:var(--gold);
  font-size:16px;font-weight:700;display:none;align-items:center;justify-content:center;line-height:1;flex-shrink:0;
}
body.has-points .statrow .plus{display:flex}
#shard-row{
  margin:11px 0 0;padding:10px;text-align:center;border:1px solid rgba(139,92,246,.35);
  font-family:var(--font-d);font-size:9px;letter-spacing:.2em;color:#c9b2ff;
}
#shard-row b{font-family:var(--font-n);font-size:13px}

/* ============ VIEWS — każdy wypełnia ekran, przewija się wewnętrznie ============ */
.view{display:none;height:100%}
.view.active{
  display:flex;flex-direction:column;gap:11px;height:100%;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:12px 11px calc(12px + env(safe-area-inset-bottom,0px));
  scrollbar-width:thin;scrollbar-color:rgba(94,231,255,.25) transparent;
}
.view.active::-webkit-scrollbar{width:4px}
.view.active::-webkit-scrollbar-thumb{background:rgba(94,231,255,.25);border-radius:2px}
.view.active > *{flex-shrink:0}
.view-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:11px;gap:8px;flex-wrap:wrap}
.vt-label{font-family:var(--font-d);font-size:9px;letter-spacing:.28em;color:var(--mut)}
#newday-btn{display:none}

/* ============ BATTLE SCENE ============ */
#battle{overflow:hidden;margin-bottom:11px;border-color:var(--zone-b,var(--line));transition:border-color .8s ease}
#battle::before{border-top-color:var(--zone-c,var(--line-cyan));border-left-color:var(--zone-c,var(--line-cyan));transition:border-color .8s ease}
#battle::after{border-bottom-color:var(--zone-c,var(--line-cyan));border-right-color:var(--zone-c,var(--line-cyan));transition:border-color .8s ease}
.gc-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:6}
#decay-banner{
  margin:11px 14px 0;padding:10px 13px;border:1px solid rgba(255,61,104,.5);
  background:rgba(255,61,104,.08);font-size:12px;color:#ffb9c8;line-height:1.55;
  animation:pulse 3s infinite;position:relative;z-index:3;
}
#boss-bar{padding:11px 15px 2px;position:relative;z-index:3}
.bb-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px}
#zone-tag{font-family:var(--font-d);font-size:8px;letter-spacing:.34em;color:var(--zone-c,var(--blood));opacity:.8;margin-bottom:3px}
#guardian-name{
  font-family:var(--font-d);font-weight:700;font-size:21px;letter-spacing:.15em;color:#fdeef2;
  text-shadow:0 0 22px var(--zone-g,rgba(255,61,104,.42));
}
#guardian-floor{font-family:var(--font-d);font-size:8.5px;letter-spacing:.3em;color:var(--mut)}
#arena{
  position:relative;height:172px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 70% 80% at 50% 56%,var(--zone-f,rgba(255,61,104,.06)),transparent 72%);
  transition:box-shadow .8s ease;
}
#battle[data-streak="low"] #arena{box-shadow:inset 0 0 40px rgba(255,93,104,.1)}
#battle[data-streak="mid"] #arena{box-shadow:inset 0 0 60px rgba(255,93,104,.18)}
#battle[data-streak="high"] #arena{box-shadow:inset 0 0 90px rgba(255,93,104,.28);animation:streakPulse 3s ease-in-out infinite}
@keyframes streakPulse{0%,100%{box-shadow:inset 0 0 90px rgba(255,93,104,.28)}50%{box-shadow:inset 0 0 120px rgba(255,93,104,.42)}}
@keyframes errShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
#floor-seal{
  position:absolute;font-family:var(--font-j);font-weight:300;font-size:164px;
  color:rgba(255,61,104,.045);user-select:none;pointer-events:none;line-height:1;
}
#aura{
  position:absolute;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,var(--zone-g,rgba(255,61,104,.13)),transparent 62%);
  animation:aurapulse 4.5s ease-in-out infinite;
}
#guardian-visual{
  width:160px;height:160px;position:relative;z-index:2;
  filter:drop-shadow(0 0 20px var(--zone-g,rgba(255,61,104,.38)));
  animation:breath 5s ease-in-out infinite;
}
#guardian-art{
  position:relative;z-index:2;max-height:158px;max-width:80%;object-fit:contain;
  filter:drop-shadow(0 0 24px var(--zone-g,rgba(255,61,104,.42)));animation:breath 5s ease-in-out infinite;
}
.rune-ring-a{transform-origin:120px 120px;animation:rot 30s linear infinite}
.rune-ring-b{transform-origin:120px 120px;animation:rot 18s linear infinite reverse}
.g-eye{animation:eyeflicker 6s ease-in-out infinite}
#guardian-desc{padding:0 15px 6px;position:relative;z-index:3;font-size:11.5px;line-height:1.65;color:#8aa0b5;font-style:italic}
#battle-foot{padding:0 15px 13px;position:relative;z-index:3}
.mult-chips{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:7px}
.chip{
  font-family:var(--font-n);font-weight:600;font-size:11px;letter-spacing:.05em;
  padding:3px 9px;border:1px solid var(--line);color:var(--mut);background:rgba(3,6,12,.6);
  clip-path:polygon(4px 0,100% 0,calc(100% - 4px) 100%,0 100%);
}
.chip b{color:var(--cyan)}
.chip.hot{border-color:rgba(255,200,87,.38)}
.chip.hot b{color:var(--gold)}
.forecast{font-size:12px;line-height:1.65;color:var(--mut)}
.next-note{font-family:var(--font-d);font-size:9px;letter-spacing:.17em;color:#3b5878;margin-top:5px}
.next-note b{color:var(--cyan)}
.dmg-float{
  position:absolute;z-index:7;font-family:var(--font-n);font-weight:700;color:#fff;
  pointer-events:none;text-shadow:0 0 13px var(--blood),0 2px 4px #000;
}
.dmg-float.crit{color:var(--gold);text-shadow:0 0 18px var(--gold),0 2px 4px #000}
#joran-btn{
  position:absolute;bottom:12px;left:50%;transform:translateX(-50%);z-index:8;
  padding:11px 22px;background:rgba(255,61,104,.12);border:1px solid var(--blood);color:#ffd9e2;
  font-family:var(--font-d);font-size:10px;letter-spacing:.26em;font-weight:700;
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
  animation:pulse 2.2s infinite;transition:all .2s;
}
#joran-btn:hover{background:rgba(255,61,104,.28)}
#joran-btn b{color:#fff}

/* boss states */
#battle.lowhp .bar.hp .fill{animation:pulse 1.1s infinite}
#battle.lowhp #guardian-name{animation:pulse 1.6s infinite}
#battle.lowhp .forecast{color:var(--gold)}
#battle.bossfloor #aura{width:280px;height:280px}
#battle.bossfloor #guardian-visual{width:240px;height:240px}
#battle.bossfloor #zone-tag{color:var(--gold)}

/* ============ SESSION PANEL ============ */
#session-panel{padding:12px 13px 14px}
#session-head{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
#session-head .p-title{padding:0;border:none;margin-bottom:0}
#session-sub{font-size:11px;color:var(--mut);line-height:1.5}
#session-day{color:var(--cyan)}
#session-toggle{width:100%;font-size:13px}
#session-ex{display:flex;flex-direction:column;gap:9px}

.sx-card{
  border:1px solid var(--line);background:rgba(3,6,12,.45);padding:11px 12px;
  transition:border-color .2s,background .2s;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.sx-card.sx-done{border-color:rgba(111,224,168,.42);background:rgba(111,224,168,.04)}
.sx-card.sx-active{border-color:rgba(94,231,255,.45);box-shadow:0 0 12px rgba(94,231,255,.08)}
.sx-top{display:flex;align-items:baseline;gap:7px;margin-bottom:5px;flex-wrap:wrap}
.sx-top b{font-family:var(--font-d);font-size:14px;letter-spacing:.06em;color:#eaf6ff}
.sx-grp{font-family:var(--font-d);font-size:8px;letter-spacing:.2em;color:var(--mut)}
.sx-target{font-family:var(--font-n);font-size:12px;color:var(--cyan);margin-left:auto;white-space:nowrap;display:flex;align-items:center;gap:6px}
.sx-sets-badge{font-family:var(--font-d);font-size:9px;letter-spacing:.1em;color:var(--mut);background:rgba(255,255,255,.04);padding:2px 5px;border:1px solid var(--line)}
.sx-sets-badge.done{color:var(--green);border-color:rgba(111,224,168,.4);background:rgba(111,224,168,.08)}
.sx-rec{font-size:11px;color:#8aa0b5;line-height:1.5;margin-bottom:8px}
.sx-rec i{font-style:normal;color:var(--mut);font-family:var(--font-d);font-size:8px;letter-spacing:.16em}
.sx-deload{color:var(--gold);font-family:var(--font-d);font-size:9px;letter-spacing:.1em}

.sx-log{display:flex;gap:7px;align-items:stretch}
.sx-log input{
  flex:1;padding:12px 8px;background:rgba(3,6,12,.7);border:1px solid var(--line);
  color:#fff;font-family:var(--font-n);font-size:20px;text-align:center;
  min-width:0;min-height:48px;
}
.sx-log input:focus{outline:none;border-color:var(--cyan)}
.sx-log input.input-error{border-color:var(--red);animation:errShake .3s ease}
.sx-hit{
  flex:2;min-height:48px;
  background:linear-gradient(180deg,rgba(255,61,104,.22),rgba(255,61,104,.1));
  border:1px solid rgba(255,61,104,.55);color:#ff8fa8;font-family:var(--font-d);font-weight:700;
  letter-spacing:.18em;font-size:13px;transition:all .15s;
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
}
.sx-hit:hover,.sx-hit:active{background:rgba(255,61,104,.38);color:#fff;box-shadow:0 0 16px rgba(255,61,104,.28)}
.sx-hit:disabled{opacity:.4;cursor:default;box-shadow:none}

.sx-sets{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.sx-set{font-family:var(--font-n);font-size:11px;padding:2px 7px;border:1px solid var(--line);color:var(--mut)}
.sx-set.pr{border-color:var(--gold);color:var(--gold)}
.sx-prev{font-size:10px;color:var(--mut);margin-top:4px}

#session-foot{
  margin-bottom:12px;display:flex;flex-direction:column;gap:9px;
  border-bottom:1px solid var(--line);padding-bottom:12px;
}
#session-stats{
  display:flex;justify-content:space-between;
  font-family:var(--font-d);font-size:9px;letter-spacing:.13em;color:var(--mut);
}
#session-stats b{font-family:var(--font-n);font-size:16px;color:var(--cyan);margin-left:3px;letter-spacing:0}
.sstat-pr{color:var(--gold)}
.sstat-pr b{color:var(--gold)}
#session-end{width:100%}
#session-end.ready{border-color:var(--green);color:var(--green);animation:melduj-pulse 2.4s ease-in-out infinite}
@keyframes melduj-pulse{0%,100%{box-shadow:0 0 0 rgba(111,224,168,0)}50%{box-shadow:0 0 18px rgba(111,224,168,.3)}}
.sx-all-done{
  margin-top:14px;padding:14px 16px;border:1px solid rgba(111,224,168,.38);
  background:rgba(111,224,168,.05);display:flex;flex-direction:column;align-items:center;gap:10px;
}
.sx-all-done-label{color:var(--green);font-family:var(--font-d);font-size:11px;letter-spacing:.12em}
.sx-all-done .ghost-btn{width:100%;border-color:var(--green);color:var(--green)}
.sx-all-done .ghost-btn:hover{background:rgba(111,224,168,.09);box-shadow:0 0 18px rgba(111,224,168,.18)}

.sx-rest{padding:28px 16px;text-align:center;border:1px dashed rgba(93,114,135,.28);background:rgba(3,6,12,.3)}
.sx-rest-jp{display:block;font-family:var(--font-d);font-size:36px;color:var(--mut);margin-bottom:10px;opacity:.4}
.sx-rest-label{font-family:var(--font-d);font-size:9px;letter-spacing:.22em;color:var(--mut);margin-bottom:8px}
.sx-rest-note{font-size:12px;color:var(--mut);line-height:1.6;max-width:280px;margin:0 auto;opacity:.7}

/* ============ PLAN VIEW ============ */
#plan-week{display:grid;grid-template-columns:1fr;gap:9px;margin-bottom:6px}
.plan-day{padding:11px 13px}
.plan-day.today{border-color:var(--cyan);box-shadow:0 0 16px rgba(94,231,255,.1)}
.pd-head{font-family:var(--font-d);font-weight:700;font-size:12px;letter-spacing:.1em;color:#eaf6ff;margin-bottom:7px}
.plan-day.today .pd-head{color:var(--cyan)}
.pd-ex{display:flex;flex-direction:column;gap:4px}
.pd-ex span{display:flex;justify-content:space-between;gap:6px;font-size:11px;color:#8aa0b5}
.pd-ex i{font-style:normal;font-family:var(--font-n);color:var(--mut);white-space:nowrap}
.pd-rest{font-family:var(--font-d);font-size:9px;letter-spacing:.12em;color:var(--mut);font-style:normal}
.plan-day.past{opacity:.45}
.plan-day.rest-day .pd-head{color:var(--mut)}
.prog-row{padding:9px 13px;border-bottom:1px solid var(--line)}
.prog-row:last-child{border:0}
.prog-row.prog-today{border-left:2px solid var(--cyan);background:rgba(94,231,255,.03)}
.prog-h{display:flex;justify-content:space-between;align-items:baseline;gap:8px;flex-wrap:wrap}
.prog-h b{font-family:var(--font-d);font-size:12px;letter-spacing:.05em;color:#eaf6ff}
.prog-tag{font-family:var(--font-d);font-size:8px;letter-spacing:.18em;color:var(--cyan);border:1px solid var(--line-cyan);padding:1px 5px}
.prog-w{font-family:var(--font-n);font-size:13px;color:var(--cyan);white-space:nowrap;margin-left:auto}
.prog-note{font-size:11px;color:var(--mut);margin-top:3px;line-height:1.5}
.prog-trend{font-family:var(--font-n);font-size:10px;margin-left:4px;vertical-align:middle}
.prog-trend.up{color:var(--green)}
.prog-trend.stable{color:var(--mut)}
.prog-trend.down{color:var(--blood)}
.prog-trend.deload{color:var(--gold)}
.prog-trend.new{color:var(--cyan)}
.weak-row{padding:10px 12px;margin:7px;border-left:2px solid var(--blood);background:rgba(255,61,104,.06);font-size:12px;color:#ffb9c8;line-height:1.5}
.weak-row.zaniedbanie{border-color:var(--gold);background:rgba(255,200,87,.06);color:#ffe2a8}
.weak-row.stagnacja{border-color:var(--cyan);background:rgba(94,231,255,.04);color:#bfe6f2}
.weak-row.priority{border-color:#a06fff;background:rgba(160,111,255,.06);color:#d4bcff}
.prog-row.prog-weak{background:rgba(160,111,255,.04)}
.prog-tag.weak-tag{color:#a06fff;border-color:#a06fff}
.prog-other-toggle{
  padding:9px 13px;font-family:var(--font-d);font-size:8px;letter-spacing:.2em;
  color:var(--mut);cursor:pointer;border-top:1px solid var(--line);
  transition:color .15s;user-select:none;
}
.prog-other-toggle::before{content:'+ '}
.prog-other-toggle:hover{color:var(--cyan)}
.prog-other-toggle.open{color:var(--cyan)}
.prog-other-toggle.open::before{content:'− '}
.prog-other{overflow:hidden;max-height:0;transition:max-height .35s ease}
.prog-other.open{max-height:900px;transition-duration:.45s;transition-timing-function:ease-out}
.empty,.klog-empty{padding:26px 18px;text-align:center;color:var(--mut);font-size:12.5px;line-height:1.7;max-width:300px;margin:0 auto}
.klog-entry{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:9px 13px;border-bottom:1px solid var(--line);font-size:12px;color:#cfe3f0;border-left:2px solid transparent}
.klog-entry b{font-family:var(--font-d);letter-spacing:.05em}
.klog-entry i{font-style:normal;color:var(--mut);font-size:10px;margin-left:auto}
.klog-entry.has-pr{border-left-color:var(--gold)}
.klog-pr{color:var(--gold)}
.klog-floor{font-family:var(--font-d);font-size:9px;color:var(--mut);letter-spacing:.08em;border:1px solid rgba(93,114,135,.35);padding:1px 5px;border-radius:2px}
.klog-ex{flex-basis:100%;font-size:10px;color:var(--mut);letter-spacing:.03em;margin-top:-2px;padding-bottom:1px}
.klog-toggle{padding:9px 13px;font-size:11px;letter-spacing:.1em;color:var(--mut);cursor:pointer;border-top:1px solid var(--line);transition:color .15s}
.klog-toggle:hover{color:var(--acc)}
.klog-toggle::before{content:'+ '}
.klog-toggle.open::before{content:'− '}
.klog-rest{overflow:hidden;max-height:0;transition:max-height .35s ease}
.klog-rest.open{max-height:2400px;transition-duration:.5s;transition-timing-function:ease-out}
.klog-rest .klog-entry{opacity:.75}

/* ============ TOWER ============ */
/* CYTADELA: wieża wypełnia ekran i przewija się wewnętrznie (bez pustej przestrzeni pod) */
#view-cytadela.view.active{overflow:hidden}
#view-cytadela > .panel{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}
#view-cytadela > .panel > .p-title{flex-shrink:0}
#tower{display:flex;flex-direction:column;gap:5px;flex:1 1 auto;min-height:0;overflow-y:auto;padding:13px}
.tower-progress{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 12px 6px;font-family:var(--font-d);font-size:8px;letter-spacing:.22em;
  color:var(--mut);border-bottom:1px solid var(--line);margin-bottom:6px;
}
.tower-progress b{color:var(--blood);font-size:13px;font-family:var(--font-n)}
.floor-row{
  display:flex;align-items:center;gap:10px;padding:8px 12px;font-size:11px;
  border:1px solid transparent;background:rgba(3,6,12,.4);
  clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);
}
.floor-row .fnum{font-family:var(--font-n);font-weight:700;font-size:13px;min-width:30px;color:var(--mut)}
.floor-row .fname{flex:1;color:var(--mut);font-family:var(--font-d);font-size:11px;letter-spacing:.04em}
.floor-row .fstate{font-family:var(--font-d);font-size:7px;letter-spacing:.22em;color:var(--mut)}
.floor-hp-track{width:80px;height:4px;background:rgba(255,61,104,.15);border-radius:2px;flex-shrink:0}
.floor-hp-fill{height:100%;background:var(--blood);border-radius:2px;transition:width .4s}
.floor-row.cleared{border-color:rgba(var(--zone-rgb,111,224,168),.2)}
.floor-row.cleared .fnum{color:var(--zone-c,var(--green))}
.floor-row.current{border-color:rgba(255,61,104,.5);background:rgba(255,61,104,.06)}
.floor-row.current .fnum,.floor-row.current .fstate{color:var(--blood)}
.floor-row.current .fname{color:#fdeef2}
.floor-row.future{opacity:.3}
.floor-row.boss .fname{color:var(--gold)}
.zone-head{
  display:flex;align-items:center;gap:8px;padding:7px 12px;margin-top:4px;
  font-family:var(--font-d);font-size:8px;letter-spacing:.3em;color:var(--zone-c,var(--mut));
}
.zone-head::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(var(--zone-rgb,93,114,135),.3),transparent)}

/* ============ EKWIPUNEK — GEAR SLOTS ============ */
#gear-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px}
.gear-slot{display:flex;flex-direction:column;align-items:center;gap:7px}
.gs-label{font-family:var(--font-d);font-size:8px;letter-spacing:.22em;color:var(--mut)}
.gs-item{
  width:100%;min-height:88px;
  border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:8px 6px;text-align:center;
  transition:border-color .2s;
  position:relative;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.gs-item.has-item{border-color:rgba(94,231,255,.35);background:rgba(94,231,255,.03);cursor:pointer}
.gs-item.has-item:hover{border-color:var(--cyan);background:rgba(94,231,255,.07)}
.gs-empty{font-family:var(--font-d);font-size:8px;letter-spacing:.15em;color:#1f3044}
.gs-gear-jp{font-family:var(--font-j);font-size:22px;line-height:1;margin-bottom:4px}
.gs-gear-name{font-family:var(--font-d);font-size:8px;letter-spacing:.14em;line-height:1.4}
.gs-gear-tier{font-size:7px;letter-spacing:.18em;margin-top:3px;color:var(--mut)}
.gs-unequip{
  position:absolute;top:3px;right:3px;
  font-size:8px;font-family:var(--font-d);letter-spacing:.08em;
  color:var(--mut);background:transparent;border:none;padding:1px 3px;
  opacity:0;transition:opacity .15s;
}
.gs-item.has-item:hover .gs-unequip{opacity:1}

/* gear bag list */
#gear-list{padding:8px}
.gear-card{
  display:flex;align-items:center;gap:12px;
  padding:10px 13px;border-top:1px solid var(--line);cursor:pointer;
  transition:background .18s;
}
.gear-card:first-child{border-top:none}
.gear-card:hover{background:rgba(94,231,255,.04)}
.gear-card.equipped{background:rgba(94,231,255,.07);border-left:2px solid var(--cyan)}
.gc-jp{font-family:var(--font-j);font-size:22px;flex-shrink:0;line-height:1}
.gc-info{flex:1;min-width:0}
.gc-name{font-family:var(--font-d);font-size:11px;letter-spacing:.15em;color:var(--txt);margin-bottom:2px}
.gc-tier-slot{font-family:var(--font-d);font-size:8px;letter-spacing:.16em;color:var(--mut);margin-bottom:4px}
.gc-desc{font-size:12px;color:#7a9ab8;line-height:1.55}
.gc-badge{
  font-family:var(--font-d);font-size:7px;letter-spacing:.18em;
  padding:2px 7px;border:1px solid currentColor;flex-shrink:0;
}
.tier-common{color:#6a9aaa}
.tier-uncommon{color:#4dde99}
.tier-rare{color:#a06fff}
.tier-epic{color:#ff9b21}
.tier-legendary{color:#ff4455}

/* tutorial highlight pulse */
.tutorial-hl{
  outline:2px solid var(--cyan);
  box-shadow:0 0 18px rgba(94,231,255,.45),inset 0 0 14px rgba(94,231,255,.08);
  animation:pulse 1.4s ease-in-out infinite;
  z-index:999;
  position:relative;
}

/* ============ SOJUSZNICY ============ */
#soj-counters{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:4px}

/* ============ ARCHIWUM ============ */
#arch-counters{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px}
.arch-stat{padding:10px 6px;text-align:center}
.arch-stat b{display:block;font-family:var(--font-n);font-weight:700;font-size:18px;color:var(--cyan)}
.arch-stat span{font-family:var(--font-d);font-size:7px;letter-spacing:.18em;color:var(--mut)}
.note-row{padding:13px 15px;border-top:1px solid var(--line);cursor:default;transition:background .2s}
.note-row:first-child{border-top:none}
.note-row:hover{background:rgba(94,231,255,.03)}
.note-row .nr-head{display:flex;gap:9px;align-items:baseline;margin-bottom:5px}
.note-row .nr-author{font-family:var(--font-d);font-size:11px;letter-spacing:.18em;color:var(--cyan)}
.note-row .nr-author.echo{color:#6b7886}
.note-row .nr-floor{font-family:var(--font-d);font-size:8px;letter-spacing:.16em;color:var(--mut)}
.note-row .nr-body{font-size:13px;color:#9db4c8;line-height:1.75;white-space:pre-line}
.note-row.locked .nr-author{color:#22364a}
.note-row.locked .nr-body{color:#22364a;letter-spacing:.07em}
/* zablokowane zapiski — zwarty jednowierszowy rząd */
.note-row.locked.compact{display:flex;justify-content:space-between;align-items:center;padding:9px 15px}
.note-row.locked.compact .nr-author{color:#3a5066;font-size:10px}
.note-row.locked.compact .nr-floor{color:#22364a}
.dict-row{padding:12px 15px;border-top:1px solid var(--line)}
.dict-row:first-child{border-top:none}
.dict-row .d-name{font-family:var(--font-d);font-size:11px;letter-spacing:.2em;color:var(--gold)}
.dict-row .d-jp{font-family:var(--font-j);font-size:11px;color:var(--mut);margin-left:7px}
.dict-row .d-expl{font-size:13px;color:#9db4c8;line-height:1.72;margin-top:5px}

/* ============ BESTIARIUSZ ============ */
.beast-row{display:flex;gap:14px;padding:13px 15px;border-top:1px solid var(--line);align-items:flex-start}
.beast-row:first-child{border-top:none}
.beast-row.beast-boss{background:rgba(255,200,87,.03)}
.beast-seal{font-family:var(--font-j);font-size:26px;line-height:1;min-width:34px;padding-top:2px;opacity:.85}
.beast-info{flex:1;min-width:0}
.beast-head{display:flex;align-items:baseline;gap:10px;margin-bottom:5px;flex-wrap:wrap}
.beast-name{font-family:var(--font-d);font-size:11px;letter-spacing:.18em}
.beast-meta{font-family:var(--font-d);font-size:8px;letter-spacing:.16em;color:var(--mut)}
.beast-desc{font-size:13px;color:#9db4c8;line-height:1.75}

/* ============ MICRO GOALS ============ */
#micros{border-top:1px solid var(--line);margin-bottom:8px}
#micros:empty{display:none}
.micro{padding:7px 13px;border-bottom:1px solid var(--line)}
.micro:last-child{border-bottom:none}
.micro-first{padding:6px 13px;font-size:10px;color:var(--gold);border-bottom:1px solid var(--line);letter-spacing:.04em;opacity:.85}
.mhead{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.mname{font-size:10.5px;color:var(--mut);line-height:1.4;flex:1}
.mval{font-family:var(--font-n);font-size:11px;color:var(--cyan);white-space:nowrap}
.micro.done .mname{color:var(--green)}
.micro.done .mval{color:var(--green)}
.micro .bar{height:4px}
.micro .bar .fill{background:linear-gradient(90deg,rgba(94,231,255,.35),var(--cyan))}
.micro.done .bar .fill{background:linear-gradient(90deg,rgba(111,224,168,.35),var(--green))}

/* flash po zalogowaniu serii */
.sx-card.just-hit{
  border-color:rgba(255,61,104,.65)!important;
  background:rgba(255,61,104,.08)!important;
}

/* ============ WREN (szuflada) ============ */
#wren{display:flex;flex-direction:column}
#wren-head{display:flex;align-items:center;gap:10px;padding:13px 14px;border-bottom:1px solid var(--line)}
.wren-head-txt{flex:1;min-width:0}
.w-ava{
  width:30px;height:30px;border:1px solid var(--line-cyan);display:flex;align-items:center;justify-content:center;flex-shrink:0;
  clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);background:rgba(94,231,255,.05);
}
.w-ava span{width:8px;height:8px;background:var(--cyan);box-shadow:0 0 10px var(--cyan);border-radius:50%;animation:pulse 2.8s infinite}
#wren-head b{display:block;font-family:var(--font-d);font-size:13px;letter-spacing:.38em;color:#eaf6ff}
#wren-head i{font-family:var(--font-d);font-style:normal;font-size:7px;letter-spacing:.18em;color:var(--mut)}
#wren-feed{flex:1;overflow-y:auto;padding:13px;display:flex;flex-direction:column;gap:8px;min-height:0}
#wren-feed:empty::before{content:'WREN // INICJALIZACJA';display:block;padding:12px 14px;color:var(--mut);font-family:var(--font-d);font-size:8px;letter-spacing:.22em;opacity:.45}
.wmsg{
  padding:10px 12px;background:rgba(3,6,12,.6);border:1px solid var(--line);border-left:2px solid var(--cyan);
  font-size:13px;line-height:1.6;color:#b9cede;
}
.wmsg.user{border-left-color:#3a4a5e;color:#7e93a8}
.wren-typing{padding:12px 14px}
.wt-dots{display:inline-flex;gap:5px;align-items:center}
.wt-dots i{width:6px;height:6px;border-radius:50%;background:var(--cyan);opacity:.3;animation:wtblink 1.2s infinite}
.wt-dots i:nth-child(2){animation-delay:.2s}
.wt-dots i:nth-child(3){animation-delay:.4s}
@keyframes wtblink{0%,60%,100%{opacity:.25}30%{opacity:1}}
.wmsg .wtime{display:block;font-family:var(--font-d);font-size:7px;color:var(--mut);margin-top:5px;letter-spacing:.15em}
#wren-inputrow{display:flex;gap:7px;padding:9px 11px;border-top:1px solid var(--line)}
#wren-input{flex:1;padding:10px 12px;background:rgba(3,6,12,.8);border:1px solid var(--line);color:var(--txt);font-size:16px;font-family:var(--font-b)}
#wren-input:focus{outline:none;border-color:var(--cyan)}
#wren-send{padding:10px 13px;border:1px solid var(--line);background:transparent;color:var(--mut);font-size:11px;transition:all .2s}
#wren-send:hover{color:var(--cyan);border-color:var(--line-cyan)}

/* ============ TOASTS ============ */
#toasts{
  position:fixed;top:calc(var(--top-h) + 7px);right:11px;z-index:80;
  display:flex;flex-direction:column;gap:7px;pointer-events:none;
  max-width:min(300px,calc(100vw - 22px));
}
.toast{
  padding:10px 13px;background:rgba(6,10,20,.96);
  border:1px solid var(--line);border-left:3px solid var(--cyan);
  clip-path:polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px);
}
.toast .t-head{font-family:var(--font-d);font-size:8px;letter-spacing:.26em;color:var(--cyan);margin-bottom:3px}
.toast .t-body{font-size:12.5px;color:var(--txt);line-height:1.5}
.toast.red{border-left-color:var(--blood)}.toast.red .t-head{color:var(--blood)}
.toast.gold{border-left-color:var(--gold)}.toast.gold .t-head{color:var(--gold)}
.toast.green{border-left-color:var(--green)}.toast.green .t-head{color:var(--green)}

/* ============ MODAL ============ */
#modal-overlay{
  position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;
  background:rgba(2,3,8,.9);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:14px;
}
#modal{width:100%;max-width:520px;padding:32px 22px;text-align:center}
.m-jp{font-family:var(--font-j);font-weight:300;font-size:40px;letter-spacing:.35em;color:var(--blood);text-indent:.35em;
  text-shadow:0 0 32px rgba(255,61,104,.48);margin-bottom:11px}
#modal h2{font-family:var(--font-d);font-size:20px;letter-spacing:.2em;color:#eaf6ff;margin-bottom:4px}
.m-sub{font-family:var(--font-d);font-size:9px;letter-spacing:.38em;color:var(--blood);margin-bottom:20px}
.m-body{font-size:13.5px;line-height:1.9;color:#9db4c8;text-align:left;white-space:pre-line;min-height:55px}
#modal .cta-btn{margin-top:22px;width:100%}
.wall-names{font-family:var(--font-d);letter-spacing:.26em;line-height:2.2;text-align:center;color:#7e93a8}
.wall-names .you{color:var(--gold);text-shadow:0 0 16px rgba(255,200,87,.42);animation:pulse 2s infinite}

/* ============ LEVEL UP FX ============ */
#lvlfx{position:fixed;inset:0;z-index:95;display:flex;align-items:center;justify-content:center;pointer-events:none}
#lvlfx .ring{position:absolute;width:100px;height:100px;border:2px solid var(--gold);border-radius:50%}
#lvlfx .txt{font-family:var(--font-d);font-weight:700;font-size:44px;letter-spacing:.36em;color:var(--gold);text-shadow:0 0 42px rgba(255,200,87,.75);text-indent:.36em}

/* ============ OVERLAYS ============ */
#note-overlay{
  position:fixed;inset:0;z-index:92;display:flex;align-items:flex-end;justify-content:center;
  background:rgba(2,3,8,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
#note-paper{width:100%;max-height:88vh;overflow-y:auto;padding:26px 20px 36px;background:rgba(10,13,20,.98)}
#note-paper .n-found{font-family:var(--font-d);font-size:9px;letter-spacing:.48em;color:var(--gold);margin-bottom:16px;animation:pulse 2.4s infinite}
#note-paper .n-author{font-family:var(--font-d);font-weight:700;font-size:18px;letter-spacing:.2em;color:#eaf6ff}
#note-paper .n-author.echo{color:#6b7886;letter-spacing:.36em}
#note-paper .n-floor{font-family:var(--font-d);font-size:8px;letter-spacing:.26em;color:var(--mut);margin:4px 0 20px}
#note-paper .n-body{font-size:14.5px;line-height:1.95;color:#c5d6e4;white-space:pre-line;border-left:2px solid rgba(148,170,196,.17);padding-left:16px}
#note-paper .n-body.echo{color:#8b96a3;border-left-color:rgba(176,140,255,.2)}
#note-paper .cta-btn{margin-top:24px;width:100%}

#offer-overlay{
  position:fixed;inset:0;z-index:93;display:flex;align-items:flex-end;justify-content:center;
  background:rgba(250,252,255,.05);backdrop-filter:blur(14px) brightness(1.5);-webkit-backdrop-filter:blur(14px) brightness(1.5);
}
#offer-box{width:100%;padding:34px 20px 44px;text-align:center;background:rgba(8,10,16,.97);border-top:1px solid rgba(242,246,255,.18);clip-path:none}
#offer-box .o-jp{font-family:var(--font-j);font-weight:300;font-size:44px;letter-spacing:.28em;color:#f2f6ff;text-indent:.28em;text-shadow:0 0 42px rgba(242,246,255,.48);margin-bottom:11px}
#offer-box h2{font-family:var(--font-d);font-size:20px;letter-spacing:.24em;color:#fff;margin-bottom:3px}
#offer-box .o-domain{font-family:var(--font-d);font-size:9px;letter-spacing:.46em;color:#8fa3bd;margin-bottom:20px}
#offer-box .o-body{font-size:13.5px;line-height:1.9;color:#c5d6e4;text-align:left;white-space:pre-line}
#offer-box .o-btns{display:flex;flex-direction:column;gap:9px;margin-top:26px}
#offer-box #offer-accept{border-color:rgba(148,170,196,.2);color:#5d7287;font-size:10px}
#offer-box #offer-accept:hover{border-color:#f2f6ff;color:#f2f6ff}

/* ============ FINALE ============ */
#finale{
  position:fixed;inset:0;z-index:96;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:30px;background:var(--void);padding:22px;
}
#fin-bird{width:100px;height:100px;opacity:0}
#fin-bird svg{width:100%;height:100%;filter:drop-shadow(0 0 18px rgba(94,231,255,.52))}
#fin-text{width:100%;max-width:560px;font-size:17px;line-height:2.1;color:#dcebf7;text-align:center;white-space:pre-line}
#fin-btn{margin-top:8px}

/* ============ MISC ============ */
#daily-banner{
  margin-bottom:11px;padding:10px 13px;border:1px solid rgba(255,200,87,.38);
  background:rgba(255,200,87,.07);font-size:12.5px;color:#ffe2a8;line-height:1.55;
  font-family:var(--font-d);letter-spacing:.06em;
}
#demo-tag{display:none}
/* sekcja DANE w szufladzie POSTAĆ */
.char-data{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:16px;padding-top:13px;border-top:1px solid var(--line);
}
.char-data-label{font-family:var(--font-d);font-size:8px;letter-spacing:.26em;color:var(--mut)}
#reset-btn{flex-shrink:0}

/* ============ TUTORIAL OVERLAY ============ */
#tutorial-overlay{
  position:fixed;bottom:calc(var(--tab-h) + 14px);left:0;right:0;
  z-index:90;display:flex;justify-content:center;
  padding:0 12px;pointer-events:none;
}
#tutorial-overlay.hidden{display:none}
#tutorial-box{
  background:rgba(3,6,13,.96);border:1px solid var(--line-cyan);
  padding:16px 18px 14px;max-width:520px;width:100%;
  pointer-events:all;
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  box-shadow:0 0 30px rgba(94,231,255,.18);
}
#tutorial-step-label{font-family:var(--font-d);font-size:8px;letter-spacing:.26em;color:var(--cyan);margin-bottom:9px}
#tutorial-text{font-size:13.5px;color:#b9cede;line-height:1.75;min-height:42px;margin-bottom:13px}
#tutorial-btns{display:flex;gap:10px;justify-content:flex-end}
#tutorial-progress{
  display:flex;gap:5px;justify-content:center;margin-top:11px;
}
.tutorial-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--line);transition:background .2s;
}
.tutorial-dot.active{background:var(--cyan)}


/* ============================================================
   SKRZYNKI I KLUCZE (CS:GO mechanic)
============================================================ */

/* ---- INVENTORY PANEL (in ARCHIWUM) ---- */
.inv-keys{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  font-family:var(--font-d);font-size:13px;letter-spacing:.08em;
  border-bottom:1px solid var(--line);
}
.ik-label{color:var(--mut);font-size:11px;letter-spacing:.12em}
.ik-count{font-size:22px;color:var(--gold);line-height:1}
.ik-hint{color:var(--mut);font-size:11px}
.inv-buy-key{margin:8px 14px 4px;font-size:11px;letter-spacing:.08em}
.inv-buy-key:disabled{opacity:.35;cursor:default;box-shadow:none}

.inv-cases{
  display:flex;flex-wrap:wrap;gap:10px;
  padding:12px 14px;
}
.inv-case{
  flex:1 1 130px;max-width:180px;
  background:rgba(0,0,0,.35);
  border:1px solid var(--cc, var(--line));
  border-radius:4px;
  padding:12px 10px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  text-align:center;
}
.ic-jp{
  font-family:var(--font-j);font-size:28px;line-height:1;
  color:var(--cc,var(--cyan));
  text-shadow:0 0 16px var(--cc,var(--cyan));
}
.ic-name{
  font-family:var(--font-d);font-size:10px;letter-spacing:.1em;
  color:var(--cc,var(--txt));line-height:1.3;
}
.ic-open{
  margin-top:4px;padding:5px 10px;font-size:10px;
  border-color:var(--cc,var(--line));
  color:var(--cc,var(--txt));
}
.ic-open:not([disabled]):hover{
  background:color-mix(in srgb,var(--cc,var(--cyan)) 12%,transparent);
}
.inv-empty{color:var(--mut);font-size:13px;padding:10px 14px}

.inv-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  border-left:3px solid var(--ic,var(--cyan));
  border-bottom:1px solid var(--line);
  font-family:var(--font-d);
}
.inv-item:last-child{border-bottom:none}
.ii-tier{font-size:9px;letter-spacing:.14em;color:var(--ic,var(--cyan));min-width:72px}
.ii-name{font-size:13px;color:var(--txt);flex:1}
.ii-desc{font-size:11px;color:var(--mut)}

/* ---- SKLEP ---- */
.shop-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  transition:background .2s;
}
.shop-item:last-child{border-bottom:none}
.shop-item.active{background:rgba(255,255,255,.03)}
.si-jp{
  font-family:var(--font-j);font-size:28px;line-height:1;
  color:var(--si,var(--cyan));
  text-shadow:0 0 14px var(--si,var(--cyan));
  min-width:36px;text-align:center;padding-top:2px;
}
.si-info{flex:1;min-width:0}
.si-name{
  display:block;
  font-family:var(--font-d);font-size:12px;letter-spacing:.1em;
  color:var(--si,var(--txt));margin-bottom:4px;
}
.si-desc{display:block;font-size:11px;color:var(--mut);line-height:1.5}
.si-active{
  display:inline-block;margin-top:4px;
  font-family:var(--font-d);font-size:9px;letter-spacing:.14em;
  color:var(--si,var(--cyan));
  border:1px solid var(--si,var(--cyan));
  padding:1px 6px;border-radius:2px;
}
.si-buy{
  flex-shrink:0;padding:5px 10px;font-size:10px;
  border-color:var(--si,var(--line));color:var(--si,var(--txt));
}
.si-buy:not([disabled]):hover{
  background:color-mix(in srgb,var(--si,var(--cyan)) 12%,transparent);
}
.si-buy:disabled{opacity:.3;cursor:default;box-shadow:none}

/* ---- INKUBATOR ---- */
.egg-card{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  border-bottom:1px solid var(--line);
}
.egg-card:last-child{border-bottom:none}
.egg-card.ready{background:rgba(255,255,255,.04);border-bottom-color:var(--ec,var(--cyan));box-shadow:0 0 0 1px var(--ec,var(--cyan)) inset;animation:egg-pulse 2s ease-in-out infinite}
@keyframes egg-pulse{0%,100%{opacity:1}50%{opacity:.75}}
.egg-jp{
  font-family:var(--font-j);font-size:30px;line-height:1;
  color:var(--ec,var(--cyan));
  text-shadow:0 0 16px var(--ec,var(--cyan));
  min-width:38px;text-align:center;
}
.egg-info{flex:1;min-width:0}
.egg-name{
  display:block;
  font-family:var(--font-d);font-size:12px;letter-spacing:.1em;
  color:var(--ec,var(--txt));margin-bottom:2px;
}
.egg-type{display:block;font-size:10px;color:var(--mut);letter-spacing:.08em;margin-bottom:6px}
.egg-bar{
  height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;margin-bottom:4px;
}
.egg-fill{height:100%;background:var(--ec,var(--cyan));border-radius:2px;transition:width .3s}
.egg-progress{font-size:10px;color:var(--mut);font-family:var(--font-d);letter-spacing:.06em}
.egg-card.ready .egg-progress{color:var(--ec,var(--cyan))}
.egg-hatch{
  flex-shrink:0;padding:6px 12px;font-size:10px;
  border-color:var(--ec,var(--cyan));color:var(--ec,var(--cyan));
}
.egg-hatch:hover{background:color-mix(in srgb,var(--ec,var(--cyan)) 12%,transparent)}

/* ---- TOWARZYSZE ---- */
.comp-card{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  border-left:3px solid var(--compc,var(--cyan));
}
.comp-card:last-child{border-bottom:none}
.comp-jp{
  font-family:var(--font-j);font-size:28px;line-height:1;
  color:var(--compc,var(--cyan));
  text-shadow:0 0 14px var(--compc,var(--cyan));
  min-width:36px;text-align:center;
}
.comp-info{flex:1;min-width:0}
.comp-name{
  display:block;
  font-family:var(--font-d);font-size:12px;letter-spacing:.1em;
  color:var(--compc,var(--txt));margin-bottom:2px;
}
.comp-rarity{
  display:inline-block;
  font-size:9px;letter-spacing:.14em;color:var(--compc,var(--mut));
  border:1px solid var(--compc,var(--line));
  padding:1px 5px;border-radius:2px;margin-bottom:4px;
}
.comp-bonus{display:block;font-size:11px;color:var(--mut);line-height:1.4}
.comp-card.locked{opacity:.4;border-left-color:var(--line)}
.comp-locked-jp{filter:grayscale(1);opacity:.55}
.comp-locked-name{color:var(--line)}
/* zablokowani towarzysze — zwarta siatka kafli */
.comp-locked-head{
  font-family:var(--font-d);font-size:8px;letter-spacing:.2em;color:var(--mut);
  padding:10px 2px 2px;margin-top:2px;border-top:1px solid var(--line);
}
.comp-locked-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;padding:2px}
.comp-tile{
  display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 4px 9px;
  border:1px solid var(--line);border-top:2px solid color-mix(in srgb,var(--compc,var(--line)) 55%,transparent);
  background:rgba(3,6,12,.4);opacity:.62;
  clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px);
}
.comp-tile-jp{font-family:var(--font-j);font-size:26px;line-height:1;filter:grayscale(1);opacity:.7;color:var(--compc,var(--mut))}
.comp-tile-name{font-size:8px;letter-spacing:.06em;color:var(--mut);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.comp-tile-rar{font-family:var(--font-d);font-size:6.5px;letter-spacing:.08em;color:var(--mut);text-align:center;opacity:.6}

/* ---- CASE OPENING OVERLAY ---- */
#case-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(4,6,13,.97);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:24px;padding:20px;
}
#case-header{text-align:center}
.case-jp{
  font-family:var(--font-j);font-size:48px;line-height:1;
  color:var(--cyan);text-shadow:0 0 24px var(--cyan);
  margin-bottom:6px;
}
.case-title{
  font-family:var(--font-d);font-size:14px;letter-spacing:.2em;
  color:var(--txt);
}
.case-status{
  font-family:var(--font-d);font-size:11px;letter-spacing:.14em;
  color:var(--mut);margin-top:4px;
}

#case-reel-wrap{
  width:100%;max-width:600px;
  overflow:hidden;
  position:relative;
  padding:4px 0;
  border-top:2px solid var(--cyan);
  border-bottom:2px solid var(--cyan);
}
.reel-marker{
  position:absolute;top:0;bottom:0;left:50%;
  width:2px;background:#fff;opacity:.7;
  transform:translateX(-50%);z-index:2;pointer-events:none;
}
#case-reel{
  display:flex;gap:6px;
  padding:8px 0;
  will-change:transform;
  backface-visibility:hidden;
}
.case-card{
  flex:0 0 110px;height:130px;
  background:rgba(10,14,24,.9);
  border:1px solid var(--cc,var(--line));
  border-radius:4px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:5px;padding:8px;text-align:center;
  transition:box-shadow .3s;
  font-family:var(--font-d);
}
.case-card.winner{border-color:var(--cc,var(--cyan))}
.case-card.glow{
  box-shadow:0 0 28px var(--cc,var(--cyan));
  border-color:var(--cc,var(--cyan));
  background:color-mix(in srgb,var(--cc,var(--cyan)) 8%,rgba(10,14,24,.95));
}
.cc-tier{font-size:9px;letter-spacing:.14em;color:var(--cc,var(--cyan))}
.cc-name{font-size:12px;font-weight:700;color:var(--txt);line-height:1.2}
.cc-desc{font-size:10px;color:var(--mut);line-height:1.3}

#case-result{
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  animation:fadeUp .4s ease both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.cr-tier{font-family:var(--font-d);font-size:11px;letter-spacing:.18em}
.cr-name{font-family:var(--font-d);font-size:22px;letter-spacing:.08em;color:var(--txt)}
.cr-desc{font-size:13px;color:var(--mut)}
#case-result .cta-btn{margin-top:6px}

/* ============================================================
   SZUFLADY — POSTAĆ (z lewej) i WREN (z dołu)
============================================================ */
/* UWAGA: pozycja sterowana wyłącznie klasą .open (natychmiast) — NIGDY transition,
   bo kompozytor/rAF zamarza w tle i szuflada utknęłaby w pozycji zamkniętej.
   Płynny wjazd dodaje GSAP jako wzbogacenie (transform + clearProps). */
.drawer{
  position:fixed;z-index:85;background:rgba(7,11,20,.98);
  display:flex;flex-direction:column;
}
.drawer-left{
  top:0;bottom:0;left:0;width:min(87vw,370px);
  border-right:1px solid var(--line-cyan);
  transform:translateX(-101%);
  padding:14px 15px calc(14px + env(safe-area-inset-bottom,0px));
}
.drawer-bottom{
  left:0;right:0;bottom:0;height:min(74vh,580px);
  border-top:1px solid var(--line-cyan);
  transform:translateY(101%);
}
/* jedna reguła otwarcia dla obu osi — brak niejednoznaczności kaskady */
.drawer.open{transform:translate(0,0);box-shadow:0 0 50px rgba(0,0,0,.6)}

.drawer-backdrop{
  position:fixed;inset:0;z-index:84;background:rgba(2,3,8,.66);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
  display:none;
}
.drawer-backdrop.open{display:block}

.drawer-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding-bottom:12px;border-bottom:1px solid var(--line);margin-bottom:14px;flex-shrink:0;
}
#wren-head.drawer-head,#wren #wren-head{margin-bottom:0}
.drawer-title{font-family:var(--font-d);font-size:12px;letter-spacing:.3em;color:var(--cyan)}
.drawer-close{
  width:30px;height:30px;flex-shrink:0;border:1px solid var(--line);background:transparent;
  color:var(--mut);font-size:13px;transition:all .18s;
  clip-path:polygon(6px 0,100% 0,calc(100% - 6px) 100%,0 100%);
}
.drawer-close:active,.drawer-close:hover{color:var(--blood);border-color:var(--blood)}
.drawer-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}
.drawer-body::-webkit-scrollbar{width:4px}
.drawer-body::-webkit-scrollbar-thumb{background:rgba(94,231,255,.25);border-radius:2px}

#wren-inputrow{flex-shrink:0;padding-bottom:calc(9px + env(safe-area-inset-bottom,0px))}

/* ============================================================
   PODNAWIGACJA — segmenty wewnątrz ciężkich widoków
   (każda sekcja = osobna pełnoekranowa karta)
============================================================ */
.subnav{
  display:flex;gap:6px;flex-shrink:0;
  position:sticky;top:0;z-index:6;
  background:linear-gradient(180deg,rgba(4,7,14,.98) 70%,rgba(4,7,14,0));
  padding:0 0 9px;margin:0 0 1px;
}
.subtab{
  flex:1;padding:10px 4px;border:1px solid var(--line);background:rgba(3,6,12,.5);
  color:var(--mut);font-family:var(--font-d);font-size:9px;font-weight:600;letter-spacing:.14em;
  clip-path:polygon(7px 0,100% 0,calc(100% - 7px) 100%,0 100%);transition:all .18s;position:relative;
}
.subtab:active,.subtab:hover{color:var(--txt)}
.subtab.active{border-color:var(--line-cyan);background:rgba(94,231,255,.09);color:var(--cyan)}
.subtab .sub-badge{
  display:inline-block;margin-left:5px;font-family:var(--font-n);font-size:9px;
  color:var(--gold);letter-spacing:0;
}
.subview{display:none;flex-direction:column;gap:11px}
/* animacja TYLKO transform — opacity nigdy, bo rAF zamarza w tle i karta zniknęłaby */
.subview.active{display:flex;animation:subfade .3s ease both}
@keyframes subfade{from{transform:translateY(10px)}to{transform:none}}
