/* ========== RESET ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;font-family:'Segoe UI',system-ui,sans-serif;background:#1a1a2e;color:#e0e0e0}
canvas{position:fixed;top:0;left:0;z-index:0}
.hidden{display:none !important}

/* ========== TITLE SCREEN ========== */
.title-screen{position:fixed;top:0;left:0;width:100%;height:100%;z-index:100;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#0d1117 0%,#1a2332 50%,#0d1a0d 100%)}
.title-content{text-align:center}
.title-logo{font-size:3.5rem;font-weight:900;letter-spacing:-2px;color:#fff;margin-bottom:4px}
.title-logo span{color:#66bb6a}
.title-sub{color:#888;font-size:1.1rem;margin-bottom:32px}
.title-buttons{display:flex;flex-direction:column;gap:10px;align-items:center}
.title-btn{padding:14px 48px;border-radius:12px;border:none;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s;min-width:220px}
.title-continue{background:linear-gradient(135deg,#66bb6a,#4caf50);color:#000}
.title-continue:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(76,175,80,.3)}
.title-new{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15)}
.title-new:hover{background:rgba(255,255,255,.15)}
.title-warn{color:#666;font-size:.8rem;margin-top:16px}
.title-info{text-align:left;max-width:400px;margin:0 auto 20px;font-size:.85rem;color:#aaa;line-height:1.6}
.title-info p{margin-bottom:8px}
.title-lose{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.25);border-radius:8px;padding:8px 12px;color:#f87171;font-size:.82rem;margin:10px 0}
.title-controls{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.title-controls span{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:4px 10px;font-size:.75rem;color:#888;font-family:monospace}

/* ========== RESOURCE BAR ========== */
#resourceBar{position:fixed;top:0;left:0;right:0;height:40px;background:rgba(10,10,20,.9);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;padding:0 16px;gap:16px;z-index:10;font-size:.85rem}
.res-item{display:flex;align-items:center;gap:5px;font-weight:600}
.res-icon{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.res-img{width:18px;height:18px;object-fit:contain;flex-shrink:0;image-rendering:pixelated}
.trap-icon{background:#e57373;border-radius:50%}
.res-divider{width:1px;height:20px;background:rgba(255,255,255,.1)}
.critter-counter{color:#ce93d8}
#resWood{color:#8d6e63}
#resStone{color:#90a4ae}
#resFood{color:#9ccc65}
#resIron{color:#b0bec5}
.res-rate{font-size:.65rem;color:#4ade80;font-weight:400;margin-left:2px}
.res-time{color:#fbbf24;font-weight:700;font-size:.8rem;font-family:monospace}
.res-horde{color:#f87171;font-weight:700;font-size:.8rem;font-family:monospace}
.res-actions{display:flex;gap:4px;margin-left:auto}
.res-btn{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:#aaa;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.res-btn:hover{background:rgba(255,255,255,.12);color:#fff}

/* Settings Panel */
.settings-panel{position:fixed;top:48px;right:308px;width:280px;background:rgba(14,14,28,.97);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:12px;z-index:20;padding:16px}
.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:700;font-size:.95rem}
.settings-body{display:flex;flex-direction:column;gap:10px}
.setting-row{display:flex;align-items:center;gap:8px;font-size:.82rem;color:#ccc}
.setting-row span:first-child{flex:1;min-width:100px}
.setting-row input[type="range"]{flex:1;accent-color:#66bb6a;height:4px}
.setting-row input[type="checkbox"]{accent-color:#66bb6a;width:16px;height:16px}
.setting-row span:last-child{min-width:36px;text-align:right;color:#888;font-size:.75rem}

/* Pause Overlay */
.pause-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:200;display:flex;justify-content:center;align-items:center}
.pause-overlay.hidden{display:none}
.pause-content{text-align:center}
.pause-content h2{font-size:3rem;font-weight:900;color:#fff;margin-bottom:8px;letter-spacing:4px}
.pause-content p{color:#888;margin-bottom:20px}

/* ========== BUILD MENU MODAL ========== */
.build-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:200;display:flex;justify-content:center;align-items:center}
.build-modal.hidden{display:none}
.build-modal-content{background:rgba(14,14,28,.97);border:1px solid rgba(255,255,255,.1);border-radius:16px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}
.build-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.build-modal-header h2{font-size:1.2rem;font-weight:800;color:#fff;margin:0}
.build-modal-close{background:none;border:none;color:#888;font-size:1.6rem;cursor:pointer;padding:0 4px}
.build-modal-close:hover{color:#fff}
.build-modal-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06)}
.bm-tab{flex:1;padding:10px;border:none;background:transparent;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}
.bm-tab.active{color:#66bb6a;border-bottom:2px solid #66bb6a}
.bm-tab:hover{color:#fff}
.build-modal-body{flex:1;overflow-y:auto;padding:14px;max-height:calc(85vh - 110px)}

/* Kept for panel body content styling */
.panel-body{overflow-y:auto;padding:10px}

/* Build items */
.panel-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#555;padding:6px 0 4px}
.build-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.build-item{padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);cursor:pointer;transition:all .2s;position:relative}
.build-item:hover{border-color:rgba(102,187,106,.3);background:rgba(102,187,106,.08);transform:translateY(-1px)}
.build-item.disabled{opacity:.35;cursor:not-allowed}
.build-item.disabled:hover{border-color:rgba(255,255,255,.08);background:rgba(255,255,255,.03);transform:none}
.build-item.locked{opacity:.5}
.build-item.locked::after{content:'🔒';position:absolute;top:8px;right:8px;font-size:1rem}
.build-locked-text{display:block;font-size:.7rem;color:#f87171;font-style:italic}
.build-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.build-icon{width:40px;height:40px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}
.build-icon-fallback{display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;color:#fff}
.build-header-text{flex:1;min-width:0}
.build-name{display:block;font-weight:700;font-size:.9rem;color:#fff}
.build-cost{display:block;font-size:.75rem;color:#fbbf24;margin-top:1px}
.build-desc{display:block;font-size:.7rem;color:#888;margin-top:2px}
.build-hp{display:block;font-size:.65rem;color:#90a4ae;margin-top:2px}

/* Placed buildings */
.placed-building{padding:8px;border-radius:6px;background:rgba(255,255,255,.02);margin-bottom:4px;display:flex;justify-content:space-between;align-items:center;font-size:.8rem}
.pb-name{font-weight:600;color:#ddd}
.pb-workers{color:#888}
.pb-rate{color:#4ade80;font-weight:600}

/* Critter cards */
.panel-empty{text-align:center;color:#555;padding:24px;font-size:.85rem;line-height:1.6}
.critter-card{padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);margin-bottom:6px}
.cc-header{display:flex;align-items:center;gap:6px}
.cc-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.cc-icon{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}
.cc-name{font-weight:700;font-size:.9rem;flex:1}
.cc-level{color:#fbbf24;font-size:.75rem;font-weight:600}
.cc-type-row{display:flex;align-items:center;gap:8px;margin:2px 0}
.critter-card{position:relative}
.cc-card-injured{border-color:rgba(248,113,113,.3) !important;background:rgba(248,113,113,.05) !important}
.cc-top{display:flex;gap:10px;align-items:center;margin-bottom:6px}
.cc-top-info{flex:1;min-width:0}
.cc-name-row{display:flex;align-items:baseline;gap:6px}
.cc-meta-row{display:flex;align-items:center;gap:6px;margin-top:2px}
.cc-status{font-size:.65rem;font-weight:600;margin-left:auto}
.cc-rarity{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.cc-type{font-size:.65rem;font-weight:600}

/* Passives section — prominent */
.cc-passives-section{margin:6px 0;padding:6px;background:rgba(255,255,255,.02);border-radius:6px;border:1px solid rgba(255,255,255,.04)}
.cc-passives-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#555;margin-bottom:4px}
.cc-passive-full{display:flex;gap:6px;align-items:flex-start;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.03)}
.cc-passive-full:last-child{border:none}
.cc-passive-full.cc-passive-neg{opacity:.7}
.cc-pf-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center}
.cc-pf-info{flex:1;min-width:0}
.cc-pf-name{display:block;font-size:.75rem;font-weight:700}
.cc-pf-desc{display:block;font-size:.65rem;color:#888;line-height:1.3}
.cc-no-passives{font-size:.65rem;color:#444;text-align:center;padding:4px}

/* Patrol HP bar */
.cc-patrol-hp-bar{position:relative;height:14px;background:#222;border-radius:4px;margin:4px 0;overflow:hidden}
.cc-php-fill{height:100%;background:linear-gradient(90deg,#f87171,#ef4444);border-radius:4px;transition:width .3s}
.cc-patrol-hp-bar span{position:absolute;top:0;left:0;right:0;text-align:center;font-size:.6rem;line-height:14px;color:#fff;font-weight:600}
.cc-type-match{color:#4ade80 !important;background:rgba(74,222,128,.1) !important}
.cc-type-mismatch{color:#f87171 !important;background:rgba(248,113,113,.1) !important}
.cc-stats{display:flex;gap:6px;margin:4px 0;flex-wrap:wrap}
.cc-stat{font-size:.7rem;color:#aaa;background:rgba(255,255,255,.04);padding:2px 6px;border-radius:4px;display:flex;align-items:center;gap:2px}
.cc-stat-icon{width:12px;height:12px;object-fit:contain}
.cc-assign{margin-top:6px}
.cc-assign select{width:100%;background:#1a1a2e;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:6px 8px;color:#e0e0e0;font-size:.8rem;cursor:pointer}
.cc-assign select:focus{outline:none;border-color:rgba(102,187,106,.4)}
.cc-assign select option{background:#1a1a2e;color:#e0e0e0}
.cc-assign-hint{display:block;font-size:.6rem;color:#555;margin-top:2px;text-align:center}
.cc-xp{position:relative;height:14px;background:#222;border-radius:4px;margin:4px 0;overflow:hidden}
.cc-xp-bar{height:100%;background:linear-gradient(90deg,#fbbf24,#f59e0b);border-radius:4px;transition:width .3s}
.cc-xp-text{position:absolute;top:0;left:0;right:0;text-align:center;font-size:.6rem;line-height:14px;color:#fff;font-weight:600}
.cc-xp-max{background:rgba(74,222,128,.15);text-align:center}
.cc-bonus{font-size:.68rem;color:#4ade80;background:rgba(74,222,128,.08);padding:3px 6px;border-radius:4px;margin-top:4px}
.cc-injured{font-size:.72rem;color:#f87171;background:rgba(248,113,113,.1);padding:4px 8px;border-radius:6px;margin:4px 0;font-weight:600}
.cc-passives{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0}
.cc-passive{font-size:.65rem;padding:2px 6px;border-radius:4px;border:1px solid;background:rgba(255,255,255,.03);cursor:help;font-weight:600}
.cc-passive-neg{opacity:.7}
.cc-patrol-hp{font-size:.72rem;color:#f87171;margin:2px 0}
.cc-name{cursor:pointer}.cc-name:hover{text-decoration:underline;text-decoration-style:dotted}
.cc-sacrifice{width:100%;padding:6px;margin-top:4px;border-radius:6px;border:1px solid rgba(248,113,113,.25);background:rgba(248,113,113,.06);color:#f87171;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}
.cc-sacrifice:hover{background:rgba(248,113,113,.15);border-color:rgba(248,113,113,.4)}
.res-dead{color:#f87171;font-weight:600;cursor:help}
.mb-injured{opacity:.5;border:1px solid rgba(248,113,113,.2) !important}
.mb-injury-time{margin-left:auto;color:#f87171;font-size:.7rem;font-weight:600}
.build-stat{display:flex;align-items:center;gap:4px;font-size:.72rem;color:#4ade80;margin-bottom:2px}
.build-stat-icon{width:14px;height:14px;object-fit:contain}
.title-hint{color:#666;font-size:.8rem;margin-top:16px}

/* ========== MANAGE TAB ========== */
.manage-building{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:10px;margin-bottom:8px}
.mb-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.mb-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}
.mb-name{font-weight:700;font-size:.85rem;flex:1}
.mb-cap{font-size:.7rem;color:#888}
.mb-best-type{font-size:.65rem;font-weight:600;margin-left:auto;margin-right:6px}
.mb-workers{display:flex;flex-direction:column;gap:4px}
.mb-worker{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;background:rgba(255,255,255,.03);cursor:pointer;transition:all .2s}
.mb-worker:hover{background:rgba(248,113,113,.08)}
.mb-worker.mb-empty{opacity:.3;cursor:default}
.mb-worker.mb-empty:hover{background:rgba(255,255,255,.03)}
.mb-worker-icon{width:24px;height:24px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff;object-fit:cover}
.mb-empty-icon{background:rgba(255,255,255,.1) !important;font-size:1rem;color:#555}
.mb-worker-name{font-size:.8rem;flex:1;color:#ddd}
.mb-worker-lv{font-size:.65rem;color:#fbbf24;font-weight:600}
.mb-worker-stat{font-size:.65rem;color:#4ade80;font-weight:600}
.mb-prod{font-size:.7rem;color:#4ade80;text-align:center;margin-top:6px;padding:4px;background:rgba(74,222,128,.06);border-radius:4px}
.mb-empty-assign{padding:4px}
.mb-assign-select{width:100%;background:#1a1a2e;border:1px solid rgba(102,187,106,.25);border-radius:6px;padding:6px 8px;color:#66bb6a;font-size:.78rem;cursor:pointer}
.mb-assign-select:focus{outline:none;border-color:rgba(102,187,106,.5)}
.mb-assign-select option{background:#1a1a2e;color:#e0e0e0}
.mb-idle-list{display:flex;flex-direction:column;gap:3px}
.mb-idle-critter{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;background:rgba(255,255,255,.02);font-size:.8rem;color:#888}

/* ========== WORKBENCH ========== */
.wb-open-btn{width:100%;padding:6px;margin-top:6px;border-radius:6px;border:1px solid rgba(255,171,145,.3);background:rgba(255,171,145,.1);color:#ffab91;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}
.wb-open-btn:hover{background:rgba(255,171,145,.2)}
.wb-inline-prog{height:3px;background:#222;border-radius:2px;margin-top:4px;overflow:hidden}
.wb-inline-bar{height:100%;background:#ffab91;border-radius:2px;transition:width .3s}
.wb-queue{font-size:.65rem;color:#888;display:block;margin-top:2px}

/* Workbench Panel */
.wb-panel{padding:4px 0}
.wb-panel-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:10px;font-weight:700;font-size:1rem}
.wb-close{background:none;border:none;color:#888;font-size:1.2rem;cursor:pointer;padding:0 4px}
.wb-close:hover{color:#fff}
.wb-recipe{display:flex;gap:12px;padding:12px;border-radius:10px;background:rgba(255,171,145,.06);border:1px solid rgba(255,171,145,.15);margin-bottom:10px}
.wb-recipe-icon{font-size:2rem;display:flex;align-items:center}
.wb-recipe-info{flex:1}
.wb-recipe-name{font-weight:700;font-size:.95rem;color:#fff}
.wb-recipe-desc{font-size:.72rem;color:#888;margin:2px 0}
.wb-recipe-cost{display:flex;gap:10px}
.wb-res{font-size:.78rem;color:#4ade80;font-weight:600}
.wb-res-lack{color:#f87171}
.wb-progress{margin-bottom:10px}
.wb-prog-bar{height:8px;background:#222;border-radius:4px;overflow:hidden}
.wb-prog-fill{height:100%;background:linear-gradient(90deg,#ffab91,#ff8a65);border-radius:4px;transition:width .3s}
.wb-prog-text{font-size:.7rem;color:#888;margin-top:2px;display:block;text-align:center}
.wb-craft-btns{display:flex;gap:6px;margin-bottom:10px}
.wb-craft-btn{flex:1;padding:10px;border-radius:8px;border:1px solid rgba(255,171,145,.3);background:rgba(255,171,145,.1);color:#ffab91;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s}
.wb-craft-btn:hover{background:rgba(255,171,145,.2);transform:translateY(-1px)}
.wb-craft-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}
.wb-queue-info{text-align:center;font-size:.8rem;color:#fbbf24;font-weight:600;padding:6px;background:rgba(251,191,36,.08);border-radius:6px;margin-bottom:10px}
.wb-workers-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#555;margin-bottom:6px}
.wb-worker-list{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.wb-worker-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;background:rgba(255,255,255,.03);font-size:.8rem}
.wb-worker-icon{width:20px;height:20px;border-radius:50%;object-fit:cover;flex-shrink:0}
.wb-no-workers{text-align:center;color:#555;font-size:.78rem;padding:8px;background:rgba(255,255,255,.02);border-radius:6px;margin-bottom:10px}
.wb-recipe{display:flex;gap:10px;padding:10px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);margin-bottom:6px;align-items:center}
.wb-recipe-icon{font-size:1.6rem;flex-shrink:0;width:36px;text-align:center}
.wb-recipe-info{flex:1;min-width:0}
.wb-recipe-name{font-weight:700;font-size:.9rem;color:#fff}
.wb-recipe-desc{font-size:.68rem;color:#888;margin:1px 0}
.wb-recipe-cost{display:flex;gap:8px;font-size:.75rem;flex-wrap:wrap}
.wb-recipe-btns{display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.wb-craft-sm{padding:4px 10px;border-radius:5px;border:1px solid rgba(255,171,145,.25);background:rgba(255,171,145,.08);color:#ffab91;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .15s}
.wb-craft-sm:hover{background:rgba(255,171,145,.2)}
.wb-craft-sm:disabled{opacity:.3;cursor:not-allowed}
.wb-recipe-locked{opacity:.4;cursor:not-allowed}
.wb-speed-info{font-size:.75rem;color:#888;text-align:center;margin-bottom:8px}
.wb-queue-sm{text-align:center;font-size:.7rem;color:#fbbf24;margin-bottom:6px}
.wb-inv-row{display:flex;justify-content:space-around;padding:8px;background:rgba(255,255,255,.03);border-radius:8px;font-size:.85rem;color:#ccc;margin-top:8px}
.wb-inv-row b{color:#fff}
.wb-status-msg{text-align:center;font-size:.78rem;font-weight:600;color:#fbbf24;padding:6px;margin:6px 0;transition:opacity .5s;min-height:24px}

/* ========== RESEARCH ========== */
.research-progress{padding:10px;border-radius:8px;background:rgba(92,107,188,.1);border:1px solid rgba(92,107,188,.3);margin-bottom:8px}
.rp-name{font-weight:700;font-size:.85rem;color:#818cf8;display:block;margin-bottom:4px}
.rp-bar{height:6px;background:#222;border-radius:3px;overflow:hidden}
.rp-fill{height:100%;background:linear-gradient(90deg,#818cf8,#a78bfa);border-radius:3px;transition:width .3s}
.rp-pct{font-size:.7rem;color:#888;margin-top:2px;display:block}
.research-item{padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);margin-bottom:6px}
.research-item.disabled{opacity:.4}
.research-item.active{border-color:rgba(129,140,248,.3);background:rgba(129,140,248,.06)}
.research-item.done{opacity:.5}
.ri-name{display:block;font-weight:700;font-size:.85rem;color:#ddd}
.ri-desc{display:block;font-size:.7rem;color:#888;margin:2px 0}
.ri-cost{display:block;font-size:.7rem;color:#fbbf24;margin-bottom:4px}
.ri-max{color:#4ade80;font-size:.75rem;font-weight:600}
.ri-btn{padding:4px 12px;border-radius:6px;border:1px solid rgba(129,140,248,.3);background:rgba(129,140,248,.1);color:#818cf8;font-size:.8rem;font-weight:600;cursor:pointer;float:right;margin-top:-20px}
.ri-btn:hover{background:rgba(129,140,248,.2)}
.ri-btn:disabled{opacity:.3;cursor:not-allowed}

/* ========== PARTY HUD (left side) ========== */
.party-hud{position:fixed;top:48px;left:8px;width:180px;z-index:10;display:flex;flex-direction:column;gap:6px;pointer-events:none}
.ph-section{background:rgba(10,10,20,.85);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:8px;pointer-events:auto}
.ph-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#666;margin-bottom:6px}
.ph-critter{display:flex;gap:8px;align-items:center;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.04)}
.ph-critter:last-child{margin-bottom:0;padding-bottom:0;border:none}
.ph-icon{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.ph-icon-fb{display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff}
.ph-info{flex:1;min-width:0}
.ph-name{font-size:.75rem;font-weight:700;color:#ddd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ph-lv{font-size:.6rem;color:#fbbf24;font-weight:600}
.ph-type{font-size:.7rem}
.ph-bar{position:relative;height:10px;background:#222;border-radius:3px;overflow:hidden;margin-top:2px}
.ph-fill{height:100%;border-radius:3px;transition:width .3s}
.ph-hp-fill{background:linear-gradient(90deg,#f87171,#ef4444)}
.ph-xp-fill{background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.ph-hunger-fill{background:linear-gradient(90deg,#4ade80,#22c55e)}
.ph-bar span{position:absolute;top:0;left:0;right:0;text-align:center;font-size:.5rem;line-height:10px;color:#fff;font-weight:600}

/* Hunger bar in critter cards */
.cc-hunger-bar{position:relative;height:12px;background:#222;border-radius:4px;margin:4px 0;overflow:hidden}
.cc-hunger-fill{height:100%;border-radius:4px;transition:width .3s}
.cc-hunger-bar span{position:absolute;top:0;left:0;right:0;text-align:center;font-size:.55rem;line-height:12px;color:#fff;font-weight:600}

/* ========== CONTROLS HINT ========== */
#controlsHint{position:fixed;bottom:12px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.3);font-size:.75rem;z-index:10;pointer-events:none}

/* ========== MULTIPLAYER HUD ========== */
.mp-hud{position:fixed;top:46px;right:12px;z-index:20;display:flex;align-items:center;gap:8px;background:rgba(10,10,30,.85);border:1px solid rgba(102,187,106,.3);border-radius:8px;padding:6px 12px;font-size:.8rem}
.mp-room{color:#66bb6a;font-weight:600}
.mp-room span{color:#fff}
.mp-btn{padding:4px 10px;border-radius:6px;border:none;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}
.mp-leave{background:rgba(248,113,113,.15);color:#f87171;border:1px solid rgba(248,113,113,.25)}
.mp-leave:hover{background:rgba(248,113,113,.3)}

/* ========== MULTIPLAYER LOBBY ========== */
.mp-lobby{position:fixed;top:0;left:0;width:100%;height:100%;z-index:90;display:flex;justify-content:center;align-items:center;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.mp-lobby-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.1);border-radius:16px;width:420px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.mp-lobby-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.mp-lobby-header h2{font-size:1.2rem;color:#fff}
.mp-lobby-body{padding:16px 20px}
.mp-section{margin-bottom:14px}
.mp-section label{display:block;font-size:.78rem;color:#888;margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.mp-input{width:100%;padding:8px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);color:#fff;font-size:.9rem;outline:none;transition:border-color .2s}
.mp-input:focus{border-color:#66bb6a}
.mp-actions{display:flex;gap:8px;margin-bottom:14px}
.mp-actions .title-btn{padding:10px 20px;font-size:.85rem;min-width:auto;flex:1}
.mp-room-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.mp-room-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .15s}
.mp-room-item:hover{background:rgba(102,187,106,.1);border-color:rgba(102,187,106,.3)}
.mp-room-info{display:flex;flex-direction:column;gap:2px}
.mp-room-host{font-weight:600;font-size:.9rem;color:#fff}
.mp-room-meta{font-size:.72rem;color:#888}
.mp-room-join{padding:6px 16px;border-radius:6px;border:none;background:linear-gradient(135deg,#66bb6a,#4caf50);color:#000;font-weight:700;font-size:.78rem;cursor:pointer}
.mp-room-join:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(76,175,80,.3)}
.mp-status{margin-top:10px;font-size:.8rem;color:#888;text-align:center;min-height:20px}
.mp-status.error{color:#f87171}

/* ========== SCROLLBAR ========== */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
