:root{
  --bg:#0f172a;
  --bg-2:#111827;
  --panel:#1e293b;
  --panel-2:#0b1220;
  --text:#e5e7eb;
  --muted:#94a3b8;
  --accent:#22c55e;
  --op:#f59e0b;
  --fn:#64748b;
  --eq:#22c55e;
  --danger:#ef4444;
  --border:#334155;
  --radius:14px;
  --pad:12px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:16px/1.4 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;min-height:100vh}
body{display:flex;flex-direction:column;min-height:100dvh}

header{
  padding:env(safe-area-inset-top) 16px 0;
  background:linear-gradient(180deg,#0b1220,#0f172a);
  border-bottom:1px solid var(--border);
}
header h1{margin:8px 0;font-size:18px;letter-spacing:.02em;color:#cbd5e1}

nav#tabs{display:flex;gap:6px;margin:8px 0 0;overflow-x:auto}
nav .tab{
  background:transparent;color:var(--muted);border:1px solid var(--border);
  padding:8px 14px;border-radius:999px;cursor:pointer;font-size:14px;
  white-space:nowrap;
}
nav .tab.active{background:var(--panel);color:var(--text);border-color:#475569}

main{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:14px;gap:14px;max-width:560px;width:100%;margin:0 auto}

.pane{display:none}
.pane.active{display:flex;flex-direction:column;gap:12px}

.display{
  background:var(--panel-2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  text-align:right;
  min-height:90px;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.display .expr{font-size:clamp(28px,8vw,40px);font-weight:600;word-wrap:break-word;word-break:break-all;line-height:1.15}
.display .hint{font-size:12px;color:var(--muted);min-height:14px}

.keypad{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
}

.sci-bar{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;
}

.key{
  background:var(--panel);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 0;
  font-size:18px;
  font-weight:500;
  cursor:pointer;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
  transition:transform .05s,background .15s;
}
.key:active{transform:scale(0.97)}
.key.op{background:#1f2937;color:var(--op);font-weight:600}
.key.fn{background:#1f2937;color:#cbd5e1}
.key.eq{background:var(--eq);color:#04210d;font-weight:700}
.key.sci{padding:10px 0;font-size:14px;color:#cbd5e1;background:#1f2937}

.area{
  background:var(--panel-2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  display:flex;flex-direction:column;gap:14px;
}
.area h2{margin:0;font-size:18px}
.area label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.area .row{display:flex;gap:6px}
.area input,.area select{
  background:var(--panel);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;
  font-size:16px;
  flex:1;
  min-width:0;
}
.area select{flex:0 0 80px}
.area-out{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:10px;
  padding:14px;text-align:center;
}
.area-out .big{font-size:28px;font-weight:700;color:var(--accent)}
.area-actions{display:flex;justify-content:flex-end}

footer{
  text-align:center;padding:12px;color:var(--muted);font-size:12px;
  border-top:1px solid var(--border);
}

@media (max-width:380px){
  .key{padding:14px 0;font-size:16px}
  .key.sci{padding:8px 0;font-size:13px}
}

@media (prefers-reduced-motion:reduce){
  .key{transition:none}
}
