/* app.css — Mobile-first dark theme (red primary) */
@import url('https://fonts.googleapis.com/css2?family=Tajawal:wght@300;400;500;700;800&display=swap');

:root{
  --bg:#0b0e11;
  --card:#111418;
  --card2:#14181d;
  --border:#1f2429;
  --text:#ffffff;
  --muted:#9aa0a6;
  --red:#e50914;
  --red2:#b20710;
  --green:#25D366;
  --blue:#0a3d62;
  --shadow: 0 8px 25px rgba(0,0,0,.45);
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Tajawal', system-ui, -apple-system, Segoe UI, sans-serif;
  -webkit-font-smoothing:antialiased;
  display:flex;
  justify-content:center;
}

/* Mobile-only layout: center a phone-width app */
.app{
  width:100%;
  max-width:440px;
  min-height:100vh;
  padding:16px;
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}

.brand{
  font-weight:800;
  font-size:18px;
  letter-spacing:.2px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:16px;
  box-shadow:var(--shadow);
}

.card + .card{margin-top:12px;}

.h1{font-size:22px;font-weight:800;margin:0;}
.h2{font-size:18px;font-weight:800;margin:0;}
.muted{color:var(--muted);}

.grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.stat{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px;
}

.stat .label{font-size:13px;color:var(--muted);}
.stat .value{font-size:22px;font-weight:800;margin-top:8px;}

.input{
  width:100%;
  padding:14px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  font-size:16px;
  outline:none;
}

.textarea{
  min-height:100px;
  resize:none;
}

.label{display:block;margin:0 0 8px 0;color:var(--muted);font-size:14px;font-weight:600;}

.btn{
  width:100%;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  font-size:17px;
  font-weight:800;
  cursor:pointer;
  text-decoration:none;
}

.btn:active{transform:scale(.99);}

.btn-primary{background:var(--red);border-color:transparent;box-shadow:0 10px 25px rgba(229,9,20,.25);}
.btn-primary:hover{background:var(--red2);}

.btn-secondary{background:rgba(255,255,255,.04);}

.btn-green{background:var(--green);border-color:transparent;color:#06210f;}

.btn-disabled{
  background:#f2f2f2;
  color:#111;
  border-color:#d0d0d0;
  cursor:not-allowed;
  filter:grayscale(100%);
}


.btn-link{
  background:transparent;
  border-color:transparent;
  color:var(--muted);
  font-weight:700;
  padding:10px 6px;
}

hr.sep{border:none;border-top:1px solid var(--border);margin:14px 0;}

.notice{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-size:14px;
}

.notice.success{border-color:rgba(37,211,102,.35);background:rgba(37,211,102,.08);color:#bff4d2;}
.notice.error{border-color:rgba(229,9,20,.35);background:rgba(229,9,20,.08);color:#ffb7bb;}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0 10px;
}

.table td{
  background:var(--card2);
  border:1px solid var(--border);
  padding:12px;
}

.table td:first-child{border-radius:14px 0 0 14px;}
.table td:last-child{border-radius:0 14px 14px 0;}

.op{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px;
}

.op .row{display:flex;justify-content:space-between;gap:10px;align-items:center;}
.op .title{font-weight:800;}
.op .small{font-size:13px;color:var(--muted);margin-top:6px;}

.pill{
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  font-size:13px;
  white-space:nowrap;
}

.pill.plus{border-color:rgba(37,211,102,.35);color:#bff4d2;}
.pill.minus{border-color:rgba(229,9,20,.35);color:#ffb7bb;}

/* Keep everything readable on very small phones */
@media (max-width: 360px){
  .app{padding:12px;}
  .btn{font-size:16px;}
  .stat .value{font-size:20px;}
}
