/* main.css - Thème fantasy rétro premium */
*{box-sizing:border-box}
:root{
  --bg:#1a1510;
  --pane:#2e251b;
  --pane2:#3e3227;
  --txt:#f0e6d2;
  --muted:#b0a188;
  --accent:#ffc44d;
  --gold:#ffd700;
  --danger:#e74c3c;
  --success:#2ecc71;
  --info:#3498db;
  --magic:#9b59b6;
}
html,body{height:100%;margin:0;background:var(--bg);color:var(--txt);font-family:Georgia,'Times New Roman',serif;overflow:hidden}
#game-wrapper{position:relative;width:100vw;height:100vh;overflow:hidden}

/* Screens */
.screen{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center}
.screen.active{display:flex}
#screen-title{background:radial-gradient(1200px 600px at 50% 30%,#2a2016,#1a1510);}
.title-content{text-align:center}
#screen-title h1{font-size:4rem;margin:0;color:var(--gold);text-shadow:0 0 16px rgba(255,215,0,.4),0 4px 0 #5e4b26;letter-spacing:.06em}
#screen-title h2{font-size:1.4rem;color:var(--muted);margin:.4rem 0 1.6rem;font-weight:400}
.btn-primary,.btn{display:inline-block;padding:.7rem 1.4rem;border:none;border-radius:.5rem;cursor:pointer;font:inherit;font-weight:700;letter-spacing:.02em;text-shadow:0 1px 0 rgba(0,0,0,.4)}
.btn{background:linear-gradient(180deg,var(--pane2),var(--pane));color:var(--txt);border:1px solid #574335;box-shadow:0 4px 0 #1c150f}
.btn-primary{background:linear-gradient(180deg,#f5b041,#c87a1d);color:#2b1e0a;border:1px solid #a86b18;box-shadow:0 4px 0 #5c3e0e}
.btn:active,.btn-primary:active{transform:translateY(2px);box-shadow:0 2px 0 #1c150f}
.btn:hover{filter:brightness(1.08)}
.btn-close{position:absolute;top:.6rem;right:.6rem;width:2rem;height:2rem;border-radius:50%;border:1px solid #574335;background:#3e3227;color:var(--txt);cursor:pointer;font-weight:700}

/* Main layout */
#screen-main{background:var(--bg);display:none;flex-direction:column;align-items:stretch;justify-content:flex-start}
#main-layout{display:flex;flex:1;overflow:hidden}
#ui-top-bar{padding:.4rem .8rem;background:linear-gradient(90deg,#2e251b,#3e3227,#2e251b);border-bottom:2px solid #4a3b2a;display:flex;align-items:center;justify-content:space-between;font-size:.9rem}
#ui-top-bar .ui-flex-row{display:flex;gap:1.2rem;align-items:center}
#ui-level-name{font-weight:700;color:var(--accent)}
#ui-objective{color:var(--muted);font-size:.85rem}

/* Side panels */
#ui-left-panel,#ui-right-panel{width:220px;flex-shrink:0;background:#221a12;border-right:2px solid #4a3b2a;display:flex;flex-direction:column;gap:.6rem;padding:.6rem;overflow-y:auto}
#ui-right-panel{border-right:none;border-left:2px solid #4a3b2a}
.ui-panel{background:linear-gradient(180deg,#2e251b,#251e16);border:1px solid #4a3b2a;border-radius:.5rem;padding:.6rem;box-shadow:0 6px 0 #150f0a}
.panel-header{font-weight:700;color:var(--accent);border-bottom:1px solid #4a3b2a;margin:-.6rem -.6rem .5rem -.6rem;padding:.4rem .6rem;background:rgba(255,195,77,.06);border-radius:.5rem .5rem 0 0}
#char-portrait{width:72px;height:72px;border-radius:50%;margin:0 auto .4rem;background:conic-gradient(#90caf9,#42a5f5,#1565c0,#42a5f5,#90caf9);border:3px solid #6d563d;box-shadow:0 0 0 2px #221a12}
#char-name{text-align:center;font-weight:700}
#char-lvl{text-align:center;color:var(--muted);font-size:.82rem;margin-bottom:.3rem}
.bar{height:10px;background:#3e3227;border:1px solid #4a3b2a;border-radius:5px;overflow:hidden;margin-bottom:.25rem}
.bar-fill{height:100%;border-radius:5px;transition:width .3s ease}
#char-hp-bar .bar-fill{background:linear-gradient(90deg,#e74c3c,#c0392b)}
#char-ap,#char-mp{font-size:.9rem}
#ui-actions{display:flex;flex-direction:column;gap:.4rem}
#ui-actions button{width:100%;text-align:left}

/* Game view */
#game-view{flex:1;display:flex;align-items:center;justify-content:center;position:relative;background:#18120e}
#iso-canvas{position:relative}
#map-canvas{display:block;border:2px solid #4a3b2a;border-radius:.25rem;box-shadow:0 0 24px rgba(0,0,0,.6)}
#map-tooltip{position:absolute;pointer-events:none;background:rgba(30,24,16,.95);border:1px solid #6d563d;padding:.35rem .6rem;border-radius:.4rem;font-size:.8rem;white-space:pre-line;box-shadow:0 6px 12px rgba(0,0,0,.5);z-index:10}
#map-tooltip.hidden{display:none}

/* Mini + journal */
#mini-map{height:120px;background:#120d08;border:1px solid #4a3b2a;border-radius:.3rem;position:relative;overflow:hidden}
#journal-log{height:140px;overflow-y:auto;font-size:.82rem;color:var(--muted);line-height:1.35}
#journal-log .entry{margin:.15rem 0}
#journal-log .entry.danger{color:#f5b7b1}
#journal-log .entry.success{color:#a9dfbf}
#journal-log .entry.info{color:#aed6f1}

/* Combat screen */
#screen-combat{display:none;flex-direction:column;background:#18120e}
#combat-hud{display:flex;align-items:center;justify-content:space-between;padding:.4rem .8rem;background:#221a12;border-bottom:2px solid #4a3b2a;min-height:52px}
#combat-char-info,#combat-enemy-info{display:flex;gap:.6rem;align-items:center;font-size:.85rem}
#combat-timeline{display:flex;gap:.3rem;align-items:center;justify-content:center;flex:1}
.timeline-chip{padding:.2rem .5rem;border-radius:.3rem;font-size:.78rem;border:1px solid #4a3b2a;background:#2e251b}
.timeline-chip.active{background:rgba(255,195,77,.18);border-color:var(--accent)}
#combat-view{flex:1;display:flex;align-items:center;justify-content:center;position:relative}
#combat-canvas{display:block;border:2px solid #4a3b2a;border-radius:.25rem}
#combat-action-bar{display:flex;gap:.6rem;align-items:center;justify-content:center;padding:.5rem;background:#221a12;border-top:2px solid #4a3b2a}
#combat-spells{display:flex;gap:.4rem}
.spell-btn{width:48px;height:48px;border:2px solid #4a3b2a;border-radius:.4rem;background:#2e251b;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.spell-btn:hover{border-color:var(--accent)}
.spell-btn.disabled{opacity:.4;cursor:not-allowed}
.spell-cost{position:absolute;bottom:0;right:0;background:#e74c3c;color:#fff;font-size:.65rem;padding:.05rem .2rem;border-radius:.2rem}
#combat-log{position:absolute;bottom:8px;left:8px;right:8px;height:90px;overflow-y:auto;background:rgba(20,14,8,.9);border:1px solid #4a3b2a;border-radius:.3rem;padding:.4rem;font-size:.82rem;color:var(--muted)}

/* Reward screen */
#screen-reward{display:none}
.panel-centered{background:#2e251b;border:2px solid #4a3b2a;border-radius:.6rem;padding:1.2rem 1.6rem;max-width:720px;width:90%;text-align:center;box-shadow:0 12px 24px rgba(0,0,0,.5)}
.panel-centered h2{margin-top:0;color:var(--accent)}
#reward-loot{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin:.8rem 0}
.loot-card{width:120px;border:1px solid #4a3b2a;border-radius:.4rem;background:#221a12;padding:.5rem;cursor:pointer}
.loot-card .rarity-tag{font-size:.7rem;padding:.15rem .3rem;border-radius:.2rem;display:inline-block;margin-bottom:.3rem}
.loot-card .loot-name{font-weight:700;font-size:.82rem}
.loot-card .loot-stats{font-size:.75rem;color:var(--muted)}
#reward-choice{display:flex;gap:.8rem;justify-content:center;margin:1rem 0}
.choice-card{width:180px;border:2px solid #4a3b2a;border-radius:.5rem;background:#251e16;padding:.6rem;cursor:pointer;transition:border-color .2s}
.choice-card:hover{border-color:var(--accent)}
.choice-card .choice-label{font-weight:700;color:var(--accent)}
.choice-card .choice-advice{font-size:.8rem;color:var(--muted);margin-top:.3rem}

/* Overlay panels */
.overlay{position:absolute;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:50}
.overlay.hidden{display:none}
.overlay-content{background:linear-gradient(180deg,#2e251b,#1e1812);border:2px solid #4a3b2a;border-radius:.6rem;width:900px;max-width:92vw;height:76vh;display:flex;flex-direction:column;box-shadow:0 18px 40px rgba(0,0,0,.6)}
.overlay-header{padding:.6rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #4a3b2a;position:relative}
.overlay-body{flex:1;overflow-y:auto;padding:1rem}

/* Inventory overlay specific */
#overlay-body{display:flex;gap:1rem}
#equipment-slots{width:280px;flex-shrink:0}
.slot-row{display:flex;align-items:center;gap:.6rem;margin:.35rem 0}
.slot-label{width:90px;font-size:.85rem;color:var(--muted)}
.slot-box{width:44px;height:44px;border:2px dashed #4a3b2a;border-radius:.3rem;background:rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;font-size:.9rem;position:relative;cursor:pointer}
.slot-box.filled{border-style:solid;border-color:#6d563d;background:#251e16}
.slot-box .item-level{position:absolute;top:-6px;right:-6px;background:#e74c3c;color:#fff;font-size:.65rem;padding:.05rem .2rem;border-radius:.2rem}
#inventory-list{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}
.inv-item{padding:.4rem;border:1px solid #4a3b2a;border-radius:.4rem;background:#251e16;cursor:pointer;position:relative}
.inv-item .item-name{font-weight:700;font-size:.85rem}
.inv-item .item-bonuses{font-size:.75rem;color:var(--muted)}
.inv-item .item-actions{margin-top:.3rem;display:flex;gap:.25rem}
.inv-item .item-actions button{font-size:.72rem;padding:.2rem .4rem}

/* Spells overlay */
#spells-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.6rem}
.spell-card{padding:.6rem;border:1px solid #4a3b2a;border-radius:.4rem;background:#251e16}
.spell-card-header{display:flex;align-items:center;justify-content:space-between}
.spell-card-name{font-weight:700}
.spell-card-level{font-size:.8rem;color:var(--muted)}
.spell-card-meta{font-size:.82rem;color:#b0a188;margin:.25rem 0}

/* Stats overlay */
#stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}
.stat-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;border-bottom:1px solid rgba(255,255,255,.06)}
.stat-label{color:var(--muted);font-size:.85rem}
.stat-value{font-weight:700;font-size:.9rem}
.stat-value.positive{color:#58d68d}

/* Pause / Game Over */
#screen-pause,#screen-gameover{background:rgba(0,0,0,.7)}
.overlay-panel{background:#2e251b;border:2px solid #4a3b2a;border-radius:.6rem;padding:1.5rem 2rem;text-align:center;box-shadow:0 12px 24px rgba(0,0,0,.5)}
.overlay-panel h2{margin-top:0;color:var(--accent)}
#gameover-stats{text-align:left;margin:1rem 0;font-size:.9rem;color:var(--muted);max-height:320px;overflow-y:auto}
