/* ================================================================
   TibiaVault — Dark Medieval Tibia Theme
   Desktop-only, sidebar SPA layout
   ================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d0b0a;--bg-darker:#080706;--bg-card:#1a1614;--bg-card-hover:#231f1b;--bg-input:#141110;--bg-sidebar:#110f0d;
  --gold:#d4a537;--gold-dark:#8b6914;--gold-light:#f0d68a;--gold-dim:rgba(212,165,55,.08);
  --parchment:#e8dcc8;--parch-dim:#a89a84;--blood:#8b1a1a;
  --fire:#ef4444;--ice:#3b82f6;--energy:#a855f7;--earth:#22c55e;--holy:#facc15;--death:#6b7280;--physical:#c9a96e;--drown:#06b6d4;--lifedrain:#991b1b;--manadrain:#4338ca;
  --common:#22c55e;--uncommon:#3b82f6;--semi-rare:#a855f7;--rare:#f59e0b;--very-rare:#ef4444;
  --border:rgba(212,165,55,.10);--border-h:rgba(212,165,55,.28);
  --r:6px;--rl:10px;
  --sidebar-w:210px;--topbar-h:52px;
}
html{scroll-behavior:smooth}
body{font-family:'Crimson Text',Georgia,serif;background:var(--bg);color:var(--parchment);line-height:1.6;overflow:hidden;height:100vh;min-width:1100px}
h1,h2,h3,h4,h5{font-family:'Cinzel',serif;color:var(--gold-light);line-height:1.2;font-weight:600}
a{color:var(--gold);text-decoration:none;transition:color .15s}a:hover{color:var(--gold-light)}
img{max-width:100%;display:block}
button{font-family:'Crimson Text',serif;cursor:pointer;border:none;background:none;color:var(--parchment)}
input,select{font-family:'Crimson Text',serif;background:var(--bg-input);color:var(--parchment);border:1px solid var(--border);border-radius:var(--r);padding:7px 11px;font-size:14px;transition:border-color .15s}
input:focus,select:focus{outline:none;border-color:var(--gold)}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:7px 10px;border-bottom:1px solid var(--border)}
th{font-family:'Cinzel',serif;font-size:11px;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-darker);position:sticky;top:0;z-index:1}
tr:hover td{background:rgba(212,165,55,.03)}
::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold)}

/* ===== GRID LAYOUT ===== */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;height:100vh;overflow:hidden}

/* ===== TOPBAR ===== */
.topbar{grid-column:1/-1;display:flex;align-items:center;gap:16px;padding:0 16px;background:linear-gradient(180deg,#151210 0%,var(--bg-sidebar) 100%);border-bottom:1px solid var(--border);z-index:50}
.tb-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}
.tb-logo img{height:34px;border-radius:5px}
.tb-logo span{font-family:'Cinzel',serif;font-size:17px;font-weight:700;color:var(--gold-light)}
.tb-logo span b{color:var(--gold)}
.tb-search{flex:1;max-width:360px;position:relative}
.tb-search input{width:100%;padding-left:30px;font-size:13px;background:var(--bg-card);border-color:var(--border)}
.tb-search .search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:14px;height:14px;opacity:.4}
.tb-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.boosted{display:flex;align-items:center;gap:6px;padding:3px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.boosted img{width:26px;height:26px;image-rendering:auto}
.boosted-info{display:flex;flex-direction:column;line-height:1.2}
.boosted-info .blabel{font-size:9px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.5px}
.boosted-info .bname{font-size:11px;color:var(--gold-light);font-weight:600;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== SIDEBAR ===== */
.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}
.sidebar-nav{flex:1;padding:6px 0}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 14px;color:var(--parch-dim);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;border-left:3px solid transparent;user-select:none}
.nav-item:hover{background:rgba(212,165,55,.05);color:var(--parchment)}
.nav-item.active{color:var(--gold);background:var(--gold-dim);border-left-color:var(--gold)}
.nav-item .ni-icon{width:20px;height:20px;flex-shrink:0;opacity:.7;image-rendering:auto}
.nav-item.active .ni-icon{opacity:1}
.nav-divider{height:1px;background:var(--border);margin:6px 14px}
.nav-discord{background:rgba(88,101,242,.06)!important;border-left-color:rgba(88,101,242,.4)!important}
.nav-discord:hover{background:rgba(88,101,242,.12)!important;color:#7289da!important}
.nav-discord .ni-icon{filter:brightness(0) invert(1);opacity:.5}
.nav-discord:hover .ni-icon{opacity:.9}
.sidebar-footer{padding:10px 14px;border-top:1px solid var(--border);font-size:10px;color:var(--parch-dim);text-align:center;line-height:1.5}
.sidebar-footer a{color:var(--gold);font-size:10px}

/* ===== CONTENT ===== */
.content{overflow-y:auto;padding:20px 24px;background:var(--bg)}
.panel{display:none}.panel.active{display:block}
.ph{margin-bottom:20px}
.ph h2{font-size:22px;margin-bottom:3px}
.ph p{color:var(--parch-dim);font-size:14px}
.ph-line{width:40px;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-dark));margin-top:8px;border-radius:1px}

/* ===== SHARED ===== */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.si{flex:1;min-width:180px}
.fg{display:flex;gap:3px;flex-wrap:wrap}
.fb{padding:5px 12px;border-radius:14px;font-size:11px;font-weight:600;border:1px solid var(--border);transition:all .12s;font-family:'Cinzel',serif}
.fb.active,.fb:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.badge{display:inline-block;padding:2px 7px;border-radius:8px;font-size:10px;font-weight:700}
.bg-gold{background:var(--gold-dim);color:var(--gold)}
.bg-red{background:rgba(139,26,26,.2);color:#e74c3c}
.bg-blue{background:rgba(59,130,246,.12);color:#3b82f6}
.bg-green{background:rgba(34,197,94,.12);color:#22c55e}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);padding:14px;transition:border-color .12s}
.card:hover{border-color:var(--border-h)}
.empty{text-align:center;padding:40px;color:var(--parch-dim);font-style:italic}
.loading{text-align:center;padding:30px;color:var(--parch-dim)}
.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .5s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.pag{display:flex;justify-content:center;gap:3px;margin-top:16px}
.pg{min-width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r);border:1px solid var(--border);font-size:11px;font-weight:600;transition:all .12s;padding:0 5px}
.pg.active,.pg:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
.pg:disabled{opacity:.3;cursor:not-allowed}
.rcount{text-align:center;margin-top:6px;font-size:11px;color:var(--parch-dim)}

/* ===== TIBIA IMAGE HELPERS ===== */
.timg{image-rendering:auto;vertical-align:middle}
.timg-sm{width:24px;height:24px}
.timg-md{width:32px;height:32px}
.timg-lg{width:64px;height:64px}
.timg-xl{width:96px;height:96px}

/* ===== ELEMENT ICONS ===== */
.elem{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:800;color:#fff;flex-shrink:0}
.elem-fire{background:var(--fire)}.elem-ice{background:var(--ice)}.elem-energy{background:var(--energy)}.elem-earth{background:var(--earth)}
.elem-holy{background:var(--holy);color:#333}.elem-death{background:var(--death)}.elem-physical{background:var(--physical);color:#333}
.elem-drown{background:var(--drown)}.elem-lifedrain{background:var(--lifedrain)}.elem-manadrain{background:var(--manadrain)}

/* ===== NEWS ===== */
.news-grid{display:grid;grid-template-columns:1fr 260px;gap:16px}
.news-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);padding:14px;margin-bottom:10px;cursor:pointer;transition:all .12s}
.news-item:hover{border-color:var(--border-h)}
.news-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.news-date{font-size:11px;color:var(--parch-dim)}
.news-title{font-family:'Cinzel',serif;font-size:15px;color:var(--gold-light)}
.news-preview{font-size:13px;color:var(--parch-dim);line-height:1.5;max-height:40px;overflow:hidden}
.news-item.expanded .news-preview{max-height:none}
.news-body{display:none;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:13px;line-height:1.7}
.news-item.expanded .news-body{display:block}
.news-body img{max-width:100%;border-radius:var(--r);margin:6px 0}
.news-side .card{margin-bottom:10px;text-align:center;padding:12px}
.news-side .card h4{font-size:12px;color:var(--gold);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.news-side .card img{margin:0 auto 4px}
.news-side .card .bn{font-size:13px;color:var(--gold-light);font-weight:600}

/* ===== BESTIARY ===== */
.cg{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}
.cc{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:8px 6px;text-align:center;cursor:pointer;transition:all .12s}
.cc:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.cc img{width:48px;height:48px;margin:0 auto 4px;image-rendering:auto}
.cc .cn{font-family:'Cinzel',serif;font-size:10px;color:var(--parchment);line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Creature Detail */
.cd{display:none}.cd.active{display:block}
.cd-back{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--r);border:1px solid var(--border);font-size:12px;margin-bottom:14px;cursor:pointer;transition:all .12s}
.cd-back:hover{border-color:var(--gold);color:var(--gold)}
.cd-top{display:flex;gap:20px;margin-bottom:16px;align-items:flex-start}
.cd-sprite{width:120px;height:120px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--rl);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-sprite img{max-width:96px;max-height:96px;image-rendering:auto}
.cd-info h3{font-size:20px;margin-bottom:3px}
.cd-desc{font-size:13px;color:var(--parch-dim);font-style:italic;line-height:1.5}
.cd-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:16px}
.cd-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:8px;text-align:center}
.cd-stat .v{font-family:'Cinzel',serif;font-size:16px;color:var(--gold-light)}
.cd-stat .l{font-size:9px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.5px}
.cd-sec{margin-bottom:16px}
.cd-sec h4{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
/* Resistance bars */
.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}
.res-item{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:6px 8px}
.res-item .elem{flex-shrink:0}
.res-info{flex:1;min-width:0}
.res-info .rn{font-size:10px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.3px}
.res-info .rv{font-family:'Cinzel',serif;font-size:13px;font-weight:700}
.res-immune{border-color:rgba(239,68,68,.25)}.res-immune .rv{color:var(--fire)}
.res-strong{border-color:rgba(249,115,22,.25)}.res-strong .rv{color:#f97316}
.res-neutral .rv{color:var(--parch-dim)}
.res-weak{border-color:rgba(34,197,94,.25)}.res-weak .rv{color:var(--earth)}
/* Loot grid — visual cards */
.loot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.loot-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px 10px;background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--r);text-align:center;transition:all .15s;cursor:default}
.loot-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}
.loot-card img{width:40px;height:40px;image-rendering:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}
.loot-card .loot-name{font-size:11px;color:var(--parch-dim);line-height:1.3;max-width:100px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.loot-card .loot-amount{font-size:10px;color:var(--parchment);font-weight:700}
.loot-card .lr{font-weight:700;text-transform:uppercase;font-size:9px}
.loot-common{border-bottom:2px solid rgba(34,197,94,.3)}.loot-common:hover{border-color:var(--common);box-shadow:0 0 10px rgba(34,197,94,.15)}
.loot-uncommon{border-bottom:2px solid rgba(59,130,246,.3)}.loot-uncommon:hover{border-color:var(--uncommon);box-shadow:0 0 10px rgba(59,130,246,.15)}
.loot-semi-rare{border-bottom:2px solid rgba(168,85,247,.3)}.loot-semi-rare:hover{border-color:var(--semi-rare);box-shadow:0 0 10px rgba(168,85,247,.15)}
.loot-rare{border-bottom:2px solid rgba(245,158,11,.3)}.loot-rare:hover{border-color:var(--rare);box-shadow:0 0 10px rgba(245,158,11,.15)}
.loot-very-rare{border-bottom:2px solid rgba(239,68,68,.3)}.loot-very-rare:hover{border-color:var(--very-rare);box-shadow:0 0 10px rgba(239,68,68,.15)}
.lr-common{color:var(--common)}.lr-uncommon{color:var(--uncommon)}.lr-semi-rare{color:var(--semi-rare)}.lr-rare{color:var(--rare)}.lr-very-rare{color:var(--very-rare)}

/* ===== MY BUILD BAR (horizontal) ===== */
.my-build{display:flex;align-items:center;gap:10px;padding:10px 16px;background:linear-gradient(135deg,rgba(212,165,55,.06) 0%,rgba(212,165,55,.02) 100%);border:1px solid var(--border-h);border-radius:var(--rl);margin-bottom:10px;flex-wrap:wrap}
.build-label{display:flex;align-items:center;gap:6px;font-family:'Cinzel',serif;font-size:13px;color:var(--gold);font-weight:700;flex-shrink:0}
.build-char{display:flex;align-items:center;gap:6px}
.build-char input{width:160px;padding:5px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);color:var(--parchment);font-family:'Crimson Text',serif;font-size:13px}
.build-char input:focus{border-color:var(--gold);outline:none;box-shadow:0 0 8px rgba(212,165,55,.15)}
.build-char .btn-g{padding:5px 12px;background:linear-gradient(135deg,var(--gold-dark),var(--gold));color:var(--bg-main);border:none;border-radius:var(--r);font-family:'Cinzel',serif;font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}
.build-char .btn-g:hover{filter:brightness(1.15);box-shadow:0 0 10px rgba(212,165,55,.3)}
.build-level{display:flex;align-items:center;gap:4px}
.build-level label{font-family:'Cinzel',serif;font-size:11px;color:var(--gold);font-weight:600}
.build-level input{width:60px;text-align:center;font-family:'Cinzel',serif;font-weight:700;font-size:13px;color:var(--gold-light);padding:5px 4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r)}
.build-level input:focus{border-color:var(--gold);outline:none}
.build-sep{width:1px;height:28px;background:var(--border-h);flex-shrink:0}
.build-vocs{display:flex;gap:3px}
.bv{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--r);font-size:9px;font-weight:700;border:1px solid var(--border);transition:all .12s;font-family:'Cinzel',serif;color:var(--parch-dim)}
.bv img{width:20px;height:20px;image-rendering:pixelated;object-fit:contain}
.bv:hover{border-color:var(--border-h);color:var(--parchment)}
.bv.active{border-color:var(--gold);color:var(--gold);background:var(--gold-dim);box-shadow:0 0 8px rgba(212,165,55,.15)}
/* ===== CHARACTER INFO PANEL ===== */
.build-info{padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);margin-bottom:12px;display:none}
.build-info.visible{display:block}
.bi-stats-row{display:flex;gap:6px;margin-bottom:12px}
.bi-stat{display:flex;flex-direction:column;align-items:center;padding:8px 10px 6px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);text-align:center;flex:1;transition:border-color .15s}
.bi-stat-hl{background:linear-gradient(135deg,rgba(212,165,55,.06),rgba(212,165,55,.02));border-color:var(--border-h)}
.bi-num{font-family:'Cinzel',serif;font-size:20px;font-weight:700;color:var(--gold-light);line-height:1}
.bi-stat-hl .bi-num{color:var(--gold)}
.bi-lbl{font-size:9px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.3px;margin-top:4px;line-height:1.2}
.bi-char-header{display:flex;align-items:center;gap:16px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.bi-voc-icon{width:32px;height:32px;image-rendering:pixelated;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(212,165,55,.25))}
.bi-char-name-block{display:flex;flex-direction:column;gap:2px;min-width:0}
.bi-divider{height:1px;background:var(--border);margin:8px 0}
.bi-char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:4px 16px}
.bi-char-field{display:flex;flex-direction:column;gap:1px;padding:3px 0}
.bi-char-field .bi-fl{font-size:8px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.5px}
.bi-char-field .bi-fv{font-size:12px;color:var(--parchment);font-weight:600}
.bi-premium{color:#22c55e}
.bi-online{color:#22c55e;font-weight:700}
.bi-section-label{font-family:'Cinzel',serif;font-size:11px;color:var(--gold);font-weight:600;margin-bottom:6px;letter-spacing:.5px}
@media(max-width:768px){.my-build{gap:8px}.build-char input{width:120px}.build-sep{display:none}}

/* ===== HUNTING SPOTS — Card Grid ===== */
.hunt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.hunt-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:all .25s;cursor:pointer;position:relative}
.hunt-card::before,.hunt-card::after{content:'';position:absolute;width:18px;height:18px;pointer-events:none;z-index:2}
.hunt-card::before{top:0;left:0;border-top:2px solid var(--gold-dark);border-left:2px solid var(--gold-dark);border-radius:var(--rl) 0 0 0}
.hunt-card::after{bottom:0;right:0;border-bottom:2px solid var(--gold-dark);border-right:2px solid var(--gold-dark);border-radius:0 0 var(--rl) 0}
.hunt-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.4),0 0 15px rgba(212,165,55,.1)}
.hunt-card:hover::before,.hunt-card:hover::after{border-color:var(--gold)}
/* Card header */
.hunt-card-header{display:flex;align-items:center;gap:10px;padding:14px 14px 8px}
.hunt-card-header img{width:48px;height:48px;image-rendering:auto;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}
.hunt-card-hinfo{flex:1;min-width:0}
.hunt-card-hinfo .hc-name{font-family:'Cinzel',serif;font-size:15px;color:var(--gold-light);font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hunt-card-hinfo .hc-city{font-size:11px;color:var(--parch-dim)}
/* Card meta row */
.hunt-card-meta{display:flex;gap:5px;flex-wrap:wrap;align-items:center;padding:0 14px 8px;font-size:10px}
.hunt-vocs{display:flex;gap:3px}
.hunt-voc{font-size:9px;padding:3px 6px;border-radius:4px;background:rgba(212,165,55,.08);color:var(--gold);font-weight:700}
.hunt-lvl{font-size:11px;padding:3px 10px;border-radius:10px;background:var(--gold-dim);color:var(--gold);font-weight:700;font-family:'Cinzel',serif}
.hunt-team{font-size:10px;padding:2px 7px;border-radius:6px;border:1px solid var(--border);color:var(--parch-dim);font-weight:600;text-transform:uppercase}
.hunt-verified{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:5px;font-size:9px;font-weight:700;font-family:'Cinzel',serif}
.hunt-verified.verified{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:var(--common)}
.hunt-verified.unverified{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);color:#f59e0b}
/* Card stats row */
.hunt-card-stats{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.hunt-card-stat{padding:8px 14px;text-align:center}
.hunt-card-stat:first-child{border-right:1px solid var(--border)}
.hunt-card-stat .hcs-val{font-family:'Cinzel',serif;font-size:15px;color:var(--gold-light);font-weight:700;display:block}
.hunt-card-stat .hcs-label{font-size:9px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.4px}
/* Card creatures row */
.hunt-card-creatures{display:flex;gap:4px;padding:8px 14px 4px;align-items:center}
.hunt-card-creatures img{width:28px;height:28px;image-rendering:auto;border-radius:4px;background:rgba(0,0,0,.2);padding:1px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5))}
.hunt-card-creatures .hcc-more{font-size:10px;color:var(--parch-dim);margin-left:2px}
/* Card rating */
.hunt-card-rating{padding:4px 14px 12px}
.spot-rating{display:inline-flex;align-items:center;gap:1px;flex-shrink:0}
.rate-star{font-size:13px;color:rgba(212,165,55,.2);cursor:pointer;transition:color .12s;line-height:1;user-select:none}
.rate-star:hover{color:rgba(212,165,55,.6)}
.rate-star.filled{color:var(--gold);text-shadow:0 0 4px rgba(212,165,55,.3)}
.rate-label{font-size:10px;color:var(--gold);font-family:'Cinzel',serif;font-weight:700;margin-left:4px;min-width:28px}

/* ===== HUNT MODAL ===== */
.hunt-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.82);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:30px 20px;overflow-y:auto;backdrop-filter:blur(6px);animation:hmFadeIn .2s ease}
@keyframes hmFadeIn{from{opacity:0}to{opacity:1}}
.hunt-modal{background:var(--bg-card);border:2px solid var(--gold-dark);border-radius:16px;max-width:900px;width:100%;position:relative;box-shadow:0 24px 80px rgba(0,0,0,.7),0 0 40px rgba(212,165,55,.08);animation:hmSlideUp .25s ease}
@keyframes hmSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hunt-modal-close{position:sticky;top:0;float:right;width:36px;height:36px;border-radius:50%;background:var(--bg-darker);border:1px solid var(--border);color:var(--parch-dim);font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;margin:12px 12px 0 0;transition:all .12s;line-height:1}
.hunt-modal-close:hover{border-color:var(--gold);color:var(--gold);background:var(--bg-card)}
.hunt-modal-content{padding:20px 24px 24px}
/* Modal hero header */
.hunt-modal-hero{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.hunt-modal-hero img{width:80px;height:80px;image-rendering:auto;filter:drop-shadow(0 4px 10px rgba(0,0,0,.5))}
.hunt-modal-hero-info{flex:1;min-width:0}
.hunt-modal-hero-info h3{font-family:'Cinzel',serif;font-size:24px;color:var(--gold-light);margin-bottom:4px;line-height:1.1}
.hunt-modal-hero-info .hm-badges{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-top:6px}
/* Modal metrics grid */
.hunt-modal-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px}
.hunt-metric{background:linear-gradient(135deg,var(--bg-darker) 0%,rgba(26,22,20,.8) 100%);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;text-align:center;transition:border-color .12s}
.hunt-metric:hover{border-color:var(--border-h)}
.hunt-metric .hm-val{font-family:'Cinzel',serif;font-size:18px;color:var(--gold-light);font-weight:700}
.hunt-metric .hm-label{font-size:10px;color:var(--parch-dim);text-transform:uppercase;letter-spacing:.5px}
/* Hunt detail body — used inside modal */
.hunt-badges{display:flex;gap:6px;align-items:center;flex-shrink:0}
.hunt-sec{margin-top:14px}
.hunt-sec-title{font-family:'Cinzel',serif;font-size:14px;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.hunt-sec-title img{width:24px;height:24px;image-rendering:auto}
/* Route info — tibiaroute.com style */
.hunt-route{display:flex;flex-direction:column;gap:12px}
.hunt-minimap{width:100%;height:450px;border:2px solid var(--border-h);border-radius:var(--rl);overflow:hidden;background:var(--bg-darker);box-shadow:0 4px 20px rgba(0,0,0,.4)}
.leaflet-image-layer{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}
.hunt-route-text{font-size:14px;color:var(--parch-dim);line-height:1.7;padding:12px 16px;background:var(--bg-darker);border-radius:var(--r);border-left:3px solid var(--gold-dark)}
.hunt-access{margin-top:6px;font-size:11px;color:var(--parch-dim)}
.hunt-access strong{color:var(--parchment)}
/* Route step markers */
.route-steps{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.route-step{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);font-size:12px;color:var(--parch-dim);transition:all .12s}
.route-step:hover{border-color:var(--gold);color:var(--parchment)}
.route-step .rs-num{width:20px;height:20px;border-radius:50%;background:var(--gold);color:var(--bg);font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Cinzel',serif}
.route-step.rs-underground{border-color:rgba(168,85,247,.3);background:rgba(168,85,247,.06)}
.route-step.rs-underground .rs-num{background:#a855f7}
.rs-floor{font-size:9px;padding:1px 5px;border-radius:4px;background:rgba(168,85,247,.15);color:#a855f7;font-weight:700;margin-left:4px}
/* Leaflet step marker icon */
.step-marker{background:var(--gold);color:var(--bg);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;font-family:'Cinzel',serif;border:2px solid #f0d68a;box-shadow:0 2px 6px rgba(0,0,0,.5)}
.step-marker-start{background:#3b82f6;border-color:#93bbfd}
.step-marker-end{background:#ef4444;border-color:#fca5a5}
.step-marker-stairs{background:#a855f7;border-color:#d8b4fe;font-size:13px;cursor:pointer}
.step-marker-npc{background:#22c55e;border-color:#86efac;font-size:12px}
.step-marker-teleport{background:#3b82f6;border-color:#93bbfd;font-size:12px;cursor:pointer}
.map-tip{font-family:'Cinzel',serif!important;font-size:11px!important;font-weight:600!important;background:rgba(13,11,10,.92)!important;color:var(--gold-light)!important;border:1px solid var(--border-h)!important;border-radius:4px!important;padding:3px 8px!important;box-shadow:0 4px 12px rgba(0,0,0,.5)!important}
.map-tip::before{border-top-color:rgba(13,11,10,.92)!important}
/* Floor control — tibiaroute.com style */
.floor-ctrl{display:flex;flex-direction:column;align-items:center;background:rgba(13,11,10,.94);border:1px solid var(--border-h);border-radius:var(--r);overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.6)}
.fc-btn{width:32px;height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--gold);cursor:pointer;transition:all .12s;border:none;background:none}
.fc-btn:hover{background:rgba(212,165,55,.15);color:var(--gold-light)}
.fc-btn:disabled{opacity:.25;cursor:not-allowed}
.fc-lbl{width:32px;height:26px;display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-size:13px;font-weight:800;color:var(--gold-light);background:rgba(212,165,55,.1);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
/* Route direction arrows */
.route-arrow{color:var(--gold);font-size:14px;font-weight:700;text-shadow:0 0 4px rgba(0,0,0,.8),0 0 2px rgba(0,0,0,.9);line-height:1;pointer-events:none}
/* Creature cards */
.hunt-creatures{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:12px}
.hc-card{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--rl);padding:16px;display:flex;gap:16px;align-items:flex-start;transition:all .15s}
.hc-card:hover{border-color:var(--border-h);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.hc-sprite{width:96px;height:96px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:radial-gradient(circle,rgba(212,165,55,.06) 0%,var(--bg-card) 70%);border:2px solid var(--border);border-radius:var(--rl);position:relative}
.hc-sprite img{max-width:80px;max-height:80px;image-rendering:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}
.hc-info{flex:1;min-width:0}
.hc-name{font-family:'Cinzel',serif;font-size:16px;color:var(--gold-light);margin-bottom:6px;font-weight:600}
.hc-stats{display:flex;gap:12px;font-size:13px;color:var(--parch-dim);margin-bottom:10px;flex-wrap:wrap}
.hc-stats span{display:flex;align-items:center;gap:3px}
.hc-stats .hcs-val{color:var(--parchment);font-weight:700;font-size:14px}
/* Charm badge — graphical with TibiaWiki icons */
.hc-charm{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:var(--r);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.hc-charm .charm-icon{width:28px;height:28px;flex-shrink:0;image-rendering:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5))}
.hc-charm.charm-fire{background:rgba(239,68,68,.12);color:var(--fire);border:1px solid rgba(239,68,68,.3)}
.hc-charm.charm-fire .charm-icon{filter:drop-shadow(0 0 6px rgba(239,68,68,.5))}
.hc-charm.charm-ice{background:rgba(59,130,246,.12);color:var(--ice);border:1px solid rgba(59,130,246,.3)}
.hc-charm.charm-ice .charm-icon{filter:drop-shadow(0 0 6px rgba(59,130,246,.5))}
.hc-charm.charm-energy{background:rgba(168,85,247,.12);color:var(--energy);border:1px solid rgba(168,85,247,.3)}
.hc-charm.charm-energy .charm-icon{filter:drop-shadow(0 0 6px rgba(168,85,247,.5))}
.hc-charm.charm-earth{background:rgba(34,197,94,.12);color:var(--earth);border:1px solid rgba(34,197,94,.3)}
.hc-charm.charm-earth .charm-icon{filter:drop-shadow(0 0 6px rgba(34,197,94,.5))}
.hc-charm.charm-holy{background:rgba(250,204,21,.12);color:var(--holy);border:1px solid rgba(250,204,21,.3)}
.hc-charm.charm-holy .charm-icon{filter:drop-shadow(0 0 8px rgba(250,204,21,.6))}
.hc-charm.charm-death{background:rgba(107,114,128,.12);color:#9ca3af;border:1px solid rgba(107,114,128,.3)}
.hc-charm.charm-death .charm-icon{filter:drop-shadow(0 0 6px rgba(107,114,128,.5))}
.hc-charm.charm-physical{background:rgba(201,169,110,.12);color:var(--physical);border:1px solid rgba(201,169,110,.3)}
.hc-charm.charm-physical .charm-icon{filter:drop-shadow(0 0 6px rgba(201,169,110,.5))}
.hc-charm.charm-null{background:rgba(212,165,55,.06);color:var(--gold);border:1px solid var(--border)}
.hc-charm.charm-null .charm-icon{filter:drop-shadow(0 0 6px rgba(212,165,55,.4))}
/* Imbuements row */
.hunt-imbu{display:flex;gap:8px;flex-wrap:wrap}
.imbu-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:600;color:var(--parchment);transition:border-color .12s}
.imbu-chip:hover{border-color:var(--border-h)}
.imbu-chip img{width:28px;height:28px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));image-rendering:auto}
/* Supplies */
.hunt-supplies{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}
.supply-voc{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px}
.supply-voc h6{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.supply-voc h6 img{width:22px;height:22px;image-rendering:auto}
.supply-voc ul{list-style:none;padding:0;font-size:13px;color:var(--parch-dim);line-height:2.2}
.supply-voc ul li{display:flex;align-items:center;gap:6px}
.supply-voc ul li img{width:22px;height:22px;flex-shrink:0;image-rendering:auto}
/* Trinket */
.hunt-trinket{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--r)}
.hunt-trinket img{width:40px;height:40px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5));image-rendering:auto}
.hunt-trinket span{font-size:14px;color:var(--gold-light);font-weight:600}
/* Drops grid — VISUAL */
.hunt-drops{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.drop-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px 10px;background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--r);transition:all .15s;cursor:default;text-align:center}
.drop-item:hover{border-color:var(--gold);box-shadow:0 0 12px rgba(212,165,55,.15);transform:translateY(-2px)}
.drop-item img{width:40px;height:40px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));image-rendering:auto}
.drop-item .drop-name{font-size:11px;color:var(--parch-dim);line-height:1.3;max-width:100px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
/* Gear recommendation */
.hunt-gear{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:8px}
.gear-bracket{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px}
.gear-bracket h6{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.gear-active{border-color:var(--border-h);background:linear-gradient(135deg,rgba(212,165,55,.04) 0%,var(--bg-darker) 100%)}
.gear-prot-section{margin-top:8px}
.gear-prot{border-color:rgba(239,68,68,.2)}
.elem-bg-fire{border-left:3px solid var(--fire)}.elem-bg-ice{border-left:3px solid var(--ice)}.elem-bg-energy{border-left:3px solid var(--energy)}.elem-bg-earth{border-left:3px solid var(--earth)}.elem-bg-death{border-left:3px solid var(--death)}.elem-bg-holy{border-left:3px solid var(--holy)}.elem-bg-physical{border-left:3px solid var(--physical)}
.supply-active{border-color:var(--border-h);background:linear-gradient(135deg,rgba(212,165,55,.04) 0%,var(--bg-darker) 100%)}
.gear-bracket .gear-items{display:flex;flex-wrap:wrap;gap:6px}
.gear-bracket .gear-item{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);font-size:12px;color:var(--parchment);transition:border-color .12s}
.gear-bracket .gear-item:hover{border-color:var(--border-h)}
.gear-bracket .gear-item img{width:24px;height:24px;image-rendering:auto;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
/* Tips */
.hunt-tips{padding:14px 16px;background:rgba(212,165,55,.04);border:1px solid rgba(212,165,55,.12);border-radius:var(--r);font-size:14px;color:var(--gold-light);line-height:1.7;position:relative;padding-left:22px}
.hunt-tips::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--gold),var(--gold-dark));border-radius:4px 0 0 4px}
/* Buttons */
.btn-s{padding:5px 12px;border-radius:var(--r);font-size:11px;font-weight:600;border:1px solid var(--border);transition:all .12s;font-family:'Cinzel',serif}
.btn-s:hover{border-color:var(--gold);color:var(--gold)}
.btn-g{background:var(--gold);color:var(--bg);border-color:var(--gold)}.btn-g:hover{background:var(--gold-light);color:var(--bg)}

/* ===== EQUIPMENT ===== */
.eq-ctrl{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.eq-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.eq-slot .eq-head{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.eq-slot .eq-sicon{width:28px;height:28px;image-rendering:auto}
.eq-slot .eq-type{font-family:'Cinzel',serif;font-size:12px;color:var(--gold)}
.eq-slot .eq-item{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.eq-slot .eq-iimg{width:32px;height:32px;image-rendering:auto;flex-shrink:0;background:var(--bg-darker);border:1px solid var(--border);border-radius:4px;padding:2px}
.eq-slot .eq-iname{font-family:'Cinzel',serif;font-size:14px;color:var(--gold-light)}
.eq-slot .eq-stats{font-size:12px;color:var(--common)}
.eq-slot .eq-src{font-size:10px;color:var(--parch-dim);margin-top:4px;font-style:italic}

/* ===== QUESTS ===== */
.ql{display:flex;flex-direction:column;gap:8px}
.qc{overflow:hidden}
.qh{display:flex;align-items:center;gap:8px;padding:12px 14px;cursor:pointer;transition:background .12s}
.qh:hover{background:var(--bg-card-hover)}
.q-arrow{color:var(--gold);transition:transform .2s;font-size:12px;flex-shrink:0}
.qc.open .q-arrow{transform:rotate(90deg)}
.q-title{font-family:'Cinzel',serif;font-size:13px;color:var(--gold-light);flex:1}
.q-badges{display:flex;gap:3px;flex-shrink:0}
.qb{display:none;padding:0 14px 14px;border-top:1px solid var(--border)}
.qc.open .qb{display:block}
.qs{margin-top:12px}
.qs h5{font-size:11px;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.qs p,.qs ul,.qs ol{font-size:12px;color:var(--parch-dim);line-height:1.7}
.qs ul{list-style:none;padding:0}.qs ul li::before{content:'▸ ';color:var(--gold)}
.qs ol{padding-left:18px}.qs ol li{margin-bottom:4px}
.qs .tip{padding:8px 10px;background:rgba(212,165,55,.05);border:1px solid var(--gold-dim);border-radius:var(--r);font-size:11px;color:var(--gold-light)}

/* ===== SPELLS ===== */
.sp-wrap{max-height:calc(100vh - 200px);overflow:auto;border:1px solid var(--border);border-radius:var(--rl)}
.sp-tbl{font-size:12px}
.sp-tbl td{padding:5px 8px}
.sp-tbl .sp-img{width:32px;height:32px;image-rendering:auto}
.sp-formula{font-family:monospace;color:var(--gold);font-size:11px}

/* ===== MAP ===== */
#tibiaMap{width:100%;height:calc(100vh - 170px);border-radius:var(--rl);border:1px solid var(--border);background:var(--bg-card)}
.map-ctrl{display:flex;gap:8px;margin-bottom:10px;align-items:center;font-size:12px;color:var(--parch-dim)}
.map-legend{display:flex;gap:14px;margin-top:8px;font-size:11px;color:var(--parch-dim)}
.map-legend span{display:flex;align-items:center;gap:4px}
.ld{width:8px;height:8px;border-radius:50%;display:inline-block}
.ld-gold{background:var(--gold)}.ld-blue{background:var(--ice)}

/* ===== CHARACTER ===== */
.ch-box{display:flex;gap:8px;margin-bottom:16px;max-width:450px}
.ch-box input{flex:1}
.ch-box button{padding:7px 18px;background:var(--gold);color:var(--bg);border-radius:var(--r);font-weight:700;font-family:'Cinzel',serif;font-size:13px}
.ch-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ch-field{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px}
.ch-field .fl{color:var(--parch-dim)}.ch-field .fv{color:var(--gold-light);font-weight:600}
.death-item{padding:4px 0;border-bottom:1px solid var(--border);font-size:11px;color:var(--parch-dim)}
.death-item .dr{color:var(--parchment)}

/* ===== WORLDS ===== */
.w-stats{display:flex;gap:12px;margin-bottom:14px}
.w-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:10px 16px;text-align:center}
.w-stat .wv{font-family:'Cinzel',serif;font-size:20px;color:var(--gold-light)}
.w-stat .wl{font-size:10px;color:var(--parch-dim);text-transform:uppercase}
.w-wrap{max-height:calc(100vh - 240px);overflow:auto;border:1px solid var(--border);border-radius:var(--rl)}
.w-tbl{font-size:12px}.w-tbl td{padding:5px 8px}
.online{color:var(--common)}.offline{color:var(--fire)}

/* ===== CALCULATORS ===== */
.calc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.calc h3{font-size:15px;margin-bottom:12px}
.calc .cf{margin-bottom:8px}
.calc label{display:block;font-size:11px;color:var(--parch-dim);margin-bottom:3px}
.calc input{width:100%}
.calc .cr{margin-top:12px;padding:10px;background:var(--bg-darker);border-radius:var(--r)}
.calc .crv{font-family:'Cinzel',serif;font-size:18px;color:var(--gold-light)}
.calc .crl{font-size:10px;color:var(--parch-dim)}

/* ===== ROUTE EDITOR ===== */
.ed-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.ed-mode-btn.active{background:var(--gold);color:var(--bg);border-color:var(--gold)}
.ed-spot-select{min-width:220px;font-size:12px}
.ed-layout{display:flex;gap:14px;height:calc(100vh - 220px);min-height:500px}
.ed-map-wrap{flex:3;display:flex;flex-direction:column;min-width:0}
.ed-map{flex:1;border:2px solid var(--border-h);border-radius:var(--rl);overflow:hidden;background:var(--bg-darker)}
.ed-map-ctrl{display:flex;gap:8px;align-items:center;padding:8px 0;font-size:12px;color:var(--parch-dim)}
.ed-sidebar{flex:2;display:flex;flex-direction:column;min-width:280px;max-width:420px}
.ed-wp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.ed-wp-header h4{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);margin:0}
.ed-wp-count{font-size:11px;color:var(--parch-dim)}
.ed-wp-list{flex:1;overflow-y:auto;border:1px solid var(--border);border-radius:var(--r);background:var(--bg-darker);margin-bottom:10px;min-height:120px;max-height:250px}
.ed-wp-empty{padding:20px;text-align:center;color:var(--parch-dim);font-size:13px;font-style:italic}
.ed-wp-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
.ed-wp-item:hover{background:rgba(212,165,55,.05)}
.ed-wp-item.active{background:rgba(212,165,55,.08);border-left:3px solid var(--gold)}
.ed-wp-num{width:22px;height:22px;border-radius:50%;background:var(--gold);color:var(--bg);font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Cinzel',serif}
.ed-wp-num.stairs{background:#a855f7}
.ed-wp-info{flex:1;min-width:0}
.ed-wp-desc{font-size:12px;color:var(--parchment);display:block;width:100%;background:none;border:none;border-bottom:1px solid transparent;padding:0 0 2px;font-family:'Crimson Text',serif;outline:none;transition:border-color .12s}
.ed-wp-desc:focus{border-bottom-color:var(--gold);color:var(--gold-light)}
.ed-wp-floor{font-size:10px;color:var(--parch-dim);margin-top:2px}
.ed-wp-del{width:20px;height:20px;border-radius:4px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--parch-dim);cursor:pointer;flex-shrink:0;transition:all .12s;background:none}
.ed-wp-del:hover{border-color:var(--fire);color:var(--fire);background:rgba(239,68,68,.08)}
.ed-form{overflow-y:auto;padding:2px 0}
.ed-form h4{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.ed-field{margin-bottom:8px}
.ed-field label{display:block;font-size:11px;color:var(--parch-dim);margin-bottom:3px}
.ed-field input,.ed-field select,.ed-field textarea{width:100%;font-size:13px}
.ed-field textarea{resize:vertical;background:var(--bg-input);color:var(--parchment);border:1px solid var(--border);border-radius:var(--r);padding:7px;font-family:'Crimson Text',serif;font-size:13px}
.ed-field-row{display:flex;gap:8px}
.ed-field-row .ed-field{flex:1}
.ed-vocs{display:flex;gap:10px;font-size:12px}
.ed-vocs label{display:flex;align-items:center;gap:4px;cursor:pointer;color:var(--parchment)}
.ed-vocs input[type="checkbox"]{accent-color:var(--gold)}
.ed-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.ed-actions .btn-s{flex:1;text-align:center;padding:8px}
.ed-status{margin-top:10px;padding:10px 14px;border-radius:var(--r);font-size:13px;display:none}
.ed-status.success{display:block;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);color:var(--common)}
.ed-status.error{display:block;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--fire)}
.ed-status.info{display:block;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);color:var(--ice)}
.hunt-fix-btn{font-size:10px;padding:3px 8px;border-radius:6px;border:1px solid var(--border);color:var(--parch-dim);cursor:pointer;transition:all .12s;background:none;font-family:'Cinzel',serif;font-weight:600}
.hunt-fix-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-dim)}
/* Hunt sub-tabs */
.hunt-tabs{display:flex;gap:4px;margin-bottom:14px}
.hunt-tab{padding:8px 20px;border-radius:var(--r) var(--r) 0 0;font-size:13px;font-weight:700;font-family:'Cinzel',serif;border:1px solid var(--border);border-bottom:none;color:var(--parch-dim);background:var(--bg-darker);cursor:pointer;transition:all .12s}
.hunt-tab:hover{color:var(--parchment);background:var(--bg-card)}
.hunt-tab.active{color:var(--gold);background:var(--bg-card);border-color:var(--border-h);box-shadow:0 -2px 8px rgba(212,165,55,.08)}
.hunt-tab-create{color:#22c55e;border-color:rgba(34,197,94,.25);background:rgba(34,197,94,.06)}
.hunt-tab-create:hover{color:#4ade80;background:rgba(34,197,94,.12)}
.hunt-tab-create.active{color:#22c55e;background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.4);box-shadow:0 -2px 8px rgba(34,197,94,.1)}
.hunt-tab-content{display:none}.hunt-tab-content.active{display:block}
/* Hunt mode badges */
.hunt-mode-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700;font-family:'Cinzel',serif;text-transform:capitalize}
.hunt-mode-solo{color:#22c55e;border:1px solid rgba(34,197,94,.3);background:rgba(34,197,94,.08)}
.hunt-mode-duo{color:#3b82f6;border:1px solid rgba(59,130,246,.3);background:rgba(59,130,246,.08)}
.hunt-mode-team{color:#a855f7;border:1px solid rgba(168,85,247,.3);background:rgba(168,85,247,.08)}
/* Welcome/Onboarding Modal */
.hw-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);z-index:999;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.hw-box{background:var(--bg-card);border:2px solid var(--border-h);border-radius:16px;padding:28px 32px;max-width:480px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.7)}
.hw-header{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.hw-header .hw-avatar{width:48px;height:48px;image-rendering:auto}
.hw-header h3{font-family:'Cinzel',serif;font-size:18px;color:var(--gold-light);margin-bottom:2px}
.hw-header p{font-size:13px;color:var(--parch-dim)}
.hw-fields{display:flex;flex-direction:column;gap:14px;margin-bottom:20px}
.hw-field label{display:block;font-family:'Cinzel',serif;font-size:11px;color:var(--gold);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
.hw-field input{width:100%;font-size:14px;padding:9px 12px}
.hw-vocs{display:flex;gap:6px;flex-wrap:wrap}
.hw-voc{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 12px;border-radius:var(--r);border:2px solid var(--border);background:var(--bg-darker);cursor:pointer;transition:all .15s;min-width:64px}
.hw-voc img{width:40px;height:40px;image-rendering:auto}
.hw-voc span{font-size:10px;font-family:'Cinzel',serif;font-weight:700;color:var(--parch-dim)}
.hw-voc:hover{border-color:var(--border-h)}
.hw-voc.active{border-color:var(--gold);background:var(--gold-dim);box-shadow:0 0 12px rgba(212,165,55,.2)}
.hw-voc.active span{color:var(--gold)}
.hw-actions{display:flex;gap:10px;align-items:center}
.hw-go{flex:1;padding:12px 20px!important;font-size:14px!important;font-weight:700}
.hw-skip{font-size:12px;color:var(--parch-dim);padding:8px 16px!important}

/* CTA Banner */
.hunt-cta{position:relative;display:flex;align-items:center;padding:12px 18px;margin-bottom:14px;background:linear-gradient(135deg,rgba(212,165,55,.08) 0%,rgba(139,105,20,.04) 50%,rgba(212,165,55,.06) 100%);border:1px solid rgba(212,165,55,.25);border-radius:var(--rl);overflow:hidden}
.hunt-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(212,165,55,.06) 0%,transparent 50%);pointer-events:none}
.cta-inner{display:flex;align-items:center;gap:14px;flex:1;position:relative;z-index:1}
.cta-icon{width:28px;height:28px;flex-shrink:0;filter:drop-shadow(0 2px 6px rgba(212,165,55,.3))}
.cta-text{flex:1;font-size:12px;color:var(--parch-dim);line-height:1.5}
.cta-text b{color:var(--gold)}
.cta-actions{display:flex;gap:6px;flex-shrink:0}
.cta-actions .btn-s{padding:6px 14px;font-size:11px}
.cta-actions a{text-decoration:none}
.hunt-cta-big::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('https://tibia.fandom.com/wiki/Special:Redirect/file/Gold_Coin.gif') repeat;opacity:.03;pointer-events:none}
@keyframes ctaPulse{0%,100%{border-color:rgba(212,165,55,.3)}50%{border-color:rgba(212,165,55,.5)}}
.cta-close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--parch-dim);font-size:20px;cursor:pointer;line-height:1;padding:4px;transition:color .12s;z-index:2}
.cta-close:hover{color:var(--gold)}
/* No-route placeholder */
.hunt-no-route{padding:20px;text-align:center;background:var(--bg-darker);border:2px dashed var(--border);border-radius:var(--rl);margin-top:8px}
.hunt-no-route p{color:var(--parch-dim);font-size:13px;margin-bottom:10px}
.hunt-no-route .btn-s{font-size:12px;padding:6px 16px}
/* Feedback form sections */
.fb-sections{display:flex;flex-direction:column;gap:8px}
.fb-sec{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .12s}
.fb-sec:has(.fb-cat:checked){border-color:var(--border-h);background:rgba(212,165,55,.03)}
.fb-sec-label{display:flex;align-items:center;gap:8px;padding:8px 12px;font-family:'Cinzel',serif;font-size:11px;color:var(--parch-dim);cursor:pointer;font-weight:600;text-transform:uppercase;letter-spacing:.3px;background:var(--bg-card);transition:all .12s}
.fb-sec-label:hover{color:var(--parchment);background:var(--bg-card-hover)}
.fb-sec-label input[type="checkbox"]{accent-color:var(--gold)}
.fb-sec-label img{flex-shrink:0}
.fb-field{display:none;width:100%;background:var(--bg-input);color:var(--parchment);border:none;border-top:1px solid var(--border);padding:8px 12px;font-family:'Crimson Text',serif;font-size:13px;resize:vertical;outline:none}
.fb-sec:has(.fb-cat:checked) .fb-field{display:block}
/* Editor hunt mode fields */
.ed-hunt-modes{display:flex;flex-direction:column;gap:8px}
.ed-hm{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;flex-wrap:wrap}
.ed-hm>input[type="checkbox"]{accent-color:var(--gold)}
.ed-hm-range{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:400;color:var(--parch-dim);margin-left:8px}
.ed-hm-range input[type="number"]{width:60px;padding:4px 6px;font-size:11px}
.ed-hm-range input:disabled{opacity:.4;cursor:not-allowed}
.ed-hm-same{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--parch-dim);margin-left:4px;cursor:pointer}
.ed-hm-same input{accent-color:var(--gold)}
