:root {
  --bg: #0b0d12;
  --bg2: #12151d;
  --card: #171b25;
  --card2: #1d222e;
  --line: #262c3a;
  --txt: #e7ebf3;
  --muted: #8a93a6;
  --accent: #7c6cff;
  --accent2: #9a8dff;
  --plan: #4aa3ff;
  --default: #36c98d;
  --accept: #f0b429;
  --bypass: #ff5d5d;
  --write: #f0b429;
  --exec: #ff7849;
  --network: #4aa3ff;
  --radius: 14px;
  --safe-b: env(safe-area-inset-bottom, 0px);
  --safe-t: env(safe-area-inset-top, 0px);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { height: 100%; margin: 0; }
body {
  background: var(--bg);
  color: var(--txt);
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  overflow: hidden;
}
.mono { font-family: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, monospace; font-size: 13px; }
.muted { color: var(--muted); }
.small { font-size: 12px; }
.hidden { display: none !important; }
.grow { flex: 1; }

.screen { position: fixed; inset: 0; display: flex; flex-direction: column; }
.center { align-items: center; justify-content: center; gap: 18px; padding: 24px; }

/* login */
.brand { text-align: center; }
.logo {
  width: 64px; height: 64px; margin: 0 auto 12px; border-radius: 18px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  display: grid; place-items: center; font-weight: 800; font-size: 26px; color: #fff;
  box-shadow: 0 8px 30px rgba(124,108,255,.4);
}
.brand h1 { margin: 0 0 4px; font-size: 24px; letter-spacing: -.5px; }

/* banner */
.banner {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: calc(6px + var(--safe-t)) 10px 6px; text-align: center; font-size: 13px;
  background: #3a2330; color: #ffb4b4;
}

/* header */
#hdr { background: var(--bg2); border-bottom: 1px solid var(--line); padding-top: var(--safe-t); }
.hdr-top { display: flex; align-items: center; gap: 10px; padding: 10px 12px; }
.hdr-title { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.hdr-title #hdr-ws { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.icon-btn {
  background: var(--card); border: 1px solid var(--line); color: var(--txt);
  width: 38px; height: 38px; border-radius: 10px; font-size: 16px; flex: none;
}
.chip {
  padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 600;
  background: var(--card2); border: 1px solid var(--line);
}
.chip.thinking, .chip.starting { color: var(--accent2); }
.chip.streaming { color: var(--default); }
.chip.awaiting-approval { color: var(--exec); background: #2a1d18; }
.chip.idle { color: var(--muted); }
.chip.error { color: var(--bypass); }

/* mode bar */
.modebar { display: flex; gap: 6px; padding: 0 12px 10px; }
.modebar button {
  flex: 1; padding: 7px 4px; border-radius: 9px; font-size: 12px; font-weight: 600;
  background: var(--card); border: 1px solid var(--line); color: var(--muted);
}
.modebar button.on[data-mode=plan]   { color: #fff; background: var(--plan); border-color: var(--plan); }
.modebar button.on[data-mode=default]{ color: #04241a; background: var(--default); border-color: var(--default); }
.modebar button.on[data-mode=acceptEdits]{ color: #2a1f00; background: var(--accept); border-color: var(--accept); }
.modebar button.on[data-mode=bypassPermissions]{ color: #fff; background: var(--bypass); border-color: var(--bypass); }

/* transcript */
.transcript { flex: 1; overflow-y: auto; padding: 14px 12px 20px; -webkit-overflow-scrolling: touch; }
.msg { margin-bottom: 12px; }
.bubble {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 11px 13px; white-space: pre-wrap; word-break: break-word;
}
.bubble.assistant { border-top-left-radius: 4px; }
.tool {
  background: var(--card2); border: 1px solid var(--line); border-radius: 12px;
  padding: 10px 12px; margin-bottom: 10px;
}
.tool-head { display: flex; align-items: center; gap: 8px; }
.tool-name { font-weight: 600; font-size: 13px; }
.tool-body { margin-top: 8px; max-height: 220px; overflow: auto; }
.tool pre { margin: 0; white-space: pre-wrap; word-break: break-word; color: var(--muted); }
.dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.dot.run { background: var(--accent2); animation: pulse 1s infinite; }
.dot.ok { background: var(--default); }
.dot.err { background: var(--bypass); }
@keyframes pulse { 50% { opacity: .3; } }
.result { text-align: center; color: var(--muted); font-size: 12px; margin: 8px 0; }

.jump {
  position: fixed; bottom: 78px; left: 50%; transform: translateX(-50%);
  background: var(--accent); color: #fff; border: none; border-radius: 999px;
  padding: 7px 14px; font-size: 13px; z-index: 20; box-shadow: 0 4px 16px rgba(0,0,0,.4);
}

/* composer */
#composer {
  display: flex; align-items: flex-end; gap: 8px; padding: 8px 10px;
  padding-bottom: calc(8px + var(--safe-b));
  background: var(--bg2); border-top: 1px solid var(--line);
}
#prompt {
  flex: 1; resize: none; max-height: 120px; background: var(--card); color: var(--txt);
  border: 1px solid var(--line); border-radius: 12px; padding: 9px 12px; font: inherit;
}
.send { background: var(--accent); color: #fff; border: none; width: 42px; height: 42px; border-radius: 12px; font-size: 17px; flex: none; }
.send:disabled { opacity: .4; }

/* approval sheet */
.sheet { position: fixed; inset: 0; z-index: 40; background: rgba(0,0,0,.5); display: flex; align-items: flex-end; }
.sheet-card {
  width: 100%; background: var(--card); border-top-left-radius: 20px; border-top-right-radius: 20px;
  border-top: 1px solid var(--line); padding: 16px 14px calc(16px + var(--safe-b));
  animation: rise .18s ease-out;
}
@keyframes rise { from { transform: translateY(40px); opacity: .6; } }
.sheet-head { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.badge { padding: 3px 9px; border-radius: 7px; font-size: 11px; font-weight: 700; text-transform: uppercase; }
.badge.exec { background: #3a241a; color: var(--exec); }
.badge.write { background: #3a2f12; color: var(--write); }
.badge.network { background: #16293d; color: var(--network); }
.badge.other { background: var(--card2); color: var(--muted); }
#ap-input, #ap-reason {
  width: 100%; background: var(--bg); color: var(--txt); border: 1px solid var(--line);
  border-radius: 10px; padding: 10px; font: inherit;
}
#ap-reason { margin-top: 8px; }
.sheet-actions { display: flex; gap: 10px; margin-top: 12px; }
.sheet-actions button { flex: 1; padding: 13px; border-radius: 12px; font-weight: 700; font-size: 15px; border: none; }
.btn-allow { background: var(--default); color: #04241a; }
.btn-deny { background: var(--card2); color: var(--bypass); border: 1px solid var(--bypass) !important; }

/* overlays */
.overlay { position: fixed; inset: 0; z-index: 30; background: var(--bg); display: flex; flex-direction: column; }
.overlay-head { display: flex; align-items: center; gap: 12px; padding: calc(12px + var(--safe-t)) 12px 12px; border-bottom: 1px solid var(--line); }
.overlay-head h2 { margin: 0; font-size: 17px; }
.overlay-body { flex: 1; overflow-y: auto; padding: 12px; }

.ws-row, .file-row {
  display: flex; align-items: center; gap: 10px; padding: 12px; margin-bottom: 8px;
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
}
.ws-row .grow { min-width: 0; }
.ws-row .name { font-weight: 600; }
.row-actions { display: flex; gap: 6px; }
.mini { background: var(--card2); border: 1px solid var(--line); color: var(--txt); padding: 6px 10px; border-radius: 8px; font-size: 12px; }
.mini.danger { color: var(--bypass); border-color: var(--bypass); }

.newform { margin-top: 14px; background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 12px; }
.newform summary { font-weight: 600; cursor: pointer; }
.newform input { display: block; width: 100%; margin: 8px 0; background: var(--bg); color: var(--txt); border: 1px solid var(--line); border-radius: 9px; padding: 9px; font: inherit; }
.clonelog { background: #000; padding: 8px; border-radius: 8px; max-height: 160px; overflow: auto; font-size: 11px; }

.crumbs { font-size: 13px; color: var(--muted); margin-bottom: 10px; word-break: break-all; }
.crumbs a { color: var(--accent2); text-decoration: none; }
.file-row .ext { font-size: 11px; color: var(--muted); }
.fv-head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
#fv-edit { width: 100%; background: var(--bg); color: var(--txt); border: 1px solid var(--line); border-radius: 10px; padding: 10px; }
.md { background: var(--card); border: 1px solid var(--line); border-radius: 10px; padding: 14px; }
.md h1,.md h2,.md h3 { margin: .6em 0 .3em; }
.md code { background: var(--bg); padding: 1px 5px; border-radius: 5px; font-family: ui-monospace, monospace; }
.md pre { background: var(--bg); padding: 10px; border-radius: 8px; overflow: auto; }
.md a { color: var(--accent2); }

.env-section { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 12px; margin-bottom: 12px; }
.env-section h3 { margin: 0 0 8px; font-size: 14px; }
.kv { display: flex; gap: 8px; margin: 6px 0; }
.kv input { flex: 1; background: var(--bg); color: var(--txt); border: 1px solid var(--line); border-radius: 8px; padding: 7px; font: inherit; }
.tier { font-size: 10px; padding: 2px 6px; border-radius: 5px; background: var(--card2); color: var(--muted); }

#gbtn { min-height: 44px; }
