/* ============================================================
   Location Intelligence Platform — Application CSS
   PHP 8+ MVC · No frameworks · cPanel compatible
   Sprint 2 — Admin Core Foundation
   ============================================================ */

:root {
    --bg:#fff;--sf:#fff;--sfh:#f7f7f8;--bd:#e5e7eb;--tx:#111827;--tx2:#6b7280;--tx3:#9ca3af;
    --pr:#111827;--prf:#fff;--ok:#059669;--okbg:#ecfdf5;--err:#dc2626;--errbg:#fef2f2;
    --wrn:#d97706;--wrnbg:#fffbeb;--inf:#0284c7;--infbg:#f0f9ff;
    --acc:#f3f4f6;--r:8px;--sh:0 1px 3px rgba(0,0,0,.1);
    --sb:240px;--hd:56px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:14px;line-height:1.6;color:var(--tx);background:var(--bg)}
a{color:var(--pr);text-decoration:none}a:hover{text-decoration:underline}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;border:1px solid transparent;border-radius:var(--r);cursor:pointer;transition:.2s;font-family:inherit}
.btn:disabled,.btn.disabled{opacity:.5;cursor:not-allowed}
.btn-p{background:var(--pr);color:var(--prf);border-color:var(--pr)}.btn-p:hover:not(:disabled){background:#1f2937}
.btn-o{background:0;color:var(--tx);border-color:var(--bd)}.btn-o:hover:not(:disabled){background:var(--acc)}
.btn-sm{padding:5px 12px;font-size:13px}.btn-lg{padding:10px 24px;font-size:16px}.btn-full{width:100%}
.btn-danger{background:var(--err);color:#fff;border-color:var(--err)}.btn-danger:hover:not(:disabled){background:#b91c1c}
.btn-warning{background:var(--wrn);color:#fff;border-color:var(--wrn)}.btn-warning:hover:not(:disabled){background:#b45309}

/* Badges & Alerts */
.badge{display:inline-flex;padding:2px 8px;font-size:10px;font-weight:600;border-radius:999px}
.badge.ok{background:var(--okbg);color:var(--ok);border:1px solid #a7f3d0}
.badge.o{background:0;color:var(--tx2);border:1px solid var(--bd)}
.badge-dev{background:var(--infbg);color:var(--inf);border:1px solid #bae6fd}
.badge-prod{background:var(--okbg);color:var(--ok);border:1px solid #a7f3d0}
.alert{padding:10px 14px;border-radius:var(--r);font-size:13px;margin-bottom:16px}
.alert.err{background:var(--errbg);color:var(--err);border:1px solid #fecaca}
.alert.ok{background:var(--okbg);color:var(--ok);border:1px solid #a7f3d0}

/* Forms */
.fg{margin-bottom:16px}.fg label{display:block;font-size:13px;font-weight:500;margin-bottom:4px}
.fg input[type=email],.fg input[type=password],.fg input[type=text],.fg input[type=number],.fg select,.fg textarea{width:100%;padding:8px 12px;font-size:14px;font-family:inherit;border:1px solid var(--bd);border-radius:var(--r);background:var(--sf);transition:.2s}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--pr);box-shadow:0 0 0 3px rgba(0,0,0,.05)}
.fg textarea{resize:vertical;min-height:80px}
.hint{display:block;font-size:11px;color:var(--tx3);margin-top:4px}
.pw-wrap{position:relative}.pw-wrap input{padding-right:40px}
.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:0;border:0;cursor:pointer;font-size:16px;opacity:.5;padding:4px}.pw-toggle:hover{opacity:1}
code{background:var(--acc);padding:1px 6px;border-radius:4px;font-family:'SF Mono',monospace;font-size:12px}
.small-code{font-size:10px;word-break:break-all}
.form-actions{margin-top:20px;display:flex;gap:12px;align-items:center}

/* Toggle Switch */
.toggle-group{display:flex;align-items:center;justify-content:space-between;gap:16px}
.toggle-wrap{display:flex;align-items:center;gap:8px}
.toggle-wrap input[type=checkbox]{width:18px;height:18px;cursor:pointer}
.toggle-label{font-size:13px;color:var(--tx2);cursor:pointer}

/* === GUEST LAYOUT === */
.guest-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:16px}
.login-wrap{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.login-logo{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:var(--pr);color:var(--prf);font-weight:700;font-size:16px}
.login-brand h1{font-size:20px;font-weight:700}.login-brand p{font-size:11px;color:var(--tx2)}
.login-card{width:100%;background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:32px 28px}
.login-head{text-align:center;margin-bottom:24px}.login-icon{font-size:28px;margin-bottom:8px}
.login-head h2{font-size:20px;font-weight:600}.login-head p{font-size:13px;color:var(--tx2);margin-top:4px}
.dev-creds{margin-top:16px;padding:10px 12px;background:var(--acc);border-radius:var(--r);font-size:12px;color:var(--tx2)}
.dev-lbl{font-weight:600;margin-bottom:4px}.dev-creds p{margin:2px 0}
.login-foot{margin-top:24px;font-size:12px;color:var(--tx3)}

/* === APP LAYOUT === */
.app-wrap{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sb);background:var(--sf);border-right:1px solid var(--bd);display:flex;flex-direction:column;flex-shrink:0;transition:left .2s}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:40}
.sb-head{display:flex;align-items:center;gap:10px;padding:12px 16px;height:var(--hd);border-bottom:1px solid var(--bd)}
.sb-logo{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r);background:var(--pr);color:var(--prf);font-weight:700;font-size:13px;flex-shrink:0}
.sb-brand b{font-size:13px;display:block}.sb-brand small{font-size:10px;color:var(--tx3);display:block}
.sb-nav{flex:1;padding:8px;overflow-y:auto}
.nav-section{font-size:10px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px;padding:12px 12px 4px;margin-top:4px}
.nav-i{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--tx2);border-radius:var(--r);transition:.2s;text-decoration:none;margin-bottom:1px}
.nav-i:hover:not(.disabled){background:var(--acc);color:var(--tx);text-decoration:none}
.nav-i.active{background:var(--pr);color:var(--prf)}
.nav-i.disabled{opacity:.5;cursor:not-allowed}
.soon{margin-left:auto;font-size:9px;background:var(--acc);padding:1px 6px;border-radius:999px}
.sb-foot{border-top:1px solid var(--bd);padding:10px 16px}
.sb-ver{font-size:11px;color:var(--tx3)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:var(--hd);display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--bd);background:var(--sf);flex-shrink:0}
.topbar-l{display:flex;align-items:center;gap:12px}
.menu-toggle{background:0;border:0;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:var(--r);color:var(--tx2);display:none}
.menu-toggle:hover{background:var(--acc)}
.tag{font-size:13px;font-weight:500;color:var(--tx2)}.ver{font-size:10px;background:var(--acc);padding:1px 6px;border-radius:999px;color:var(--tx3);margin-left:8px}
.topbar-r{display:flex;align-items:center;gap:8px}.uname{font-size:13px;font-weight:500}
.dropdown{position:relative}.dd-btn{background:0;border:0;cursor:pointer;padding:4px}
.dd-avatar{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--pr);color:var(--prf);font-size:12px;font-weight:600}
.dd-menu{display:none;position:absolute;right:0;top:100%;width:220px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);z-index:100;padding:4px;margin-top:4px}
.dd-menu.show{display:block}.dd-head{padding:8px 12px;border-bottom:1px solid var(--bd)}.dd-head b{display:block;font-size:13px}.dd-head small{font-size:11px;color:var(--tx2)}
.dd-sep{border-top:1px solid var(--bd);margin:4px 0}
.dd-item{display:block;padding:8px 12px;font-size:13px;border-radius:4px;text-decoration:none;color:var(--tx)}.dd-item:hover{background:var(--acc);text-decoration:none}
.dd-item.out{color:var(--err)}

/* Breadcrumb */
.breadcrumb{padding:10px 20px;border-bottom:1px solid var(--bd);background:var(--sfh);font-size:13px;display:flex;align-items:center;gap:4px;flex-shrink:0}
.breadcrumb a{color:var(--tx2)}.breadcrumb a:hover{color:var(--tx);text-decoration:none}
.bc-sep{color:var(--tx3);margin:0 2px}
.bc-current{color:var(--tx);font-weight:500}

.content{flex:1;overflow-y:auto;padding:20px}

/* === DASHBOARD === */
.page-hd{margin-bottom:20px}.page-hd h1{font-size:22px;font-weight:700}.page-hd p{font-size:13px;color:var(--tx2);margin-top:2px}
.section-title{font-size:14px;font-weight:600;color:var(--tx2);margin-bottom:12px;text-transform:uppercase;letter-spacing:.3px}

/* Geo Stats */
.geo-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.geo-card{background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;transition:.2s}
.geo-card:hover{border-color:var(--pr);box-shadow:var(--sh)}
.geo-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--acc);border-radius:var(--r);flex-shrink:0}
.geo-val{font-size:22px;font-weight:700;line-height:1.2}
.geo-label{font-size:11px;color:var(--tx2);margin-top:2px}

/* System Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.sc{background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:16px}
.sc-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.sc-t{font-size:13px;font-weight:500;color:var(--tx2)}.sc-v{font-size:28px;font-weight:700;line-height:1.2}
.sc-d{font-size:12px;color:var(--tx3);margin-top:4px}
.g{color:var(--ok)}.r{color:var(--err)}

/* Import Overview */
.import-overview{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.imp-stat{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:12px;text-align:center}
.imp-stat.info{border-left:3px solid var(--inf)}
.imp-stat.warn{border-left:3px solid var(--wrn)}
.imp-stat.proc{border-left:3px solid var(--inf);background:var(--infbg)}
.imp-stat.ok{border-left:3px solid var(--ok);background:var(--okbg)}
.imp-stat.err{border-left:3px solid var(--err);background:var(--errbg)}
.imp-val{font-size:20px;font-weight:700}.imp-label{font-size:11px;color:var(--tx2);margin-top:2px}

.divider{border:none;border-top:1px solid var(--bd);margin:20px 0}

/* Sprint Cards */
.sprint-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sp{background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:16px}
.sp.active{border-color:var(--pr);border-width:2px}.sp.done{border-color:var(--ok);border-width:2px;opacity:.8}.sp.upcoming{opacity:.5}
.sp-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.sp-h h3{font-size:15px;font-weight:600}
.sp-d{font-size:12px;color:var(--tx2);margin-bottom:12px}
.sp-list{list-style:none}.sp-list li{font-size:13px;padding:3px 0}.sp-list .done{color:var(--tx)}.sp-list .pending{color:var(--tx3)}

/* Quick Actions */
.qa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.qa{display:flex;align-items:center;gap:12px;padding:16px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);cursor:not-allowed;opacity:.5;font-family:inherit;text-align:left;transition:.2s}
.qa.enabled{cursor:pointer;opacity:1;text-decoration:none}.qa.enabled:hover{border-color:var(--pr);box-shadow:var(--sh)}
.qa b{font-size:13px;display:block}.qa small{font-size:10px;color:var(--tx3);display:block}.qa span:last-child{margin-left:auto;font-size:12px;color:var(--tx3)}

/* === CARDS === */
.card{background:var(--sf);border:1px solid var(--bd);border-radius:12px;margin-bottom:16px}
.card-hd{padding:16px 20px;border-bottom:1px solid var(--bd)}.card-hd h3{font-size:15px;font-weight:600}.card-hd p{font-size:12px;color:var(--tx2);margin-top:2px}
.card-body{padding:20px}.card-body.no-pad{padding:0}

/* === TABLES === */
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{background:var(--sfh);padding:10px 16px;text-align:left;font-weight:600;font-size:12px;color:var(--tx2);border-bottom:1px solid var(--bd);white-space:nowrap}
.table td{padding:10px 16px;border-bottom:1px solid var(--bd);vertical-align:top}
.table tbody tr:hover{background:var(--sfh)}
.table-footer{padding:10px 16px;text-align:center;font-size:12px;color:var(--tx3);border-top:1px solid var(--bd)}
.info-table td{padding:10px 20px}
.info-key{width:200px;font-weight:500;color:var(--tx2);white-space:nowrap;font-size:13px}
.info-val{font-size:13px}

/* Status Badges */
.status-badge{display:inline-block;padding:2px 10px;font-size:11px;font-weight:600;border-radius:999px;text-transform:capitalize}
.status-uploaded{background:var(--infbg);color:var(--inf)}
.status-pending{background:var(--wrnbg);color:var(--wrn)}
.status-processing{background:var(--infbg);color:var(--inf)}
.status-completed{background:var(--okbg);color:var(--ok)}
.status-failed{background:var(--errbg);color:var(--err)}

/* File items */
.file-name{font-weight:500}.file-stored{font-size:11px;color:var(--tx3);margin-top:2px}
.action-group{display:flex;align-items:center;gap:8px}
.status-select{padding:4px 8px;font-size:12px;border:1px solid var(--bd);border-radius:4px;background:var(--sf);cursor:pointer}

/* Empty State */
.empty-state{text-align:center;padding:40px 20px}
.empty-icon{font-size:36px;margin-bottom:12px}.empty-state p{font-size:15px;font-weight:500;margin-bottom:4px}
.empty-state small{font-size:13px;color:var(--tx2)}

/* === SETTINGS === */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--bd);margin-bottom:20px}
.tab{padding:10px 20px;font-size:14px;font-weight:500;color:var(--tx2);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px;transition:.2s}
.tab:hover{color:var(--tx);text-decoration:none}.tab.active{color:var(--pr);border-bottom-color:var(--pr)}
.tab-content{min-height:200px}

/* === UPLOADS === */
.upload-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px}
.us-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:12px;text-align:center}
.us-val{font-size:18px;font-weight:700}.us-label{font-size:11px;color:var(--tx2);margin-top:2px}
.us-uploaded{border-left:3px solid var(--inf)}.us-pending{border-left:3px solid var(--wrn)}
.us-processing{border-left:3px solid var(--inf);background:var(--infbg)}.us-completed{border-left:3px solid var(--ok);background:var(--okbg)}
.us-failed{border-left:3px solid var(--err);background:var(--errbg)}

.upload-form{display:flex;flex-direction:column;gap:16px}
.upload-drop{border:2px dashed var(--bd);border-radius:var(--r);padding:24px;text-align:center;transition:.2s;cursor:pointer}
.upload-drop:hover,.upload-drop:has(input:focus){border-color:var(--pr);background:var(--sfh)}
.upload-drop input[type=file]{margin-bottom:8px}
.upload-hint p{font-size:14px;font-weight:500;margin-bottom:4px}.upload-hint small{font-size:12px;color:var(--tx2)}

/* === IMPORTS === */
.import-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px}
.is-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:12px;text-align:center}
.is-val{font-size:18px;font-weight:700}.is-label{font-size:11px;color:var(--tx2);margin-top:2px}
.is-total{border-left:3px solid var(--pr)}
.is-uploaded{border-left:3px solid var(--inf)}
.is-pending{border-left:3px solid var(--wrn)}
.is-processing{border-left:3px solid var(--inf);background:var(--infbg)}
.is-completed{border-left:3px solid var(--ok);background:var(--okbg)}
.is-failed{border-left:3px solid var(--err);background:var(--errbg)}

.info-notice{border-left:4px solid var(--inf);background:var(--infbg)}
.notice-content{display:flex;align-items:flex-start;gap:12px;padding:4px 0}
.notice-icon{font-size:20px;flex-shrink:0}
.notice-content b{font-size:14px;display:block;margin-bottom:2px}
.notice-content p{font-size:13px;color:var(--tx2);margin:0}

.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.detail-item{display:flex;flex-direction:column;gap:2px}
.detail-label{font-size:12px;color:var(--tx3);font-weight:500}
.detail-value{font-size:14px;font-weight:500}

/* === CACHE === */
.cache-status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.cs-card{background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px}
.cs-icon{font-size:24px}.cs-val{font-size:18px;font-weight:700;line-height:1.2}
.cs-label{font-size:12px;color:var(--tx2);margin-top:2px}

.action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.action-form{text-align:center}
.action-desc{font-size:12px;color:var(--tx2);margin-top:8px}

/* === SYSTEM INFO === */
.ext-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.ext-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--bd);border-radius:var(--r);font-size:13px}
.ext-ok{background:var(--okbg)}.ext-missing{background:var(--errbg)}

/* === LOG VIEWER === */
.filter-form{width:100%}
.filter-row{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}
.filter-row .fg{margin-bottom:0;flex:1;min-width:150px}
.filter-action{display:flex;gap:8px;align-items:center;flex:none !important;padding-bottom:0}
.filter-select{width:100%;padding:8px 12px;border:1px solid var(--bd);border-radius:var(--r);font-size:14px;background:var(--sf)}

.log-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.ls-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:12px;text-align:center}
.ls-val{font-size:16px;font-weight:700}.ls-label{font-size:11px;color:var(--tx2);margin-top:2px}

.log-entries{max-height:600px;overflow-y:auto}
.log-entry{padding:12px 20px;border-bottom:1px solid var(--bd);transition:.2s}
.log-entry:hover{background:var(--sfh)}
.log-entry:last-child{border-bottom:none}
.log-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.log-level{display:inline-block;padding:1px 8px;font-size:10px;font-weight:700;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}
.log-level-error{background:var(--errbg);color:var(--err)}
.log-level-warn{background:var(--wrnbg);color:var(--wrn)}
.log-level-info{background:var(--infbg);color:var(--inf)}
.log-level-debug{background:var(--acc);color:var(--tx3)}
.log-time{font-size:12px;color:var(--tx3);font-family:monospace}
.log-msg{font-size:13px;font-weight:500;margin-bottom:4px}
.log-ctx{margin-top:4px}
.log-ctx pre{background:var(--acc);padding:8px 12px;border-radius:4px;font-size:11px;font-family:'SF Mono',monospace;overflow-x:auto;max-height:120px;overflow-y:auto}

.log-error{border-left:3px solid var(--err)}
.log-warn{border-left:3px solid var(--wrn)}
.log-info{border-left:3px solid var(--inf)}
.log-debug{border-left:3px solid var(--tx3)}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px;padding:12px}
.page-info{font-size:13px;color:var(--tx2)}

/* === LANDING === */
.landing{min-height:100vh;display:flex;flex-direction:column}
.l-head{border-bottom:1px solid var(--bd)}.l-head-in{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 20px}
.l-brand{display:flex;align-items:center;gap:8px}.l-brand b{font-size:15px}
.l-badge{font-size:10px;background:var(--acc);padding:1px 8px;border-radius:999px;color:var(--tx2)}
.l-logo{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r);background:var(--pr);color:var(--prf);font-weight:700;font-size:13px}
.hero{text-align:center;padding:64px 20px 48px;max-width:800px;margin:0 auto}
.hero-tag{display:inline-block;font-size:13px;background:var(--acc);padding:4px 14px;border-radius:999px;color:var(--tx2);margin-bottom:16px}
.hero-t{font-size:40px;font-weight:700;line-height:1.15;margin-bottom:16px}.hero-acc{color:var(--pr)}
.hero-sub{font-size:16px;color:var(--tx2);max-width:600px;margin:0 auto 28px}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.feat-sec,.arch-sec{padding:48px 20px;max-width:1100px;margin:0 auto;text-align:center}
.sec-sub{color:var(--tx2);font-size:14px;margin-bottom:28px}
.feat-sec{border-top:1px solid var(--bd);background:var(--sfh)}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.feat-card{background:var(--sf);border:1px solid var(--bd);border-radius:12px;padding:20px;text-align:left}
.feat-card.on{border-color:var(--pr)}.feat-card.off{opacity:.5}
.feat-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:20px}
.feat-card h3{font-size:14px;font-weight:600;margin-bottom:4px}.feat-card p{font-size:12px;color:var(--tx2)}
.arch-sec{border-top:1px solid var(--bd)}
.arch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;text-align:left}
.arch-i{display:flex;gap:12px;padding:14px;border:1px solid var(--bd);border-radius:var(--r);background:var(--sf)}
.arch-i span:first-child{font-size:20px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--acc);border-radius:var(--r)}
.arch-i h4{font-size:13px;font-weight:500}.arch-i p{font-size:11px;color:var(--tx2);margin-top:2px}
.l-foot{border-top:1px solid var(--bd);margin-top:auto;padding:20px}
.l-foot-in{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.l-foot-brand{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tx2)}
.l-logo-sm{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:var(--pr);color:var(--prf);font-weight:700;font-size:9px}
.l-foot-info{font-size:12px;color:var(--tx3);display:flex;gap:8px}

/* === SPRINT 3: IMPORT PIPELINE === */
.progress-wrap{position:relative;height:24px;background:var(--acc);border-radius:12px;overflow:hidden}
.progress-bar{height:100%;background:var(--pr);border-radius:12px;transition:width .3s;min-width:0}
.progress-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--tx);z-index:1}
.progress-wrap.progress-lg{height:32px}
.stat-valid{color:var(--ok);font-weight:600}.stat-invalid{color:var(--err);font-weight:600}.stat-sep{color:var(--tx3);margin:0 2px}
.file-meta{font-size:11px;color:var(--tx3);margin-top:2px}

/* Pipeline Steps */
.pipeline-steps{display:flex;align-items:flex-start;gap:8px;overflow-x:auto;padding:8px 0}
.pipeline-step{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 8px;background:var(--sfh);border:1px solid var(--bd);border-radius:var(--r)}
.pipeline-step .ps-icon{font-size:24px;margin-bottom:6px}
.pipeline-step .ps-info b{font-size:12px;display:block;margin-bottom:2px}
.pipeline-step .ps-info p{font-size:10px;color:var(--tx2);line-height:1.4}
.pipeline-arrow{font-size:16px;color:var(--tx3);flex-shrink:0;align-self:center}

/* Danger Zone */
.danger-card{border-color:var(--err)}
.danger-card .card-hd{background:var(--errbg);color:var(--err);border-bottom-color:#fecaca}
.danger-text{font-size:13px;color:var(--tx2);margin-bottom:12px}
.danger-form{display:flex;gap:8px;align-items:center}
.danger-input{flex:1;padding:8px 12px;border:1px solid var(--bd);border-radius:var(--r);font-size:13px;font-family:inherit}

/* === ERRORS === */
.err-box{text-align:center;max-width:400px}.err-ico{font-size:48px;margin-bottom:12px}.err-ico.danger{color:var(--err)}
.err-code{font-size:48px;font-weight:700}.err-title{font-size:18px;font-weight:600;margin-bottom:8px}
.err-desc{font-size:14px;color:var(--tx2);margin-bottom:20px}.err-btns{display:flex;gap:12px;justify-content:center}

/* === RESPONSIVE === */
@media(max-width:1200px){
  .geo-stats{grid-template-columns:repeat(3,1fr)}
  .import-overview,.upload-stats,.import-stats{grid-template-columns:repeat(3,1fr)}
  .ext-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1024px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .sprint-grid{grid-template-columns:1fr 1fr}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .info-grid{grid-template-columns:repeat(2,1fr)}
  .action-grid{grid-template-columns:1fr}
  .cache-status-grid{grid-template-columns:repeat(2,1fr)}
  .detail-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sidebar{position:fixed;left:-260px;z-index:50;height:100vh;width:260px;transition:left .2s;box-shadow:var(--sh)}
  .sidebar.mobile-open{left:0}
  .sb-overlay.show{display:block}
  .main{width:100%}
  .menu-toggle{display:block}
  .geo-stats{grid-template-columns:repeat(2,1fr)}
  .import-overview,.upload-stats,.import-stats{grid-template-columns:repeat(2,1fr)}
  .hero-t{font-size:28px}
  .sprint-grid,.qa-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .arch-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .ext-grid{grid-template-columns:repeat(2,1fr)}
  .filter-row{flex-direction:column}
  .filter-action{padding-top:8px}
  .table{font-size:12px}.table th,.table td{padding:8px 10px}
  .topbar{padding:0 12px}
  .content{padding:12px}
  .breadcrumb{padding:8px 12px;font-size:12px}
}
