/* css/base.css
   Core layout + CRT terminal vibe (green) + general UI
*/

/* ===== Theme ===== */
:root{
  --bg:#03060a;
  --panel:rgba(0,20,10,.72);
  --panel2:rgba(0,12,8,.55);
  --line:rgba(0,255,140,.22);
  --text:rgba(160,255,210,.92);
  --muted:rgba(120,220,180,.75);
  --accent:rgba(0,255,140,.92);
  --bad:rgba(255,80,120,.92);
  --good:rgba(0,255,160,.92);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;
  color: var(--text);
  background: var(--bg);
  overflow-x:hidden;
}

/* Matrix-ish drifting background */
body::before{
  content:"";
  position:fixed; inset:-40%;
  background:
    radial-gradient(900px 600px at 15% 10%, rgba(0,255,140,.12), transparent 60%),
    radial-gradient(900px 600px at 80% 20%, rgba(0,255,140,.10), transparent 60%),
    radial-gradient(1200px 900px at 40% 80%, rgba(0,255,140,.08), transparent 70%),
    repeating-linear-gradient(90deg, rgba(0,255,140,.06) 0 1px, transparent 1px 14px),
    repeating-linear-gradient(180deg, rgba(0,255,140,.04) 0 1px, transparent 1px 18px);
  filter: blur(0.4px);
  animation: drift 16s linear infinite;
  opacity:.9;
  pointer-events:none;
  z-index:-2;
}
@keyframes drift{
  0%{ transform: translate3d(-2%, -1%, 0) rotate(0.2deg); }
  50%{ transform: translate3d(2%, 1%, 0) rotate(-0.2deg); }
  100%{ transform: translate3d(-2%, -1%, 0) rotate(0.2deg); }
}

/* CRT scanlines + vignette */
body::after{
  content:"";
  position:fixed; inset:0;
  background:
    repeating-linear-gradient(180deg, rgba(0,0,0,.0) 0 2px, rgba(0,0,0,.18) 2px 3px),
    radial-gradient(1400px 900px at 50% 40%, transparent 50%, rgba(0,0,0,.55) 100%);
  mix-blend-mode: multiply;
  opacity:.55;
  pointer-events:none;
  z-index:-1;
}

/* ===== Layout ===== */
.wrap{ max-width: 980px; margin:0 auto; padding:18px; }

.row{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 12px;
  margin-top: 12px;
}
@media (max-width: 860px){
  .row{ grid-template-columns: 1fr; }
}

.card{
  background: linear-gradient(180deg, var(--panel), var(--panel2));
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 0 0 1px rgba(0,255,140,.07), 0 18px 60px rgba(0,0,0,.55);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(900px 260px at 50% 0%, rgba(0,255,140,.10), transparent 60%);
  pointer-events:none;
}

.main{ min-height: 520px; }
.side{ min-height: 520px; }

.panel{ margin-top: 12px; }
.panel-pill{ margin:8px 0; display:inline-block; }
.panel-actions{ margin-top:8px; display:flex; gap:10px; flex-wrap:wrap; }
.panel-note{ margin-top:8px; }

/* ===== Header ===== */
.topbar{
  display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:16px;
  background: linear-gradient(180deg, rgba(0,255,140,.10), rgba(0,0,0,.10));
  box-shadow: 0 0 0 1px rgba(0,255,140,.07), 0 20px 60px rgba(0,0,0,.55);
  position:relative;
  overflow:hidden;
}
.topbar::before{
  content:"";
  position:absolute; inset:-2px;
  background: linear-gradient(90deg, transparent, rgba(0,255,140,.12), transparent);
  transform: translateX(-120%);
  animation: sweep 4.5s ease-in-out infinite;
}
@keyframes sweep{
  0%, 30%{ transform: translateX(-120%); }
  55%{ transform: translateX(120%); }
  100%{ transform: translateX(120%); }
}

.title{
  font-size: 16px;
  margin:0;
  letter-spacing:.6px;
  text-shadow: 0 0 10px rgba(0,255,140,.25);
}

/* ===== Controls ===== */
.controls{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.ctrl{
  display:flex;
  align-items:center;
  gap:8px;
}

.inline-check{
  padding: 6px 8px;
  border-radius: 12px;
  background: rgba(0,255,140,.03);
  border: 1px solid rgba(0,255,140,.12);
}

select, input[type="number"], textarea, .typebox{
  background: rgba(0,255,140,.06);
  color: var(--text);
  border: 1px solid rgba(0,255,140,.25);
  border-radius: 12px;
  padding: 10px 12px;
  outline: none;
  box-shadow: 0 0 0 1px rgba(0,255,140,.06) inset;
}
select:focus, input[type="number"]:focus, textarea:focus, .typebox:focus{
  border-color: rgba(0,255,140,.6);
  box-shadow: 0 0 0 4px rgba(0,255,140,.16);
}

input[type="number"]{
  width: 92px;
}

textarea.customText{
  width: 100%;
  resize: vertical;
  padding: 12px;
  font-size: 13px;
}

/* ===== Buttons ===== */
.btn{
  cursor:pointer;
  background: rgba(0,255,140,.06);
  color: var(--text);
  border: 1px solid rgba(0,255,140,.25);
  border-radius: 12px;
  padding: 10px 12px;
  box-shadow: 0 0 0 1px rgba(0,255,140,.06) inset;
  user-select:none;
}
.btn.primary{
  background: linear-gradient(180deg, rgba(0,255,140,.22), rgba(0,255,140,.06));
  border-color: rgba(0,255,140,.55);
  text-shadow: 0 0 10px rgba(0,255,140,.18);
}
.btn:active{ transform: translateY(1px); }
.btn:disabled{
  opacity: .5;
  cursor:not-allowed;
}

/* ===== Typography bits ===== */
.muted{
  color: var(--muted);
  font-size: 12px;
}

.pill{
  display:inline-block;
  padding: 4px 8px;
  border-radius:999px;
  background: rgba(0,255,140,.06);
  border:1px solid rgba(0,255,140,.22);
  text-shadow: 0 0 10px rgba(0,255,140,.12);
}

.kbd{
  font-family: inherit;
  background: rgba(0,255,140,.08);
  border:1px solid rgba(0,255,140,.22);
  padding:2px 6px;
  border-radius:8px;
}

/* ===== Prompt area ===== */
.prompt-header{
  margin-top:10px;
  display:inline-block;
}

.prompt{
  margin-top:10px;
  font-size: 18px;
  line-height: 1.7;
  padding: 14px;
  border-radius: 14px;
  background: rgba(0,255,140,.04);
  border: 1px dashed rgba(0,255,140,.28);
  min-height: 96px;
  word-break: break-word;
  text-shadow: 0 0 10px rgba(0,255,140,.10);
}

/* character classes from renderer */
.prompt .done{ color: var(--good); text-shadow: 0 0 10px rgba(0,255,160,.14); }
.prompt .bad{
  color: var(--bad);
  text-decoration: underline;
  text-decoration-thickness: 2px;
}
.prompt .next{
  color: var(--accent);
  border-bottom: 2px solid rgba(0,255,140,.7);
  animation: blink 1.05s steps(1,end) infinite;
}
@keyframes blink{ 50%{ opacity:.25; } }

/* ===== Input ===== */
.input-area{ margin-top: 12px; }

.typebox{
  width:100%;
  padding: 14px;
  font-size: 18px;
  caret-color: var(--accent);
}

/* ===== Footer ===== */
.footer{
  margin-top: 10px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.footnote{ margin-top: 12px; }

/* ===== Glitch label effect (status) ===== */
.glitch{
  position:relative;
  display:inline-block;
}
.glitch::before, .glitch::after{
  content: attr(data-text);
  position:absolute; left:0; top:0;
  opacity:.35;
  pointer-events:none;
}
.glitch::before{ transform: translate(1px,0); color: rgba(0,255,140,.85); }
.glitch::after{ transform: translate(-1px,0); color: rgba(0,180,120,.85); }

/* ===== Stats ===== */
.stats{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:10px;
  margin-top:12px;
}
.stat{
  padding: 12px;
  border-radius: 14px;
  background: rgba(0,255,140,.035);
  border:1px solid rgba(0,255,140,.18);
}
.stat .k{ font-size: 12px; color: var(--muted); }
.stat .v{ font-size: 20px; margin-top: 4px; text-shadow: 0 0 10px rgba(0,255,140,.14); }

/* ===== Live log box ===== */
.logbox{
  height: 220px;
  overflow: auto;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(0,255,140,.03);
  border: 1px solid rgba(0,255,140,.18);
  line-height: 1.5;
  font-size: 12px;
  white-space: pre-wrap;
}

/* ===== Danger report ===== */
.danger{
  margin-top: 12px;
}
.danger-body{
  margin-top: 8px;
  line-height: 1.6;
  font-size: 12px;
}

/* ===== History table ===== */
.history{ margin-top: 12px; }
.history-title{ margin-bottom: 6px; }
.hist-table{
  width:100%;
  border-collapse: collapse;
  font-size: 12px;
}
.hist-table th, .hist-table td{
  padding: 8px;
  border-bottom: 1px solid rgba(0,255,140,.14);
  text-align:left;
}
.history-actions{
  margin-top: 10px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* ===== Select fix (avoid white native background) ===== */
select{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;

  background-color: rgba(0,255,140,.06);
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(0,255,140,.85) 50%),
    linear-gradient(135deg, rgba(0,255,140,.85) 50%, transparent 50%),
    linear-gradient(180deg, rgba(0,255,140,.08), rgba(0,0,0,.10));
  background-position:
    calc(100% - 18px) 55%,
    calc(100% - 12px) 55%,
    0 0;
  background-size:
    6px 6px,
    6px 6px,
    100% 100%;
  background-repeat: no-repeat;

  padding-right: 34px; /* arrow space */
}

select::-ms-expand{ display:none; } /* old Edge/IE */

select option{
  background: #06130c;        /* ドロップダウンの中身 */
  color: rgba(160,255,210,.95);
}

/* ===== Force dark native controls ===== */
:root{
  color-scheme: dark; /* これが効くとネイティブUIが暗色寄りになる */
}
html, body{
  background: #03060a;
}

/* ===== Force select styling ===== */
select{
  color-scheme: dark;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;

  background-color: rgba(0,255,140,.06) !important;
  color: rgba(160,255,210,.95) !important;
  border: 1px solid rgba(0,255,140,.25) !important;

  padding-right: 36px !important; /* 矢印スペース */
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(0,255,140,.9) 50%),
    linear-gradient(135deg, rgba(0,255,140,.9) 50%, transparent 50%),
    linear-gradient(180deg, rgba(0,255,140,.10), rgba(0,0,0,.15)) !important;
  background-position:
    calc(100% - 18px) 55%,
    calc(100% - 12px) 55%,
    0 0 !important;
  background-size: 6px 6px, 6px 6px, 100% 100% !important;
  background-repeat: no-repeat !important;
}

select:focus{
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(0,255,140,.18) !important;
}

select option{
  background-color: #06130c !important;
  color: rgba(160,255,210,.95) !important;
}
