/* =============================================
   Rankaia Growth Hub — Design System v3.0
   Coursie-Style: White / Indigo Clean Theme
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800;900&display=swap');

/* ── Tokens ── */
:root {
  --primary:       #6366F1;
  --primary-2:     #7C3AED;
  --primary-light: #EEF2FF;
  --primary-dark:  #4F46E5;
  --accent:        #8B5CF6;

  --bg:     #F3F4F8;
  --card:   #FFFFFF;
  --border: #E5E7EB;
  --text:   #111827;
  --muted:  #9CA3AF;
  --soft:   #F9FAFB;
  --sidebar:#FFFFFF;

  --good:   #10B981;
  --warn:   #F59E0B;
  --bad:    #EF4444;
  --info:   #3B82F6;

  --shadow-xs: 0 1px 2px rgba(0,0,0,.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
  --shadow:    0 4px 12px rgba(0,0,0,.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.08);

  --sidebar-w: 220px;
  --radius-sm: 8px;
  --radius:    12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body {
  font-family: 'Cairo', Tahoma, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  direction: rtl;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--primary); text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ══════════════════════════════════════════
   APP SHELL
   Fixed sidebar + margin-offset main (no grid — avoids double offset)
   ══════════════════════════════════════════ */
.app {
  display: block;
  min-height: 100vh;
}

/* ══════════════════════════════════════════
   SIDEBAR — White flat with border
   ══════════════════════════════════════════ */
.side {
  background: var(--sidebar);
  border-left: 1px solid var(--border);
  width: var(--sidebar-w);
  position: fixed;
  top: 0; right: 0; bottom: 0;
  display: flex;
  flex-direction: column;
  z-index: 40;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.side::-webkit-scrollbar { width: 3px; }
.side::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* Brand */
.brand {
  padding: 18px 16px 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 60px;
}
.brand-logo { max-width: 120px; max-height: 36px; object-fit: contain; }
.mark {
  width: 34px; height: 34px; flex: 0 0 34px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff;
  display: grid; place-items: center;
  font-weight: 900; font-size: 14px;
}
.brand h1 { font-size: 17px; font-weight: 900; color: var(--text); }
.brand p  { font-size: 10px; color: var(--muted); margin-top: 1px; }

/* Nav groups */
.nav { flex: 1; padding: 4px 0 8px; }
.nav-group { margin-bottom: 4px; }
.nav-group-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 12px 16px 5px;
  display: block;
}
.nav button {
  width: 100%;
  border: none;
  background: transparent;
  text-align: right;
  padding: 9px 16px 9px 12px;
  border-right: 3px solid transparent;
  color: var(--muted);
  font-weight: 600;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all .15s;
  cursor: pointer;
}
.nav button:hover { background: var(--soft); color: var(--text); }
.nav button.active {
  background: var(--primary-light);
  color: var(--primary);
  font-weight: 700;
  border-right-color: var(--primary);
}
.nav button .ui-icon { width: 16px; height: 16px; flex: 0 0 auto; }
.nav button:hover .ui-icon { color: var(--text); }
.nav button.active .ui-icon { color: var(--primary); }

/* Sidebar app-promo card */
.side-promo {
  margin: 8px 12px 14px;
  background: linear-gradient(135deg, #312E81, #4F46E5);
  border-radius: var(--radius-lg);
  padding: 16px 14px;
  color: #fff;
  flex-shrink: 0;
}
.side-promo small { font-size: 10px; color: rgba(255,255,255,.6); display: block; margin-bottom: 6px; }
.side-promo h4 { font-size: 13px; font-weight: 800; margin-bottom: 4px; }
.side-promo p { font-size: 11px; color: rgba(255,255,255,.7); margin-bottom: 12px; line-height: 1.5; }
.side-promo .btn-promo {
  width: 100%; padding: 8px; border: none; border-radius: 8px;
  background: #fff; color: var(--primary-dark); font: inherit; font-size: 12px; font-weight: 800;
  cursor: pointer; transition: opacity .15s;
}
.side-promo .btn-promo:hover { opacity: .9; }

/* ── Main Content ── */
.main {
  margin-right: var(--sidebar-w);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ══════════════════════════════════════════
   TOPBAR — White card style
   ══════════════════════════════════════════ */
.topbar {
  position: sticky; top: 0; z-index: 30;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  box-shadow: var(--shadow-xs);
}
.topbar-left { display: flex; align-items: center; gap: 12px; flex: 1; }
.topbar-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

/* Search */
.topbar-search {
  display: flex; align-items: center; gap: 8px;
  background: var(--soft);
  border: 1.5px solid var(--border);
  border-radius: 999px;
  padding: 8px 16px;
  max-width: 300px; flex: 1;
  transition: border-color .15s, box-shadow .15s;
}
.topbar-search:focus-within {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(99,102,241,.12);
}
.topbar-search input {
  border: none; background: transparent; font: inherit;
  font-size: 13px; color: var(--text); flex: 1; outline: none;
}
.topbar-search input::placeholder { color: var(--muted); }
.topbar-search .ui-icon { color: var(--muted); width: 15px; height: 15px; flex: 0 0 auto; }

/* Icon buttons */
.topbar-icon-btn {
  width: 36px; height: 36px;
  border: 1.5px solid var(--border);
  background: var(--card);
  color: var(--muted);
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  transition: all .15s; position: relative;
}
.topbar-icon-btn:hover { color: var(--primary); border-color: var(--primary-light); background: var(--primary-light); }
.topbar-icon-btn .notif-dot {
  position: absolute; top: 6px; right: 6px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--bad); border: 2px solid #fff;
}

/* User profile in topbar */
.topbar-user {
  display: flex; align-items: center; gap: 9px;
  padding: 5px 10px 5px 8px;
  border: 1.5px solid var(--border);
  border-radius: 999px;
  background: var(--card);
  cursor: pointer;
  transition: all .15s;
  position: relative;
}
.topbar-user:hover { border-color: var(--primary-light); background: var(--primary-light); }
.topbar-user-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color: #fff; display: grid; place-items: center;
  font-size: 12px; font-weight: 900; flex: 0 0 28px; overflow: hidden;
}
.topbar-user-avatar img { width: 100%; height: 100%; object-fit: cover; }
.topbar-user-name { font-size: 13px; font-weight: 700; color: var(--text); white-space: nowrap; }
.topbar-user-role { font-size: 10px; color: var(--muted); }
.topbar-user-chevron { font-size: 11px; color: var(--muted); margin-right: 2px; }
.user-menu-wrap { position: relative; display: flex; align-items: center; gap: 4px; }
.topbar-user-caret {
  width: 30px; height: 30px; flex: 0 0 30px;
  border: 1.5px solid var(--border); background: var(--card);
  border-radius: 999px; color: var(--muted); font-size: 11px;
  display: grid; place-items: center; cursor: pointer; transition: all .15s;
}
.topbar-user-caret:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-light); }

/* User dropdown */
.user-menu {
  display: none;
  position: absolute; top: calc(100% + 8px); left: 0;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow-lg);
  min-width: 200px; z-index: 300; overflow: hidden;
}
.user-menu.show { display: block; }
.user-menu button {
  width: 100%; text-align: right; padding: 10px 14px;
  border: none; background: transparent; font: inherit;
  font-size: 13px; font-weight: 600; color: var(--text);
  display: flex; align-items: center; gap: 8px; cursor: pointer;
  transition: background .12s;
}
.user-menu button:hover { background: var(--soft); }
.user-menu button .ui-icon { color: var(--muted); }
.user-menu-wrap { position: relative; }

/* ── Page Header ── */
.page-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px; margin-bottom: 20px; flex-wrap: wrap;
}
.page-header-title h1 { font-size: 22px; font-weight: 900; color: var(--text); margin: 0; }
.page-header-title p  { font-size: 13px; color: var(--muted); margin-top: 4px; }
.page-header-actions  { display: flex; gap: 10px; align-items: center; }

/* ── View / Content ── */
.view-wrap { padding: 22px 24px; flex: 1; }

/* ══════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════ */
.btn {
  border: none; border-radius: var(--radius-sm);
  background: var(--primary);
  color: #fff; padding: 9px 18px;
  font: inherit; font-size: 13px; font-weight: 700;
  cursor: pointer; display: inline-flex; align-items: center;
  gap: 6px; transition: all .15s; white-space: nowrap;
  box-shadow: 0 2px 8px rgba(99,102,241,.25);
}
.btn:hover { background: var(--primary-dark); box-shadow: 0 4px 14px rgba(99,102,241,.35); }
.btn.alt {
  background: var(--card); color: var(--text);
  border: 1.5px solid var(--border); box-shadow: var(--shadow-xs);
}
.btn.alt:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-light); }
.btn.danger { background: var(--bad); box-shadow: none; }
.btn.danger:hover { background: #DC2626; }
.btn.mini { padding: 6px 12px; font-size: 12px; border-radius: 7px; box-shadow: none; }
.btn.full { width: 100%; justify-content: center; }
.btn .ui-icon { width: 14px; height: 14px; }

/* ══════════════════════════════════════════
   CARDS
   ══════════════════════════════════════════ */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
}

/* ── Metric cards ── */
.metric { padding: 18px 20px; }
.metric small { font-size: 12px; font-weight: 600; color: var(--muted); display: block; }
.metric b {
  font-size: 28px; font-weight: 900; display: block;
  margin: 6px 0 4px; font-variant-numeric: tabular-nums;
  color: var(--text); line-height: 1;
}
.metric span { font-size: 12px; color: var(--muted); }
.metric.accent {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-2) 100%);
  border-color: transparent; color: #fff;
}
.metric.accent small, .metric.accent span { color: rgba(255,255,255,.7); }
.metric.accent b { color: #fff; }

/* Featured metric card (like Coursie first card) */
.metric-feat {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-2) 100%);
  border-color: transparent;
  box-shadow: 0 8px 24px rgba(99,102,241,.3);
}
.metric-feat .metric-title { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.8); }
.metric-feat .metric-value { font-size: 40px; font-weight: 900; color: #fff; font-variant-numeric: tabular-nums; margin: 10px 0 8px; line-height: 1; }
.metric-feat .metric-sub { font-size: 12px; color: rgba(255,255,255,.65); }
.metric-feat .metric-arrow { background: rgba(255,255,255,.2); color: #fff; }

/* Regular metric cards (like Coursie 2-4) */
.metric-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 0;
  position: relative;
}
.metric-title { font-size: 13px; font-weight: 600; color: var(--muted); }
.metric-value {
  font-size: 36px; font-weight: 900; color: var(--text);
  font-variant-numeric: tabular-nums; margin: 8px 0 6px; line-height: 1;
}
.metric-sub { font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 4px; }
.metric-arrow {
  position: absolute; top: 18px; left: 18px;
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--soft); color: var(--muted);
  border: 1.5px solid var(--border);
  display: grid; place-items: center; font-size: 14px;
  cursor: pointer; transition: all .15s;
}
.metric-arrow:hover { background: var(--primary-light); color: var(--primary); border-color: var(--primary); }
.metric-trend { display: flex; align-items: center; gap: 3px; }
.metric-trend-icon { font-size: 13px; }
.metric-trend.up   { color: var(--good); }
.metric-trend.down { color: var(--bad); }

/* ── Dashboard grid classes ── */
.dash-metrics { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 16px; margin-bottom: 20px; }
.dash-stats-row { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 14px; }
.dash-row { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.dash-row-3 { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 16px; margin-bottom: 16px; }

/* ── Bar chart (Coursie bulbous style) ── */
.bar-chart-wrap { width: 100%; overflow: hidden; }
.bar-chart-svg { display: block; width: 100%; }
.chart-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.chart-header h3 { font-size: 14px; font-weight: 800; margin: 0; }
.chart-header p  { font-size: 12px; color: var(--muted); margin-top: 2px; }
.toggle-pills { display: flex; background: var(--soft); border: 1.5px solid var(--border); border-radius: 999px; padding: 3px; gap: 2px; }
.toggle-pill { border: none; background: transparent; border-radius: 999px; padding: 5px 12px; font: inherit; font-size: 12px; font-weight: 700; color: var(--muted); cursor: pointer; transition: all .15s; }
.toggle-pill.active { background: var(--primary); color: #fff; box-shadow: 0 2px 8px rgba(99,102,241,.3); }

/* ── Project / Task list items ── */
.project-list { display: flex; flex-direction: column; gap: 10px; }
.project-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--radius-sm); background: var(--soft); border: 1px solid var(--border); transition: all .15s; cursor: pointer; }
.project-item:hover { background: var(--primary-light); border-color: rgba(99,102,241,.2); }
.project-dot { width: 10px; height: 10px; border-radius: 50%; flex: 0 0 10px; }
.project-item-info { flex: 1; min-width: 0; }
.project-item-info h4 { font-size: 13px; font-weight: 700; margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.project-item-info p  { font-size: 11px; color: var(--muted); margin-top: 1px; }
.project-item-date { font-size: 11px; color: var(--muted); flex-shrink: 0; }

/* ── Team member rows ── */
.team-list { display: flex; flex-direction: column; gap: 10px; }
.team-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--radius-sm); background: var(--soft); border: 1px solid var(--border); }
.team-avatar { width: 34px; height: 34px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: #fff; display: grid; place-items: center; font-size: 12px; font-weight: 800; flex: 0 0 34px; overflow: hidden; }
.team-avatar img { width: 100%; height: 100%; object-fit: cover; }
.team-info { flex: 1; min-width: 0; }
.team-info h4 { font-size: 13px; font-weight: 700; margin: 0; }
.team-info p  { font-size: 11px; color: var(--muted); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Dark stat card (Time Tracker style) ── */
.stat-dark {
  background: linear-gradient(135deg, #1F2937, #111827);
  border-color: transparent;
  color: #fff;
}
.stat-dark h4 { font-size: 12px; font-weight: 700; color: rgba(255,255,255,.6); margin-bottom: 10px; }
.stat-dark .stat-num { font-size: 32px; font-weight: 900; font-variant-numeric: tabular-nums; letter-spacing: .04em; margin-bottom: 12px; }
.stat-dark .stat-actions { display: flex; gap: 8px; }
.stat-dark-btn {
  width: 36px; height: 36px; border-radius: 50%; border: none;
  display: grid; place-items: center; cursor: pointer; transition: opacity .15s;
}
.stat-dark-btn:hover { opacity: .85; }
.stat-dark-btn.pause { background: rgba(255,255,255,.15); color: #fff; }
.stat-dark-btn.stop  { background: var(--bad); color: #fff; }

/* ── Donut / Ring progress ── */
.ring-wrap { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 16px 0; }
.ring-wrap .ring-pct { font-size: 26px; font-weight: 900; color: var(--text); font-variant-numeric: tabular-nums; }
.ring-wrap .ring-sub { font-size: 12px; color: var(--muted); }
.ring-legend { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.ring-legend-item { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--muted); }
.ring-legend-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 8px; }

/* ── Notification / Meeting card ── */
.meeting-card { display: flex; flex-direction: column; justify-content: space-between; height: 100%; }
.meeting-card h3 { font-size: 16px; font-weight: 900; color: var(--primary); margin-bottom: 6px; }
.meeting-card .meeting-time { font-size: 12px; color: var(--muted); margin-bottom: 14px; }
.meeting-card .btn-meet {
  width: 100%; padding: 10px; border: none; border-radius: var(--radius-sm);
  background: var(--primary); color: #fff; font: inherit; font-size: 13px; font-weight: 800;
  cursor: pointer; transition: all .15s; display: flex; align-items: center; justify-content: center; gap: 6px;
  box-shadow: 0 4px 14px rgba(99,102,241,.3);
}
.meeting-card .btn-meet:hover { background: var(--primary-dark); }

/* ══════════════════════════════════════════
   GRID LAYOUTS
   ══════════════════════════════════════════ */
.grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 16px; margin-bottom: 20px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px; }
.grid-2 { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px; }
.split { display: grid; grid-template-columns: 1.4fr 1fr; gap: 16px; }
.span-2 { grid-column: 1/-1; }

/* Section Head */
.section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.section-head h3 { font-size: 14px; font-weight: 800; color: var(--text); margin: 0; }
.section-head p  { font-size: 11px; color: var(--muted); margin-top: 2px; }
.section-title { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.section-title h3 { font-size: 14px; font-weight: 700; margin: 0; }
.section-title p  { font-size: 11px; color: var(--muted); margin-top: 2px; }
.panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.panel-head h3 { font-size: 14px; font-weight: 700; margin: 0; }
.panel-head p { font-size: 11px; color: var(--muted); margin-top: 2px; }

/* ══════════════════════════════════════════
   TABLES
   ══════════════════════════════════════════ */
.table-wrap { width: 100%; overflow-x: auto; border-radius: var(--radius); border: 1px solid var(--border); }
.table { width: 100%; border-collapse: collapse; font-size: 13px; }
.table th { padding: 10px 14px; background: var(--soft); color: var(--muted); font-weight: 700; text-align: right; font-size: 12px; border-bottom: 1px solid var(--border); white-space: nowrap; }
.table td { padding: 12px 14px; border-bottom: 1px solid var(--border); text-align: right; color: var(--text); vertical-align: middle; }
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr:hover td { background: var(--soft); }

/* ══════════════════════════════════════════
   STATUS BADGES
   ══════════════════════════════════════════ */
.status {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 700; border: 1px solid transparent;
  white-space: nowrap;
}
.status-active,.status-paid,.status-done,.status-income,.status-client_payment,.status-project_payment {
  background: #ECFDF5; color: #065F46; border-color: #A7F3D0;
}
.status-in_progress { background: var(--primary-light); color: var(--primary); border-color: rgba(99,102,241,.2); }
.status-todo        { background: var(--soft); color: var(--muted); border-color: var(--border); }
.status-waiting,.status-scheduled,.status-partial {
  background: #FFFBEB; color: #92400E; border-color: #FDE68A;
}
.status-cancelled,.status-expired,.status-unpaid,.status-bad {
  background: #FEF2F2; color: #991B1B; border-color: #FECACA;
}
.status-lead,.status-paused,.status-info   { background: #EFF6FF; color: #1D4ED8; border-color: #BFDBFE; }
.status-saving      { background: #F5F3FF; color: #5B21B6; border-color: #DDD6FE; }
.status-admin,.status-manager { background: #FAF5FF; color: #7C3AED; border-color: #E9D5FF; }
.status-staff       { background: var(--primary-light); color: var(--primary); border-color: rgba(99,102,241,.2); }
.status-client      { background: #ECFDF5; color: #065F46; border-color: #A7F3D0; }
.status-warning     { background: #FFFBEB; color: #92400E; border-color: #FDE68A; }
.status-success     { background: #ECFDF5; color: #065F46; border-color: #A7F3D0; }
.status-danger      { background: #FEF2F2; color: #991B1B; border-color: #FECACA; }
.status-expense,.status-debt { background: #FEF2F2; color: #991B1B; border-color: #FECACA; }
.status-subscription,.status-tool_renewal,.status-domain_renewal {
  background: var(--primary-light); color: var(--primary); border-color: rgba(99,102,241,.2);
}

/* ══════════════════════════════════════════
   FILTERS / TOOLBAR
   ══════════════════════════════════════════ */
.toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.toolbar input,.filters input,.filters select,
.strong-filters input,.strong-filters select {
  padding: 8px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  background: var(--card); font: inherit; font-size: 13px; color: var(--text);
  transition: border-color .15s, box-shadow .15s;
}
.toolbar input:focus,.filters input:focus,.filters select:focus,
.strong-filters input:focus,.strong-filters select:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(99,102,241,.1);
}
.toolbar input { flex: 1; min-width: 200px; }
.filters,.strong-filters { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin-bottom: 16px; }
.strong-filters input,.strong-filters select { flex: 1; min-width: 160px; }

/* ══════════════════════════════════════════
   MODAL
   ══════════════════════════════════════════ */
.modal { position: fixed; inset: 0; background: rgba(17,24,39,.4); display: none; align-items: center; justify-content: center; padding: 20px; z-index: 200; }
.modal.show { display: flex; }
.modal-box {
  width: min(760px,100%); max-height: 90vh; overflow-y: auto;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); padding: 24px;
}
.modal-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.modal-head h3 { font-size: 16px; font-weight: 800; margin: 0; }

/* ══════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════ */
.form { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.form.one { grid-template-columns: 1fr; }
.form label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; font-weight: 600; color: var(--muted); }
.form input,.form select,.form textarea {
  width: 100%; padding: 9px 12px; border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); background: var(--card);
  font: inherit; font-size: 13px; color: var(--text);
  transition: border-color .15s, box-shadow .15s;
}
.form input:focus,.form select:focus,.form textarea:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(99,102,241,.1);
}
.form textarea { grid-column: 1/-1; min-height: 88px; resize: vertical; }
.full { grid-column: 1/-1; }
.pass-field { display: flex; gap: 8px; }
.pass-field input { flex: 1; }
.pass-field button { width: 38px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); color: var(--muted); display: grid; place-items: center; }
.form-hint { font-size: 11px; color: var(--muted); margin-top: 2px; grid-column: 1/-1; }
.error { color: var(--bad); font-size: 12px; }
.success { color: var(--good); font-size: 12px; }
.hint { color: var(--muted); font-size: 12px; }

/* ══════════════════════════════════════════
   LOGIN
   ══════════════════════════════════════════ */
.login-page {
  min-height: 100vh; display: flex; align-items: center; justify-content: flex-end;
  background: linear-gradient(135deg, #1E1B4B 0%, #312E81 40%, #4F46E5 100%);
  position: relative; overflow: hidden;
}
.login-bg-shapes { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.login-bg-shapes span { position: absolute; border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,.06), transparent 70%); }
.login-bg-shapes span:nth-child(1) { width: 500px; height: 500px; top: -150px; left: 5%; }
.login-bg-shapes span:nth-child(2) { width: 300px; height: 300px; bottom: -80px; left: 25%; }
.login-bg-shapes span:nth-child(3) { width: 200px; height: 200px; top: 50%; right: 8%; }
.login-panel { width: 420px; min-height: 100vh; background: var(--card); display: flex; flex-direction: column; justify-content: center; padding: 48px 40px; }
.login-brand { margin-bottom: 32px; }
.login-brand .mark-lg { width: 50px; height: 50px; border-radius: 14px; background: linear-gradient(135deg,var(--primary),var(--primary-2)); color: #fff; display: grid; place-items: center; font-size: 22px; font-weight: 900; margin-bottom: 18px; box-shadow: 0 8px 24px rgba(99,102,241,.3); }
.login-brand h1 { font-size: 24px; font-weight: 900; color: var(--text); margin-bottom: 6px; }
.login-brand p { font-size: 13px; color: var(--muted); line-height: 1.6; }
.login-form { display: flex; flex-direction: column; gap: 14px; }
.login-form label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; font-weight: 700; color: var(--text); }
.login-form input { padding: 11px 14px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 14px; color: var(--text); background: var(--card); transition: border-color .15s, box-shadow .15s; }
.login-form input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(99,102,241,.1); }
.login-submit { margin-top: 6px; padding: 13px; font-size: 14px; font-weight: 800; border-radius: var(--radius-sm); }
.login-footer { margin-top: 20px; font-size: 12px; color: var(--muted); text-align: center; }

/* ══════════════════════════════════════════
   MISC
   ══════════════════════════════════════════ */
.pre { white-space: pre-wrap; line-height: 1.8; font-size: 13px; }
.muted { color: var(--muted); font-size: 13px; }
.num-en { font-variant-numeric: tabular-nums; }
.ui-icon { width: 16px; height: 16px; display: inline-block; vertical-align: middle; flex: 0 0 auto; }
.icon-btn { width: 34px; height: 34px; border: 1.5px solid var(--border); background: var(--card); color: var(--muted); border-radius: var(--radius-sm); display: grid; place-items: center; cursor: pointer; transition: all .15s; }
.icon-btn:hover { color: var(--primary); background: var(--primary-light); border-color: rgba(99,102,241,.2); }
.row-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.link { border: none; background: transparent; color: var(--primary); font-weight: 700; cursor: pointer; font: inherit; font-size: 13px; }
.link:hover { text-decoration: underline; }
.link.strong { font-size: 14px; }
.kv { display: grid; grid-template-columns: 140px 1fr; gap: 10px; font-size: 13px; }
.kv b { color: var(--muted); font-weight: 600; }
.kv.compact { grid-template-columns: 100px 1fr; }
.detail-head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.detail-head h2 { font-size: 20px; font-weight: 900; margin: 0; }

/* Progress bar */
.mini-progress {
  position: relative; min-width: 90px; height: 22px;
  background: var(--primary-light); border-radius: 999px;
  overflow: hidden; display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; color: var(--primary);
  border: 1px solid rgba(99,102,241,.15);
}
.mini-progress i { position: absolute; inset: 0 auto 0 0; background: linear-gradient(90deg,var(--primary),var(--primary-2)); border-radius: 999px; opacity: .28; }
.mini-progress span { position: relative; }

/* Bars */
.bars { display: grid; gap: 10px; }
.bar-row { display: grid; grid-template-columns: 90px 1fr 36px; gap: 10px; align-items: center; font-size: 12px; }
.bar { height: 7px; background: var(--primary-light); border-radius: 999px; overflow: hidden; }
.bar i { display: block; height: 100%; background: linear-gradient(90deg,var(--primary),var(--primary-2)); border-radius: 999px; }

/* Home list */
.home-list { display: flex; flex-direction: column; gap: 8px; }
.home-list-card { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); transition: background .15s; }
.home-list-card:hover { background: var(--primary-light); }
.home-list-card p { font-size: 11px; color: var(--muted); margin-top: 1px; }
.home-list-badges { display: flex; gap: 5px; flex-shrink: 0; }
.home-date-card { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); }
.home-date { text-align: center; flex: 0 0 38px; }
.home-date b { display: block; font-size: 16px; font-weight: 900; color: var(--primary); font-variant-numeric: tabular-nums; }
.home-date span { font-size: 10px; color: var(--muted); }
.empty-soft { font-size: 12px; color: var(--muted); padding: 10px 0; text-align: center; }

/* Home hero */
.home-hero { padding: 20px 22px; margin-bottom: 0; background: linear-gradient(135deg,var(--primary),var(--primary-2)); border-color: transparent; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.home-hero-copy small { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .05em; }
.home-hero-copy h3 { font-size: 17px; font-weight: 900; margin: 5px 0 7px; color: #fff; }
.home-hero-copy p { font-size: 12px; color: rgba(255,255,255,.7); line-height: 1.7; }
.home-hero-metrics { display: flex; gap: 20px; flex-shrink: 0; }
.home-hero-metrics div { text-align: center; }
.home-hero-metrics span { display: block; font-size: 10px; color: rgba(255,255,255,.5); margin-bottom: 4px; }
.home-hero-metrics b { font-size: 20px; font-weight: 900; color: #fff; font-variant-numeric: tabular-nums; }
.home-layout { display: grid; grid-template-columns: 1fr 320px; gap: 16px; }
.home-main-col { display: flex; flex-direction: column; gap: 16px; }
.home-side-col { display: flex; flex-direction: column; gap: 16px; }
.quick-links h3 { font-size: 13px; font-weight: 800; margin-bottom: 10px; }
.quick-links div { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.quick-links div button { border: 1.5px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); color: var(--text); font: inherit; font-size: 12px; font-weight: 600; padding: 8px; cursor: pointer; transition: all .15s; }
.quick-links div button:hover { background: var(--primary-light); border-color: var(--primary); color: var(--primary); }

/* Item cards */
.card-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; margin-bottom: 18px; }
.item-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px; display: flex; flex-direction: column; gap: 12px; box-shadow: var(--shadow-sm); transition: all .2s; }
.item-card:hover { box-shadow: var(--shadow); border-color: rgba(99,102,241,.2); transform: translateY(-1px); }
.item-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.item-card-title { font-size: 14px; font-weight: 700; color: var(--primary); padding: 0; background: none; border: none; text-align: right; cursor: pointer; }
.item-card-title:hover { text-decoration: underline; }
.item-card-sub { font-size: 11px; color: var(--muted); margin-top: 3px; }
.item-card-meta { display: flex; flex-direction: column; gap: 5px; }
.item-card-meta span { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--muted); }
.item-card-meta .ui-icon { color: var(--muted); width: 12px; height: 12px; }
.item-card-stats { display: grid; grid-template-columns: repeat(2,1fr); background: var(--soft); border-radius: var(--radius-sm); padding: 10px; gap: 5px 12px; border: 1px solid var(--border); }
.item-card-stats b { font-size: 16px; font-weight: 900; color: var(--primary); font-variant-numeric: tabular-nums; }
.item-card-stats span { font-size: 11px; color: var(--muted); }
.item-card-actions { display: flex; gap: 7px; }
.item-card-actions .btn { flex: 1; justify-content: center; box-shadow: none; }

/* Finance */
.finance-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px; box-shadow: var(--shadow-sm); transition: all .2s; }
.finance-card:hover { box-shadow: var(--shadow); }
.finance-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.finance-card-head strong { font-size: 18px; font-weight: 900; color: var(--text); font-variant-numeric: tabular-nums; }
.finance-card h4 { font-size: 13px; font-weight: 700; margin-bottom: 4px; }
.finance-card p { font-size: 11px; color: var(--muted); margin-bottom: 8px; }
.finance-card-meta { display: flex; flex-wrap: wrap; gap: 5px; align-items: center; }
.finance-meta { display: flex; flex-wrap: wrap; gap: 5px; align-items: center; margin-top: 8px; }
.finance-cards-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; margin-bottom: 16px; }
.finance-summary-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 18px; }
.finance-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin: 14px 0; }
.mini-metric { padding: 16px 18px; }
.mini-metric small { display: block; font-size: 11px; color: var(--muted); font-weight: 600; margin-bottom: 4px; }
.mini-metric b { display: block; font-size: 20px; font-weight: 900; font-variant-numeric: tabular-nums; }
.mini-metric span { font-size: 11px; color: var(--muted); }
.finance-type-summary { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.finance-type-summary .status { cursor: pointer; gap: 6px; transition: opacity .15s; }
.finance-type-summary .status:hover { opacity: .75; }

/* Workspace */
.workspace-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.workspace-head h2 { font-size: 20px; font-weight: 900; margin: 0; }
.workspace-head p { font-size: 12px; color: var(--muted); margin-top: 3px; }
.workspace-hero { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 14px; margin-bottom: 16px; }
.project-hero { background: linear-gradient(135deg,var(--primary),var(--primary-2)); border-color: transparent; color: #fff; }
.project-hero small,.project-hero p { color: rgba(255,255,255,.65); }
.project-hero b { font-size: 28px; font-weight: 900; display: block; margin: 5px 0 4px; font-variant-numeric: tabular-nums; }
.workspace-grid { display: grid; grid-template-columns: 1.3fr .7fr; gap: 14px; }
.kanban-lite { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
.kanban-col { background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; min-height: 120px; }
.kanban-col h4 { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 12px; font-weight: 700; color: var(--muted); margin-bottom: 10px; }
.kanban-col h4 span { background: var(--primary-light); border-radius: 999px; padding: 2px 7px; font-size: 11px; color: var(--primary); }
.mini-task { display: block; width: 100%; text-align: right; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 9px 10px; margin-bottom: 7px; cursor: pointer; transition: all .15s; color: var(--text); }
.mini-task:hover { box-shadow: var(--shadow-sm); border-color: rgba(99,102,241,.2); }
.mini-task b { display: block; font-size: 12px; margin-bottom: 3px; }
.mini-task small { display: block; color: var(--muted); font-size: 11px; margin-bottom: 3px; }
.empty-mini { font-size: 12px; color: var(--muted); padding: 8px 0; text-align: center; }
.link-grid { display: grid; gap: 7px; }
.link-grid a { display: block; padding: 8px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); color: var(--primary); font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; transition: all .15s; }
.link-grid a:hover { background: var(--primary-light); }
.finance-mini { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 12px; }
.finance-mini div { background: var(--primary-light); border-radius: var(--radius-sm); padding: 10px; }
.finance-mini small { display: block; font-size: 11px; color: var(--muted); margin-bottom: 3px; }
.finance-mini b { font-size: 16px; font-weight: 900; font-variant-numeric: tabular-nums; color: var(--primary); }

/* Task Pro */
.task-pro-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 16px; }
.task-checklist,.task-comments { display: flex; flex-direction: column; gap: 8px; }
.task-check-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--card); font-size: 13px; }
.task-check-item input[type=checkbox] { width: 15px; height: 15px; accent-color: var(--primary); flex: 0 0 15px; }
.task-check-item.done b { text-decoration: line-through; opacity: .65; }
.task-comment { padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--card); }
.task-comment p { font-size: 13px; margin-bottom: 4px; }
.task-comment small { font-size: 11px; color: var(--muted); }
.task-quick-add { display: flex; gap: 8px; margin-top: 10px; }
.task-quick-add input { flex: 1; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; }
.task-progress-control { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
.task-progress-control input[type=range] { flex: 1; accent-color: var(--primary); }
.check-dot { width: 14px; height: 14px; border-radius: 50%; border: 2px solid var(--border); display: inline-block; flex: 0 0 14px; }
.check-dot.on { background: var(--good); border-color: var(--good); }
.subtask { display: grid; grid-template-columns: 18px 1fr auto; gap: 8px; align-items: center; padding: 10px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--card); font-size: 13px; margin-bottom: 7px; }

/* Chat */
.project-chat-messages { display: flex; flex-direction: column; gap: 8px; min-height: 120px; max-height: 280px; overflow-y: auto; margin-bottom: 12px; }
.chat-message { padding: 9px 12px; border-radius: var(--radius-sm); border: 1px solid var(--border); background: var(--soft); font-size: 13px; }
.chat-message.mine { background: var(--primary-light); margin-right: 16px; }
.chat-message b { font-size: 12px; font-weight: 700; color: var(--primary); }
.chat-message small { font-size: 11px; color: var(--muted); display: block; margin-bottom: 3px; }
.project-chat-input { display: flex; gap: 8px; }
.project-chat-input input { flex: 1; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; }

/* Settings */
.settings-pro-layout { display: grid; grid-template-columns: 220px 1fr; gap: 16px; }
.settings-tabs-card h3 { font-size: 14px; font-weight: 800; margin-bottom: 6px; }
.settings-tabs { display: flex; flex-direction: column; gap: 4px; margin-top: 12px; }
.settings-tabs button { width: 100%; text-align: right; padding: 9px 12px; border: none; background: transparent; color: var(--muted); font: inherit; font-size: 13px; font-weight: 600; border-radius: var(--radius-sm); cursor: pointer; display: flex; align-items: center; gap: 8px; transition: all .15s; }
.settings-tabs button:hover { background: var(--primary-light); color: var(--primary); }
.settings-tabs button.active { background: var(--primary-light); color: var(--primary); font-weight: 700; }
.settings-tab-panel { display: none; }
.settings-tab-panel.active { display: block; }
.settings-form .form-cluster { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; margin-bottom: 16px; }
.settings-form .form-cluster label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; font-weight: 600; color: var(--muted); }
.settings-form .form-cluster input,.settings-form .form-cluster select { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); background: var(--card); font: inherit; font-size: 13px; color: var(--text); }
.settings-section-title { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.settings-section-title .ui-icon { width: 20px; height: 20px; color: var(--primary); }
.settings-section-title h3 { font-size: 15px; font-weight: 800; margin: 0; }
.settings-section-title p { font-size: 12px; color: var(--muted); margin-top: 2px; }
.settings-actions-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.settings-upload-grid { display: grid; gap: 12px; }
.upload-card { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px; border: 2px dashed var(--border); border-radius: var(--radius); background: var(--soft); }
.upload-card h4 { font-size: 13px; font-weight: 700; margin-bottom: 4px; }
.upload-card p { font-size: 11px; color: var(--muted); }
.image-preview { width: 52px; height: 52px; border-radius: 12px; background: linear-gradient(135deg,var(--primary),var(--primary-2)); color: #fff; display: grid; place-items: center; font-size: 18px; font-weight: 900; overflow: hidden; flex: 0 0 52px; }
.image-preview img { width: 100%; height: 100%; object-fit: cover; }
.logo-preview { width: 130px; min-height: 50px; border-radius: var(--radius); background: var(--card); border: 1px solid var(--border); display: grid; place-items: center; padding: 8px; overflow: hidden; flex: 0 0 auto; }
.logo-preview img { max-width: 100%; max-height: 40px; object-fit: contain; }
.file-picker-modern { display: inline-block; margin-top: 5px; }
.file-picker-modern input[type=file] { display: none; }
.file-picker-modern span { display: inline-block; padding: 6px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font-size: 12px; font-weight: 600; color: var(--muted); background: var(--card); cursor: pointer; transition: all .15s; }
.file-picker-modern:hover span { background: var(--primary-light); border-color: var(--primary); color: var(--primary); }
.permission-notes { display: grid; gap: 10px; margin-bottom: 14px; }
.permission-notes div { display: flex; gap: 10px; font-size: 13px; align-items: flex-start; }
.permission-notes b { flex: 0 0 80px; color: var(--primary); }
.permission-notes span { color: var(--muted); }
.system-info-grid { display: grid; grid-template-columns: 120px 1fr; gap: 10px; font-size: 13px; }
.system-info-grid span { color: var(--muted); font-weight: 600; }
.changelog-card ul { padding-right: 16px; display: flex; flex-direction: column; gap: 6px; }
.changelog-card li { font-size: 13px; color: var(--muted); }
.data-tools { border-radius: var(--radius); background: var(--soft); padding: 14px; border: 1px solid var(--border); }
.data-tools h4 { font-size: 14px; font-weight: 700; margin-bottom: 6px; }

/* Profile */
.profile-single-wrap { max-width: 680px; }
.profile-pro-card { padding: 0; overflow: hidden; }
.profile-pro-cover { display: flex; align-items: center; gap: 14px; padding: 22px 24px; background: linear-gradient(135deg,var(--primary),var(--primary-2)); }
.profile-avatar-xl { width: 56px; height: 56px; border-radius: 50%; background: rgba(255,255,255,.2); border: 2px solid rgba(255,255,255,.3); display: grid; place-items: center; font-size: 20px; font-weight: 900; color: #fff; flex: 0 0 56px; overflow: hidden; }
.profile-avatar-xl img { width: 100%; height: 100%; object-fit: cover; }
.profile-pro-cover h3 { font-size: 16px; font-weight: 900; color: #fff; margin: 0; }
.profile-pro-cover p { font-size: 12px; color: rgba(255,255,255,.7); margin-top: 3px; }
.profile-badges { display: flex; gap: 5px; margin-top: 7px; }
.profile-pro-body { padding: 22px 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.profile-form-modern h4 { font-size: 13px; font-weight: 800; margin-bottom: 12px; }
.profile-form-modern label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; font-weight: 600; color: var(--muted); margin-bottom: 10px; }
.profile-form-modern input { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; color: var(--text); background: var(--card); }
.modern-file { display: block; margin-top: 4px; font-size: 13px; color: var(--muted); }

/* Notifications / Activity */
.notify-card { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 14px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 8px; transition: box-shadow .15s; }
.notify-card:hover { box-shadow: var(--shadow-sm); }
.notify-card.warning { border-right: 3px solid var(--warn); }
.notify-card.danger  { border-right: 3px solid var(--bad); }
.notify-card.info    { border-right: 3px solid var(--info); }
.notify-card.success { border-right: 3px solid var(--good); }
.notify-main h4 { font-size: 13px; font-weight: 700; margin: 3px 0 2px; }
.notify-main p { font-size: 12px; color: var(--muted); margin-bottom: 3px; }
.notify-main small { font-size: 11px; color: var(--muted); }
.notify-top { display: flex; align-items: center; gap: 6px; margin-bottom: 3px; }
.notify-kind { font-size: 11px; font-weight: 700; color: var(--muted); }
.activity-card { display: flex; gap: 10px; padding: 11px; border-radius: var(--radius-sm); border: 1px solid var(--border); background: var(--card); margin-bottom: 7px; }
.activity-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--primary); display: block; margin-top: 4px; flex: 0 0 8px; }
.activity-top { display: flex; align-items: center; gap: 7px; margin-bottom: 3px; }
.activity-top strong { font-size: 13px; font-weight: 700; }
.activity-body p { font-size: 12px; color: var(--text); margin-bottom: 2px; }
.activity-body small { font-size: 11px; color: var(--muted); }
.activity-type-card { display: flex; flex-direction: column; align-items: center; padding: 9px 12px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); min-width: 65px; }
.activity-type-card b { font-size: 16px; font-weight: 900; font-variant-numeric: tabular-nums; color: var(--primary); }
.activity-type-card span { font-size: 11px; color: var(--muted); }
.activity-types { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 14px; }

/* Calendar */
.calendar-month { margin-bottom: 14px; }
.calendar-month-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.calendar-month-head h3 { font-size: 13px; font-weight: 800; }
.calendar-month-head span { font-size: 11px; color: var(--primary); background: var(--primary-light); border-radius: 999px; padding: 2px 8px; }
.calendar-list { display: flex; flex-direction: column; gap: 7px; }
.calendar-card { display: grid; grid-template-columns: 110px 1fr auto; align-items: center; gap: 10px; padding: 10px 12px; background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius-sm); }
.date-chip b { font-size: 12px; font-weight: 800; color: var(--primary); display: block; font-variant-numeric: tabular-nums; }
.date-chip span { font-size: 11px; color: var(--muted); }
.calendar-content h4 { font-size: 12px; font-weight: 700; margin: 0 0 2px; }
.calendar-content p { font-size: 11px; color: var(--muted); }

/* Reports */
.report-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 16px; }
.executive-summary { display: grid; grid-template-columns: 1.4fr .6fr; gap: 14px; margin-bottom: 16px; }
.exec-box h4,.report-mini-list h4 { font-size: 13px; font-weight: 800; margin-bottom: 8px; }
.exec-box p { font-size: 13px; color: var(--muted); line-height: 1.8; }
.exec-points { display: flex; flex-direction: column; gap: 9px; }
.exec-points div { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.exec-points i { width: 7px; height: 7px; border-radius: 50%; background: var(--primary); flex: 0 0 7px; }
.client-report-badge { display: inline-flex; font-size: 11px; font-weight: 700; color: var(--primary); background: var(--primary-light); border-radius: 999px; padding: 2px 8px; margin-bottom: 8px; }
.report-split { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 16px; }
.report-card-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 9px; }
.report-card { background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 11px; }
.report-card h4 { font-size: 16px; font-weight: 900; margin: 5px 0 3px; font-variant-numeric: tabular-nums; }
.report-card p { font-size: 11px; color: var(--muted); }
.report-tables { display: grid; gap: 14px; margin-bottom: 16px; }
.report-builder-shell { display: flex; flex-direction: column; gap: 14px; }
.report-builder-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.report-builder-head h3 { font-size: 15px; font-weight: 800; margin: 0; }
.report-builder-head p { font-size: 12px; color: var(--muted); margin-top: 4px; }
.filters.pro { display: grid; grid-template-columns: repeat(4,1fr) auto; gap: 10px; align-items: end; }
.filters.pro label { display: flex; flex-direction: column; gap: 5px; font-size: 11px; font-weight: 700; color: var(--muted); }
.filters.pro input,.filters.pro select { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; background: var(--card); color: var(--text); }

/* More page */
.more-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.more-card { text-align: right; cursor: pointer; min-height: 110px; display: flex; flex-direction: column; gap: 8px; justify-content: center; padding: 16px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); transition: all .2s; box-shadow: var(--shadow-sm); }
.more-card:hover { box-shadow: var(--shadow); border-color: rgba(99,102,241,.2); transform: translateY(-1px); }
.more-card .ui-icon { width: 22px; height: 22px; color: var(--primary); }
.more-card b { font-size: 13px; font-weight: 800; }
.more-card span { font-size: 11px; color: var(--muted); line-height: 1.5; }

/* Loaders */
.page-loader { min-height: 180px; display: grid; place-items: center; text-align: center; padding: 30px; border-radius: var(--radius-xl); background: var(--card); border: 1px solid var(--border); box-shadow: var(--shadow-sm); }
.loader-ring { width: 36px; height: 36px; border-radius: 50%; border: 3px solid var(--border); border-top-color: var(--primary); animation: spin .8s linear infinite; margin-bottom: 12px; }
@keyframes spin { to { transform: rotate(360deg); } }
.page-loader h3 { font-size: 14px; font-weight: 700; margin: 0 0 4px; }
.page-loader p { font-size: 12px; color: var(--muted); }
.compact-loader { min-height: 110px; padding: 20px; }
.empty-state { display: grid; place-items: center; text-align: center; padding: 28px; min-height: 130px; border-radius: var(--radius-xl); background: var(--soft); border: 2px dashed var(--border); }
.empty-icon { width: 44px; height: 44px; border-radius: var(--radius); background: var(--primary-light); color: var(--primary); display: grid; place-items: center; margin-bottom: 10px; }
.empty-state h3 { font-size: 13px; font-weight: 800; margin: 0 0 4px; }
.empty-state p { font-size: 12px; color: var(--muted); }
.error-card { border-color: rgba(239,68,68,.2); background: #FFF5F5; }
.error-card h3 { color: var(--bad); font-size: 14px; margin-bottom: 6px; }

/* Misc page components */
.section-hero { margin-bottom: 18px; }
.section-hero h3 { font-size: 16px; font-weight: 900; margin-bottom: 6px; }
.section-hero p { font-size: 13px; color: var(--muted); line-height: 1.7; }
.template-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.invoice-sheet { padding: 14px; }
.invoice-sheet h2 { font-size: 17px; font-weight: 900; margin-bottom: 4px; }
.invoice-lines { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin-top: 14px; font-size: 13px; }
.presentation-preview { display: flex; flex-direction: column; gap: 10px; }
.cover-slide { background: linear-gradient(135deg,var(--primary),var(--primary-2)); color: #fff; padding: 18px; border-radius: var(--radius); }
.preview-slide { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); font-size: 12px; }
.slide-stack { display: flex; flex-direction: column; gap: 5px; }
.boot-error { max-width: 480px; margin: 60px auto; padding: 28px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); text-align: center; }
.boot-error h1 { font-size: 17px; margin-bottom: 10px; color: var(--bad); }
.boot-error p { font-size: 13px; color: var(--muted); margin-bottom: 10px; }
.boot-error code { display: block; background: var(--soft); border-radius: var(--radius-sm); padding: 8px 12px; font-size: 11px; color: var(--bad); margin-bottom: 12px; word-break: break-all; }
.health-strip { display: flex; gap: 5px; flex-wrap: wrap; justify-content: center; margin-top: 10px; }
.health-chip { font-size: 11px; font-weight: 700; background: var(--primary-light); border-radius: 999px; padding: 2px 9px; color: var(--primary); }
.mobile-nav { display: none; }
.mobile-brand-head { display: none; }
.form-grid { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; margin-bottom: 10px; }
.form-grid select { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; }
.user-form-pro label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; font-weight: 600; color: var(--muted); }
.user-form-pro select,.user-form-pro input { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; color: var(--text); background: var(--card); }
.desktop-only {}
.mb-16 { margin-bottom: 16px; }
.mt-4  { margin-top: 4px; }
.fw-800{ font-weight: 800; }
.fs-15 { font-size: 15px; }
.change { font-size: 11px; font-weight: 700; }
.change.pos { color: var(--good); }
.change.neg { color: var(--bad); }
.client-welcome { margin-bottom: 16px; border: 1px solid rgba(99,102,241,.15); background: var(--primary-light); }
.client-welcome h3 { font-size: 14px; font-weight: 800; color: var(--primary); margin-bottom: 4px; }
.client-welcome p { font-size: 12px; color: var(--muted); }
.client-portal-intro { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.client-lock { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: var(--primary); flex-shrink: 0; }

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */

/* 1400px: minor adjustments */
@media (max-width: 1400px) {
  .dash-metrics,.grid { grid-template-columns: repeat(2,1fr); }
  .dash-stats-row { grid-template-columns: repeat(2,1fr); }
  .workspace-hero { grid-template-columns: 1fr 1fr; }
  .report-kpis { grid-template-columns: repeat(2,1fr); }
  .finance-summary-grid,.finance-strip { grid-template-columns: repeat(2,1fr); }
  .dash-row { grid-template-columns: 1fr 1fr; }
  .dash-row-3 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 1150px) {
  .card-grid,.finance-cards-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .home-layout { grid-template-columns: 1fr; }
  .home-side-col { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
  .workspace-grid,.task-pro-grid,.settings-pro-layout { grid-template-columns: 1fr; }
  .executive-summary,.report-split,.template-layout,.split { grid-template-columns: 1fr; }
  .kanban-lite { grid-template-columns: repeat(2,1fr); }
  .dash-row,.dash-row-3 { grid-template-columns: 1fr; }
}

/* ── TABLET: Icon-only mini sidebar ── */
@media (min-width: 821px) and (max-width: 1150px) {
  :root { --sidebar-w: 64px; }
  .side { padding: 0; }
  .brand { padding: 16px 0; justify-content: center; border-bottom: 1px solid var(--border); margin-bottom: 6px; }
  .brand h1,.brand p { display: none; }
  .brand-logo { display: none; }
  .mark { margin: 0 auto; }
  .nav-group-label { display: none; }
  .nav-group { margin-bottom: 0; }
  .nav button { padding: 10px 0; justify-content: center; gap: 0; border-radius: 0; border-right-width: 3px; }
  .nav button span { display: none; }
  .nav button .ui-icon { width: 18px; height: 18px; }
  .nav button::after { content: attr(data-tip); position: absolute; right: calc(100% + 8px); top: 50%; transform: translateY(-50%); background: var(--text); color: #fff; padding: 5px 10px; border-radius: 8px; font-size: 12px; font-weight: 600; white-space: nowrap; opacity: 0; pointer-events: none; transition: opacity .15s; z-index: 200; }
  .nav button:hover::after { opacity: 1; }
  .side-promo { display: none; }
}

/* ── MOBILE ── */
@media (max-width: 820px) {
  :root { --sidebar-w: 0px; }
  .app { display: flex; flex-direction: column; min-height: 100dvh; }
  .side { display: none; }
  .main { flex: 1; display: flex; flex-direction: column; margin-right: 0; }
  .topbar { padding: 8px 14px; height: auto; min-height: 54px; }
  .topbar-search { max-width: none; }
  .view-wrap { padding: 14px 14px calc(84px + env(safe-area-inset-bottom)); flex: 1; }
  .page-header { margin-bottom: 16px; }
  .page-header-title h1 { font-size: 18px; }

  /* Bottom Nav */
  .mobile-nav {
    display: grid; grid-template-columns: repeat(5,1fr);
    position: fixed; bottom: calc(10px + env(safe-area-inset-bottom));
    right: 10px; left: 10px;
    background: rgba(255,255,255,.97); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
    border: 1.5px solid var(--border); border-radius: 22px;
    box-shadow: 0 8px 32px rgba(0,0,0,.1); padding: 5px 4px; gap: 2px; z-index: 100;
    overflow: hidden; height: 62px; align-content: start;
  }
  .mobile-nav button {
    border: none; background: transparent; color: var(--muted); border-radius: 16px;
    height: 52px; display: flex; flex-direction: column; align-items: center;
    justify-content: center; gap: 3px; font: inherit; font-size: 10px; font-weight: 700;
    transition: background .15s, color .15s; padding: 4px 2px; white-space: nowrap;
  }
  .mobile-nav button .ui-icon { width: 20px; height: 20px; }
  .mobile-nav button.active { background: var(--primary-light); color: var(--primary); }
  .mobile-nav button.active .ui-icon { color: var(--primary); }

  /* Dashboard */
  .dash-metrics { grid-template-columns: repeat(2,minmax(0,1fr)) !important; gap: 10px !important; margin-bottom: 14px !important; }
  .dash-stats-row { grid-template-columns: repeat(2,minmax(0,1fr)) !important; gap: 10px !important; }
  .home-metrics,.grid { grid-template-columns: repeat(2,1fr); gap: 10px; }
  .home-layout { grid-template-columns: 1fr; gap: 12px; }
  .home-side-col { display: flex; flex-direction: column; gap: 12px; }
  .dash-row,.dash-row-3 { grid-template-columns: 1fr; gap: 12px; }
  .metric-feat .metric-value { font-size: 30px; }
  .metric-value { font-size: 28px; }

  /* Cards */
  .card { padding: 14px; }
  .card-grid,.finance-cards-grid { grid-template-columns: 1fr; gap: 10px; }
  .item-card { padding: 14px; gap: 10px; }
  .item-card:hover { transform: none; }
  .more-card:hover { transform: none; }
  .kanban-lite { grid-template-columns: 1fr; gap: 10px; }
  .more-grid { grid-template-columns: repeat(2,1fr); gap: 10px; }
  .workspace-hero { grid-template-columns: 1fr 1fr; gap: 10px; }
  .workspace-grid,.task-pro-grid { grid-template-columns: 1fr; gap: 12px; }
  .report-kpis { grid-template-columns: 1fr 1fr; gap: 10px; }
  .finance-summary-grid,.finance-strip { grid-template-columns: 1fr 1fr; gap: 10px; }
  .table-wrap { border-radius: 12px; }
  .table { min-width: 600px; }
  .table th,.table td { padding: 10px 12px; font-size: 12px; }
  .form { grid-template-columns: 1fr; gap: 10px; }
  .form input,.form select,.form textarea { font-size: 16px; }
  .modal { align-items: flex-end; padding: 0; }
  .modal-box { width: 100%; max-height: 90dvh; border-radius: 24px 24px 0 0; padding: 20px 16px; }
  .settings-pro-layout { grid-template-columns: 1fr; }
  .profile-pro-body { grid-template-columns: 1fr; gap: 16px; padding: 16px; }
  .executive-summary,.report-split { grid-template-columns: 1fr; }
  .filters.pro { grid-template-columns: 1fr; }
  .login-page { justify-content: center; }
  .login-panel { width: 100%; min-height: 100dvh; padding: 40px 24px; }
  .desktop-only { display: none; }
  .home-hero { flex-direction: column; gap: 12px; }
  .home-hero-metrics { flex-wrap: wrap; justify-content: flex-start; }
  .topbar-search { max-width: none; flex: 1; }
}

/* ── SMALL MOBILE ── */
@media (max-width: 480px) {
  .view-wrap { padding: 12px 12px calc(80px + env(safe-area-inset-bottom)); }
  .topbar { padding: 6px 12px; }
  .page-header-title h1 { font-size: 16px; }
  .dash-metrics { gap: 8px !important; }
  .dash-stats-row { gap: 8px !important; }
  .home-metrics,.grid { gap: 8px; }
  .workspace-hero { grid-template-columns: 1fr; gap: 8px; }
  .more-grid { grid-template-columns: 1fr; }
  .report-kpis { grid-template-columns: 1fr 1fr; gap: 8px; }
  .finance-summary-grid,.finance-strip { grid-template-columns: 1fr 1fr; gap: 8px; }
  .row-actions { grid-template-columns: 1fr 1fr; gap: 6px; }
  .row-actions .btn { justify-content: center; }
  .mobile-nav { right: 6px; left: 6px; border-radius: 18px; }
  .mobile-nav button { font-size: 9.5px; }
  .mobile-nav button .ui-icon { width: 18px; height: 18px; }
  .metric-feat .metric-value { font-size: 26px; }
  .metric-value { font-size: 24px; }
  .topbar-search { display: none; }
  .card { padding: 12px; border-radius: var(--radius); }
}

@media (hover:none) and (pointer:coarse) {
  .btn,.nav button,.mobile-nav button,.link { touch-action: manipulation; }
  .item-card:hover,.more-card:hover { transform: none; box-shadow: var(--shadow-sm); }
}

/* ══════════════════════════════════════════
   MARKETING REPORTS MODULE
   ══════════════════════════════════════════ */
.reports-hero { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.reports-hero-actions { display: flex; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }
.reports-summary { margin-bottom: 16px; }
.report-doc-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; }
.report-doc-card {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 16px; cursor: pointer; transition: all .2s; display: flex; flex-direction: column; gap: 12px;
  box-shadow: var(--shadow-sm);
}
.report-doc-card:hover { box-shadow: var(--shadow); border-color: rgba(108,92,231,.2); transform: translateY(-2px); }
.rdc-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.rdc-head h4 { font-size: 14px; font-weight: 800; margin: 0; }
.rdc-head p { font-size: 12px; color: var(--muted); margin-top: 3px; }
.rdc-meta { display: flex; flex-direction: column; gap: 5px; }
.rdc-meta span { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted); }
.rdc-meta .ui-icon { width: 13px; height: 13px; color: var(--muted); }
.rdc-actions { display: flex; gap: 6px; }
.rdc-actions .btn { flex: 1; justify-content: center; box-shadow: none; }

.pf-badge { display: grid; place-items: center; border-radius: 11px; font-size: 11px; font-weight: 900; flex: 0 0 auto; letter-spacing: -.02em; }
.pf-chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.pf-chip i { width: 7px; height: 7px; border-radius: 50%; }
.report-platforms-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }

.report-doc { max-width: 920px; margin: 0 auto; }
.report-doc-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
#reportPrintArea { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 32px; box-shadow: var(--shadow-sm); }
.report-cover { border-bottom: 2px solid var(--border); padding-bottom: 20px; margin-bottom: 24px; }
.report-cover-brand { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.report-cover-brand .mark { width: 38px; height: 38px; border-radius: 11px; background: linear-gradient(135deg,var(--primary),var(--primary-2)); color: #fff; display: grid; place-items: center; font-weight: 900; }
.report-cover-brand b { display: block; font-size: 14px; font-weight: 800; }
.report-cover-brand span { font-size: 11px; color: var(--muted); }
.report-cover h1 { font-size: 24px; font-weight: 900; margin-bottom: 12px; }
.report-cover-meta { display: flex; flex-wrap: wrap; gap: 8px 16px; align-items: center; }
.report-cover-meta span { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted); }
.report-cover-meta .ui-icon { width: 13px; height: 13px; }

.report-summary-block { margin-bottom: 24px; padding: 18px 20px; background: var(--soft); border-radius: var(--radius); border: 1px solid var(--border); }
.report-summary-block h3 { font-size: 15px; font-weight: 800; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.report-summary-block h3 .ui-icon { width: 17px; height: 17px; color: var(--primary); }
.report-summary-block .pre { font-size: 13px; line-height: 1.9; color: var(--text); }
.report-final { background: linear-gradient(135deg, var(--primary-light), var(--soft)); border-color: rgba(108,92,231,.2); }
.empty-summary { background: transparent; border-style: dashed; }

.pf-sections { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; }
.pf-section { border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px; border-right: 4px solid var(--pf, var(--primary)); }
.pf-section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.pf-section-title { display: flex; align-items: center; gap: 12px; }
.pf-section-title h4 { font-size: 15px; font-weight: 800; margin: 0; }
.pf-spend { font-size: 11px; color: var(--muted); font-weight: 700; }
.pf-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(90px,1fr)); gap: 10px; margin-bottom: 14px; }
.pf-metric { background: var(--pfbg, var(--soft)); border-radius: var(--radius-sm); padding: 10px 12px; text-align: center; }
.pf-metric small { display: block; font-size: 10px; color: var(--muted); font-weight: 600; margin-bottom: 4px; }
.pf-metric b { font-size: 17px; font-weight: 900; color: var(--text); font-variant-numeric: tabular-nums; }
.pf-block { margin-top: 10px; }
.pf-block h5 { font-size: 12px; font-weight: 800; color: var(--pf, var(--primary)); margin-bottom: 5px; }
.pf-block .pre { font-size: 13px; line-height: 1.8; }
.pf-reco { background: var(--soft); border-radius: var(--radius-sm); padding: 12px 14px; }
.report-foot { display: flex; align-items: center; justify-content: space-between; padding-top: 16px; margin-top: 8px; border-top: 1px solid var(--border); font-size: 11px; color: var(--muted); }

.sec-metric-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
.sec-metric-grid label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; font-weight: 600; color: var(--muted); }
.sec-metric-grid input { padding: 8px 10px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; }

.cp-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.cp-row { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm); background: var(--soft); }
.cp-info { flex: 1; min-width: 0; }
.cp-info b { display: block; font-size: 13px; font-weight: 700; }
.cp-info span { font-size: 11px; color: var(--muted); }
.cp-add { border-top: 1px solid var(--border); padding-top: 16px; }
.cp-add h4 { font-size: 14px; font-weight: 700; margin-bottom: 12px; }

/* Permission matrix */
.perm-matrix-head { margin-bottom: 10px; }
.perm-matrix-head b { font-size: 13px; font-weight: 800; display: block; margin-bottom: 2px; }
.perm-matrix-note { font-size: 12px; color: var(--muted); background: var(--primary-light); border-radius: var(--radius-sm); padding: 10px 12px; }
.perm-matrix { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.perm-item { display: flex; align-items: center; gap: 7px; padding: 8px 10px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font-size: 12px; font-weight: 600; cursor: pointer; transition: all .15s; background: var(--card); }
.perm-item:hover { border-color: var(--primary); background: var(--soft); }
.perm-item input { width: 15px; height: 15px; accent-color: var(--primary); flex: 0 0 15px; }
.perm-item input:checked + span { color: var(--primary); }
@media (max-width: 820px) { .perm-matrix { grid-template-columns: repeat(2,1fr); } }

@media (max-width: 1150px) { .report-doc-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (max-width: 820px) {
  .report-doc-grid { grid-template-columns: 1fr; }
  .reports-hero { flex-direction: column; }
  #reportPrintArea { padding: 18px; }
  .report-cover h1 { font-size: 19px; }
  .pf-section-head { flex-direction: column; align-items: flex-start; gap: 8px; }
  .sec-metric-grid { grid-template-columns: 1fr; }
}

@media print {
  .side, .right-panel, .topbar, .mobile-nav, .no-print, .report-doc-toolbar { display: none !important; }
  body { background: #fff; }
  .main { margin: 0 !important; }
  .view-wrap { padding: 0 !important; }
  .report-doc { max-width: 100%; }
  #reportPrintArea { border: none; box-shadow: none; padding: 0; border-radius: 0; }
  .pf-section, .report-summary-block { break-inside: avoid; page-break-inside: avoid; }
}

/* ══════════════════════════════════════════
   BILLING — Subscriptions · Services · Invoices
   ══════════════════════════════════════════ */
.billing-hero { display: flex; flex-direction: column; gap: 14px; }
.billing-tabs { display: flex; gap: 4px; background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 4px; width: fit-content; }
.billing-tabs button { border: none; background: transparent; border-radius: var(--radius-sm); padding: 8px 16px; font: inherit; font-size: 13px; font-weight: 700; color: var(--muted); cursor: pointer; transition: all .15s; }
.billing-tabs button.active { background: var(--card); color: var(--primary); box-shadow: var(--shadow-sm); }
.billing-summary { margin-bottom: 16px; }

/* Invoice builder */
.inv-builder { background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.inv-items-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; font-size: 13px; font-weight: 700; }
.inv-item-row { display: grid; grid-template-columns: 1fr 70px 90px 80px 32px; gap: 8px; align-items: center; margin-bottom: 8px; }
.inv-item-row input { padding: 8px 10px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; }
.inv-item-row .inv-amount { font-size: 13px; font-weight: 700; text-align: center; font-variant-numeric: tabular-nums; }
.inv-totals { display: flex; flex-direction: column; gap: 6px; background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.inv-totals > div { display: flex; align-items: center; justify-content: space-between; font-size: 13px; }
.inv-totals span { color: var(--muted); }
.inv-totals b { font-variant-numeric: tabular-nums; }
.inv-grand { border-top: 1px solid var(--border); padding-top: 8px; margin-top: 4px; }
.inv-grand span, .inv-grand b { font-size: 16px; font-weight: 900; color: var(--primary); }

/* Invoice document */
.invoice-sheet-doc { max-width: 760px; margin: 0 auto; }
.invoice-doc-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; border-bottom: 2px solid var(--border); padding-bottom: 18px; margin-bottom: 20px; }
.invoice-doc-num { text-align: left; }
.invoice-doc-num b { display: block; font-size: 20px; font-weight: 900; margin-bottom: 6px; font-variant-numeric: tabular-nums; }
.invoice-doc-parties { display: flex; justify-content: space-between; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.invoice-doc-parties small { font-size: 11px; color: var(--muted); display: block; margin-bottom: 4px; }
.invoice-doc-parties b { font-size: 15px; font-weight: 800; display: block; }
.invoice-doc-parties span { display: block; font-size: 12px; color: var(--muted); }
.invoice-doc-dates { display: flex; gap: 20px; }
.invoice-doc-table { width: 100%; border-collapse: collapse; margin-bottom: 18px; }
.invoice-doc-table th { background: var(--soft); padding: 10px 12px; text-align: right; font-size: 12px; font-weight: 700; color: var(--muted); border-bottom: 2px solid var(--border); }
.invoice-doc-table td { padding: 11px 12px; border-bottom: 1px solid var(--border); font-size: 13px; font-variant-numeric: tabular-nums; }
.invoice-doc-totals { width: 280px; margin-inline-start: auto; display: flex; flex-direction: column; gap: 6px; }
.invoice-doc-totals > div { display: flex; align-items: center; justify-content: space-between; font-size: 13px; }
.invoice-doc-totals span { color: var(--muted); }
.invoice-doc-totals b { font-variant-numeric: tabular-nums; }
.invoice-doc-totals .inv-grand { border-top: 1px solid var(--border); padding-top: 8px; margin-top: 4px; }
.invoice-doc-totals .inv-due b { color: var(--bad); }
.invoice-doc-notes { margin-top: 20px; padding: 14px; background: var(--soft); border-radius: var(--radius); }
.invoice-doc-notes small { font-size: 11px; color: var(--muted); display: block; margin-bottom: 4px; }

@media (max-width: 820px) {
  .billing-tabs { width: 100%; }
  .billing-tabs button { flex: 1; padding: 8px 6px; font-size: 12px; }
  .inv-item-row { grid-template-columns: 1fr 1fr; gap: 6px; }
  .inv-item-row .inv-desc { grid-column: 1/-1; }
  .invoice-doc-totals { width: 100%; }
  .invoice-doc-parties { flex-direction: column; }
}

/* ══════════════════════════════════════════
   MARKETING PLANS
   ══════════════════════════════════════════ */
.plan-budget-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.plan-budget-grid label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; font-weight: 600; color: var(--muted); }
.plan-sections-editor { border-top: 1px solid var(--border); padding-top: 14px; margin-top: 4px; }
.plan-sections-title { font-size: 14px; font-weight: 800; margin-bottom: 12px; }
.plan-sec-field { display: flex; flex-direction: column; gap: 3px; margin-bottom: 14px; }
.plan-sec-field b { font-size: 13px; font-weight: 700; }
.plan-sec-field .hint { font-size: 11px; margin-bottom: 4px; }
.plan-sec-field textarea { min-height: 70px; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; resize: vertical; }

.plan-budgets { margin-bottom: 24px; padding: 18px 20px; background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius); }
.plan-budgets h3 { font-size: 15px; font-weight: 800; margin-bottom: 14px; }
.plan-budget-bars { display: flex; flex-direction: column; gap: 12px; }
.plan-budget-bar .pbb-head { display: flex; align-items: center; justify-content: space-between; font-size: 13px; margin-bottom: 5px; }
.plan-budget-bar .pbb-head b { font-variant-numeric: tabular-nums; }
.pbb-track { height: 9px; background: var(--border); border-radius: 999px; overflow: hidden; }
.pbb-track i { display: block; height: 100%; border-radius: 999px; }

.plan-sections { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; }
.plan-section { border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px; border-right: 4px solid var(--primary); }
.plan-section h4 { font-size: 15px; font-weight: 800; margin-bottom: 8px; color: var(--primary); }
.plan-section .pre { font-size: 13px; line-height: 1.9; }

@media (max-width: 820px) {
  .plan-budget-grid { grid-template-columns: 1fr 1fr; }
}
@media print { .plan-section { break-inside: avoid; page-break-inside: avoid; } }

/* ══════════════════════════════════════════
   UNIFIED PROFILE
   ══════════════════════════════════════════ */
.profile-page { max-width: 880px; margin: 0 auto; }
.profile-tabs { display: flex; gap: 4px; padding: 0 24px 16px; }
.profile-tabs button { border: none; background: transparent; padding: 9px 14px; border-radius: var(--radius-sm); font: inherit; font-size: 13px; font-weight: 700; color: var(--muted); cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: all .15s; }
.profile-tabs button .ui-icon { width: 15px; height: 15px; }
.profile-tabs button:hover { background: var(--soft); color: var(--text); }
.profile-tabs button.active { background: var(--primary-light); color: var(--primary); }
.profile-tab-content { margin-top: 16px; }
.profile-tab-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.profile-tab-grid.one { grid-template-columns: 1.2fr .8fr; }
.profile-edit-card h4, .profile-info-card h4 { font-size: 14px; font-weight: 800; margin-bottom: 14px; }
.profile-edit-card { display: flex; flex-direction: column; gap: 12px; }
.profile-edit-card label { display: flex; flex-direction: column; gap: 5px; font-size: 13px; font-weight: 600; color: var(--muted); }
.profile-edit-card input { padding: 9px 12px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 13px; color: var(--text); background: var(--card); }
.profile-edit-card input:disabled { background: var(--soft); color: var(--muted); }
.profile-info-grid { display: grid; grid-template-columns: auto 1fr; gap: 12px 16px; font-size: 13px; align-items: center; }
.profile-info-grid span { color: var(--muted); font-weight: 600; }
.profile-info-grid b { font-weight: 700; }
.profile-online { display: inline-flex; align-items: center; gap: 6px; color: var(--good); font-weight: 700; }
.profile-online i { width: 8px; height: 8px; border-radius: 50%; background: var(--good); display: inline-block; }
.security-tips { padding-inline-start: 18px; display: flex; flex-direction: column; gap: 8px; }
.security-tips li { font-size: 13px; color: var(--muted); }
@media (max-width: 820px) {
  .profile-tab-grid, .profile-tab-grid.one { grid-template-columns: 1fr; }
  .profile-tabs { overflow-x: auto; padding: 0 14px 14px; }
}

/* ══════════════════════════════════════════
   CSV IMPORT (report sections)
   ══════════════════════════════════════════ */
.csv-import-bar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 10px 12px; background: var(--primary-light); border: 1px dashed rgba(108,92,231,.3); border-radius: var(--radius-sm); margin-bottom: 12px; }
.csv-import-bar .hint { flex: 1; min-width: 160px; }
.csv-map { background: var(--soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px; }
.csv-map-head { display: flex; flex-direction: column; gap: 3px; margin-bottom: 12px; }
.csv-map-head b { font-size: 13px; font-weight: 800; display: flex; align-items: center; gap: 6px; }
.csv-map-head b .ui-icon { width: 15px; height: 15px; color: var(--primary); }
.csv-map-rows { display: flex; flex-direction: column; gap: 8px; }
.csv-map-row { display: grid; grid-template-columns: 1fr 1.2fr 90px 70px; gap: 8px; align-items: center; }
.csv-map-label { font-size: 12px; font-weight: 600; }
.csv-map-row select { padding: 7px 9px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font: inherit; font-size: 12px; background: var(--card); }
.csv-preview { font-size: 13px; font-weight: 800; text-align: center; color: var(--primary); font-variant-numeric: tabular-nums; background: var(--card); border-radius: 6px; padding: 5px; }
.csv-map-actions { display: flex; gap: 8px; margin-top: 14px; }
@media (max-width: 820px) {
  .csv-map-row { grid-template-columns: 1fr 1fr; }
  .csv-map-label { grid-column: 1/-1; }
}

/* ══════════════════════════════════════════
   ENTITY CARDS — clients / projects / tasks / domains / users
   (render functions use these class names; unify with item-card look)
   ══════════════════════════════════════════ */
.client-cards, .project-cards, .task-cards, .domain-cards, .user-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.client-card, .project-card, .task-card, .domain-card, .user-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .2s, border-color .2s, transform .2s;
}
.client-card:hover, .project-card:hover, .task-card:hover, .domain-card:hover, .user-card:hover {
  box-shadow: var(--shadow); border-color: rgba(108,92,231,.2); transform: translateY(-2px);
}
.client-card-head, .project-card-head, .task-card-head, .domain-card-head, .user-card-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
}
.client-card-head > div, .project-card-head > div, .task-card-head > div, .domain-card-head > div, .user-card-head > div { min-width: 0; }
.client-name, .project-name, .task-title, .domain-name, .user-name {
  font-size: 14px; font-weight: 700; color: var(--primary);
  padding: 0; background: none; border: none; text-align: right; cursor: pointer;
}
.client-name:hover, .project-name:hover, .task-title:hover, .domain-name:hover { text-decoration: underline; }
.client-card-head p, .project-card-head p, .task-card-head p, .domain-card-head p, .user-card-head p {
  font-size: 12px; color: var(--muted); margin-top: 3px;
}
.client-meta, .project-meta, .task-meta, .domain-meta, .user-meta {
  display: flex; flex-direction: column; gap: 6px;
}
.client-meta span, .project-meta span, .task-meta span, .domain-meta span, .user-meta span {
  display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--muted);
}
.client-meta .ui-icon, .project-meta .ui-icon, .task-meta .ui-icon,
.domain-meta .ui-icon, .user-meta .ui-icon { width: 13px; height: 13px; color: var(--muted); flex: 0 0 auto; }
.client-stats, .project-stats, .domain-stats, .user-stats {
  display: grid; grid-template-columns: repeat(2, 1fr);
  background: var(--primary-light); border-radius: var(--radius-sm);
  padding: 10px; gap: 4px 12px; align-items: center;
}
.client-stats b, .project-stats b, .domain-stats b, .user-stats b {
  font-size: 16px; font-weight: 900; color: var(--primary); font-variant-numeric: tabular-nums;
}
.client-stats span, .project-stats span, .domain-stats span, .user-stats span {
  font-size: 11px; color: var(--muted);
}
.project-progress { display: flex; flex-direction: column; gap: 6px; }
.project-progress small { font-size: 11px; color: var(--muted); }
.task-priority-row {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--soft); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 8px 10px;
}
.client-actions, .project-actions, .task-actions, .domain-actions, .user-actions {
  display: flex; gap: 7px; flex-wrap: wrap;
}
.client-actions .btn, .project-actions .btn, .task-actions .btn,
.domain-actions .btn, .user-actions .btn { flex: 1; min-width: 80px; justify-content: center; box-shadow: none; }

@media (max-width: 1150px) {
  .client-cards, .project-cards, .task-cards, .domain-cards, .user-cards { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 820px) {
  .client-cards, .project-cards, .task-cards, .domain-cards, .user-cards { grid-template-columns: 1fr; }
  .client-card:hover, .project-card:hover, .task-card:hover, .domain-card:hover, .user-card:hover { transform: none; }
}

/* changelog list in quick system-info modal */
.changelog-list { padding-inline-start: 16px; display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }
.changelog-list li { font-size: 12px; color: var(--muted); line-height: 1.6; }
.system-mini-modal h4 { color: var(--text); }

/* Reference codes (CL-/PRJ-/TSK-/REP-/SUB-…) */
.ref-code {
  display: inline-block; font-family: ui-monospace, monospace;
  font-size: 10px; font-weight: 700; color: var(--primary);
  background: var(--primary-light); border-radius: 5px;
  padding: 1px 6px; margin-inline-end: 4px; letter-spacing: .03em;
  font-variant-numeric: tabular-nums;
}
.no-perm { text-align: center; max-width: 460px; margin: 40px auto; }
.no-perm .empty-icon { margin: 0 auto 12px; }
