/* assets/style.css — Mizan theme (teal/gold), responsive */
:root{
  --teal:#0D4F5C; --teal-d:#0a3d47; --gold:#B8860B; --gold-l:#d4af37;
  --bg:#f4f6f7; --card:#ffffff; --ink:#1f2937; --muted:#6b7280;
  --line:#e3e8ea; --ok:#0f7b4a; --okbg:#e7f6ee; --err:#b3261e; --errbg:#fce8e6;
  --radius:12px; --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:var(--bg);font-size:15px;line-height:1.5}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
code{font-family:Consolas,monospace;font-size:.85em}

/* ---------- Auth pages ---------- */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,var(--teal) 0%,var(--teal-d) 100%);padding:20px}
.auth-card{background:var(--card);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.25);
  padding:32px;width:100%;max-width:380px;text-align:center}
.auth-logo{max-width:200px;height:auto;margin:0 auto 8px}
.auth-title{font-size:1.4rem;margin:.2rem 0;color:var(--teal)}
.auth-sub{color:var(--muted);margin:.2rem 0 1.2rem;font-size:.9rem}
.auth-card form{text-align:left}
.auth-card label{display:block;font-weight:bold;font-size:.85rem;margin:.6rem 0 .25rem}
.auth-card input{width:100%}
.auth-divider{display:flex;align-items:center;gap:10px;margin:18px 0;color:var(--muted);font-size:.85rem}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-foot{margin-top:16px;font-size:.9rem}
.g_id_signin{display:flex;justify-content:center;margin:6px 0}

/* ---------- Inputs/buttons ---------- */
input,select{padding:.55rem .6rem;border:1px solid var(--line);border-radius:8px;font-size:.95rem;background:#fff;font-family:inherit}
input:focus,select:focus{outline:2px solid var(--gold-l);border-color:var(--gold-l)}
button{cursor:pointer;font-family:inherit}
.btn-primary{background:var(--teal);color:#fff;border:0;border-radius:8px;padding:.6rem 1rem;font-weight:bold}
.btn-primary:hover{background:var(--teal-d)}
.btn-danger{background:var(--err);color:#fff;border:0;border-radius:8px;padding:.6rem 1rem;font-weight:bold}
.btn-block{display:block;width:100%;margin-top:1rem}
.btn-sm{padding:.3rem .6rem;font-size:.82rem;border:1px solid var(--line);background:#fff;border-radius:6px}
.btn-sm.btn-primary{border:0}
.btn-logout{background:rgba(255,255,255,.15);color:#fff;padding:.4rem .8rem;border-radius:8px;font-size:.85rem}
.btn-logout:hover{background:rgba(255,255,255,.28);text-decoration:none}

/* ---------- App shell ---------- */
.topbar{display:flex;align-items:center;gap:12px;background:var(--teal);color:#fff;
  padding:8px 16px;position:sticky;top:0;z-index:30;box-shadow:var(--shadow)}
.topbar .logo{height:38px;width:auto;background:#fff;border-radius:8px;padding:3px 8px}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.user-chip{font-size:.85rem;opacity:.95}
.lang-form select{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3);padding:.3rem .4rem}
.lang-form option{color:#000}
.hamburger{display:none;background:transparent;border:0;color:#fff;font-size:1.4rem}

.layout{display:flex;min-height:calc(100vh - 54px)}
.sidebar{width:230px;background:#fff;border-right:1px solid var(--line);padding:12px 8px;flex-shrink:0}
.sidebar a{display:flex;align-items:center;gap:10px;padding:.6rem .8rem;border-radius:8px;color:var(--ink);font-size:.92rem}
.sidebar a:hover{background:var(--bg);text-decoration:none}
.sidebar a.active{background:var(--teal);color:#fff;font-weight:bold}
.content{flex:1;padding:22px;max-width:1100px}
.page-title{font-size:1.5rem;margin:.2rem 0 1rem;color:var(--teal)}
.footer{text-align:center;color:var(--muted);font-size:.8rem;padding:16px}

/* ---------- Components ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card h3{margin:.1rem 0 .6rem;color:var(--teal)}
.stat{text-align:center}
.stat-num{font-size:2rem;font-weight:bold;color:var(--teal)}
.stat-lbl{color:var(--muted);font-size:.85rem;margin-bottom:.4rem}
.muted{color:var(--muted)}
.banner-freeze{background:#fff4d6;border:1px solid var(--gold);color:#7a5c00;padding:.6rem .9rem;border-radius:8px;margin-bottom:14px;font-weight:bold}
.flash{padding:.6rem .9rem;border-radius:8px;margin-bottom:10px;font-size:.9rem}
.flash-success{background:var(--okbg);color:var(--ok);border:1px solid #bfe6cf}
.flash-error{background:var(--errbg);color:var(--err);border:1px solid #f3c3bf}

.table-wrap{overflow-x:auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
table.data{width:100%;border-collapse:collapse;font-size:.9rem;min-width:640px}
table.data th{background:var(--teal);color:#fff;text-align:left;padding:.6rem .7rem;font-weight:bold;white-space:nowrap}
table.data td{padding:.55rem .7rem;border-top:1px solid var(--line);vertical-align:top}
table.data tr:nth-child(even) td{background:#fafbfb}
.nowrap{white-space:nowrap}
.json{display:block;max-width:240px;overflow:auto;color:#444}
.tags{font-family:Consolas,monospace;font-size:.82rem;color:var(--teal)}
.badge{display:inline-block;padding:.1rem .5rem;border-radius:20px;font-size:.75rem;background:#eef2f3;color:#445}
.badge-active{background:var(--okbg);color:var(--ok)}
.badge-inactive{background:var(--errbg);color:var(--err)}
.badge-pending{background:#fff4d6;color:#7a5c00}
.row-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:8px 14px;margin-bottom:16px}
.panel>summary{display:inline-block;margin:6px 0;list-style:none}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;padding:12px 0}
.form-grid label{display:flex;flex-direction:column;font-size:.85rem;font-weight:bold;gap:.25rem}
.form-grid input,.form-grid select{font-weight:normal}
.form-actions{grid-column:1/-1}
.form-inline{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.form-narrow{max-width:420px;display:flex;flex-direction:column;gap:.3rem}
.form-narrow label{font-weight:bold;font-size:.85rem;display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}
.mini-form{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.mini-form input,.mini-form select{font-size:.82rem;padding:.3rem .4rem}
details.inline{display:inline-block}
.pager{display:flex;gap:4px;flex-wrap:wrap;margin-top:12px}
.pager a{padding:.3rem .6rem;border:1px solid var(--line);border-radius:6px}
.pager a.active{background:var(--teal);color:#fff}

/* simple icons (unicode glyphs as background-free markers) */
.ico{width:18px;display:inline-block;text-align:center}
.ico-home::before{content:"⌂"}.ico-users::before{content:"👤"}.ico-settings::before{content:"⚙"}
.ico-list::before{content:"☰"}.ico-shield::before{content:"🛡"}.ico-key::before{content:"🔑"}

/* ---------- Responsive / mobile ---------- */
@media (max-width:820px){
  .hamburger{display:block}
  .sidebar{position:fixed;left:-240px;top:54px;bottom:0;transition:left .2s;z-index:25;box-shadow:var(--shadow)}
  body.nav-open .sidebar{left:0}
  .content{padding:16px}
  .user-chip{display:none}
}

.chk{display:flex;align-items:center;gap:6px;font-weight:normal;font-size:.85rem}
.chk input{width:auto}
