/* ================================================================
   layout.css — App Shell, Navbar, Sidebar & Page Layout
   DomainOS Control Center
================================================================ */
/* ── Page Load Overlay ───────────────────────────────────── */
#page-load-overlay{position:fixed;inset:0;z-index:99999;background:linear-gradient(135deg,#060a14 0%,#0d1631 50%,#060a14 100%);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;transition:opacity .3s ease;}
#page-load-overlay.fade-out{opacity:0;pointer-events:none;}
.plo-spinner{width:38px;height:38px;border:3px solid rgba(99,102,241,0.2);border-top-color:#6366f1;border-radius:50%;animation:plo-spin .7s linear infinite;}
@keyframes plo-spin{to{transform:rotate(360deg)}}
.plo-text{font-size:13px;color:rgba(255,255,255,0.45);letter-spacing:.5px;}



/* ── APP SHELL: hidden until authenticated ── */
.navbar,.sidebar,.main{visibility:hidden;opacity:0;}
.app-ready .navbar,.app-ready .sidebar,.app-ready .main{visibility:visible;opacity:1;transition:opacity .25s ease;}
body:not(.app-ready) .navbar{visibility:hidden;opacity:0;}
body:not(.app-ready) .sidebar{visibility:hidden;opacity:0;}
body:not(.app-ready) .main{visibility:hidden;opacity:0;}
/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);background:rgba(255,255,255,0.97);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px 0 0;box-shadow:0 1px 12px rgba(30,58,138,0.07);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);will-change:transform;visibility:hidden;opacity:0;}
.nav-logo{width:var(--sidebar-w);display:flex;align-items:center;gap:10px;padding:0 20px;flex-shrink:0;}
.logo-mark{width:34px;height:34px;background:linear-gradient(135deg,var(--primary),var(--cyan));border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-weight:800;color:#fff;font-size:13px;box-shadow:0 3px 10px rgba(30,58,138,0.3);}
.logo-text{font-family:'Inter',sans-serif;font-weight:700;font-size:17px;color:var(--primary);}
.logo-text span{color:var(--cyan);}
.nav-center{flex:1;display:flex;align-items:center;padding:0 20px;}
.nav-search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:9px 16px;width:300px;transition:border-color .2s,box-shadow .2s;}
.nav-search:focus-within{border-color:var(--primary-light);box-shadow:0 0 0 3px rgba(59,130,246,0.1);}
.nav-search input{border:none;background:none;outline:none;font-family:'Inter',sans-serif;font-size:13px;color:var(--text);width:100%;}
.nav-search input::placeholder{color:var(--text-faint);}
.nav-actions{display:flex;align-items:center;gap:8px;margin-left:auto;}
.nav-notif-btn{position:relative;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:16px;background:var(--card);transition:all .2s;}
.nav-notif-btn:hover{border-color:var(--amber);color:var(--amber);background:#FFFBEB;}
.notif-badge{position:absolute;top:-5px;right:-5px;width:19px;height:19px;background:linear-gradient(135deg,#DC2626,var(--red));border-radius:50%;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;border:2px solid var(--card);box-shadow:0 2px 4px rgba(239,68,68,0.4);}
.nav-avatar{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--cyan));display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:13px;cursor:pointer;box-shadow:0 3px 8px rgba(30,58,138,0.25);}

/* NOTIFICATION PANEL */
.notif-panel{position:fixed;top:calc(var(--nav-h) + 8px);right:20px;width:30%;max-width:380px;min-width:280px;font-size:9px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:150;display:none;}
.notif-panel.open{display:block;}
.notif-panel-hdr{padding:8px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.notif-panel-title{font-family:'Inter',sans-serif;font-weight:700;font-size:11px;}
.notif-panel-close{cursor:pointer;color:var(--text-muted);font-size:12px;}
.notif-item{padding:10px 14px;border-bottom:1px solid #F1F5F9;display:flex;gap:8px;align-items:flex-start;cursor:pointer;transition:background .15s;}
.notif-item:hover{background:var(--bg);}
.notif-item:last-child{border-bottom:none;}
.notif-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:3px;}
.notif-dot.red{background:var(--red);}
.notif-dot.amber{background:var(--amber);}
.notif-dot.cyan{background:var(--cyan);}
.notif-dot.blue{background:#6366F1;}
.notif-title{font-size:10px;font-weight:500;color:var(--text);}
.notif-sub{font-size:9px;color:var(--text-muted);margin-top:1px;}
.notif-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:10px;}

/* SIDEBAR */
/* ── SIDEBAR ── */
.sidebar{
  position:fixed;top:var(--nav-h);left:0;bottom:0;width:var(--sidebar-w);
  background:#050D1A;
  background:linear-gradient(160deg,#071020 0%,#050D1A 40%,#030810 100%);
  z-index:90;display:flex;flex-direction:column;overflow:hidden;
  transition:width .3s ease;
  box-shadow:4px 0 28px rgba(0,0,0,0.28),inset -1px 0 0 rgba(255,255,255,0.06);
  -webkit-transform:translateZ(0);transform:translateZ(0);
  visibility:hidden;opacity:0;font-family:'Inter',sans-serif;
}
/* top cyan accent bar */
.sidebar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#2563EB,#06B6D4,#2563EB);
  opacity:0.9;pointer-events:none;
}
.sidebar.collapsed{width:64px;}

/* ── NAV SCROLL AREA ── */
.sidebar-nav{flex:1;padding:8px 10px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.15) transparent;}
.sidebar-nav::-webkit-scrollbar{width:3px;}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:3px;}
.sidebar-section{margin-bottom:8px;}

/* ── SECTION LABELS ── */
.sidebar-label{
  font-size:9.5px;font-weight:700;letter-spacing:2px;
  color:rgba(255,255,255,0.45);
  text-transform:uppercase;padding:4px 14px 4px;
  white-space:nowrap;overflow:hidden;font-family:'Inter',sans-serif;
}
.sidebar.collapsed .sidebar-label{opacity:0;}

/* ── NAV ITEMS — default ── */
.nav-item{
  display:flex;align-items:center;gap:9px;padding:7px 11px;
  border-radius:10px;cursor:pointer;transition:all .18s ease;
  color:rgba(255,255,255,0.72);
  font-size:12.5px;font-weight:500;white-space:nowrap;
  margin-bottom:2px;position:relative;font-family:'Inter',sans-serif;
}

/* ── HOVER ── */
.nav-item:hover{
  background:rgba(255,255,255,0.11);
  color:#fff;
}
.nav-item:hover .icon{opacity:1;transform:scale(1.1);}

/* ── ACTIVE ── */
.nav-item.active{
  background:linear-gradient(135deg,rgba(37,99,235,0.55) 0%,rgba(6,182,212,0.35) 100%);
  color:#fff;
  font-weight:600;
  box-shadow:inset 0 0 0 1px rgba(96,165,250,0.35),0 2px 8px rgba(0,0,0,0.2);
}
.nav-item.active::before{
  content:'';position:absolute;left:0;top:50%;
  transform:translateY(-50%);
  width:4px;height:65%;
  background:linear-gradient(180deg,#60A5FA,#22D3EE);
  border-radius:0 4px 4px 0;
}
.nav-item .icon{font-size:16px;flex-shrink:0;width:20px;display:flex;justify-content:center;opacity:0.8;transition:all .18s;}
.nav-item span,.nav-item svg,.nav-item i,.nav-item .icon{pointer-events:none;}
.nav-item.active .icon{opacity:1;}
.sidebar.collapsed .nav-item .label{opacity:0;width:0;overflow:hidden;}

/* ── SIDEBAR QUICK-ADD (+) BUTTONS ── */
.sidebar-quick-add {
  pointer-events: auto !important;
  display: none;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  margin-left: auto;
  border-radius: 6px;
  background: rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.7);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: all 0.15s ease;
  flex-shrink: 0;
}
.nav-item:hover .sidebar-quick-add {
  display: flex;
}
.sidebar-quick-add:hover {
  background: #fff;
  color: var(--primary);
  transform: scale(1.1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.sidebar.collapsed .sidebar-quick-add {
  display: none !important;
}
/* Fixed nav-item height to prevent shifting */
.sidebar-nav .nav-item {
  height: 34px;
  min-height: 34px;
  max-height: 34px;
  box-sizing: border-box;
}

/* ── FOOTER & COLLAPSE ── */
.sidebar-footer{padding:12px 10px;border-top:1px solid rgba(255,255,255,0.1);}
.collapse-btn{
  display:flex;align-items:center;gap:10px;padding:10px 13px;
  border-radius:10px;cursor:pointer;
  color:rgba(255,255,255,0.5);
  font-size:13px;transition:all .18s;white-space:nowrap;font-family:'Inter',sans-serif;
}
.collapse-btn:hover{color:#fff;background:rgba(255,255,255,0.1);}
.collapse-btn .icon{font-size:16px;flex-shrink:0;width:20px;text-align:center;}
.sidebar.collapsed .collapse-btn .clabel{opacity:0;}

/* MAIN */
.main{margin-left:var(--sidebar-w);margin-top:var(--nav-h);padding:28px 32px 60px;min-height:calc(100vh - var(--nav-h));transition:margin-left .3s ease;}
.main:has(#page-billing.active){padding-bottom:0;}
.main.expanded{margin-left:64px;}
.page{display:none;}
.page.active{display:block;}
#page-notes.active{display:flex;flex-direction:column;}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:12px;}
.page-title{font-family:'Inter',sans-serif;font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.6px;}
.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px;}
.header-actions{display:flex;gap:8px;flex-wrap:wrap;}

/* ALERT BANNER */
.alert-banner{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:12px;margin-bottom:14px;font-size:13px;}
.alert-banner.critical{background:linear-gradient(135deg,#FEF2F2,#FFF5F5);border:1px solid #FECACA;color:#991B1B;box-shadow:0 2px 8px rgba(239,68,68,0.1);}
.alert-banner.warning{background:linear-gradient(135deg,#FFFBEB,#FFFEF0);border:1px solid #FDE68A;color:#92400E;box-shadow:0 2px 8px rgba(245,158,11,0.1);}
.alert-banner.info{background:linear-gradient(135deg,#EFF6FF,#F5F9FF);border:1px solid #BFDBFE;color:#1E40AF;box-shadow:0 2px 8px rgba(30,58,138,0.08);}
.alert-icon{font-size:18px;flex-shrink:0;}
.alert-text{flex:1;}
.alert-title{font-weight:600;}
.alert-sub{font-size:11px;margin-top:2px;opacity:.8;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:9px;font-family:'Inter',sans-serif;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .2s;white-space:nowrap;}
.btn-primary{background:linear-gradient(135deg,var(--primary),#2563EB);color:#fff;box-shadow:0 3px 10px rgba(30,58,138,0.28);}
.btn-primary:hover{background:linear-gradient(135deg,var(--primary-mid),#3B82F6);box-shadow:0 5px 14px rgba(30,58,138,0.35);}
.btn-outline{background:var(--card);color:var(--text-mid);border:1px solid var(--border-strong);}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:#EFF6FF;}
.btn-sm{padding:6px 13px;font-size:12px;}
.btn-danger{background:linear-gradient(135deg,#DC2626,var(--red));color:#fff;box-shadow:0 3px 8px rgba(239,68,68,0.28);}
.btn-success{background:linear-gradient(135deg,#047857,var(--emerald));color:#fff;}

/* CARD */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);}

/* AVATAR */
.mini-avatar{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;flex-shrink:0;box-shadow:0 2px 6px rgba(30,58,138,0.2);}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px;}
.kpi-card{border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;border:1.5px solid var(--border);background:var(--card);color:var(--text);}
.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.kpi-card.blue{background:linear-gradient(135deg,#1E3A8A 0%,#2563EB 100%);color:#fff;border-color:rgba(255,255,255,0.1);}
.kpi-card.cyan{background:linear-gradient(135deg,#0369A1 0%,#06B6D4 100%);color:#fff;border-color:rgba(255,255,255,0.1);}
.kpi-card.emerald{background:linear-gradient(135deg,#065F46 0%,#10B981 100%);color:#fff;border-color:rgba(255,255,255,0.1);}
.kpi-card.red{background:linear-gradient(135deg,#991B1B 0%,#EF4444 100%);color:#fff;border-color:rgba(255,255,255,0.1);}
.kpi-card::after{content:'';position:absolute;bottom:-16px;right:-16px;width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,0.07);}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;}
.kpi-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;background:rgba(255,255,255,0.18);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);}
.kpi-card:not([class*="blue"]):not([class*="cyan"]):not([class*="emerald"]):not([class*="red"]):not([style*="background:linear"]) .kpi-icon{background:var(--bg);border:1px solid var(--border);}
.kpi-val{font-family:'Inter',sans-serif;font-size:26px;font-weight:800;letter-spacing:-1px;color:#fff;line-height:1;margin-bottom:3px;}
.kpi-card:not([class*="blue"]):not([class*="cyan"]):not([class*="emerald"]):not([class*="red"]):not([style*="background:linear"]) .kpi-val{color:var(--text);}
.kpi-label{font-size:11px;color:rgba(255,255,255,0.72);font-weight:500;letter-spacing:.2px;}
.kpi-card:not([class*="blue"]):not([class*="cyan"]):not([class*="emerald"]):not([class*="red"]):not([style*="background:linear"]) .kpi-label{color:var(--text-muted);}

/* TABLE */
.table-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:visible;}
.table-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;}
.table-title{font-family:'Inter',sans-serif;font-weight:700;font-size:14.5px;color:var(--text);}
table{width:100%;border-collapse:collapse;}
thead th{padding:12px 18px;background:linear-gradient(to bottom,#F8FAFD,#F1F5FB);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;}
tbody td{padding:14px 18px;font-size:13px;color:var(--text-mid);border-bottom:1px solid #F1F5FA;vertical-align:middle;}
tbody tr:last-child td{border-bottom:none;}
tbody tr{transition:background .12s;}
tbody tr:hover td{background:linear-gradient(to right,rgba(30,58,138,0.03),rgba(6,182,212,0.02));}
.td-domain{font-family:'DM Mono',monospace;font-size:12.5px;color:var(--primary);font-weight:600;}
.td-customer{display:flex;align-items:center;gap:8px;}
.td-date{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-muted);}
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted);}
.empty-state .empty-icon{font-size:40px;margin-bottom:12px;}
.empty-state h3{font-family:'Inter',sans-serif;font-size:16px;color:var(--text-mid);margin-bottom:6px;}

/* PAGINATION */
.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-top:1px solid var(--border);flex-wrap:wrap;gap:8px;background:linear-gradient(to bottom,#FAFBFD,#F8FAFC);}
.pag-info{font-size:12px;color:var(--text-muted);}
.pag-controls{display:flex;align-items:center;gap:6px;}
.pag-btn{padding:6px 14px;border-radius:8px;border:1px solid var(--border-strong);background:var(--card);font-size:12px;color:var(--text-mid);cursor:pointer;transition:all .15s;font-family:'Inter',sans-serif;box-shadow:var(--shadow-sm);}
.pag-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:#EFF6FF;}
.pag-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none;}
.pag-btn.active{background:linear-gradient(135deg,var(--primary),#2563EB);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px rgba(30,58,138,0.3);}
.pag-size{padding:6px 10px;border-radius:8px;border:1px solid var(--border-strong);background:var(--card);font-size:12px;color:var(--text-mid);cursor:pointer;font-family:'Inter',sans-serif;outline:none;box-shadow:var(--shadow-sm);}

/* BADGE */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:.1px;}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.badge-active{background:linear-gradient(135deg,rgba(16,185,129,0.12),rgba(5,150,105,0.08));color:#047857;border:1px solid rgba(16,185,129,0.25);}
.badge-active::before{background:var(--emerald);box-shadow:0 0 0 2px rgba(16,185,129,0.2);}
.badge-expiring{background:linear-gradient(135deg,rgba(245,158,11,0.12),rgba(217,119,6,0.08));color:#B45309;border:1px solid rgba(245,158,11,0.25);}
.badge-expiring::before{background:var(--amber);box-shadow:0 0 0 2px rgba(245,158,11,0.2);}
.badge-suspended{background:linear-gradient(135deg,rgba(239,68,68,0.12),rgba(220,38,38,0.08));color:#DC2626;border:1px solid rgba(239,68,68,0.25);}
.badge-suspended::before{background:var(--red);box-shadow:0 0 0 2px rgba(239,68,68,0.2);}
.badge-new{background:linear-gradient(135deg,rgba(6,182,212,0.12),rgba(8,145,178,0.08));color:#0891B2;border:1px solid rgba(6,182,212,0.25);}
.badge-new::before{background:var(--cyan);box-shadow:0 0 0 2px rgba(6,182,212,0.2);}

/* CONTROLS */
.controls-bar{display:flex;align-items:center;gap:8px;margin-bottom:20px;flex-wrap:wrap;}
.search-box{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border-strong);border-radius:10px;padding:9px 16px;flex:1;min-width:200px;max-width:320px;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s;}
.search-box:focus-within{border-color:var(--primary-light);box-shadow:0 0 0 3px rgba(59,130,246,0.1);}
.search-box input{border:none;background:none;outline:none;font-size:13px;color:var(--text);font-family:'Inter',sans-serif;width:100%;}
.select-filter{background:var(--card);border:1px solid var(--border-strong);border-radius:10px;padding:9px 14px;font-size:13px;color:var(--text-mid);font-family:'Inter',sans-serif;cursor:pointer;outline:none;box-shadow:var(--shadow-sm);}
.action-group{display:flex;gap:5px;}
.icon-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:13px;color:var(--text-muted);transition:all .15s;box-shadow:var(--shadow-sm);}
.icon-btn:hover{border-color:var(--primary);color:var(--primary);background:#EFF6FF;box-shadow:var(--shadow);}
.icon-btn.danger:hover{border-color:var(--red);color:var(--red);background:#FEF2F2;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,0.55);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.modal-overlay.modal-top{z-index:10000;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--card);border-radius:var(--radius-lg);padding:30px;width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:translateY(12px);transition:transform .25s;border:1px solid var(--border);}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-title{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;color:var(--text);margin-bottom:22px;display:flex;justify-content:space-between;align-items:center;}
.modal-close{cursor:pointer;color:var(--text-muted);font-size:18px;flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:7px;transition:all .15s;}
.modal-close:hover{background:var(--bg);color:var(--text);}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:24px;padding-top:18px;border-top:1px solid var(--border);}

/* FORM */
.form-group{margin-bottom:14px;}
.form-label{font-size:12px;font-weight:600;color:var(--text-mid);margin-bottom:6px;display:block;letter-spacing:.1px;}
.form-input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border-strong);border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s;}
.form-input:focus{border-color:var(--primary);background:var(--card-bg,var(--bg));box-shadow:0 0 0 3px rgba(59,130,246,0.1);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grid .full{grid-column:1/-1;}
.form-section-title{font-family:'Inter',sans-serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.phone-input-wrap{display:flex;align-items:center;border:1px solid var(--border-strong);border-radius:9px;background:var(--bg);overflow:hidden;transition:border-color .2s,box-shadow .2s;}
.phone-input-wrap:focus-within{border-color:var(--primary);background:var(--card-bg,var(--bg));box-shadow:0 0 0 3px rgba(59,130,246,0.1);}
.phone-prefix{padding:10px 12px;font-size:13px;font-weight:600;color:var(--primary);background:var(--primary-glow);border-right:1px solid var(--border-strong);white-space:nowrap;}
.phone-input-wrap input{border:none;background:none;outline:none;padding:10px 14px;font-size:13px;font-family:'Inter',sans-serif;color:var(--text);width:100%;}
.custom-fields-wrap{border:1px dashed var(--border-strong);border-radius:9px;padding:14px;}
.cf-item{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-bottom:8px;align-items:center;}
.cf-item input{padding:7px 12px;border:1px solid var(--border-strong);border-radius:7px;font-size:12px;background:var(--bg);outline:none;font-family:'Inter',sans-serif;color:var(--text);}
.cf-item input:focus{border-color:var(--primary);background:var(--card-bg,var(--bg));}
.cf-remove{width:30px;height:30px;border-radius:7px;background:var(--red-light);color:var(--red);border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.cf-remove:hover{background:var(--red);color:#fff;}

/* PROGRESS */
.progress-bar{height:6px;background:var(--bg);border-radius:10px;overflow:hidden;margin-top:8px;}
.progress-fill{height:100%;border-radius:10px;}

/* PROFILE DROPDOWN */
.profile-dropdown{position:fixed;top:calc(var(--nav-h) + 8px);right:12px;width:240px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:150;display:none;}
.profile-dropdown.open{display:block;}
.profile-dd-hdr{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.profile-dd-name{font-family:'Inter',sans-serif;font-weight:700;font-size:14px;color:var(--text);}
.profile-dd-email{font-size:11px;color:var(--text-muted);margin-top:1px;}
.profile-dd-item{display:flex;align-items:center;gap:10px;padding:11px 18px;cursor:pointer;font-size:13px;color:var(--text-mid);transition:background .15s;}
.profile-dd-item:hover{background:var(--bg);color:var(--primary);}
.profile-dd-item .pd-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0;}
.profile-dd-sep{height:1px;background:var(--border);margin:4px 0;}
.profile-dd-item.danger{color:var(--red);}
.profile-dd-item.danger:hover{background:#FEF2F2;color:var(--red);}
.toast-container{position:fixed;bottom:28px;right:28px;z-index:999999;display:flex;flex-direction:column;gap:8px;}
.toast{background:#0F172A;color:#fff;padding:13px 20px;border-radius:12px;font-size:13px;display:flex;align-items:center;gap:10px;box-shadow:0 8px 30px rgba(0,0,0,0.25);animation:slideUp .3s ease;max-width:330px;border:1px solid rgba(255,255,255,0.08);}
.toast.success{border-left:3px solid var(--emerald);}
.toast.error{border-left:3px solid var(--red);}
.toast.info{border-left:3px solid var(--cyan);}
@keyframes slideUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}

/* DETAIL */
.detail-header{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.detail-left{display:flex;align-items:center;gap:20px;}
.detail-icon{width:56px;height:56px;border-radius:14px;background:var(--primary-glow);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;}
.detail-name{font-family:'Inter',sans-serif;font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px;}
.detail-meta{display:flex;gap:16px;margin-top:8px;flex-wrap:wrap;}
.detail-meta-item{font-size:12px;color:var(--text-muted);}

/* TABS */
.tabs{display:flex;gap:2px;margin-bottom:20px;border-bottom:1px solid var(--border);overflow-x:auto;}
.tab{padding:10px 18px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;white-space:nowrap;}
.tab:hover{color:var(--primary);}
.tab.active{color:var(--primary);border-bottom-color:var(--primary);}

/* SETTINGS */
.settings-grid{display:grid;grid-template-columns:220px 1fr;gap:20px;}
.settings-nav{display:flex;flex-direction:column;gap:2px;}
.settings-nav-item{padding:9px 14px;border-radius:8px;font-size:13px;cursor:pointer;color:var(--text-muted);transition:all .15s;}
.settings-nav-item:hover{background:var(--bg);color:var(--text);}
.settings-nav-item.active{background:var(--primary-glow);color:var(--primary);font-weight:500;}

/* TOGGLE */
.sw-track{width:38px;height:20px;border-radius:10px;background:var(--border-strong);cursor:pointer;position:relative;transition:background .2s;display:inline-block;}
.sw-track.on{background:var(--emerald);}
.sw-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,0.2);}
.sw-track.on .sw-thumb{left:20px;}

/* INFO GRID */
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.info-item{background:var(--bg);border-radius:8px;padding:12px 14px;}
.info-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);margin-bottom:4px;}
.info-val{font-size:13px;color:var(--text);font-weight:500;}

/* TIMELINE */
.tl-item{display:flex;gap:16px;margin-bottom:20px;position:relative;}
.tl-item:not(:last-child)::after{content:'';position:absolute;left:15px;top:32px;width:2px;height:calc(100% + 4px);background:var(--border);}
.tl-dot{width:32px;height:32px;border-radius:50%;background:var(--primary-glow);border:2px solid var(--primary);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;z-index:1;}
.tl-content{flex:1;}
.tl-title{font-size:13px;font-weight:500;color:var(--text);}
.tl-date{font-size:11px;color:var(--text-muted);margin-top:2px;font-family:'DM Mono',monospace;}

/* CUSTOMER HERO */
.customer-hero{background:linear-gradient(135deg,var(--primary) 0%,#1e4db7 60%,var(--cyan) 100%);border-radius:var(--radius-lg);padding:28px;margin-bottom:20px;color:#fff;position:relative;}
.customer-hero::after{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);pointer-events:none;overflow:hidden;}
.customer-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,0.05);pointer-events:none;z-index:0;}
.ch-avatar{width:64px;height:64px;border-radius:16px;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-size:22px;font-weight:800;margin-bottom:16px;border:2px solid rgba(255,255,255,0.3);position:relative;z-index:1;}
.ch-name{font-family:'Inter',sans-serif;font-size:22px;font-weight:700;letter-spacing:-.5px;position:relative;z-index:1;}
.ch-name{font-family:'Inter',sans-serif;font-size:22px;font-weight:700;letter-spacing:-.5px;}
.ch-meta{display:flex;gap:20px;margin-top:12px;flex-wrap:wrap;}
.ch-meta-item{font-size:12px;opacity:.8;}
.ch-stats{display:flex;gap:18px;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.15);flex-wrap:wrap;position:relative;z-index:1;}
.ch-stat-val{font-family:'Inter',sans-serif;font-size:20px;font-weight:700;}
.ch-stat-lbl{font-size:11px;opacity:.6;}

.service-type-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;background:var(--primary-glow);color:var(--primary);}
.renewal-select{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:11.5px;font-family:'DM Mono',monospace;color:var(--text-mid);cursor:pointer;outline:none;max-width:150px;}

/* CALENDAR */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:12px;}
.cal-day-hdr{font-size:10px;text-align:center;color:var(--text-faint);font-weight:600;padding:4px;}
.cal-day{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-family:'DM Mono',monospace;cursor:default;transition:all .15s;position:relative;}
.cal-day.empty{opacity:0;pointer-events:none;}
.cal-day.has-expiry{background:var(--amber-light);color:#D97706;font-weight:600;}
.cal-day.has-critical{background:var(--red-light);color:var(--red);font-weight:700;}
.cal-day.today{border:1.5px solid var(--primary);color:var(--primary);font-weight:600;}

/* REPORTS PERIOD TABS */
.period-tabs{display:flex;gap:4px;background:var(--bg);border-radius:8px;padding:3px;}
.period-tab{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text-muted);transition:all .2s;}
.period-tab.active{background:var(--card);color:var(--primary);box-shadow:var(--shadow-sm);}

@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:768px){.settings-grid{grid-template-columns:1fr;}.form-grid{grid-template-columns:1fr;}}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px;}

/* ── Floating Label Form System ─────────────────────────────────── */
.fl-group{position:relative;margin-bottom:10px;}
.fl-input{
  width:100%;padding:18px 14px 5px;
  background:var(--bg);border:1.5px solid var(--border-strong);
  border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;
  color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;
  box-sizing:border-box;
}
.fl-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.10);}
.fl-label{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  font-size:12px;color:var(--text-faint);pointer-events:none;
  transition:all .16s cubic-bezier(.4,0,.2,1);font-weight:400;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 28px);
}
.fl-input:focus ~ .fl-label,
.fl-input:not(:placeholder-shown) ~ .fl-label{
  top:9px;transform:none;font-size:10px;font-weight:700;
  color:var(--primary);letter-spacing:.3px;text-transform:uppercase;
}
/* Select floating */
.fl-select{
  width:100%;padding:18px 14px 5px;
  background:var(--bg);border:1.5px solid var(--border-strong);
  border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;
  color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.fl-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.10);}
.fl-select ~ .fl-label{top:9px;transform:none;font-size:10px;font-weight:700;color:var(--primary);letter-spacing:.3px;text-transform:uppercase;}
/* Phone row for floating */
.fl-phone-wrap{
  display:flex;align-items:stretch;border:1.5px solid var(--border-strong);
  border-radius:9px;background:var(--bg);overflow:hidden;
  transition:border-color .18s,box-shadow .18s;
}
.fl-phone-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.10);}
.fl-phone-prefix{
  padding:18px 10px 5px 12px;font-size:13px;font-weight:700;
  color:var(--primary);background:var(--primary-glow);
  border-right:1.5px solid var(--border-strong);white-space:nowrap;
  display:flex;align-items:flex-end;padding-bottom:6px;
}
.fl-phone-input{
  border:none;background:none;outline:none;padding:18px 12px 5px;
  font-size:13px;font-family:'Inter',sans-serif;color:var(--text);flex:1;min-width:0;
}
.fl-group:has(.fl-phone-wrap) .fl-label{
  top:50%;transform:translateY(-50%);
}
.fl-phone-wrap:focus-within ~ .fl-label,
.fl-phone-wrap.has-value ~ .fl-label{
  top:9px;transform:none;font-size:10px;font-weight:700;
  color:var(--primary);letter-spacing:.3px;text-transform:uppercase;
}
/* Textarea floating */
.fl-textarea{
  width:100%;padding:22px 14px 6px;resize:vertical;min-height:64px;
  background:var(--bg);border:1.5px solid var(--border-strong);
  border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;
  color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;
  box-sizing:border-box;
}
.fl-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.10);}
.fl-textarea ~ .fl-label{top:12px;transform:none;}
.fl-textarea:focus ~ .fl-label,
.fl-textarea:not(:placeholder-shown) ~ .fl-label{top:7px;font-size:10px;font-weight:700;color:var(--primary);letter-spacing:.3px;text-transform:uppercase;}
/* Required star */
.fl-label .req{color:var(--red);font-size:11px;margin-left:2px;}
/* Compact modal */
.modal-compact{width:600px;max-height:88vh;overflow-y:auto;}
.modal-compact .modal-title{margin-bottom:16px;font-size:15px;}
.modal-compact .modal-footer{margin-top:16px;padding-top:14px;}
/* 3-col grid helper */
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
[data-theme='dark'] .fl-input:focus,[data-theme='dark'] .fl-select:focus,[data-theme='dark'] .fl-textarea:focus{background:var(--card);}

/* ── Enhanced Customer Modal ─────────────────────────────────── */
.modal-customer-enhanced{width:640px;max-height:90vh;overflow-y:auto;padding:0;border-radius:16px;}

/* Header */
.cmodal-header{display:flex;align-items:center;gap:14px;padding:22px 24px 18px;border-bottom:1.5px solid var(--border);background:linear-gradient(135deg,var(--primary) 0%,#6366F1 100%);border-radius:16px 16px 0 0;}
.cmodal-header-icon{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;}
.cmodal-header-icon i{width:22px;height:22px;}
.cmodal-title{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.2px;}
.cmodal-subtitle{font-size:12px;color:rgba(255,255,255,0.72);margin-top:2px;}
.cmodal-header .modal-close{color:rgba(255,255,255,0.8);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s;}
.cmodal-header .modal-close:hover{background:rgba(255,255,255,0.15);color:#fff;}

/* Section labels */
.cmodal-section-label{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:800;color:var(--primary);letter-spacing:.8px;text-transform:uppercase;margin:16px 0 10px;}

/* New field system — label on top, icon inside input */
.nfl-group{margin-bottom:0;}
.nfl-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:5px;letter-spacing:.2px;}
.nfl-req{color:var(--red);margin-left:2px;}
.nfl-input-wrap{position:relative;display:flex;align-items:center;}
.nfl-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-faint);pointer-events:none;transition:color .15s;flex-shrink:0;}
.nfl-input{
  width:100%;padding:9px 12px 9px 34px;
  background:var(--bg);border:1.5px solid var(--border-strong);
  border-radius:9px;font-size:13px;font-family:'Inter',sans-serif;
  color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s,background .18s;
  box-sizing:border-box;
}
.nfl-input::placeholder{color:var(--text-faint);opacity:1;transition:opacity .15s;}
.nfl-input:focus::placeholder{opacity:0;}
.nfl-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.12);background:var(--card);}
.nfl-input-wrap:focus-within .nfl-icon{color:var(--primary);}

/* Textarea variant */
.nfl-textarea-wrap .nfl-icon{top:12px;transform:none;}
.nfl-textarea{resize:vertical;min-height:60px;padding-top:9px;padding-bottom:9px;}

/* Select variant */
.nfl-select-wrap::after{content:'';position:absolute;right:12px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-faint);pointer-events:none;}
.nfl-select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:32px;}

/* Phone variant */
.nfl-phone-wrap{border:1.5px solid var(--border-strong);border-radius:9px;background:var(--bg);overflow:hidden;transition:border-color .18s,box-shadow .18s;}
.nfl-phone-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.12);}
.nfl-phone-prefix{padding:0 10px 0 12px;font-size:12px;font-weight:700;color:var(--primary);background:var(--primary-glow);border-right:1.5px solid var(--border-strong);white-space:nowrap;display:flex;align-items:center;height:100%;flex-shrink:0;}
.nfl-phone-wrap .nfl-input{border:none;box-shadow:none;border-radius:0;background:transparent;padding-left:12px;}
.nfl-phone-wrap .nfl-input:focus{border:none;box-shadow:none;background:transparent;}

/* Footer */
.cmodal-footer{display:flex;justify-content:flex-end;gap:10px;padding:18px 24px;border-top:1.5px solid var(--border);margin-top:20px;background:var(--bg);border-radius:0 0 16px 16px;}

[data-theme='dark'] .nfl-input{background:var(--card);}
[data-theme='dark'] .nfl-input:focus{background:var(--bg);}


/* ── KPI Card — Horizontal layout + bigger badge ── */
.dkpi-icon-wrap {
  position: relative !important;
  overflow: visible !important;
  flex-shrink: 0;
}
.dkpi-icon-wrap .dkpi-badge {
  position: absolute;
  top: -9px;
  right: -9px;
  min-width: 22px;
  height: 22px;
  background: var(--ic, #3B82F6);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  line-height: 1;
  border: 2.5px solid var(--card);
  z-index: 2;
  pointer-events: none;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}

/* Horizontal layout — icon left, text right */
.dash-kpi-card {
  padding: 20px 18px !important;
  min-height: 80px;
}
.dash-kpi-card .dkpi-top {
  align-items: center;
  margin-bottom: 0 !important;
  gap: 14px;
}
.dash-kpi-card .dkpi-glow {
  display: none;
}
/* Hide old value div (now using badge) */
.dash-kpi-card .dkpi-value {
  display: none !important;
}
/* Icon bigger */
.dash-kpi-card .dkpi-icon-wrap {
  width: 52px !important;
  height: 52px !important;
  border-radius: 14px !important;
}
.dash-kpi-card .dkpi-icon {
  width: 24px !important;
  height: 24px !important;
}
/* Label bigger and clearer */
.dash-kpi-card .dkpi-label {
  font-size: 14px !important;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -0.2px;
}
.dash-kpi-card .dkpi-sub {
  font-size: 11px !important;
  font-weight: 500;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Bar stays at bottom */
.dash-kpi-card .dkpi-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

/* ── Search box clear button ── */
.search-box{position:relative;}
.search-clear-btn{
  display:none;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  background:var(--red);color:#fff;
  border:none;cursor:pointer;font-size:10px;line-height:1;
  flex-shrink:0;padding:0;opacity:.85;transition:opacity .15s;
}
.search-clear-btn:hover{opacity:1;}
.search-clear-btn.visible{display:flex;}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none;margin:0;}
input[type="number"]{-moz-appearance:textfield;}

/* ── Lucide Icon Sizing ─────────────────────────────────────── */
/* Sidebar icons */
.sidebar-nav .nav-item .icon svg,
.sidebar-footer .collapse-btn .icon svg {
  width: 16px; height: 16px; stroke-width: 2; vertical-align: middle;
}
/* Navbar icons */
.nav-search svg {
  width: 15px; height: 15px; stroke-width: 2;
  color: var(--text-faint); flex-shrink: 0;
}
.nav-notif-btn svg { width: 18px; height: 18px; stroke-width: 2; vertical-align: middle; }
/* Page header icons */
.page-header .page-title svg,
.table-title svg,
.form-section-title svg {
  width: 16px; height: 16px; stroke-width: 2;
  vertical-align: middle; margin-right: 4px;
}
/* Profile dropdown icons */
.pd-icon svg { width: 14px; height: 14px; stroke-width: 2; vertical-align: middle; }
/* KPI card icons */
.kpi-icon svg { width: 22px; height: 22px; stroke-width: 2; }
/* Settings nav icons */
.settings-nav-item svg {
  width: 14px; height: 14px; stroke-width: 2;
  vertical-align: middle; margin-right: 2px;
}
