/* ISP PREMIUM ADMIN PANEL — DESIGN SYSTEM v2.0 */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

:root {
  --bg:#f4f3f0;--surface:#ffffff;--surface-2:#faf9f7;--surface-3:#f7f5f2;
  --border:#e8e4de;--border-2:#ddd9d2;--border-3:#ede9e3;
  --ink:#111111;--ink-2:#2c2c2c;--ink-3:#555555;
  --muted:#8a8a8a;--muted-2:#b8b8b8;
  --accent:#B8960C;--accent-light:#FBF4DC;--accent-mid:#E8C84A;--accent-dark:#9a7a09;
  --red:#C0392B;--red-light:#FCEAEA;
  --green:#1A7A45;--green-light:#EDFAF3;
  --blue:#2375B3;--blue-light:#EDF6FF;
  --purple:#6B3FA0;--purple-light:#F2EBFF;
  --orange:#D65F1A;--orange-light:#FFF0E6;
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans',sans-serif;
  --radius-xs:4px;--radius-sm:6px;--radius:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;
  --shadow-xs:0 1px 2px rgba(0,0,0,.04);--shadow-sm:0 1px 4px rgba(0,0,0,.06);
  --shadow:0 4px 16px rgba(0,0,0,.08);--shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --sidebar-w:224px;--header-h:58px;--transition:.18s ease;
}
[data-theme="dark"] {
  --bg:#0f0f0f;--surface:#1a1a1a;--surface-2:#222222;--surface-3:#272727;
  --border:#2e2e2e;--border-2:#3a3a3a;--border-3:#262626;
  --ink:#f0f0f0;--ink-2:#d4d4d4;--ink-3:#a0a0a0;
  --muted:#666666;--muted-2:#444444;
  --accent:#D4A80E;--accent-light:#2a2100;--accent-mid:#F0C830;--accent-dark:#e8bc12;
  --red:#e05545;--red-light:#2a0f0f;
  --green:#2db068;--green-light:#0a2015;
  --blue:#4a9dde;--blue-light:#0a1e32;
  --purple:#9b72d4;--purple-light:#1a0f30;
  --orange:#e8782b;--orange-light:#2a1505;
  --shadow-xs:0 1px 2px rgba(0,0,0,.3);--shadow-sm:0 1px 4px rgba(0,0,0,.4);
  --shadow:0 4px 16px rgba(0,0,0,.5);--shadow-lg:0 12px 40px rgba(0,0,0,.6);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}
table.dataTable tbody th,table.dataTable tbody td{padding:2px 10px!important}
.form-select{padding:.375rem 2.25rem .375rem .75rem!important}

/* THEME TOGGLE */
.theme-toggle{width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border-2);background:var(--surface-2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-3);font-size:15px;transition:background var(--transition),color var(--transition);flex-shrink:0}
.theme-toggle:hover{background:var(--border);color:var(--ink)}

/* HEADER */
.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;z-index:1000;box-shadow:var(--shadow-sm)}
.header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.header-menu-btn{width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border-2);background:var(--surface-2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-3);font-size:15px;transition:background var(--transition),color var(--transition);flex-shrink:0}
.header-menu-btn:hover{background:var(--border);color:var(--ink)}
.header-logo-mark{width:30px;height:30px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.header-title{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--ink);white-space:nowrap;letter-spacing:-.01em}
.header-search{flex:1;max-width:400px;margin:0 auto;display:flex;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:0 12px;gap:8px;transition:border-color var(--transition),box-shadow var(--transition)}
.header-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);background:var(--surface)}
.header-search input{border:none;background:transparent;outline:none;font-family:var(--font-body);font-size:13px;color:var(--ink);width:100%;padding:8px 0}
.header-search input::placeholder{color:var(--muted-2)}
.header-search-icon{color:var(--muted-2);font-size:12px;flex-shrink:0}
.header-search-btn{background:none;border:none;cursor:pointer;color:var(--muted);font-size:13px;padding:4px 6px;border-radius:5px;transition:color var(--transition)}
.header-search-btn:hover{color:var(--ink)}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}
.header-user-chip{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 6px;border-radius:20px;border:1px solid var(--border);background:var(--surface-2);cursor:pointer;position:relative;transition:background var(--transition)}
.header-user-chip:hover{background:var(--border-3)}
.header-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);flex-shrink:0}
.header-username{font-size:12.5px;font-weight:500;color:var(--ink-2);white-space:nowrap;max-width:110px;overflow:hidden;text-overflow:ellipsis}
.header-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:185px;padding:6px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity var(--transition),transform var(--transition);z-index:200}
.header-user-chip:hover .header-dropdown,.header-user-chip.open .header-dropdown{opacity:1;pointer-events:all;transform:translateY(0)}
.header-dropdown a{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--ink-3);transition:background var(--transition),color var(--transition)}
.header-dropdown a:hover{background:var(--surface-2);color:var(--ink)}
.header-dropdown a.danger{color:var(--red)}
.header-dropdown a.danger:hover{background:var(--red-light)}
.header-dropdown .divider{height:1px;background:var(--border-3);margin:4px 0}

/* SIDEBAR */
.sidebar{position:fixed;top:var(--header-h);left:0;bottom:0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;overflow-x:hidden;z-index:900;padding:1rem 0 2rem;transition:transform var(--transition);scrollbar-width:thin;scrollbar-color:var(--border-2) transparent}
.sidebar::-webkit-scrollbar{width:4px}
.sidebar::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}
@media(max-width:900px){.sidebar{transform:translateX(-100%);box-shadow:var(--shadow-lg)}.sidebar.show{transform:translateX(0)}}
.sb-group-label{font-size:9.5px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted-2);padding:1.2rem 1.25rem .4rem;display:block}
.sb-item{display:flex;align-items:center;gap:9px;padding:9px 1.25rem;font-size:13px;font-weight:400;color:var(--ink-3);cursor:pointer;position:relative;transition:background var(--transition),color var(--transition);user-select:none;white-space:nowrap}
.sb-item:hover{background:var(--surface-2);color:var(--ink)}
.sb-item.active{color:var(--ink);font-weight:500;background:var(--accent-light)}
.sb-item.active::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.sb-icon{width:20px;text-align:center;font-size:13px;color:var(--muted);flex-shrink:0;transition:color var(--transition)}
.sb-item:hover .sb-icon,.sb-item.active .sb-icon{color:var(--accent)}
.sb-arrow{margin-left:auto;font-size:10px;color:var(--muted-2);transition:transform .25s ease;flex-shrink:0}
.sb-item[aria-expanded="true"] .sb-arrow{transform:rotate(180deg)}
.sb-sub{padding:3px 0;background:var(--surface-2);border-bottom:1px solid var(--border-3)}
.sb-sub a{display:flex;align-items:center;gap:8px;padding:7px 1.25rem 7px 2.75rem;font-size:12.5px;color:var(--muted);transition:color var(--transition),background var(--transition)}
.sb-sub a:hover{color:var(--ink);background:var(--bg)}
.sb-sub a::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--border-2);flex-shrink:0;transition:background var(--transition)}
.sb-sub a:hover::before{background:var(--accent)}
.sb-sub a.active-link{color:var(--accent);font-weight:500}
.sb-sub a.active-link::before{background:var(--accent)}
.sb-divider{height:1px;background:var(--border-3);margin:.5rem 1.25rem}

/* MAIN CONTENT */
.content{margin-left:var(--sidebar-w);margin-top:var(--header-h);min-height:calc(100vh - var(--header-h));padding:1rem 1.75rem 4rem}
@media(max-width:900px){.content{margin-left:0;padding:1.25rem 1rem 3rem}}

/* PAGE HEADER */
.pm-page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:12px}
.pm-eyebrow{font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.pm-page-title{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--ink);line-height:1.15}
.pm-page-title span{color:var(--muted);font-weight:400}
.pm-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* BUTTONS */
.pm-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:background var(--transition),color var(--transition),border-color var(--transition),transform .1s;white-space:nowrap;border:1.5px solid transparent;line-height:1.3}
.pm-btn:active{transform:scale(.98)}
.pm-btn i{font-size:12px}
.pm-btn-sm{padding:6px 12px;font-size:12px}
.pm-btn-lg{padding:11px 22px;font-size:14px}
.pm-btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.pm-btn-primary:hover{background:var(--ink-2);color:#fff;text-decoration:none}
.pm-btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.pm-btn-accent:hover{background:var(--accent-dark);color:#fff;text-decoration:none}
.pm-btn-ghost{background:var(--surface);color:var(--ink-3);border-color:var(--border-2)}
.pm-btn-ghost:hover{background:var(--surface-2);color:var(--ink);text-decoration:none}
.pm-btn-success{background:var(--green);color:#fff;border-color:var(--green)}
.pm-btn-success:hover{background:#156037;color:#fff;text-decoration:none}
.pm-btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.pm-btn-danger:hover{background:#a32d2d;color:#fff;text-decoration:none}
.pm-btn-warning{background:var(--orange);color:#fff;border-color:var(--orange)}
.pm-btn-warning:hover{background:#b8501a;color:#fff;text-decoration:none}
.pm-back-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius);border:1.5px solid var(--border-2);background:var(--surface);color:var(--ink-3);font-family:var(--font-body);font-size:13px;font-weight:500;text-decoration:none;transition:background var(--transition),color var(--transition)}
.pm-back-btn:hover{background:var(--surface-2);color:var(--ink);text-decoration:none}

/* CARDS */
.pm-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}
.pm-card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-3);background:var(--surface-2);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pm-card-icon{width:34px;height:34px;border-radius:9px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.pm-card-icon.accent{background:var(--accent)}.pm-card-icon.green{background:var(--green)}.pm-card-icon.blue{background:var(--blue)}.pm-card-icon.red{background:var(--red)}
.pm-card-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--ink);margin:0}
.pm-card-sub{font-size:12px;color:var(--muted);margin:1px 0 0}
.pm-section{border-bottom:1px solid var(--border-3);padding:1.4rem 1.75rem}
.pm-section:last-child{border-bottom:none}
.pm-section-header{display:flex;align-items:center;gap:10px;margin-bottom:1.1rem}
.pm-section-icon{width:30px;height:30px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted);flex-shrink:0}
.pm-section-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--ink);margin:0}
.pm-section-subtitle{font-size:11px;color:var(--muted-2);margin:2px 0 0}

/* STAT CARDS */
.pm-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:1rem;margin-bottom:1.5rem}
.pm-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:6px;text-decoration:none;position:relative;overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);cursor:pointer}
.pm-stat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.pm-stat-card:hover{border-color:var(--accent-mid);box-shadow:var(--shadow);transform:translateY(-2px);text-decoration:none}
.pm-stat-card:hover::after{transform:scaleX(1)}
.pm-stat-top{display:flex;align-items:center;gap:10px}
.pm-stat-icon{width:36px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--muted);flex-shrink:0}
.pm-stat-value{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
.pm-stat-label{font-size:12px;color:var(--muted)}
.pm-stat-sub{font-size:11px;color:var(--muted-2)}

.kp-blue{background:linear-gradient(135deg,var(--blue-light),#d4e9ff);border-color:#c0d8f0}
.kp-green{background:linear-gradient(135deg,var(--green-light),#c8f0da);border-color:#a8dfc0}
.kp-yellow{background:linear-gradient(135deg,var(--accent-light),#fff0b0);border-color:#e8d070}
.kp-purple{background:linear-gradient(135deg,var(--purple-light),#e0ccff);border-color:#c8b0f0}
.kp-red{background:linear-gradient(135deg,var(--red-light),#ffc8c8);border-color:#f0a0a0}
.kp-cyan{background:linear-gradient(135deg,#e8feff,#c8f8ff);border-color:#a0e8f8}
.kp-orange{background:linear-gradient(135deg,var(--orange-light),#ffe0c0);border-color:#f0c090}
[data-theme="dark"] .kp-blue{background:linear-gradient(135deg,#0a1e32,#0d2540);border-color:#1a3050}
[data-theme="dark"] .kp-green{background:linear-gradient(135deg,#0a2015,#0d2a1a);border-color:#1a4028}
[data-theme="dark"] .kp-yellow{background:linear-gradient(135deg,#2a2100,#322800);border-color:#4a3800}
[data-theme="dark"] .kp-purple{background:linear-gradient(135deg,#1a0f30,#221540);border-color:#3a2560}
[data-theme="dark"] .kp-red{background:linear-gradient(135deg,#2a0f0f,#361212);border-color:#4a1a1a}
[data-theme="dark"] .kp-cyan{background:linear-gradient(135deg,#0a2226,#0d2830);border-color:#1a3840}
[data-theme="dark"] .kp-orange{background:linear-gradient(135deg,#2a1505,#351a08);border-color:#4a2510}
.kp-blue .pm-stat-icon{color:var(--blue);background:var(--blue-light);border-color:#c0d8f0}
.kp-green .pm-stat-icon{color:var(--green);background:var(--green-light);border-color:#a8dfc0}
.kp-yellow .pm-stat-icon{color:var(--accent);background:var(--accent-light);border-color:#e8d070}
.kp-purple .pm-stat-icon{color:var(--purple);background:var(--purple-light);border-color:#c8b0f0}
.kp-red .pm-stat-icon{color:var(--red);background:var(--red-light);border-color:#f0a0a0}
.kp-cyan .pm-stat-icon{color:#0891b2;background:#e8feff;border-color:#a0e8f8}
.kp-orange .pm-stat-icon{color:var(--orange);background:var(--orange-light);border-color:#f0c090}

/* FILTER TABS */
.pm-filter-bar{display:flex;align-items:center;gap:6px;margin-bottom:1.25rem;flex-wrap:wrap}
.pm-filter-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;font-size:12.5px;font-weight:500;border:1.5px solid var(--border-2);background:var(--surface);color:var(--ink-3);text-decoration:none;transition:all var(--transition)}
.pm-filter-tab:hover{border-color:var(--ink);color:var(--ink);text-decoration:none}
.pm-filter-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pm-filter-tab .badge-count{font-size:11px;padding:1px 7px;border-radius:10px;font-weight:600;background:rgba(255,255,255,.2);color:inherit}
.pm-filter-tab:not(.active) .badge-count{background:var(--surface-2);color:var(--muted)}

/* BADGES */
.pm-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:500;letter-spacing:.03em;text-transform:capitalize;background:var(--surface-2);color:var(--ink-3);border:1px solid var(--border)}
.pm-badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.pm-badge-green{background:var(--green-light);color:var(--green);border-color:#a8dfc0}
.pm-badge-red{background:var(--red-light);color:var(--red);border-color:#f0a0a0}
.pm-badge-accent{background:var(--accent-light);color:#7a5e00;border-color:#e8d070}
.pm-badge-blue{background:var(--blue-light);color:var(--blue);border-color:#c0d8f0}
.pm-badge-purple{background:var(--purple-light);color:var(--purple);border-color:#c8b0f0}
.pm-badge-orange{background:var(--orange-light);color:var(--orange);border-color:#f0c090}
.pm-badge-gray{background:var(--surface-2);color:var(--muted);border-color:var(--border)}

/* DATA TABLE */
.pm-table-wrap{overflow-x:auto}
.pm-data-table{width:100%;border-collapse:collapse;font-size:13px}
.pm-data-table thead tr{border-bottom:1px solid var(--border-2)}
.pm-data-table th{padding:9px 12px;text-align:left;font-size:10.5px;font-weight:600;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;background:var(--surface-2);white-space:nowrap}
.pm-data-table th:first-child{border-radius:var(--radius) 0 0 var(--radius);padding-left:1.25rem}
.pm-data-table th:last-child{border-radius:0 var(--radius) var(--radius) 0;padding-right:1.25rem}
.pm-data-table tbody tr{border-bottom:1px solid var(--border-3);transition:background var(--transition)}
.pm-data-table tbody tr:last-child{border-bottom:none}
.pm-data-table tbody tr:hover{background:var(--surface-2)}
.pm-data-table td{padding:10px 12px;vertical-align:middle}
.pm-data-table td:first-child{padding-left:1.25rem}
.pm-data-table td:last-child{padding-right:1.25rem}
.pm-tbl-actions{display:flex;align-items:center;gap:5px}
.pm-tbl-btn{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:12px;border:1px solid var(--border);background:var(--surface);color:var(--ink-3);cursor:pointer;text-decoration:none;transition:all var(--transition)}
.pm-tbl-btn:hover{background:var(--surface-2);color:var(--ink);border-color:var(--border-2);text-decoration:none}
.pm-tbl-btn.view{color:var(--blue);border-color:#c0d8f0}
.pm-tbl-btn.view:hover{background:var(--blue-light)}
.pm-tbl-btn.edit{color:var(--accent);border-color:#e8d070}
.pm-tbl-btn.edit:hover{background:var(--accent-light)}
.pm-tbl-btn.del{color:var(--red);border-color:#f0a0a0}
.pm-tbl-btn.del:hover{background:var(--red-light)}
.pm-tbl-btn.green{color:var(--green);border-color:#a8dfc0}
.pm-tbl-btn.green:hover{background:var(--green-light)}

/* FORMS */
.pm-label{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:5px}
.pm-label .required{color:var(--red);margin-left:2px}
.pm-input,.pm-select,.pm-textarea{font-family:var(--font-body);font-size:13.5px;color:var(--ink);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:9px 12px;width:100%;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}
.pm-input:focus,.pm-select:focus,.pm-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}
.pm-input::placeholder{color:var(--muted-2)}
.pm-select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23bbb' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer;appearance:none}
.pm-textarea{resize:vertical;min-height:90px;line-height:1.55}
.pm-form-group{margin-bottom:1.1rem}
.pm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.pm-form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
@media(max-width:700px){.pm-form-row,.pm-form-row-3{grid-template-columns:1fr}}
.pm-input-icon-wrap{position:relative}
.pm-input-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:12px;pointer-events:none}
.pm-input-icon-wrap .pm-input{padding-left:32px}

/* ALERTS */
.pm-alert{border-radius:var(--radius);padding:.9rem 1.1rem;font-size:13px;margin-bottom:1.25rem;display:flex;align-items:flex-start;gap:10px;border:1px solid}
.pm-alert i{margin-top:1px;flex-shrink:0;font-size:14px}
.pm-alert-error{background:var(--red-light);border-color:#f0a0a0;color:#a32d2d}
.pm-alert-success{background:var(--green-light);border-color:#a8dfc0;color:#156037}
.pm-alert-info{background:var(--blue-light);border-color:#c0d8f0;color:#185fa5}
.pm-alert-warning{background:var(--accent-light);border-color:#e8d070;color:#7a5e00}

/* DETAIL GRID */
.pm-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem 1.5rem}
.pm-detail-grid-3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:700px){.pm-detail-grid,.pm-detail-grid-3{grid-template-columns:1fr}}
.pm-detail-label{font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.pm-detail-value{font-size:13.5px;color:var(--ink-2);word-break:break-word}
.pm-detail-value.mono{font-family:'Courier New',monospace;font-size:12.5px}

/* TOOLBAR */
.pm-toolbar{display:flex;align-items:center;gap:10px;padding:.85rem 1.5rem;border-bottom:1px solid var(--border-3);flex-wrap:wrap}
.pm-search-wrap{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:6px 12px;flex:1;min-width:160px;max-width:280px;transition:border-color var(--transition)}
.pm-search-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}
.pm-search-wrap i{color:var(--muted-2);font-size:12px}
.pm-search-input{border:none;background:transparent;font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none;width:100%}
.pm-search-input::placeholder{color:var(--muted-2)}
.pm-filter-select{padding:7px 28px 7px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);font-family:var(--font-body);font-size:12.5px;color:var(--ink-3);cursor:pointer;appearance:none;outline:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23bbb' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
.pm-filter-select:focus{border-color:var(--accent)}

/* UPLOAD ZONE */
.pm-upload-zone{border:2px dashed var(--border-2);border-radius:var(--radius-md);padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:border-color var(--transition),background var(--transition)}
.pm-upload-zone:hover{border-color:var(--accent);background:var(--accent-light)}
.pm-upload-zone i{font-size:32px;color:var(--muted-2);margin-bottom:.75rem;display:block}
.pm-upload-zone p{font-size:14px;color:var(--muted);margin:0}
.pm-upload-zone small{font-size:12px;color:var(--muted-2)}

/* INVOICE */
.pm-invoice-card{background:var(--surface);border-radius:14px;border:1px solid var(--border);overflow:hidden}
.pm-inv-head{padding:2rem 2rem 1.5rem;border-bottom:1px solid var(--border-3);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:20px}
.pm-inv-logo-area h2{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--ink);margin:0 0 4px}
.pm-inv-logo-area p{font-size:12px;color:var(--muted);margin:0}
.pm-inv-meta{text-align:right}
.pm-inv-num-large{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--ink);margin:0 0 4px}
.pm-inv-month{display:inline-block;background:var(--blue-light);color:var(--blue);border-radius:20px;padding:3px 12px;font-size:12px;font-weight:500}
.pm-inv-info{display:grid;grid-template-columns:1fr 1fr;gap:1px}
.pm-inv-info-col{padding:1.25rem 2rem;background:var(--surface)}
.pm-inv-info-col:first-child{border-right:1px solid var(--border-3)}
.pm-inv-info-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:6px;font-weight:600}
.pm-inv-info-name{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--ink)}
.pm-inv-info-val{font-size:12.5px;color:var(--ink-3);margin-top:2px}
.pm-inv-items{padding:1.5rem 2rem}
.pm-inv-items table{width:100%;border-collapse:collapse;font-size:13px}
.pm-inv-items th{padding:8px 12px;text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1.5px solid var(--border-2);font-weight:600}
.pm-inv-items td{padding:10px 12px;border-bottom:1px solid var(--border-3);vertical-align:middle}
.pm-inv-items tr:last-child td{border-bottom:none}
.pm-inv-total-row{padding:1.25rem 2rem;border-top:1px solid var(--border-2);display:flex;justify-content:flex-end}
.pm-inv-total-box{min-width:220px}
.pm-inv-total-line{display:flex;justify-content:space-between;padding:5px 0;font-size:13px;color:var(--ink-3);border-bottom:1px solid var(--border-3)}
.pm-inv-total-line.final{font-weight:600;color:var(--ink);font-size:16px;border-bottom:none;padding-top:10px}

/* QUICK ACTIONS */
.dash-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px}
.dash-action-btn{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--ink-3);font-family:var(--font-body);font-size:13px;font-weight:500;text-decoration:none;transition:background var(--transition),border-color var(--transition),color var(--transition),transform .1s}
.dash-action-btn:hover{background:var(--accent-light);border-color:var(--accent-mid);color:var(--ink);text-decoration:none;transform:translateY(-1px)}
.dash-action-btn i{font-size:13px;color:var(--accent);width:16px;text-align:center}

/* ACTIVITY LOG */
.dash-log-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border-3)}
.dash-log-item:last-child{border-bottom:none}
.dash-log-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);margin-top:5px;flex-shrink:0}
.dash-log-desc{font-size:12.5px;color:var(--ink-3);line-height:1.45;flex:1}
.dash-log-time{font-size:10.5px;color:var(--muted-2);white-space:nowrap;margin-top:2px}
.dash-log-module{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);padding:1px 7px;border-radius:4px}

/* PORT GRID */
.pm-port-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:.75rem}
.pm-port{width:40px;height:40px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600;cursor:pointer;border:1.5px solid;transition:all var(--transition);position:relative}
.pm-port.free{background:var(--green-light);border-color:#a8dfc0;color:var(--green)}
.pm-port.used{background:var(--accent-light);border-color:#e8d070;color:#7a5e00}
.pm-port.uplink{background:var(--blue-light);border-color:#c0d8f0;color:var(--blue)}
.pm-port.damaged{background:var(--red-light);border-color:#f0a0a0;color:var(--red)}
.pm-port:hover{transform:scale(1.1);box-shadow:var(--shadow)}

/* FOOTER */
.pm-footer{text-align:center;padding:1.5rem;font-size:11.5px;color:var(--muted-2);border-top:1px solid var(--border-3);margin-top:2rem}
#backToTop{position:fixed;bottom:25px;right:25px;z-index:999;background:var(--ink);color:#fff;border:none;padding:10px 14px;border-radius:var(--radius);font-size:16px;cursor:pointer;display:none;box-shadow:var(--shadow);transition:all .2s}
#backToTop:hover{background:var(--ink-2);transform:translateY(-2px)}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:850}
.sb-overlay.show{display:block}

/* DASHBOARD */
.dash-welcome{margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border-3)}
.dash-welcome-name{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--ink)}
.dash-welcome-sub{font-size:13px;color:var(--muted);margin-top:3px}
.dash-section-label{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.85rem;display:block}
.dash-lower{display:grid;grid-template-columns:1fr 340px;gap:1.25rem}
@media(max-width:900px){.dash-lower{grid-template-columns:1fr}}

/* MISC */
.pm-empty-state{text-align:center;padding:3rem 2rem;color:var(--muted)}
.pm-empty-state i{font-size:32px;color:var(--muted-2);display:block;margin-bottom:.75rem}
.pm-empty-state p{font-size:14px;margin:0}
.pm-divider{height:1px;background:var(--border-3);margin:1.25rem 0}
.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--muted);font-size:12px}.text-mono{font-family:'Courier New',monospace;font-size:12px}.fw-600{font-weight:600}
.pm-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.pm-three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.25rem}
@media(max-width:700px){.pm-two-col,.pm-three-col{grid-template-columns:1fr}}
