/* ═══════════════════════════════════════════════════════════
   BuildGenius — Phase 2K  |  styles.css
   Complete design system: foundation + all modules
   ═══════════════════════════════════════════════════════════ */

/* ─── 1. ROOT VARIABLES ──────────────────────────────────── */
:root {
  /* Color palette */
  --bg:#f0f4f8;
  --card:#fff;
  --navy:#0b1220;
  --navy-2:#0f172a;
  --blue:#2563eb;
  --blue-dark:#1d4ed8;
  --blue-light:rgba(37,99,235,.09);
  --blue-soft:#eaf1ff;
  --text:#0b1220;
  --text-2:#334155;
  --muted:#64748b;
  --muted-2:#94a3b8;
  --border:#dde3ec;
  --border-2:#c8d1de;
  --danger:#dc2626;
  --danger-bg:rgba(220,38,38,.08);
  --green:#16a34a;
  --green-bg:rgba(22,163,74,.08);
  --amber:#d97706;
  --amber-bg:rgba(217,119,6,.09);
  --purple:#7c3aed;
  --purple-bg:rgba(124,58,237,.09);
  --teal:#0891b2;
  --teal-bg:rgba(8,145,178,.09);
  /* Typography */
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  /* Shape & shadow */
  --radius:12px;
  --radius-sm:8px;
  --radius-lg:16px;
  --shadow:0 0 0 1px rgba(11,18,32,.05),0 2px 6px rgba(11,18,32,.06),0 6px 18px rgba(11,18,32,.05);
  --shadow-md:0 0 0 1px rgba(11,18,32,.05),0 4px 12px rgba(11,18,32,.08),0 12px 32px rgba(11,18,32,.09);
  --shadow-lg:0 0 0 1px rgba(11,18,32,.06),0 8px 24px rgba(11,18,32,.12),0 24px 56px rgba(11,18,32,.12);
}

/* ─── 2. RESET ───────────────────────────────────────────── */
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
button,input,select,textarea{font:inherit}
a{color:var(--blue);text-decoration:none}
.hidden{display:none!important}

/* ─── 3. LOADING / LOGIN ─────────────────────────────────── */
.loading-screen,.login-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 100%);z-index:1000}
.loading-screen{flex-direction:column;color:#fff}
.loading-logo{width:88px;height:88px;object-fit:contain}
.loading-title{font:700 28px var(--font);margin-top:14px;letter-spacing:-.5px}
.loading-title span,.login-card h1 span,.brand-row span{color:#60a5fa}
.loading-message{margin-top:8px;color:rgba(255,255,255,.65);font-size:14px}
.login-card{width:min(420px,calc(100vw - 32px));background:#fff;border-radius:20px;padding:40px;box-shadow:0 24px 64px rgba(0,0,0,.30)}
.login-logo{width:68px;height:68px;display:block;margin:0 auto 12px}
.login-card h1{text-align:center;margin:0;font:700 30px var(--font);letter-spacing:-.5px}
.login-card p{text-align:center;color:var(--muted);font-size:14px;line-height:1.6;margin:8px 0 0}
.login-card label{display:block;margin-top:16px;font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.login-card input[type=email],.login-card input[type=password]{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-top:6px;font-size:15px;transition:border-color .15s;outline:none}
.login-card input:focus{border-color:var(--blue)}
.remember{display:flex!important;align-items:center;gap:9px;text-transform:none!important;letter-spacing:0!important;font-size:13px!important;font-weight:500!important;color:var(--text-2)!important}
.remember input{width:16px;height:16px;accent-color:var(--blue)}
.login-card button[type=submit]{width:100%;border:0;background:var(--blue);color:#fff;border-radius:var(--radius-sm);padding:13px;margin-top:20px;font-weight:700;font-size:15px;cursor:pointer;transition:background .15s}
.login-card button[type=submit]:hover{background:var(--blue-dark)}
.login-card button:disabled{opacity:.6}
.error-text{color:var(--danger);font-size:13px;min-height:20px;text-align:center;margin-top:10px}

/* ─── 4. APP SHELL + SIDEBAR ─────────────────────────────── */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:260px;background:linear-gradient(180deg,#0b1220 0%,#0e1829 100%);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:20;flex-shrink:0;box-shadow:1px 0 0 rgba(255,255,255,.04);transition:width .22s ease;overflow:hidden}
.brand-row{display:flex;gap:10px;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.07)}
.brand-row img{width:30px;height:30px;border-radius:6px;flex-shrink:0}
.brand-row strong{font:700 17px var(--font);letter-spacing:-.3px}
.brand-row small,.user-card small{display:block;color:rgba(255,255,255,.42);font-size:11px;margin-top:2px}
.brand-text{flex:1;overflow:hidden;transition:opacity .15s,max-width .22s ease;max-width:200px;white-space:nowrap}
.mobile-close{margin-left:auto;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);color:rgba(255,255,255,.65);border-radius:8px;width:32px;height:32px;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:16px}
.user-card{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.07)}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--blue);display:grid;place-items:center;font-weight:800;font-size:13px;flex-shrink:0}
.user-card strong{font-size:13px;font-weight:600}
.user-info{overflow:hidden;transition:opacity .15s,max-width .22s ease;max-width:220px}
.side-nav{padding:10px 8px;flex:1;overflow:hidden}
.side-nav button{width:100%;text-align:left;background:transparent;color:rgba(255,255,255,.55);border:0;border-left:2px solid transparent;border-radius:0 8px 8px 0;padding:10px 12px;cursor:pointer;font-weight:500;font-size:13.5px;transition:all .15s;display:flex;align-items:center;gap:9px;white-space:nowrap;overflow:hidden}
.side-nav button i{font-style:normal;font-size:15px;flex-shrink:0;width:20px;text-align:center}
.side-nav button span{flex:1;overflow:hidden;transition:opacity .15s,max-width .22s ease;max-width:200px}
.side-nav button:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.88);border-left-color:rgba(255,255,255,.15)}
.side-nav button.active{background:rgba(37,99,235,.18);color:#fff;font-weight:600;border-left-color:var(--blue)}
.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.07)}
.sidebar-collapse-btn{display:block;width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);color:rgba(255,255,255,.55);border-radius:7px;padding:7px;cursor:pointer;font-size:12px;font-weight:700;margin-bottom:8px;transition:background .15s;text-align:center}
.sidebar-collapse-btn:hover{background:rgba(255,255,255,.12);color:#fff}
/* Collapsed state */
.app-shell.sidebar-collapsed .sidebar{width:52px}
.app-shell.sidebar-collapsed .brand-text,
.app-shell.sidebar-collapsed .user-info,
.app-shell.sidebar-collapsed .status-pill{opacity:0;pointer-events:none;max-width:0}
.app-shell.sidebar-collapsed .side-nav button span{opacity:0;max-width:0;pointer-events:none}
.app-shell.sidebar-collapsed .side-nav button{padding:10px;justify-content:center;border-left-color:transparent}
.app-shell.sidebar-collapsed .side-nav button.active{border-left-color:var(--blue)}
.app-shell.sidebar-collapsed .sidebar-collapse-btn{font-size:14px}
.status-pill{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:10px}
.secondary{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.70);border-radius:8px;padding:10px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s}
.secondary:hover{background:rgba(255,255,255,.12)}

/* ─── 5. MAIN AREA + TOPBAR ──────────────────────────────── */
.main-area{flex:1;min-width:0}
.topbar{height:62px;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:none;box-shadow:0 1px 0 var(--border),0 2px 12px rgba(11,18,32,.04);display:flex;align-items:center;gap:14px;padding:0 28px;position:sticky;top:0;z-index:15}
.topbar h2{margin:0;font:700 19px var(--font);letter-spacing:-.4px}
.topbar p{margin:2px 0 0;color:var(--muted);font-size:12px}
.mobile-menu{display:none;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-sm);width:40px;height:40px;cursor:pointer;font-size:18px}
#top-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.view{padding:28px}
.drawer-overlay{display:none}
.bottom-nav{display:none}

/* ─── 6. CORE COMPONENTS ─────────────────────────────────── */
/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}

/* Badges */
.badges{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.02em;background:var(--blue-light);color:var(--blue-dark)}
.badge.gray{background:#f1f5f9;color:var(--muted)}
.badge.stage-concept{background:#f1f5f9;color:#475569}
.badge.stage-predevelopment{background:var(--purple-bg);color:var(--purple)}
.badge.stage-financing{background:var(--amber-bg);color:#92400e}
.badge.stage-construction{background:var(--blue-light);color:var(--blue-dark)}
.badge.stage-stabilization{background:var(--teal-bg);color:var(--teal)}
.badge.stage-completed{background:var(--green-bg);color:var(--green)}

/* Buttons — all naming conventions used across modules */
.btn-primary,.primary-button{background:var(--blue);color:#fff;border:0;border-radius:var(--radius-sm);padding:10px 18px;font-weight:700;font-size:14px;cursor:pointer;transition:background .15s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.btn-primary:hover,.primary-button:hover{background:var(--blue-dark)}
.btn-outline,.small-button{background:#fff;color:var(--text-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 16px;font-weight:600;font-size:14px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.btn-outline:hover,.small-button:hover{border-color:rgba(37,99,235,.45);color:var(--blue)}
.btn-sm{background:var(--blue);color:#fff;border:0;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}
.btn-sm:hover{background:var(--blue-dark)}
.link-button{white-space:nowrap}
.danger-button{border-color:rgba(185,28,28,.25)!important;color:#b91c1c!important;background:#fff!important}
.danger-button:hover{background:#fee2e2!important;border-color:#b91c1c!important;color:#991b1b!important}
.danger-text{color:var(--danger)!important}

/* Utility */
.meta{color:var(--muted);font-size:13px;line-height:1.5}
.notice{background:#fffbeb;border:1.5px solid rgba(217,119,6,.25);padding:14px 16px;border-radius:var(--radius);color:#92400e;font-size:14px}
.notice-card{border:1.5px solid rgba(37,99,235,.18);background:rgba(37,99,235,.05);border-radius:var(--radius);padding:12px 16px}
.notice-card strong{display:block;margin-bottom:4px}
.error-card{background:#fff;border:1.5px solid rgba(220,38,38,.25);color:var(--danger);border-radius:var(--radius);padding:18px}
.no-link{color:var(--muted);font-size:13px;font-weight:600}
.kicker,.bg-kicker{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--blue)}
.delete-admin-note{font-size:12px;color:var(--muted)}

/* ─── 7. PROJECT CARDS + METRICS ─────────────────────────── */
.project-card{cursor:pointer;transition:box-shadow .15s,border-color .15s,transform .15s}
.project-card:hover{transform:translateY(-2px);border-color:rgba(37,99,235,.40);box-shadow:var(--shadow-md)}
.project-card h3{margin:0 0 5px;font:700 17px var(--font);letter-spacing:-.3px}
.project-hero{border-color:rgba(37,99,235,.30);box-shadow:var(--shadow-md)}
.project-hero h2{font:700 22px var(--font);letter-spacing:-.5px}
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:14px;margin-top:16px}
.metric small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.07em;font-weight:600}
.metric strong{display:block;font-size:20px;font-weight:700;margin-top:4px;letter-spacing:-.4px}

/* Project tabs (inside project detail) */
.project-tabs{display:flex;gap:8px;margin-top:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.project-tabs button{border:1.5px solid var(--border);background:#fff;color:var(--muted);border-radius:999px;padding:9px 16px;font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s}
.project-tabs button.active{background:var(--blue-light);border-color:rgba(37,99,235,.35);color:var(--blue-dark)}

/* Section header pattern used across all modules */
.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.section-header h3{margin:0 0 4px;font:700 20px var(--font);letter-spacing:-.4px}
.actions-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* ─── 8. DASHBOARD — bg-* system (Phase 2K) ─────────────── */
.bg-dashboard-shell{display:flex;flex-direction:column;gap:22px}
.bg-loading-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow);color:var(--muted)}

/* Hero / greeting */
.bg-dashboard-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:22px;padding:4px 0 2px}
.bg-dashboard-hero h2{font:800 34px var(--font);line-height:1.05;margin:4px 0;color:var(--text);letter-spacing:-1px}
.bg-dashboard-hero p{margin:0;color:var(--muted);font-size:13.5px}
.bg-hero-actions{display:flex;gap:10px;align-items:center}
.bg-button{border:1.5px solid rgba(37,99,235,.28);border-radius:var(--radius-sm);padding:11px 18px;font-weight:700;cursor:pointer;font-size:14px;transition:background .15s,border-color .15s}
.bg-button-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.bg-button-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.bg-button-soft{background:var(--blue-soft);color:var(--blue-dark);border-color:rgba(37,99,235,.25)}
.bg-button-soft:hover{background:var(--blue-light);border-color:rgba(37,99,235,.45)}

/* KPI stat cards */
.bg-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(130px,1fr));gap:12px}
.bg-metric-card{background:#fff;border:none;border-radius:14px;padding:20px 22px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.bg-metric-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0;background:var(--border)}
.bg-metric-card:has(strong.blue)::before{background:var(--blue)}
.bg-metric-card:has(strong.green)::before{background:var(--green)}
.bg-metric-card:has(strong.red)::before{background:var(--danger)}
.bg-metric-card:has(strong.amber)::before{background:var(--amber)}
.bg-metric-card small{display:block;color:var(--muted);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;margin-bottom:10px}
.bg-metric-card strong{display:block;font-size:clamp(14px,1.55vw,22px);font-weight:800;line-height:1;color:var(--text);margin-bottom:7px;letter-spacing:-.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.bg-metric-card strong.blue,.blue{color:var(--blue)!important}
.bg-metric-card strong.green,.green{color:var(--green)!important}
.bg-metric-card strong.red,.red{color:var(--danger)!important}
.bg-metric-card strong.amber,.amber{color:var(--amber)!important}
.bg-metric-card span{color:var(--muted-2);font-size:12px}

/* Attention / panel cards */
.bg-attention-card,.bg-panel{background:#fff;border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.bg-attention-card{padding:24px}
.bg-panel{padding:24px}
.bg-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}
.bg-section-head.compact{margin-bottom:12px}
.bg-section-head h3{font:700 17px var(--font);line-height:1.1;margin:0;color:var(--text);letter-spacing:-.3px}
.bg-section-head p{margin:5px 0 0;color:var(--muted-2);font-size:12px}

/* Mini button inside panels */
.bg-mini-button{background:var(--blue);color:#fff;border:0;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}
.bg-mini-button:hover{background:var(--blue-dark)}

/* Attention items */
.bg-attention-list{display:flex;flex-direction:column}
.bg-attention-item{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;border:0;border-bottom:1px solid var(--border);background:transparent;padding:13px 0;text-align:left;cursor:pointer;width:100%}
.bg-attention-item:last-child{border-bottom:0}
.bg-attention-item strong{display:block;font-size:15px;color:var(--text);font-weight:600}
.bg-attention-item em{display:block;font-style:normal;color:var(--muted);margin-top:3px;font-size:13px}
.bg-chip{border-radius:999px;font-weight:700;font-size:11px;padding:5px 10px;white-space:nowrap}
.bg-chip.red{background:var(--danger-bg);color:var(--danger)}
.bg-chip.amber{background:var(--amber-bg);color:var(--amber)}

/* Main 3-column grid */
.bg-main-grid{display:grid;grid-template-columns:1.1fr 1.1fr .8fr;gap:18px}

/* Task items (inside dashboard) */
.bg-list{display:flex;flex-direction:column}
.bg-task-item{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;border:0;border-bottom:1px solid #f0f4f8;background:transparent;padding:13px 0;text-align:left;cursor:pointer;width:100%;transition:opacity .12s}
.bg-task-item:last-child{border-bottom:0}
.bg-task-item:hover{opacity:.78}
.bg-task-item strong{display:block;font-size:14px;color:var(--text);font-weight:600}
.bg-task-item span{font-size:12.5px;color:var(--muted)}
.bg-status-pill{background:#f1f5f9;color:var(--muted);border-radius:999px;padding:5px 11px;font-weight:700;font-size:12px;white-space:nowrap}
.bg-avatar-mini{width:34px;height:34px;border-radius:50%;background:#1e40af;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;flex-shrink:0}

/* Project items (inside dashboard) */
.bg-project-stack{display:flex;flex-direction:column}
.bg-project-item{border:0;border-bottom:1px solid #f0f4f8;background:transparent;padding:14px 0;text-align:left;cursor:pointer;width:100%;transition:opacity .12s}
.bg-project-item:last-child{border-bottom:0}
.bg-project-item:hover{opacity:.78}
.bg-project-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}
.bg-project-head strong{font-size:14px;color:var(--text);font-weight:600;letter-spacing:-.2px}
.bg-stage-pill{border-radius:6px;padding:3px 9px;font-size:11px;font-weight:700;background:#f1f5f9;color:var(--muted);letter-spacing:.01em}
.bg-stage-pill.concept{background:#f1f5f9;color:#475569}
.bg-stage-pill.predevelopment{background:var(--purple-bg);color:var(--purple)}
.bg-stage-pill.financing{background:var(--amber-bg);color:#92400e}
.bg-stage-pill.construction{background:var(--blue-light);color:var(--blue-dark)}
.bg-stage-pill.stabilization{background:var(--teal-bg);color:var(--teal)}
.bg-stage-pill.completed{background:var(--green-bg);color:var(--green)}
.bg-progress{height:4px;background:#e8edf4;border-radius:999px;overflow:hidden;margin:10px 0}
.bg-progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,var(--blue-dark))}
.bg-project-meta{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:12px}

/* Portfolio Pulse / side panels */
.bg-side-stack{display:flex;flex-direction:column;gap:18px}
.bg-pulse-row{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid #f0f4f8;padding:10px 0;font-size:13.5px}
.bg-pulse-row:last-child{border-bottom:0}
.bg-pulse-row span{color:var(--muted)}
.bg-pulse-row strong{font-weight:700;color:var(--text);letter-spacing:-.2px}
.bg-pulse-row strong.green{color:var(--green)}
.bg-pulse-row strong.red{color:var(--danger)}
.bg-pulse-row strong.amber{color:var(--amber)}
.bg-pulse-row strong.blue{color:var(--blue)}

/* Stages */
.bg-stage-list{display:flex;flex-direction:column;gap:10px}
.bg-stage-row{display:grid;grid-template-columns:110px 1fr 28px;gap:10px;align-items:center;color:var(--muted);font-size:13px}
.bg-stage-bar{height:4px;background:#e8edf4;border-radius:999px;overflow:hidden}
.bg-stage-bar i{display:block;height:100%;background:var(--blue);border-radius:999px}
.bg-stage-row strong{color:var(--blue);text-align:right;font-weight:700}

/* Weekly Analytics */
.bg-weekly h3{font:700 22px var(--font);margin:0 0 14px;letter-spacing:-.4px}
.bg-analytics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bg-blue-label{text-transform:uppercase;color:var(--blue);font-weight:800;font-size:12px;letter-spacing:.06em;margin-bottom:14px}
.bg-pipeline-row{display:grid;grid-template-columns:130px 1fr auto;gap:12px;align-items:center;border-bottom:1px solid var(--border);padding:11px 0}
.bg-pipeline-row:last-child{border-bottom:0}
.bg-pipeline-row strong{font-weight:700;font-size:14px}
.bg-pipeline-row em{font-style:normal;color:var(--muted);font-size:13px}
.bg-empty{color:var(--muted);padding:18px;border:1.5px dashed var(--border);border-radius:var(--radius);background:#fafafa;text-align:center;font-size:14px}

/* ─── 9. DOCUMENTS MODULE (2A) ───────────────────────────── */
.drive-card{display:flex;justify-content:space-between;align-items:center;gap:14px;border:1.5px solid rgba(37,99,235,.18);background:rgba(37,99,235,.04);border-radius:var(--radius);padding:14px;margin-bottom:16px}
.doc-folder-list{display:flex;flex-direction:column;gap:10px}
.doc-folder{border:1.5px solid var(--border);border-radius:var(--radius);background:#f8fafc;overflow:hidden}
.doc-folder summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;font-weight:700;cursor:pointer;font-size:15px}
.doc-folder summary::-webkit-details-marker{display:none}
.folder-count{background:var(--blue-light);color:var(--blue-dark);border-radius:999px;min-width:26px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.doc-folder-body{border-top:1px solid var(--border);background:#fff;padding:12px}
.folder-actions{margin-bottom:10px}
.doc-row{display:flex;align-items:center;gap:12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px;background:#fff}
.doc-row:last-child{margin-bottom:0}
.doc-icon{font-size:22px;flex-shrink:0}
.doc-info{flex:1;min-width:0}
.doc-info strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px}
.doc-info span{font-size:12px;color:var(--muted)}
.empty-row{color:var(--muted);font-size:13px;padding:10px 0}

/* ─── 10. TASKS + MEETING NOTES (2C / 2D) ───────────────── */
.task-filter-bar{display:grid;grid-template-columns:180px 1fr 220px;gap:10px;margin:12px 0 16px}
.task-filter-bar input,.task-filter-bar select{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:#fff;outline:none;transition:border-color .15s}
.task-filter-bar input:focus,.task-filter-bar select:focus{border-color:var(--blue)}
.task-summary-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.task-summary-row span{background:#f1f5f9;border-radius:999px;padding:5px 12px;color:var(--muted);font-size:12px;font-weight:700}
.task-list{display:flex;flex-direction:column;gap:10px}
.task-row{display:flex;justify-content:space-between;gap:16px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;padding:14px;box-shadow:var(--shadow)}
.task-main{min-width:0;flex:1}
.task-title-button{border:0;background:transparent;padding:0;text-align:left;font-weight:700;font-size:15px;cursor:pointer;color:var(--text)}
.task-title-button:hover{color:var(--blue-dark)}
.task-description{margin-top:6px;color:var(--text-2);font-size:13px;line-height:1.5}
.chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.mini-chip{display:inline-flex;align-items:center;border-radius:999px;background:var(--blue-light);color:var(--blue-dark);font-size:11px;font-weight:700;padding:4px 9px}
.muted-chip{background:#f1f5f9;color:var(--muted)}
.project-chip{background:#fff8e8;color:#92400e}
.task-side{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end;min-width:260px}
.status-pill-lite{border-radius:999px;padding:5px 10px;font-size:11px;font-weight:700;background:#f1f5f9;color:var(--muted)}
.status-pill-lite.completed{background:var(--green-bg);color:var(--green)}
.priority-pill{border-radius:999px;padding:5px 10px;font-size:11px;font-weight:700;background:#f1f5f9;color:var(--muted)}
.priority-pill.high,.priority-pill.urgent{background:var(--danger-bg);color:var(--danger)}
.priority-pill.medium{background:var(--amber-bg);color:var(--amber)}
.priority-pill.low{background:var(--green-bg);color:var(--green)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.compact-notice{margin-top:12px;padding:10px}
.compact-header{margin-bottom:8px}
.task-attachments-panel{border:1.5px solid var(--border);border-radius:var(--radius);padding:12px;margin-top:14px;background:#f8fafc}
.task-attachments-panel .doc-row{margin-bottom:8px}
/* Meeting notes */
.meeting-notes-card .note-row .task-description{max-width:900px}
.notes-filter-bar{grid-template-columns:180px 1fr 180px}

/* ─── 11. CONTACTS MODULE (2F) ───────────────────────────── */
.toolbar-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.search-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:#fff;font-size:14px;min-height:40px;outline:none;flex:1;min-width:240px;transition:border-color .15s}
.search-input:focus{border-color:var(--blue)}
.select-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;background:#fff;font-size:14px;min-height:40px;min-width:180px;outline:none;transition:border-color .15s}
.select-input:focus{border-color:var(--blue)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-actions .meta{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}
.contact-summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.contact-list .contact-row{align-items:flex-start}

/* ─── 12. TIME TRACKER MODULE (2H) ───────────────────────── */
.time-table-wrap{overflow:auto;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff}
.time-table{width:100%;border-collapse:collapse;font-size:13px;min-width:900px}
.time-table th,.time-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.time-table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#f8fafc;font-weight:700}
.time-table tr:last-child td{border-bottom:0}
.time-summary-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}

/* ─── 13. PHOTOS + MAP MODULE (2I) ───────────────────────── */
.map-card{display:grid;grid-template-columns:320px 1fr;gap:16px;border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:14px;background:#fff;margin-bottom:16px;box-shadow:var(--shadow)}
.map-info{padding:8px}
.project-map-frame{width:100%;height:320px;border:0;border-radius:var(--radius);background:#f1f5f9}
.photo-summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.photo-card{border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.photo-thumb-button{border:0;padding:0;margin:0;background:#f1f5f9;width:100%;height:180px;display:block;cursor:pointer;overflow:hidden}
.photo-thumb-button img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .18s ease}
.photo-thumb-button:hover img{transform:scale(1.04)}
.photo-placeholder{height:180px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;color:var(--muted);font-weight:700}
.photo-card-body{padding:12px}
.photo-card-body p{font-size:13px;color:var(--text-2);margin:6px 0}
.photo-viewer-modal{width:min(960px,96vw)}
.photo-viewer-image{width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius);background:#111}
.photo-viewer-overlay{align-items:center}

/* ─── 14. DRAW SCHEDULE / PROFORMA (2J) ─────────────────── */
.draw-summary-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.draw-table-wrap{margin-top:12px;overflow:auto;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff}
.draw-table{width:100%;border-collapse:collapse;font-size:13px;min-width:980px}
.draw-table th,.draw-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.draw-table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#f8fafc;font-weight:700}
.draw-table tr:last-child td{border-bottom:0}
.form-grid.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.snapshot-list{margin-top:12px}
.mini-tabs{display:flex;gap:6px;overflow-x:auto}
.mini-tabs button{border:1.5px solid var(--border);background:#fff;color:var(--muted);border-radius:999px;padding:7px 14px;font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap;transition:all .15s}
.mini-tabs button.active{background:var(--blue-light);border-color:rgba(37,99,235,.35);color:var(--blue-dark)}

/* ─── 15. SHARED — MODALS, FORMS, FILE PREVIEW, SHEET ───── */
/* Modals */
.modal-lite-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:2000;display:flex;align-items:center;justify-content:center;padding:18px}
.modal-lite{width:min(560px,100%);background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:0 24px 70px rgba(0,0,0,.28)}
.modal-lite-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.modal-lite-header h3{margin:0;font:700 20px var(--font);letter-spacing:-.4px}
.icon-button{background:transparent;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--muted);padding:4px}
.icon-button:hover{color:var(--text)}
.modal-lite label{display:block;margin-top:14px;font-size:11px;text-transform:uppercase;letter-spacing:.07em;font-weight:700;color:var(--muted)}
.modal-lite input,.modal-lite select,.modal-lite textarea{width:100%;margin-top:6px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;background:#fff;outline:none;transition:border-color .15s;font-size:14px}
.modal-lite input:focus,.modal-lite select:focus,.modal-lite textarea:focus{border-color:var(--blue)}
.modal-lite textarea{resize:vertical;min-height:80px}
.modal-lite-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}
.task-modal textarea,.note-modal textarea,.draw-modal textarea{width:100%;margin-top:6px;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;background:#fff;resize:vertical;outline:none;transition:border-color .15s}
.task-modal textarea:focus,.note-modal textarea:focus,.draw-modal textarea:focus{border-color:var(--blue)}

/* File preview */
.preview-button{background:var(--blue)!important;color:#fff!important;border-color:var(--blue)!important}
.file-preview-modal{width:min(980px,96vw)}
.file-preview-body{height:min(72vh,720px);background:#111;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;overflow:hidden}
.file-preview-body iframe{width:100%;height:100%;border:0;background:#fff}
.file-preview-body img{max-width:100%;max-height:100%;object-fit:contain}

/* Compact list (company data room) */
.compact-list{display:flex;flex-direction:column;gap:8px}
.compact-row{border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;padding:13px 16px;display:grid;grid-template-columns:1fr 160px 140px;gap:12px;text-align:left;cursor:pointer;transition:border-color .15s}
.compact-row:hover{border-color:rgba(37,99,235,.45)}

/* Mobile bottom sheet (More menu) */
.mobile-more-sheet{position:fixed;left:10px;right:10px;bottom:calc(-100% - 20px);z-index:80;background:rgba(255,255,255,.98);border:1.5px solid var(--border);border-radius:24px 24px calc(24px + env(safe-area-inset-bottom,0px)) calc(24px + env(safe-area-inset-bottom,0px));box-shadow:0 -14px 50px rgba(15,23,42,.20);padding:10px 16px calc(18px + env(safe-area-inset-bottom,0px));transition:bottom .24s ease;backdrop-filter:blur(20px)}
.mobile-more-sheet.open{bottom:10px}
.sheet-handle{width:44px;height:5px;background:rgba(15,23,42,.18);border-radius:999px;margin:4px auto 12px}
.sheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sheet-header strong{font:700 19px var(--font);letter-spacing:-.3px}
.sheet-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.sheet-grid button{border:1.5px solid var(--border);background:#fff;border-radius:var(--radius);min-height:62px;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color .15s}
.sheet-grid button:hover{border-color:rgba(37,99,235,.45)}
.sheet-grid button:active{transform:scale(.98)}

/* ─── 15b. PROJECT LIST PAGE ─────────────────────────────── */
.proj-page-shell{display:flex;flex-direction:column;gap:0}

/* Toolbar: filter tabs + controls */
.proj-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.proj-filter-tabs{display:flex;gap:6px;flex-wrap:wrap}
.proj-filter-tab{border:1.5px solid var(--border);background:#fff;color:var(--muted);border-radius:999px;padding:7px 14px;font-weight:600;font-size:13px;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.proj-filter-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}
.proj-filter-tab:hover:not(.active){border-color:rgba(37,99,235,.4);color:var(--blue)}
.proj-count-badge{background:rgba(0,0,0,.10);color:inherit;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:700}
.proj-filter-tab.active .proj-count-badge{background:rgba(255,255,255,.25)}
.proj-controls{display:flex;gap:8px;align-items:center}
.proj-sort-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;background:#fff;font-size:13px;color:var(--text);cursor:pointer;outline:none;font-weight:500;transition:border-color .15s}
.proj-sort-select:focus{border-color:var(--blue)}
.proj-view-toggle{display:flex;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:#fff}
.proj-view-btn{border:0;background:transparent;padding:7px 11px;cursor:pointer;color:var(--muted);font-size:16px;transition:all .15s;line-height:1}
.proj-view-btn.active{background:var(--blue);color:#fff}
.proj-view-btn:hover:not(.active){background:#f1f5f9;color:var(--text)}

/* Grid view */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px}
.proj-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:column}
.proj-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.proj-photo{height:164px;overflow:hidden;position:relative;flex-shrink:0;background:#e8edf4}
.proj-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.proj-card:hover .proj-photo img{transform:scale(1.04)}
.proj-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.proj-photo-initial{font:800 48px var(--font);color:rgba(255,255,255,.22);letter-spacing:-2px;user-select:none}
.proj-card-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:0;flex:1}
.proj-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}
.proj-card-head h3{margin:0;font:700 15px var(--font);letter-spacing:-.3px;line-height:1.35;flex:1;color:var(--text)}
.proj-card-addr{font-size:12px;color:var(--muted);margin-bottom:10px;line-height:1.45}
.proj-type-chips{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.proj-type-chip{background:#f1f5f9;color:#475569;border-radius:5px;padding:3px 8px;font-size:11px;font-weight:600;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}
.proj-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px 0;border-top:1px solid #f0f4f8;border-bottom:1px solid #f0f4f8;margin-bottom:12px}
.proj-stat small{display:block;color:var(--muted-2);font-size:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:3px}
.proj-stat strong{display:block;font:700 13.5px var(--font);color:var(--text);letter-spacing:-.2px}
.proj-task-row{display:flex;align-items:center;gap:8px;margin-top:auto}
.proj-task-label{font-size:11px;font-weight:700;color:var(--muted-2);white-space:nowrap;flex:none}
.proj-task-bar{flex:1;height:4px;background:#e8edf4;border-radius:999px;overflow:hidden}
.proj-task-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,var(--blue-dark));transition:width .5s ease}
.proj-task-pct{font:700 12px var(--font);color:var(--blue-dark);white-space:nowrap;min-width:32px;text-align:right}

/* List view */
.proj-list-wrap{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;background:#fff}
.proj-table{width:100%;border-collapse:collapse;min-width:700px}
.proj-table thead th{padding:11px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);background:#f8fafc;border-bottom:1.5px solid var(--border);text-align:left;white-space:nowrap;cursor:pointer;user-select:none;transition:color .15s}
.proj-table thead th:hover{color:var(--blue)}
.proj-table thead th.sort-active{color:var(--blue)}
.proj-table tbody tr{border-bottom:1px solid #f4f6f9;cursor:pointer;transition:background .12s}
.proj-table tbody tr:last-child{border-bottom:0}
.proj-table tbody tr:hover{background:#f8fafc}
.proj-table td{padding:12px 16px;vertical-align:middle}
.proj-list-name-cell{display:flex;align-items:center;gap:12px}
.proj-list-thumb{width:50px;height:50px;border-radius:8px;overflow:hidden;flex-shrink:0;position:relative}
.proj-list-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.proj-list-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font:700 18px var(--font);color:rgba(255,255,255,.35)}
.proj-list-name strong{display:block;font:600 14px var(--font);color:var(--text);letter-spacing:-.2px}
.proj-list-name span{font-size:12px;color:var(--muted)}
.proj-list-progress{display:flex;align-items:center;gap:8px;min-width:90px}
.proj-list-progress-bar{flex:1;height:4px;background:#e8edf4;border-radius:999px;overflow:hidden}
.proj-list-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3b82f6,var(--blue-dark))}
.proj-list-pct{font:600 12px var(--font);color:var(--blue-dark);white-space:nowrap}
.proj-empty{padding:32px;text-align:center;color:var(--muted);font-size:14px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow)}

/* ─── 16. PROJECT DETAIL ────────────────────────────────── */
.pd-shell{display:flex;flex-direction:column;gap:0}
.pd-hero{background:linear-gradient(135deg,#0b1220 0%,#0e1829 100%);border-radius:var(--radius-lg);padding:26px 28px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:0;box-shadow:var(--shadow-md)}
.pd-hero-left{flex:1;min-width:0}
.pd-hero-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.pd-type-chip{background:rgba(255,255,255,.10);color:rgba(255,255,255,.75);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;letter-spacing:.04em}
.pd-hero-name{margin:0 0 4px;font-size:clamp(18px,2.2vw,26px);font-weight:800;letter-spacing:-.5px;color:#fff;line-height:1.2}
.pd-hero-addr{margin:0 0 16px;font-size:13px;color:rgba(255,255,255,.48)}
.pd-progress-row{display:flex;align-items:center;gap:10px;max-width:360px}
.pd-progress-bar{flex:1;height:6px;background:rgba(255,255,255,.12);border-radius:3px;overflow:hidden}
.pd-progress-fill{height:100%;background:var(--blue);border-radius:3px;transition:width .4s ease}
.pd-progress-pct{font-size:12px;font-weight:700;color:rgba(255,255,255,.65);flex-shrink:0;min-width:32px}
.pd-hero-stats{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap;flex-shrink:0}
.pd-hero-stat{text-align:right}
.pd-hero-stat small{display:block;font-size:10.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:4px}
.pd-hero-stat strong{display:block;font-size:clamp(15px,1.6vw,22px);font-weight:800;color:#fff;letter-spacing:-.4px}
.pd-hero-actions{display:flex;gap:8px;align-items:center;margin-top:4px}
.pd-tabs-wrap{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:56px;z-index:10;margin:0 0 0;box-shadow:0 1px 0 var(--border)}
.pd-tabs-wrap .proj-filter-tabs{padding:0 4px;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch}
/* Overview grid */
.pd-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pd-overview-panel{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px 22px}
.pd-overview-panel h4{margin:0 0 14px;font-size:14px;font-weight:700;letter-spacing:-.2px;color:var(--text)}
.pd-overview-wide{grid-column:1/-1}
/* Stage steps */
.pd-stage-steps{display:flex;flex-direction:column;gap:10px}
.pd-stage-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted-2)}
.pd-stage-dot{width:12px;height:12px;border-radius:50%;background:var(--border);flex-shrink:0}
.pd-stage-step.done .pd-stage-dot{background:var(--green)}
.pd-stage-step.current .pd-stage-dot{background:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2)}
.pd-stage-step.current{color:var(--blue-dark,#1d4ed8);font-weight:700}
/* Super Admin shell */
.sa-shell{display:flex;flex-direction:column;gap:18px}

/* ─── 17. COMPANY PAGE ──────────────────────────────────── */
.co-shell{display:flex;flex-direction:column;gap:0}
.co-hero{background:linear-gradient(135deg,#0b1220 0%,#0e1829 100%);padding:26px 28px 22px;border-radius:var(--radius-lg);margin-bottom:0;color:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}
.co-kicker{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.38);margin-bottom:6px}
.co-hero h2{margin:0 0 4px;font-size:clamp(20px,2.2vw,28px);font-weight:800;letter-spacing:-.6px;color:#fff;line-height:1.15}
.co-hero p{margin:0;font-size:13px;color:rgba(255,255,255,.48);line-height:1.5}
.co-hero-actions{display:flex;gap:8px;align-items:flex-start;flex-shrink:0}
.co-tabs-wrap{padding:20px 0 0}
.co-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.co-stat-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;position:relative;overflow:hidden}
.co-stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0;background:var(--border)}
.co-stat-card.blue::before{background:var(--blue)}
.co-stat-card.green::before{background:var(--green)}
.co-stat-card.amber::before{background:var(--amber)}
.co-stat-card.purple::before{background:var(--purple)}
.co-stat-card small{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.co-stat-card strong{display:block;font-size:clamp(22px,2.2vw,30px);font-weight:800;color:var(--text);letter-spacing:-.5px;line-height:1;margin-bottom:4px}
.co-stat-card span{font-size:12px;color:var(--muted-2)}
.co-overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.co-info-panel{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px 22px}
.co-info-panel h4{margin:0 0 14px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.co-info-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid #f4f6f9;font-size:13.5px}
.co-info-row:last-child{border-bottom:0}
.co-info-row .label{color:var(--muted)}
.co-info-row .value{font-weight:600;color:var(--text)}
.co-stage-list{display:flex;flex-direction:column;gap:10px}
.co-stage-row{display:grid;grid-template-columns:110px 1fr 28px;align-items:center;gap:10px;font-size:13px}
.co-stage-bar{height:5px;background:#edf0f5;border-radius:999px;overflow:hidden}
.co-stage-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--blue-dark))}
.co-stage-count{font-weight:700;color:var(--text);text-align:right}

/* ─── 17. TASKS PAGE ─────────────────────────────────────── */
.tk-shell{display:flex;flex-direction:column;gap:16px}
.tk-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.tk-panel{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}
.tk-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px 0}
.tk-panel-head h3{margin:0 0 3px;font:700 18px var(--font);letter-spacing:-.35px;color:var(--text)}
.tk-panel-head p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.4}
.tk-panel-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.tk-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;flex-wrap:wrap;border-bottom:1px solid #f0f4f8}
.tk-filter-tabs{display:flex;gap:5px;flex-wrap:wrap}
.tk-filter-tab{border:1.5px solid var(--border);background:#fff;color:var(--muted);border-radius:999px;padding:6px 13px;font-weight:600;font-size:12.5px;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.tk-filter-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}
.tk-filter-tab:hover:not(.active){border-color:rgba(37,99,235,.4);color:var(--blue)}
.tk-filter-tab .tk-count{background:rgba(0,0,0,.10);color:inherit;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:700}
.tk-filter-tab.active .tk-count{background:rgba(255,255,255,.25)}
.tk-search-row{display:flex;gap:8px;align-items:center}
.tk-search-row input{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;background:#fff;font-size:13px;color:var(--text);outline:none;transition:border-color .15s;min-width:160px}
.tk-search-row input:focus{border-color:var(--blue)}
.tk-list{padding:12px 20px;display:flex;flex-direction:column;gap:8px}
.tk-item{display:grid;grid-template-columns:1fr auto;gap:14px;border:1.5px solid var(--border);border-radius:var(--radius);background:#fff;padding:13px 15px;transition:border-color .15s,box-shadow .15s;align-items:start}
.tk-item:hover{border-color:rgba(37,99,235,.25);box-shadow:0 2px 10px rgba(37,99,235,.07)}
.tk-item.tk-completed{opacity:.62}
.tk-item-main{min-width:0}
.tk-item-title{border:0;background:transparent;padding:0;text-align:left;font:700 14.5px var(--font);cursor:pointer;color:var(--text);letter-spacing:-.25px;line-height:1.3;display:block;width:100%}
.tk-item-title:hover{color:var(--blue-dark)}
.tk-item-meta{font-size:12px;color:var(--muted);margin-top:4px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.tk-item-meta .sep{color:var(--border-2)}
.tk-item-desc{margin-top:7px;font-size:13px;color:var(--text-2);line-height:1.55;max-width:680px}
.tk-chip-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.tk-project-chip{background:var(--blue-light);color:var(--blue-dark);border-radius:5px;padding:3px 8px;font-size:11px;font-weight:700}
.tk-assignee-chip{background:#f1f5f9;color:var(--text-2);border-radius:5px;padding:3px 8px;font-size:11px;font-weight:600}
.tk-unassigned{background:#f8fafc;color:var(--muted-2);border-radius:5px;padding:3px 8px;font-size:11px;font-style:italic}
.tk-item-side{display:flex;flex-direction:column;gap:6px;align-items:flex-end;min-width:130px}
.tk-status-pill{border-radius:6px;padding:4px 9px;font-size:11px;font-weight:700;white-space:nowrap;display:inline-block;text-align:center}
.tk-status-pill.not-started{background:#f1f5f9;color:var(--muted)}
.tk-status-pill.in-progress{background:var(--blue-light);color:var(--blue-dark)}
.tk-status-pill.blocked{background:var(--danger-bg);color:var(--danger)}
.tk-status-pill.completed{background:var(--green-bg);color:var(--green)}
.tk-priority-pill{border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;white-space:nowrap}
.tk-priority-pill.low{background:var(--green-bg);color:var(--green)}
.tk-priority-pill.medium{background:var(--amber-bg);color:var(--amber)}
.tk-priority-pill.high,.tk-priority-pill.urgent{background:var(--danger-bg);color:var(--danger)}
.tk-due{font-size:12px;font-weight:600;color:var(--muted)}
.tk-due.overdue{color:var(--danger)}
.tk-edit-btn{font-size:12px;font-weight:600;border:1.5px solid var(--border);border-radius:6px;padding:5px 10px;background:#fff;cursor:pointer;color:var(--text-2);transition:border-color .15s,color .15s;white-space:nowrap}
.tk-edit-btn:hover{border-color:var(--blue);color:var(--blue)}
.tk-empty{text-align:center;padding:40px 20px;color:var(--muted)}
.tk-empty strong{display:block;font-size:15px;color:var(--text);margin-bottom:6px}
.tk-summary-bar{display:flex;gap:8px;flex-wrap:wrap;padding:12px 20px 0}
.tk-summary-chip{background:#f1f5f9;border-radius:999px;padding:5px 12px;color:var(--muted);font-size:12px;font-weight:700}

/* ─── 18. RESPONSIVE / MOBILE ────────────────────────────── */
@media(max-width:1180px){
  .bg-kpi-grid{grid-template-columns:repeat(3,1fr)}
  .bg-main-grid{grid-template-columns:1fr}
  .bg-side-stack{display:grid;grid-template-columns:1fr 1fr}
  .bg-analytics-grid{grid-template-columns:1fr}
}
@media(max-width:900px){
  /* Shell */
  .app-shell{display:block}
  .sidebar{position:fixed;left:-280px;top:0;bottom:0;height:100dvh;width:min(84vw,300px);transition:left .22s ease;z-index:70}
  .sidebar.open{left:0}
  .mobile-close{display:flex}
  .drawer-overlay.open{display:block;position:fixed;inset:0;background:rgba(15,23,42,.50);z-index:60;backdrop-filter:blur(2px)}
  .main-area{min-height:100dvh;padding-bottom:90px}
  .topbar{height:60px;padding:0 16px}
  .topbar h2{font-size:17px;max-width:64vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mobile-menu{display:flex;align-items:center;justify-content:center}
  .view{padding:16px}
  .grid{grid-template-columns:1fr}
  /* Bottom nav — 5 items for phase 2K */
  .bottom-nav{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom,0px));z-index:55;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:8px;background:rgba(255,255,255,.95);border:1.5px solid var(--border);border-radius:20px;box-shadow:0 8px 28px rgba(15,23,42,.15);backdrop-filter:blur(20px)}
  .bottom-nav button{border:0;background:transparent;color:var(--muted);min-height:50px;border-radius:12px;font-weight:700;font-size:11px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer}
  .bottom-nav button span{font-size:18px}
  .bottom-nav button.active{background:var(--blue-light);color:var(--blue-dark)}
  /* Dashboard */
  .bg-dashboard-hero{display:block}
  .bg-hero-actions{margin-top:14px;display:grid;grid-template-columns:1fr 1fr}
  .bg-kpi-grid{grid-template-columns:repeat(2,1fr)}
  .bg-side-stack{grid-template-columns:1fr}
  .bg-metric-card{padding:15px}
  .bg-metric-card strong{font-size:22px}
  .bg-task-item{grid-template-columns:1fr auto}
  .bg-task-item .bg-avatar-mini{display:none}
  .bg-stage-row{grid-template-columns:92px 1fr 24px}
  .bg-pipeline-row{grid-template-columns:1fr;gap:4px}
  .bg-dashboard-shell{gap:16px}
  /* Modules */
  .section-header,.drive-card{display:block}
  .actions-row{margin-top:12px}
  .primary-button,.small-button{min-height:44px}
  .doc-info strong{white-space:normal}
  .task-filter-bar,.notes-filter-bar{grid-template-columns:1fr}
  .task-row{display:block}
  .task-side{justify-content:flex-start;min-width:0;margin-top:12px}
  .two-col{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
  .form-grid.three-col{grid-template-columns:1fr}
  .contact-actions .meta{text-align:left}
  .toolbar-row{flex-direction:column;align-items:stretch}
  .search-input,.select-input{width:100%;min-width:0}
  .time-table{min-width:760px}
  .map-card{grid-template-columns:1fr}
  .project-map-frame{height:260px}
  .photo-gallery{grid-template-columns:1fr 1fr}
  .photo-thumb-button{height:150px}
  .compact-row{grid-template-columns:1fr}
  .modal-lite-overlay{align-items:flex-end;padding:0}
  .modal-lite{border-radius:22px 22px 0 0;width:100%;max-height:92dvh;overflow:auto}
  .file-preview-modal{width:100%;border-radius:22px 22px 0 0}
  .file-preview-body{height:62vh}
  .sidebar .side-nav button:not([data-route="dashboard"]):not([data-route="projects"]):not([data-route="company"]):not([data-route="tasks"]):not([data-route="employee-hub"]):not([data-route="superadmin"]){display:none!important}
  /* Company page */
  .co-kpi-row{grid-template-columns:repeat(2,1fr)}
  .co-hero{display:block}
  .co-hero-actions{margin-top:14px;display:grid;grid-template-columns:1fr 1fr}
  /* Tasks page */
  .tk-kpi-row{grid-template-columns:repeat(2,1fr)}
  .tk-toolbar{flex-direction:column;gap:10px;align-items:stretch}
  .tk-item{grid-template-columns:1fr;gap:10px}
  .tk-item-side{flex-direction:row;justify-content:flex-start;min-width:0;flex-wrap:wrap}
  .tk-search-row{flex-wrap:wrap}
  .tk-search-row input{min-width:0;flex:1}
}
@media(max-width:560px){
  .photo-gallery{grid-template-columns:1fr}
  .photo-thumb-button{height:210px}
}
@media(max-width:720px){
  .time-table{min-width:760px}
}
@media(max-width:768px){
  .pd-hero{display:block}
  .pd-hero-stats{margin-top:16px;justify-content:flex-start}
  .pd-overview-grid{grid-template-columns:1fr}
  .bg-metric-card strong{font-size:18px}
}

/* Phase 2L — Admin / Users / Company Settings */
.admin-shell-card .admin-tabs{display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid rgba(15,23,42,.08);padding-bottom:10px}
.admin-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-form-panel label.admin-field{display:block;margin:10px 0 0}.admin-field span{display:block;font-size:12px;font-weight:800;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.admin-form-panel input,.admin-form-panel textarea,.admin-user-modal input,.admin-user-modal select{width:100%;border:1px solid rgba(15,23,42,.12);border-radius:12px;padding:11px 12px;background:#fff;font:inherit;color:var(--text)}
.admin-form-panel input[readonly],.admin-form-panel textarea[readonly]{background:#f8fafc;color:#64748b}.readonly-notice{background:#fff7ed;border-color:#fed7aa}.admin-user-list{display:flex;flex-direction:column;gap:10px}.admin-user-row{align-items:center}.admin-table-wrap{overflow:auto;border:1px solid rgba(15,23,42,.08);border-radius:14px}.admin-table{width:100%;border-collapse:collapse;min-width:760px;background:#fff}.admin-table th,.admin-table td{padding:12px;border-bottom:1px solid rgba(15,23,42,.08);text-align:left}.admin-table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:#64748b;background:#f8fafc}.admin-project-access-list{max-height:220px;overflow:auto;border:1px solid rgba(15,23,42,.1);border-radius:14px;padding:10px;background:#fff}.admin-project-access-list .remember{display:flex;margin:6px 0;font-size:13px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:900px){.admin-settings-grid,.two-col{grid-template-columns:1fr}.admin-shell-card .admin-tabs{overflow-x:auto;flex-wrap:nowrap}.admin-shell-card .admin-tabs button{white-space:nowrap}}

/* Phase 2L latest patch: back button + editable company details */
.topbar-back-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1.5px solid var(--border);background:#fff;color:var(--text-2);border-radius:var(--radius-sm);padding:8px 12px;font-weight:700;font-size:13px;cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s,background .15s}.topbar-back-button:hover{border-color:var(--blue);color:var(--blue-dark);background:var(--blue-soft)}.co-panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.co-panel-title-row h4{margin:0}.co-edit-company-btn{padding:6px 10px;font-size:12px}@media(max-width:720px){.topbar-back-button{padding:7px 10px;font-size:12px}.co-panel-title-row{align-items:flex-start;flex-direction:column}.co-edit-company-btn{width:100%}}

/* Phase 3A — AI Foundation */
.ai-shell-card{background:var(--card,#fff)}
.ai-safety-note{border:1px solid rgba(37,99,235,.18);background:rgba(37,99,235,.06);border-radius:14px;padding:12px 14px;margin:0 0 16px;color:var(--text,#0f172a);font-size:13px}.ai-safety-note strong{color:var(--blue,#2563eb)}
.ai-grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:18px}.ai-context-panel,.ai-chat-panel{border:1px solid var(--border,#e5e7eb);border-radius:18px;background:#fff;padding:16px}.ai-context-panel h4{margin:0 0 12px}.ai-quick-prompts{display:flex;flex-direction:column;gap:8px;margin-top:16px}.ai-messages{min-height:340px;max-height:560px;overflow:auto;display:flex;flex-direction:column;gap:12px;padding:4px}.ai-empty-state{border:1px dashed var(--border,#d1d5db);border-radius:16px;padding:24px;text-align:center;color:var(--muted,#64748b)}.ai-empty-state strong{display:block;color:var(--text,#0f172a);font-size:18px;margin-bottom:6px}.ai-message{border-radius:16px;padding:14px 16px;border:1px solid var(--border,#e5e7eb);background:#f8fafc}.ai-message.user{background:#eff6ff;border-color:rgba(37,99,235,.22);align-self:flex-end;max-width:86%}.ai-message.assistant{background:#fff;box-shadow:0 10px 26px rgba(15,23,42,.06)}.ai-message-role{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:var(--muted,#64748b);margin-bottom:6px}.ai-message-text{font-size:14px;line-height:1.6;color:var(--text,#0f172a)}.ai-form{display:flex;flex-direction:column;gap:10px;margin-top:14px}.ai-form textarea,.ai-form select,.ai-settings-form textarea,.ai-settings-form input,.ai-settings-form select{width:100%;border:1px solid var(--border,#d1d5db);border-radius:12px;padding:12px;background:#fff;font:inherit}.ai-form-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.ai-action-card{margin-top:12px;border:1px solid rgba(37,99,235,.22);background:#f8fbff;border-radius:14px;padding:12px}.ai-action-card pre{white-space:pre-wrap;background:#0f172a;color:#dbeafe;border-radius:10px;padding:10px;font-size:12px;max-height:220px;overflow:auto}.ai-settings-form{display:flex;flex-direction:column;gap:12px}.toggle-line{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--text,#0f172a)}.toggle-line input{width:auto}.desktop-guide-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.desktop-guide-card{border:1px solid var(--border,#e5e7eb);border-radius:14px;background:#fff;padding:14px}.desktop-guide-card strong{display:block;margin-bottom:8px}.desktop-guide-card ol{margin:0;padding-left:18px;color:var(--muted,#64748b);font-size:13px;line-height:1.55}
@media(max-width:900px){.ai-grid{grid-template-columns:1fr}.ai-message.user{max-width:100%}.ai-form-actions{justify-content:stretch}.ai-form-actions button{flex:1}}

/* Phase 3A project field category refinements */
.project-editor-wide{max-width:860px;max-height:86vh;overflow:auto}.project-editor-section{border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:14px;padding:14px;margin:12px 0}.project-editor-section h4,.project-detail-group-title{font-size:13px;font-weight:800;margin:0 0 10px;color:var(--blue-dark,#1d4ed8);letter-spacing:-.01em}.project-detail-group-title{margin-top:16px;border-top:1px solid rgba(15,23,42,.08);padding-top:12px}.project-editor-section label{display:block;font-weight:700;font-size:12px;margin-top:10px;color:var(--text,#111827)}.project-editor-section textarea{width:100%;border:1px solid var(--border,#d6d3cc);border-radius:10px;padding:10px;font:inherit;background:#fff}.project-editor-section .two-col,.form-grid.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}@media(max-width:720px){.project-editor-section .two-col,.form-grid.two-col{grid-template-columns:1fr}.project-editor-wide{max-width:94vw}}

/* Phase 3B — Notifications */
.notification-summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.notification-row.notification-unread{border-left:4px solid var(--primary-blue,#2563eb);background:rgba(37,99,235,.035)}
.admin-check{display:flex;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid rgba(15,23,42,.08)}
.admin-check input{width:auto!important;margin:0!important}
.danger-chip{background:rgba(239,68,68,.12)!important;color:#b91c1c!important}

/* Phase 5A — Permissions / Roles / Audit */
.phase5a-admin-card .admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.admin-summary-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.admin-group-row td{background:#f8fafc;font-weight:800;color:var(--bg-blue);text-transform:uppercase;font-size:11px;letter-spacing:.05em}.permission-table th,.permission-table td{text-align:center}.permission-table th:first-child,.permission-table td:first-child{text-align:left}.danger-chip{background:#fee2e2;color:#991b1b;border-color:#fecaca}.readonly-notice{background:#f8fafc}.admin-project-access-list{display:grid;gap:8px;margin:8px 0 12px}.admin-user-row .task-side{min-width:100px}.admin-form-panel textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:12px;font:inherit;background:#fff}.admin-field select{width:100%;margin-top:6px;border:1px solid var(--border);border-radius:10px;padding:12px;background:#fff;font:inherit}.admin-field input[readonly],.admin-form-panel textarea[readonly]{background:#f8fafc;color:#64748b}
@media(max-width:800px){.phase5a-admin-card .admin-tabs{overflow:auto;flex-wrap:nowrap;padding-bottom:6px}.admin-table-wrap{overflow:auto}.permission-table{min-width:900px}}

/* ═══════════════════════════════════════════════════════════
   Project Page Visual Restoration Patch
   Restores the Claude-styled project tab spacing/shape while keeping
   the latest ChatGPT build logic intact.
   ═══════════════════════════════════════════════════════════ */

/* Add breathing room between the blue project header and project module tabs */
.pd-shell .pd-hero{
  margin-bottom:20px !important;
}

/* Project module tab bar: full-width, rounded, elevated, and separated from header */
.pd-tabs-wrap{
  position:relative !important;
  top:auto !important;
  z-index:5;
  width:100%;
  margin:0 0 22px !important;
  padding:8px;
  background:rgba(255,255,255,.96);
  border:1px solid var(--border) !important;
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:visible;
}

.pd-tabs-wrap .proj-filter-tabs{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(118px,1fr));
  gap:8px !important;
  width:100%;
  padding:0 !important;
  overflow:visible !important;
}

.pd-tabs-wrap .proj-filter-tab{
  width:100%;
  justify-content:center;
  min-height:42px;
  border-radius:14px;
  padding:10px 12px;
  border:1px solid var(--border);
  background:#f8fafc;
  color:var(--text-2);
  font-weight:800;
  box-shadow:none;
}

.pd-tabs-wrap .proj-filter-tab:hover:not(.active){
  background:#eef4ff;
  border-color:rgba(37,99,235,.28);
  color:var(--blue-dark);
  transform:translateY(-1px);
}

.pd-tabs-wrap .proj-filter-tab.active{
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  border-color:var(--blue-dark);
  color:#fff;
  box-shadow:0 10px 22px rgba(37,99,235,.22);
}

/* Keep section content spacing consistent after the tab bar */
#project-section-view{
  margin-top:0 !important;
}

/* Project invoice/financial summary cards should match dashboard KPI cards */
.financial-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:14px;
  margin-bottom:18px;
}

.financial-summary-grid .metric{
  background:#fff;
  border:none;
  border-radius:16px;
  padding:20px 22px 18px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  min-height:112px;
}

.financial-summary-grid .metric::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:var(--blue);
}

.financial-summary-grid .metric:nth-child(3)::before{background:var(--green)}
.financial-summary-grid .metric:nth-child(4)::before{background:var(--amber)}
.financial-summary-grid .metric:nth-child(5)::before{background:var(--purple)}
.financial-summary-grid .metric:nth-child(6)::before{background:var(--teal)}

.financial-summary-grid .metric small{
  display:block;
  color:var(--muted);
  font-size:10.5px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.09em;
  margin-bottom:10px;
}

.financial-summary-grid .metric strong{
  display:block;
  font-size:clamp(18px,1.55vw,24px);
  font-weight:850;
  line-height:1.05;
  color:var(--text);
  letter-spacing:-.45px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}

/* Keep the invoice sub-tabs spaced and styled like the project tab system */
.financials-card .project-tabs.mini-tabs{
  margin-top:18px !important;
  margin-bottom:16px;
  padding:8px;
  background:#f8fafc;
  border:1px solid var(--border);
  border-radius:18px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:8px;
  overflow:visible;
}

.financials-card .project-tabs.mini-tabs button{
  width:100%;
  justify-content:center;
  border-radius:14px;
  min-height:40px;
  font-weight:800;
}

/* Project overview cards: align spacing with the updated project tab system */
.pd-overview-grid,
.financials-card,
.tasks-card,
.meeting-notes-card,
.contacts-card,
.project-photos-map-card,
.draw-proforma-card{
  margin-top:0;
}

@media(max-width:760px){
  .pd-shell .pd-hero{margin-bottom:16px!important}
  .pd-tabs-wrap{border-radius:16px;padding:7px;margin-bottom:18px!important}
  .pd-tabs-wrap .proj-filter-tabs{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px!important}
  .pd-tabs-wrap .proj-filter-tab{font-size:12.5px;min-height:40px;padding:9px 8px}
  .financial-summary-grid{grid-template-columns:1fr 1fr;gap:10px}
  .financial-summary-grid .metric{padding:16px 14px;min-height:96px}
  .financial-summary-grid .metric strong{font-size:18px}
}


/* Phase 5B — Notification bell/count badge */
#top-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.notification-bell-button{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1.5px solid var(--border);border-radius:999px;background:#fff;color:var(--text);cursor:pointer;box-shadow:0 4px 14px rgba(11,18,32,.06);transition:transform .15s,box-shadow .15s,border-color .15s,background .15s}
.notification-bell-button:hover{transform:translateY(-1px);border-color:var(--blue);background:var(--blue-soft);box-shadow:0 8px 22px rgba(37,99,235,.12)}
.notification-bell-icon{font-size:18px;line-height:1}
.notification-badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;border:2px solid #fff;font-size:11px;font-weight:800;line-height:16px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(239,68,68,.35);z-index:2}
.notification-badge[hidden]{display:none!important}
.has-notification-badge{position:relative!important}
.side-nav .route-notification-badge{top:8px;right:12px;border-color:var(--sidebar-bg,#0b1220)}
.bottom-nav .route-notification-badge{top:2px;right:12px;border-color:#fff}
.error-inline{margin-top:8px;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:8px 10px;font-size:12px;font-weight:600}
@media(max-width:720px){.notification-bell-button{width:36px;height:36px}.notification-badge{min-width:18px;height:18px;font-size:10px;line-height:14px}.bottom-nav .route-notification-badge{right:8px}}


/* Phase 5C — Task Assignment Cleanup */
.task-assignee-select{width:100%;min-height:120px;border:1px solid var(--border);border-radius:12px;padding:10px;background:#fff;font:inherit;margin-bottom:8px}
.task-assignee-select option{padding:6px}
.tk-assignee-chip{background:rgba(37,99,235,.10);border:1px solid rgba(37,99,235,.18);color:#1d4ed8;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700}
.tk-unassigned{background:#f1f5f9;color:#64748b;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700}

/* Phase 5E v5 — first-login app install onboarding */
.app-install-modal .notice-card{margin-top:12px}
.app-install-steps .meta{display:grid;gap:8px;margin-top:8px}
.install-step{position:relative;padding-left:22px;line-height:1.45;color:var(--text)}
.install-step::before{content:'✓';position:absolute;left:0;top:0;color:var(--blue);font-weight:900}
@media (max-width:760px){
  .app-install-overlay{align-items:flex-end}
  .app-install-modal{border-radius:22px 22px 0 0}
}

/* Phase 5G — Activity Feed / Audit Timeline */
.activity-feed-card{overflow:hidden}.activity-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.activity-toolbar h4{margin:0 0 4px;font-size:18px;color:var(--text,#0f172a)}.activity-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:14px 0}.activity-metric strong{font-size:26px}.activity-filter-row{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:10px;margin:14px 0}.activity-feed-list{display:flex;flex-direction:column;gap:10px}.activity-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:12px;align-items:flex-start;border:1px solid var(--border,#e5e7eb);border-radius:16px;background:#fff;padding:14px;box-shadow:0 10px 22px rgba(15,23,42,.04)}.activity-icon{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#eff6ff;border:1px solid rgba(37,99,235,.16);font-size:19px}.activity-main{min-width:0}.activity-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.activity-head strong{font-size:14px;color:var(--text,#0f172a);line-height:1.35}.activity-head span{font-size:12px;color:var(--muted,#64748b);white-space:nowrap}.activity-row p{margin:7px 0 0;font-size:13px;line-height:1.45;color:var(--muted,#64748b)}.activity-actions{display:flex;justify-content:flex-end;align-items:flex-start}.activity-row.hidden{display:none!important}@media(max-width:760px){.activity-toolbar{flex-direction:column}.activity-filter-row{grid-template-columns:1fr}.activity-row{grid-template-columns:38px minmax(0,1fr);padding:12px}.activity-icon{width:38px;height:38px}.activity-actions{grid-column:2;justify-content:flex-start}.activity-head{flex-direction:column;gap:2px}.activity-head span{white-space:normal}.activity-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}


/* Phase 5H — keep Project Detail tabs on one horizontal line */
.pd-tabs-wrap{
  overflow:hidden !important;
}
.pd-tabs-wrap .proj-filter-tabs{
  display:flex !important;
  flex-wrap:nowrap !important;
  align-items:center;
  gap:8px !important;
  width:100%;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  padding:0 2px 2px !important;
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
}
.pd-tabs-wrap .proj-filter-tab{
  flex:1 1 0 !important;
  width:auto !important;
  white-space:nowrap !important;
  justify-content:center;
  text-align:center;
  min-height:40px;
  padding:9px 13px;
}
@media(max-width:760px){
  .pd-tabs-wrap .proj-filter-tabs{
    display:flex !important;
    flex-wrap:nowrap !important;
    gap:7px !important;
    overflow-x:auto !important;
  }
  .pd-tabs-wrap .proj-filter-tab{
    width:auto !important;
    flex:0 0 auto !important;
  }
}

/* ─── Phase 5J Dynamic Dashboard ─────────────────────────── */
.bg-market-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.bg-market-content{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bg-rate-widget{border:1px solid #eef2f7;border-radius:14px;background:#f8fafc;padding:14px;min-height:185px;overflow:hidden}
.bg-rate-widget iframe{display:block;width:100%;min-height:95px;background:#fff;border-radius:10px}
.bg-rate-chart-widget iframe{height:260px;min-height:260px}
.bg-source-line{margin:8px 0 0;color:var(--muted);font-size:11px}
.bg-source-line a{color:var(--blue);font-weight:700;text-decoration:none}
.bg-news-status{background:var(--blue-light);color:var(--blue-dark);border-radius:999px;padding:5px 10px;font-size:11px;font-weight:800;white-space:nowrap}
.bg-news-ticker{overflow:hidden;background:#0f172a;border-radius:14px;margin-bottom:12px;min-height:46px;display:flex;align-items:center}
.bg-news-track{display:flex;gap:10px;white-space:nowrap;animation:bgTicker 42s linear infinite;padding:9px 12px}
.bg-news-track:hover{animation-play-state:paused}
.bg-news-track a{display:inline-flex;align-items:center;gap:8px;color:#fff;text-decoration:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:8px 12px;max-width:520px}
.bg-news-track strong{overflow:hidden;text-overflow:ellipsis;max-width:390px;font-size:12px}
.bg-news-track span{color:#bfdbfe;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.bg-news-list{display:flex;flex-direction:column;border-top:1px solid #eef2f7}
.bg-news-item{display:block;text-decoration:none;color:var(--text);padding:12px 0;border-bottom:1px solid #eef2f7}
.bg-news-item strong{display:block;font-size:13.5px;line-height:1.25;letter-spacing:-.1px}
.bg-news-item span{display:block;margin-top:4px;color:var(--muted);font-size:11.5px}
.bg-video-card{margin-top:14px;border:1px solid rgba(37,99,235,.25);border-radius:14px;background:var(--blue-soft);padding:14px;display:block}
.bg-video-head{margin-bottom:12px}
.bg-video-card strong{display:block;color:var(--blue-dark);font-size:14px}
.bg-video-card span{display:block;color:var(--muted);font-size:12px;margin-top:3px}
.bg-video-embed{position:relative;width:100%;padding-top:56.25%;border-radius:12px;overflow:hidden;background:#000}
.bg-video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.bg-team-snapshot{padding:24px}
.bg-team-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.bg-team-card{border:1px solid #eef2f7;border-radius:14px;background:#fff;box-shadow:var(--shadow);padding:14px;display:flex;gap:12px;align-items:flex-start;min-width:0}
.bg-team-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;font-weight:900;font-size:12px;flex:0 0 auto}
.bg-team-card strong{display:block;font-size:13.5px;color:var(--text);text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.bg-team-card span,.bg-team-card em{display:block;color:var(--muted);font-size:11.5px;font-style:normal;margin-top:3px}
@keyframes bgTicker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media(max-width:1180px){
  .bg-market-grid{grid-template-columns:1fr}
  .bg-team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:900px){
  .bg-market-content{grid-template-columns:1fr}
  .bg-rate-chart-widget iframe{height:240px;min-height:240px}
  .bg-news-track a{max-width:360px}
  .bg-news-track strong{max-width:230px}
  .bg-video-card{display:block}
  .bg-video-card .bg-mini-button{margin-top:10px;width:100%}
  .bg-team-grid{grid-template-columns:1fr}
}

/* Phase 5K — persistent time tracker visibility */
.topbar #top-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.topbar-time-control{display:flex;align-items:center;gap:6px}
.time-presence-button{position:relative;border:1.5px solid var(--border);background:#fff;color:var(--text);border-radius:999px;padding:8px 11px;font-weight:800;font-size:12px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.04);transition:all .15s ease;white-space:nowrap}
.time-presence-button:hover{border-color:var(--blue);color:var(--blue-dark);background:var(--blue-soft)}
.time-presence-button.active-time-running{border-color:#f97316;background:#fff7ed;color:#9a3412;box-shadow:0 0 0 3px rgba(249,115,22,.12)}
.time-presence-icon{font-size:15px;line-height:1}.time-presence-label{line-height:1}.time-presence-count{background:#fed7aa;color:#9a3412;border:1px solid #fdba74;border-radius:999px;padding:2px 7px;font-size:11px;font-weight:900;min-width:38px;text-align:center}
.time-clockout-button{border:1.5px solid #fecaca;background:#fef2f2;color:#b91c1c;border-radius:999px;padding:8px 11px;font-weight:900;font-size:12px;cursor:pointer;white-space:nowrap;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.time-clockout-button:hover{background:#fee2e2;border-color:#fca5a5}
.has-time-presence-badge{position:relative!important}.time-presence-badge{position:absolute;top:5px;right:8px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#f97316;color:#fff;border:2px solid rgba(255,255,255,.92);font-size:9px;font-weight:900;line-height:14px;display:inline-flex;align-items:center;justify-content:center;letter-spacing:.3px;box-shadow:0 2px 6px rgba(249,115,22,.28)}
.side-nav button.time-is-active{background:rgba(249,115,22,.14);color:#fff;border-left-color:#f97316}.bottom-nav button.time-is-active{background:#fff7ed;color:#9a3412}.bottom-nav .time-presence-badge{top:1px;right:10px;border-color:#fff}.side-nav .time-presence-badge{top:6px;right:9px;border-color:var(--sidebar-bg,#0b1220)}
@media(max-width:720px){.topbar #top-actions{gap:5px}.time-presence-button{padding:7px 9px}.time-presence-label{display:none}.time-clockout-button{padding:7px 9px;font-size:11px}.time-presence-count{font-size:10px;min-width:34px;padding:2px 6px}.bottom-nav{grid-template-columns:repeat(6,1fr)}.bottom-nav button{font-size:10px}.bottom-nav button span{font-size:17px}}

/* Phase 5K hotfix: active time guard and global reminder */
.primary-button.danger-button,
.danger-button{background:#dc2626!important;border-color:#dc2626!important;color:#fff!important}
.active-time-page-notice{border-color:#fed7aa;background:#fff7ed;color:#9a3412}
.floating-time-reminder{position:fixed;right:18px;bottom:22px;z-index:2000;display:flex;align-items:center;gap:8px;background:#fff7ed;border:1.5px solid #fdba74;border-radius:999px;padding:8px 9px;box-shadow:0 14px 32px rgba(15,23,42,.18)}
.floating-time-reminder[hidden]{display:none!important}
.floating-time-open{border:0;background:transparent;color:#9a3412;font-weight:900;display:inline-flex;align-items:center;gap:7px;cursor:pointer;max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.floating-time-clockout{border:1px solid #dc2626;background:#dc2626;color:#fff;border-radius:999px;padding:7px 10px;font-weight:900;cursor:pointer;white-space:nowrap}
@media(max-width:720px){.floating-time-reminder{left:10px;right:10px;bottom:76px;justify-content:space-between;border-radius:18px}.floating-time-open{max-width:calc(100vw - 145px)}}

/* ─── Phase 5L — UI Card Polish + Dashboard Spacing ─────────────
   Converts module summary numbers into KPI cards and fixes the dynamic
   dashboard spacing/margins so pages feel consistent with BuildGenius. */

/* Universal summary cards for Notifications, HR Hub, Time Tracker, Contacts, Photos, Admin, etc. */
.summary-grid,
.notification-summary-grid,
.employee-hub-summary-grid,
.time-summary-grid,
.contact-summary-grid,
.photo-summary-grid,
.draw-summary-grid,
.admin-summary-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr)) !important;
  gap:14px !important;
  margin:18px 0 20px !important;
  align-items:stretch;
}
.summary-grid .metric,
.notification-summary-grid .metric,
.employee-hub-summary-grid .metric,
.time-summary-grid .metric,
.contact-summary-grid .metric,
.photo-summary-grid .metric,
.draw-summary-grid .metric,
.admin-summary-grid .metric{
  background:#fff !important;
  border:1px solid rgba(221,227,236,.9) !important;
  border-radius:16px !important;
  padding:17px 18px 16px !important;
  box-shadow:var(--shadow) !important;
  position:relative;
  overflow:hidden;
  min-height:96px;
}
.summary-grid .metric::before,
.notification-summary-grid .metric::before,
.employee-hub-summary-grid .metric::before,
.time-summary-grid .metric::before,
.contact-summary-grid .metric::before,
.photo-summary-grid .metric::before,
.draw-summary-grid .metric::before,
.admin-summary-grid .metric::before{
  content:'';
  position:absolute;
  left:0;right:0;top:0;height:4px;
  background:var(--blue);
}
.summary-grid .metric:nth-child(2)::before,
.notification-summary-grid .metric:nth-child(2)::before,
.employee-hub-summary-grid .metric:nth-child(2)::before,
.time-summary-grid .metric:nth-child(2)::before,
.contact-summary-grid .metric:nth-child(2)::before,
.photo-summary-grid .metric:nth-child(2)::before,
.admin-summary-grid .metric:nth-child(2)::before{background:var(--green)}
.summary-grid .metric:nth-child(3)::before,
.notification-summary-grid .metric:nth-child(3)::before,
.employee-hub-summary-grid .metric:nth-child(3)::before,
.time-summary-grid .metric:nth-child(3)::before,
.contact-summary-grid .metric:nth-child(3)::before,
.photo-summary-grid .metric:nth-child(3)::before,
.admin-summary-grid .metric:nth-child(3)::before{background:var(--amber)}
.summary-grid .metric:nth-child(4)::before,
.notification-summary-grid .metric:nth-child(4)::before,
.employee-hub-summary-grid .metric:nth-child(4)::before,
.time-summary-grid .metric:nth-child(4)::before,
.contact-summary-grid .metric:nth-child(4)::before,
.photo-summary-grid .metric:nth-child(4)::before,
.admin-summary-grid .metric:nth-child(4)::before{background:var(--purple)}
.summary-grid .metric small,
.notification-summary-grid .metric small,
.employee-hub-summary-grid .metric small,
.time-summary-grid .metric small,
.contact-summary-grid .metric small,
.photo-summary-grid .metric small,
.draw-summary-grid .metric small,
.admin-summary-grid .metric small{
  display:block;
  color:var(--muted);
  font-size:10.5px;
  line-height:1.2;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-weight:800;
  margin-bottom:10px;
}
.summary-grid .metric strong,
.notification-summary-grid .metric strong,
.employee-hub-summary-grid .metric strong,
.time-summary-grid .metric strong,
.contact-summary-grid .metric strong,
.photo-summary-grid .metric strong,
.draw-summary-grid .metric strong,
.admin-summary-grid .metric strong{
  display:block;
  font-size:clamp(24px,2.4vw,34px) !important;
  line-height:1;
  letter-spacing:-.8px;
  font-weight:900;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Module cards should have room to breathe at the top and not look like loose number lists. */
.notifications-card,
.employee-hub-card,
.time-tracker-card{
  padding:28px !important;
  border-radius:22px !important;
  box-shadow:var(--shadow-md) !important;
}
.notifications-card .section-header,
.employee-hub-card .section-header,
.time-tracker-card .section-header{
  margin-bottom:18px !important;
}
.notifications-card .admin-tabs,
.employee-hub-card .project-tabs,
.time-tracker-card .toolbar-row{
  margin-top:12px !important;
}

/* Dashboard spacing and market/news polish. */
.bg-dashboard-shell{
  gap:24px !important;
  max-width:1680px;
  margin:0 auto;
}
.bg-dashboard-hero,
.bg-kpi-grid,
.bg-market-grid,
.bg-team-snapshot,
.bg-main-grid,
.bg-weekly{
  width:100%;
}
.bg-kpi-grid{
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr)) !important;
  gap:14px !important;
}
.bg-market-grid{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:20px !important;
}
.bg-market-panel,
.bg-news-panel,
.bg-team-snapshot{
  border-radius:22px !important;
  padding:26px !important;
  overflow:hidden;
}
.bg-market-content{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr)) !important;
  gap:18px !important;
  align-items:stretch;
}
.bg-rate-widget{
  min-height:210px !important;
  padding:18px !important;
  border-radius:18px !important;
  background:#f8fafc !important;
  border:1px solid #e7edf5 !important;
}
.bg-rate-widget iframe{
  width:100% !important;
  min-height:130px !important;
  transform:none !important;
}
.bg-rate-chart-widget iframe{
  height:300px !important;
  min-height:300px !important;
}
.bg-news-panel .bg-news-ticker{
  margin-top:10px;
  margin-bottom:18px;
}
.bg-news-list{
  border-top:1px solid #e7edf5 !important;
}
.bg-news-item{
  padding:15px 0 !important;
}
.bg-video-card{
  margin-top:18px !important;
  padding:18px !important;
  border-radius:18px !important;
}
.bg-team-grid{
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr)) !important;
  gap:14px !important;
}
.bg-team-card{
  min-height:112px;
  border-radius:18px !important;
  padding:18px !important;
  align-items:center !important;
}
.bg-team-card>div{
  min-width:0 !important;
  flex:1 1 auto !important;
}
.bg-team-card strong{
  max-width:100% !important;
  font-size:15px !important;
}
.bg-team-card span,.bg-team-card em{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.bg-team-avatar{
  width:48px !important;
  height:48px !important;
  font-size:14px !important;
}

@media(max-width:900px){
  .view{padding:18px}
  .notifications-card,.employee-hub-card,.time-tracker-card,.bg-panel,.bg-attention-card,.bg-team-snapshot{padding:20px !important;border-radius:20px !important}
  .section-header{flex-direction:column;align-items:stretch}
  .actions-row{justify-content:flex-start}
  .summary-grid,
  .notification-summary-grid,
  .employee-hub-summary-grid,
  .time-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
  .bg-market-content{grid-template-columns:1fr !important}
}
@media(max-width:560px){
  .summary-grid,
  .notification-summary-grid,
  .employee-hub-summary-grid,
  .time-summary-grid{grid-template-columns:1fr 1fr !important;gap:10px !important}
  .summary-grid .metric,
  .notification-summary-grid .metric,
  .employee-hub-summary-grid .metric,
  .time-summary-grid .metric{padding:14px !important;min-height:86px}
  .summary-grid .metric strong,
  .notification-summary-grid .metric strong,
  .employee-hub-summary-grid .metric strong,
  .time-summary-grid .metric strong{font-size:24px !important}
  .bg-dashboard-hero{display:block}
  .bg-hero-actions{margin-top:14px;flex-wrap:wrap}
}

/* ─── Phase 5M Mobile UX Polish ──────────────────────────── */
:root{--mobile-nav-height:86px}

.mobile-more-sheet .sheet-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.mobile-more-sheet .sheet-grid button{
  border:1px solid var(--border);
  background:#fff;
  border-radius:16px;
  min-height:58px;
  padding:10px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  color:var(--text);
  font-weight:800;
  cursor:pointer;
  text-align:left;
}
.mobile-more-sheet .sheet-grid button span{font-size:13px}

@media(max-width:900px){
  .main-area{padding-bottom:calc(var(--mobile-nav-height) + env(safe-area-inset-bottom,0px))}
  .topbar{
    position:sticky;
    top:0;
    z-index:50;
    min-height:64px;
    height:auto;
    padding:8px 12px;
    gap:8px;
    align-items:center;
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(15,23,42,.08);
  }
  .topbar > div:nth-of-type(1){
    min-width:0;
    flex:1 1 150px;
  }
  .topbar h2{font-size:17px;line-height:1.15;max-width:100%}
  .topbar p{font-size:12px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  #top-actions{
    gap:6px;
    flex:0 0 auto;
    margin-left:0;
    justify-content:flex-end;
    max-width:48vw;
    overflow:visible;
  }
  .topbar-back-button{min-height:38px;padding:8px 10px;border-radius:12px;font-size:12px;max-width:82px;white-space:nowrap}
  .time-presence-button{min-height:38px;padding:7px 9px;box-shadow:none}
  .time-presence-count{min-width:48px;font-size:10px;line-height:1.1}
  .time-clockout-button{min-height:38px;padding:7px 9px;font-size:11px;border-radius:999px}
  .notification-bell-button{width:38px;height:38px;box-shadow:none}

  /* Six-item mobile nav after adding Time. */
  .bottom-nav{
    grid-template-columns:repeat(6,minmax(0,1fr)) !important;
    left:8px;
    right:8px;
    bottom:calc(8px + env(safe-area-inset-bottom,0px));
    padding:7px;
    gap:2px;
    border-radius:18px;
  }
  .bottom-nav button{min-width:0;min-height:50px;font-size:9.5px;line-height:1.05;padding:4px 2px}
  .bottom-nav button span{font-size:17px;line-height:1}

  /* Keep project/company/admin tab systems one-line and easy to swipe. */
  .project-tabs,.mini-tabs,.admin-shell-card .admin-tabs,.phase5a-admin-card .admin-tabs,
  .notifications-card .admin-tabs,.employee-hub-card .project-tabs,.co-tabs-wrap .project-tabs,
  .tk-filter-tabs,.proj-filter-tabs{
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    overflow-y:hidden !important;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    padding-bottom:5px;
  }
  .project-tabs button,.mini-tabs button,.admin-shell-card .admin-tabs button,.phase5a-admin-card .admin-tabs button,
  .notifications-card .admin-tabs button,.employee-hub-card .project-tabs button,.co-tabs-wrap .project-tabs button,
  .tk-filter-tab,.proj-filter-tab{
    flex:0 0 auto !important;
    white-space:nowrap !important;
    min-height:42px;
  }

  /* Touch-friendly module headers and action buttons. */
  .section-header,.tk-panel-head,.activity-toolbar,.bg-panel-header{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:12px !important;
  }
  .actions-row,.tk-panel-actions,.bg-hero-actions,.co-hero-actions{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:9px !important;
    width:100%;
  }
  .actions-row .primary-button,.actions-row .secondary,.actions-row .small-button,
  .tk-panel-actions button,.bg-hero-actions button,.co-hero-actions button{
    width:100%;
    min-height:44px;
    justify-content:center;
  }

  /* Better mobile summaries/cards. */
  .summary-grid,.notification-summary-grid,.employee-hub-summary-grid,.time-summary-grid,
  .activity-summary-grid,.co-kpi-row,.tk-kpi-row,.bg-kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:10px !important;
  }
  .metric,.bg-metric-card,.activity-metric{
    min-height:92px;
    padding:14px !important;
    border-radius:16px !important;
  }
  .metric strong,.bg-metric-card strong,.activity-metric strong{font-size:clamp(22px,7vw,30px) !important}

  /* Dashboard market/news should stack without squeezed iframes. */
  .bg-dashboard-shell{gap:18px !important}
  .bg-market-panel,.bg-news-panel,.bg-team-snapshot,.bg-panel{padding:18px !important;border-radius:20px !important}
  .bg-market-content{grid-template-columns:1fr !important}
  .bg-rate-widget{min-height:auto !important;padding:14px !important}
  .bg-rate-widget iframe{min-height:170px !important;max-width:100% !important}
  .bg-rate-chart-widget iframe{height:310px !important;min-height:310px !important}
  .bg-news-ticker{border-radius:12px;min-height:42px}
  .bg-news-track a{max-width:78vw;padding:7px 10px}
  .bg-news-track strong{max-width:56vw}
  .bg-team-grid{grid-template-columns:1fr !important}
  .bg-team-card{min-height:96px !important}

  /* Tables remain scrollable but are framed so the page itself does not break. */
  .time-table-wrap,.admin-table-wrap,.table-wrap,.activity-table-wrap{
    max-width:100%;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    border-radius:16px;
  }
  .time-table{min-width:720px !important}

  /* Modal bottom sheets feel native on phones. */
  .modal-lite-overlay,.app-install-overlay{align-items:flex-end !important;padding:0 !important}
  .modal-lite,.app-install-modal,.file-preview-modal{
    width:100% !important;
    max-width:100% !important;
    max-height:92dvh !important;
    border-radius:24px 24px 0 0 !important;
    overflow:auto !important;
  }

  /* Keep active clock controls above the bottom nav. */
  .floating-time-reminder{
    left:10px !important;
    right:10px !important;
    bottom:calc(var(--mobile-nav-height) + 10px + env(safe-area-inset-bottom,0px)) !important;
    border-radius:18px !important;
    padding:9px 10px !important;
  }
}

@media(max-width:560px){
  .view{padding:14px 12px 104px !important}
  .topbar{padding:7px 10px}
  .topbar h2{font-size:16px}
  #top-actions{max-width:54vw}
  .time-presence-label{display:none !important}
  .time-clockout-button{max-width:82px;overflow:hidden;text-overflow:ellipsis}
  .summary-grid,.notification-summary-grid,.employee-hub-summary-grid,.time-summary-grid,
  .activity-summary-grid,.co-kpi-row,.tk-kpi-row,.bg-kpi-grid{
    grid-template-columns:1fr 1fr !important;
  }
  .actions-row,.tk-panel-actions,.bg-hero-actions,.co-hero-actions{
    grid-template-columns:1fr !important;
  }
  .mobile-more-sheet .sheet-grid{grid-template-columns:1fr 1fr}
  .mobile-more-sheet .sheet-grid button{min-height:54px;font-size:13px}
  .bg-rate-widget iframe{min-height:190px !important}
  .bg-news-track a{max-width:84vw}
  .bg-news-track strong{max-width:62vw}
}

/* ─── Phase 5O: Offline Drafts / Local Save Protection ─── */
.offline-draft-banner{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:90;
  display:flex;align-items:center;gap:10px;max-width:min(780px,calc(100vw - 28px));
  background:#0f172a;color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:999px;
  box-shadow:var(--shadow-lg);padding:10px 14px;font-size:13px;font-weight:700;
}
.offline-draft-banner button{border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.10);color:#fff;border-radius:999px;padding:5px 10px;font-weight:800;cursor:pointer}
.offline-drafts-status-chip{border:1.5px solid var(--border);background:#fff;color:var(--muted);border-radius:999px;min-width:38px;height:36px;padding:0 10px;display:inline-flex;gap:5px;align-items:center;justify-content:center;cursor:pointer;font-weight:800;box-shadow:0 1px 0 rgba(11,18,32,.03)}
.offline-drafts-status-chip.has-drafts{border-color:rgba(37,99,235,.35);background:var(--blue-light);color:var(--blue-dark)}
.offline-drafts-status-chip span,.offline-nav-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--blue);color:#fff;font-size:11px;font-style:normal;font-weight:900}
.offline-nav-badge{margin-left:auto}
.offline-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px;background:linear-gradient(135deg,#ffffff 0%,#eef5ff 100%)}
.offline-hero h2{margin:4px 0 6px;font-size:26px;letter-spacing:-.8px}
.offline-hero-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.offline-status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:900;border:1px solid var(--border)}
.offline-status-pill.online{background:var(--green-bg);color:var(--green);border-color:rgba(22,163,74,.18)}
.offline-status-pill.offline{background:var(--amber-bg);color:#92400e;border-color:rgba(217,119,6,.20)}
.offline-summary-grid{margin:0 0 16px}
.offline-draft-list{display:grid;gap:10px}
.offline-draft-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border:1px solid var(--border);border-radius:14px;background:#fff;box-shadow:0 1px 0 rgba(11,18,32,.02)}
.offline-draft-card p{margin:4px 0;color:var(--text-2);font-size:14px}
.offline-draft-card small{color:var(--muted);font-size:12px}
.offline-draft-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.offline-draft-toast{position:fixed;right:18px;bottom:80px;z-index:95;background:#0f172a;color:#fff;border-radius:14px;padding:12px 14px;box-shadow:var(--shadow-lg);max-width:min(360px,calc(100vw - 28px));font-weight:700;font-size:13px}
@media(max-width:760px){
  .offline-hero,.offline-draft-card{display:block}
  .offline-hero-actions,.offline-draft-actions{margin-top:12px;justify-content:flex-start}
  .offline-draft-banner{bottom:calc(var(--mobile-nav-height,72px) + 12px + env(safe-area-inset-bottom,0px));border-radius:16px;align-items:flex-start;flex-wrap:wrap;left:12px;right:12px;transform:none;max-width:none}
  .offline-draft-toast{left:12px;right:12px;bottom:calc(var(--mobile-nav-height,72px) + 78px);max-width:none}
}

/* Phase 5P — final navigation and local draft polish */
.offline-drafts-card{
  padding:28px!important;
  border-radius:22px!important;
  box-shadow:var(--shadow-md)!important;
  margin-bottom:18px;
  background:linear-gradient(135deg,#ffffff 0%,#eef5ff 100%);
}
.offline-drafts-card h3{font-size:28px;margin:4px 0 8px;letter-spacing:-.8px}
.offline-summary-grid .metric span{
  display:block;color:var(--text-2);font-size:13px;line-height:1.35;margin-top:8px;font-weight:700;
}
.offline-summary-grid .metric:nth-child(2)::before{background:var(--green)}
.offline-summary-grid .metric:nth-child(3)::before{background:var(--amber)}
.offline-summary-grid .metric:nth-child(4)::before{background:var(--purple)}
#offline-drafts-status-chip{display:none}
#offline-drafts-status-chip.has-drafts{display:inline-flex}
.time-presence-button .time-presence-label{font-weight:900}
.time-presence-button.active-time-running{background:#fff7ed;border-color:#fdba74;color:#9a3412}
.floating-time-open strong{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:760px){.offline-drafts-card{padding:20px!important}.offline-drafts-card h3{font-size:24px}}

/* ─── Phase 5Q Mobile Refinements ────────────────────────── */

/* 1 ─ iOS Safari: inputs < 16px trigger auto-zoom; force minimum */
@media(max-width:900px){
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="tel"],
  input[type="url"],
  input[type="search"],
  input[type="date"],
  textarea,select{
    font-size:16px !important;
    /* Also improve tap accuracy */
    -webkit-tap-highlight-color:transparent;
  }
}

/* 2 ─ Mini-tabs (financials sub-tabs): base style is display:grid which
   ignores flex-wrap:nowrap set in Phase 5M — explicitly switch to flex
   so horizontal scrolling actually works */
@media(max-width:900px){
  .mini-tabs,.project-tabs.mini-tabs{
    display:flex !important;
    flex-wrap:nowrap !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
    gap:6px !important;
    padding:6px !important;
    scrollbar-width:none;
  }
  .mini-tabs::-webkit-scrollbar{display:none}
  .mini-tabs button,.project-tabs.mini-tabs button{
    flex:0 0 auto !important;
    white-space:nowrap !important;
    min-height:42px !important;
  }
}

/* 3 ─ Hide horizontal scrollbars on all swipeable tab rows for a
   cleaner look (still scrollable via touch) */
.pd-tabs-wrap .proj-filter-tabs::-webkit-scrollbar,
.proj-filter-tabs::-webkit-scrollbar,
.admin-tabs::-webkit-scrollbar,
.project-tabs::-webkit-scrollbar,
.tk-filter-tabs::-webkit-scrollbar{
  height:0;
  width:0;
  background:transparent;
}

/* 4 ─ Project editor modal: native sheet feel on phones */
@media(max-width:760px){
  .project-editor-wide{
    max-width:100vw !important;
    max-height:100dvh !important;
    border-radius:0 !important;
    width:100% !important;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
  }
}

/* 5 ─ Prevent double-padding stack at 560px: main-area already covers
   the fixed nav offset; view's explicit 104px bottom is enough */
@media(max-width:560px){
  .main-area{padding-bottom:0 !important}
}

/* 6 ─ Notification and admin settings radio/checkbox touch targets */
@media(max-width:900px){
  .admin-check{
    min-height:44px;
    display:flex;
    align-items:center;
    gap:10px;
    padding:4px 0;
  }
  .admin-check input[type="checkbox"],
  .admin-check input[type="radio"]{
    width:20px !important;
    height:20px !important;
    flex-shrink:0;
    cursor:pointer;
    accent-color:var(--blue);
    font-size:16px !important;
  }
}

/* 7 ─ Task rows: better tap target and wrapping on narrow phones */
@media(max-width:560px){
  .task-row{padding:14px 12px}
  .task-chips{flex-wrap:wrap}
  .notification-row .task-main strong{font-size:14px}
  .notification-row .task-description{font-size:13px}
  .notification-row .task-side{flex-wrap:wrap;gap:6px}
  .task-side button{min-height:38px;font-size:13px;padding:8px 12px}
}

/* 8 ─ Project detail: hero action buttons full-width on very small phones */
@media(max-width:480px){
  .pd-hero-actions{flex-direction:column;align-items:stretch}
  .pd-hero-actions button,.pd-hero-actions a{min-height:44px;justify-content:center}
}
/* ──────────────────────────────────────────────────────────── */
