:root {
  /* Palette sampled from callofduty.com/warzone CSS bundles 2026-06-07:
     #f96800 accent (25 hits), #1b1b1b/#000 backgrounds, #393939/#3c4147 borders,
     #fff/#d9d9d9 type, #d70000 red, #ffd000 yellow. */
  --bg-primary:#050505;--bg-secondary:#101010;--bg-card:#1b1b1b;--bg-card-hover:#242424;
  --border:#393939;--border-accent:#f96800;--text-primary:#ffffff;--text-secondary:#d9d9d9;--text-muted:#8a9097;
  --gold:#f96800;--gold-dim:#c45200;--ember:#d70000;--ember-deep:#8f0000;--accent-red:#d70000;--accent-red-dim:#8f0000;
  --accent-blue:#5b7d99;--accent-cyan:#7fb2c9;--accent-green:#9bf00b;--accent-orange:#f96800;--accent-purple:#8d86b8;
  --biome-meadows:#f96800;--biome-bf:#ffd000;--biome-swamp:#d70000;--biome-mtn:#d9d9d9;
  --biome-plains:#c45200;--biome-mist:#8a9097;--biome-ash:#d70000;--biome-north:#5b7d99;--biome-ocean:#3c4147;
  --glow-gold:0 0 18px rgba(249,104,0,0.30);
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg-primary);color:var(--text-primary);font-family:'Saira',sans-serif;min-height:100vh;
  background-image:linear-gradient(rgba(249,104,0,0.022) 1px,transparent 1px),linear-gradient(90deg,rgba(249,104,0,0.022) 1px,transparent 1px),radial-gradient(ellipse at top,rgba(60,65,71,0.20),transparent 55%);
  background-size:44px 44px,44px 44px,100% 100%}
body::after{content:'';position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,0.04) 3px,rgba(0,0,0,0.04) 6px);z-index:9999;opacity:0.6}
.sticky-nav{position:sticky;top:0;z-index:100;background:#050505;border-bottom:none}
.header{border-bottom:none;padding:0}
.header-inner{max-width:1600px;margin:0 auto;height:62px;padding:6px 32px 8px;display:flex;align-items:center;justify-content:space-between;border-bottom:none;background-image:linear-gradient(to right,transparent,var(--border) 20px,var(--border) calc(100% - 20px),transparent);background-size:100% 1px;background-position:bottom;background-repeat:no-repeat}
.logo{display:flex;align-items:center;gap:16px}
.logo-mark{width:40px;height:40px;border-radius:2px;object-fit:cover;display:block;padding:3px;background:#000;border:1px solid var(--border);outline:1px solid rgba(249,104,0,0.55);outline-offset:-3px;box-shadow:var(--glow-gold)}
.logo-text{font-family:'Saira Semi Condensed',sans-serif;font-weight:800;font-size:25px;line-height:37px;letter-spacing:3px;white-space:nowrap;
  background:linear-gradient(110deg,rgba(255,255,255,0) 42%,rgba(255,255,255,0.95) 50%,rgba(255,255,255,0) 58%) no-repeat,linear-gradient(#f96800,#f96800);
  background-size:220% 100%,100% 100%;background-position:220% 0,0 0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:logoGlisten 12s linear infinite}
@keyframes logoGlisten{0%{background-position:220% 0,0 0}30%{background-position:-220% 0,0 0}100%{background-position:-220% 0,0 0}}
.logo-name{text-transform:none}
.logo-sub{font-family:'Saira Condensed',sans-serif;font-size:11px;line-height:13px;color:var(--text-muted);letter-spacing:4px;text-transform:uppercase;text-align:center}
.build-tag{font-size:8px;color:var(--text-muted);letter-spacing:1px;opacity:0.5;margin-top:6px}
.header-stats{display:flex;gap:24px;flex:1;justify-content:center}
.header-stat{text-align:center}
.header-stat-val{font-family:'Saira Semi Condensed',sans-serif;font-weight:700;font-size:20px;line-height:32px;color:var(--gold)}
.header-stat-label{font-family:'Saira Condensed',sans-serif;font-size:11px;line-height:13px;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px}

.controls{max-width:1600px;margin:0 auto;padding:4px 32px 5px;display:flex;gap:8px;flex-wrap:wrap;align-items:center;border-bottom:none;background-image:linear-gradient(to right,transparent,var(--border) 20px,var(--border) calc(100% - 20px),transparent);background-size:100% 1px;background-position:bottom;background-repeat:no-repeat}
.search-box{flex:1;min-width:220px;position:relative}
.search-box input{width:100%;display:block;padding:0 36px 0 40px;height:34px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:2px;
  color:var(--text-primary);font-family:'Saira',sans-serif;font-size:13px;outline:none;transition:border-color 0.2s}
.search-box input:focus{border-color:var(--accent-cyan)}
.search-box input:-webkit-autofill,
.search-box input:-webkit-autofill:hover,
.search-box input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--bg-secondary) inset;-webkit-text-fill-color:var(--text-primary);caret-color:var(--text-primary)}
.search-box::before{content:'⌕';position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:14px}
.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);
  font-size:16px;cursor:pointer;padding:2px 6px;display:none;transition:color 0.15s}
.search-clear:hover{color:var(--text-primary)}
.search-box.has-query .search-clear{display:block}
select.fs{padding:4px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:2px;
  color:var(--text-secondary);font-family:'Saira',sans-serif;font-size:11px;outline:none;cursor:pointer;transition:all 0.15s}
select.fs:hover{border-color:var(--ember);color:var(--text-primary)}
select.fs:focus{border-color:var(--accent-cyan)}
.view-toggle{display:flex;gap:4px;background:rgba(127,178,201,0.08);border:1px solid rgba(127,178,201,0.35);border-radius:2px;padding:2px;height:34px;align-self:center}
.view-btn{padding:0 12px;font-size:11px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;color:var(--text-secondary);background:transparent;
  border:none;border-radius:2px;cursor:pointer;transition:all 0.15s}
.view-btn:hover{color:var(--text-primary)}.view-btn.active{color:var(--gold);background:rgba(249,104,0,0.12)}

.sort-bar{max-width:1600px;margin:0 auto;padding:2px 32px 5px;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);background-color:var(--bg-primary);border-bottom:none;background-image:linear-gradient(to right,transparent,var(--border) 20px,var(--border) calc(100% - 20px),transparent);background-size:100% 1px;background-position:bottom;background-repeat:no-repeat}
.col-toggles{max-width:1600px;margin:0 auto;padding:2px 32px;display:none;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);flex-wrap:wrap;background:var(--bg-primary)}
.col-toggles.show{display:flex}
.col-toggles label{display:flex;align-items:center;gap:3px;cursor:pointer;padding:2px 6px;border-radius:2px;background:rgba(255,255,255,0.03);border:1px solid var(--border)}
.col-toggles label:hover{border-color:var(--gold)}
.col-toggles input{accent-color:var(--gold)}
.col-toggle-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:2px;font-size:11px;cursor:pointer;font-family:'Saira Condensed',sans-serif;letter-spacing:0.3px;transition:all 0.15s}
.col-toggle-btn:hover,.col-toggle-btn.active{color:var(--gold);border-color:var(--gold)}
.filter-chips{max-width:1600px;margin:0 auto;padding:2px 32px;margin-top:-1px;border:none;background-image:linear-gradient(to right,transparent,var(--border) 20px,var(--border) calc(100% - 20px),transparent),linear-gradient(to right,transparent,var(--border) 20px,var(--border) calc(100% - 20px),transparent);background-size:100% 1px,100% 1px;background-position:top,bottom;background-repeat:no-repeat,no-repeat;display:flex;gap:6px;flex-wrap:wrap;align-items:center;background-color:var(--bg-primary)}
.filter-chips:empty{display:none}
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;font-family:'Saira',sans-serif;font-size:11px;font-weight:600;
  border-radius:2px;cursor:default;animation:chipIn 0.15s ease-out}
.chip .chip-x{cursor:pointer;opacity:0.6;font-size:13px;line-height:1;margin-left:2px;transition:opacity 0.15s}
.chip .chip-x:hover{opacity:1}
.chip-search{color:var(--gold);background:rgba(249,104,0,0.1);border:1px solid rgba(249,104,0,0.3)}
.chip-cat{color:var(--accent-cyan);background:rgba(127,178,201,0.1);border:1px solid rgba(127,178,201,0.25)}
.chip-biome{color:var(--biome-meadows);background:rgba(124,174,90,0.1);border:1px solid rgba(124,174,90,0.25)}
.chip-rarity{color:var(--accent-red);background:rgba(215,0,0,0.12);border:1px solid rgba(215,0,0,0.35)}
.chip-clear{color:var(--text-muted);background:transparent;border:1px solid var(--border);cursor:pointer;font-weight:400;transition:all 0.15s}
.chip-clear:hover{color:var(--gold);border-color:var(--gold)}
@keyframes chipIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}
.sort-btn{padding:4px 10px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.3px;font-size:11px;color:var(--text-secondary);background:var(--bg-card);
  border:1px solid var(--border);border-radius:2px;cursor:pointer;transition:all 0.15s}
.sort-btn:hover{color:var(--text-primary);border-color:var(--ember)}
.sort-btn.active{color:var(--gold);background:rgba(249,104,0,0.1);border-color:rgba(249,104,0,0.35)}

.content{max-width:1600px;margin:0 auto;padding:6px 32px 64px}

.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:10px}
.item-card{background:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:14px;
  transition:all 0.25s;cursor:default;position:relative;overflow:hidden;animation:fadeUp 0.3s ease both;
  display:flex;flex-direction:column}
.item-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--card-accent,var(--gold));opacity:0;transition:opacity 0.25s}
.item-card:hover{border-color:var(--border-accent);background:var(--bg-card-hover);
  transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.4)}
.item-card:hover::before{opacity:1}
.card-boss{border-color:rgba(215,0,0,0.4)}
.card-boss::before{opacity:0.5}

/* Header block is fixed-height so divider 1 sits at the same y on every card:
   130px image slot, 2-line name reserve, 4-line clamped desc */
.card-head{position:relative;min-height:132px;overflow:hidden}
.card-hero{display:flex;gap:12px;align-items:stretch}
.card-img-wrap{flex-shrink:0;display:flex}
.card-info{flex:1;min-width:0}
.card-name{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:17px;line-height:1.2;padding-right:70px;
  min-height:2.4em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-cat{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:6px;font-family:'Saira Condensed',sans-serif}
.card-desc{font-size:11px;color:var(--text-muted);font-style:italic;margin-top:6px;line-height:1.4;height:5.6em;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.card-thumb{width:130px;height:130px;border-radius:2px;background:rgba(0,0,0,0.25);border:1px solid var(--border);flex-shrink:0;object-fit:contain;align-self:flex-start;image-rendering:auto;padding:6px}
/* Small game-UI sprites (<=96px natural, tagged .icon-sm by JS): 64px sprite ->
   75px content in a 91px slot; smooth scaling (auto) -- at this modest 1.17x upscale,
   bilinear smoothing reads far less harsh than pixelated's uneven pixel chunks */
.card-thumb.icon-sm{width:91px;height:91px;object-fit:contain;image-rendering:auto;padding:8px;
  background:radial-gradient(circle at 50% 42%,rgba(249,104,0,0.10),rgba(0,0,0,0) 60%),linear-gradient(180deg,#242424,#101010);
  border-color:#3c4147;box-shadow:inset 0 2px 10px rgba(0,0,0,0.7),inset 0 0 0 1px rgba(127,178,201,0.14)}
/* Two-pane body under divider 1: equal 50/50 panes so the vertical line sits at
   the exact center of the card; each pane keeps 12px clearance from the line */
.card-cols{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.card-body{min-width:0;padding-right:12px;padding-bottom:8px}
.card-body:only-child{grid-column:1/-1;padding-right:0}
.card-body:empty{display:none}
.card-bottom{min-width:0;padding-left:12px;border-left:1px solid var(--border);
  display:grid;grid-template-columns:auto minmax(0,auto);justify-content:start;gap:3px 10px;align-content:start;font-size:11px}
.cb-row{display:contents}
.cb-row .attr-label{font-size:10px;color:var(--text-muted);white-space:nowrap;text-transform:uppercase;font-weight:600;letter-spacing:0.5px;font-family:'Saira Condensed',sans-serif}
.cb-val{color:var(--text-secondary);overflow-wrap:anywhere}
.cb-chips{display:flex;flex-direction:column;gap:3px;align-items:flex-start;min-width:0;max-width:100%}
.cb-chips .recipe-pill{white-space:normal}
.card-head .badge-boss{position:absolute;top:0;right:0}
.card-head .build-badge{position:absolute;top:0;right:0;margin-top:0}

/* value column hugs content (no stretch = no dead band before the center line);
   minmax(0,auto) still lets long values shrink + wrap via overflow-wrap */
.card-stats-grid{display:grid;grid-template-columns:auto minmax(0,auto);justify-content:start;gap:3px 10px;font-size:11px;align-items:baseline}
.card-creature .card-stats-grid{grid-template-columns:auto minmax(0,auto)}
.card-stats-grid .sg-cell{display:contents}
.card-stats-grid .sg-lbl{color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:8px;letter-spacing:0.5px;white-space:nowrap;font-family:'Saira Condensed',sans-serif}
.card-stats-grid .sg-val{color:var(--text-secondary);overflow-wrap:anywhere}
.stat-hp{color:#e8694a;font-weight:600}
.stat-stam{color:var(--biome-meadows);font-weight:600}
.stat-eitr{color:var(--accent-purple);font-weight:600}
.hp-stars{display:flex;flex-wrap:wrap;gap:8px}
.hp-star{font-size:10px;color:var(--gold);white-space:nowrap}

.card-note{font-size:11px;color:var(--text-secondary);margin-top:6px;line-height:1.4;font-style:italic;padding:5px 8px;background:rgba(249,104,0,0.05);border-left:2px solid rgba(249,104,0,0.3);border-radius:0 4px 4px 0}
.card-note strong{color:var(--gold);font-style:normal}

.card-sources{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px;padding:6px 0;border-top:1px solid var(--border);margin-top:6px}
.card-sources .attr-label{font-size:10px;color:var(--text-muted);margin-right:4px;white-space:nowrap;text-transform:uppercase;font-weight:600;letter-spacing:0.5px;font-family:'Saira Condensed',sans-serif}
/* display:contents lets pills participate directly in the row's flex flow,
   so chips wrap inline after the label instead of dropping below it as a block */
.source-list{display:contents}
.source-pill{font-size:9px;padding:1px 6px;border-radius:2px;background:rgba(90,143,176,0.1);border:1px solid rgba(90,143,176,0.25);color:var(--accent-blue);white-space:nowrap}
.zone-pill{font-size:9px;padding:1px 6px;border-radius:2px;background:rgba(127,178,201,0.1);border:1px solid rgba(127,178,201,0.2);color:var(--accent-cyan);white-space:nowrap}
.recipe-pill{display:inline-flex;align-items:center;gap:3px;font-size:9px;padding:1px 6px;border-radius:2px;background:rgba(249,104,0,0.08);border:1px solid rgba(249,104,0,0.25);color:var(--gold);white-space:nowrap}
.recipe-qty{font-family:'Saira Condensed',sans-serif;font-weight:700;color:var(--text-primary)}
.biome-pill{font-size:9px;padding:1px 7px;border-radius:2px;background:rgba(255,255,255,0.03);border:1px solid var(--border);white-space:nowrap;font-weight:600}
.boss-pill{font-size:9px;padding:1px 6px;border-radius:2px;background:rgba(215,0,0,0.12);border:1px solid rgba(215,0,0,0.35);color:var(--accent-red);white-space:nowrap;font-weight:600}
.weak-pill{font-size:9px;padding:1px 6px;border-radius:2px;white-space:nowrap;background:rgba(255,255,255,0.03);border:1px solid var(--border);color:var(--text-secondary)}
.weak-weak{color:#e8694a;border-color:rgba(232,105,74,0.3);background:rgba(232,105,74,0.08)}
.weak-res{color:var(--accent-cyan);border-color:rgba(127,178,201,0.3);background:rgba(127,178,201,0.07)}
.weak-vres{color:var(--accent-blue);border-color:rgba(90,143,176,0.3);background:rgba(90,143,176,0.07)}
.weak-imm{color:var(--text-muted);border-color:var(--border)}

.badge{padding:3px 8px;font-family:'Saira Condensed',sans-serif;font-size:10px;border-radius:2px;letter-spacing:0.5px;white-space:nowrap;font-weight:700}
.badge-boss{color:#050505;background:linear-gradient(135deg,var(--accent-red),#8f0000);border:1px solid rgba(215,0,0,0.6);box-shadow:0 0 10px rgba(215,0,0,0.4)}
.tbl-boss{font-size:8px;padding:1px 5px;margin-left:4px}

/* Tracking badges (favorite star + build) -- bottom-anchored */
.card-track-row{margin-top:auto;padding-top:10px;display:flex;justify-content:flex-end}
.badge-track{color:var(--text-muted);background:rgba(255,255,255,0.04);border:1px solid var(--border);font-size:9px;padding:3px 10px;border-radius:2px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all 0.15s;font-family:'Saira Condensed',sans-serif;letter-spacing:0.3px}
.badge-track:hover{background:rgba(249,104,0,0.1);border-color:rgba(249,104,0,0.3);color:var(--text-secondary)}
.badge-track input{accent-color:var(--gold);cursor:pointer;width:12px;height:12px}
.fav-btn .fav-star{font-size:12px;color:var(--gold)}
.badge-completed{color:var(--gold)!important;background:rgba(249,104,0,0.12)!important;border-color:rgba(249,104,0,0.45)!important;font-weight:700}
.badge-completed input{accent-color:var(--gold)!important}

.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:2px;background:var(--bg-card)}
table.dt{width:100%;border-collapse:collapse;font-size:13px}
table.dt th{padding:10px 12px;font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:11px;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border);
  text-align:left;white-space:nowrap;cursor:pointer;user-select:none;transition:color 0.15s}
table.dt th:hover{color:var(--gold)}table.dt th.sorted{color:var(--gold)}
table.dt td{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,0.03);vertical-align:top}
table.dt tr:hover td{background:rgba(255,255,255,0.02)}
.tbl-thumb{width:32px;height:32px;border-radius:2px;background:rgba(0,0,0,0.25);border:1px solid var(--border);object-fit:contain;vertical-align:middle;padding:2px}
.tbl-thumb.icon-sm{background:linear-gradient(180deg,#242424,#101010);border-color:#3c4147}

.load-more-btn{display:block;width:100%;padding:12px;margin-top:10px;background:rgba(249,104,0,0.1);border:1px solid rgba(249,104,0,0.3);border-radius:2px;color:var(--gold);font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;font-size:13px;cursor:pointer;transition:all 0.15s}
.load-more-btn:hover{background:rgba(249,104,0,0.2);border-color:var(--gold)}
.linkish{background:none;border:none;color:var(--accent-cyan);cursor:pointer;text-decoration:underline;font-size:inherit}

/* Auth UI */
.auth-wrap{display:flex;gap:6px;align-items:center}
.auth-btn{padding:0 14px;height:34px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;font-size:11px;color:var(--gold);
  background:rgba(249,104,0,0.1);border:1px solid rgba(249,104,0,0.3);border-radius:2px;cursor:pointer;transition:all 0.2s;white-space:nowrap;display:flex;align-items:center}
.auth-btn:hover{background:rgba(249,104,0,0.2);border-color:var(--gold)}
.auth-username{font-weight:600}
.dash-edit-btn{margin-left:8px;padding:0;background:none;border:none;color:var(--text-muted);font-size:15px;line-height:1;cursor:pointer;vertical-align:middle}
.dash-edit-btn:hover{color:var(--gold)}
.auth-modal-title{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:12px;text-align:center;font-family:'Saira Condensed',sans-serif}
.auth-user{position:relative}
.auth-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:4px;background:#050505;border:1px solid var(--border);border-radius:2px;overflow:hidden;z-index:200;min-width:120px}
.auth-dropdown.open{display:block}
.auth-dropdown a{display:block;padding:8px 16px;color:var(--text-secondary);text-decoration:none;font-size:11px;font-family:'Saira',sans-serif;transition:background 0.15s}
.auth-dropdown a:hover{background:rgba(249,104,0,0.1);color:var(--gold)}
.auth-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:300;background:rgba(0,0,0,0.85);align-items:center;justify-content:center}
.auth-modal.open{display:flex}
.auth-modal-content{background:#1b1b1b;border:1px solid var(--border-accent);border-radius:2px;padding:24px;width:340px;max-width:90vw;position:relative;box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.auth-modal-close{position:absolute;top:8px;right:12px;background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer}
.auth-modal-close:hover{color:var(--text-primary)}
.auth-tabs{display:flex;gap:4px;margin-bottom:16px}
.auth-tab{flex:1;padding:8px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;font-size:12px;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:2px;cursor:pointer;transition:all 0.15s}
.auth-tab.active{color:var(--gold);background:rgba(249,104,0,0.1);border-color:rgba(249,104,0,0.3)}
.auth-input{width:100%;padding:10px 14px;margin-bottom:8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:2px;color:var(--text-primary);font-family:'Saira',sans-serif;font-size:13px;outline:none;box-sizing:border-box}
.auth-input:focus{border-color:var(--accent-cyan)}
.auth-submit{width:100%;padding:10px;margin-top:4px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;font-size:12px;color:var(--gold);background:rgba(249,104,0,0.1);border:1px solid rgba(249,104,0,0.3);border-radius:2px;cursor:pointer;transition:all 0.2s}
.auth-submit:hover{background:rgba(249,104,0,0.2);border-color:var(--gold)}
.auth-forgot{display:block;text-align:center;margin-top:8px;font-size:11px;color:var(--text-muted);text-decoration:none}
.auth-forgot:hover{color:var(--gold)}
.auth-hint{font-size:11px;color:var(--text-muted);margin-bottom:8px;text-align:center}
.auth-msg{font-size:11px;margin-bottom:8px;padding:6px 10px;border-radius:2px;display:none}
.auth-msg.error{display:block;color:#e8694a;background:rgba(232,105,74,0.1);border:1px solid rgba(232,105,74,0.2)}
.auth-msg.success{display:block;color:var(--biome-meadows);background:rgba(124,174,90,0.1);border:1px solid rgba(124,174,90,0.2)}
.auth-toast{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:var(--biome-meadows);color:#050505;padding:12px 24px;border-radius:2px;font-size:14px;font-weight:600;z-index:10000;animation:toastFade 5s ease-in-out}
@keyframes toastFade{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}10%{opacity:1;transform:translateX(-50%) translateY(0)}80%{opacity:1}100%{opacity:0}}

/* Dashboard */
.dashboard{max-width:1600px;margin:0 auto;padding:6px 32px 64px}
.dash-hero{display:flex;align-items:center;gap:24px;padding:20px 24px;margin-bottom:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:2px}
.dash-hero-ring{width:90px;height:90px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:conic-gradient(var(--ring-color) calc(var(--pct) * 1%),rgba(127,178,201,0.15) 0);flex-shrink:0;position:relative}
.dash-hero-ring::before{content:'';position:absolute;width:70px;height:70px;border-radius:50%;background:var(--bg-card)}
.dash-hero-num{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:24px;color:var(--text-primary);z-index:1}
.dash-hero-info{flex:1}
.dash-title{font-family:'Saira Condensed',sans-serif;font-size:22px;color:var(--gold);margin-bottom:2px}
.dash-rank{font-family:'Saira Condensed',sans-serif;font-size:14px;margin-bottom:8px;letter-spacing:1px}
.dash-hero-stats{display:flex;gap:16px;font-size:11px;color:var(--text-muted);font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px}
.dash-pct{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:14px;margin-left:4px}
.dash-section{margin-bottom:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:2px;overflow:hidden}
.dash-header{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background 0.15s}
.dash-header:hover{background:rgba(255,255,255,0.02)}
.dash-label{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:16px;color:var(--text-primary)}
.dash-progress{font-family:'Saira Condensed',sans-serif;font-size:12px;color:var(--gold);margin-left:auto;letter-spacing:0.5px}
.dash-bar{width:120px;height:6px;background:rgba(127,178,201,0.12);border-radius:2px;overflow:hidden}
.dash-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 0.3s}
.dash-list{padding:8px 16px 16px;display:grid;grid-template-columns:repeat(2,1fr);gap:2px 12px}
.dash-list.collapsed{display:none}
.dash-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:2px;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:background 0.15s}
.dash-item:hover{background:rgba(255,255,255,0.03)}
.dash-item>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.dash-item.checked span{color:var(--gold)}
.dash-thumb{width:28px;height:28px;border-radius:2px;object-fit:contain;flex-shrink:0;background:rgba(0,0,0,0.2);padding:2px}
.dash-thumb.icon-sm{background:linear-gradient(180deg,#242424,#101010)}
.dash-item input{accent-color:var(--gold)}
.dash-fav-cat{flex:0 0 auto!important;font-size:9px;color:var(--text-muted);font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:0.5px}
.dash-empty{grid-column:1/-1;padding:16px;color:var(--text-muted);font-size:12px;font-style:italic}

.empty-state{text-align:center;padding:80px 32px;color:var(--text-muted)}
.empty-state .icon{font-size:48px;margin-bottom:16px;opacity:0.3}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.donate-wrap{position:relative;display:flex;align-items:center;gap:8px}
.creator-msg{font-family:'Saira Condensed',sans-serif;font-size:12.5px;color:var(--text-muted);letter-spacing:0.6px;line-height:1.5;text-align:right;align-self:center}
.creator-msg strong{color:var(--gold)}
.donate-btn{padding:0 14px;height:34px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;font-size:11px;color:var(--gold);background:rgba(249,104,0,0.1);display:flex;align-items:center;
  border:1px solid rgba(249,104,0,0.3);border-radius:2px;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.donate-btn:hover{background:rgba(249,104,0,0.2);border-color:var(--gold)}
.donate-popup{display:none;position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-card);border:1px solid var(--border-accent);
  border-radius:2px;padding:20px;z-index:200;box-shadow:0 12px 40px rgba(0,0,0,0.6);text-align:center;min-width:240px}
.donate-popup.open{display:block}
.donate-title{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:15px;margin-bottom:10px;color:var(--text-primary)}
.donate-label{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px}
.donate-crypto{font-family:'Saira Condensed',sans-serif;font-size:11px;font-weight:700;color:var(--gold)}
.donate-crypto-name{font-size:10px;color:var(--text-muted)}
.donate-qr{border-radius:2px;width:160px;height:160px;display:block;margin:0 auto 10px}
.donate-copy{display:flex;align-items:center;gap:6px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:2px;padding:6px 8px;cursor:pointer}
.donate-addr{font-family:'Saira',sans-serif;font-size:9px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.donate-copy-txt{font-size:10px;color:var(--gold);font-weight:600;white-space:nowrap}
.site-footer{text-align:center;padding:24px 16px;margin-top:32px;border-top:1px solid var(--border);color:var(--text-muted);font-size:11px;line-height:1.6}
.visitor-counter{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}
.vc-label{font-family:'Saira Condensed',sans-serif;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px}
.vc-num{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:18px;color:var(--gold);letter-spacing:1px}

#mobilePanel{border-top:none}
#mobilePanel.collapsed{display:none}
#filterPanel{transition:max-height 0.25s ease,opacity 0.2s ease;overflow:hidden}
#filterPanel.collapsed{max-height:0!important;opacity:0;pointer-events:none}
.filter-row{max-width:1600px;margin:0 auto;display:flex;flex-wrap:wrap;gap:6px;padding:2px 32px}
.cat-bar{max-width:1600px;margin:-1px auto 0;display:flex;flex-wrap:wrap;gap:4px;padding:5px 32px 2px;overflow-x:auto;align-items:center;border-top:none;background-image:linear-gradient(to right,transparent,var(--border) 20px,var(--border) calc(100% - 20px),transparent);background-size:100% 1px;background-position:top;background-repeat:no-repeat}
#catBar{display:contents}
.cat-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:2px;padding:4px 10px;font-size:11px;
  color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all 0.15s ease;font-family:'Saira Condensed',sans-serif;letter-spacing:0.3px}
.cat-btn:hover{border-color:var(--ember);color:var(--text-primary)}
.cat-btn.active{background:rgba(249,104,0,0.1);border-color:rgba(249,104,0,0.35);color:var(--gold);font-weight:600}
.cat-count{font-size:9px;color:var(--text-muted);margin-left:2px}
.cat-btn.active .cat-count{color:rgba(233,228,208,0.7)}

.card-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:rgba(0,0,0,0.85);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:20px;overflow-y:auto}
.card-overlay-wrap{max-width:420px;width:100%;cursor:default}
.card-overlay-wrap .item-card{margin:0}
/* Detail overlay: unclamp name/desc so the full text is readable */
.card-overlay-wrap .card-name{display:block;min-height:0;-webkit-line-clamp:none}
.card-overlay-wrap .card-desc{display:block;height:auto;-webkit-line-clamp:none}
.card-overlay-wrap .card-head{min-height:0}
.buildlog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;background:rgba(0,0,0,0.85);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:20px}
.buildlog-wrap{max-width:560px;width:100%;max-height:85vh;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border-accent);border-radius:2px;cursor:default;overflow:hidden;box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.buildlog-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:16px;letter-spacing:1px;color:var(--gold)}
.buildlog-head .buildlog-close{font-family:initial;color:var(--text-muted)}
.buildlog-close{background:none;border:none;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;padding:0 4px}
.buildlog-close:hover{color:var(--text-primary)}
.buildlog-body{padding:14px 18px;overflow-y:auto;font-size:12px;line-height:1.5;color:var(--text-secondary)}
.buildlog-body>:first-child{margin-top:0}
.buildlog-body h3{font-size:13px;color:var(--text-primary);margin:14px 0 4px;border-bottom:1px solid var(--border);padding-bottom:3px;font-family:'Saira Condensed',sans-serif}
.buildlog-body ul{margin:2px 0 8px;padding-left:16px}
.buildlog-body li{margin:2px 0}
.buildlog-body p{margin:4px 0}
.buildlog-body code{background:rgba(255,255,255,0.08);padding:1px 4px;border-radius:2px;font-size:11px;color:var(--accent-cyan)}
.version-tag,.build-tag{cursor:pointer}
.version-tag:hover,.build-tag:hover{color:var(--gold)}

.mobile-fab{display:none;position:fixed;top:10px;right:10px;z-index:200;background:var(--bg-card);border:1px solid var(--border);
  border-radius:2px;color:var(--text-secondary);font-size:18px;padding:8px 12px;cursor:pointer;line-height:1;
  opacity:0;transition:opacity 0.2s ease;pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,0.4)}
.mobile-fab.visible{opacity:1;pointer-events:auto}
.mobile-menu-btn{background:rgba(249,104,0,0.1);border:1px solid rgba(249,104,0,0.3);border-radius:2px;height:34px;display:flex;align-items:center;
  color:var(--gold);font-size:11px;font-family:'Saira Condensed',sans-serif;letter-spacing:0.5px;padding:6px 12px;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.mobile-menu-btn:hover,.mobile-menu-btn.open{background:rgba(249,104,0,0.2);border-color:var(--gold)}
.btn-short{display:none}
@media(max-width:768px){
  .header{padding:0}
  .header-inner{gap:6px;padding:4px 12px;height:auto}
  .header-stats{gap:8px}
  .logo{gap:4px}
  .logo-mark{width:24px;height:24px;font-size:16px}
  .logo-text{font-size:13px;line-height:15px;letter-spacing:0.5px}
  .logo-sub{font-size:7px;line-height:9px;letter-spacing:1px}
  .creator-msg{display:none}
  .header-stat-val{font-size:11px;line-height:15px;}
  .header-stat-label{font-size:7px;line-height:9px;letter-spacing:1px}
  .auth-btn{height:22px;font-size:8px;padding:0 6px}
  .dash-edit-btn{font-size:13px}
  .auth-wrap{gap:4px}
  .donate-wrap{gap:4px}
  .mobile-donate-stack{display:flex;flex-direction:row;align-items:center;gap:4px}
  .donate-btn{font-size:8px;padding:0 6px;height:22px}
  .donate-btn .donate-btn-text{display:none}
  .mobile-menu-btn{padding:0 6px;height:22px}
  .btn-full{display:none}
  .btn-short{display:inline-block;font-size:7px;line-height:1.2;text-align:center}
  #mobilePanel{display:none}
  #mobilePanel.open{display:block}
  .controls,.filter-row,.cat-bar,.sort-bar,.col-toggles,.filter-chips,.content,.dashboard{padding-left:12px;padding-right:12px}
  .controls{flex-wrap:nowrap;padding-top:4px;padding-bottom:5px}
  .search-box{min-width:0}
  .view-toggle{height:22px}
  .view-btn{padding:0 6px;font-size:9px}
  .search-box input{height:22px;font-size:11px}
  .card-grid{grid-template-columns:1fr}
  .dash-hero{flex-direction:column;text-align:center;padding:14px 12px;gap:12px}
  .dash-hero-ring{width:72px;height:72px}
  .dash-hero-ring::before{width:56px;height:56px}
  .dash-hero-num{font-size:20px}
  .dash-title{font-size:18px}
  .dash-rank{font-size:12px}
  .dash-hero-stats{justify-content:center;flex-wrap:wrap;gap:8px;font-size:10px}
  .dash-header{padding:10px 12px;gap:8px}
  .dash-label{font-size:14px}
  .dash-progress{font-size:10px}
  .dash-bar{width:80px;height:5px}
  .dash-list{grid-template-columns:1fr;padding:6px 10px 12px}
  .dash-item{gap:8px;padding:6px 8px;font-size:12px}
  .dash-thumb{width:24px;height:24px}
  .card-head{min-height:100px}
  .card-thumb,.no-img{width:98px;height:98px;padding:4px}
  /* mobile slot: 96px content box, 64px sprites upscale 1.5x pixelated */
  .card-thumb.icon-sm{padding:0}
  .card-name{font-size:15px;padding-right:64px}
  .auth-modal-content{padding:16px;width:calc(100vw - 24px)}
}

/* Click-to-enlarge lightbox (apex pattern) */
.img-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:1000;display:flex;align-items:center;justify-content:center;cursor:zoom-out}
.img-overlay img{max-width:92vw;max-height:88vh;object-fit:contain;background:var(--bg-card);padding:12px;border:1px solid var(--border);border-radius:2px}
.card-thumb{cursor:zoom-in}
.no-img{width:130px;height:130px;border-radius:2px;background:rgba(0,0,0,0.25);border:1px dashed var(--border);flex-shrink:0;align-self:flex-start;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-family:'Saira Condensed',sans-serif;font-size:11px;letter-spacing:2px}
.streak-cost{color:var(--gold);font-weight:700;font-size:15px}
