/* ===================================================================
   Eiwaz Network — admin.css  (پنل مدیریت)
   از متغیرهای رنگ styles.css استفاده می‌کند (باید قبل از این لینک شود)
   =================================================================== */

body.admin{background:var(--bg);min-height:100vh}
.admin-wrap{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ===== Sidebar ===== */
.side{position:sticky;top:0;height:100vh;border-left:1px solid var(--border);
  background:var(--bg-2);display:flex;flex-direction:column;padding:20px 16px;overflow-y:auto}
.side-brand{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1.2rem;margin-bottom:1.6rem;padding:0 6px}
.side-brand .brand-logo{width:38px;height:38px}
.side-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}
.side-nav button{display:flex;align-items:center;gap:.7rem;width:100%;text-align:right;
  padding:.75rem .9rem;border-radius:12px;border:1px solid transparent;background:none;color:var(--muted);
  font-family:inherit;font-size:.96rem;font-weight:500;transition:.2s}
.side-nav button:hover{background:rgba(255,255,255,.04);color:var(--text)}
.side-nav button.active{background:rgba(25,227,194,.1);border-color:var(--border);color:var(--primary)}
.side-nav .ic{font-size:1.1rem;width:22px;text-align:center}
.side-nav .badge-n{margin-inline-start:auto;min-width:20px;height:20px;padding:0 5px;border-radius:999px;
  display:grid;place-items:center;font-size:.72rem;font-weight:700;background:var(--danger);color:#fff}
.side-foot{margin-top:1rem;border-top:1px solid var(--border);padding-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.side-foot a,.side-foot button{font-size:.88rem;color:var(--muted);background:none;border:none;
  font-family:inherit;text-align:right;padding:.4rem .6rem;border-radius:8px;cursor:pointer;transition:.2s}
.side-foot a:hover,.side-foot button:hover{color:var(--primary)}

/* ===== Main ===== */
.main{padding:26px 30px;max-width:1100px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.8rem;gap:1rem;flex-wrap:wrap}
.topbar h1{font-size:1.5rem;font-weight:800}
.topbar .sub{color:var(--muted);font-size:.9rem;margin-top:.2rem}
.panel{display:none}
.panel.active{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ===== Metric cards ===== */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:1.8rem}
.metric{padding:18px 20px;border-radius:16px;background:var(--surface);border:1px solid var(--border)}
.metric .m-label{color:var(--muted);font-size:.85rem;margin-bottom:.4rem}
.metric .m-val{font-size:1.9rem;font-weight:800;color:var(--text)}
.metric .m-ic{float:left;font-size:1.4rem;opacity:.6}

/* ===== Card / sections ===== */
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:22px;margin-bottom:1.5rem}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem;gap:1rem;flex-wrap:wrap}
.card-head h2{font-size:1.15rem;font-weight:700}
.card-head h3{font-size:1.02rem;font-weight:700}

/* ===== Table ===== */
.tbl-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border)}
table.tbl{width:100%;border-collapse:collapse;font-size:.9rem;min-width:560px}
table.tbl th,table.tbl td{padding:.8rem .9rem;text-align:right;border-bottom:1px solid var(--border);white-space:nowrap}
table.tbl th{color:var(--muted);font-weight:600;background:rgba(255,255,255,.02);font-size:.82rem}
table.tbl tr:last-child td{border-bottom:none}
table.tbl td.wrap{white-space:normal;min-width:160px}
.empty{text-align:center;color:var(--muted);padding:2.4rem 1rem}

/* ===== Status pills ===== */
.pill{padding:.25rem .7rem;border-radius:999px;font-size:.76rem;font-weight:700;display:inline-block}
.pill.new{background:rgba(43,209,255,.14);color:var(--primary-2)}
.pill.confirmed{background:rgba(25,227,194,.14);color:var(--primary)}
.pill.done{background:rgba(124,92,255,.16);color:#c9bcff}
.pill.cancelled{background:rgba(255,92,124,.14);color:var(--danger)}
.pill.available{background:rgba(25,227,194,.14);color:var(--primary)}
.pill.booked{background:rgba(255,189,46,.16);color:#ffce6b}

/* ===== Buttons / inputs (reuse .btn from styles.css) ===== */
.btn-sm{padding:.45rem .85rem;font-size:.82rem;border-radius:10px}
.btn-danger{background:rgba(255,92,124,.12);border:1px solid rgba(255,92,124,.3);color:var(--danger)}
.btn-danger:hover{background:rgba(255,92,124,.2)}
.btn-soft{background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text)}
.btn-soft:hover{border-color:var(--primary);color:var(--primary)}
.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}
select.mini{padding:.4rem .6rem;border-radius:9px;background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text);font-family:inherit;font-size:.82rem}
select.mini option{background:var(--bg-2)}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grid .full{grid-column:1/-1}
.hint{color:var(--muted);font-size:.82rem;margin-top:.3rem}

/* product admin row */
.padmin{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;
  background:rgba(255,255,255,.02);border:1px solid var(--border);margin-bottom:.7rem}
.padmin .pa-ic{font-size:1.5rem;width:46px;height:46px;display:grid;place-items:center;border-radius:10px;
  background:rgba(255,255,255,.04);flex-shrink:0}
.padmin .pa-info{flex:1;min-width:0}
.padmin .pa-info h4{font-size:.96rem;margin-bottom:.2rem}
.padmin .pa-info p{color:var(--muted);font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.padmin .pa-price{color:var(--primary);font-weight:700;font-size:.88rem;white-space:nowrap}
.padmin.off{opacity:.5}

/* ===== Modal ===== */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);z-index:100;
  display:none;align-items:center;justify-content:center;padding:20px}
.modal-ov.open{display:flex}
.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:18px;width:560px;max-width:100%;
  max-height:90vh;overflow-y:auto;padding:26px;box-shadow:var(--shadow)}
.modal h3{margin-bottom:1.2rem}

/* ===== Login ===== */
.login-ov{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(900px 500px at 80% -10%,rgba(124,92,255,.18),transparent 60%),
  radial-gradient(700px 400px at -10% 20%,rgba(25,227,194,.14),transparent 55%),var(--bg)}
.login-card{width:400px;max-width:100%;padding:34px;text-align:center}
.login-card .brand-logo{width:56px;height:56px;margin:0 auto 1rem}
.login-card h2{font-size:1.3rem;margin-bottom:.4rem}
.login-card p{color:var(--muted);font-size:.9rem;margin-bottom:1.5rem}
.login-card .field{text-align:right}
.login-err{color:var(--danger);font-size:.85rem;margin-top:.6rem;min-height:1.2em}
.login-note{color:var(--muted);font-size:.78rem;margin-top:1rem}

/* ===== Toast (reuse styles.css .toast) ===== */

/* ===== Responsive ===== */
@media (max-width:880px){
  .admin-wrap{grid-template-columns:1fr}
  .side{position:fixed;z-index:80;right:0;width:248px;transform:translateX(100%);transition:.3s}
  .side.open{transform:none}
  .main{padding:18px}
  .mobile-bar{display:flex!important}
  .metrics{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
}
.mobile-bar{display:none;align-items:center;gap:.7rem;margin-bottom:1.2rem}
.mobile-bar button{width:44px;height:44px;border-radius:12px;background:var(--surface);
  border:1px solid var(--border);color:var(--text);font-size:1.3rem}
@media (max-width:520px){.metrics{grid-template-columns:1fr}}
