/* free-alkhalidi admin panel - styles.css
   Aesthetic: restrained editorial. Warm paper, ink, single petrol accent.
   Mobile-first. Large tap targets. Sticky bottom nav on phones. */

:root {
  --paper:#f7f4ee; --paper-2:#fffdf8; --card:#ffffff;
  --ink:#1c1b18; --ink-2:#54514a; --ink-3:#8a877e;
  --rule:#e4ded2; --rule-2:#d6cfbf;
  --accent:#0f5a52; --accent-ink:#0b3f39; --accent-soft:#e3efec;
  --amber:#9a6a12; --amber-soft:#f6ecd6;
  --red:#9b2f2f; --red-soft:#f4e2e0;
  --green:#2f6b3a; --green-soft:#e3efe4;
  --shadow:0 1px 2px rgba(28,27,24,.06), 0 6px 18px rgba(28,27,24,.06);
  --radius:14px; --radius-sm:9px;
  --tap:48px;
  --sans:"Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
}

* { box-sizing:border-box; }
html,body { margin:0; padding:0; }
body {
  font-family:var(--sans); background:var(--paper); color:var(--ink);
  font-size:16px; line-height:1.5; -webkit-text-size-adjust:100%;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3 { font-family:var(--serif); font-weight:600; line-height:1.15; letter-spacing:-.01em; margin:0 0 .4em; }
h1 { font-size:1.65rem; }
h2 { font-size:1.25rem; }
h3 { font-size:1.02rem; }
a { color:var(--accent-ink); }
small { color:var(--ink-3); }

/* ---------- layout ---------- */
.app { min-height:100dvh; display:flex; flex-direction:column; }
.topbar {
  position:sticky; top:0; z-index:30; background:var(--paper-2);
  border-bottom:1px solid var(--rule); display:flex; align-items:center;
  gap:.6rem; padding:.7rem 1rem; min-height:56px;
}
.topbar .brand { font-family:var(--serif); font-weight:600; font-size:1.05rem; }
.topbar .brand b { color:var(--accent); }
.topbar .spacer { flex:1; }
.topbar .who { font-size:.78rem; color:var(--ink-2); text-align:right; line-height:1.2; }
.topbar .who b { display:block; color:var(--ink); font-size:.85rem; }

main { flex:1; width:100%; max-width:880px; margin:0 auto; padding:1rem 1rem 6.5rem; }

/* desktop side rail appears >=860px */
.railnav { display:none; }

/* bottom nav (mobile) */
.bottomnav {
  position:fixed; bottom:0; left:0; right:0; z-index:30;
  background:var(--paper-2); border-top:1px solid var(--rule);
  display:flex; overflow-x:auto; scrollbar-width:none;
  padding:.3rem .4rem calc(.3rem + env(safe-area-inset-bottom));
}
.bottomnav::-webkit-scrollbar { display:none; }
.bottomnav button {
  flex:0 0 auto; min-width:64px; min-height:var(--tap);
  background:none; border:none; color:var(--ink-2);
  font:inherit; font-size:.68rem; display:flex; flex-direction:column;
  align-items:center; gap:.15rem; padding:.35rem .55rem; border-radius:10px;
  cursor:pointer;
}
.bottomnav button .ic { font-size:1.15rem; line-height:1; }
.bottomnav button.active { color:var(--accent); background:var(--accent-soft); }
.bottomnav button .badge {
  position:absolute; transform:translate(14px,-6px); background:var(--red);
  color:#fff; font-size:.6rem; min-width:16px; height:16px; border-radius:9px;
  display:flex; align-items:center; justify-content:center; padding:0 4px;
}

/* ---------- cards & lists ---------- */
.card {
  background:var(--card); border:1px solid var(--rule); border-radius:var(--radius);
  padding:1rem; box-shadow:var(--shadow); margin-bottom:.85rem;
}
.card.tight { padding:.8rem; }
.row { display:flex; align-items:center; gap:.6rem; }
.row.wrap { flex-wrap:wrap; }
.between { justify-content:space-between; }
.stack > * + * { margin-top:.7rem; }
.muted { color:var(--ink-2); }
.dim { color:var(--ink-3); font-size:.8rem; }
.kpi-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:.7rem; }
.kpi { background:var(--card); border:1px solid var(--rule); border-radius:var(--radius); padding:.9rem; }
.kpi .n { font-family:var(--serif); font-size:1.8rem; font-weight:600; }
.kpi .l { font-size:.74rem; color:var(--ink-2); text-transform:uppercase; letter-spacing:.04em; }

/* ---------- pills / status ---------- */
.pill {
  display:inline-flex; align-items:center; gap:.3rem; font-size:.7rem;
  font-weight:600; padding:.18rem .5rem; border-radius:99px; text-transform:uppercase;
  letter-spacing:.03em; border:1px solid transparent; white-space:nowrap;
}
.pill.draft { background:var(--paper); color:var(--ink-2); border-color:var(--rule-2); }
.pill.pending { background:var(--amber-soft); color:var(--amber); }
.pill.published { background:var(--green-soft); color:var(--green); }
.pill.archived { background:var(--red-soft); color:var(--red); }
.pill.role { background:var(--accent-soft); color:var(--accent-ink); text-transform:none; }

/* ---------- buttons ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.4rem;
  min-height:var(--tap); padding:0 1.1rem; border-radius:var(--radius-sm);
  font:inherit; font-weight:600; font-size:.92rem; cursor:pointer;
  border:1px solid var(--ink); background:var(--ink); color:#fff;
  transition:transform .04s ease, opacity .15s ease; text-decoration:none;
}
.btn:active { transform:translateY(1px); }
.btn.accent { background:var(--accent); border-color:var(--accent); }
.btn.ghost { background:transparent; color:var(--ink); border-color:var(--rule-2); }
.btn.ghost.accent { color:var(--accent-ink); border-color:var(--accent); }
.btn.danger { background:var(--red); border-color:var(--red); }
.btn.sm { min-height:38px; padding:0 .8rem; font-size:.82rem; }
.btn.block { width:100%; }
.btn:disabled { opacity:.5; pointer-events:none; }
.btn-row { display:flex; gap:.5rem; flex-wrap:wrap; }

/* ---------- forms ---------- */
label { display:block; font-size:.8rem; font-weight:600; color:var(--ink-2); margin:0 0 .3rem; }
input, textarea, select {
  width:100%; font:inherit; font-size:16px; color:var(--ink);
  background:var(--paper-2); border:1px solid var(--rule-2); border-radius:var(--radius-sm);
  padding:.7rem .8rem; min-height:var(--tap);
}
textarea { min-height:120px; resize:vertical; line-height:1.5; }
input:focus, textarea:focus, select:focus {
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft);
}
.field + .field { margin-top:.75rem; }

/* ---------- reference popover (English root for translators) ---------- */
.ref {
  background:var(--accent-soft); border:1px solid #cfe2dd; border-radius:var(--radius-sm);
  padding:.6rem .75rem; margin:0 0 .5rem; font-size:.9rem; color:var(--accent-ink);
}
.ref .lbl { font-size:.66rem; text-transform:uppercase; letter-spacing:.05em; font-weight:700; opacity:.8; display:block; margin-bottom:.2rem; }

/* ---------- table-ish rows for small screens ---------- */
.item { border:1px solid var(--rule); border-radius:var(--radius); background:var(--card); padding:.85rem; margin-bottom:.7rem; box-shadow:var(--shadow); }
.item .title { font-family:var(--serif); font-size:1.05rem; font-weight:600; }
.item .meta { font-size:.74rem; color:var(--ink-3); margin-top:.15rem; }

/* ---------- login ---------- */
.login-wrap { min-height:100dvh; display:flex; align-items:center; justify-content:center; padding:1.2rem; background:
  radial-gradient(120% 80% at 50% -10%, #fffdf8 0%, var(--paper) 55%); }
.login-card { width:100%; max-width:380px; }
.login-card .mark { font-family:var(--serif); font-size:1.5rem; font-weight:600; text-align:center; margin-bottom:.2rem; }
.login-card .mark b { color:var(--accent); }
.login-card .sub { text-align:center; color:var(--ink-3); font-size:.82rem; margin-bottom:1.2rem; }

/* ---------- toast ---------- */
.toast-host { position:fixed; left:50%; bottom:calc(74px + env(safe-area-inset-bottom)); transform:translateX(-50%); z-index:60; display:flex; flex-direction:column; gap:.5rem; width:calc(100% - 2rem); max-width:420px; }
.toast { background:var(--ink); color:#fff; padding:.75rem 1rem; border-radius:10px; font-size:.88rem; box-shadow:var(--shadow); animation:rise .2s ease; }
.toast.err { background:var(--red); }
.toast.ok { background:var(--green); }
@keyframes rise { from { opacity:0; transform:translateY(8px); } }

/* ---------- modal ---------- */
.modal-host { position:fixed; inset:0; z-index:50; background:rgba(28,27,24,.45); display:flex; align-items:flex-end; justify-content:center; padding:0; }
.modal { background:var(--paper-2); width:100%; max-width:620px; max-height:92dvh; overflow:auto; border-radius:18px 18px 0 0; padding:1.1rem 1.1rem calc(1.3rem + env(safe-area-inset-bottom)); box-shadow:0 -8px 30px rgba(0,0,0,.18); animation:sheet .22s ease; }
@keyframes sheet { from { transform:translateY(20px); opacity:.6; } }
.modal h2 { margin-top:.2rem; }
.modal .close { float:right; background:none; border:none; font-size:1.5rem; color:var(--ink-3); cursor:pointer; min-height:40px; min-width:40px; }

.empty { text-align:center; color:var(--ink-3); padding:2.5rem 1rem; }
.empty .ic { font-size:2rem; display:block; margin-bottom:.4rem; opacity:.6; }
.spin { display:inline-block; width:18px; height:18px; border:2px solid var(--rule-2); border-top-color:var(--accent); border-radius:50%; animation:sp .7s linear infinite; }
@keyframes sp { to { transform:rotate(360deg); } }
.center-load { display:flex; justify-content:center; padding:3rem; }

.seglist { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:.9rem; }
.seg { border:1px solid var(--rule-2); background:var(--paper-2); border-radius:99px; padding:.35rem .8rem; font-size:.8rem; font-weight:600; color:var(--ink-2); cursor:pointer; min-height:38px; }
.seg.active { background:var(--ink); color:#fff; border-color:var(--ink); }

.lang-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(96px,1fr)); gap:.5rem; }
.lang-cell { border:1px solid var(--rule-2); border-radius:10px; padding:.5rem; text-align:center; cursor:pointer; background:var(--paper-2); min-height:62px; }
.lang-cell .code { font-weight:700; text-transform:uppercase; font-size:.85rem; }
.lang-cell .st { font-size:.62rem; text-transform:uppercase; letter-spacing:.04em; margin-top:.2rem; }
.lang-cell.published { border-color:var(--green); background:var(--green-soft); }
.lang-cell.pending { border-color:var(--amber); background:var(--amber-soft); }
.lang-cell.draft { border-color:var(--rule-2); }

.media-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:.6rem; }
.media-tile { border:1px solid var(--rule); border-radius:10px; overflow:hidden; background:var(--card); }
.media-tile img { width:100%; aspect-ratio:1; object-fit:cover; display:block; }
.media-tile .cap { padding:.4rem .5rem; font-size:.68rem; color:var(--ink-3); word-break:break-all; }

.logline { font-size:.82rem; padding:.55rem 0; border-bottom:1px solid var(--rule); }
.logline .a { font-weight:600; }
.logline .t { color:var(--ink-3); font-size:.72rem; }

/* ---------- desktop ---------- */
@media (min-width:860px) {
  .app { flex-direction:row; }
  .bottomnav { display:none; }
  .railnav {
    display:flex; flex-direction:column; gap:.2rem; width:230px; flex:0 0 230px;
    border-right:1px solid var(--rule); background:var(--paper-2);
    padding:1rem .7rem; position:sticky; top:0; height:100dvh;
  }
  .railnav .rbrand { font-family:var(--serif); font-size:1.15rem; font-weight:600; padding:.4rem .6rem 1rem; }
  .railnav .rbrand b { color:var(--accent); }
  .railnav button {
    text-align:left; background:none; border:none; font:inherit; font-size:.92rem;
    color:var(--ink-2); padding:.6rem .7rem; border-radius:9px; cursor:pointer;
    display:flex; align-items:center; gap:.6rem; min-height:44px; position:relative;
  }
  .railnav button.active { background:var(--accent-soft); color:var(--accent-ink); font-weight:600; }
  .railnav button .badge { margin-left:auto; background:var(--red); color:#fff; font-size:.66rem; border-radius:9px; padding:0 6px; min-width:18px; text-align:center; }
  .app-main-col { flex:1; display:flex; flex-direction:column; min-width:0; }
  main { padding-bottom:2rem; }
  .kpi-grid { grid-template-columns:repeat(4,1fr); }
  .modal-host { align-items:center; }
  .modal { border-radius:18px; }
}

/* ---------- machine-translation states ---------- */
.lang-cell.machine { border-color:#7a5cc0; background:#efeaf9; }
.lang-cell.machine .st { color:#5a3fa0; font-weight:700; }
.pill.machine { background:#efeaf9; color:#5a3fa0; }
.ref.warn { background:#f6ecd6; border-color:#e6d3a3; color:#7a5a12; }
.ref.warn .lbl { opacity:.95; }

/* ---------- language toggle + RTL ---------- */
.langtoggle{
  min-height:34px; padding:0 .7rem; border:1px solid var(--rule-2); background:var(--paper-2);
  color:var(--ink); border-radius:99px; font:inherit; font-size:.78rem; font-weight:700; cursor:pointer;
}
.langtoggle:active{ transform:translateY(1px); }
[dir="rtl"] body, [dir="rtl"] input, [dir="rtl"] textarea, [dir="rtl"] .kpi .l { text-align:right; }
[dir="rtl"] .topbar .who{ text-align:left; }
[dir="rtl"] .railnav{ border-right:none; border-left:1px solid var(--rule); }
[dir="rtl"] .railnav button{ text-align:right; }
[dir="rtl"] .bottomnav button .badge{ transform:translate(-14px,-6px); }
[dir="rtl"] .modal .close{ float:left; }
/* keep Latin-script inputs (e.g. URLs, usernames) left-aligned even in RTL */
input[dir="ltr"], textarea[dir="ltr"]{ text-align:left; }
