/* ============================================================
   LOST PIECE — PLAYER HUB  |  styles.css
   ============================================================ */
:root {
  --c-bg:#07080f;--c-gold:#d4a017;--c-gold-light:#f5c842;
  --c-text:#e8dcc8;--c-text-dim:#8a7e6a;
  --c-panel:rgba(255,255,255,0.025);--c-border:rgba(212,160,23,0.18);
  --c-uncommon:#4caf7d;--mrp-w:295px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--c-bg);color:var(--c-text);font-family:'Lato',sans-serif;min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;z-index:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(10,30,70,.55) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(20,5,50,.45) 0%,transparent 60%),linear-gradient(180deg,#07080f 0%,#040d1c 40%,#060810 100%);pointer-events:none;}
.particles{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.particle{position:absolute;border-radius:50%;background:rgba(212,160,23,.15);animation:float linear infinite;}
@keyframes float{0%{transform:translateY(110vh) scale(0);opacity:0;}10%{opacity:1;}90%{opacity:.6;}100%{transform:translateY(-10vh) scale(1);opacity:0;}}
.view{display:none;position:relative;z-index:10;animation:fadeIn .4s ease;}
.view.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.site-header{position:relative;z-index:20;text-align:center;padding:44px 20px 28px;}
.header-ornament{font-size:11px;letter-spacing:6px;color:var(--c-gold);text-transform:uppercase;opacity:.75;margin-bottom:12px;}
.site-header h1{font-family:'Cinzel Decorative',serif;font-size:clamp(22px,4.5vw,46px);font-weight:900;background:linear-gradient(135deg,#d4a017,#f5c842,#d4a017);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:2px;line-height:1.25;}
.header-sub{font-family:'Cinzel',serif;font-size:12px;letter-spacing:5px;color:var(--c-text-dim);margin-top:10px;text-transform:uppercase;}
.header-line{width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--c-gold),transparent);margin:16px auto 0;}
.breadcrumb-bar{position:relative;z-index:20;display:flex;align-items:center;justify-content:center;gap:10px;padding:0 20px 24px;font-family:'Cinzel',serif;font-size:11px;letter-spacing:3px;color:var(--c-text-dim);text-transform:uppercase;}
.bc-home{color:var(--c-gold);cursor:pointer;display:flex;align-items:center;gap:6px;transition:opacity .2s;}
.bc-home:hover{opacity:.7;}.bc-sep{opacity:.35;}.bc-current{color:var(--c-text);}
/* HOME */
.hub-wrap{max-width:900px;margin:0 auto;padding:10px 24px 60px;}
.hub-greeting{text-align:center;margin-bottom:48px;}
.hub-greeting p{font-size:15px;color:var(--c-text-dim);line-height:1.8;max-width:560px;margin:0 auto;}
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;}
.hub-card{position:relative;background:linear-gradient(160deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.01) 100%);border:1px solid var(--c-border);border-radius:18px;overflow:hidden;cursor:pointer;padding:32px 28px 28px;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;box-shadow:0 0 40px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.04);}
.hub-card::before{content:'';position:absolute;inset:0;border-radius:18px;background:radial-gradient(ellipse at 50% 0%,rgba(212,160,23,.05) 0%,transparent 65%);pointer-events:none;}
.hub-card::after{content:'';position:absolute;top:0;left:15%;right:15%;height:2px;background:var(--card-accent,var(--c-gold));border-radius:0 0 4px 4px;filter:blur(.8px);box-shadow:0 0 12px var(--card-accent,var(--c-gold));}
.hub-card:hover{transform:translateY(-5px);border-color:var(--card-accent,var(--c-gold));box-shadow:0 12px 50px rgba(0,0,0,.7),0 0 28px var(--card-glow,rgba(212,160,23,.15));}
.hub-card.coming-soon{opacity:.55;cursor:default;pointer-events:none;}
.hub-card .soon-badge{position:absolute;top:14px;right:14px;font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;padding:3px 10px;border-radius:20px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--c-text-dim);}
.hub-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;background:var(--card-icon-bg,rgba(212,160,23,.1));border:1px solid var(--card-accent,rgba(212,160,23,.2));box-shadow:0 0 18px var(--card-glow,rgba(212,160,23,.15));overflow:hidden;}
.hub-card-icon svg{width:28px;height:28px;}
.hub-icon-img{width:40px;height:40px;object-fit:contain;display:block;}
.hub-card-title{font-family:'Cinzel Decorative',serif;font-size:15px;font-weight:700;color:var(--c-text);margin-bottom:8px;line-height:1.3;}
.hub-card-desc{font-size:13px;color:var(--c-text-dim);line-height:1.7;}
.hub-card-arrow{margin-top:22px;font-family:'Cinzel',serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--card-accent,var(--c-gold));display:flex;align-items:center;gap:8px;opacity:.7;transition:opacity .2s,gap .2s;}
.hub-card:hover .hub-card-arrow{opacity:1;gap:12px;}
/* TOOLS */
.tools-wrap{max-width:900px;margin:0 auto;padding:0 24px 60px;}
.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;}
.section-heading{font-family:'Cinzel',serif;font-size:11px;letter-spacing:5px;color:var(--c-text-dim);text-transform:uppercase;margin-bottom:20px;text-align:center;}
/* DEVIL FRUITS */
.gallery-wrap{position:relative;z-index:10;max-width:860px;margin:0 auto;padding:0 20px 20px;}
.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
.fruit-counter{font-family:'Cinzel',serif;font-size:13px;color:var(--c-text-dim);letter-spacing:2px;}
.fruit-counter span{color:var(--c-gold);font-weight:600;}
.rarity-badge{font-family:'Cinzel',serif;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;padding:5px 14px;border-radius:20px;border:1px solid currentColor;transition:all .4s ease;}
.df-card{background:linear-gradient(160deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);border:1px solid rgba(212,160,23,.2);border-radius:20px;overflow:hidden;position:relative;box-shadow:0 0 60px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.05);}
.df-card::before{content:'';position:absolute;inset:0;border-radius:20px;background:radial-gradient(ellipse at 50% 0%,rgba(212,160,23,.06) 0%,transparent 60%);pointer-events:none;}
.df-card::after{content:'';position:absolute;top:0;left:10%;right:10%;height:2px;background:var(--rarity-color,var(--c-gold));border-radius:0 0 4px 4px;filter:blur(1px);box-shadow:0 0 12px var(--rarity-color,var(--c-gold));}
.df-card.slide-out-left{animation:slideOutLeft .28s forwards;}
.df-card.slide-out-right{animation:slideOutRight .28s forwards;}
.df-card.slide-in-left{animation:slideInLeft .32s forwards;}
.df-card.slide-in-right{animation:slideInRight .32s forwards;}
@keyframes slideOutLeft{to{transform:translateX(-60px);opacity:0;}}
@keyframes slideOutRight{to{transform:translateX(60px);opacity:0;}}
@keyframes slideInLeft{from{transform:translateX(60px);opacity:0;}to{transform:none;opacity:1;}}
@keyframes slideInRight{from{transform:translateX(-60px);opacity:0;}to{transform:none;opacity:1;}}
.card-inner{display:grid;grid-template-columns:1fr 1fr;}
@media(max-width:600px){.card-inner{grid-template-columns:1fr;}}
.card-image-side{position:relative;min-height:360px;display:flex;align-items:center;justify-content:center;padding:30px;background:linear-gradient(135deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.15) 100%);border-right:1px solid rgba(255,255,255,.05);}
.fruit-image-wrap{position:relative;width:220px;height:220px;border-radius:50%;box-shadow:0 0 40px rgba(0,0,0,.6),0 0 0 3px rgba(212,160,23,.3);transition:box-shadow .5s ease;background:#0a0a18;display:flex;align-items:center;justify-content:center;overflow:visible;}
.fruit-img-inner{width:100%;height:100%;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#0a0a18;}
.fruit-img-inner img{width:90%;height:90%;object-fit:contain;object-position:center;display:block;transition:opacity .35s ease;}
.fruit-img-inner img.loading{opacity:0;}
.fruit-img-inner img.loaded{opacity:1;}
.fruit-image-wrap::after{content:'';position:absolute;inset:-4px;border-radius:50%;background:transparent;box-shadow:0 0 26px 6px var(--glow,rgba(212,160,23,.3));animation:pulse 3s ease-in-out infinite;pointer-events:none;}
@keyframes pulse{0%,100%{opacity:.45;}50%{opacity:1;}}
.card-number-bg{position:absolute;bottom:16px;left:16px;font-family:'Cinzel Decorative',serif;font-size:72px;font-weight:900;color:rgba(255,255,255,.04);line-height:1;user-select:none;}
.card-info-side{padding:32px 28px 28px;display:flex;flex-direction:column;}
.fruit-id{font-family:'Cinzel',serif;font-size:11px;letter-spacing:4px;color:var(--c-text-dim);margin-bottom:4px;}
.fruit-name{font-family:'Cinzel Decorative',serif;font-size:clamp(15px,2.6vw,24px);font-weight:700;color:var(--c-text);line-height:1.2;margin-bottom:4px;}
.fruit-name-suffix{font-family:'Cinzel',serif;font-size:12px;color:var(--c-text-dim);letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;}
.divider{width:100%;height:1px;background:linear-gradient(90deg,rgba(212,160,23,.3),transparent);margin:14px 0;}
.price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:16px;}
.price-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--c-text-dim);}
.price-value{font-family:'Cinzel',serif;font-size:18px;font-weight:600;color:var(--c-gold-light,#f5c842);}
.section-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--c-text-dim);margin-bottom:8px;}
.buff-value{font-size:14px;font-weight:700;color:#6ee7b7;background:rgba(110,231,183,.08);border:1px solid rgba(110,231,183,.2);border-radius:8px;padding:6px 12px;display:inline-block;margin-bottom:16px;}
.buff-value.unknown{color:var(--c-text-dim);background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.08);}
.attacks-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;}
.attack-pill{font-size:12px;padding:4px 11px;border-radius:20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:var(--c-text);letter-spacing:.5px;transition:background .2s,border-color .2s;}
.attack-pill:hover{background:rgba(212,160,23,.12);border-color:rgba(212,160,23,.3);}
.attack-pill.unknown{color:var(--c-text-dim);font-style:italic;}
.info-box{flex:1;min-height:60px;background:rgba(255,255,255,.02);border:1px dashed rgba(255,255,255,.08);border-radius:10px;padding:12px 14px;font-size:13px;line-height:1.7;color:var(--c-text-dim);font-style:italic;}
.nav-row{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:28px;}
.nav-btn{width:52px;height:52px;border-radius:50%;border:1px solid rgba(212,160,23,.35);background:rgba(212,160,23,.08);color:var(--c-gold);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;backdrop-filter:blur(4px);}
.nav-btn:hover:not(:disabled){background:rgba(212,160,23,.18);border-color:var(--c-gold);transform:scale(1.08);box-shadow:0 0 20px rgba(212,160,23,.3);}
.nav-btn:disabled{opacity:.25;cursor:default;}
.slider-wrap{max-width:640px;margin:28px auto 0;padding:0 4px;}
.slider-info-row{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px;}
.slider-fruit-name{font-family:'Cinzel',serif;font-size:13px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--c-text);transition:color .3s ease;text-align:center;}
.slider-count-badge{font-family:'Cinzel',serif;font-size:10px;letter-spacing:2px;color:var(--c-text-dim);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:3px 10px;white-space:nowrap;}
.slider-count-badge strong{color:var(--c-gold);}
.slider-track-wrap{position:relative;height:24px;display:flex;align-items:center;}
.slider-track-bg{position:absolute;left:0;right:0;height:6px;border-radius:6px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.06);}
.slider-track-fill{position:absolute;left:0;height:6px;border-radius:6px;background:linear-gradient(90deg,var(--c-gold-dark,#8a6509),var(--rarity-slider,var(--c-gold)));box-shadow:0 0 8px var(--rarity-slider,rgba(212,160,23,.5));width:var(--fill,0%);transition:width .2s ease,background .4s ease;pointer-events:none;}
input[type=range].df-slider{-webkit-appearance:none;appearance:none;position:absolute;left:0;right:0;width:100%;height:24px;background:transparent;outline:none;cursor:pointer;margin:0;}
input[type=range].df-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:linear-gradient(145deg,#f5c842,#b87800);border:2px solid rgba(255,255,255,.25);box-shadow:0 0 14px var(--rarity-slider,rgba(212,160,23,.7)),0 2px 8px rgba(0,0,0,.6);cursor:grab;transition:transform .15s,box-shadow .15s;}
input[type=range].df-slider:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.15);}
input[type=range].df-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:linear-gradient(145deg,#f5c842,#b87800);border:2px solid rgba(255,255,255,.25);box-shadow:0 0 14px rgba(212,160,23,.7);cursor:grab;}
.slider-ticks{display:flex;justify-content:space-between;margin-top:10px;padding:0 2px;align-items:flex-end;height:14px;}
.slider-ticks span{flex:1;display:flex;justify-content:center;cursor:pointer;}
.slider-ticks span::before{content:'';display:block;width:2px;height:5px;border-radius:2px;background:currentColor;opacity:.25;transition:height .2s,opacity .2s;}
.slider-ticks span.t-active::before{height:12px;opacity:1;}
/* PUZZLE */
.puzzle-wrap{max-width:720px;margin:0 auto;padding:0 24px 60px;}
.puzzle-howto{background:var(--c-panel);border:1px solid var(--c-border);border-radius:14px;padding:20px 24px;margin-bottom:32px;font-size:13px;color:var(--c-text-dim);line-height:1.85;}
.puzzle-howto strong{color:var(--c-gold);font-family:'Cinzel',serif;letter-spacing:1px;}
.puzzle-status-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:12px;flex-wrap:wrap;}
.puzzle-next-label{font-family:'Cinzel',serif;font-size:13px;letter-spacing:3px;color:var(--c-text-dim);text-transform:uppercase;margin-bottom:2px;}
.puzzle-next-num{font-family:'Cinzel Decorative',serif;font-size:28px;font-weight:900;background:linear-gradient(135deg,var(--c-gold),var(--c-gold-light,#f5c842));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.puzzle-next-box{display:flex;align-items:center;gap:16px;}
.puzzle-done-msg{font-family:'Cinzel',serif;font-size:14px;letter-spacing:2px;color:var(--c-uncommon);display:none;}
.puzzle-done-msg.visible{display:block;}
.puzzle-actions{display:flex;gap:10px;}
.pz-btn{font-family:'Cinzel',serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;padding:8px 20px;border-radius:30px;border:1px solid rgba(212,160,23,.35);background:rgba(212,160,23,.08);color:var(--c-gold);cursor:pointer;transition:all .2s ease;}
.pz-btn:hover{background:rgba(212,160,23,.18);border-color:var(--c-gold);box-shadow:0 0 18px rgba(212,160,23,.25);}
.pz-btn.danger{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.07);color:#f87171;}
.pz-btn.danger:hover{background:rgba(239,68,68,.15);border-color:#f87171;box-shadow:0 0 18px rgba(239,68,68,.2);}
.puzzle-grid-outer{background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border:1px solid var(--c-border);border-radius:20px;padding:28px;box-shadow:0 0 60px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.04);position:relative;}
.puzzle-grid-outer::after{content:'';position:absolute;top:0;left:15%;right:15%;height:2px;background:var(--c-gold);border-radius:0 0 4px 4px;filter:blur(1px);box-shadow:0 0 12px var(--c-gold);}
.puzzle-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.pz-cell{aspect-ratio:1;border-radius:12px;border:1.5px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:border-color .2s,transform .15s,box-shadow .2s,background .2s;user-select:none;}
.pz-cell:hover:not(.filled){border-color:rgba(212,160,23,.5);background:rgba(212,160,23,.06);transform:scale(1.04);box-shadow:0 0 18px rgba(212,160,23,.15);}
.pz-cell.filled{background:rgba(212,160,23,.12);border-color:rgba(212,160,23,.55);box-shadow:inset 0 0 20px rgba(212,160,23,.08),0 0 14px rgba(212,160,23,.2);cursor:default;animation:cellPop .25s cubic-bezier(.36,.07,.19,.97);}
@keyframes cellPop{0%{transform:scale(.88);opacity:.5;}60%{transform:scale(1.08);}100%{transform:scale(1);opacity:1;}}
.pz-cell.last-filled{border-color:var(--c-gold-light,#f5c842);box-shadow:inset 0 0 24px rgba(245,200,66,.15),0 0 22px rgba(245,200,66,.35);}
.pz-cell-number{font-family:'Cinzel Decorative',serif;font-size:clamp(11px,2vw,18px);font-weight:900;background:linear-gradient(135deg,var(--c-gold),var(--c-gold-light,#f5c842));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:0;transition:opacity .25s ease;line-height:1;}
.pz-cell.filled .pz-cell-number{opacity:1;}
.pz-cell-glow{position:absolute;inset:0;border-radius:11px;background:radial-gradient(circle at 50% 50%,rgba(212,160,23,.18) 0%,transparent 70%);opacity:0;transition:opacity .25s;pointer-events:none;}
.pz-cell.filled .pz-cell-glow{opacity:1;}
.puzzle-sequence{margin-top:26px;background:var(--c-panel);border:1px dashed rgba(255,255,255,.08);border-radius:12px;padding:18px 20px;}
.puzzle-sequence-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--c-text-dim);margin-bottom:12px;}
.sequence-pills{display:flex;flex-wrap:wrap;gap:7px;min-height:30px;}
.seq-pill{font-family:'Cinzel',serif;font-size:11px;letter-spacing:1px;padding:4px 12px;border-radius:20px;background:rgba(212,160,23,.1);border:1px solid rgba(212,160,23,.25);color:var(--c-gold-light,#f5c842);animation:pillIn .2s ease;}
@keyframes pillIn{from{transform:scale(.8);opacity:0;}to{transform:scale(1);opacity:1;}}
.seq-empty{font-size:12px;color:rgba(138,126,106,.4);font-style:italic;letter-spacing:1px;}
/* MAP */
.map-tab-bar{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;gap:10px;padding:0 24px 20px;}
.map-tab{font-family:'Cinzel',serif;font-size:12px;font-weight:600;letter-spacing:3px;text-transform:uppercase;padding:9px 22px;border-radius:30px;cursor:pointer;display:flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--c-text-dim);transition:all .25s ease;}
.map-tab:hover:not(.disabled){background:rgba(255,255,255,.07);color:var(--c-text);border-color:rgba(255,255,255,.2);}
.map-tab.active{background:rgba(212,160,23,.1);border-color:rgba(212,160,23,.45);color:var(--c-gold);box-shadow:0 0 18px rgba(212,160,23,.12);}
.map-tab.disabled{opacity:.4;cursor:default;}
.map-tab-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;opacity:.8;}
.map-tab-soon{font-size:8px;letter-spacing:2px;padding:2px 7px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:var(--c-text-dim);}
.map-layout{position:relative;z-index:10;display:flex;flex-direction:row;height:calc(100vh - 285px);min-height:500px;margin:0 24px 40px;border-radius:18px;overflow:hidden;border:1px solid var(--c-border);box-shadow:0 0 60px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.04);}
#leaflet-map{flex:1;min-width:0;height:100%;background-color:#040d1c;background-image:linear-gradient(rgba(212,160,23,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(212,160,23,.035) 1px,transparent 1px);background-size:60px 60px;}
/* RIGHT PANEL */
.map-right-panel{width:var(--mrp-w);flex-shrink:0;height:100%;display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(5,7,18,.97) 0%,rgba(4,8,16,.98) 100%);border-left:1px solid var(--c-border);position:relative;overflow:hidden;}
.map-right-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 5%,var(--c-gold) 50%,transparent 95%);filter:blur(.5px);box-shadow:0 0 10px rgba(212,160,23,.4);}
.mrp-header{padding:18px 18px 14px;display:flex;align-items:center;gap:8px;font-family:'Cinzel',serif;font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--c-gold);opacity:.85;flex-shrink:0;}
.mrp-section{padding:0 18px 16px;flex-shrink:0;}
.mrp-section-title{font-family:'Cinzel',serif;font-size:10px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--c-text-dim);display:flex;align-items:center;gap:7px;margin-bottom:14px;}
.mrp-cat-row{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;border-radius:10px;margin-bottom:6px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:background .2s,border-color .2s;user-select:none;}
.mrp-cat-row:hover{background:rgba(255,255,255,.055);}
.mrp-cat-row.active{border-color:rgba(255,255,255,.1);}
.mrp-cat-left{display:flex;align-items:center;gap:9px;flex:1;min-width:0;}
.mrp-cat-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.mrp-cat-label{font-family:'Cinzel',serif;font-size:11px;font-weight:600;letter-spacing:1.5px;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mrp-cat-count{font-family:'Lato',sans-serif;font-size:10px;color:var(--c-text-dim);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:1px 7px;flex-shrink:0;margin-left:6px;}
.mrp-toggle{width:36px;height:20px;border-radius:10px;flex-shrink:0;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);position:relative;cursor:pointer;transition:background .25s ease,border-color .25s ease,box-shadow .25s ease;}
.mrp-toggle.on{background:var(--toggle-color,var(--c-gold));border-color:var(--toggle-color,var(--c-gold));box-shadow:0 0 10px var(--toggle-glow,rgba(212,160,23,.35));}
.mrp-toggle-knob{position:absolute;top:3px;left:3px;width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.5);transition:transform .25s cubic-bezier(.4,0,.2,1),background .25s;}
.mrp-toggle.on .mrp-toggle-knob{transform:translateX(16px);background:white;}
.mrp-pin-count{font-size:11px;color:var(--c-text-dim);letter-spacing:1px;padding:8px 12px 0;font-family:'Lato',sans-serif;}
.mrp-pin-count strong{color:var(--c-gold);font-weight:700;}
.mrp-rule{height:1px;flex-shrink:0;margin:4px 18px 16px;background:linear-gradient(90deg,transparent,rgba(212,160,23,.25),transparent);}
.mrp-details-section{flex:1;overflow-y:auto;padding:0 18px 20px;scrollbar-width:thin;scrollbar-color:rgba(212,160,23,.25) transparent;}
.mrp-details-section::-webkit-scrollbar{width:3px;}
.mrp-details-section::-webkit-scrollbar-track{background:transparent;}
.mrp-details-section::-webkit-scrollbar-thumb{background:rgba(212,160,23,.25);border-radius:3px;}
.mrp-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:32px 20px;color:var(--c-text-dim);text-align:center;}
.mrp-empty-icon{opacity:.35;}
.mrp-empty-text{font-family:'Cinzel',serif;font-size:11px;letter-spacing:2px;line-height:1.7;text-transform:uppercase;color:var(--c-text-dim);opacity:.7;}
.mrp-loc-content{display:flex;flex-direction:column;gap:0;}
.mrp-loc-img-wrap{position:relative;width:100%;height:148px;border-radius:12px;overflow:hidden;background:rgba(0,0,0,.4);margin-bottom:14px;flex-shrink:0;}
#mrp-loc-img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .4s;}
#mrp-loc-img.hidden{opacity:0;}
.mrp-loc-img-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--c-text-dim);background:rgba(4,13,28,.8);border-radius:12px;}
.mrp-loc-img-placeholder.hidden{display:none;}
.mrp-loc-body{display:flex;flex-direction:column;gap:0;}
.mrp-loc-meta-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.mrp-loc-badge{font-family:'Cinzel',serif;font-size:9px;font-weight:600;letter-spacing:3px;text-transform:uppercase;padding:2px 9px;border-radius:20px;border:1px solid currentColor;white-space:nowrap;}
.mrp-loc-category{font-family:'Cinzel',serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--c-text-dim);}
.mrp-loc-name{font-family:'Cinzel Decorative',serif;font-size:clamp(13px,1.5vw,17px);font-weight:700;color:var(--c-text);line-height:1.25;margin-bottom:2px;}
.mrp-loc-rule{height:1px;background:linear-gradient(90deg,rgba(212,160,23,.25),transparent);margin:10px 0;}
.mrp-loc-desc{font-size:12px;color:var(--c-text-dim);line-height:1.75;}
.mrp-tips-wrap{margin-top:12px;}
.mrp-tips-title{font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--c-gold);opacity:.8;display:flex;align-items:center;gap:5px;margin-bottom:8px;}
.mrp-tips-list{list-style:none;display:flex;flex-direction:column;gap:5px;}
.mrp-tips-list li{font-size:11px;color:var(--c-text-dim);line-height:1.6;padding-left:14px;position:relative;}
.mrp-tips-list li::before{content:'▸';position:absolute;left:0;color:var(--c-gold);opacity:.55;font-size:9px;top:1px;}
/* PINS — Teardrop */
.map-pin{position:relative;display:flex;flex-direction:column;align-items:center;}
.map-pin-teardrop{width:44px;height:56px;background:var(--pin-color,#d4a017);clip-path:path('M22 2 C11 2, 2 11, 2 22 C2 37, 22 55, 22 55 C22 55, 42 37, 42 22 C42 11, 33 2, 22 2 Z');display:flex;justify-content:center;padding-top:5px;flex-shrink:0;transition:transform .22s cubic-bezier(.34,1.56,.64,1),filter .2s ease;filter:drop-shadow(0 5px 10px rgba(0,0,0,.55));cursor:pointer;}
.map-pin-circle{width:32px;height:32px;border-radius:50%;border:2.5px solid rgba(255,255,255,.65);overflow:hidden;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.18);flex-shrink:0;}
.map-pin-cat-icon{width:16px;height:16px;color:white;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.map-pin-cat-icon svg{width:16px;height:16px;}
.map-pin-custom-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.map-pin:hover .map-pin-teardrop{transform:translateY(-6px) scale(1.12);filter:drop-shadow(0 10px 18px rgba(0,0,0,.65));}
.map-pin.selected .map-pin-teardrop{transform:translateY(-8px) scale(1.16);filter:drop-shadow(0 12px 22px rgba(0,0,0,.7));}
.map-pin.selected .map-pin-circle{border-color:white;box-shadow:0 0 0 2px rgba(255,255,255,.35);}
.map-pin-label{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);white-space:nowrap;font-family:'Cinzel',serif;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--c-text);background:rgba(5,7,18,.92);border:1px solid var(--c-border);backdrop-filter:blur(8px);padding:4px 10px;border-radius:8px;pointer-events:none;opacity:0;transition:opacity .18s ease;z-index:10;}
.map-pin-label::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:rgba(212,160,23,.35);}
.map-pin:hover .map-pin-label,.map-pin.selected .map-pin-label{opacity:1;}
/* Leaflet overrides */
.leaflet-bar{border:1px solid rgba(212,160,23,.3)!important;border-radius:10px!important;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.6)!important;}
.leaflet-bar a{background:rgba(5,7,20,.92)!important;color:var(--c-gold)!important;border-bottom-color:rgba(212,160,23,.2)!important;font-size:16px!important;font-weight:300!important;width:32px!important;height:32px!important;line-height:32px!important;transition:background .2s!important;}
.leaflet-bar a:hover{background:rgba(212,160,23,.15)!important;color:var(--c-gold-light,#f5c842)!important;}
.leaflet-bar a:last-child{border-bottom:none!important;}
.leaflet-control-attribution{background:rgba(5,7,15,.75)!important;color:rgba(138,126,106,.45)!important;font-family:'Lato',sans-serif!important;font-size:9px!important;letter-spacing:1px!important;backdrop-filter:blur(6px)!important;border-radius:6px 0 0 0!important;padding:3px 8px!important;}
.leaflet-control-attribution a{color:rgba(212,160,23,.45)!important;}
.leaflet-container{background:transparent!important;}
@media(max-width:800px){.map-layout{flex-direction:column;height:auto;min-height:unset;}#leaflet-map{width:100%;height:55vw;min-height:280px;max-height:55vh;}.map-right-panel{width:100%;height:auto;min-height:260px;max-height:55vh;border-left:none;border-top:1px solid var(--c-border);}.map-right-panel::before{top:0;left:15%;right:15%;}}
/* FOOTER */
.site-footer{position:relative;z-index:10;padding:50px 20px 56px;text-align:center;}
.footer-line{width:200px;height:1px;background:linear-gradient(90deg,transparent,rgba(212,160,23,.4),transparent);margin:0 auto 40px;}
.footer-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:6px;color:var(--c-text-dim);text-transform:uppercase;margin-bottom:32px;opacity:.6;}
.footer-circles{display:flex;justify-content:center;align-items:flex-start;gap:40px;flex-wrap:wrap;}
.footer-circle-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;}
.footer-circle{width:82px;height:82px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;text-decoration:none;cursor:default;transition:transform .25s ease,box-shadow .25s ease;}
a.footer-circle{cursor:pointer;}
a.footer-circle:hover{transform:translateY(-5px) scale(1.1);}
.fc-discord{background:linear-gradient(145deg,#5865f2,#404eed);box-shadow:0 0 0 2px rgba(88,101,242,.5),0 8px 28px rgba(88,101,242,.4);}
a.fc-discord:hover{box-shadow:0 0 0 3px rgba(88,101,242,.9),0 14px 40px rgba(88,101,242,.6);}
.fc-user{background:linear-gradient(145deg,#1c1c38,#2c2c5a);box-shadow:0 0 0 2px rgba(212,160,23,.45),0 8px 28px rgba(212,160,23,.2);position:relative;}
.fc-avatar-img{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:50%;display:block;flex-shrink:0;}
.fc-avatar-img.fc-avatar-error{display:none;}
.fc-avatar-svg{display:none;width:36px;height:36px;flex-shrink:0;}
.fc-avatar-img.fc-avatar-error~.fc-avatar-svg{display:block;}
.fc-server{background:linear-gradient(145deg,#0e2016,#1c4830);box-shadow:0 0 0 2px rgba(78,205,114,.45),0 8px 28px rgba(78,205,114,.2);}
.footer-circle-info{display:flex;flex-direction:column;align-items:center;gap:4px;}
.circle-label{font-family:'Cinzel',serif;font-size:12px;letter-spacing:1px;color:var(--c-text);text-align:center;max-width:115px;line-height:1.5;font-weight:600;}
.circle-sublabel{font-family:'Lato',sans-serif;font-size:10px;color:var(--c-text-dim);letter-spacing:2px;text-transform:uppercase;text-align:center;}
.footer-copy{margin-top:44px;font-size:11px;color:rgba(138,126,106,.3);letter-spacing:2px;font-family:'Cinzel',serif;}
/* ============================================================
   LEVEL CALCULATORS — Single page layout
   ============================================================ */

.calc-page-wrap {
  max-width: 600px;
  margin: 0 auto;
  padding: 0 24px 60px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.calc-card {
  background: linear-gradient(160deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.01) 100%);
  border: 1px solid var(--c-border);
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 0 60px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.04);
}
.calc-card::after {
  content: '';
  position: absolute;
  top: 0; left: 15%; right: 15%; height: 2px;
  background: var(--c-gold);
  border-radius: 0 0 4px 4px;
  filter: blur(0.8px);
  box-shadow: 0 0 12px var(--c-gold);
}
.calc-card-soon { opacity: 0.55; }

.calc-card-header {
  display: flex; align-items: center; gap: 14px;
  padding: 24px 24px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.calc-card-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid; flex-shrink: 0;
}
.calc-card-title {
  font-family: 'Cinzel Decorative', serif;
  font-size: 15px; font-weight: 700;
  color: var(--c-text); line-height: 1.3;
}
.calc-card-sub {
  font-size: 11px; color: var(--c-text-dim);
  letter-spacing: 1px; margin-top: 2px;
}
.calc-card-body { padding: 22px 24px 28px; }
.calc-row { margin-bottom: 16px; }
.calc-label {
  display: block; font-family: 'Cinzel', serif;
  font-size: 10px; letter-spacing: 3px;
  text-transform: uppercase; color: var(--c-text-dim); margin-bottom: 7px;
}
.calc-optional { opacity: 0.5; font-style: italic; letter-spacing: 1px; }
.calc-input {
  width: 100%; padding: 10px 14px; border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  color: var(--c-text); font-family: 'Lato', sans-serif;
  font-size: 14px; outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.calc-input:focus {
  border-color: rgba(212,160,23,0.5);
  box-shadow: 0 0 12px rgba(212,160,23,0.12);
}
.calc-input::placeholder { color: rgba(138,126,106,0.4); }
.calc-input-sm { width: 80px; padding: 7px 10px; font-size: 13px; text-align: center; }

.calc-btn {
  width: 100%; padding: 12px; margin-top: 6px;
  border-radius: 12px; border: 1px solid rgba(212,160,23,0.4);
  background: rgba(212,160,23,0.1); color: var(--c-gold);
  font-family: 'Cinzel', serif; font-size: 12px; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase;
  cursor: pointer; transition: all 0.2s ease;
}
.calc-btn:hover {
  background: rgba(212,160,23,0.18); border-color: var(--c-gold);
  box-shadow: 0 0 18px rgba(212,160,23,0.2);
}

.calc-result {
  margin-top: 18px; padding: 16px 18px; border-radius: 12px;
  background: rgba(110,231,183,0.06);
  border: 1px solid rgba(110,231,183,0.2);
}
.calc-result-title {
  font-family: 'Cinzel', serif; font-size: 10px;
  letter-spacing: 3px; text-transform: uppercase;
  color: #6ee7b7; margin-bottom: 8px;
}
.calc-result-value {
  font-family: 'Cinzel Decorative', serif;
  font-size: clamp(18px, 3vw, 26px); font-weight: 900;
  color: var(--c-gold-light, #f5c842); line-height: 1.2; margin-bottom: 4px;
}
.calc-result-desc {
  font-size: 12px; color: var(--c-text-dim);
  line-height: 1.6; margin-top: 4px;
}

.calc-toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; margin-bottom: 16px; border-radius: 10px;
  background: rgba(168,85,247,0.06); border: 1px solid rgba(168,85,247,0.2);
  cursor: pointer; user-select: none; transition: background 0.2s;
}
.calc-toggle-row:hover { background: rgba(168,85,247,0.1); }
.calc-toggle-left { display: flex; flex-direction: column; gap: 2px; }
.calc-toggle-label { font-family: 'Cinzel', serif; font-size: 12px; font-weight: 600; color: var(--c-text); letter-spacing: 1px; }
.calc-toggle-hint { font-size: 10px; color: var(--c-text-dim); }

.calc-switch { position: relative; width: 40px; height: 22px; display: block; flex-shrink: 0; }
.calc-switch input { display: none; }
.calc-switch-slider {
  position: absolute; inset: 0; border-radius: 11px;
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.1);
  cursor: pointer; transition: background 0.25s, border-color 0.25s, box-shadow 0.25s;
}
.calc-switch-slider::before {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 14px; height: 14px; border-radius: 50%;
  background: rgba(255,255,255,0.5);
  transition: transform 0.25s cubic-bezier(0.4,0,0.2,1), background 0.25s;
}
.calc-switch input:checked + .calc-switch-slider {
  background: #a855f7; border-color: #a855f7;
  box-shadow: 0 0 10px rgba(168,85,247,0.35);
}
.calc-switch input:checked + .calc-switch-slider::before {
  transform: translateX(18px); background: white;
}

.calc-shard-section { margin-top: 20px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.06); }
.calc-shard-title {
  font-family: 'Cinzel', serif; font-size: 10px; font-weight: 600;
  letter-spacing: 3px; text-transform: uppercase; color: var(--c-text-dim);
  display: flex; align-items: center; gap: 7px; margin-bottom: 12px;
}
.calc-shard-auto {
  padding: 14px 16px; border-radius: 10px;
  background: rgba(255,255,255,0.025);
  border: 1px dashed rgba(255,255,255,0.08);
  font-size: 12px; color: var(--c-text-dim); line-height: 1.9;
}
.calc-shard-auto strong { color: var(--c-gold-light, #f5c842); font-weight: 700; }
.calc-shard-divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent); margin: 16px 0; }
.calc-shard-inputs { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.calc-shard-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.calc-shard-label { font-family: 'Cinzel', serif; font-size: 12px; font-weight: 600; color: var(--c-text); letter-spacing: 1px; }
.calc-shard-xp { font-family: 'Lato', sans-serif; font-size: 10px; color: var(--c-text-dim); font-weight: 400; }
.calc-shard-result {
  padding: 12px 14px; border-radius: 10px;
  background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.06);
  font-size: 13px; color: var(--c-text-dim); line-height: 1.7; min-height: 40px;
}
.calc-shard-result strong { color: var(--c-gold-light, #f5c842); }
.calc-shard-result .xp-covered { color: #6ee7b7; }
.calc-shard-result .xp-remaining { color: #f97316; }

/* ── Clickable breadcrumb links ── */
.breadcrumb-bar {
  display: flex;
  align-items: center;
  justify-content: center;
}
#breadcrumb-items {
  display: flex;
  align-items: center;
  gap: 0;
}
.bc-link {
  color: var(--c-gold);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: opacity 0.2s;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
}
.bc-link:hover { opacity: 0.7; }
.bc-link svg { flex-shrink: 0; }
.bc-sep-item {
  margin: 0 8px;
  opacity: 0.35;
  color: var(--c-text-dim);
  font-size: 11px;
}
.bc-current-item {
  color: var(--c-text);
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
}
/* ── Calc layout: input rows + field note ── */
.calc-input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:4px;}
.calc-field{}
.calc-field-btn{display:flex;flex-direction:column;}
@media(max-width:480px){.calc-input-row{grid-template-columns:1fr;}}
.calc-field-note{margin-top:2px;margin-bottom:10px;font-size:11px;color:var(--c-text-dim);letter-spacing:.5px;min-height:16px;}

/* ── Max Level button ── */
.calc-max-btn{width:100%;padding:10px 14px;border-radius:10px;border:1px solid rgba(212,160,23,.35);background:rgba(212,160,23,.08);color:var(--c-gold);font-family:'Cinzel',serif;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;white-space:nowrap;}
.calc-max-btn:hover{background:rgba(212,160,23,.16);border-color:var(--c-gold);box-shadow:0 0 14px rgba(212,160,23,.2);}

/* ── Rize credit ── */
.calc-card-credit{font-size:10px;color:var(--c-text-dim);margin-top:3px;letter-spacing:1px;opacity:.7;}

/* ── Info box ── */
.calc-info-box{padding:18px 20px;border-radius:14px;background:rgba(255,255,255,.02);border:1px dashed rgba(255,255,255,.08);}
.calc-info-title{font-family:'Cinzel',serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--c-gold);margin-bottom:8px;opacity:.8;}
.calc-info-box p{font-size:12px;color:var(--c-text-dim);line-height:1.75;margin:0;}

/* ── Nerd Mode toggle ── */
.nerd-toggle-bar{display:flex;justify-content:flex-end;margin-bottom:14px;grid-column:1/-1;}
.nerd-toggle-btn{display:flex;align-items:center;gap:7px;padding:7px 16px;border-radius:20px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--c-text-dim);font-family:'Cinzel',serif;font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.nerd-toggle-btn:hover{background:rgba(255,255,255,.08);color:var(--c-text);border-color:rgba(255,255,255,.2);}
.nerd-toggle-btn.active{background:rgba(212,160,23,.1);border-color:rgba(212,160,23,.4);color:var(--c-gold);box-shadow:0 0 14px rgba(212,160,23,.12);}

/* ── Nerd Mode layout ── */
.calc-page-wrap{max-width:600px;margin:0 auto;padding:0 24px 60px;display:flex;flex-direction:column;gap:20px;}
.calc-main-col{display:flex;flex-direction:column;gap:20px;}
.calc-side-col{display:none;flex-direction:column;gap:20px;}
.calc-page-wrap.nerd-active{max-width:1100px;display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.calc-page-wrap.nerd-active .nerd-toggle-bar{grid-column:1/-1;}
.calc-page-wrap.nerd-active .calc-main-col{min-width:0;}
.calc-page-wrap.nerd-active .calc-side-col{display:flex!important;}
.hk-nerd-table{max-height:500px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(236,72,153,.25) transparent;}
.hk-nerd-table::-webkit-scrollbar{width:4px;}
.hk-nerd-table::-webkit-scrollbar-thumb{background:rgba(236,72,153,.25);border-radius:4px;}
.nerd-table-wrap{max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(212,160,23,.25) transparent;}
.nerd-table-wrap::-webkit-scrollbar{width:4px;}
.nerd-table-wrap::-webkit-scrollbar-thumb{background:rgba(212,160,23,.25);border-radius:4px;}
.nerd-table-row{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:8px;padding:6px 10px;font-size:11px;color:var(--c-text-dim);border-bottom:1px solid rgba(255,255,255,.04);}
.nerd-table-row:hover{background:rgba(212,160,23,.04);}
.nerd-table-row strong{color:var(--c-text);font-weight:700;}
.nerd-table-head{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:8px;padding:8px 10px;font-family:'Cinzel',serif;font-size:8px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--c-text-dim);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;background:rgba(5,7,18,.95);z-index:1;}
@media(max-width:800px){.calc-page-wrap.nerd-active{grid-template-columns:1fr;}}

/* ── Haki runs + ice + table ── */
.hk-runs-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;}
.hk-run-card{padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);text-align:center;}
.hk-run-label{font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--c-text-dim);margin-bottom:6px;}
.hk-run-value{font-family:'Cinzel Decorative',serif;font-size:clamp(18px,3vw,24px);font-weight:900;color:var(--c-gold-light,#f5c842);line-height:1.2;}
.hk-run-sub{font-size:10px;color:var(--c-text-dim);margin-top:4px;}
.hk-ice-section{margin-top:16px;padding:14px 16px;border-radius:12px;background:rgba(236,72,153,.04);border:1px solid rgba(236,72,153,.15);}
.hk-ice-result{margin-top:10px;font-size:13px;color:var(--c-text-dim);}
.hk-ice-result span:first-child{font-weight:700;color:var(--c-gold-light,#f5c842);}
.hk-table-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9998;opacity:0;pointer-events:none;transition:opacity .3s ease;}
.hk-table-overlay.open{opacity:1;pointer-events:auto;}
.hk-table-panel{position:fixed;top:0;right:0;width:min(440px,90vw);height:100vh;z-index:9999;background:linear-gradient(180deg,rgba(5,7,18,.98),rgba(4,8,16,.99));border-left:1px solid var(--c-border);box-shadow:-8px 0 40px rgba(0,0,0,.7);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
.hk-table-panel.open{transform:translateX(0);}
.hk-table-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 5%,#ec4899 50%,transparent 95%);filter:blur(.5px);box-shadow:0 0 10px rgba(236,72,153,.4);}
.hk-table-panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;}
.hk-table-close{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--c-text-dim);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.hk-table-close:hover{background:rgba(236,72,153,.12);border-color:rgba(236,72,153,.35);color:#ec4899;}
.hk-table-scroll{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(236,72,153,.25) transparent;}
.hk-table-scroll::-webkit-scrollbar{width:4px;}
.hk-table-scroll::-webkit-scrollbar-thumb{background:rgba(236,72,153,.25);border-radius:4px;}
.hk-table{width:100%;}
.hk-table-head{display:grid;grid-template-columns:.6fr .6fr 1.1fr .9fr 1.1fr;gap:8px;padding:12px 16px;font-family:'Cinzel',serif;font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--c-text-dim);background:rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:1;}
.hk-table-row{display:grid;grid-template-columns:.6fr .6fr 1.1fr .9fr 1.1fr;gap:8px;padding:8px 16px;font-size:12px;color:var(--c-text-dim);border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s;}
.hk-table-row:hover{background:rgba(236,72,153,.04);}
.hk-table-row strong{color:var(--c-text);font-weight:700;}
.hk-table-row .hk-runs-cell{color:var(--c-gold-light,#f5c842);font-weight:700;}
.hk-table-btn{border-color:rgba(236,72,153,.35)!important;background:rgba(236,72,153,.08)!important;color:#ec4899!important;}
.hk-table-btn:hover{background:rgba(236,72,153,.15)!important;border-color:#ec4899!important;box-shadow:0 0 18px rgba(236,72,153,.2)!important;}