/* filename: dungeon/styles.css */

:root{
  --bg0: #0a0612;
  --bg1: #140821;
  --bg2: #1d0a2e;

  --ink: #f4ecdb;
  --ink-mute: rgba(244,236,219,0.66);
  --ink-dim: rgba(244,236,219,0.40);

  --paper: #f3e7c9;
  --paper-ink: #1c1610;

  --accent: #ff6b3d;        /* ember */
  --accent2: #f0c75e;       /* gold */
  --accent3: #b061ff;       /* arcane purple */
  --accent4: #4ad0c2;       /* mint */
  --danger:  #ff4d6a;
  --success: #6bd97c;

  --line: rgba(255,255,255,0.08);
  --line-strong: rgba(255,255,255,0.18);

  --serif: "IM Fell English", Georgia, serif;
  --caps:  "Cinzel", Georgia, serif;
  --mono:  "JetBrains Mono", ui-monospace, monospace;

  --r-lg: 22px;
  --r-md: 14px;
  --r-sm: 10px;
}

*{ box-sizing: border-box; }
html, body{ height: 100%; margin: 0; }

body{
  background:
    radial-gradient(1200px 900px at 12% -10%, rgba(176,97,255,0.22), transparent 60%),
    radial-gradient(1000px 800px at 110% 10%, rgba(255,107,61,0.18), transparent 60%),
    radial-gradient(1400px 1000px at 50% 120%, rgba(74,208,194,0.14), transparent 65%),
    linear-gradient(180deg, var(--bg0), var(--bg1) 40%, var(--bg2));
  color: var(--ink);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  overflow: hidden;
}

button{ font-family: inherit; }

/* =========================================================
   CHARACTER SHEET
   ========================================================= */

.charsheet{
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 24px;
  overflow: auto;
}

.cs-bg{
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(600px 400px at 20% 30%, rgba(176,97,255,0.25), transparent 60%),
    radial-gradient(700px 500px at 85% 70%, rgba(255,107,61,0.22), transparent 60%);
  filter: blur(6px);
}

.cs-shell{
  position: relative;
  width: min(1180px, 100%);
  border-radius: var(--r-lg);
  padding: 28px;
  background:
    linear-gradient(180deg, rgba(30,18,48,0.85), rgba(20,12,33,0.92));
  border: 1px solid var(--line-strong);
  box-shadow:
    0 30px 100px rgba(0,0,0,0.55),
    inset 0 0 0 1px rgba(255,255,255,0.04),
    0 0 80px rgba(176,97,255,0.10);
  backdrop-filter: blur(14px);
}

.cs-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
}

.cs-brand{
  display:flex; gap: 14px; align-items:center;
}
.cs-sigil{
  width: 28px; height: 28px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, #fff, var(--accent2) 40%, var(--accent) 80%);
  box-shadow:
    0 0 0 2px rgba(255,255,255,0.06),
    0 0 30px var(--accent),
    0 0 60px rgba(255,107,61,0.4);
}
.cs-brandText{
  font-family: var(--caps);
  font-weight: 900;
  font-size: 28px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: linear-gradient(180deg, #fff, var(--accent2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.cs-tag{
  font-family: var(--serif);
  font-style: italic;
  font-size: 16px;
  color: var(--ink-mute);
}

.cs-grid{
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 18px;
}

.cs-panel{
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 18px;
  position: relative;
}

.cs-panel h2{
  font-family: var(--caps);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0 0 14px;
  color: var(--accent2);
}
.cs-panel h2.cs-mt{ margin-top: 22px; }

.cs-hint{
  font-family: var(--serif);
  font-size: 14px;
  color: var(--ink-mute);
  margin: -6px 0 12px;
}
.cs-hint span{
  color: var(--accent2);
  font-weight: 700;
  font-family: var(--mono);
}

.cs-field{
  display:flex; flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}
.cs-field span{
  font-family: var(--caps);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.cs-field input,
.cs-field textarea,
.cs-row input{
  width: 100%;
  padding: 11px 14px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,0.30);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 15px;
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease, background 120ms ease;
}
.cs-field textarea{ resize: vertical; line-height: 1.4; }
.cs-field input:focus,
.cs-field textarea:focus,
.cs-row input:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255,107,61,0.20);
  background: rgba(0,0,0,0.42);
}

.cs-row{ display: grid; gap: 10px; margin-bottom: 12px; }
.cs-row.two{ grid-template-columns: 1fr 1fr; }
.cs-row.three{ grid-template-columns: 1fr 1fr 1fr; }

/* stats */
.cs-statList{ display:flex; flex-direction: column; gap: 12px; }
.stat-row{
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 14px;
  row-gap: 8px;
  align-items: center;
  padding: 12px;
  border-radius: var(--r-sm);
  background: rgba(0,0,0,0.22);
  border: 1px solid var(--line);
}
.stat-meta .stat-name{
  font-family: var(--caps);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.stat-meta .stat-blurb{
  font-family: var(--serif);
  font-size: 13px;
  color: var(--ink-mute);
  margin-top: 2px;
}
.stat-ctrl{
  display:flex; align-items:center; gap: 8px;
}
.step{
  width: 30px; height: 30px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,0.05);
  color: var(--ink);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: all 120ms ease;
}
.step:hover{
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-1px);
}
.stat-value{
  width: 30px;
  text-align: center;
  font-family: var(--mono);
  font-weight: 600;
  font-size: 18px;
  color: var(--accent2);
}
.stat-pips{
  grid-column: 1 / -1;
  display:flex; gap: 6px;
}
.pip{
  flex: 1;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  transition: background 200ms ease, box-shadow 200ms ease;
}
.pip.on{
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow: 0 0 12px rgba(255,107,61,0.5);
}

/* tone chips */
.cs-chips{ display:flex; flex-wrap: wrap; gap: 8px; }
.cs-chips button{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,0.04);
  color: var(--ink);
  font-family: var(--caps);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 120ms ease;
}
.cs-chips button:hover{
  border-color: var(--accent3);
  color: #fff;
}
.cs-chips button.on{
  background: linear-gradient(135deg, var(--accent3), var(--accent));
  border-color: transparent;
  color: #fff;
  box-shadow: 0 8px 26px rgba(176,97,255,0.35);
}

/* footer */
.cs-foot{
  display:flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.cs-btn{
  padding: 12px 22px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,0.04);
  color: var(--ink);
  font-family: var(--caps);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 140ms ease;
}
.cs-btn:hover{ background: rgba(255,255,255,0.08); transform: translateY(-1px); }
.cs-btn.primary{
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-color: transparent;
  color: #1a0e05;
  box-shadow: 0 12px 30px rgba(255,107,61,0.35);
}
.cs-btn.primary:hover{
  filter: brightness(1.08);
  box-shadow: 0 16px 40px rgba(255,107,61,0.45);
}

/* =========================================================
   APP (main game)
   ========================================================= */

.app{
  height: 100vh;
  display: flex;
  flex-direction: column;
  position: relative;
}

.app-head{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(20,12,33,0.92), rgba(20,12,33,0.65));
  backdrop-filter: blur(10px);
  z-index: 5;
}
.app-brand{
  display:flex; align-items:center; gap: 10px;
}
.app-sigil{
  width: 18px; height: 18px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #fff, var(--accent2) 40%, var(--accent));
  box-shadow: 0 0 22px var(--accent);
}
.app-brandText{
  font-family: var(--caps);
  font-weight: 900;
  font-size: 18px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: linear-gradient(180deg, #fff, var(--accent2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.app-meta{
  display:flex; gap: 8px; flex-wrap: wrap;
  justify-content: center;
}
.app-actions{ display:flex; gap: 8px; }

.pill{
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,0.04);
  color: var(--ink-mute);
  font-family: var(--caps);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.pill.status{
  color: var(--accent4);
  border-color: rgba(74,208,194,0.4);
  background: rgba(74,208,194,0.08);
}

.btn{
  padding: 9px 14px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,0.04);
  color: var(--ink);
  font-family: var(--caps);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 120ms ease;
}
.btn:hover{ background: rgba(255,255,255,0.10); transform: translateY(-1px); }
.btn.primary{
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-color: transparent;
  color: #1a0e05;
  font-weight: 700;
}
.btn.primary:hover{ filter: brightness(1.08); }
.btn.ghost{ background: transparent; }

/* main split */
.app-main{
  flex: 1;
  display: block;
  position: relative;
  min-height: 0;
}

/* hamburger */
.hamburger{
  width: 38px; height: 38px;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,0.04);
  cursor: pointer;
  margin-right: 4px;
  transition: all 120ms ease;
}
.hamburger:hover{ background: rgba(255,255,255,0.10); }
.hamburger span{
  display:block;
  width: 18px; height: 2px;
  border-radius: 2px;
  background: var(--ink);
  transition: transform 220ms ease, opacity 180ms ease;
}
.hamburger.on span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.hamburger.on span:nth-child(2){ opacity: 0; }
.hamburger.on span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* drawer scrim */
.drawer-scrim{
  position: absolute;
  inset: 0;
  background: rgba(5,2,12,0.55);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
  z-index: 8;
}
.drawer-scrim.show{ opacity: 1; pointer-events: auto; }

/* sidebar (drawer) */
.sidebar{
  position: absolute;
  top: 0; bottom: 0; left: 0;
  width: min(360px, 86vw);
  padding: 18px;
  overflow-y: auto;
  display:flex;
  flex-direction: column;
  gap: 14px;
  background:
    linear-gradient(180deg, rgba(20,12,33,0.96), rgba(15,8,26,0.98));
  border-right: 1px solid var(--line-strong);
  box-shadow: 18px 0 60px rgba(0,0,0,0.55);
  transform: translateX(-100%);
  transition: transform 280ms cubic-bezier(.2,.7,.2,1);
  z-index: 9;
}
.sidebar.open{ transform: translateX(0); }
.side-card{
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 14px;
}
.side-card h3{
  font-family: var(--caps);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent2);
  margin: 0 0 10px;
}
.char-summary .cs-name{
  font-family: var(--caps);
  font-weight: 900;
  font-size: 18px;
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}
.char-summary .cs-line{
  font-family: var(--serif);
  font-size: 14px;
  color: var(--ink-mute);
  margin-bottom: 10px;
}
.char-summary .cs-block{
  font-family: var(--serif);
  font-size: 13px;
  line-height: 1.4;
  margin-top: 8px;
  color: var(--ink-mute);
}
.char-summary .lbl{
  display: inline-block;
  font-family: var(--caps);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-right: 6px;
}

.stat-bars{ display:flex; flex-direction: column; gap: 8px; }
.bar-row{
  display: grid;
  grid-template-columns: 70px 1fr 24px;
  align-items: center;
  gap: 10px;
}
.bar-label{
  font-family: var(--caps);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.bar-track{
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
}
.bar-fill{
  height: 100%;
  background: linear-gradient(90deg, var(--accent3), var(--accent), var(--accent2));
  box-shadow: 0 0 14px rgba(255,107,61,0.5);
}
.bar-num{
  font-family: var(--mono);
  font-weight: 600;
  font-size: 13px;
  color: var(--accent2);
  text-align: right;
}

.inv-list{
  list-style: none;
  margin: 0; padding: 0;
  display:flex; flex-direction: column; gap: 6px;
}
.inv-list li{
  font-family: var(--serif);
  font-size: 14px;
  padding: 8px 10px;
  border-radius: var(--r-sm);
  background: rgba(0,0,0,0.22);
  border: 1px solid var(--line);
  color: var(--ink);
}
.inv-list li::before{
  content: "◆";
  margin-right: 8px;
  color: var(--accent2);
}

/* conversation */
.conversation{
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.log{
  flex: 1;
  overflow-y: auto;
  padding: 28px 36px;
  scroll-behavior: smooth;
}

.msg{
  max-width: 820px;
  margin: 0 auto 22px;
  animation: msg-in 320ms ease both;
}
@keyframes msg-in{
  from{ opacity: 0; transform: translateY(8px); }
  to  { opacity: 1; transform: none; }
}
.msg-who{
  font-family: var(--caps);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 6px;
  color: var(--ink-dim);
}
.msg-text{
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.55;
  white-space: pre-wrap;
  padding: 18px 22px;
  border-radius: var(--r-md);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.03);
  letter-spacing: 0.005em;
}
.msg.dm .msg-text{
  /* extra breathing room between paragraphs in DM blocks */
  line-height: 1.6;
}

.msg.dm .msg-who{ color: var(--accent2); }
.msg.dm .msg-text{
  background: linear-gradient(180deg, rgba(255,107,61,0.06), rgba(176,97,255,0.04));
  border-color: rgba(255,107,61,0.20);
}
.msg.you .msg-who{ color: var(--accent4); }
.msg.you .msg-text{
  background: rgba(74,208,194,0.06);
  border-color: rgba(74,208,194,0.22);
}
.msg.system .msg-who{ color: var(--ink-dim); }
.msg.system .msg-text{
  font-style: italic;
  color: var(--ink-mute);
  font-size: 14px;
  background: transparent;
  border-style: dashed;
  text-align: center;
}
.msg.dice .msg-who{ color: var(--accent3); }
.msg.dice .msg-text{
  font-family: var(--mono);
  font-size: 14px;
  background: rgba(176,97,255,0.08);
  border-color: rgba(176,97,255,0.30);
}
.msg.error .msg-who{ color: var(--danger); }
.msg.error .msg-text{
  font-family: var(--mono);
  font-size: 13px;
  background: rgba(255,77,106,0.08);
  border-color: rgba(255,77,106,0.30);
}

/* dice tray (docked above composer) */
.dice-tray{
  flex: 0 0 auto;
  display: none;
  align-items: center;
  gap: 14px;
  margin: 0 36px;
  padding: 12px 16px;
  border-radius: var(--r-md);
  background:
    linear-gradient(135deg, rgba(176,97,255,0.18), rgba(255,107,61,0.16));
  border: 1px solid rgba(176,97,255,0.4);
  box-shadow:
    0 -8px 30px rgba(0,0,0,0.35),
    0 0 40px rgba(176,97,255,0.14);
  animation: msg-in 240ms ease both;
}
.dice-tray.show{ display: flex; margin-bottom: 6px; }
.dice-text{ flex: 1; min-width: 0; }
.dice-context{
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
}
.tiny{
  margin-top: 2px;
  font-family: var(--caps);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.dice-result{
  font-family: var(--mono);
  font-weight: 600;
  font-size: 18px;
  padding: 10px 16px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,0.4);
  min-width: 60px;
  text-align: center;
}
.dice-result.success     { background: rgba(107,217,124,0.18); border-color: rgba(107,217,124,0.5); color: var(--success); }
.dice-result.failure     { background: rgba(255,107,61,0.18);  border-color: rgba(255,107,61,0.5);  color: var(--accent); }
.dice-result.crit-success{ background: rgba(240,199,94,0.22);  border-color: rgba(240,199,94,0.6);  color: var(--accent2); box-shadow: 0 0 20px rgba(240,199,94,0.4); }
.dice-result.crit-failure{ background: rgba(255,77,106,0.22);  border-color: rgba(255,77,106,0.6);  color: var(--danger);  box-shadow: 0 0 20px rgba(255,77,106,0.4); }

/* composer */
.composer{
  flex: 0 0 auto;
  display:flex;
  gap: 10px;
  padding: 18px 36px 22px;
  border-top: 1px solid var(--line);
  background: linear-gradient(0deg, rgba(20,12,33,0.95), rgba(20,12,33,0.75));
  backdrop-filter: blur(10px);
}
#typed{
  flex: 1;
  padding: 14px 18px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-strong);
  background: rgba(0,0,0,0.45);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 17px;
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
#typed::placeholder{ color: var(--ink-dim); font-style: italic; }
#typed:focus{
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255,107,61,0.20);
}
.composer .btn.primary{ padding: 12px 22px; font-size: 13px; }

/* scrollbars */
.log::-webkit-scrollbar,
.sidebar::-webkit-scrollbar,
.charsheet::-webkit-scrollbar{ width: 10px; }
.log::-webkit-scrollbar-track,
.sidebar::-webkit-scrollbar-track,
.charsheet::-webkit-scrollbar-track{ background: transparent; }
.log::-webkit-scrollbar-thumb,
.sidebar::-webkit-scrollbar-thumb,
.charsheet::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,0.10);
  border-radius: 999px;
}
.log::-webkit-scrollbar-thumb:hover{ background: rgba(255,255,255,0.18); }

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width: 1000px){
  .cs-grid{ grid-template-columns: 1fr 1fr; }
  .cs-identity{ grid-column: 1 / -1; }

  .dice-tray{ margin: 0 16px; }
  .log{ padding: 20px 18px; }
  .composer{ padding: 14px 16px 18px; }
}

@media (max-width: 640px){
  body{ overflow: auto; }
  .app{ height: auto; min-height: 100vh; }

  .cs-shell{ padding: 18px; }
  .cs-grid{ grid-template-columns: 1fr; }
  .cs-row.two, .cs-row.three{ grid-template-columns: 1fr; }
  .cs-brandText{ font-size: 22px; }

  .app-head{
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .app-actions, .app-meta{ justify-content: flex-start; }

  .msg-text{ font-size: 17px; }
}
