  :root{
    /* Brand — Steel Blue palette */
    --orange:#4A7FA7;       /* primary accent (legacy var name kept) */
    --orange-600:#3A6A8E;   /* hover */
    --orange-100:#B3CFE5;   /* tint */
    --orange-50:#EBEFF0;    /* bg tint */
    --blue:#4A7FA7;
    --purple:#607682;
    --green:#22C55E;
    --amber:#F59E0B;
    --red:#EF4444;
    --slate:#607682;
    --slate-2:#A7AAAF;

    /* Light surfaces */
    --bg:#EBEFF0;
    --surface:#FFFFFF;
    --surface-2:#F6F8F9;
    --ink:#1A2733;
    --ink-2:#3C3C3C;
    --muted:#607682;
    --line:#D2D9E1;
    --sidebar:#FFFFFF;
    --sidebar-ink:#1A2733;
  }
  body.dark{
    --bg:#0D1620;
    --surface:#15202B;
    --surface-2:#0F1820;
    --ink:#EBEFF0;
    --ink-2:#D2D9E1;
    --muted:#A7AAAF;
    --line:#273542;
    --sidebar:#0F1820;
    --sidebar-ink:#EBEFF0;
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:'Inter',sans-serif;
    background:var(--bg);
    color:var(--ink);
    font-size:14px;
    -webkit-font-smoothing:antialiased;
    transition:background .25s,color .25s;
  }

  /* ====== Shell ====== */
  .shell{max-width:1440px;margin:0 auto;padding:24px}
  .app{
    background:var(--surface-2);
    border-radius:28px;
    padding:14px;
    display:grid;
    grid-template-columns:220px 1fr;
    gap:14px;
    min-height:calc(100vh - 48px);
    border:1px solid var(--line);
  }
  body.dark .app{background:#0A1118;border-color:#1F2A36}

  /* ====== Sidebar ====== */
  .sidebar{
    background:var(--sidebar);
    border-radius:20px;
    padding:18px 14px;
    display:flex;
    flex-direction:column;
    border:1px solid var(--line);
    transition:width .25s ease,padding .25s ease;
    position:relative;
  }
  body.dark .sidebar{background:#15202B;border-color:#273542}
  .app.collapsed{grid-template-columns:78px 1fr}
  .app.collapsed .sidebar{padding:18px 10px}
  .app.collapsed .brand-name,
  .app.collapsed .nav-item span.lbl,
  .app.collapsed .nav-section,
  .app.collapsed .cta-card p,
  .app.collapsed .cta-card h5,
  .app.collapsed .cta-card button{display:none}
  .app.collapsed .nav-item{justify-content:center;padding:12px 8px}
  .app.collapsed .nav-item.active::before{left:-10px}
  .app.collapsed .cta-card{padding:12px;text-align:center}
  .app.collapsed .cta-card .ic{margin:0 auto}
  .app.collapsed .brand{justify-content:center;padding:8px 0 22px}
  .collapse-btn{
    position:absolute;right:-14px;top:22px;z-index:5;
    width:28px;height:28px;border-radius:50%;
    background:var(--surface);border:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    color:var(--muted);box-shadow:0 2px 8px rgba(0,0,0,.06);
    transition:.2s;
  }
  .collapse-btn:hover{color:var(--orange);border-color:var(--orange)}
  .collapse-btn svg{transition:transform .25s}
  .app.collapsed .collapse-btn svg{transform:rotate(180deg)}
  .brand{display:flex;align-items:center;gap:10px;padding:8px 6px 22px}
  .brand-logo{
    width:36px;height:36px;border-radius:10px;
    background:linear-gradient(135deg,#4A7FA7,#3A6A8E);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 6px 16px rgba(74,127,167,.35);
    flex-shrink:0;
  }
  .brand-name{font-weight:700;font-size:17px;color:var(--sidebar-ink);letter-spacing:-.01em}
  .nav{display:flex;flex-direction:column;gap:2px;overflow:hidden}
  .nav-item{
    display:flex;align-items:center;gap:12px;
    padding:10px 12px;border-radius:12px;
    color:var(--muted);font-weight:500;font-size:14px;
    cursor:pointer;position:relative;
    transition:background .15s,color .15s;
    overflow:hidden;min-width:0;
  }
  .nav-item:hover{background:rgba(74,127,167,.08);color:var(--ink)}
  .nav-item.active{color:var(--orange);font-weight:600;background:rgba(74,127,167,.1)}
  .nav-item.active::before{
    content:"";position:absolute;left:-14px;top:6px;bottom:6px;width:3px;
    background:var(--orange);border-radius:0 3px 3px 0;
  }
  .nav-item .lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
  .nav-section{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);padding:18px 12px 6px}

  .cta-card{
    margin-top:auto;background:var(--orange);border-radius:18px;padding:16px;color:#fff;
    text-align:left;position:relative;overflow:hidden;
  }
  .cta-card::after{
    content:"";position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;
    background:radial-gradient(circle,rgba(255,255,255,.25),transparent 70%);
  }
  .cta-card .ic{width:32px;height:32px;background:rgba(255,255,255,.22);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
  .cta-card h5{font-size:14px;font-weight:700;margin:0 0 4px;line-height:1.25}
  .cta-card p{font-size:11px;opacity:.9;margin:0 0 12px}
  .cta-card button{background:#fff;color:var(--orange);border:0;border-radius:999px;padding:8px 14px;font-weight:700;font-size:12px;cursor:pointer}

  /* ====== Main ====== */
  .main{
    background:var(--surface);
    border-radius:20px;
    padding:22px 24px;
    border:1px solid var(--line);
    min-width:0;
  }
  body.dark .main{background:#15202B;border-color:#273542}

  .topbar{display:flex;align-items:center;gap:14px;margin-bottom:20px}
  .topbar-title{font-size:20px;font-weight:700;margin:0;letter-spacing:-.01em;color:var(--ink)}
  .search{
    flex:1;display:flex;align-items:center;gap:10px;
    background:var(--surface-2);border:1px solid var(--line);
    border-radius:999px;padding:10px 16px;color:var(--muted);
  }
  body.dark .search{background:#0F1820;border-color:#273542}
  .search input{background:transparent;border:0;outline:0;color:var(--ink);flex:1;font-family:inherit;font-size:13px}
  .topbar .icon-btn{
    width:40px;height:40px;border-radius:50%;
    background:var(--surface-2);border:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    color:var(--ink-2);transition:.15s;
  }
  body.dark .topbar .icon-btn{background:#0F1820;border-color:#273542}
  .topbar .icon-btn:hover{color:var(--orange);border-color:var(--orange)}
  .topbar .icon-btn.spinning svg{animation:icon-spin .8s linear infinite}
  @keyframes icon-spin{to{transform:rotate(360deg)}}
  .user{display:flex;align-items:center;gap:10px;padding-left:4px}
  .user .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#4A7FA7,#607682);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px}
  .user .meta{line-height:1.1}
  .user .meta .n{font-weight:700;font-size:13px}
  .user .meta .e{font-size:11px;color:var(--muted)}

  /* ====== Header block ====== */
  .hero{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:22px;flex-wrap:wrap}
  .hero h1{font-size:30px;font-weight:700;margin:0 0 6px;letter-spacing:-.02em}
  .hero p{margin:0;color:var(--muted);font-size:14px}
  #hero-count{color:var(--orange);font-weight:800}
  .btn{border:0;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:11px 18px;transition:.15s}
  .btn-primary{background:var(--orange);color:#fff;box-shadow:0 8px 20px rgba(74,127,167,.35)}
  .btn-primary:hover{background:var(--orange-600)}
  .btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
  .btn-ghost:hover{border-color:var(--orange);color:var(--orange)}

  /* ====== KPI Feature + Metric cards ====== */
  .kpi-feat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
  .kpi-metr-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
  .kpi-feat,.kpi-metr{
    background:var(--surface);border:1px solid var(--line);border-radius:18px;
    padding:18px;display:flex;flex-direction:column;gap:5px;
  }
  body.dark .kpi-feat,body.dark .kpi-metr{background:var(--surface-2);border-color:var(--line)}
  .kf-outline{border-color:#EF4444;border-width:1.5px}
  .kf-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);display:flex;align-items:center;gap:6px}
  .kf-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
  .kf-main{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin:2px 0}
  .kf-val{font-size:42px;font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--ink)}
  .kpi-metr .kf-val{font-size:34px}
  .kf-unit{font-size:14px;font-weight:600;color:var(--muted)}
  .kf-unit-sm{font-size:18px;font-weight:700;color:var(--ink)}
  .kf-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.05em;align-self:center}
  .kf-crit{background:#FEE2E2;color:#DC2626}
  .kf-aten{background:#FEF3C7;color:#D97706}
  .kf-ok{background:#DCFCE7;color:#16A34A}
  .kf-leve{background:#FEF9C3;color:#A16207}
  body.dark .kf-crit{background:rgba(239,68,68,.18);color:#F87171}
  body.dark .kf-aten{background:rgba(245,158,11,.18);color:#FBBF24}
  body.dark .kf-ok{background:rgba(34,197,94,.18);color:#4ADE80}
  .kf-sub{font-size:12px;color:var(--muted);line-height:1.4}
  .kf-foot{font-size:12px;color:var(--muted);margin-top:auto;padding-top:4px}
  .kf-bar{height:4px;background:var(--line);border-radius:999px;overflow:hidden;margin-top:6px}
  .kf-bar-fill{height:100%;border-radius:999px;transition:width .6s ease;width:0%}
  .kf-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
  .kf-chip{font-size:11px;padding:3px 8px;border-radius:6px;background:rgba(239,68,68,.08);color:#DC2626;font-weight:500;white-space:nowrap}
  body.dark .kf-chip{background:rgba(239,68,68,.18);color:#F87171}
  .kf-cta{margin-top:10px;align-self:flex-start;background:transparent;border:1px solid #EF4444;color:#EF4444;font-weight:700;font-size:11.5px;padding:6px 12px;border-radius:999px;cursor:pointer;transition:.15s;font-family:inherit}
  .kf-cta:hover{background:#EF4444;color:#fff}
  @media(max-width:1100px){.kpi-feat-row{grid-template-columns:1fr}.kpi-metr-row{grid-template-columns:repeat(2,1fr)}}

  /* ====== KPI tiles (legacy, unused) ====== */
  .kpi-row{display:grid;grid-template-columns:1fr 280px;gap:14px;margin-bottom:14px}
  .kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
  .kpi{
    background:var(--surface-2);
    border:1px solid var(--line);
    border-radius:18px;
    padding:18px;
    min-height:140px;
    display:flex;flex-direction:column;justify-content:space-between;
    position:relative;
  }
  body.dark .kpi{background:#0F1820;border-color:#273542}
  .kpi .label{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:12.5px;font-weight:600}
  .kpi .dots{cursor:pointer;opacity:.6}
  .kpi .val{font-size:44px;font-weight:700;line-height:1;letter-spacing:-.02em;margin-top:6px}
  .kpi .val small{font-size:16px;color:var(--muted);font-weight:500;margin-left:6px}
  .kpi .trend{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600}
  .trend.up{color:#16A34A}
  .trend.down{color:#EF4444}
  .trend.flat{color:var(--muted)}
  .kpi .spark{height:34px;width:60px;opacity:.9}

  /* Right column Schedule */
  .schedule{
    background:var(--surface-2);
    border:1px solid var(--line);
    border-radius:18px;
    padding:16px;
    display:flex;flex-direction:column;
    min-height:0;
    max-height:560px;
  }
  .schedule #sched-list{overflow-y:auto}
  body.dark .schedule{background:#0F1820;border-color:#273542}
  .schedule .hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
  .schedule .hd h4{margin:0;font-size:16px;font-weight:700}
  .tabs{display:flex;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:3px;font-size:11.5px;font-weight:600}
  body.dark .tabs{background:#0A1118;border-color:#2B3A48}
  .tabs button{border:0;background:transparent;padding:5px 12px;border-radius:999px;color:var(--muted);cursor:pointer;font-family:inherit;font-weight:600}
  .tabs button.on{background:var(--orange);color:#fff}
  .sched-item{
    background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:10px;
    transition:.15s;cursor:pointer;
  }
  body.dark .sched-item{background:#15202B;border-color:#2B3A48}
  .sched-item:hover{border-color:var(--orange)}
  .sched-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
  .sched-head .ttl{font-weight:700;font-size:13px}
  .sched-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;border:1px solid}
  .sb-start{color:var(--orange);border-color:var(--orange);background:var(--orange-50)}
  .sb-sched{color:#607682;border-color:#D2D9E1;background:#EBEFF0}
  body.dark .sb-start{background:rgba(74,127,167,.18)}
  body.dark .sb-sched{background:rgba(96,118,130,.18);border-color:rgba(96,118,130,.45)}
  .sched-tag{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:4px 8px;font-size:11px;font-weight:600;color:var(--ink-2)}
  body.dark .sched-tag{background:#0A1118;border-color:#2B3A48}
  .sched-meta{color:var(--muted);font-size:11px;margin-top:6px}
  .sched-foot{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid var(--line)}
  .avatars{display:flex}
  .avatars .av{width:22px;height:22px;border-radius:50%;border:2px solid var(--surface);margin-left:-6px;background:#ddd;font-size:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
  .avatars .av:first-child{margin-left:0}
  .view-link{color:var(--orange);font-size:11px;font-weight:700;text-decoration:none}

  /* ====== Charts row ====== */
  .charts-row{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:14px;margin-bottom:14px}
  .card{
    background:var(--surface-2);
    border:1px solid var(--line);
    border-radius:18px;
    padding:18px 20px;
  }
  body.dark .card{background:#0F1820;border-color:#273542}
  .card-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
  .card-hd h3{margin:0;font-size:16px;font-weight:700}
  .card-hd .sub{color:var(--muted);font-size:12px;margin-top:2px}
  .pill-select{
    background:var(--surface);border:1px solid var(--line);
    border-radius:999px;padding:6px 12px;font-size:11.5px;font-weight:600;
    display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:var(--ink-2)
  }
  body.dark .pill-select{background:#0A1118;border-color:#2B3A48}
  .legend{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--muted);font-weight:500}
  .legend .sw{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}

  /* ====== Time tracker strip ====== */
  .tracker{
    background:var(--orange);color:#fff;
    border-radius:18px;padding:18px 24px;
    display:flex;justify-content:space-between;align-items:center;gap:20px;
    position:relative;overflow:hidden;
  }
  .tracker{background:linear-gradient(135deg,#4A7FA7 0%,#607682 100%)}
  .tracker::before{
    content:"";position:absolute;inset:0;background:
      radial-gradient(circle at 20% 20%,rgba(255,255,255,.18),transparent 40%),
      radial-gradient(circle at 80% 80%,rgba(0,0,0,.15),transparent 50%);
    pointer-events:none;
  }
  .tracker h3{margin:0;font-size:18px;font-weight:700;z-index:1;position:relative}
  .tracker .meta{font-size:12px;opacity:.9;margin-top:2px;z-index:1;position:relative}
  .tracker .time{font-variant-numeric:tabular-nums;font-size:42px;font-weight:700;letter-spacing:-.02em;z-index:1;position:relative}
  .tracker .ctrls{display:flex;gap:10px;z-index:1;position:relative}
  .tracker .ctrls button{
    width:44px;height:44px;border-radius:50%;border:0;cursor:pointer;
    background:#fff;color:var(--orange);display:flex;align-items:center;justify-content:center;
  }

  /* ====== Filter bar ====== */
  .filter-bar{display:flex;flex-wrap:wrap;gap:18px;align-items:center;margin-bottom:14px;padding:14px 18px;background:var(--surface-2);border:1px solid var(--line);border-radius:18px}
  body.dark .filter-bar{background:#0F1820;border-color:#273542}
  .filter-grp{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .filter-grp .lbl{font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-right:4px}
  .chip{
    background:var(--surface);border:1px solid var(--line);
    border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;
    cursor:pointer;color:var(--ink-2);transition:.12s;
  }
  body.dark .chip{background:#0A1118;border-color:#2B3A48}
  .chip:hover{border-color:var(--orange);color:var(--orange)}
  .chip.on{background:var(--orange);color:#fff;border-color:var(--orange)}
  .chip.reset{color:#EF4444;border-color:rgba(239,68,68,.3)}

  /* ====== Projects table ====== */
  .table-wrap{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;overflow:hidden}
  body.dark .table-wrap{background:#0F1820;border-color:#273542}
  .table-hd{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line)}
  .table-hd h3{margin:0;font-size:16px;font-weight:700}
  .tbl{width:100%;border-collapse:collapse;font-size:13px}
  .tbl th{
    background:transparent;color:var(--muted);
    font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.08em;
    padding:12px 18px;text-align:left;border-bottom:1px solid var(--line)
  }
  .tbl td{padding:14px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
  .tbl tr:last-child td{border-bottom:0}
  .tbl tr:hover td{background:rgba(74,127,167,.06)}
  .proj-cell{display:flex;align-items:center;gap:12px}
  .proj-icon{
    width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:13px;color:#fff;flex-shrink:0;
  }
  .proj-cell .n{font-weight:700;font-size:13px;line-height:1.3;color:var(--ink);word-break:break-word}
  .proj-cell .sub{color:var(--muted);font-size:11.5px;margin-top:1px}
  .proj-name-wrap{min-width:0;flex:1}

  .status-pill{display:inline-block;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid}
  .sp-done{color:#16A34A;background:#DCFCE7;border-color:#BBF7D0}
  .sp-prog{color:#3C83F6;background:#EFF4FF;border-color:#BFD6FF}
  .sp-pause{color:#EF4444;background:#FEE2E2;border-color:#FECACA}
  .sp-none{color:#6B7280;background:#F3F4F6;border-color:#E5E7EB}
  body.dark .sp-done{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.35)}
  body.dark .sp-prog{background:rgba(60,131,246,.14);border-color:rgba(60,131,246,.35)}
  body.dark .sp-pause{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.35)}
  body.dark .sp-none{background:rgba(120,120,120,.14);border-color:rgba(120,120,120,.35);color:#B8B8B8}

  .enf-pill{display:inline-block;padding:3px 9px;border-radius:8px;font-size:11px;font-weight:700;border:1px solid}
  .ep-ana{color:#4A7FA7;background:rgba(74,127,167,.1);border-color:rgba(74,127,167,.3)}
  .ep-dev{color:#607682;background:rgba(96,118,130,.1);border-color:rgba(96,118,130,.3)}
  .ep-inv{color:#A7AAAF;background:rgba(167,170,175,.12);border-color:rgba(167,170,175,.35)}
  .ep-imp{color:#3A6A8E;background:rgba(58,106,142,.1);border-color:rgba(58,106,142,.3)}
  .ep-gen{color:#6B7280;background:rgba(107,114,128,.1);border-color:rgba(107,114,128,.3)}

  .tipo-dot{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600}
  .tipo-dot .d{width:8px;height:8px;border-radius:50%}

  .bar{width:100%;height:6px;background:var(--line);border-radius:999px;overflow:hidden}
  body.dark .bar{background:#273542}
  .bar > span{display:block;height:100%;border-radius:999px;transition:width .6s ease}

  /* ====== Upload screen ====== */
  #upload{position:fixed;inset:0;z-index:50;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:20px}
  .upload-card{
    max-width:540px;width:100%;background:var(--surface);border:1px solid var(--line);
    border-radius:24px;padding:40px;text-align:center;
  }
  body.dark .upload-card{background:#15202B;border-color:#273542}
  .upload-logo{width:56px;height:56px;margin:0 auto 18px;border-radius:14px;background:linear-gradient(135deg,#4A7FA7,#3A6A8E);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(74,127,167,.35)}
  .upload-card h1{font-size:26px;font-weight:700;margin:0 0 6px;letter-spacing:-.02em}
  .upload-card p{color:var(--muted);margin:0 0 28px;font-size:13.5px}
  .dropzone{
    border:2px dashed var(--orange);background:var(--orange-50);
    border-radius:18px;padding:38px 20px;cursor:pointer;transition:.2s;
  }
  body.dark .dropzone{background:rgba(74,127,167,.08)}
  .dropzone:hover{background:rgba(74,127,167,.15)}
  .dropzone .ic{width:52px;height:52px;margin:0 auto 12px;border-radius:12px;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center}
  .dropzone .t{font-weight:700;color:var(--ink);font-size:15px}
  .dropzone .s{color:var(--muted);font-size:12px;margin-top:4px}
  .upload-err{color:#EF4444;font-size:12.5px;font-weight:600;margin-top:12px;display:none}
  .upload-retry{
    margin-top:14px;padding:10px 22px;border-radius:10px;border:0;cursor:pointer;
    background:var(--orange);color:#fff;font-weight:600;font-size:13.5px;
    align-items:center;gap:8px;transition:background .15s;
  }
  .upload-retry:hover{background:var(--orange-600)}

  /* ====== Tweaks panel ====== */
  #tweaks{position:fixed;right:24px;bottom:24px;width:300px;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 20px 50px rgba(0,0,0,.18);z-index:80;display:none}
  body.dark #tweaks{background:#15202B;border-color:#273542}
  #tweaks h4{margin:0 0 14px;font-size:14px;font-weight:700;display:flex;justify-content:space-between;align-items:center}
  #tweaks .row{display:flex;justify-content:space-between;align-items:center;margin:10px 0;font-size:12.5px;gap:10px}
  #tweaks select,#tweaks input[type=color]{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:6px 8px;font-family:inherit;font-size:12px;color:var(--ink)}
  body.dark #tweaks select{background:#0A1118;border-color:#273542}
  #tweaks .close{cursor:pointer;color:var(--muted);border:0;background:transparent;font-size:18px}

  /* ====== View tabs (Dashboard / Projects) ====== */
  .view-tabs{display:flex;gap:22px;padding:0 4px;margin-bottom:12px;border-bottom:1px solid var(--line)}
  .view-tabs .t{
    background:transparent;border:0;padding:10px 2px 12px;cursor:pointer;
    font-size:14px;font-weight:600;color:var(--muted);
    position:relative;transition:color .15s;
  }
  .view-tabs .t:hover{color:var(--ink)}
  .view-tabs .t.on{color:var(--ink)}
  .view-tabs .t.on::after{
    content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
    background:var(--ink);border-radius:2px;
  }

  /* ====== Projects view (UI-kit faithful) ====== */
  .view{display:none}
  .view.active{display:block}
  .proj-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:14px;margin-bottom:14px}
  .proj-head h2{margin:0 0 4px;font-size:24px;font-weight:800;letter-spacing:-.02em}
  .proj-head p{margin:0;color:var(--muted);font-size:13px}
  .proj-tabs{display:flex;gap:22px;margin:18px 0 14px;align-items:center}
  .proj-tab{background:transparent;border:0;padding:6px 2px;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;position:relative}
  .proj-tab.on{color:var(--ink)}
  .proj-tab.on::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--ink);border-radius:2px}
  .proj-toolbar{display:flex;gap:10px;margin-left:auto;align-items:center}
  .proj-search{
    display:flex;align-items:center;gap:8px;background:var(--surface);
    border:1px solid var(--line);border-radius:999px;padding:8px 16px;min-width:280px;
  }
  .proj-search input{border:0;outline:0;background:transparent;font-size:13px;flex:1;color:var(--ink);font-family:inherit}
  .proj-filter-btn{
    display:inline-flex;align-items:center;gap:8px;background:var(--surface);
    border:1px solid var(--line);border-radius:999px;padding:8px 18px;
    font-size:13px;font-weight:600;cursor:pointer;color:var(--ink);
  }
  .proj-filter-btn:hover{border-color:var(--orange);color:var(--orange)}

  .planes-kanban{margin-top:8px}
  .planes-kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  @media(max-width:1100px){.planes-kanban-board{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:640px){.planes-kanban-board{grid-template-columns:1fr}}

  .proj-table-card{
    background:var(--surface-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  }
  .proj-table-hd{padding:18px 22px;font-size:15px;font-weight:700}
  .proj-table{width:100%;border-collapse:collapse;font-size:13px}
  .proj-table th{
    background:transparent;color:var(--muted);
    font-weight:500;font-size:12px;
    padding:10px 18px;text-align:left;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  }
  .proj-table td{padding:14px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
  .proj-table tbody tr:last-child td{border-bottom:0}
  .proj-table tbody tr:hover td{background:rgba(74,127,167,.04)}
  body.dark .proj-table tbody tr:hover td{background:rgba(74,127,167,.08)}

  .proj-company{display:flex;align-items:center;gap:12px}
  .proj-logo{
    width:36px;height:36px;border-radius:50%;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-weight:700;font-size:12px;letter-spacing:.02em;
  }
  .proj-company .n{font-weight:700;font-size:13.5px;line-height:1.2;color:var(--ink)}
  .proj-company .d{color:var(--muted);font-size:11.5px;margin-top:2px}

  /* Pill buttons exactly like UI kit */
  .ui-pill{
    display:inline-block;padding:5px 16px;border-radius:999px;
    font-size:11.5px;font-weight:600;border:1.3px solid;background:var(--surface);
    min-width:92px;text-align:center;
  }
  .ui-pill.done{color:#22C55E;border-color:#22C55E}
  .ui-pill.prog{color:#F59E0B;border-color:#F59E0B}
  .ui-pill.paus{color:#EF4444;border-color:#EF4444}
  .ui-pill.none{color:#9CA3AF;border-color:#D1D5DB}

  .proj-assign .t{font-weight:700;font-size:13px;color:var(--ink);line-height:1.2}
  .proj-assign .s{color:var(--muted);font-size:11.5px;margin-top:2px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  .members{display:flex;align-items:center}
  .members .av{
    width:28px;height:28px;border-radius:50%;border:2px solid var(--surface-2);
    margin-left:-8px;display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:10px;font-weight:700;flex-shrink:0;
  }
  .members .av:first-child{margin-left:0}
  .members .more{
    width:28px;height:28px;border-radius:50%;background:var(--line);color:var(--ink-2);
    font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:-8px;border:2px solid var(--surface-2);
  }

  .prog-cell{display:flex;align-items:center;gap:12px;min-width:160px}
  .prog-track{flex:1;height:6px;background:var(--line);border-radius:999px;overflow:hidden}
  body.dark .prog-track{background:#273542}
  .prog-fill{height:100%;border-radius:999px;transition:width .6s ease}
  .prog-pct{font-size:12px;font-weight:700;color:var(--ink);min-width:34px;text-align:right}
  .prog-dot{width:8px;height:8px;border-radius:50%;background:#EF4444;margin-right:6px;display:inline-block}

  .row-action{background:transparent;border:0;color:var(--muted);padding:6px;cursor:pointer;border-radius:6px}
  .row-action:hover{background:var(--line);color:var(--ink)}

  @media(max-width:1100px){
    .kpi-row{grid-template-columns:1fr}
    .kpi-grid{grid-template-columns:repeat(2,1fr)}
    .charts-row{grid-template-columns:1fr}
  }
  @media print{.no-print{display:none!important}}

/* ====== Area filter badge (sidebar) ====== */
.area-count{margin-left:auto;font-size:10.5px;font-weight:700;color:var(--muted);background:var(--surface-2);padding:2px 7px;border-radius:999px;transition:.15s}
.nav-item.active .area-count{background:rgba(255,255,255,.25);color:rgba(255,255,255,.9)}
body.dark .area-count{background:#273542}
.app.collapsed .area-count{display:none}
.app.collapsed .nav-item svg{flex-shrink:0}

/* ====== Gantt chart ====== */
.gantt-card{background:var(--surface-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-bottom:14px}
body.dark .gantt-card{background:#0F1820;border-color:#273542}
.gantt-head-row{display:flex;align-items:center;min-height:36px;border-bottom:1px solid var(--line);background:var(--surface-2);position:sticky;top:0;z-index:4}
body.dark .gantt-head-row{background:#0F1820}
.gantt-head-label{width:230px;flex-shrink:0;padding:8px 16px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-right:1px solid var(--line)}
.gantt-head-track{flex:1;position:relative;height:36px;overflow:hidden}
.gantt-month{position:absolute;top:0;bottom:0;border-left:1px solid var(--line)}
.gantt-month-label{position:absolute;top:8px;left:6px;font-size:10px;color:var(--muted);font-weight:600;white-space:nowrap}
.gantt-wrap{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 320px);position:relative}
.gantt-row{display:flex;align-items:center;border-bottom:1px solid var(--line);min-height:46px}
.gantt-row:last-child{border-bottom:0}
.gantt-row:hover{background:rgba(74,127,167,.04)}
body.dark .gantt-row:hover{background:rgba(74,127,167,.08)}
.gantt-label{width:230px;flex-shrink:0;padding:8px 16px;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-right:1px solid var(--line);color:var(--ink)}
.gantt-label .gl-sub{font-size:10.5px;font-weight:400;color:var(--muted);margin-top:1px}
.gantt-track{flex:1;position:relative;height:46px;min-width:0}
.gantt-bar{position:absolute;height:24px;top:11px;border-radius:7px;min-width:6px;display:flex;align-items:center;overflow:hidden;cursor:pointer;transition:filter .15s}
.gantt-bar:hover{filter:brightness(1.1)}
.gantt-bar-fill{position:absolute;left:0;top:0;height:100%;border-radius:7px;opacity:.55}
.gantt-bar-text{position:relative;z-index:1;font-size:10px;font-weight:700;color:#fff;padding:0 7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.gantt-today-line{position:absolute;top:0;bottom:0;width:2px;background:#EF4444;z-index:3;pointer-events:none}
.gantt-today-line::before{content:"HOY";position:absolute;top:4px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:800;color:#EF4444;white-space:nowrap;letter-spacing:.05em}
.gantt-empty{text-align:center;padding:48px 24px;color:var(--muted);font-size:13px}
.gantt-legend{display:flex;gap:16px;flex-wrap:wrap;padding:12px 18px;border-top:1px solid var(--line);font-size:11.5px;color:var(--muted)}
.gantt-legend span{display:flex;align-items:center;gap:6px;font-weight:500}
.gantt-legend .sw{width:12px;height:12px;border-radius:3px;flex-shrink:0}
