/* ================================================
   Web4Cause CRM — Design System & Stylesheet
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap');

/* ── Variables ── */
:root {
  --bg:         #0C1526;
  --bg2:        #111D35;
  --bg3:        #162040;
  --card:       rgba(17,29,53,0.95);
  --glass:      rgba(255,255,255,0.03);
  --border:     rgba(148,163,184,0.09);
  --border2:    rgba(148,163,184,0.18);

  --teal:       #0E8C8C;
  --teal-l:     #16B5B5;
  --teal-d:     #0A6868;
  --teal-glow:  rgba(14,140,140,0.28);
  --teal-sub:   rgba(14,140,140,0.1);

  --amber:      #F5A623;
  --amber-l:    #FBBF45;
  --amber-d:    #C8841A;
  --amber-glow: rgba(245,166,35,0.22);
  --amber-sub:  rgba(245,166,35,0.1);

  --txt:        #EEF2FF;
  --txt2:       #94A3B8;
  --txt3:       #64748B;

  --green:      #10B981; --green-bg: rgba(16,185,129,0.1);
  --red:        #EF4444; --red-bg:   rgba(239,68,68,0.1);
  --yellow:     #F59E0B; --yellow-bg:rgba(245,158,11,0.1);
  --blue:       #3B82F6; --blue-bg:  rgba(59,130,246,0.1);
  --purple:     #8B5CF6; --purple-bg:rgba(139,92,246,0.1);

  --sidebar-w:  258px;
  --sidebar-c:  68px;
  --topbar-h:   62px;

  --r-sm: 6px; --r: 10px; --r-md: 13px; --r-lg: 16px; --r-xl: 20px; --r-full: 9999px;

  --sh:     0 4px 20px rgba(0,0,0,0.35);
  --sh-teal:0 4px 22px rgba(14,140,140,0.3);
  --sh-lg:  0 8px 40px rgba(0,0,0,0.45);

  --ease: all .2s cubic-bezier(.4,0,.2,1);
  --ease-s: all .35s cubic-bezier(.4,0,.2,1);

  --f-body:'Inter',system-ui,sans-serif;
  --f-head:'Outfit',system-ui,sans-serif;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--bg);color:var(--txt);line-height:1.6;overflow:hidden;height:100vh}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--teal-d)}

/* Auth styles are defined in the Auth System section below (line ~722) */

/* ── App Shell ── */
#app{display:flex;height:100vh;overflow:hidden;
  background: radial-gradient(ellipse 60% 50% at 15% 50%,rgba(14,140,140,.07) 0%,transparent 65%),
              radial-gradient(ellipse 50% 40% at 85% 15%,rgba(245,166,35,.05) 0%,transparent 55%),
              var(--bg)}

/* ── Sidebar ── */
#sidebar{width:var(--sidebar-w);height:100vh;background:var(--bg2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;transition:var(--ease-s);flex-shrink:0;z-index:100;overflow:hidden}
#sidebar.collapsed{width:var(--sidebar-c)}
#sidebar.collapsed .logo-text,
#sidebar.collapsed .user-details,
#sidebar.collapsed .nav-group-label,
#sidebar.collapsed .nav-item>span,
#sidebar.collapsed .nav-badge{display:none!important}

.sidebar-header{padding:16px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;
  justify-content:space-between;min-height:var(--topbar-h);gap:10px}
.logo{display:flex;align-items:center;gap:11px;overflow:hidden;min-width:0}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--teal),var(--teal-l));
  border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--f-head);
  font-weight:800;font-size:10px;color:#fff;flex-shrink:0;box-shadow:var(--sh-teal);letter-spacing:.5px}
.logo-text{display:flex;flex-direction:column;overflow:hidden;white-space:nowrap}
.logo-name{font-family:var(--f-head);font-weight:700;font-size:15px;color:var(--txt);line-height:1.2}
.logo-tag{font-size:9.5px;color:var(--teal-l);font-weight:600;letter-spacing:1.2px;text-transform:uppercase}

.sidebar-toggle{width:28px;height:28px;border-radius:var(--r-sm);background:var(--glass);color:var(--txt2);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--border);transition:var(--ease);flex-shrink:0}
.sidebar-toggle:hover{background:var(--teal-sub);color:var(--teal-l);border-color:var(--teal-glow)}
.sidebar-toggle svg{width:15px;height:15px}

.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 0}
.nav-group{padding:0 10px;margin-bottom:4px}
.nav-group-label{display:block;font-size:9.5px;font-weight:700;letter-spacing:1.3px;text-transform:uppercase;
  color:var(--txt3);padding:10px 10px 5px;white-space:nowrap}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r);
  color:var(--txt2);font-size:13.5px;font-weight:500;cursor:pointer;transition:var(--ease);
  position:relative;white-space:nowrap;user-select:none;margin-bottom:2px}
.nav-item svg{width:16px;height:16px;flex-shrink:0}
.nav-item:hover{background:var(--glass);color:var(--txt)}
.nav-item.active{background:var(--teal-sub);color:var(--teal-l);font-weight:600}
.nav-item.active::before{content:'';position:absolute;left:0;top:25%;height:50%;width:3px;
  background:var(--teal-l);border-radius:0 99px 99px 0}
.nav-badge{margin-left:auto;background:var(--red-bg);color:var(--red);border-radius:99px;
  padding:1px 6px;font-size:10px;font-weight:700;border:1px solid rgba(239,68,68,.2);font-style:normal}

.sidebar-footer{padding:12px;border-top:1px solid var(--border)}
.user-info{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r);
  cursor:pointer;transition:var(--ease)}
.user-info:hover{background:var(--glass)}
.user-avatar{width:34px;height:34px;background:linear-gradient(135deg,var(--amber-d),var(--amber));
  border-radius:99px;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.user-name{display:block;font-size:13px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{display:block;font-size:11px;color:var(--txt3)}

/* ── Main ── */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
#topbar{height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;border-bottom:1px solid var(--border);background:rgba(12,21,38,.85);
  backdrop-filter:blur(12px);flex-shrink:0;z-index:50}
.topbar-left{display:flex;flex-direction:column;gap:2px}
#pageTitle{font-family:var(--f-head);font-size:20px;font-weight:700;color:var(--txt);line-height:1.2}
.breadcrumb{font-size:11.5px;color:var(--txt3)}
.topbar-right{display:flex;align-items:center;gap:10px}
.icon-btn{width:36px;height:36px;border-radius:var(--r);background:var(--glass);border:1px solid var(--border);
  color:var(--txt2);display:flex;align-items:center;justify-content:center;transition:var(--ease);position:relative}
.icon-btn svg{width:16px;height:16px}
.icon-btn:hover{background:var(--teal-sub);color:var(--teal-l);border-color:var(--teal-glow)}
.notif-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;
  background:var(--amber);border-radius:50%;border:1.5px solid var(--bg)}
.notif-dropdown{position:absolute;top:calc(var(--topbar-h) - 10px);right:24px;width:320px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);z-index:100;max-height:400px;overflow-y:auto;display:flex;flex-direction:column}
.notif-hdr{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:600;display:flex;justify-content:space-between;align-items:center}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;gap:12px;cursor:pointer;transition:var(--ease)}
.notif-item:hover{background:var(--glass)}
.notif-item:last-child{border-bottom:none}
.notif-icon{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-icon svg{width:14px;height:14px}
.notif-title{font-size:13px;font-weight:600;color:var(--txt);margin-bottom:2px}
.notif-desc{font-size:11.5px;color:var(--txt2)}
.date-badge{padding:6px 14px;background:var(--glass);border:1px solid var(--border);
  border-radius:99px;font-size:11.5px;color:var(--txt2);font-weight:500;white-space:nowrap}

/* ── Content / Panels ── */
#content{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px}
.panel{display:none;animation:fadeUp .25s ease forwards}
.panel.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── Section Header ── */
.sec-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.sec-title{font-family:var(--f-head);font-size:20px;font-weight:700;color:var(--txt)}
.sec-sub{font-size:12px;color:var(--txt3);margin-top:3px}
.sec-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--r);
  font-size:13px;font-weight:600;cursor:pointer;transition:var(--ease);border:1px solid transparent;
  white-space:nowrap;font-family:inherit}
.btn svg{width:14px;height:14px}
.btn-primary{background:linear-gradient(135deg,var(--teal),var(--teal-l));color:#fff;box-shadow:var(--sh-teal)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(14,140,140,.45)}
.btn-amber{background:linear-gradient(135deg,var(--amber-d),var(--amber-l));color:#fff}
.btn-amber:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(245,166,35,.35)}
.btn-ghost{background:var(--glass);color:var(--txt2);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg3);color:var(--txt);border-color:var(--border2)}
.btn-danger{background:var(--red-bg);color:var(--red);border-color:rgba(239,68,68,.2)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-xs{padding:3px 9px;font-size:11px}

/* ── Cards ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:20px;transition:var(--ease);backdrop-filter:blur(10px)}
.card:hover{border-color:var(--border2);box-shadow:var(--sh)}
.card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-family:var(--f-head);font-size:14px;font-weight:600;color:var(--txt)}
.card-sub{font-size:11.5px;color:var(--txt3);margin-top:2px}

/* ── Stats Grid ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:22px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;
  display:flex;align-items:flex-start;gap:14px;transition:var(--ease);position:relative;overflow:hidden;cursor:default}
.stat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--teal),var(--teal-l));opacity:0;transition:var(--ease)}
.stat-card:hover{border-color:var(--teal-glow);transform:translateY(-2px);box-shadow:var(--sh-teal)}
.stat-card:hover::after{opacity:1}
.stat-icon{width:42px;height:42px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon svg{width:20px;height:20px}
.si-teal{background:var(--teal-sub);color:var(--teal-l)}
.si-amber{background:var(--amber-sub);color:var(--amber)}
.si-green{background:var(--green-bg);color:var(--green)}
.si-red{background:var(--red-bg);color:var(--red)}
.si-blue{background:var(--blue-bg);color:var(--blue)}
.si-purple{background:var(--purple-bg);color:var(--purple)}
.stat-val{font-family:var(--f-head);font-size:26px;font-weight:700;color:var(--txt);line-height:1.1}
.stat-lbl{font-size:11.5px;color:var(--txt3);margin-top:3px;font-weight:500}
.stat-chg{font-size:11px;font-weight:600;margin-top:5px;display:flex;align-items:center;gap:3px}
.chg-up{color:var(--green)}.chg-dn{color:var(--red)}

/* ── Dashboard 2col grid ── */
.dash-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;margin-bottom:16px}
.dash-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}
.chart-wrap{position:relative;height:210px}
.chart-wrap canvas{border-radius:var(--r)}

/* ── Activity Feed ── */
.activity-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.activity-item:last-child{border-bottom:none}
.act-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:7px}
.act-dot.teal{background:var(--teal-l)}.act-dot.amber{background:var(--amber)}.act-dot.green{background:var(--green)}
.act-dot.red{background:var(--red)}.act-dot.blue{background:var(--blue)}.act-dot.purple{background:var(--purple)}
.act-body{flex:1;font-size:12.5px;color:var(--txt2);line-height:1.45}
.act-body strong{color:var(--txt);font-weight:600}
.act-time{font-size:11px;color:var(--txt3);flex-shrink:0;margin-top:1px}

/* ── Deadline items ── */
.dl-item{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--border)}
.dl-item:last-child{border-bottom:none}
.dl-date{width:38px;text-align:center;flex-shrink:0}
.dl-day{font-family:var(--f-head);font-size:17px;font-weight:700;color:var(--teal-l);line-height:1}
.dl-mon{font-size:9.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:.5px}
.dl-info{flex:1}
.dl-name{font-size:13px;font-weight:600;color:var(--txt)}
.dl-client{font-size:11px;color:var(--txt3);margin-top:1px}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:99px;
  font-size:11px;font-weight:600;white-space:nowrap}
.b-teal{background:var(--teal-sub);color:var(--teal-l);border:1px solid var(--teal-glow)}
.b-amber{background:var(--amber-sub);color:var(--amber);border:1px solid var(--amber-glow)}
.b-green{background:var(--green-bg);color:var(--green);border:1px solid rgba(16,185,129,.2)}
.b-red{background:var(--red-bg);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.b-yellow{background:var(--yellow-bg);color:var(--yellow);border:1px solid rgba(245,158,11,.2)}
.b-blue{background:var(--blue-bg);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.b-purple{background:var(--purple-bg);color:var(--purple);border:1px solid rgba(139,92,246,.2)}
.b-muted{background:rgba(100,116,139,.1);color:var(--txt3);border:1px solid rgba(100,116,139,.2)}

/* ── Filter Bar ── */
.filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:180px;max-width:340px}
.search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--txt3);pointer-events:none}
.srch-in,.f-select{padding:8px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  color:var(--txt);font-size:13px;transition:var(--ease);width:100%}
.srch-in{padding-left:33px}
.srch-in::placeholder{color:var(--txt3)}
.srch-in:focus,.f-select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-sub)}
.f-select{width:auto;cursor:pointer;background:var(--card)}
option{background:var(--bg2)}

/* ── Tabs ── */
.tabs{display:flex;gap:3px;background:var(--bg2);border-radius:var(--r);padding:4px;
  margin-bottom:18px;border:1px solid var(--border);flex-wrap:wrap}
.tab-btn{padding:6px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;
  color:var(--txt3);cursor:pointer;transition:var(--ease);white-space:nowrap}
.tab-btn:hover{color:var(--txt);background:var(--glass)}
.tab-btn.active{background:var(--teal-sub);color:var(--teal-l);font-weight:600;border:1px solid var(--teal-glow)}

/* ── Cards Grid ── */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:15px}
.client-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:18px;cursor:pointer;transition:var(--ease);position:relative;overflow:hidden}
.client-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal),var(--teal-l));opacity:0;transition:var(--ease)}
.client-card:hover{border-color:var(--teal-glow);transform:translateY(-3px);box-shadow:var(--sh-teal)}
.client-card:hover::before{opacity:1}
.client-card-hdr{display:flex;align-items:flex-start;gap:11px;margin-bottom:12px}
.client-av{width:40px;height:40px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--teal-d),var(--teal-l));
  display:flex;align-items:center;justify-content:center;font-family:var(--f-head);font-size:13px;font-weight:700;
  color:#fff;flex-shrink:0;text-transform:uppercase}
.client-name{font-family:var(--f-head);font-size:14px;font-weight:700;color:var(--txt);line-height:1.3}
.client-cause{font-size:11px;color:var(--txt3);margin-top:2px}
.client-meta{display:flex;gap:8px;margin-top:10px}
.client-stat{flex:1;text-align:center;padding:7px;background:var(--glass);border-radius:var(--r-sm);border:1px solid var(--border)}
.cs-val{font-family:var(--f-head);font-size:15px;font-weight:700;color:var(--teal-l)}
.cs-lbl{font-size:9.5px;color:var(--txt3);margin-top:1px}

/* ── Table ── */
.tbl-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--border)}
.dtbl{width:100%;border-collapse:collapse;font-size:13px}
.dtbl thead th{padding:11px 14px;text-align:left;font-size:10.5px;font-weight:700;letter-spacing:.8px;
  text-transform:uppercase;color:var(--txt3);background:var(--bg2);border-bottom:1px solid var(--border);white-space:nowrap}
.dtbl tbody td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--txt2);vertical-align:middle}
.dtbl tbody tr{transition:var(--ease)}
.dtbl tbody tr:hover{background:var(--glass)}
.dtbl tbody tr:last-child td{border-bottom:none}
.t-name{font-weight:600;color:var(--txt)}
.t-sub{font-size:11px;color:var(--txt3);margin-top:1px}
.tbl-actions{display:flex;gap:5px}

/* ── Kanban ── */
.kanban{display:flex;gap:15px;overflow-x:auto;padding-bottom:14px;min-height:380px}
.k-col{min-width:230px;max-width:250px;flex-shrink:0;display:flex;flex-direction:column;gap:10px}
.k-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;
  background:var(--bg2);border-radius:var(--r);border:1px solid var(--border)}
.k-title{font-size:12.5px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:8px}
.k-count{width:20px;height:20px;border-radius:50%;background:var(--teal-sub);color:var(--teal-l);
  font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:1px solid var(--teal-glow)}
.k-cards{display:flex;flex-direction:column;gap:10px;flex:1}
.k-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);
  padding:14px;cursor:pointer;transition:var(--ease)}
.k-card:hover{border-color:var(--teal-glow);transform:translateY(-2px);box-shadow:var(--sh)}
.k-card-name{font-size:13px;font-weight:600;color:var(--txt);margin-bottom:6px}
.k-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.lead-score{display:flex;align-items:center;gap:3px;font-size:12px;font-weight:700;color:var(--amber)}

/* ── Progress ── */
.prog-bar{height:5px;background:var(--bg3);border-radius:99px;overflow:hidden;margin-top:8px}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-l));border-radius:99px;transition:width .6s ease}
.prog-fill.a{background:linear-gradient(90deg,var(--amber-d),var(--amber))}
.prog-fill.r{background:linear-gradient(90deg,#c0392b,var(--red))}
.prog-fill.g{background:linear-gradient(90deg,#059669,var(--green))}
.prog-fill.e{background:linear-gradient(90deg,var(--red),#f87171)}

/* ── Stage Tracker ── */
.stages{display:flex;align-items:center;gap:0;overflow-x:auto;padding:4px 0}
.st-step{display:flex;align-items:center;flex:1;min-width:70px}
.st-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:var(--bg2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;font-weight:700;
  color:var(--txt3);transition:var(--ease);z-index:1;position:relative}
.st-dot.done{background:var(--teal);border-color:var(--teal);color:#fff}
.st-dot.curr{background:var(--amber-sub);border-color:var(--amber);color:var(--amber);box-shadow:0 0 0 3px var(--amber-glow)}
.st-line{flex:1;height:2px;background:var(--border)}
.st-line.done{background:var(--teal)}

/* ── Forms ── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--txt2);margin-bottom:7px;letter-spacing:.3px}
.form-label .req{color:var(--red)}
.form-input,.form-select,.form-textarea{width:100%;padding:9px 13px;background:var(--bg2);
  border:1px solid var(--border);border-radius:var(--r);color:var(--txt);font-size:13px;transition:var(--ease);appearance:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--txt3)}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--teal);
  background:rgba(22,32,64,.9);box-shadow:0 0 0 3px var(--teal-sub)}
.form-textarea{min-height:75px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.form-hint{font-size:11px;color:var(--txt3);margin-top:4px}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(5px);
  display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding:16px}
.modal-overlay.hidden{display:none!important}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r-xl);
  width:100%;max-width:620px;max-height:88vh;overflow-y:auto;position:relative;
  animation:slideUp .25s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--sh-lg)}
.modal-box.modal-lg{max-width:780px}
@keyframes slideUp{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;
  border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1}
.modal-title{font-family:var(--f-head);font-size:17px;font-weight:700;color:var(--txt)}
.modal-close{width:30px;height:30px;border-radius:var(--r-sm);background:var(--glass);border:1px solid var(--border);
  color:var(--txt2);display:flex;align-items:center;justify-content:center;transition:var(--ease)}
.modal-close:hover{background:var(--red-bg);color:var(--red);border-color:rgba(239,68,68,.2)}
.modal-close svg{width:14px;height:14px}
.modal-body{padding:22px 24px}
.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;
  border-top:1px solid var(--border)}

/* ── Toast ── */
#toastContainer{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:var(--r-md);
  background:var(--bg2);border:1px solid var(--border2);box-shadow:var(--sh-lg);
  min-width:260px;max-width:360px;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);font-size:13px;color:var(--txt2)}
.toast svg{width:16px;height:16px;flex-shrink:0}
.toast.t-success{border-left:3px solid var(--green)}.toast.t-success svg{color:var(--green)}
.toast.t-error{border-left:3px solid var(--red)}.toast.t-error svg{color:var(--red)}
.toast.t-info{border-left:3px solid var(--blue)}.toast.t-info svg{color:var(--blue)}
.toast.t-warn{border-left:3px solid var(--amber)}.toast.t-warn svg{color:var(--amber)}
@keyframes toastIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}

/* ── Color swatches ── */
.color-swatch{width:28px;height:28px;border-radius:var(--r-sm);border:2px solid rgba(255,255,255,.15);
  display:inline-block;cursor:pointer}

/* ── Empty state ── */
.empty-state{text-align:center;padding:60px 20px;color:var(--txt3)}
.empty-state svg{width:52px;height:52px;opacity:.35;margin-bottom:14px}
.empty-state h3{font-family:var(--f-head);font-size:16px;color:var(--txt2);margin-bottom:6px}
.empty-state p{font-size:12.5px;margin-bottom:18px}

/* ── Detail View ── */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.detail-item label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--txt3)}
.detail-item p{font-size:13.5px;color:var(--txt);margin-top:3px;font-weight:500}
.detail-divider{border:none;border-top:1px solid var(--border);margin:16px 0}

/* ── Workload ── */
.workload-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}
.workload-row:last-child{border-bottom:none}
.wl-av{width:36px;height:36px;border-radius:99px;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.wl-info{flex:1}
.wl-name{font-size:13px;font-weight:600;color:var(--txt)}
.wl-tasks{font-size:11px;color:var(--txt3)}
.wl-bar{flex:2}
.wl-pct{font-size:11px;color:var(--txt3);margin-left:8px;flex-shrink:0}

/* ── Finance tabs content ── */
.fin-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.fin-kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);
  padding:14px;text-align:center}
.fin-kpi .val{font-family:var(--f-head);font-size:20px;font-weight:700;color:var(--teal-l)}
.fin-kpi .lbl{font-size:11px;color:var(--txt3);margin-top:2px}

/* ── Checklist ── */
.checklist-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.checklist-item:last-child{border-bottom:none}
.chk-box{width:18px;height:18px;border-radius:4px;border:2px solid var(--border2);
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:var(--ease)}
.chk-box.checked{background:var(--teal);border-color:var(--teal)}
.chk-box svg{width:11px;height:11px;color:#fff;opacity:0}
.chk-box.checked svg{opacity:1}
.chk-label{flex:1;font-size:13px;color:var(--txt2)}
.chk-label.done{text-decoration:line-through;color:var(--txt3)}

/* ── Misc helpers ── */
.flex-center{display:flex;align-items:center;gap:10px}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}.mt-4{margin-top:24px}
.mb-1{margin-bottom:6px}.mb-2{margin-bottom:12px}.mb-3{margin-bottom:18px}
.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}
.text-teal{color:var(--teal-l)}.text-muted{color:var(--txt3)}
.fw-6{font-weight:600}.fw-7{font-weight:700}
.font-head{font-family:var(--f-head)}

/* ── Search Results hover ── */
#searchResults div:hover{background:var(--glass)!important}

/* ── Kanban scroll ── */
.kanban{padding-bottom:20px}
.k-cards{min-height:200px}

/* ── Modal wider for long forms ── */
.modal-box{scrollbar-width:thin}

/* ── Stage tracker responsive ── */
@media(max-width:768px){
  .form-row,.form-row-3{grid-template-columns:1fr!important}
  .dash-grid,.dash-grid-3{grid-template-columns:1fr}
  #sidebar{width:var(--sidebar-c)}
  #sidebar .logo-text,#sidebar .user-details,#sidebar .nav-group-label,#sidebar .nav-item>span,#sidebar .nav-badge{display:none!important}
}

/* ============================================================
   Light Mode — Google 4-Color Brand Theme
   Primary: Blue #4285F4 | Red #EA4335 | Yellow #FBBC05 | Green #34A853
   ============================================================ */

[data-theme="light"] {
  --bg:         #FFFFFF;
  --bg2:        #F8F9FA;
  --bg3:        #F1F3F4;
  --card:       rgba(255,255,255,1);
  --glass:      rgba(0,0,0,0.025);
  --border:     rgba(60,64,67,0.10);
  --border2:    rgba(60,64,67,0.18);

  /* Google Blue → primary (replaces teal) */
  --teal:       #4285F4;
  --teal-l:     #1A73E8;
  --teal-d:     #1558B0;
  --teal-glow:  rgba(66,133,244,0.22);
  --teal-sub:   rgba(66,133,244,0.10);

  /* Google Yellow → accent (replaces amber) */
  --amber:      #F9AB00;
  --amber-l:    #FBBC05;
  --amber-d:    #E37400;
  --amber-glow: rgba(249,171,0,0.22);
  --amber-sub:  rgba(249,171,0,0.10);

  --txt:        #202124;
  --txt2:       #5F6368;
  --txt3:       #9AA0A6;

  /* Google semantic colors */
  --green:      #1E8E3E;  --green-bg:   rgba(30,142,62,0.10);
  --red:        #D93025;  --red-bg:     rgba(217,48,37,0.10);
  --yellow:     #F9AB00;  --yellow-bg:  rgba(249,171,0,0.10);
  --blue:       #4285F4;  --blue-bg:    rgba(66,133,244,0.10);
  --purple:     #9334EA;  --purple-bg:  rgba(147,52,234,0.10);

  --sh:         0 1px 4px rgba(60,64,67,0.15),0 1px 2px rgba(60,64,67,0.10);
  --sh-teal:    0 2px 16px rgba(66,133,244,0.22);
  --sh-lg:      0 4px 28px rgba(60,64,67,0.22);
}

/* ── Body & App ── */
[data-theme="light"] body { background:var(--bg); color:var(--txt); }
[data-theme="light"] #app {
  background:
    radial-gradient(ellipse 55% 45% at 10% 50%,rgba(66,133,244,.06) 0%,transparent 65%),
    radial-gradient(ellipse 45% 35% at 92% 10%,rgba(52,168,83,.05) 0%,transparent 55%),
    radial-gradient(ellipse 35% 25% at 55% 95%,rgba(234,67,53,.04) 0%,transparent 50%),
    var(--bg);
}

/* ── Sidebar ── */
[data-theme="light"] #sidebar { background:var(--bg2); border-right:1px solid var(--border); box-shadow:none; }
[data-theme="light"] .sidebar-header { position:relative; border-bottom-color:transparent; padding-bottom:19px; }
/* Google 4-color strip at bottom of sidebar header */
[data-theme="light"] .sidebar-header::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(to right,#4285F4 25%,#EA4335 25% 50%,#FBBC05 50% 75%,#34A853 75%);
}
[data-theme="light"] .logo-icon { background:linear-gradient(135deg,#4285F4,#1A73E8); box-shadow:0 2px 8px rgba(66,133,244,.3); }
[data-theme="light"] .logo-name { color:var(--txt); }
[data-theme="light"] .logo-tag { color:#4285F4; letter-spacing:1.5px; }
[data-theme="light"] .sidebar-toggle { background:rgba(0,0,0,.04); border-color:var(--border); color:var(--txt2); }
[data-theme="light"] .sidebar-toggle:hover { background:rgba(66,133,244,.10); color:#4285F4; border-color:rgba(66,133,244,.3); }
[data-theme="light"] .nav-group-label { color:var(--txt3); }
[data-theme="light"] .nav-item { color:var(--txt2); }
[data-theme="light"] .nav-item:hover { background:rgba(66,133,244,.06); color:#4285F4; }
[data-theme="light"] .nav-item.active { background:rgba(66,133,244,.12); color:#1558B0; font-weight:600; }
[data-theme="light"] .nav-item.active::before { background:#4285F4; }
[data-theme="light"] .nav-badge { background:rgba(217,48,37,.08); color:#D93025; border-color:rgba(217,48,37,.2); }
[data-theme="light"] .user-avatar { background:linear-gradient(135deg,#E37400,#FBBC05); }
[data-theme="light"] .user-name { color:var(--txt); }
[data-theme="light"] .user-role { color:var(--txt3); }
[data-theme="light"] .sidebar-footer { border-top-color:var(--border); }

/* ── Topbar ── */
[data-theme="light"] #topbar { background:rgba(255,255,255,.95); border-bottom-color:var(--border); }
[data-theme="light"] #pageTitle { color:var(--txt); }
[data-theme="light"] .breadcrumb { color:var(--txt3); }
[data-theme="light"] .icon-btn { background:var(--glass); border-color:var(--border); color:var(--txt2); }
[data-theme="light"] .icon-btn:hover { background:rgba(66,133,244,.10); color:#4285F4; border-color:rgba(66,133,244,.3); }
[data-theme="light"] .date-badge { background:var(--bg2); border-color:var(--border); color:var(--txt2); }
[data-theme="light"] .notif-dot { border-color:#fff; }
/* Theme toggle: glows Google Yellow when in light mode */
[data-theme="light"] #themeToggle { background:rgba(249,171,0,.10); border-color:rgba(249,171,0,.3); color:#E37400; }
[data-theme="light"] #themeToggle:hover { background:rgba(249,171,0,.18); }

/* ── Cards ── */
[data-theme="light"] .card { background:#fff; border-color:var(--border); box-shadow:var(--sh); }
[data-theme="light"] .card:hover { border-color:rgba(66,133,244,.3); box-shadow:var(--sh-teal); }
[data-theme="light"] .card-title { color:var(--txt); }
[data-theme="light"] .card-sub { color:var(--txt3); }

/* ── Stat Cards — each gets a Google color accent strip ── */
[data-theme="light"] .stat-card { background:#fff; border-color:var(--border); box-shadow:var(--sh); }
[data-theme="light"] .stat-card:hover { transform:translateY(-2px); box-shadow:var(--sh-teal); border-color:rgba(66,133,244,.3); }
[data-theme="light"] .stat-val { color:var(--txt); }
[data-theme="light"] .stat-lbl { color:var(--txt3); }
/* Google 4-color accent strips cycle through Blue→Green→Yellow→Red */
[data-theme="light"] .stats-grid .stat-card:nth-child(1)::after { background:linear-gradient(90deg,#4285F4,#1A73E8); opacity:1; }
[data-theme="light"] .stats-grid .stat-card:nth-child(2)::after { background:linear-gradient(90deg,#34A853,#1E8E3E); opacity:1; }
[data-theme="light"] .stats-grid .stat-card:nth-child(3)::after { background:linear-gradient(90deg,#FBBC05,#F9AB00); opacity:1; }
[data-theme="light"] .stats-grid .stat-card:nth-child(4)::after { background:linear-gradient(90deg,#EA4335,#D93025); opacity:1; }
[data-theme="light"] .stats-grid .stat-card:nth-child(5)::after { background:linear-gradient(90deg,#4285F4,#1A73E8); opacity:1; }
[data-theme="light"] .stats-grid .stat-card:nth-child(6)::after { background:linear-gradient(90deg,#34A853,#1E8E3E); opacity:1; }

/* ── Client Cards ── */
[data-theme="light"] .client-card { background:#fff; border-color:var(--border); box-shadow:var(--sh); }
[data-theme="light"] .client-card:hover { border-color:rgba(66,133,244,.35); box-shadow:var(--sh-teal); }
[data-theme="light"] .client-card::before { background:linear-gradient(90deg,#4285F4,#1A73E8); }
[data-theme="light"] .client-name { color:var(--txt); }
[data-theme="light"] .client-cause { color:var(--txt3); }
[data-theme="light"] .client-stat { background:rgba(0,0,0,.025); border-color:var(--border); }
[data-theme="light"] .cs-val { color:#4285F4; }
[data-theme="light"] .cs-lbl { color:var(--txt3); }
[data-theme="light"] .client-av { background:linear-gradient(135deg,#1558B0,#4285F4); }

/* ── Tables ── */
[data-theme="light"] .tbl-wrap { border-color:var(--border); box-shadow:var(--sh); }
[data-theme="light"] .dtbl thead th { background:var(--bg2); color:var(--txt3); border-bottom-color:var(--border); }
[data-theme="light"] .dtbl tbody td { color:var(--txt2); border-bottom-color:var(--border); }
[data-theme="light"] .dtbl tbody tr:hover { background:rgba(66,133,244,.03); }
[data-theme="light"] .t-name { color:var(--txt); }
[data-theme="light"] .t-sub { color:var(--txt3); }

/* ── Kanban ── */
[data-theme="light"] .k-hdr { background:var(--bg2); border-color:var(--border); }
[data-theme="light"] .k-title { color:var(--txt); }
[data-theme="light"] .k-count { background:rgba(66,133,244,.10); color:#4285F4; border-color:rgba(66,133,244,.25); }
[data-theme="light"] .k-card { background:#fff; border-color:var(--border); box-shadow:var(--sh); }
[data-theme="light"] .k-card:hover { border-color:rgba(66,133,244,.35); box-shadow:var(--sh-teal); }
[data-theme="light"] .k-card-name { color:var(--txt); }

/* ── Tabs ── */
[data-theme="light"] .tabs { background:var(--bg2); border-color:var(--border); }
[data-theme="light"] .tab-btn { color:var(--txt3); }
[data-theme="light"] .tab-btn:hover { color:var(--txt); background:rgba(66,133,244,.06); }
[data-theme="light"] .tab-btn.active { background:rgba(66,133,244,.12); color:#1558B0; border-color:rgba(66,133,244,.3); }

/* ── Filter & Search ── */
[data-theme="light"] .srch-in,[data-theme="light"] .f-select { background:#fff; border-color:var(--border); color:var(--txt); }
[data-theme="light"] .srch-in::placeholder { color:var(--txt3); }
[data-theme="light"] .srch-in:focus,[data-theme="light"] .f-select:focus { border-color:#4285F4; box-shadow:0 0 0 3px rgba(66,133,244,.12); }
[data-theme="light"] option { background:#fff; color:var(--txt); }

/* ── Forms ── */
[data-theme="light"] .form-input,[data-theme="light"] .form-select,[data-theme="light"] .form-textarea { background:var(--bg2); border-color:var(--border); color:var(--txt); }
[data-theme="light"] .form-input::placeholder,[data-theme="light"] .form-textarea::placeholder { color:var(--txt3); }
[data-theme="light"] .form-input:focus,[data-theme="light"] .form-select:focus,[data-theme="light"] .form-textarea:focus { border-color:#4285F4; background:#fff; box-shadow:0 0 0 3px rgba(66,133,244,.12); }
[data-theme="light"] .form-label { color:var(--txt2); }

/* ── Modal ── */
[data-theme="light"] .modal-overlay { background:rgba(32,33,36,.65); }
[data-theme="light"] .modal-box { background:#fff; border-color:var(--border); box-shadow:var(--sh-lg); }
[data-theme="light"] .modal-hdr { background:#fff; border-bottom-color:var(--border); }
[data-theme="light"] .modal-title { color:var(--txt); }
[data-theme="light"] .modal-close { background:rgba(0,0,0,.04); border-color:var(--border); color:var(--txt2); }
[data-theme="light"] .modal-close:hover { background:rgba(217,48,37,.08); color:#D93025; border-color:rgba(217,48,37,.2); }
[data-theme="light"] .modal-footer { border-top-color:var(--border); }
[data-theme="light"] .modal-body { color:var(--txt); }

/* ── Buttons ── */
[data-theme="light"] .btn-primary { background:linear-gradient(135deg,#4285F4,#1A73E8); color:#fff; box-shadow:0 2px 8px rgba(66,133,244,.3); }
[data-theme="light"] .btn-primary:hover { box-shadow:0 4px 16px rgba(66,133,244,.4); transform:translateY(-1px); }
[data-theme="light"] .btn-amber { background:linear-gradient(135deg,#E37400,#FBBC05); color:#fff; }
[data-theme="light"] .btn-ghost { background:rgba(0,0,0,.04); color:var(--txt2); border-color:var(--border); }
[data-theme="light"] .btn-ghost:hover { background:rgba(66,133,244,.08); color:#4285F4; border-color:rgba(66,133,244,.3); }
[data-theme="light"] .btn-danger { background:rgba(217,48,37,.08); color:#D93025; border-color:rgba(217,48,37,.2); }
[data-theme="light"] .btn-danger:hover { background:#D93025; color:#fff; }

/* ── Badges ── */
[data-theme="light"] .b-teal { background:rgba(66,133,244,.10); color:#1558B0; border-color:rgba(66,133,244,.25); }
[data-theme="light"] .b-green { background:rgba(30,142,62,.10); color:#1E8E3E; border-color:rgba(30,142,62,.25); }
[data-theme="light"] .b-red { background:rgba(217,48,37,.10); color:#D93025; border-color:rgba(217,48,37,.25); }
[data-theme="light"] .b-yellow { background:rgba(249,171,0,.10); color:#E37400; border-color:rgba(249,171,0,.25); }
[data-theme="light"] .b-amber { background:rgba(249,171,0,.10); color:#E37400; border-color:rgba(249,171,0,.25); }
[data-theme="light"] .b-blue { background:rgba(66,133,244,.10); color:#1558B0; border-color:rgba(66,133,244,.25); }
[data-theme="light"] .b-purple { background:rgba(147,52,234,.10); color:#7B1FA2; border-color:rgba(147,52,234,.25); }
[data-theme="light"] .b-muted { background:rgba(154,160,166,.10); color:var(--txt3); border-color:rgba(154,160,166,.2); }

/* ── Toast ── */
[data-theme="light"] .toast { background:#fff; border-color:var(--border); box-shadow:var(--sh-lg); color:var(--txt2); }

/* ── Progress ── */
[data-theme="light"] .prog-bar { background:rgba(0,0,0,.07); }

/* ── Stage Tracker ── */
[data-theme="light"] .st-dot { background:var(--bg2); border-color:var(--border2); color:var(--txt3); }
[data-theme="light"] .st-dot.done { background:#4285F4; border-color:#4285F4; color:#fff; }
[data-theme="light"] .st-dot.curr { background:rgba(249,171,0,.12); border-color:#F9AB00; color:#E37400; box-shadow:0 0 0 3px rgba(249,171,0,.2); }
[data-theme="light"] .st-line { background:var(--border2); }
[data-theme="light"] .st-line.done { background:#4285F4; }

/* ── Finance KPI ── */
[data-theme="light"] .fin-kpi { background:var(--bg2); border-color:var(--border); }
[data-theme="light"] .fin-kpi .val { color:#4285F4; }
[data-theme="light"] .fin-kpi .lbl { color:var(--txt3); }

/* ── Checklist ── */
[data-theme="light"] .chk-box { border-color:var(--border2); background:#fff; }
[data-theme="light"] .chk-box.checked { background:#4285F4; border-color:#4285F4; }
[data-theme="light"] .chk-label { color:var(--txt2); }
[data-theme="light"] .chk-label.done { color:var(--txt3); }

/* ── Detail View ── */
[data-theme="light"] .detail-item label { color:var(--txt3); }
[data-theme="light"] .detail-item p { color:var(--txt); }
[data-theme="light"] .detail-divider { border-top-color:var(--border); }

/* ── Activity & Deadlines ── */
[data-theme="light"] .activity-item { border-bottom-color:var(--border); }
[data-theme="light"] .act-body { color:var(--txt2); }
[data-theme="light"] .act-time { color:var(--txt3); }
[data-theme="light"] .dl-item { border-bottom-color:var(--border); }
[data-theme="light"] .dl-name { color:var(--txt); }
[data-theme="light"] .dl-day { color:#4285F4; }
[data-theme="light"] .dl-client { color:var(--txt3); }

/* ── Section headers ── */
[data-theme="light"] .sec-title { color:var(--txt); }
[data-theme="light"] .sec-sub { color:var(--txt3); }

/* ── Workload ── */
[data-theme="light"] .workload-row { border-bottom-color:var(--border); }
[data-theme="light"] .wl-name { color:var(--txt); }
[data-theme="light"] .wl-tasks { color:var(--txt3); }

/* ── Empty State ── */
[data-theme="light"] .empty-state { color:var(--txt3); }
[data-theme="light"] .empty-state h3 { color:var(--txt2); }

/* ── Scrollbar ── */
[data-theme="light"] ::-webkit-scrollbar-thumb { background:rgba(0,0,0,.15); }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background:#4285F4; }

/* ── Search results ── */
[data-theme="light"] #searchResults div:hover { background:rgba(66,133,244,.06)!important; }

/* ── Auth System ── */
.auth-overlay {
  position: fixed; top: 0; left: 0; width: 100vw; height: 100vh;
  background: radial-gradient(ellipse at center, var(--bg2) 0%, var(--bg) 100%);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
}
.auth-card {
  width: 100%; max-width: 400px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-xl); padding: 40px; text-align: center;
  box-shadow: var(--sh-lg);
}
.auth-logo {
  width: 54px; height: 54px; border-radius: 12px;
  background: linear-gradient(135deg, var(--teal), var(--teal-l));
  color: #fff; font-family: var(--f-head); font-weight: 800; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px; box-shadow: var(--sh-teal);
}
.auth-title { font-family: var(--f-head); font-size: 24px; font-weight: 700; color: var(--txt); margin-bottom: 6px; }
.auth-sub { font-size: 14px; color: var(--txt3); margin-bottom: 30px; }
.auth-form { text-align: left; }
.auth-form .form-group { margin-bottom: 20px; }
.auth-btn { width: 100%; justify-content: center; padding: 12px; font-size: 14px; font-weight: 600; }
.auth-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 18px 0; color: var(--txt3); font-size: 12px;
}
.auth-divider::before, .auth-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
@keyframes spin { to { transform: rotate(360deg); } }
.spin { animation: spin 0.8s linear infinite; display: inline-block; }
.req { color: var(--red); margin-left: 2px; }
/* ── Live Chat Widget ── */
.chat-widget {
  position: fixed; bottom: 20px; right: 20px; width: 320px; 
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r-lg) var(--r-lg) 0 0; z-index: 1000;
  box-shadow: var(--sh-lg); overflow: hidden; transition: var(--ease);
}
.chat-header {
  padding: 14px 16px; background: var(--teal); color: #fff;
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer; font-weight: 600; font-size: 13px;
}
.chat-status { width: 8px; height: 8px; border-radius: 50%; background: #4ADE80; border: 1px solid rgba(255,255,255,0.3); }
.chat-body { height: 380px; display: flex; flex-direction: column; background: var(--bg); }
.chat-msgs { flex: 1; padding: 16px; overflow-y: auto; display: flex; flex-direction: column; gap: 10px; }
.chat-msg { max-width: 80%; padding: 8px 12px; border-radius: var(--r); font-size: 13px; line-height: 1.4; }
.chat-msg.me { align-self: flex-end; background: var(--teal); color: #fff; border-bottom-right-radius: 2px; }
.chat-msg.them { align-self: flex-start; background: var(--bg3); color: var(--txt); border-bottom-left-radius: 2px; }
.chat-input-area { padding: 12px; border-top: 1px solid var(--border); display: flex; gap: 8px; background: var(--card); }
.chat-input-area input { flex: 1; border: 1px solid var(--border); background: var(--bg); color: var(--txt); padding: 8px 12px; border-radius: var(--r-sm); font-size: 12.5px; outline: none; }
.chat-input-area button { width: 34px; height: 34px; background: var(--teal); color: #fff; display: flex; align-items: center; justify-content: center; border-radius: var(--r-sm); }

/* ── Client Portal specific ── */
.portal-welcome { padding: 40px; text-align: center; background: radial-gradient(circle at top right, var(--teal-sub), transparent); border-radius: var(--r-xl); margin-bottom: 24px; border: 1px solid var(--border); }
.portal-welcome h2 { font-family: var(--f-head); font-size: 28px; color: var(--txt); margin-bottom: 8px; }
.portal-welcome p { color: var(--txt2); font-size: 15px; }
