/* Olympus theme for "Les Ancêtres mythiques" */
:root{
  --bg:#0b0d11; --card:#0f1319; --surface:#141a23; --surface-strong:#1a2230; --border:#263041;
  --text:#e6ebf2; --text-strong:#f6f8fb; --muted:#98a7c0;
  --accent:#8dd6ff; --accent-2:#ffd166; --success:#63d297; --danger:#ff6b6b;
  --radius:14px; --shadow: 0 6px 22px rgba(0,0,0,.28); --focus: 0 0 0 2px rgba(141,214,255,.35);
}
[data-theme="light"]{
  --bg:#f6f7fb; --card:#ffffff; --surface:#f3f6fb; --surface-strong:#e9f0fb; --border:#d9e0ee;
  --text:#1a2332; --text-strong:#0f1520; --muted:#5f6c85;
  --accent:#3da9fc; --accent-2:#f4a261; --success:#2ab676; --danger:#e15555;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{margin:0; background: radial-gradient(1200px 800px at 80% -200px, rgba(61,169,252,.18), transparent 60%), var(--bg); color:var(--text); font: 15px/1.6 Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif}

.olympus-border{ position:relative; border:1px solid var(--border); background: var(--card); border-radius: var(--radius); box-shadow: var(--shadow); }

header{ padding: clamp(28px, 6vw, 56px) 20px clamp(12px, 3vw, 20px); text-align:center; background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 20%, transparent), transparent 70%); }
.title{ font-family: "Baloo 2", ui-rounded, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-weight:800; font-size: clamp(26px, 5vw, 46px); margin:0 0 8px; color: var(--accent); letter-spacing:.01em; text-shadow: 0 2px 12px rgba(0,0,0,.18); }
.subtitle{ color:var(--muted); margin:0 auto; max-width:none; font-size: clamp(14px, 2.2vw, 18px); line-height:1.6 }

main{ max-width:1600px; margin:22px auto; padding: 0 16px 80px; }
@media (max-width: 640px){ main{ margin: 14px auto; padding: 0 12px 64px; } }

.screen{display:none}
.screen.active{display:block}

.card{ padding:22px; border-radius: var(--radius); }
@media (max-width: 640px){ .card{ padding:16px; } }

/* Home */
.home-card{ width:100%; display:flex; flex-direction:column; gap:16px; align-items:stretch; }
.home-intro{ display:block; }
.home-title{ margin:0; font-size: clamp(22px, 4vw, 28px); font-weight:800; color: var(--accent-2); font-family: "Baloo 2", ui-rounded, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
.home-title .emoji{ font-size: 1.1em }
.home-tagline{ margin:.25rem 0 0; color:var(--muted); }
.home-summary{ margin-top: 6px; }
.home-summary p{ margin:.6rem 0; font-size: clamp(15px, 2.2vw, 17px); }

.toolbar{ position:sticky; top:0; z-index:10; display:flex; gap:6px; padding:8px; background: var(--card); border-bottom:1px solid var(--border); backdrop-filter: blur(8px); flex-wrap: wrap; align-items: center; margin-bottom: 1rem; }
[data-theme="light"] .toolbar{ background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.88)); }
[data-theme="dark"] .toolbar{ background: linear-gradient(180deg, rgba(11,13,17,.9), rgba(9,11,14,.88)); }
.spacer{ flex:1 }

.btn{ cursor:pointer; display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border:1px solid var(--border); border-radius:12px; background: var(--surface); 
      font-size:15px; font-weight:700; color:var(--text); text-decoration:none; }
.btn:hover{ background: var(--surface-strong); border-color: color-mix(in srgb, var(--accent) 45%, var(--border)); transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }
.btn:focus{ outline:none; box-shadow: var(--focus); }
.btn.primary{ background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 90%, #fff 0%), color-mix(in srgb, var(--accent) 56%, #000 0%)); color:#04121c; border-color: color-mix(in srgb, var(--accent) 65%, var(--border)); }
.btn.success{ border-color: color-mix(in srgb, var(--success) 65%, var(--border)); color:var(--text-strong); background: color-mix(in srgb, var(--success) 18%, transparent); }
.btn.danger{ border-color: color-mix(in srgb, var(--danger) 65%, var(--border)); color:var(--text-strong); background: color-mix(in srgb, var(--danger) 18%, transparent); }
.btn.small{ padding:6px 10px; font-size:13px; border-radius:8px }
.btn:disabled{ opacity:.6; cursor:not-allowed; filter: grayscale(25%) }
@media (max-width: 640px){ .toolbar .btn{ padding:8px 10px; font-size:14px; border-radius:8px; min-width:44px; justify-content:center } .toolbar .btn-text{ display:none } }

/* Layout */
.grid.layout{ display:grid; grid-template-columns: 1.3fr .7fr; gap:16px }
@media (max-width: 1024px){ .grid.layout{ grid-template-columns: 1fr; } }

/* Story */
.story h2{ margin:.2rem 0 1rem; color:var(--accent); font-weight:800; font-family: "Baloo 2", ui-rounded, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; letter-spacing:.01em }
.story p{ line-height:1.85; font-size: clamp(16px, 2.2vw, 18px); }
.story .images{ display:grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap:12px; margin:14px 0 }
.story img{ width:100%; max-height:30vh; object-fit:contain; border-radius:10px; border:1px solid var(--border); background:#00000010 }

.meta{ display:flex; flex-wrap:wrap; gap:8px; color:var(--muted); font-size:13px }
.tag{ padding:3px 8px; border-radius:1rem; border:1px solid var(--border); background: var(--surface); font-weight:700 }

/* Options */
.options{ display:grid; gap:10px; margin-top:12px }
.option{ width:100%; text-align:left }
.option-row{ display:grid; gap:6px }
.option-msg{ font-size:12px; color:var(--danger); display:flex; align-items:center; gap:6px; font-weight:700 }

/* Panels */
.panel{ padding:16px; border-radius: var(--radius); background: var(--card) }
.panel h3{ margin:0 0 8px; font-size:16px; color:var(--accent-2); font-weight:800; font-family: "Baloo 2", ui-rounded, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }

/* Assets grid (chips) */
.status-assets{ display:grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap:10px; }
.asset-chip{ display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:12px; border:1px solid var(--border); background: var(--surface); cursor:pointer; transition: transform .16s ease, box-shadow .16s ease }
.asset-chip:hover{ transform: translateY(-2px); box-shadow: 0 8px 18px rgba(0,0,0,.2) }
.asset-chip .thumb{ width:32px; height:32px; object-fit:contain; border-radius:6px; border:1px solid var(--border); background:#00000010 }
.asset-chip .emoji{ width:32px; height:32px; display:flex; align-items:center; justify-content:center; font-size:20px }
.asset-chip .name{ font-weight:700 }
.asset-chip .cat{ font-size:11px; color:var(--muted) }
.status-assets .asset-chip.off{ opacity:.55; filter: grayscale(75%); }
.status-assets .asset-chip.off .name{ color: var(--muted); }
.status-assets .asset-chip.off .emoji{ opacity:.7 }

/* Epreuves */
.epreuve {padding:1rem;}
.actions {margin-top: 1rem;}
.actions .btn.success{margin-right:1rem;}

/* Journal */
.journal{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size:12.5px; line-height:1.5; color:var(--muted); display:grid; gap:4px; white-space:pre-wrap }

/* Toasts */
#toast-host{ position: fixed; right: 14px; bottom: 16px; display:flex; flex-direction:column; gap:10px; z-index: 50; pointer-events: none; }
.toast{ pointer-events: auto; display:flex; gap:10px; align-items:flex-start; padding:10px 12px; border-radius:12px; border:1px solid var(--border); background: var(--surface); color:var(--text); transform: translateY(8px); opacity:0; transition: .2s ease }
.toast.show{ transform: translateY(0); opacity:1 }
.toast .icon{ width:22px; height:22px; display:flex; align-items:center; justify-content:center; color:var(--accent) }
.toast.success{ border-color: color-mix(in srgb, var(--success) 50%, var(--border)); }
.toast.danger{ border-color: color-mix(in srgb, var(--danger) 50%, var(--border)); }
.toast .t-title{ font-weight:800; }
.toast .t-msg{ font-size:12.5px; color:var(--muted) }

/* TTS */
.tts-panel{ position:fixed; right:10px; top:62px; width: min(360px, 92vw); padding:12px; display:none; }
.tts-panel.active{ display:block }
.tts-row{ display:grid; grid-template-columns: 1fr 1fr; align-items:center; gap:8px; margin:8px 0 }
.tts-select,.tts-range{ width:100% }
.tts-controls{ display:flex; gap:8px; flex-wrap:wrap }

/* Asset modal */
.asset-modal-backdrop{ position: fixed; inset:0; background: rgba(0,0,0,.45); display:none; align-items:center; justify-content:center; z-index:40; }
.asset-modal-backdrop.active{ display:flex }
.asset-modal{ width:min(900px, 92vw); padding:12px; }
.asset-modal header{ display:flex; align-items:center; justify-content:space-between }
.asset-modal .body{ display:grid; grid-template-columns: 240px 1fr; gap:12px }
.asset-modal .image-wrap{ display:flex; align-items:center; justify-content:center; background: var(--surface); border-radius:12px; aspect-ratio: 1 / 1; }
.asset-modal .image-wrap .emoji{ font-size:64px }
.asset-modal img.asset-image{ max-width:100%; max-height:100%; object-fit:contain; border-radius:12px; border:1px solid var(--border); background:#00000010 }

.footer{ text-align:center; color:var(--muted); margin-top:18px }

/* Progress bar */
.top-progress{ position: fixed; top:0; left:0; right:0; height:3px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; z-index: 60; }
.top-progress.active{ transform: scaleX(1); }

/* Victory styles (inspired by pigs) */
.victory-box{ padding:14px; margin-top:12px; border:1px dashed var(--border); background: color-mix(in srgb, var(--accent) 6%, var(--card)); border-radius: 12px; }
.victory-box.success{ border-color: color-mix(in srgb, var(--success) 50%, var(--border)); background: color-mix(in srgb, var(--success) 12%, transparent); }
.victory-box.warn{ border-color: color-mix(in srgb, var(--danger) 40%, var(--border)); background: color-mix(in srgb, var(--danger) 10%, transparent); }
.victory-box .v-head{ display:flex; align-items:center; gap:10px; font-weight:800; color: var(--text-strong); }
.victory-box .v-title{ font-family: "Baloo 2", ui-rounded, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; letter-spacing:.01em }
.victory-box .v-msg{ margin-top:6px; color: var(--text); }
