*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html, body { overflow-x: hidden; -webkit-text-size-adjust: 100%; }
  body { background: #f0f6ff; font-family: 'Montserrat', sans-serif; color: #0f172a; min-height: 100vh; }

  ::-webkit-scrollbar { width: 5px; height: 5px; }
  ::-webkit-scrollbar-track { background: #e8f0fe; }
  ::-webkit-scrollbar-thumb { background: #a8c4ee; border-radius: 4px; }

  @keyframes fadeUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
  @keyframes popIn  { 0%{transform:scale(0.2)} 60%{transform:scale(1.2)} 100%{transform:scale(1)} }
  @keyframes modalIn{ from{opacity:0;transform:scale(0.95) translateY(10px)} to{opacity:1;transform:none} }

  .container      { max-width:1160px; margin:0 auto; padding:0 14px; width:100%; }
  .main-container { max-width:1160px; margin:0 auto; padding:14px 14px 60px; width:100%; }

  /* ── Header ── */
  header { position:sticky; top:0; z-index:100; background:#fff; border-bottom:1px solid #c7d9f5; box-shadow:0 2px 12px rgba(29,78,216,.07); width:100%; }
  .header-stripe { height:3px; background:linear-gradient(90deg,#1e40af,#2563eb,#0891b2); }
  .header-inner  { height:56px; display:flex; align-items:center; gap:12px; justify-content:space-between; }
  .logo-wrap     { display:flex; align-items:center; gap:9px; flex-shrink:0; text-decoration:none; }
  .logo-title    { font-weight:900; font-size:18px; color:#1e3a8a; letter-spacing:-.01em; line-height:1; }
  .logo-title span { color:#2563eb; }
  .logo-sub      { font-family:'JetBrains Mono',monospace; font-size:7.5px; color:#94a3b8; letter-spacing:.06em; }
  .header-progress { flex:1; max-width:260px; display:flex; align-items:center; gap:9px; }
  .progress-text { display:flex; justify-content:space-between; margin-bottom:4px; }
  .progress-label{ font-size:11px; font-weight:600; color:#64748b; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:130px; }
  .pct-badge     { border-radius:8px; width:38px; height:38px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .pct-badge span{ color:#fff; font-weight:800; font-size:12px; }
  .view-toggle   { display:flex; background:#e8f0fe; border-radius:9px; padding:3px; flex-shrink:0; }
  .vtab { background:transparent; border:none; border-radius:7px; padding:5px 11px; font-weight:600; font-size:12px; cursor:pointer; color:#64748b; transition:all .15s; font-family:'Montserrat',sans-serif; }
  .vtab.active { background:#fff; color:#2563eb; box-shadow:0 1px 5px rgba(29,78,216,.12); }

  /* ── Bars ── */
  .bar-wrap { background:#dbeafe; border-radius:99px; overflow:hidden; flex-shrink:0; width:100%; }
  .bar-fill { border-radius:99px; transition:width .5s ease; height:100%; }

  /* ── Site bar ── */
  .site-bar { background:#fff; border:1px solid #c7d9f5; border-radius:14px; padding:12px 14px; margin-bottom:14px; box-shadow:0 1px 6px rgba(0,0,0,.04); }
  .site-tabs { display:flex; gap:6px; flex:1; overflow-x:auto; padding-bottom:2px; }
  .site-tab  { border-radius:10px; padding:7px 13px; font-weight:700; font-size:12px; display:flex; align-items:center; gap:7px; flex-shrink:0; border-width:2px; border-style:solid; cursor:pointer; transition:all .18s; font-family:'Montserrat',sans-serif; }
  .site-tab:hover { transform:translateY(-1px); }
  .site-dot  { width:8px; height:8px; border-radius:50%; flex-shrink:0; display:inline-block; }
  .site-pct  { border-radius:99px; padding:1px 7px; font-size:10px; font-family:'JetBrains Mono',monospace; font-weight:700; }
  .site-actions { display:flex; gap:6px; flex-shrink:0; }
  .site-info-row { margin-top:10px; padding-top:10px; border-top:1px solid #e8f0fe; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
  .pri-stats { margin-left:auto; display:flex; gap:14px; }
  .pri-stat  { text-align:center; }
  .pri-stat-num   { font-size:12px; font-weight:700; font-family:'JetBrains Mono',monospace; }
  .pri-stat-label { font-size:9px; color:#94a3b8; }

  /* ── Buttons ── */
  .btn { border-radius:9px; padding:7px 14px; font-weight:700; font-size:12px; border:none; cursor:pointer; font-family:'Montserrat',sans-serif; transition:all .15s; }
  .btn:hover { opacity:.85; transform:translateY(-1px); }
  .btn-primary { background:#1d4ed8; color:#fff; }
  .btn-ghost   { background:#f0f6ff; color:#334155; border:1.5px solid #c7d9f5 !important; }
  .btn-danger  { background:#fef2f2; color:#dc2626; border:1.5px solid rgba(220,38,38,.27) !important; }
  .btn-red     { background:#dc2626; color:#fff; border:none !important; }
  .btn-sm      { padding:7px 12px; font-size:12px; }

  /* ── Project grid ── */
  .proj-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin-bottom:16px; }
  .proj-card { background:#fff; border-radius:12px; padding:11px 10px; text-align:left; position:relative; overflow:hidden; cursor:pointer; border:2px solid #c7d9f5; transition:all .18s; display:block; width:100%; font-family:'Montserrat',sans-serif; }
  .proj-card:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(29,78,216,.15); }
  .proj-card.active { box-shadow:0 4px 16px rgba(0,0,0,.15); }
  .proj-top-bar { position:absolute; top:0; left:0; right:0; height:3px; border-radius:10px 10px 0 0; }
  .proj-icon  { font-size:17px; line-height:1; }
  .proj-pct   { font-family:'JetBrains Mono',monospace; font-weight:700; font-size:11px; }
  .proj-title { font-weight:700; font-size:11px; line-height:1.3; margin-bottom:6px; }
  .proj-count { margin-top:5px; font-size:10px; font-family:'JetBrains Mono',monospace; color:#94a3b8; }

  /* ── Sections ── */
  .section-card { background:#fff; border:1px solid #c7d9f5; border-radius:12px; margin-bottom:11px; overflow:hidden; box-shadow:0 1px 6px rgba(0,0,0,.04); }
  .sec-header   { background:#eff6ff; border-bottom:1px solid #c7d9f5; padding:9px 13px; display:flex; align-items:center; justify-content:space-between; gap:8px; }
  .sec-title-wrap { display:flex; align-items:center; gap:7px; min-width:0; }
  .sec-icon    { font-size:14px; flex-shrink:0; }
  .sec-title   { font-weight:700; font-size:13px; color:#0f172a; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .sec-count-badge { background:#fff; color:#64748b; border:1px solid #c7d9f5; padding:1px 7px; border-radius:99px; font-size:10px; font-family:'JetBrains Mono',monospace; flex-shrink:0; }
  .sec-progress { display:flex; align-items:center; gap:8px; flex-shrink:0; }
  .sec-pct-text { font-family:'JetBrains Mono',monospace; font-weight:700; font-size:11px; min-width:30px; text-align:right; }

  /* ── Tasks ── */
  .task-row { display:flex; align-items:flex-start; gap:10px; padding:10px 13px; transition:background .1s; cursor:pointer; }
  .task-row:hover { background:#eff6ff !important; }
  .task-row.done  { background:rgba(37,99,235,.05) !important; }
  .task-row + .task-row { border-top:1px solid #f0f6ff; }
  .checkbox { width:19px; height:19px; min-width:19px; border-radius:5px; border:2px solid #a8c4ee; background:#fff; display:flex; align-items:center; justify-content:center; margin-top:2px; transition:all .18s; flex-shrink:0; }
  .checkbox.checked { animation:popIn .25s ease; }
  .task-text { flex:1; min-width:0; font-size:13px; line-height:1.55; color:#0f172a; word-break:break-word; }
  .task-text.done-text { color:#94a3b8; text-decoration:line-through; }
  .task-meta { display:flex; gap:4px; margin-top:4px; flex-wrap:wrap; align-items:center; }
  .badge  { display:inline-block; padding:2px 7px; border-radius:99px; font-size:10px; font-weight:700; font-family:'JetBrains Mono',monospace; white-space:nowrap; border:1px solid; }
  .effort { color:#94a3b8; font-family:'JetBrains Mono',monospace; font-size:10px; }

  /* ── Banner ── */
  .proj-banner { background:#fff; border:1px solid #c7d9f5; border-radius:12px; padding:13px 16px; margin-bottom:13px; border-left:4px solid; }
  .banner-top  { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
  .banner-info { flex:1; min-width:0; }
  .banner-title-row { display:flex; align-items:center; gap:8px; margin-bottom:4px; flex-wrap:wrap; }
  .banner-title { font-weight:800; font-size:16px; color:#0f172a; }
  .banner-desc  { font-size:12px; color:#64748b; line-height:1.5; }
  .banner-stat  { flex-shrink:0; text-align:center; }
  .banner-pct   { font-weight:800; font-size:24px; line-height:1; }
  .banner-tasks { font-size:10px; color:#64748b; }
  .banner-bar   { margin-top:10px; }

  /* ── Filters ── */
  .filters { margin-bottom:13px; display:flex; flex-direction:column; gap:7px; }
  .search-input { width:100%; background:#fff; border:1.5px solid #c7d9f5; border-radius:9px; padding:8px 13px; color:#0f172a; font-size:13px; transition:all .2s; font-family:'Montserrat',sans-serif; outline:none; }
  .search-input:focus { border-color:#2563eb; box-shadow:0 0 0 3px #bfdbfe; }
  .filter-row  { display:flex; gap:6px; overflow-x:auto; padding-bottom:2px; align-items:center; }
  .filter-label{ font-size:11px; font-weight:600; color:#94a3b8; flex-shrink:0; align-self:center; white-space:nowrap; }
  .pill-btn { border-radius:99px; padding:4px 11px; font-weight:600; font-size:11px; flex-shrink:0; cursor:pointer; border:1.5px solid #c7d9f5; background:#fff; color:#64748b; font-family:'Montserrat',sans-serif; transition:all .15s; }
  .pill-btn:hover { opacity:.8; }
  .action-row { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }

  /* ── Stats/Progress ── */
  .stats-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:9px; margin-bottom:14px; }
  .stat-card  { background:#fff; border:1px solid #c7d9f5; border-radius:12px; padding:12px 14px; border-top:3px solid; }
  .stat-emoji { font-size:16px; margin-bottom:4px; }
  .stat-num   { font-weight:800; font-size:24px; line-height:1; }
  .stat-label { font-size:12px; color:#64748b; margin-top:3px; }
  .breakdown-card   { background:#fff; border:1px solid #c7d9f5; border-left:4px solid; border-radius:12px; padding:14px; margin-bottom:10px; }
  .breakdown-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; gap:8px; }
  .breakdown-title  { font-weight:700; font-size:13px; }
  .breakdown-sub    { font-size:11px; color:#64748b; }
  .breakdown-pct    { font-weight:800; font-size:20px; flex-shrink:0; }
  .sec-mini-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:6px; margin-top:10px; }
  .sec-mini { background:#f0f6ff; border-radius:8px; padding:8px 10px; border:1px solid #c7d9f5; }
  .sec-mini-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; }
  .sec-mini-title { font-size:11px; font-weight:600; color:#334155; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-right:4px; }
  .sec-mini-count { font-family:'JetBrains Mono',monospace; font-size:10px; font-weight:700; flex-shrink:0; }
  .all-sites-card { background:#fff; border:1px solid #c7d9f5; border-radius:14px; padding:16px; margin-bottom:16px; }
  .site-row { padding:10px 12px; border-radius:10px; border:1.5px solid #c7d9f5; margin-bottom:8px; cursor:pointer; transition:all .15s; }
  .site-row:hover { border-color:#a8c4ee; }
  .site-row-top   { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; gap:8px; }
  .site-row-name  { font-weight:700; font-size:13px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .site-row-url   { font-size:10px; font-family:'JetBrains Mono',monospace; color:#94a3b8; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .site-row-right { display:flex; align-items:center; gap:9px; flex-shrink:0; }
  .site-row-pct   { font-weight:800; font-size:18px; min-width:38px; text-align:right; }
  .site-mini-projs { display:grid; grid-template-columns:repeat(8,1fr); gap:4px; }
  .mini-proj      { text-align:center; }
  .mini-proj-icon { font-size:12px; }
  .mini-proj-pct  { font-size:9px; font-family:'JetBrains Mono',monospace; font-weight:700; }

  /* ════════════════════════════════
     MODALS  (all structure in HTML)
  ════════════════════════════════ */
  .modal-overlay {
    position:fixed; inset:0; z-index:200;
    display:flex; align-items:center; justify-content:center; padding:16px;
    background:rgba(15,23,42,.55); backdrop-filter:blur(4px);
    opacity:0; pointer-events:none; transition:opacity .2s;
  }
  .modal-overlay.open { opacity:1; pointer-events:all; }
  .modal-box {
    background:#fff; border-radius:18px; padding:26px 24px;
    width:100%; max-width:440px;
    box-shadow:0 24px 64px rgba(0,0,0,.22),0 2px 12px rgba(29,78,216,.10);
    position:relative; animation:modalIn .22s ease;
    border:1px solid #e0eaff;
  }
  .modal-header {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid #e8f0fe;
  }
  .modal-title {
    font-weight:800; font-size:17px; color:#0f172a;
    display:flex; align-items:center; gap:8px;
  }
  .modal-close {
    background:#f0f6ff; border:1px solid #c7d9f5; cursor:pointer;
    font-size:15px; color:#64748b; width:30px; height:30px;
    border-radius:8px; display:flex; align-items:center; justify-content:center;
    transition:all .15s; flex-shrink:0;
  }
  .modal-close:hover { background:#fef2f2; color:#dc2626; border-color:rgba(220,38,38,.3); }
  .form-group  { margin-bottom:16px; }
  .form-label  { display:block; font-size:12px; font-weight:700; color:#334155; margin-bottom:6px; letter-spacing:.02em; }
  .form-label .req { color:#dc2626; }
  .form-input  {
    width:100%; background:#f8faff; border:1.5px solid #c7d9f5; border-radius:10px;
    padding:10px 13px; color:#0f172a; font-size:13px;
    transition:all .2s; font-family:'Montserrat',sans-serif; outline:none;
  }
  .form-input:focus { border-color:#2563eb; box-shadow:0 0 0 3px #bfdbfe; background:#fff; }
  .form-input.error { border-color:#dc2626; box-shadow:0 0 0 3px #fecaca; }
  .form-hint { font-size:11px; color:#94a3b8; margin-top:4px; font-family:'JetBrains Mono',monospace; }
  .color-picker  { display:flex; gap:9px; flex-wrap:wrap; padding:4px 0; }
  .color-swatch  { width:30px; height:30px; border-radius:50%; cursor:pointer; transition:all .15s; border:3px solid transparent; box-shadow:0 2px 6px rgba(0,0,0,.15); }
  .color-swatch:hover   { transform:scale(1.12); }
  .color-swatch.selected{ border-color:#0f172a; box-shadow:0 0 0 2px rgba(0,0,0,.25); transform:scale(1.1); }
  .modal-divider { height:1px; background:#e8f0fe; margin:4px 0 18px; }
  .modal-actions { display:flex; gap:8px; }

  /* Delete modal specific */
  .delete-warning { background:#fef2f2; border:1.5px solid rgba(220,38,38,.2); border-radius:12px; padding:16px; margin-bottom:20px; }
  .delete-warning-icon  { font-size:28px; margin-bottom:10px; }
  .delete-warning-title { font-weight:800; color:#dc2626; margin-bottom:6px; font-size:15px; }
  .delete-warning-text  { font-size:13px; color:#64748b; line-height:1.6; }

  /* ── Footer ── */
  footer { background:#1e3a8a; width:100%; margin-top:auto; }
  .footer-stripe { height:3px; background:linear-gradient(90deg,#2563eb,#0891b2,#4f46e5); }
  .footer-inner  { max-width:1160px; margin:0 auto; padding:28px 16px 22px; width:100%; }
  .footer-grid   { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:24px; align-items:start; }
  .footer-brand-title     { font-weight:900; font-size:20px; color:#fff; line-height:1.1; }
  .footer-brand-title span{ color:#60a5fa; }
  .footer-brand-sub  { font-family:'JetBrains Mono',monospace; font-size:8px; color:#64748b; letter-spacing:.06em; }
  .footer-desc  { font-size:12px; color:#94a3b8; line-height:1.7; max-width:250px; margin:0 0 12px; }
  .footer-tags  { display:flex; gap:6px; flex-wrap:wrap; }
  .footer-tag   { padding:3px 9px; border-radius:99px; font-size:10px; font-family:'JetBrains Mono',monospace; color:#bfdbfe; }
  .creator-card { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:18px 20px; }
  .creator-label{ font-size:9px; color:#64748b; font-family:'JetBrains Mono',monospace; letter-spacing:.08em; margin-bottom:14px; text-transform:uppercase; }
  .creator-top  { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
  .creator-avatar{ width:44px; height:44px; min-width:44px; border-radius:50%; background:linear-gradient(135deg,#1d4ed8,#0891b2); display:flex; align-items:center; justify-content:center; font-weight:900; font-size:19px; color:#fff; }
  .creator-name { font-weight:800; font-size:16px; color:#fff; line-height:1.2; }
  .creator-role { font-size:11px; color:#93c5fd; margin-top:2px; }
  .contact-links{ display:flex; flex-direction:column; gap:7px; }
  .contact-link { display:flex; align-items:center; gap:9px; border-radius:9px; padding:8px 11px; text-decoration:none; transition:background .15s; }
  .contact-link:hover { opacity:.9; }
  .contact-text { font-family:'JetBrains Mono',monospace; font-size:12px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:22px; padding-top:14px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
  .footer-copy  { font-size:11px; color:#475569; font-family:'JetBrains Mono',monospace; }

  .hidden { display:none !important; }

  @media(max-width:640px){
    .proj-grid{grid-template-columns:repeat(4,1fr);gap:6px}
    .proj-card{padding:9px 7px} .proj-icon{font-size:14px} .proj-title{font-size:10px}
    .header-progress{display:none} .site-mini-projs{grid-template-columns:repeat(4,1fr)}
    .stats-grid{grid-template-columns:repeat(2,1fr)} .sec-mini-grid{grid-template-columns:repeat(1,1fr)}
  }
  @media(max-width:400px){
    .proj-grid{grid-template-columns:repeat(4,1fr);gap:4px}
    .proj-card{padding:8px 6px} .proj-title{font-size:9px}
  }
  /* ── Export dropdown ── */
  .export-wrap { position:relative; display:inline-block; }
  .export-menu {
    position:absolute; right:0; top:calc(100% + 5px); z-index:300;
    background:#fff; border:1.5px solid #c7d9f5; border-radius:12px;
    box-shadow:0 8px 28px rgba(0,0,0,0.13); padding:5px;
    min-width:160px; display:none;
  }
  .export-menu.open { display:block; animation:fadeUp .15s ease; }
  .export-menu-item {
    display:flex; align-items:center; gap:9px; padding:8px 11px;
    border-radius:8px; font-size:12px; font-weight:600; cursor:pointer;
    color:#334155; transition:background .12s; border:none; background:none;
    width:100%; font-family:'Montserrat',sans-serif; white-space:nowrap;
  }
  .export-menu-item:hover { background:#eff6ff; color:#1d4ed8; }
  .export-menu-divider { height:1px; background:#e8f0fe; margin:3px 0; }
  