/* =============================================
   AIO Finance — Complete Stylesheet
   ============================================= */

:root {
  --bg-base: #0f1117;
  --bg-card: #1a1d27;
  --bg-card-hover: #1e2130;
  --bg-sidebar: #13151f;
  --bg-input: #22263a;
  --accent: #6c63ff;
  --accent-light: #8b84ff;
  --accent-glow: rgba(108,99,255,0.25);
  --green: #22d3a1;
  --green-bg: rgba(34,211,161,0.1);
  --red: #ff4d6d;
  --red-bg: rgba(255,77,109,0.12);
  --yellow: #fbbf24;
  --yellow-bg: rgba(251,191,36,0.1);
  --blue: #38bdf8;
  --blue-bg: rgba(56,189,248,0.1);
  --orange: #fb923c;
  --orange-bg: rgba(251,146,60,0.1);
  --text-primary: #e8eaf0;
  --text-secondary: #8892a4;
  --text-muted: #555e73;
  --border: rgba(255,255,255,0.07);
  --border-focus: rgba(108,99,255,0.5);
  --radius: 12px;
  --radius-sm: 8px;
  --sidebar-w: 200px;
  --topbar-h: 56px;
  --shadow: 0 4px 24px rgba(0,0,0,0.4);
  --shadow-card: 0 2px 12px rgba(0,0,0,0.3);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg-base);color:var(--text-primary);line-height:1.5;min-height:100vh}
a{color:inherit;text-decoration:none}
img{max-width:100%}

/* ---- Layout ---- */
.app-wrapper{display:flex;min-height:100vh}

/* ---- Sidebar ---- */
.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:transform 0.3s ease;overflow-y:auto}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:16px 14px;border-bottom:1px solid var(--border);margin-bottom:6px}
.brand-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),var(--accent-light));border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;flex-shrink:0;box-shadow:0 4px 12px var(--accent-glow)}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-name{font-weight:700;font-size:0.88rem;color:var(--text-primary)}
.brand-sub{font-size:0.65rem;color:var(--text-muted)}
.sidebar-nav{padding:6px 10px 16px;display:flex;flex-direction:column;gap:2px}
.nav-section-label{font-size:0.6rem;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);padding:8px 8px 3px;margin-top:3px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:0.82rem;font-weight:500;transition:all 0.2s;cursor:pointer}
.nav-item i{width:16px;text-align:center;font-size:0.82rem}
.nav-item:hover{background:rgba(255,255,255,0.05);color:var(--text-primary)}
.nav-item.active{background:var(--accent-glow);color:var(--accent-light);border-left:3px solid var(--accent);padding-left:7px}
.nav-item-danger:hover{background:var(--red-bg);color:var(--red)}

/* ---- Main Content ---- */
.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{height:var(--topbar-h);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:14px;position:sticky;top:0;z-index:50}
.sidebar-toggle{background:none;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;padding:6px;border-radius:6px;transition:all 0.2s;display:none}
.sidebar-toggle:hover{color:var(--text-primary);background:rgba(255,255,255,0.06)}
.topbar-title{font-weight:600;font-size:0.95rem;color:var(--text-primary);flex:1}
.topbar-right{display:flex;align-items:center;gap:10px}
.user-badge{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:var(--text-secondary)}
.user-avatar{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--accent-light));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;color:#fff}
.page-body{padding:20px;flex:1}

/* ---- Cards ---- */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-card)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-title{font-size:0.88rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:7px}
.card-title i{color:var(--accent)}

/* ---- Tables ---- */
.table-wrapper{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:0.8rem}
thead tr{border-bottom:1px solid var(--border)}
thead th{text-align:left;padding:8px 12px;color:var(--text-muted);font-weight:600;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.05em;white-space:nowrap}
tbody tr{border-bottom:1px solid rgba(255,255,255,0.04);transition:background 0.15s}
tbody tr:hover{background:rgba(255,255,255,0.03)}
tbody td{padding:9px 12px;color:var(--text-secondary);vertical-align:middle}
.td-name{color:var(--text-primary);font-weight:500}
tr.row-expired td{background:rgba(255,77,109,0.04)}
tr.row-expiring td{background:rgba(251,191,36,0.04)}
.expiry-expired{color:var(--red)!important;font-weight:600}
.expiry-soon{color:var(--yellow)!important;font-weight:600}

/* ---- Badges ---- */
.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:0.68rem;font-weight:600}
.badge-red{background:var(--red-bg);color:var(--red)}
.badge-green{background:var(--green-bg);color:var(--green)}
.badge-yellow{background:var(--yellow-bg);color:var(--yellow)}
.badge-blue{background:var(--blue-bg);color:var(--blue)}
.badge-purple{background:var(--accent-glow);color:var(--accent-light)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:0.8rem;font-weight:500;cursor:pointer;border:none;transition:all 0.2s;text-decoration:none;white-space:nowrap;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}
.btn-primary:hover{background:var(--accent-light);transform:translateY(-1px)}
.btn-green{background:var(--green-bg);color:var(--green);border:1px solid rgba(34,211,161,0.2)}
.btn-green:hover{background:rgba(34,211,161,0.2)}
.btn-red{background:var(--red-bg);color:var(--red);border:1px solid rgba(255,77,109,0.2)}
.btn-red:hover{background:rgba(255,77,109,0.2)}
.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,0.05);color:var(--text-primary)}
.btn-sm{padding:5px 10px;font-size:0.75rem}
.btn-icon{padding:5px 7px}
.wa-btn{
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;border:none;border-radius:8px;
  padding:5px 11px;font-size:0.75rem;font-weight:600;
  cursor:pointer;transition:all 0.22s;text-decoration:none;
  display:inline-flex;align-items:center;gap:5px;
  box-shadow:0 2px 8px rgba(37,211,102,0.3);
  white-space:nowrap;
}
.wa-btn:hover{
  background:linear-gradient(135deg,#2be573,#25d366);
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(37,211,102,0.45);
}
.wa-btn:active{transform:translateY(0);box-shadow:0 2px 6px rgba(37,211,102,0.3)}
.wa-btn i{font-size:0.85rem}

/* ---- Forms ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-label{font-size:0.75rem;font-weight:500;color:var(--text-secondary)}
.form-control{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:8px 12px;border-radius:var(--radius-sm);font-size:0.83rem;font-family:inherit;transition:border-color 0.2s,box-shadow 0.2s;width:100%}
.form-control:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px rgba(108,99,255,0.12)}
.form-control::placeholder{color:var(--text-muted)}
select.form-control{cursor:pointer}
select.form-control option{background:var(--bg-card)}
textarea.form-control{resize:vertical;min-height:76px}

/* ---- Modal ---- */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);z-index:200}
.modal-overlay.show{display:block}
.modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;z-index:300;box-shadow:var(--shadow)}
.modal.show{display:block}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.modal-title{font-size:0.95rem;font-weight:600}
.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px;border-radius:4px;transition:all 0.2s}
.modal-close:hover{color:var(--text-primary);background:rgba(255,255,255,0.07)}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}

/* ---- Search ---- */
.search-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.search-input-wrap{position:relative;flex:1}
.search-input-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.8rem}
.search-input-wrap input{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:7px 12px 7px 32px;border-radius:var(--radius-sm);font-size:0.83rem;width:100%;font-family:inherit;transition:border-color 0.2s}
.search-input-wrap input:focus{outline:none;border-color:var(--border-focus)}

/* ---- Page Header ---- */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.page-header-left h1{font-size:1.25rem;font-weight:700;color:var(--text-primary)}
.page-header-left p{font-size:0.78rem;color:var(--text-secondary);margin-top:2px}

/* ---- Empty state ---- */
.empty-state{text-align:center;padding:32px 20px;color:var(--text-muted)}
.empty-state i{font-size:2rem;margin-bottom:10px;display:block}
.empty-state p{font-size:0.85rem}

/* ---- Alerts ---- */
.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:0.82rem;margin-bottom:14px}
.alert-error{background:var(--red-bg);color:var(--red);border:1px solid rgba(255,77,109,0.2)}
.alert-success{background:var(--green-bg);color:var(--green);border:1px solid rgba(34,211,161,0.2)}

/* ---- Toast ---- */
#toastContainer{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:9999}
.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;font-size:0.82rem;color:var(--text-primary);box-shadow:var(--shadow);animation:slideIn 0.3s ease;display:flex;align-items:center;gap:8px;min-width:220px}
.toast.success{border-left:3px solid var(--green)}
.toast.error{border-left:3px solid var(--red)}
@keyframes slideIn{from{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ---- Footer ---- */
.app-footer{text-align:center;padding:12px 20px;font-size:0.73rem;color:var(--text-muted);border-top:1px solid var(--border);background:var(--bg-sidebar)}
.app-footer a{color:var(--accent-light)}
.app-footer a:hover{text-decoration:underline}

/* ---- Birthday ---- */
.birthday-list{display:flex;flex-direction:column;gap:8px}
.birthday-item{display:flex;align-items:center;gap:12px;padding:9px 12px;background:var(--bg-base);border-radius:var(--radius-sm);border:1px solid var(--border)}
.birthday-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--orange));display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;color:#fff;flex-shrink:0}
.birthday-info{flex:1;min-width:0}
.birthday-name{font-size:0.83rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.birthday-meta{font-size:0.7rem;color:var(--text-muted);margin-top:2px}
.birthday-days{font-size:0.68rem;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}
.birthday-days.today{background:rgba(251,191,36,0.15);color:var(--yellow)}
.birthday-days.soon{background:var(--green-bg);color:var(--green)}

/* ---- Login ---- */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);position:relative;overflow:hidden}
.login-page::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(108,99,255,0.12) 0%,transparent 70%);top:-150px;left:-100px;pointer-events:none}
.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:36px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,0.5);position:relative;z-index:1}
.login-brand{text-align:center;margin-bottom:28px}
.login-logo{width:52px;height:52px;background:linear-gradient(135deg,var(--accent),var(--accent-light));border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;margin:0 auto 12px;box-shadow:0 8px 24px var(--accent-glow)}
.login-brand h1{font-size:1.2rem;font-weight:700;color:var(--text-primary)}
.login-brand p{font-size:0.78rem;color:var(--text-secondary);margin-top:3px}
.login-form .form-group{margin-bottom:14px}
.login-form .form-label{display:block;margin-bottom:5px}
.input-wrap{position:relative}
.input-wrap i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.85rem}
.input-wrap .form-control{padding-left:36px}
.input-wrap .toggle-pw{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:0.85rem;padding:4px}
.btn-login{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;border:none;padding:10px;border-radius:var(--radius-sm);font-size:0.9rem;font-weight:600;cursor:pointer;margin-top:6px;transition:all 0.2s;font-family:inherit;box-shadow:0 4px 16px var(--accent-glow)}
.btn-login:hover{transform:translateY(-1px);box-shadow:0 8px 20px var(--accent-glow)}

/* =============================================
   DASHBOARD STYLES
   ============================================= */

.db-welcome{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(120deg,rgba(108,99,255,0.14) 0%,rgba(34,211,161,0.07) 100%);border:1px solid rgba(108,99,255,0.22);border-radius:var(--radius);padding:16px 20px;margin-bottom:18px}
.db-welcome-title{font-size:1rem;font-weight:700;color:var(--text-primary)}
.db-welcome-title span{color:var(--accent-light)}
.db-welcome-sub{font-size:0.75rem;color:var(--text-secondary);margin-top:2px}

/* KPI Row - 4 columns, fixed height, no overflow */
.db-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.db-kpi{border-radius:var(--radius);border:1px solid var(--border);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;transition:all 0.25s;overflow:hidden;position:relative;min-height:0}
.db-kpi:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,0.25)}
.kpi-c1{background:linear-gradient(135deg,rgba(108,99,255,0.13),rgba(108,99,255,0.04));border-color:rgba(108,99,255,0.2)}
.kpi-c2{background:linear-gradient(135deg,rgba(255,77,109,0.13),rgba(255,77,109,0.04));border-color:rgba(255,77,109,0.2)}
.kpi-c3{background:linear-gradient(135deg,rgba(108,99,255,0.1),rgba(56,189,248,0.06));border-color:rgba(108,99,255,0.15)}
.kpi-c4{background:linear-gradient(135deg,rgba(56,189,248,0.13),rgba(56,189,248,0.04));border-color:rgba(56,189,248,0.2)}
.db-kpi-left{flex:1;min-width:0}
.db-kpi-label{font-size:0.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px}
.db-kpi-val{font-size:1.6rem;font-weight:800;color:var(--text-primary);line-height:1}
.db-kpi-sub{font-size:0.68rem;margin-top:5px;display:flex;align-items:center;gap:4px;color:var(--text-muted)}
.sub-red{color:var(--red)!important}
.sub-yellow{color:var(--yellow)!important}
.sub-green{color:var(--green)!important}

/* Sparkline - small and contained */
.db-kpi-spark{width:72px;height:36px;flex-shrink:0;margin-left:10px}
.db-kpi-spark svg{width:72px;height:36px;display:block}
.kpi-spark1{color:rgba(108,99,255,0.6)}
.kpi-spark2{color:rgba(255,77,109,0.6)}
.kpi-spark3{color:rgba(108,99,255,0.5)}
.kpi-spark4{color:rgba(56,189,248,0.6)}

/* Main grid - 3 columns */
.db-grid{display:grid;grid-template-columns:260px 1fr 240px;gap:16px}
.db-grid-col-left,.db-grid-col-mid,.db-grid-col-right{display:flex;flex-direction:column;gap:0;min-width:0}

/* Donut chart */
.db-donut-wrap{display:flex;align-items:center;gap:16px}
.db-donut-chart{width:100px;height:100px;flex-shrink:0}
.donut-svg{width:100px;height:100px;display:block}
.donut-num{font-size:7px;font-weight:800;fill:var(--text-primary);font-family:'Inter',sans-serif}
.donut-lbl{font-size:4px;fill:var(--text-muted);font-family:'Inter',sans-serif}
.db-donut-legend{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.donut-legend-item{display:flex;align-items:center;gap:7px;font-size:0.75rem;color:var(--text-secondary);text-decoration:none;transition:color 0.2s}
.donut-legend-item:hover{color:var(--text-primary)}
.donut-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.donut-lname{flex:1;font-size:0.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.donut-lval{font-weight:700;color:var(--text-primary);min-width:24px;text-align:right;font-size:0.75rem}
.donut-lpct{font-size:0.65rem;color:var(--text-muted);min-width:28px;text-align:right}

/* Quick Actions */
.quick-actions{display:flex;flex-direction:column;gap:5px}
.qa-btn{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:var(--radius-sm);background:var(--bg-base);border:1px solid var(--border);color:var(--text-secondary);font-size:0.78rem;font-weight:500;text-decoration:none;transition:all 0.2s;cursor:pointer}
.qa-btn:hover{background:rgba(255,255,255,0.04);color:var(--text-primary);border-color:rgba(108,99,255,0.3)}
.qa-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:0.8rem;flex-shrink:0}
.qa-btn span{flex:1}
.qa-btn .fa-chevron-right{font-size:0.6rem;color:var(--text-muted)}

/* Spacing between stacked cards */
.db-grid-col-left .card+.card,
.db-grid-col-mid .card+.card,
.db-grid-col-right .card+.card{margin-top:16px}

/* ---- Responsive ---- */
@media(max-width:1100px){
  .db-grid{grid-template-columns:1fr 1fr}
  .db-grid-col-right{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .db-grid-col-right .card+.card{margin-top:0}
}
@media(max-width:900px){
  .db-kpi-row{grid-template-columns:1fr 1fr}
  .db-grid{grid-template-columns:1fr}
  .db-grid-col-right{grid-column:1;display:flex;flex-direction:column}
  .db-grid-col-right .card+.card{margin-top:16px}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}
  .sidebar-toggle{display:flex}
}
@media(max-width:600px){
  .page-body{padding:14px}
  .db-kpi-row{grid-template-columns:1fr 1fr;gap:10px}
  .db-kpi-val{font-size:1.3rem}
  .db-kpi-spark{display:none}
  .db-welcome{flex-direction:column;gap:10px;align-items:flex-start}
  .form-grid{grid-template-columns:1fr}
  .modal{padding:16px}
  .login-card{padding:24px 18px}
}

/* =============================================
   NEW FEATURES — v5
   ============================================= */

/* Nav Badge */
.nav-badge{background:var(--red);color:#fff;font-size:0.6rem;font-weight:700;padding:1px 6px;border-radius:20px;margin-left:auto;min-width:18px;text-align:center}

/* Topbar Bell */
.topbar-bell{position:relative;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text-secondary);font-size:1rem;transition:all 0.2s;border:1px solid var(--border)}
.topbar-bell:hover{background:rgba(255,255,255,0.06);color:var(--text-primary)}
.bell-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:0.55rem;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-card)}

/* User name hide on small screens */
@media(max-width:768px){.user-name-text{display:none}}

/* Export Dropdown */
.export-dropdown{position:relative}
.export-menu{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:8px;min-width:200px;z-index:500;box-shadow:var(--shadow)}
.export-menu.open{display:block}
.export-menu-title{font-size:0.68rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted);padding:4px 8px 8px}
.export-menu a{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:6px;font-size:0.8rem;color:var(--text-secondary);transition:all 0.15s;text-decoration:none}
.export-menu a:hover{background:rgba(255,255,255,0.05);color:var(--text-primary)}
.export-divider{border-top:1px solid var(--border);margin:6px 0}

/* Notifications */
.notif-list{display:flex;flex-direction:column;gap:2px}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--radius-sm);transition:background 0.15s;border-bottom:1px solid var(--border)}
.notif-item:last-child{border-bottom:none}
.notif-unread{background:rgba(108,99,255,0.05)}
.notif-unread:hover{background:rgba(108,99,255,0.08)}
.notif-read{opacity:0.55}
.notif-read:hover{opacity:0.8;background:rgba(255,255,255,0.02)}
.notif-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;margin-top:2px}
.notif-body{flex:1;min-width:0}
.notif-msg{font-size:0.83rem;color:var(--text-primary);line-height:1.4}
.notif-meta{font-size:0.72rem;color:var(--text-muted);margin-top:4px;display:flex;align-items:center;gap:8px}

/* Client Notes */
.notes-section{margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.note-item{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:8px}
.note-text{font-size:0.83rem;color:var(--text-primary);line-height:1.5}
.note-meta{font-size:0.72rem;color:var(--text-muted);margin-top:5px}

/* Mobile Improvements */
@media(max-width:768px){
  /* Touch-friendly buttons */
  .btn{padding:9px 16px;font-size:0.83rem}
  .btn-sm{padding:7px 12px;font-size:0.78rem}
  .wa-btn{padding:7px 13px;font-size:0.8rem}
  /* Larger tap targets in table */
  tbody td{padding:11px 10px}
  thead th{padding:10px}
  /* Card padding */
  .card{padding:14px}
  /* Hide less important columns on mobile */
  .hide-mobile{display:none!important}
  /* Full width modals */
  .modal{width:96%;padding:18px;max-height:95vh}
  /* Topbar compact */
  .topbar{padding:0 14px}
  /* Export dropdown right-align fix */
  .export-menu{right:-60px}
}

/* Floating action button for mobile */
.fab{display:none;position:fixed;bottom:20px;right:20px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:1.3rem;cursor:pointer;box-shadow:0 6px 20px var(--accent-glow);z-index:150;align-items:center;justify-content:center;transition:all 0.2s}
.fab:hover{transform:scale(1.08)}
@media(max-width:768px){.fab{display:flex}}

/* Renewal date status colors in forms */
.renewal-status{font-size:0.75rem;margin-top:4px;display:flex;align-items:center;gap:5px;min-height:18px}

/* =============================================
   LIGHT THEME
   ============================================= */
[data-theme="light"] {
  --bg-base: #f4f5f9;
  --bg-card: #ffffff;
  --bg-card-hover: #f8f9fc;
  --bg-sidebar: #1a1d2e;
  --bg-input: #f0f2f8;
  --text-primary: #1a1d2e;
  --text-secondary: #4a5068;
  --text-muted: #8892a4;
  --border: rgba(0,0,0,0.08);
  --border-focus: rgba(108,99,255,0.4);
  --shadow-card: 0 2px 12px rgba(0,0,0,0.08);
  --shadow: 0 8px 30px rgba(0,0,0,0.12);
}
[data-theme="light"] .topbar { background: #fff; }
[data-theme="light"] .app-footer { background: #1a1d2e; color: rgba(255,255,255,0.5); }
[data-theme="light"] .app-footer a { color: #8b84ff; }
[data-theme="light"] .user-name-text { color: #4a5068; }

/* =============================================
   TOPBAR UPDATES
   ============================================= */
.topbar-search {
  flex: 1; max-width: 340px; position: relative;
  margin: 0 12px;
}
.topbar-search i {
  position: absolute; left: 11px; top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted); font-size: 0.8rem;
  pointer-events: none;
}
.topbar-search input {
  background: var(--bg-input); border: 1px solid var(--border);
  color: var(--text-primary); padding: 7px 12px 7px 32px;
  border-radius: 20px; font-size: 0.82rem; width: 100%;
  font-family: inherit; transition: all 0.2s;
}
.topbar-search input:focus { outline: none; border-color: var(--border-focus); background: var(--bg-card); }
.topbar-search input::placeholder { color: var(--text-muted); }
.topbar-btn {
  width: 34px; height: 34px; display: flex; align-items: center;
  justify-content: center; border-radius: 8px;
  color: var(--text-secondary); background: transparent;
  border: 1px solid var(--border); cursor: pointer;
  transition: all 0.2s; font-size: 0.9rem;
  gap: 5px; font-family: inherit;
}
.topbar-btn:hover { background: rgba(255,255,255,0.06); color: var(--text-primary); }
.topbar-btn.theme-btn { width: 34px; }
.hide-sm { display: none; }
@media(min-width:900px) { .hide-sm { display: inline; } .topbar-btn { width: auto; padding: 0 12px; } .topbar-btn.theme-btn { width: 34px; padding: 0; } }
@media(max-width:600px) { .topbar-search { max-width: 160px; } }

/* =============================================
   SEARCH PAGE
   ============================================= */
.search-hero { margin-bottom: 20px; }
.search-hero-wrap {
  display: flex; align-items: center; gap: 10px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 50px; padding: 8px 8px 8px 18px;
  box-shadow: var(--shadow-card);
  transition: box-shadow 0.2s;
}
.search-hero-wrap:focus-within { box-shadow: 0 0 0 3px var(--accent-glow); border-color: var(--border-focus); }
.search-hero-wrap i { color: var(--text-muted); font-size: 1rem; flex-shrink: 0; }
.search-hero-input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--text-primary); font-size: 1rem; font-family: inherit;
}
.search-hero-input::placeholder { color: var(--text-muted); }
.search-clear { color: var(--text-muted); padding: 4px 8px; border-radius: 50%; transition: all 0.2s; }
.search-clear:hover { background: var(--red-bg); color: var(--red); }
.search-results { display: flex; flex-direction: column; gap: 8px; }
.search-result-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 16px;
  transition: all 0.2s;
}
.search-result-item:hover { border-color: var(--accent); transform: translateX(3px); }
.sr-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
}
.sr-icon.badge-purple { background: var(--accent-glow); color: var(--accent-light); }
.sr-icon.badge-red    { background: var(--red-bg); color: var(--red); }
.sr-icon.badge-blue   { background: var(--blue-bg); color: var(--blue); }
.sr-icon.badge-green  { background: var(--green-bg); color: var(--green); }
.sr-body { flex: 1; min-width: 0; }
.sr-name { font-size: 0.92rem; font-weight: 600; color: var(--text-primary); }
.sr-name mark { background: rgba(108,99,255,0.2); color: var(--accent-light); border-radius: 3px; padding: 0 2px; }
.sr-meta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 4px; font-size: 0.75rem; color: var(--text-muted); }
.sr-right { display: flex; flex-direction: column; align-items: flex-end; flex-shrink: 0; }
.search-tips { padding: 8px 0; }
.st-title { font-size: 0.9rem; font-weight: 600; color: var(--text-primary); margin-bottom: 14px; }
.st-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 10px; }
.st-item { font-size: 0.82rem; color: var(--text-secondary); display: flex; align-items: center; gap: 10px; padding: 8px 12px; background: var(--bg-base); border-radius: var(--radius-sm); border: 1px solid var(--border); }
.st-tag { background: var(--accent-glow); color: var(--accent-light); padding: 2px 8px; border-radius: 20px; font-size: 0.7rem; font-weight: 600; flex-shrink: 0; }

/* =============================================
   ANALYTICS PAGE
   ============================================= */
.an-kpi-row { display: grid; grid-template-columns: repeat(5,1fr); gap: 12px; margin-bottom: 18px; }
.an-kpi { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; display: flex; align-items: center; gap: 12px; }
.an-kpi-icon { width: 38px; height: 38px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }
.an-kpi-val { font-size: 1.5rem; font-weight: 800; color: var(--text-primary); line-height: 1; }
.an-kpi-lbl { font-size: 0.7rem; color: var(--text-muted); margin-top: 3px; }
.an-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.an-full { grid-column: 1/-1; }
.an-legend { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); }
.an-leg-item { display: flex; align-items: center; gap: 6px; font-size: 0.78rem; color: var(--text-secondary); }
.an-leg-item span { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.an-leg-item b { color: var(--text-primary); }
@media(max-width:900px){ .an-kpi-row{grid-template-columns:repeat(3,1fr)} .an-grid{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .an-kpi-row{grid-template-columns:1fr 1fr} .an-grid{grid-template-columns:1fr} }

/* =============================================
   CLIENT PROFILE PAGE
   ============================================= */
.client-profile-header { display: flex; align-items: center; gap: 18px; margin-bottom: 18px; flex-wrap: wrap; }
.cp-avatar { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg,var(--accent),var(--orange)); display: flex; align-items: center; justify-content: center; font-size: 1.8rem; font-weight: 800; color: #fff; flex-shrink: 0; }
.cp-info { flex: 1; }
.cp-name { font-size: 1.3rem; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.cp-meta { display: flex; gap: 16px; flex-wrap: wrap; font-size: 0.82rem; color: var(--text-secondary); margin-bottom: 8px; }
.cp-meta i { margin-right: 4px; }
.cp-cats { display: flex; gap: 6px; flex-wrap: wrap; }
.cp-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.cp-detail-block { padding: 2px 0; }
.cp-detail-block + .cp-detail-block { border-top: 1px solid var(--border); margin-top: 12px; padding-top: 12px; }
.cp-detail-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; font-size: 0.82rem; border-bottom: 1px solid rgba(255,255,255,0.03); }
.cp-detail-row span:first-child { color: var(--text-muted); }
.cp-notes-card { grid-column: 1/-1; }
@media(max-width:700px){ .cp-grid{grid-template-columns:1fr} }

/* =============================================
   PASSWORD VAULT
   ============================================= */
.vault-field { display: flex; align-items: center; gap: 6px; }
.vault-masked { font-family: monospace; color: var(--text-muted); letter-spacing: 2px; font-size: 0.9rem; }
.vault-real { font-family: monospace; color: var(--text-primary); font-size: 0.82rem; word-break: break-all; }
.vault-eye, .vault-copy {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); font-size: 0.75rem; padding: 3px 5px;
  border-radius: 4px; transition: all 0.2s;
}
.vault-eye:hover { color: var(--accent-light); background: var(--accent-glow); }
.vault-copy:hover { color: var(--green); background: var(--green-bg); }

/* =============================================
   CALENDAR
   ============================================= */
.cal-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 14px; font-size: 0.78rem; color: var(--text-secondary); }
.cal-legend i { margin-right: 4px; }
.cal-card { padding: 12px; }
.cal-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 3px; }
.cal-header-cell { text-align: center; font-size: 0.7rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; padding: 6px 0; }
.cal-cell {
  min-height: 80px; background: var(--bg-base); border-radius: var(--radius-sm);
  border: 1px solid var(--border); padding: 5px 4px; position: relative;
  transition: all 0.15s;
}
.cal-cell:hover { border-color: var(--accent); }
.cal-empty { background: transparent; border-color: transparent; }
.cal-today { border-color: var(--accent) !important; background: rgba(108,99,255,0.06); }
.cal-has-expired { background: rgba(255,77,109,0.04); }
.cal-day-num { font-size: 0.72rem; font-weight: 600; color: var(--text-secondary); margin-bottom: 3px; }
.cal-today .cal-day-num { color: var(--accent-light); font-weight: 700; }
.cal-event {
  display: flex; align-items: center; gap: 3px;
  font-size: 0.62rem; color: var(--text-secondary);
  background: var(--bg-card); border-radius: 3px;
  padding: 2px 4px; margin-bottom: 2px; overflow: hidden;
}
.cal-event-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.cal-wa { color: #25d366; font-size: 0.62rem; flex-shrink: 0; opacity: 0; transition: opacity 0.2s; }
.cal-cell:hover .cal-wa { opacity: 1; }
.cal-more { font-size: 0.6rem; color: var(--text-muted); text-align: right; margin-top: 2px; }
@media(max-width:700px){
  .cal-cell { min-height: 54px; }
  .cal-event-name { display: none; }
  .cal-event { padding: 2px; justify-content: center; }
}

/* =============================================
   USER DROPDOWN MENU
   ============================================= */
.user-dropdown { position: relative; }
.user-badge {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.82rem; color: var(--text-secondary);
  cursor: pointer; padding: 4px 8px; border-radius: 8px;
  transition: background 0.2s; user-select: none;
}
.user-badge:hover { background: rgba(255,255,255,0.06); }

.user-menu {
  display: none; position: absolute; top: calc(100% + 10px); right: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 8px;
  min-width: 210px; z-index: 600;
  box-shadow: 0 12px 40px rgba(0,0,0,0.35);
  animation: menuFadeIn 0.18s ease;
}
.user-menu.open { display: block; }
@keyframes menuFadeIn {
  from { opacity:0; transform:translateY(-8px); }
  to   { opacity:1; transform:translateY(0); }
}
.user-menu-header {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 10px 12px;
}
.user-menu-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg,var(--accent),var(--accent-light));
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem; font-weight: 700; color: #fff; flex-shrink: 0;
}
.user-menu-divider { border-top: 1px solid var(--border); margin: 5px 0; }
.user-menu-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; border-radius: var(--radius-sm);
  font-size: 0.82rem; color: var(--text-secondary);
  text-decoration: none; transition: all 0.15s; cursor: pointer;
}
.user-menu-item i { width: 16px; text-align: center; font-size: 0.85rem; }
.user-menu-item:hover { background: rgba(255,255,255,0.05); color: var(--text-primary); }
.user-menu-danger:hover { background: var(--red-bg); color: var(--red); }

/* =============================================
   BIRTHDAY WISH BUTTON — special style
   ============================================= */
.wa-btn-bday {
  background: linear-gradient(135deg,#fb923c,#f59e0b) !important;
  box-shadow: 0 2px 8px rgba(251,146,60,0.35) !important;
}
.wa-btn-bday:hover {
  background: linear-gradient(135deg,#f97316,#fb923c) !important;
  box-shadow: 0 4px 14px rgba(251,146,60,0.5) !important;
}

/* =============================================
   NOTIFY BUTTON — for expiry alerts
   ============================================= */
.wa-btn-notify {
  background: linear-gradient(135deg,#6c63ff,#8b84ff) !important;
  box-shadow: 0 2px 8px rgba(108,99,255,0.35) !important;
}
.wa-btn-notify:hover {
  box-shadow: 0 4px 14px rgba(108,99,255,0.5) !important;
  transform: translateY(-1px);
}

/* Pulse animation for expired items */
.wa-btn-urgent {
  background: linear-gradient(135deg,#ff4d6d,#ff6b6b) !important;
  box-shadow: 0 2px 8px rgba(255,77,109,0.35) !important;
  animation: urgentPulse 2s infinite;
}
@keyframes urgentPulse {
  0%,100% { box-shadow: 0 2px 8px rgba(255,77,109,0.35); }
  50%      { box-shadow: 0 4px 18px rgba(255,77,109,0.6); }
}

/* =============================================
   TOPBAR SEARCH SHORTCUT HINT
   ============================================= */
.search-kbd {
  font-size: 0.65rem; background: var(--bg-input);
  border: 1px solid var(--border); border-radius: 4px;
  padding: 1px 5px; color: var(--text-muted);
  position: absolute; right: 10px; top: 50%;
  transform: translateY(-50%); pointer-events: none;
}
@media(max-width:768px){ .search-kbd{display:none} }
