/* ===== Status colors (CSS vars for both themes) ===== */
    [data-theme="light"] {
      --status-active-bg:#dcfce7;--status-active-text:#166534;--status-active-border:#86efac;
      --status-pending-bg:#fef3c7;--status-pending-text:#92400e;--status-pending-border:#fcd34d;
      --status-done-bg:#eff6ff;--status-done-text:#1e40af;--status-done-border:#bfdbfe;
      --status-pause-bg:#f3f4f6;--status-pause-text:#6b7280;--status-pause-border:#d1d5db;
      --status-terminate-bg:#fef2f2;--status-terminate-text:#991b1b;--status-terminate-border:#fecaca;
    }
    [data-theme="dark"] {
      --status-active-bg:rgba(22,101,52,.3);--status-active-text:#86efac;--status-active-border:rgba(134,239,172,.4);
      --status-pending-bg:rgba(146,64,14,.3);--status-pending-text:#fcd34d;--status-pending-border:rgba(252,211,77,.4);
      --status-done-bg:rgba(30,64,175,.3);--status-done-text:#93c5fd;--status-done-border:rgba(191,219,254,.4);
      --status-pause-bg:rgba(107,114,128,.3);--status-pause-text:#9ca3af;--status-pause-border:rgba(209,213,219,.4);
      --status-terminate-bg:rgba(127,29,29,.3);--status-terminate-text:#fca5a5;--status-terminate-border:rgba(252,165,165,.4);
    }

    .hero{background:var(--gradient);border-radius:20px;padding:44px 48px;margin-bottom:32px;position:relative;overflow:hidden;animation:fadeUp .5s ease .05s both;margin-top: 26px;}
    .hero::before{content:'';position:absolute;top:-60px;right:-40px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.07);}
    .hero::after{content:'';position:absolute;bottom:-80px;right:120px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.04);}
    .hero-label{font-family:'Space Mono',monospace;font-size:11px;color:rgba(255,255,255,.65);letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;}
    .hero-title{font-family:'Noto Serif SC',serif;font-size:38px;font-weight:300;color:#fff;line-height:1.25;margin-bottom:12px;}
    .hero-title strong{font-weight:700;}
    .hero-sub{font-size:14px;color:rgba(255,255,255,.75);max-width:520px;line-height:1.75;}
    .hero-stats{display:flex;gap:40px;margin-top:28px;flex-wrap:wrap;}
    .h-stat-n{font-family:'Space Mono',monospace;font-size:30px;font-weight:700;color:#fff;line-height:1;}
    .h-stat-l{font-size:11px;color:rgba(255,255,255,.6);margin-top:5px;letter-spacing:.05em;}
    .hero-btn{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:10px 20px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:20px;display:inline-flex;align-items:center;gap:8px;}
    .hero-btn:hover{background:rgba(255,255,255,.3);}
    .toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px;animation:fadeUp .5s ease .1s both;}
    .toolbar-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
    .tab-btn{padding:9px 18px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid var(--border);background:var(--bg-white);color:var(--text-2);box-shadow:var(--shadow);}
    .tab-btn:hover{border-color:var(--border-h);color:var(--blue);}
    .tab-btn.active{background:var(--gradient);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(37,99,235,.25);}
    .tab-count{font-family:'Space Mono',monospace;font-size:10px;opacity:.7;margin-left:4px;}
    .toolbar-right{display:flex;align-items:center;gap:8px;}
    .trash-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:100px;background:var(--bg-white);color:var(--text-2);font-size:13px;cursor:pointer;transition:all .2s;}
    .trash-btn:hover{border-color:var(--red);color:var(--red);background:#fef2f2;}
    .trash-count{background:var(--text-3);color:#fff;padding:2px 6px;border-radius:10px;font-size:11px;font-weight:600;min-width:18px;text-align:center;}
    .search-box{display:flex;align-items:center;gap:8px;background:var(--bg-white);border:1px solid var(--border);border-radius:100px;padding:9px 16px;transition:all .2s;box-shadow:var(--shadow);}
    .search-box:focus-within{border-color:var(--blue);}
    .search-box input{background:none;border:none;outline:none;color:var(--text);font-size:13px;width:180px;font-family:'Inter',sans-serif;}
    .search-box input::placeholder{color:var(--text-3);}
    .btn-primary{background:var(--gradient);color:#fff;border:none;padding:10px 20px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(37,99,235,.25);display:inline-flex;align-items:center;gap:8px;}
    .btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(37,99,235,.3);}
    .projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px;animation:fadeUp .5s ease .15s both;}
    .proj-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:0;box-shadow:var(--shadow);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden;}
    .proj-card:hover{box-shadow:0 12px 32px rgba(0,0,0,.12);border-color:var(--blue-border);transform:translateY(-4px);}
    .proj-header{padding:20px 22px 0;position:relative;}
    .proj-priority{position:absolute;top:16px;right:18px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;letter-spacing:.05em;}
    .proj-date-tag{position:absolute;top:16px;right:60px;font-size:10px;color:var(--text-3);font-family:'Space Mono',monospace;}
    .proj-priority.P0{background:#fef2f2;color:#dc2626;}
    .proj-priority.P1{background:#fff7ed;color:#ea580c;}
    .proj-priority.P2{background:#fefce8;color:#ca8a04;}
    .proj-priority.P3{background:#f0fdf4;color:#16a34a;}
    .proj-title{font-family:'Noto Serif SC',serif;font-size:18px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:8px;padding-right:50px;}
    .proj-desc{font-size:13px;color:var(--text-2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
    .proj-status-row{display:flex;align-items:center;gap:8px;margin-top:14px;}
    .proj-status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:5px 12px;border-radius:100px;white-space:nowrap;}
    .proj-status.active{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d;border:none;}
    .proj-status.planning{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;border:none;}
    .proj-status.completed{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7c3aed;border:none;}
    .proj-status.on_hold{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309;border:none;}
    .proj-status.cancelled{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c;border:none;}
    .proj-status.archived{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#4b5563;border:none;}
    .proj-body{padding:0 22px 16px;}
    .proj-progress{margin-top:12px;}
    .progress-bar{height:6px;background:var(--border);border-radius:100px;overflow:hidden;transition:background .3s;}
    .progress-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);transition:width .4s ease;}
    .progress-label{font-size:10px;color:var(--text-3);margin-top:5px;display:flex;justify-content:space-between;}
    .proj-divider{height:1px;background:var(--border);margin:12px 0;}
    .proj-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:linear-gradient(to top,rgba(0,0,0,.02),transparent);border-top:1px solid var(--border);}
    .proj-members{display:flex;align-items:center;}
    .proj-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--blue-pale),var(--blue-border));border:2px solid var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--blue);font-weight:700;margin-left:-8px;transition:all .2s;}
    .proj-avatar:first-child{margin-left:0;}
    .proj-avatar:hover{z-index:1;transform:scale(1.15);box-shadow:0 2px 8px rgba(0,0,0,.15);}
    .proj-avatar.more{background:var(--bg);color:var(--text-2);}
    .proj-info{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--text-3);}
    .proj-info-item{display:flex;align-items:center;gap:4px;}
    .proj-arrow{color:var(--text-3);font-size:20px;transition:all .25s;}
    .proj-card:hover .proj-arrow{color:var(--blue);transform:translateX(4px);}
    .proj-divider{height:1px;background:var(--border);margin:12px 0;}
    .empty-state{text-align:center;padding:80px 20px;animation:fadeUp .5s ease;}
    .empty-icon{font-size:52px;margin-bottom:16px;opacity:.3;}
    .empty-title{font-family:'Noto Serif SC',serif;font-size:20px;color:var(--text);margin-bottom:8px;}
    .empty-desc{font-size:14px;color:var(--text-2);}
    .modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;}
    .modal-overlay.show{display:flex;}
    .modal{background:var(--bg-white);border-radius:20px;padding:32px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:modalIn .25s ease;}
    @keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
    .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
    .modal-title{font-family:'Noto Serif SC',serif;font-size:20px;color:var(--text);}
    .modal-close{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--text-2);transition:all .2s;}
    .modal-close:hover{background:var(--bg-hover);color:var(--text);}
    .form-group{margin-bottom:18px;position:relative;}
    .form-label{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px;display:block;letter-spacing:.03em;}
    .form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;transition:all .2s;}
    .form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
    input[type="date"]{cursor:pointer;position:relative;}
    input[type="date"]::-webkit-calendar-picker-indicator{cursor:pointer;position:absolute;left:0;top:0;width:100%;height:100%;margin:0;padding:0;background:transparent;opacity:0;}
    .form-textarea{resize:vertical;min-height:80px;}
    .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
    .form-tags-input{display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1px solid var(--border);border-radius:10px;min-height:42px;background:var(--bg);cursor:text;align-items:center;}
    .form-tags-input:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
    .form-tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:12px;background:var(--blue-pale);color:var(--blue);border:1px solid var(--blue-border);}
    .form-tag-chip.del{background:var(--bg);border-color:var(--border);color:var(--text-2);cursor:pointer;}
    .form-tag-chip.del:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5;}
    .chip-input{border:none;background:none;outline:none;color:var(--text);font-size:13px;min-width:80px;flex:1;font-family:'Inter',sans-serif;}
    .contact-dropdown{position:absolute;z-index:1001;background:var(--bg-white);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-h);max-height:200px;overflow-y:auto;display:none;width:calc(100% - 0px);}
    .contact-dropdown-item{padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);transition:background .15s;}
    .contact-dropdown-item:last-child{border-bottom:none;}
    .contact-dropdown-item:hover{background:var(--bg);}
    .contact-dropdown-name{font-weight:500;color:var(--text);}
    .contact-dropdown-company{font-size:11px;color:var(--text-3);}
    .form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;}
    .btn-secondary{padding:10px 20px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid var(--border);background:var(--bg-white);color:var(--text-2);}
    .btn-secondary:hover{background:var(--bg);color:var(--text);}
    .detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:499;display:none;}
    .detail-overlay.show{display:block;}
    .detail-panel{position:fixed;top:0;right:0;width:520px;height:100vh;background:var(--bg-white);border-left:1px solid var(--border);box-shadow:-8px 0 32px rgba(0,0,0,.1);z-index:500;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto;}
    .detail-panel.open{transform:translateX(0);}
    .detail-header{padding:24px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-white);z-index:1;}
    .detail-back{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);cursor:pointer;margin-bottom:16px;transition:color .2s;}
    .detail-back:hover{color:var(--blue);}
    .detail-title{font-family:'Noto Serif SC',serif;font-size:22px;color:var(--text);margin-bottom:8px;}
    .detail-status{margin-bottom:12px;}
    .detail-meta{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:4px;}
    .detail-meta-item{display:flex;flex-direction:column;gap:2px;}
    .detail-meta-label{font-size:10px;color:var(--text-3);font-family:'Space Mono',monospace;letter-spacing:.08em;text-transform:uppercase;}
    .detail-meta-value{font-size:13px;color:var(--text);font-weight:500;}
    .detail-body{padding:24px 28px;}
    .detail-section{margin-bottom:28px;}
    .detail-section-title{font-size:11px;font-weight:700;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px;font-family:'Space Mono',monospace;}
    .detail-desc{font-size:14px;color:var(--text-2);line-height:1.75;}
    .detail-contacts{display:flex;flex-wrap:wrap;gap:8px;}
    .detail-contact-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:100px;background:var(--blue-pale);border:1px solid var(--blue-border);color:var(--blue);font-size:12px;font-weight:500;text-decoration:none;transition:all .2s;}
    .detail-contact-chip:hover{background:var(--blue);color:#fff;}
    .chip-remove{cursor:pointer;font-weight:700;margin-left:4px;opacity:.6;}
    .chip-remove:hover{opacity:1;}
    .timeline{position:relative;padding-left:24px;}
    .timeline::before{content:'';position:absolute;left:7px;top:4px;bottom:4px;width:2px;background:var(--border);transition:background .3s;}
    .tl-item{position:relative;margin-bottom:20px;}
    .tl-dot{position:absolute;left:-24px;top:5px;width:16px;height:16px;border-radius:50%;border:2px solid var(--blue);background:var(--bg-white);display:flex;align-items:center;justify-content:center;}
    .tl-dot.done{background:var(--blue);border-color:var(--blue);}
    .tl-dot.done::after{content:'';width:6px;height:6px;border-radius:50%;background:#fff;}
    .tl-date{font-family:'Space Mono',monospace;font-size:10px;color:var(--text-3);margin-bottom:3px;}
    .tl-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;}
    .tl-desc{font-size:12px;color:var(--text-2);line-height:1.5;}
    .tl-actions{display:none;gap:4px;margin-top:6px;}
    .tl-item:hover .tl-actions{display:flex;}
    .tl-btn{padding:4px 8px;font-size:11px;border:none;border-radius:6px;cursor:pointer;background:var(--bg-2);color:var(--text);}
    .tl-btn:hover{background:var(--blue);color:#fff;}
    .tl-btn.danger:hover{background:#ef4444;color:#fff;}
    .tl-desc{font-size:12px;color:var(--text-2);line-height:1.5;}
    .note-item{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:10px;transition:border-color .2s;}
    .note-item:hover{border-color:var(--border-h);}
    .note-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
    .note-date{font-family:'Space Mono',monospace;font-size:10px;color:var(--text-3);}
    .note-author{font-size:11px;color:var(--blue);font-weight:500;}
    .note-text{font-size:13px;color:var(--text-2);line-height:1.6;}
    .detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px;}
    .btn-sm{padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid var(--border);background:var(--bg-white);color:var(--text-2);display:inline-flex;align-items:center;gap:5px;}
    .btn-sm:hover{background:var(--bg);color:var(--text);}
    .btn-sm.danger{border-color:#fca5a5;background:#fef2f2;color:#dc2626;}
    .btn-sm.danger:hover{background:#fee2e2;}
    .btn-sm.blue{border-color:var(--blue-border);background:var(--blue-pale);color:var(--blue);}
    .btn-sm.blue:hover{background:var(--blue);color:#fff;}
    .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
    @keyframes fadeDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
    @keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
    footer { margin-top:48px; padding-top:20px; border-top:1px solid var(--border); text-align:center; transition:border-color .3s; }
    footer p { font-family:'Space Mono',monospace; font-size:11px; color:var(--text-3); letter-spacing:.08em; transition:color .3s; }
    .heart { color:var(--blue); }

    .note-item{margin-bottom:12px;padding:12px;background:var(--bg-2);border-radius:8px}
    .note-header{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12px;color:var(--text-3)}
    .note-author{font-weight:500;color:var(--text-2)}
    .note-content{font-size:14px;line-height:1.5;color:var(--text-1);white-space:pre-wrap}
    .note-actions{margin-left:auto;opacity:0;transition:opacity .2s}
    .note-item:hover .note-actions{opacity:1}
    .note-btn{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:12px;opacity:.6;transition:opacity .2s}
    .note-btn:hover{opacity:1}
    .note-btn.danger:hover{color:var(--danger)}

    @media(max-width:900px){.projects-grid{grid-template-columns:1fr}.detail-panel{width:100%}.form-row{grid-template-columns:1fr}}

.trash-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);}
.trash-item:hover{background:var(--bg);}
.trash-item-info{flex:1;}
.trash-item-name{font-weight:600;color:var(--text);margin-bottom:4px;}
.trash-item-meta{font-size:12px;color:var(--text-3);}
.trash-item-actions{display:flex;gap:8px;}
.trash-btn-restore{padding:6px 12px;border:1px solid var(--blue);border-radius:6px;background:transparent;color:var(--blue);font-size:12px;cursor:pointer;transition:all .15s;}
.trash-btn-restore:hover{background:var(--blue);color:#fff;}
.trash-btn-delete{padding:6px 12px;border:1px solid var(--red);border-radius:6px;background:transparent;color:var(--red);font-size:12px;cursor:pointer;transition:all .15s;}
.trash-btn-delete:hover{background:var(--red);color:#fff;}