/* ============================================================================
   OurStore.ng — shared design system
   ============================================================================ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#11162B;--gold:#D9A441;--parchment:#F6F2E9;
  --slate-50:#F8FAFC;--slate-100:#F1F5F9;--slate-200:#E2E8F0;
  --slate-400:#94A3B8;--slate-500:#64748B;
  --pine:#1F7A5C;--pine-bg:rgba(31,122,92,.1);
  --ember:#DD5B3E;--ember-bg:rgba(221,91,62,.1);
  --gold-bg:rgba(217,164,65,.15);
  --radius:14px;--radius-lg:20px;--radius-xl:24px;
  --shadow:0 1px 4px rgba(17,22,43,.07),0 4px 16px rgba(17,22,43,.05);
  --shadow-md:0 4px 20px rgba(17,22,43,.1);
}
body{font-family:'Inter',sans-serif;background:var(--parchment);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}
h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;line-height:1.25}
a{color:inherit;text-decoration:none}

/* ── Form Elements ── */
input,select,textarea{
  font-family:'Inter',sans-serif;color:var(--ink);background:#fff;
  border:1.5px solid var(--slate-200);border-radius:10px;
  padding:10px 14px;font-size:14px;width:100%;
  transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(217,164,65,.15);
}
input::placeholder,textarea::placeholder{color:var(--slate-400)}
label{font-size:11.5px;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:6px}
.field{margin-bottom:16px}

/* ── Cards ── */
.card{
  background:#fff;border:1px solid var(--slate-200);
  border-radius:var(--radius-lg);padding:24px;
  box-shadow:var(--shadow);
}
.card+.card{margin-top:16px}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:600;border-radius:999px;cursor:pointer;border:none;
  font-family:'Inter',sans-serif;font-size:14px;padding:11px 22px;
  transition:opacity .15s,transform .1s,box-shadow .15s;text-decoration:none;
  white-space:nowrap;
}
.btn:hover{opacity:.88;box-shadow:var(--shadow-md)}
.btn:active{transform:scale(.98)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-ink{background:var(--ink);color:#fff}
.btn-outline{background:#fff;border:1.5px solid var(--slate-200);color:var(--ink)}
.btn-pine{background:var(--pine);color:#fff}
.btn-ember{background:var(--ember);color:#fff}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:8px 16px;font-size:12.5px}
.btn-xs{padding:5px 12px;font-size:11.5px}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}

/* ── Badges ── */
.badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.badge-ok{background:var(--pine-bg);color:var(--pine)}
.badge-warn{background:var(--gold-bg);color:#916C10}
.badge-bad{background:var(--ember-bg);color:var(--ember)}

/* ── Alerts ── */
.alert{padding:14px 18px;border-radius:12px;font-size:14px;font-weight:500;margin-bottom:20px;display:flex;align-items:flex-start;gap:10px}
.alert-ok{background:var(--pine-bg);color:var(--pine)}
.alert-err{background:var(--ember-bg);color:var(--ember)}

/* ── Utilities ── */
.muted{color:var(--slate-500);font-size:13px}
.row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 0}
.row+.row{border-top:1px solid var(--slate-200)}
.grid2{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:768px){.grid2{grid-template-columns:1fr 1fr}}
.grid3{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.stat-grid .card{padding:18px 20px}

/* ── Wallet card ── */
.wallet-card{background:var(--ink);color:#fff;border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md)}
.wallet-card label,.wallet-card .muted{color:rgba(246,242,233,.5)}
.wallet-card input{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fff}

/* ── Locked feature overlay ── */
.locked{position:relative;opacity:.5;pointer-events:none;user-select:none}
.lock-badge{position:absolute;top:12px;right:12px;background:var(--ink);color:var(--gold);font-size:10px;font-weight:700;padding:3px 10px;border-radius:999px;pointer-events:auto;opacity:1;z-index:1}

/* ── Messages layout ── */
.msg-shell{display:grid;grid-template-columns:260px 1fr;border:1px solid var(--slate-200);border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.msg-list{border-right:1px solid var(--slate-200);max-height:580px;overflow-y:auto}
.msg-panel{display:flex;flex-direction:column;height:580px}
@media(max-width:700px){.msg-shell{grid-template-columns:1fr}.msg-list{max-height:220px;border-right:none;border-bottom:1px solid var(--slate-200)}.msg-panel{height:400px}}

/* ── Password toggle ── */
.pw-wrap{position:relative}
.pw-wrap input{padding-right:42px}
.pw-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--slate-400);padding:8px;font-size:15px;line-height:1}

/* ── Auth pages ── */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--parchment)}
.auth-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-md)}
.auth-brand{font-size:20px;font-weight:700;color:var(--ink);display:block;margin-bottom:6px}
.auth-brand span{color:var(--gold)}
.auth-sub{color:var(--slate-500);font-size:14px;margin-bottom:28px}
.auth-link{color:var(--gold);font-weight:600;font-size:13px}
.auth-footer{text-align:center;margin-top:20px;font-size:13px;color:var(--slate-500)}

/* ══════════════════════════════════════════════════════════
   DASHBOARD APP SHELL
   ══════════════════════════════════════════════════════════ */
.app-shell{display:block;min-height:100vh}
@media(min-width:960px){.app-shell{display:flex;height:100vh;overflow:hidden}}

.app-main{padding:20px;flex:1;overflow-y:auto}
@media(min-width:960px){.app-main{padding:36px 44px}}

/* ── Mobile topbar ── */
#mobile-topbar{
  display:flex;background:var(--ink);color:#fff;
  align-items:center;justify-content:space-between;
  padding:13px 18px;position:sticky;top:0;z-index:30;
}
@media(min-width:960px){#mobile-topbar{display:none}}

/* ── Sidebar ── */
#sidebar{
  position:fixed;inset:0 auto 0 0;
  width:256px;max-width:88vw;z-index:50;
  transform:translateX(-100%);transition:transform .26s cubic-bezier(.2,1,.3,1);
  overflow-y:auto;background:var(--ink);
  padding:20px 14px 20px;
  display:flex;flex-direction:column;
  gap:0;
}
#sidebar.open{transform:translateX(0)}
@media(min-width:960px){#sidebar{position:sticky;top:0;height:100vh;transform:none;max-width:none;flex-shrink:0}}
#sidebar-backdrop{position:fixed;inset:0;background:rgba(17,22,43,.55);z-index:40;display:none;backdrop-filter:blur(2px)}
#sidebar-backdrop.open{display:block}
@media(min-width:960px){#sidebar-backdrop{display:none!important}}
#mobile-topbar{display:flex;background:var(--ink);color:#fff;align-items:center;justify-content:space-between;padding:13px 18px;position:sticky;top:0;z-index:30;position:relative}
@media(min-width:960px){#mobile-topbar{display:none}}
#sidebar-close-btn{display:block}
@media(min-width:960px){#sidebar-close-btn{display:none}}

/* ── Seller sidebar plain nav ── */
#sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1;margin-top:28px;overflow-y:auto}
#sidebar nav a{display:flex;align-items:center;justify-content:space-between;font-size:13.5px;font-weight:500;padding:10px 14px;border-radius:10px;text-decoration:none;color:rgba(246,242,233,.6);transition:background .12s,color .12s}
#sidebar nav a:hover{color:#fff;background:rgba(255,255,255,.07)}
#sidebar nav a.active{color:var(--ink);background:var(--gold);font-weight:600}

/* Sidebar brand */
.sb-brand{
  font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;
  color:var(--gold);letter-spacing:.05em;text-transform:uppercase;
  padding:4px 10px;margin-bottom:18px;display:flex;align-items:center;gap:8px;
}
.sb-brand-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* Sidebar close (mobile) */
.sb-close{
  background:rgba(255,255,255,.08);border:none;color:rgba(246,242,233,.7);
  width:28px;height:28px;border-radius:6px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
@media(min-width:960px){.sb-close{display:none!important}}

/* ── Nav groups (dropdowns) ── */
.nav-group{margin-bottom:2px}

.nav-group-toggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:none;border:none;cursor:pointer;
  font-size:10px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  color:rgba(246,242,233,.3);padding:9px 10px 7px;border-radius:8px;
  transition:color .15s;
}
.nav-group-toggle:hover,.nav-group.open .nav-group-toggle{color:rgba(246,242,233,.55)}

.nav-group-toggle-right{display:flex;align-items:center;gap:5px}
.nav-badge{background:#E8754A;color:#fff;font-size:9px;font-weight:800;padding:1px 6px;border-radius:999px;line-height:1.4}

.nav-chevron{transition:transform .22s;flex-shrink:0;opacity:.5}
.nav-group.open .nav-chevron{transform:rotate(180deg);opacity:.8}

.nav-group-items{display:none}
.nav-group.open .nav-group-items{display:block}

.nav-group-items a{
  display:flex;align-items:center;justify-content:space-between;
  font-size:13px;font-weight:500;
  padding:8px 10px;border-radius:8px;margin-bottom:1px;
  text-decoration:none;color:rgba(246,242,233,.55);
  transition:background .12s,color .12s;
}
.nav-group-items a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav-group-items a.active{color:var(--ink);background:var(--gold);font-weight:600}

/* Divider between groups */
.nav-divider{height:1px;background:rgba(255,255,255,.06);margin:6px 0}

/* Sign out */
.signout-link{
  font-size:12px;color:rgba(246,242,233,.35);letter-spacing:.05em;
  padding:9px 10px;display:flex;align-items:center;gap:8px;border-radius:8px;
  margin-top:auto;padding-top:14px;border-top:1px solid rgba(255,255,255,.07);
  transition:color .15s;
}
.signout-link:hover{color:rgba(246,242,233,.7)}

/* ── Page header ── */
.page-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;flex-wrap:wrap;gap:12px;
}
.page-title{font-size:22px;font-weight:700;font-family:'Space Grotesk',sans-serif}
.page-subtitle{font-size:13px;color:var(--slate-500);margin-top:2px}

/* ── Section title ── */
.section-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500);margin:28px 0 14px}

/* ── Table-style cards ── */
.item-row{
  display:flex;align-items:center;gap:14px;padding:14px 20px;
  background:#fff;border:1px solid var(--slate-200);
  border-radius:12px;margin-bottom:8px;
  box-shadow:0 1px 3px rgba(17,22,43,.04);
}
.item-row:hover{border-color:var(--gold);box-shadow:0 2px 8px rgba(217,164,65,.12)}

/* Brand */
.brand{font-family:'Space Grotesk',sans-serif;font-size:17px;font-weight:700;color:var(--gold)}

/* ══════════════════════════════════════════════════════════
   DARK MODE
   ══════════════════════════════════════════════════════════ */
[data-theme="dark"] {
  --ink: #F1EDE3;
  --parchment: #1A1F2E;
  --slate-50: #1F2435;
  --slate-100: #252A3A;
  --slate-200: #333A50;
  --slate-400: #8896B0;
  --slate-500: #A0AABD;
  --pine: #4ADE80;
  --pine-bg: rgba(74,222,128,.12);
  --ember: #FB7185;
  --ember-bg: rgba(251,113,133,.12);
  --gold-bg: rgba(217,164,65,.18);
}
[data-theme="dark"] body { background: var(--parchment); color: var(--ink); }
[data-theme="dark"] .card { background: #1F2435; border-color: #333A50; }
[data-theme="dark"] input, [data-theme="dark"] select, [data-theme="dark"] textarea { background: #252A3A; border-color: #333A50; color: #F1EDE3; }
[data-theme="dark"] #sidebar { background: #0F1320; }
[data-theme="dark"] .btn-outline { background: #252A3A; border-color: #333A50; color: #F1EDE3; }
[data-theme="dark"] .msg-shell { background: #1F2435; border-color: #333A50; }
[data-theme="dark"] .msg-panel { background: #252A3A; }

/* Dark mode toggle button */
.dark-toggle {
  background: none;
  border: 1.5px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.7);
  border-radius: 999px;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: background .15s;
}
.dark-toggle:hover { background: rgba(255,255,255,.1); color: #fff; }