/* ═══════════════════════════════════════════════════════════════
   GST NOW — FULL APP STYLESHEET
   Design tokens → Layout → Components → Pages → Utilities
   ═══════════════════════════════════════════════════════════════ */

/* ── TOKENS ─────────────────────────────────────────────────── */
:root {
  --teal-50:  #e6f7f8; --teal-100: #b3e8ec; --teal-200: #7dd6df;
  --teal-300: #4ac4d2; --teal-400: #30b5c5; --teal-500: #38a3ad;
  --teal-600: #2d8a93; --teal-700: #22707a;
  --navy-900: #0f172a; --navy-800: #1e293b; --navy-700: #334155;
  --navy-600: #475569; --navy-500: #64748b; --navy-400: #94a3b8;
  --indigo-600:#4f46e5; --indigo-500:#6366f1; --indigo-400:#818cf8;
  --blue-600:  #1d4ed8; --blue-500:  #2563eb; --blue-400:  #3b82f6;
  --green-500: #22c55e; --green-400: #4ade80; --green-100:#dcfce7;
  --amber-500: #f59e0b; --amber-100: #fef3c7;
  --red-500:   #ef4444; --red-100:   #fee2e2;
  --purple-500:#a855f7; --purple-100:#f3e8ff;

  /* Semantic light */
  --bg:            #f1f5f9;
  --bg-card:       #ffffff;
  --bg-sidebar:    #0f172a;
  --bg-header:     #ffffff;
  --bg-subtle:     #f8fafc;
  --border:        #e2e8f0;
  --border-strong: #cbd5e1;
  --text-primary:  #0f172a;
  --text-secondary:#475569;
  --text-muted:    #94a3b8;
  --text-inverse:  #ffffff;
  --sidebar-text:  rgba(255,255,255,0.65);
  --sidebar-text-active: #ffffff;
  --sidebar-active-bg: rgba(56,163,173,0.18);
  --sidebar-hover-bg:  rgba(255,255,255,0.06);

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.07),0 2px 4px rgba(0,0,0,0.06);
  --shadow-lg: 0 10px 15px rgba(0,0,0,0.07),0 4px 6px rgba(0,0,0,0.05);
  --shadow-xl: 0 20px 25px rgba(0,0,0,0.08),0 8px 10px rgba(0,0,0,0.04);
  --shadow-2xl:0 25px 50px rgba(0,0,0,0.12);

  --radius-xs: 4px; --radius-sm: 6px; --radius-md: 10px;
  --radius-lg: 14px; --radius-xl: 20px; --radius-full: 9999px;

  --sidebar-w: 240px;
  --header-h:  56px;
  --transition: 0.18s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="dark"] {
  --bg:            #080d18;
  --bg-card:       #0f172a;
  --bg-sidebar:    #050a12;
  --bg-header:     #0f172a;
  --bg-subtle:     #111827;
  --border:        #1e293b;
  --border-strong: #334155;
  --text-primary:  #f1f5f9;
  --text-secondary:#94a3b8;
  --text-muted:    #475569;
  --sidebar-text:  rgba(255,255,255,0.55);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.5);
  --shadow-lg: 0 10px 15px rgba(0,0,0,0.6);
  --shadow-xl: 0 20px 25px rgba(0,0,0,0.6);
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;transition:background 0.3s,color 0.3s}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none;font-size:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}
svg{flex-shrink:0}

/* ── LOADING ────────────────────────────────────────────────── */
.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;gap:24px;background:var(--bg)}
.app-loading__logo{display:flex;align-items:center;gap:12px;font-size:1.5rem;font-weight:800;letter-spacing:-0.03em;color:var(--text-primary)}
.app-loading__spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--teal-500);border-radius:50%;animation:spin 0.7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.app-shell{display:flex;height:100dvh;overflow:hidden}

/* ── SIDEBAR ────────────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--bg-sidebar);
  display:flex;flex-direction:column;
  height:100dvh;overflow:hidden;
  transition:width var(--transition),transform var(--transition);
  position:relative;z-index:200;
}
.sidebar__logo{
  display:flex;align-items:center;gap:10px;
  padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.06);
  flex-shrink:0;
}
.sidebar__logo-mark{display:flex;align-items:center}
.sidebar__logo-text{font-size:1.1rem;font-weight:800;letter-spacing:-0.03em;color:#fff}
.sidebar__logo-badge{font-size:0.6rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;background:rgba(56,163,173,0.25);color:var(--teal-400);padding:2px 7px;border-radius:var(--radius-full);margin-left:4px;border:1px solid rgba(56,163,173,0.3)}

.sidebar__nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 0;scrollbar-width:none}
.sidebar__nav::-webkit-scrollbar{display:none}

.sidebar__section-label{
  font-size:0.65rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(255,255,255,0.25);padding:12px 20px 4px;
}
.sidebar__nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 20px;margin:1px 8px;border-radius:var(--radius-sm);
  color:var(--sidebar-text);font-size:0.85rem;font-weight:500;
  cursor:pointer;transition:all var(--transition);position:relative;
  border:1px solid transparent;user-select:none;
}
.sidebar__nav-item:hover{background:var(--sidebar-hover-bg);color:rgba(255,255,255,0.9)}
.sidebar__nav-item.active{
  background:var(--sidebar-active-bg);
  color:var(--sidebar-text-active);
  border-color:rgba(56,163,173,0.25);
}
.sidebar__nav-item.active .sidebar__nav-icon{color:var(--teal-400)}
.sidebar__nav-icon{width:18px;height:18px;flex-shrink:0;opacity:0.7;transition:opacity var(--transition)}
.sidebar__nav-item:hover .sidebar__nav-icon,.sidebar__nav-item.active .sidebar__nav-icon{opacity:1}
.sidebar__nav-badge{
  margin-left:auto;background:var(--red-500);color:#fff;
  font-size:0.65rem;font-weight:700;padding:2px 6px;
  border-radius:var(--radius-full);min-width:18px;text-align:center;
}
.sidebar__nav-badge--amber{background:var(--amber-500)}

.sidebar__footer{
  padding:12px;border-top:1px solid rgba(255,255,255,0.06);flex-shrink:0;
}
.sidebar__user{
  display:flex;align-items:center;gap:10px;padding:8px 10px;
  border-radius:var(--radius-sm);cursor:pointer;
  transition:background var(--transition);
}
.sidebar__user:hover{background:var(--sidebar-hover-bg)}
.sidebar__avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal-500),var(--blue-500));
  display:flex;align-items:center;justify-content:center;
  font-size:0.72rem;font-weight:700;color:#fff;flex-shrink:0;
}
.sidebar__user-info{flex:1;min-width:0}
.sidebar__user-name{font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar__user-role{font-size:0.72rem;color:rgba(255,255,255,0.4)}

/* ── APP BODY ───────────────────────────────────────────────── */
.app-body{flex:1;display:flex;flex-direction:column;min-width:0;height:100dvh;overflow:hidden}

/* ── HEADER ─────────────────────────────────────────────────── */
.app-header{
  height:var(--header-h);flex-shrink:0;
  background:var(--bg-header);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:16px;padding:0 24px;
  position:relative;z-index:100;
}
.app-header__title{font-size:1rem;font-weight:700;letter-spacing:-0.02em;color:var(--text-primary)}
.app-header__breadcrumb{display:flex;align-items:center;gap:6px;font-size:0.82rem;color:var(--text-muted)}
.app-header__breadcrumb span{color:var(--text-primary);font-weight:600}
.app-header__search{
  flex:1;max-width:360px;margin-left:16px;
  display:flex;align-items:center;gap:8px;
  background:var(--bg-subtle);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:7px 12px;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.app-header__search:focus-within{border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(56,163,173,0.12)}
.app-header__search input{
  border:none;background:none;outline:none;flex:1;
  font-size:0.85rem;color:var(--text-primary);
}
.app-header__search input::placeholder{color:var(--text-muted)}
.app-header__search-icon{color:var(--text-muted);width:15px;height:15px;flex-shrink:0}
.app-header__actions{display:flex;align-items:center;gap:6px;margin-left:auto}
.header-btn{
  width:34px;height:34px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-secondary);background:transparent;
  transition:all var(--transition);position:relative;
}
.header-btn:hover{background:var(--bg-subtle);color:var(--text-primary)}
.header-btn__badge{
  position:absolute;top:4px;right:4px;
  width:8px;height:8px;border-radius:50%;
  background:var(--red-500);border:2px solid var(--bg-header);
}
.header-divider{width:1px;height:24px;background:var(--border);margin:0 4px}

/* ── MAIN CONTENT ───────────────────────────────────────────── */
.app-main{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}
.page-header__left{}
.page-title{font-size:1.4rem;font-weight:800;letter-spacing:-0.03em;color:var(--text-primary)}
.page-subtitle{font-size:0.85rem;color:var(--text-secondary);margin-top:2px}
.page-header__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--radius-md);
  font-size:0.85rem;font-weight:600;letter-spacing:-0.01em;
  transition:all var(--transition);white-space:nowrap;
  border:1.5px solid transparent;line-height:1.2;cursor:pointer;
}
.btn--primary{background:linear-gradient(135deg,var(--teal-500),var(--blue-500));color:#fff;box-shadow:0 2px 8px rgba(56,163,173,0.3)}
.btn--primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(56,163,173,0.4)}
.btn--secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border)}
.btn--secondary:hover{border-color:var(--border-strong);background:var(--bg-subtle)}
.btn--ghost{background:transparent;color:var(--text-secondary);border-color:transparent}
.btn--ghost:hover{background:var(--bg-subtle);color:var(--text-primary)}
.btn--danger{background:var(--red-500);color:#fff;border-color:transparent}
.btn--danger:hover{background:#dc2626}
.btn--sm{padding:5px 12px;font-size:0.78rem;border-radius:var(--radius-sm)}
.btn--lg{padding:11px 22px;font-size:0.95rem;border-radius:var(--radius-lg)}
.btn--full{width:100%;justify-content:center}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none!important}
.btn svg{width:15px;height:15px;flex-shrink:0}

/* ── CARDS ──────────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.card--hover:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transition:all var(--transition)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-size:0.9rem;font-weight:700;letter-spacing:-0.01em;color:var(--text-primary)}
.card-subtitle{font-size:0.78rem;color:var(--text-muted);margin-top:2px}

/* ── STAT CARDS ─────────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:20px;
  display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden;
  transition:all var(--transition);
}
.stat-card:hover{box-shadow:var(--shadow-md)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.stat-card--teal::before{background:linear-gradient(90deg,var(--teal-500),var(--teal-300))}
.stat-card--blue::before{background:linear-gradient(90deg,var(--blue-500),var(--blue-400))}
.stat-card--green::before{background:linear-gradient(90deg,var(--green-500),var(--green-400))}
.stat-card--amber::before{background:linear-gradient(90deg,var(--amber-500),#fbbf24)}
.stat-card--red::before{background:linear-gradient(90deg,var(--red-500),#f87171)}
.stat-card--purple::before{background:linear-gradient(90deg,var(--purple-500),#c084fc)}
.stat-card__label{font-size:0.78rem;font-weight:600;letter-spacing:0.02em;text-transform:uppercase;color:var(--text-muted)}
.stat-card__value{font-size:1.8rem;font-weight:800;letter-spacing:-0.04em;color:var(--text-primary);line-height:1}
.stat-card__change{font-size:0.75rem;font-weight:600;display:flex;align-items:center;gap:4px;margin-top:4px}
.stat-card__change--up{color:var(--green-500)}
.stat-card__change--down{color:var(--red-500)}
.stat-card__icon{position:absolute;right:16px;top:16px;width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}
.stat-card--teal .stat-card__icon{background:rgba(56,163,173,0.1);color:var(--teal-500)}
.stat-card--blue .stat-card__icon{background:rgba(37,99,235,0.1);color:var(--blue-500)}
.stat-card--green .stat-card__icon{background:rgba(34,197,94,0.1);color:var(--green-500)}
.stat-card--amber .stat-card__icon{background:rgba(245,158,11,0.1);color:var(--amber-500)}
.stat-card--red .stat-card__icon{background:rgba(239,68,68,0.1);color:var(--red-500)}
.stat-card--purple .stat-card__icon{background:rgba(168,85,247,0.1);color:var(--purple-500)}

/* ── TABLES ─────────────────────────────────────────────────── */
.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.table-toolbar{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.table-search{
  display:flex;align-items:center;gap:8px;
  background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-md);
  padding:7px 12px;flex:1;max-width:300px;
}
.table-search:focus-within{border-color:var(--teal-500)}
.table-search input{border:none;background:none;outline:none;flex:1;font-size:0.83rem;color:var(--text-primary);min-width:0}
.table-search input::placeholder{color:var(--text-muted)}
.table-search svg{color:var(--text-muted);width:14px;height:14px;flex-shrink:0}
.table-filter{display:flex;align-items:center;gap:8px;margin-left:auto}
select.filter-select{
  border:1px solid var(--border);background:var(--bg-card);
  color:var(--text-primary);border-radius:var(--radius-sm);
  padding:6px 10px;font-size:0.82rem;cursor:pointer;outline:none;
}
select.filter-select:focus{border-color:var(--teal-500)}
table{width:100%;border-collapse:collapse}
thead th{
  padding:10px 16px;text-align:left;
  font-size:0.72rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--text-muted);background:var(--bg-subtle);
  border-bottom:1px solid var(--border);white-space:nowrap;
}
thead th:first-child{border-radius:0}
tbody tr{transition:background var(--transition);cursor:pointer}
tbody tr:hover{background:var(--bg-subtle)}
tbody tr:not(:last-child) td{border-bottom:1px solid var(--border)}
tbody td{padding:12px 16px;font-size:0.85rem;color:var(--text-primary);vertical-align:middle}
.table-empty{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:0.9rem}
.table-empty strong{display:block;color:var(--text-secondary);font-size:1rem;margin-bottom:4px}

/* ── BADGES ─────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:var(--radius-full);font-size:0.72rem;font-weight:700;white-space:nowrap}
.badge--green{background:var(--green-100);color:#15803d}
.badge--red{background:var(--red-100);color:#dc2626}
.badge--amber{background:var(--amber-100);color:#b45309}
.badge--blue{background:#dbeafe;color:#1d4ed8}
.badge--teal{background:rgba(56,163,173,0.12);color:var(--teal-600)}
.badge--purple{background:var(--purple-100);color:#7e22ce}
.badge--gray{background:var(--bg-subtle);color:var(--text-muted);border:1px solid var(--border)}
[data-theme="dark"] .badge--green{background:rgba(34,197,94,0.12);color:var(--green-400)}
[data-theme="dark"] .badge--red{background:rgba(239,68,68,0.12);color:#f87171}
[data-theme="dark"] .badge--amber{background:rgba(245,158,11,0.12);color:var(--amber-500)}
[data-theme="dark"] .badge--blue{background:rgba(37,99,235,0.12);color:var(--blue-400)}
[data-theme="dark"] .badge--teal{background:rgba(56,163,173,0.15);color:var(--teal-400)}
.badge__dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ── FORMS ──────────────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-group label{font-size:0.8rem;font-weight:600;color:var(--text-secondary)}
.form-group input,.form-group select,.form-group textarea{
  padding:9px 12px;border:1.5px solid var(--border);
  border-radius:var(--radius-md);background:var(--bg-card);
  color:var(--text-primary);font-size:0.88rem;outline:none;
  transition:border-color var(--transition),box-shadow var(--transition);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(56,163,173,0.12);
}
.form-group textarea{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-hint{font-size:0.75rem;color:var(--text-muted)}
.form-divider{border:none;border-top:1px solid var(--border);margin:16px 0}

/* ── MODALS ─────────────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.45);
  backdrop-filter:blur(4px);z-index:1000;
  display:flex;align-items:center;justify-content:center;padding:24px;
  animation:fadeIn 0.15s ease;
}
.modal{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);
  width:100%;max-width:520px;max-height:90vh;overflow:hidden;
  display:flex;flex-direction:column;animation:slideUp 0.2s ease;
}
.modal--lg{max-width:720px}
.modal--sm{max-width:380px}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.modal-title{font-size:1rem;font-weight:700;letter-spacing:-0.02em;color:var(--text-primary)}
.modal-close{
  width:28px;height:28px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:all var(--transition);
}
.modal-close:hover{background:var(--bg-subtle);color:var(--text-primary)}
.modal-body{padding:24px;overflow-y:auto;flex:1}
.modal-footer{
  display:flex;align-items:center;justify-content:flex-end;gap:8px;
  padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ── TOAST ──────────────────────────────────────────────────── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:var(--radius-md);
  background:var(--navy-800);color:#fff;
  box-shadow:var(--shadow-xl);font-size:0.85rem;font-weight:500;
  pointer-events:auto;min-width:260px;max-width:380px;
  animation:toastIn 0.25s ease;
  border:1px solid rgba(255,255,255,0.08);
}
.toast--success{background:#14532d;border-color:#16a34a}
.toast--error  {background:#7f1d1d;border-color:var(--red-500)}
.toast--info   {background:var(--navy-800);border-color:rgba(56,163,173,0.4)}
.toast.removing{animation:toastOut 0.2s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(16px)}}

/* ── TABS ───────────────────────────────────────────────────── */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}
.tab-btn{
  padding:10px 18px;font-size:0.85rem;font-weight:600;
  color:var(--text-muted);border-bottom:2px solid transparent;
  margin-bottom:-1px;transition:all var(--transition);cursor:pointer;
  background:none;border-top:none;border-left:none;border-right:none;
}
.tab-btn:hover{color:var(--text-secondary)}
.tab-btn.active{color:var(--teal-500);border-bottom-color:var(--teal-500)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ── PROGRESS BAR ───────────────────────────────────────────── */
.progress-bar{height:6px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}
.progress-bar__fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--teal-500),var(--blue-500));transition:width 0.5s ease}

/* ── AVATAR ─────────────────────────────────────────────────── */
.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;color:#fff;flex-shrink:0}
.avatar--sm{width:28px;height:28px;font-size:0.65rem}
.avatar--lg{width:48px;height:48px;font-size:0.9rem}

/* ── DROPDOWN ───────────────────────────────────────────────── */
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;right:0;top:calc(100% + 6px);
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-md);box-shadow:var(--shadow-xl);
  min-width:180px;z-index:500;padding:4px;
  animation:slideUp 0.15s ease;
}
.dropdown-item{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:var(--radius-sm);
  font-size:0.85rem;color:var(--text-secondary);cursor:pointer;
  transition:all var(--transition);
}
.dropdown-item:hover{background:var(--bg-subtle);color:var(--text-primary)}
.dropdown-item--danger:hover{background:var(--red-100);color:var(--red-500)}
[data-theme="dark"] .dropdown-item--danger:hover{background:rgba(239,68,68,0.1)}
.dropdown-divider{height:1px;background:var(--border);margin:4px 0}

/* ── EMPTY STATE ────────────────────────────────────────────── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;text-align:center}
.empty-state__icon{width:56px;height:56px;border-radius:var(--radius-xl);background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}
.empty-state__title{font-size:1rem;font-weight:700;color:var(--text-primary)}
.empty-state__desc{font-size:0.85rem;color:var(--text-muted);max-width:320px}

/* ── LOGIN PAGE ─────────────────────────────────────────────── */
.login-page{
  min-height:100dvh;display:grid;grid-template-columns:1fr 1fr;
}
.login-left{
  background:var(--navy-900);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:48px;position:relative;overflow:hidden;
}
.login-bg-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(56,163,173,0.07) 1px,transparent 1px),linear-gradient(90deg,rgba(56,163,173,0.07) 1px,transparent 1px);
  background-size:48px 48px;pointer-events:none;
}
.login-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.login-orb--1{width:400px;height:400px;background:radial-gradient(circle,rgba(56,163,173,0.2) 0%,transparent 70%);top:-100px;right:-100px}
.login-orb--2{width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,0.15) 0%,transparent 70%);bottom:-50px;left:-50px}
.login-brand{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.login-brand__text{font-size:1.3rem;font-weight:800;letter-spacing:-0.03em;color:#fff}
.login-hero{position:relative;z-index:1}
.login-hero__tag{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);background:rgba(56,163,173,0.15);border:1px solid rgba(56,163,173,0.3);color:var(--teal-400);font-size:0.75rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:16px}
.login-hero h2{font-size:2rem;font-weight:800;letter-spacing:-0.04em;line-height:1.15;color:#fff;margin-bottom:16px}
.login-hero p{font-size:0.92rem;color:rgba(255,255,255,0.55);line-height:1.7}
.login-features{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.login-feature{display:flex;align-items:center;gap:10px;font-size:0.85rem;color:rgba(255,255,255,0.6)}
.login-feature__icon{width:24px;height:24px;border-radius:var(--radius-sm);background:rgba(56,163,173,0.15);display:flex;align-items:center;justify-content:center;color:var(--teal-400);flex-shrink:0}
.login-right{
  background:var(--bg);display:flex;align-items:center;justify-content:center;padding:48px;
}
.login-form-card{width:100%;max-width:420px}
.login-form-title{font-size:1.5rem;font-weight:800;letter-spacing:-0.03em;color:var(--text-primary);margin-bottom:6px}
.login-form-sub{font-size:0.87rem;color:var(--text-muted);margin-bottom:28px}
.login-demo-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:10px;border-radius:var(--radius-md);
  background:rgba(56,163,173,0.1);border:1.5px solid rgba(56,163,173,0.3);
  color:var(--teal-500);font-size:0.87rem;font-weight:700;
  cursor:pointer;transition:all var(--transition);margin-bottom:20px;
}
.login-demo-btn:hover{background:rgba(56,163,173,0.18);border-color:var(--teal-500)}
.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-muted);font-size:0.78rem}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.login-toggle{text-align:center;margin-top:20px;font-size:0.85rem;color:var(--text-muted)}
.login-toggle a{color:var(--teal-500);font-weight:600;cursor:pointer}

/* ── DASHBOARD ──────────────────────────────────────────────── */
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.dashboard-col-2{grid-column:span 2}
.dashboard-col-1{grid-column:span 1}
.activity-feed{display:flex;flex-direction:column;gap:0}
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.activity-item:last-child{border-bottom:none}
.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.activity-content{flex:1;min-width:0}
.activity-title{font-size:0.85rem;color:var(--text-primary);font-weight:500;line-height:1.4}
.activity-meta{font-size:0.75rem;color:var(--text-muted);margin-top:2px}
.deadline-list{display:flex;flex-direction:column;gap:0}
.deadline-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.deadline-item:last-child{border-bottom:none}
.deadline-date{text-align:center;min-width:44px}
.deadline-date__day{font-size:1.1rem;font-weight:800;color:var(--text-primary);line-height:1}
.deadline-date__month{font-size:0.65rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-muted)}
.deadline-content{flex:1;min-width:0}
.deadline-title{font-size:0.83rem;font-weight:600;color:var(--text-primary)}
.deadline-client{font-size:0.75rem;color:var(--text-muted)}
.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quick-action{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;border-radius:var(--radius-md);
  border:1px solid var(--border);background:var(--bg-card);
  cursor:pointer;transition:all var(--transition);
  font-size:0.83rem;font-weight:600;color:var(--text-primary);
}
.quick-action:hover{border-color:var(--teal-500);background:rgba(56,163,173,0.04);color:var(--teal-500)}
.quick-action__icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* Mini bar chart */
.mini-chart{display:flex;align-items:flex-end;gap:4px;height:80px;padding:4px 0}
.mini-chart__bar{flex:1;border-radius:3px 3px 0 0;min-height:4px;background:var(--border);position:relative;transition:all var(--transition)}
.mini-chart__bar--active{background:linear-gradient(180deg,var(--teal-400),var(--teal-600))}
.mini-chart__bar:hover{opacity:0.8}
.mini-chart-labels{display:flex;gap:4px;margin-top:6px}
.mini-chart-label{flex:1;text-align:center;font-size:0.65rem;color:var(--text-muted)}

/* ── CLIENTS PAGE ───────────────────────────────────────────── */
.client-name{font-weight:600;color:var(--text-primary)}
.client-abn{font-size:0.75rem;color:var(--text-muted);margin-top:1px}
.table-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition)}
tr:hover .table-actions{opacity:1}
.icon-btn{
  width:28px;height:28px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:all var(--transition);
}
.icon-btn:hover{background:var(--bg-subtle);color:var(--text-primary)}
.icon-btn--danger:hover{background:var(--red-100);color:var(--red-500)}
[data-theme="dark"] .icon-btn--danger:hover{background:rgba(239,68,68,0.1)}

/* ── LEDGER PAGE ────────────────────────────────────────────── */
.ledger-client-bar{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 20px;
}
.amount-positive{color:var(--green-500);font-weight:600}
.amount-negative{color:var(--red-500);font-weight:600}
.ledger-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}

/* ── RECONCILIATION ─────────────────────────────────────────── */
.recon-wizard{max-width:800px;margin:0 auto}
.recon-steps{display:flex;align-items:center;margin-bottom:36px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 28px}
.recon-step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;position:relative}
.recon-step:not(:last-child)::after{content:'';position:absolute;top:14px;left:60%;width:80%;height:2px;background:var(--border);z-index:0}
.recon-step.done:not(:last-child)::after{background:var(--teal-500)}
.recon-step__num{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.78rem;font-weight:700;border:2px solid var(--border);
  background:var(--bg-card);color:var(--text-muted);position:relative;z-index:1;transition:all var(--transition);
}
.recon-step.active .recon-step__num{border-color:var(--teal-500);background:rgba(56,163,173,0.1);color:var(--teal-500)}
.recon-step.done .recon-step__num{border-color:var(--teal-500);background:var(--teal-500);color:#fff}
.recon-step__label{font-size:0.72rem;font-weight:600;color:var(--text-muted);text-align:center}
.recon-step.active .recon-step__label{color:var(--teal-500)}
.recon-step.done .recon-step__label{color:var(--text-secondary)}
.recon-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px}
.recon-upload-zone{
  border:2px dashed var(--border);border-radius:var(--radius-lg);
  padding:48px;text-align:center;cursor:pointer;
  transition:all var(--transition);background:var(--bg-subtle);
}
.recon-upload-zone:hover{border-color:var(--teal-500);background:rgba(56,163,173,0.04)}
.recon-upload-icon{width:56px;height:56px;border-radius:var(--radius-xl);background:rgba(56,163,173,0.1);display:flex;align-items:center;justify-content:center;color:var(--teal-500);margin:0 auto 16px}
.recon-processing{text-align:center;padding:16px 0}
.recon-processing__title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}
.recon-processing__status{font-size:0.87rem;color:var(--text-muted);margin-bottom:24px;min-height:1.5em}
.recon-log{text-align:left;margin-top:24px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;font-size:0.78rem;font-family:monospace;color:var(--text-secondary);max-height:150px;overflow-y:auto}
.recon-log-line{padding:2px 0;display:flex;gap:8px}
.recon-log-time{color:var(--text-muted);flex-shrink:0}
.recon-log-msg--ok{color:var(--green-500)}
.recon-log-msg--info{color:var(--teal-400)}
.recon-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.recon-results-stats{display:flex;gap:16px}
.recon-stat{text-align:center}
.recon-stat__val{font-size:1.4rem;font-weight:800;letter-spacing:-0.04em;color:var(--text-primary)}
.recon-stat__lbl{font-size:0.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em}
.recon-row{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;border-radius:var(--radius-md);
  border:1px solid var(--border);margin-bottom:6px;
  background:var(--bg-card);transition:all var(--transition);
}
.recon-row:hover{border-color:var(--border-strong)}
.recon-row--review{border-color:rgba(245,158,11,0.3);background:rgba(245,158,11,0.03)}
.recon-row__desc{flex:1;font-size:0.85rem;color:var(--text-primary)}
.recon-row__amount{font-size:0.85rem;font-weight:700;color:var(--text-primary);text-align:right;min-width:90px}
.recon-row__confidence{min-width:56px;text-align:center}
.confidence-pill{font-size:0.72rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}
.confidence-pill--high{background:rgba(34,197,94,0.12);color:var(--green-500)}
.confidence-pill--med{background:rgba(245,158,11,0.12);color:var(--amber-500)}
.confidence-pill--low{background:rgba(239,68,68,0.12);color:var(--red-500)}
.recon-complete{text-align:center;padding:24px}
.recon-complete__icon{width:72px;height:72px;border-radius:50%;background:rgba(34,197,94,0.1);border:2px solid var(--green-500);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:2rem;color:var(--green-500);animation:completePop 0.4s ease}
@keyframes completePop{0%{transform:scale(0.6);opacity:0}70%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}

/* ── BAS PAGE ───────────────────────────────────────────────── */
.bas-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}
.bas-form-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}
.bas-section-header{padding:12px 20px;background:var(--bg-subtle);border-bottom:1px solid var(--border);font-size:0.8rem;font-weight:700;color:var(--text-secondary);letter-spacing:0.03em}
.bas-field-row{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border)}
.bas-field-row:last-child{border-bottom:none}
.bas-field-code{font-size:0.78rem;font-weight:700;color:var(--text-muted);min-width:32px;font-family:monospace}
.bas-field-label{flex:1;font-size:0.85rem;color:var(--text-primary)}
.bas-field-value{
  text-align:right;padding:5px 10px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:0.87rem;font-weight:600;color:var(--text-primary);
  background:var(--bg-card);width:130px;outline:none;font-family:monospace;
}
.bas-field-value:focus{border-color:var(--teal-500)}
.bas-field-value--calculated{background:var(--bg-subtle);color:var(--text-secondary)}
.bas-summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:sticky;top:24px}
.bas-summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:0.87rem}
.bas-summary-row:last-child{border-bottom:none}
.bas-summary-row--total{font-weight:800;font-size:1rem;color:var(--teal-500)}
.bas-lodge-btn{width:100%;margin-top:16px}
.bas-status-badge{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);margin-bottom:12px;font-size:0.83rem;font-weight:600}
.bas-status-badge--due{background:var(--amber-100);color:#92400e;border:1px solid rgba(245,158,11,0.3)}
[data-theme="dark"] .bas-status-badge--due{background:rgba(245,158,11,0.1);color:var(--amber-500)}
.bas-status-badge--lodged{background:var(--green-100);color:#14532d;border:1px solid rgba(34,197,94,0.3)}
[data-theme="dark"] .bas-status-badge--lodged{background:rgba(34,197,94,0.1);color:var(--green-400)}

/* ── DOCUMENTS PAGE ─────────────────────────────────────────── */
.docs-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:start}
.docs-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.docs-sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.docs-sidebar-title{font-size:0.82rem;font-weight:700;color:var(--text-secondary)}
.folder-item{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;transition:background var(--transition);font-size:0.85rem;color:var(--text-secondary)}
.folder-item:hover{background:var(--bg-subtle);color:var(--text-primary)}
.folder-item.active{background:rgba(56,163,173,0.08);color:var(--teal-500);font-weight:600}
.folder-item__icon{color:var(--amber-500)}
.folder-item__count{margin-left:auto;font-size:0.7rem;background:var(--border);border-radius:var(--radius-full);padding:1px 7px;color:var(--text-muted)}
.file-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition)}
.file-item:hover{background:var(--bg-subtle)}
.file-item.active{background:rgba(56,163,173,0.06)}
.file-item__icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.8rem;font-weight:700}
.file-icon--pdf{background:#fee2e2;color:#dc2626}
.file-icon--xlsx{background:#dcfce7;color:#15803d}
.file-icon--docx{background:#dbeafe;color:#1d4ed8}
.file-item__info{flex:1;min-width:0}
.file-item__name{font-size:0.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-item__meta{font-size:0.72rem;color:var(--text-muted);margin-top:1px}
.doc-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-muted)}
.doc-preview--active{align-items:stretch;justify-content:flex-start;text-align:left}
.doc-preview-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}

/* ── INVOICING ──────────────────────────────────────────────── */
.invoice-total-row{font-size:1.5rem;font-weight:800;letter-spacing:-0.04em;color:var(--text-primary)}

/* ── PRACTICE ───────────────────────────────────────────────── */
.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.staff-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:12px;transition:all var(--transition)}
.staff-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.staff-card__top{display:flex;align-items:center;gap:12px}
.staff-card__name{font-weight:700;color:var(--text-primary);font-size:0.9rem}
.staff-card__role{font-size:0.75rem;color:var(--text-muted)}
.staff-card__stats{display:flex;gap:16px;padding-top:12px;border-top:1px solid var(--border)}
.staff-stat{flex:1}
.staff-stat__val{font-size:1rem;font-weight:700;color:var(--text-primary)}
.staff-stat__lbl{font-size:0.7rem;color:var(--text-muted)}

/* Kanban */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:start}
.kanban-col{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px}
.kanban-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding:0 4px}
.kanban-col-title{font-size:0.78rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--text-muted)}
.kanban-count{font-size:0.72rem;font-weight:700;background:var(--border);border-radius:var(--radius-full);padding:1px 8px;color:var(--text-muted)}
.kanban-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;margin-bottom:8px;cursor:grab;transition:all var(--transition)}
.kanban-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.kanban-card:last-child{margin-bottom:0}
.kanban-card__title{font-size:0.83rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}
.kanban-card__meta{font-size:0.72rem;color:var(--text-muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* Deadlines */
.deadline-full-list{display:flex;flex-direction:column;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.deadline-full-item{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background var(--transition)}
.deadline-full-item:hover{background:var(--bg-subtle)}
.deadline-full-item:last-child{border-bottom:none}
.deadline-full-date{min-width:80px;text-align:center;padding:6px 10px;border-radius:var(--radius-md);background:var(--bg-subtle)}
.deadline-full-date__day{font-size:1.2rem;font-weight:800;line-height:1;color:var(--text-primary)}
.deadline-full-date__month{font-size:0.65rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-muted)}
.deadline-full-date--urgent{background:rgba(239,68,68,0.08)}
.deadline-full-date--urgent .deadline-full-date__day{color:var(--red-500)}

/* ── SETTINGS ───────────────────────────────────────────────── */
.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}
.settings-nav{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.settings-nav-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:0.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-left:3px solid transparent}
.settings-nav-item:hover{background:var(--bg-subtle);color:var(--text-primary)}
.settings-nav-item.active{background:rgba(56,163,173,0.06);color:var(--teal-500);border-left-color:var(--teal-500);font-weight:600}
.settings-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.settings-panel-title{font-size:1.05rem;font-weight:800;letter-spacing:-0.02em;color:var(--text-primary);margin-bottom:4px}
.settings-panel-desc{font-size:0.83rem;color:var(--text-muted);margin-bottom:24px}
.settings-section{margin-bottom:24px}
.settings-section-title{font-size:0.78rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.integration-card-sm{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;transition:all var(--transition)}
.integration-card-sm:hover{border-color:var(--border-strong)}
.integration-logo-sm{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:700;color:#fff;flex-shrink:0}
.integration-info{flex:1}
.integration-name{font-size:0.87rem;font-weight:700;color:var(--text-primary)}
.integration-desc{font-size:0.75rem;color:var(--text-muted)}
.toggle{position:relative;width:36px;height:20px;cursor:pointer}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:var(--radius-full);transition:background 0.2s}
.toggle-slider::before{content:'';position:absolute;width:14px;height:14px;left:3px;top:3px;border-radius:50%;background:#fff;transition:transform 0.2s;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.toggle input:checked+.toggle-slider{background:var(--teal-500)}
.toggle input:checked+.toggle-slider::before{transform:translateX(16px)}

/* ── GRADIENT TEXT ──────────────────────────────────────────── */
.gradient-text{background:linear-gradient(135deg,var(--teal-500),var(--blue-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── UTILITY ────────────────────────────────────────────────── */
.text-muted{color:var(--text-muted)}
.text-sm{font-size:0.82rem}
.text-xs{font-size:0.72rem}
.fw-600{font-weight:600}
.fw-700{font-weight:700}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
.w-full{width:100%}
.hidden{display:none!important}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .dashboard-grid{grid-template-columns:1fr}
  .dashboard-col-2,.dashboard-col-1{grid-column:span 1}
  .kanban{grid-template-columns:repeat(2,1fr)}
  .bas-grid{grid-template-columns:1fr}
  .docs-layout{grid-template-columns:1fr}
  .settings-layout{grid-template-columns:1fr}
}
@media(max-width:768px){
  :root{--sidebar-w:0px}
  .sidebar{position:fixed;left:-240px;width:240px;z-index:300;transition:left var(--transition);box-shadow:var(--shadow-2xl)}
  .sidebar.open{left:0}
  .app-main{padding:16px}
  .stat-grid{grid-template-columns:1fr 1fr;gap:12px}
  .login-page{grid-template-columns:1fr}
  .login-left{display:none}
  .kanban{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .staff-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr}
  .page-header{flex-direction:column;align-items:stretch}
  .table-toolbar{flex-direction:column;align-items:stretch}
  .table-search{max-width:100%}
}
