@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #0E0E10;
  --card:      #161618;
  --card2:     #1C1C1F;
  --border:    #2A2A2F;
  --accent:    #C4714A;
  --accent2:   #E8946A;
  --green:     #4ADE80;
  --red:       #FF6B6B;
  --text:      #E5E5E5;
  --muted:     #6B6B7A;
  --term-bg:   #080810;
}

body {
  font-family: 'IBM Plex Mono', monospace;
  background: var(--bg);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

#app {
  max-width: 600px;
  width: 100%;
}

/* ── PIXEL MASCOT SVG ── */
#claude-avatar svg,
#home-mascot-wrap svg,
.lc-mascot svg,
.end-mascot svg,
#intro-mascot svg { image-rendering: pixelated; }

/* ── INTRO SCREEN ── */
#intro-screen {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding: 8px 0;
}

#intro-mascot {
  animation: float 2s ease-in-out infinite alternate;
}
#intro-mascot svg {
  width: 96px;
  height: 120px;
}

#intro-terminal {
  width: 100%;
  background: var(--term-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 0 40px rgba(196,113,74,.15);
}

#intro-text {
  padding: 20px 24px 24px;
  font-size: 13px;
  color: var(--accent);
  line-height: 2;
  min-height: 180px;
  font-family: 'IBM Plex Mono', monospace;
  white-space: pre-wrap;
}

#intro-btn {
  width: 100%;
  padding: 16px;
  background: var(--accent);
  color: #0E0E10;
  border: none;
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  cursor: pointer;
  letter-spacing: .05em;
  transition: background .15s;
}
#intro-btn:hover { background: var(--accent2); }

/* ── TERMINAL BAR (fake window chrome) ── */
.term-bar {
  display: flex;
  gap: 6px;
  padding: 10px 14px;
  background: var(--card2);
  border-bottom: 1px solid var(--border);
}
.term-bar span {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--border);
}
.term-bar span:nth-child(1) { background: #FF5F57; }
.term-bar span:nth-child(2) { background: #FEBC2E; }
.term-bar span:nth-child(3) { background: #28C840; }

/* ── HOME SCREEN ── */
#home-screen {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 0 60px rgba(196,113,74,.08);
}

#home-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
#home-mascot-wrap svg { width: 56px; height: 70px; }

#home-screen h1 {
  font-family: 'Press Start 2P', monospace;
  font-size: 14px;
  color: var(--accent);
  line-height: 1.6;
  margin-bottom: 6px;
}
.home-sub { color: var(--muted); font-size: 12px; }

#level-list { display: flex; flex-direction: column; gap: 8px; }

.level-btn {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  transition: border-color .15s, background .15s;
  width: 100%;
  font-family: 'IBM Plex Mono', monospace;
}
.level-btn:hover { border-color: var(--accent); background: #1E1A18; }
.level-btn.locked { opacity: .4; cursor: not-allowed; }
.level-btn .lvl-num {
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  color: var(--accent);
  flex-shrink: 0;
  width: 40px;
}
.level-btn .lvl-info { flex: 1; }
.level-btn .lvl-name { font-size: 13px; font-weight: 600; color: var(--text); display: block; margin-bottom: 3px; }
.level-btn .lvl-count { font-size: 11px; color: var(--muted); }
.level-btn .lvl-status {
  font-size: 10px;
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 600;
  flex-shrink: 0;
  padding: 3px 6px;
  border-radius: 4px;
}
.level-btn .status-done { color: var(--green);  background: rgba(74,222,128,.1); border: 1px solid rgba(74,222,128,.2); }
.level-btn .status-play { color: var(--accent); background: rgba(196,113,74,.1); border: 1px solid rgba(196,113,74,.2); }
.level-btn .status-lock { color: var(--muted);  background: rgba(107,107,122,.08); border: 1px solid var(--border); }

/* ── GAME SCREEN ── */
#game-screen {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 0 60px rgba(196,113,74,.08);
}

#game-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
#back-btn {
  background: none; border: 1px solid var(--border); cursor: pointer;
  font-size: 11px; color: var(--muted); padding: 5px 10px;
  border-radius: 6px; font-family: 'IBM Plex Mono', monospace;
  transition: border-color .15s, color .15s;
}
#back-btn:hover { border-color: var(--accent); color: var(--accent); }
#level-badge {
  font-size: 11px; font-weight: 600; color: var(--accent);
  background: rgba(196,113,74,.12); padding: 5px 10px;
  border-radius: 20px; border: 1px solid rgba(196,113,74,.25);
  font-family: 'IBM Plex Mono', monospace;
}
#scenario-counter { font-size: 11px; color: var(--muted); margin-left: auto; }

/* ── PROGRESS ── */
#progress-bar-wrap {
  height: 4px; background: var(--border); border-radius: 99px;
  overflow: hidden; margin-bottom: 20px;
}
#progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  border-radius: 99px;
  transition: width .5s ease;
  width: 0%;
}

/* ── CLAUDE AVATAR + BUBBLE ── */
#claude-container {
  display: flex; gap: 14px; align-items: flex-start; margin-bottom: 16px;
}
#claude-avatar {
  flex-shrink: 0;
  transition: transform .2s;
}
#claude-avatar svg {
  width: 52px;
  height: 65px;
}
#claude-avatar.celebrating { animation: bounce .5s ease infinite alternate; }
#claude-avatar.thinking    { animation: wobble 1.2s ease infinite; }
#claude-avatar.scared      { animation: shake-avatar .4s ease infinite; }

#claude-bubble {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 14px; border-top-left-radius: 4px;
  padding: 14px 16px; font-size: 13px; color: var(--text);
  line-height: 1.8; flex: 1;
}
#claude-bubble code {
  background: rgba(196,113,74,.15);
  color: var(--accent2);
  padding: 2px 6px; border-radius: 4px;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 12px;
}

/* ── ANIMATIONS ── */
@keyframes float   { from { transform: translateY(0); } to { transform: translateY(-8px); } }
@keyframes bounce  { from { transform: translateY(0) rotate(-5deg); } to { transform: translateY(-10px) rotate(5deg); } }
@keyframes wobble  { 0%,100% { transform: rotate(0); } 25% { transform: rotate(-8deg); } 75% { transform: rotate(8deg); } }
@keyframes shake-avatar { 0%,100% { transform: translateX(0); } 25% { transform: translateX(-4px); } 75% { transform: translateX(4px); } }

/* ── TERMINAL ── */
#terminal {
  background: var(--term-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
  box-shadow: 0 0 20px rgba(0,0,0,.4);
}
#terminal-inner {
  padding: 14px 16px;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 13px;
  min-height: 80px;
}
#terminal-output {
  color: var(--red);
  margin-bottom: 10px;
  min-height: 18px;
  line-height: 1.6;
  white-space: pre-wrap;
  word-break: break-all;
  overflow-wrap: break-word;
}
#terminal-output.ok  { color: var(--green); }
#terminal-output.dim { color: var(--muted); }

#input-line { display: flex; align-items: center; gap: 8px; }
.prompt     { color: var(--green); font-weight: bold; }
#cmd-input  {
  background: transparent; border: none; outline: none;
  color: var(--text); font-family: inherit; font-size: 13px;
  flex: 1; caret-color: var(--accent);
}
#cmd-input::placeholder { color: #2E2E3A; }
#cmd-input:disabled     { opacity: .4; }

#submit-btn {
  display: none; /* hidden on desktop */
  background: var(--accent); color: #0E0E10;
  border: none; border-radius: 6px;
  padding: 6px 14px; font-size: 13px; font-weight: 600;
  font-family: 'IBM Plex Mono', monospace;
  cursor: pointer; flex-shrink: 0;
  transition: background .15s;
}
#submit-btn:hover { background: var(--accent2); }

/* Raccourcis */
#shortcut-prompt {
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--border);
  color: var(--muted); font-size: 12px;
}
#shortcut-key-display {
  background: var(--card2); color: var(--accent);
  padding: 4px 12px; border-radius: 6px;
  border: 1px solid var(--border); font-family: inherit;
  font-size: 13px;
}

/* Shake */
@keyframes shake {
  0%,100% { transform: translateX(0); }
  20%     { transform: translateX(-7px); }
  40%     { transform: translateX(7px); }
  60%     { transform: translateX(-4px); }
  80%     { transform: translateX(4px); }
}
.shake { animation: shake .35s ease; }

/* ── HINT ── */
#hint {
  font-size: 12px; color: var(--accent2);
  background: rgba(196,113,74,.08);
  border: 1px solid rgba(196,113,74,.2);
  border-radius: 8px; overflow: hidden;
  max-height: 0; transition: max-height .3s ease, padding .3s ease;
  font-family: 'IBM Plex Mono', monospace;
}
#hint.show { max-height: 100px; padding: 10px 14px; }

/* ── CONTINUE ── */
#continue-btn {
  width: 100%; margin-top: 12px; padding: 13px;
  background: var(--accent); color: #0E0E10; border: none;
  border-radius: 8px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: background .15s;
  font-family: 'IBM Plex Mono', monospace;
}
#continue-btn:hover { background: var(--accent2); }

/* ── NIVEAU TERMINÉ ── */
#level-complete {
  text-align: center; padding: 32px 20px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 16px;
}
.lc-mascot svg { width: 72px; height: 90px; margin-bottom: 20px; animation: bounce .6s ease infinite alternate; }
#level-complete h2 {
  font-family: 'Press Start 2P', monospace;
  font-size: 13px; color: var(--accent);
  margin-bottom: 12px; line-height: 1.6;
}
#level-complete p { color: var(--muted); font-size: 12px; margin-bottom: 24px; line-height: 1.8; }
#lc-next-btn {
  width: 100%; padding: 14px;
  background: var(--accent); color: #0E0E10;
  border: none; border-radius: 8px; font-size: 13px; font-weight: 600;
  cursor: pointer; margin-bottom: 10px;
  font-family: 'IBM Plex Mono', monospace;
  transition: background .15s;
}
#lc-next-btn:hover { background: var(--accent2); }
#lc-home-btn {
  width: 100%; padding: 12px;
  background: transparent; color: var(--muted);
  border: 1px solid var(--border); border-radius: 8px;
  font-size: 12px; cursor: pointer;
  font-family: 'IBM Plex Mono', monospace;
}

/* ── FIN ── */
#end-screen {
  text-align: center; padding: 32px 20px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 16px;
}
.end-mascot svg { width: 80px; height: 100px; margin-bottom: 20px; animation: float 2s ease-in-out infinite alternate; }
#end-screen h2 {
  font-family: 'Press Start 2P', monospace;
  font-size: 12px; color: var(--accent);
  margin-bottom: 12px; line-height: 1.8;
}
#end-screen p { color: var(--muted); font-size: 12px; margin-bottom: 28px; line-height: 1.8; }
.cta {
  display: block; background: var(--accent); color: #0E0E10;
  text-decoration: none; padding: 14px 32px; border-radius: 8px;
  font-size: 13px; font-weight: 600; margin-bottom: 14px;
  transition: background .15s; font-family: 'IBM Plex Mono', monospace;
}
.cta:hover { background: var(--accent2); }
#restart-btn {
  display: block; width: 100%; padding: 12px;
  background: transparent; color: var(--muted);
  border: 1px solid var(--border); border-radius: 8px;
  font-size: 12px; cursor: pointer; margin-top: 8px;
  font-family: 'IBM Plex Mono', monospace;
}

/* ── MOBILE ── */
@media (max-width: 520px) {
  body {
    align-items: flex-start;
    padding: 8px 8px 24px;
  }

  #app {
    max-width: 100%;
  }

  /* Intro */
  #intro-mascot svg { width: 72px; height: 90px; }
  #intro-text { font-size: 12px; padding: 14px 16px 18px; min-height: 140px; }
  #intro-btn { font-size: 10px; padding: 14px; }

  /* Home */
  #home-screen {
    padding: 16px;
    border-radius: 12px;
  }
  #home-mascot-wrap svg { width: 40px; height: 50px; }
  #home-screen h1 { font-size: 10px; }
  .home-sub { font-size: 11px; }
  #home-header { gap: 10px; margin-bottom: 16px; padding-bottom: 14px; }

  .level-btn { padding: 10px 12px; gap: 10px; }
  .level-btn .lvl-num { font-size: 9px; width: 32px; }
  .level-btn .lvl-name { font-size: 12px; }
  .level-btn .lvl-count { font-size: 10px; }
  .level-btn .lvl-status { font-size: 9px; }

  /* Game */
  #game-screen {
    padding: 12px;
    border-radius: 12px;
  }
  #game-header { gap: 6px; margin-bottom: 10px; flex-wrap: nowrap; }
  #back-btn { font-size: 10px; padding: 4px 8px; flex-shrink: 0; }
  #level-badge {
    font-size: 10px; padding: 4px 8px;
    max-width: 120px; overflow: hidden;
    text-overflow: ellipsis; white-space: nowrap;
  }
  #scenario-counter { font-size: 10px; white-space: nowrap; }

  #claude-avatar svg { width: 40px; height: 50px; }
  #claude-bubble { font-size: 12px; padding: 10px 12px; line-height: 1.7; }
  #claude-container { gap: 10px; margin-bottom: 12px; }

  #terminal-inner { padding: 10px 12px; font-size: 12px; }
  #terminal-output { font-size: 12px; }
  #cmd-input { font-size: 16px; } /* prevent iOS zoom */
  #submit-btn { display: block; }

  #shortcut-key-display { font-size: 12px; }
  #hint { font-size: 11px; }
  #hint.show { max-height: 120px; }

  #continue-btn { font-size: 12px; padding: 12px; }

  /* Level complete */
  #level-complete { padding: 24px 16px; border-radius: 12px; }
  .lc-mascot svg { width: 56px; height: 70px; }
  #level-complete h2 { font-size: 11px; }
  #lc-next-btn, #lc-home-btn { font-size: 12px; padding: 12px; }

  /* End */
  #end-screen { padding: 24px 16px; border-radius: 12px; }
  .end-mascot svg { width: 64px; height: 80px; }
  #end-screen h2 { font-size: 10px; }
}
