  @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
  :root {
    --primary:#0070f3;
    --phase1:#6366f1; --phase2:#8b5cf6; --phase3:#ec4899; --phase4:#f59e0b; --phase5:#10b981; --phase6:#06b6d4;
    --bg:#f8fafc; --card:#ffffff; --border:#e2e8f0;
    --text:#1e293b; --text-secondary:#64748b;
    --success:#22c55e; --warning:#f59e0b; --danger:#ef4444;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html,body{overflow-x:hidden;}
  body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;}
  .hero{background:#fff;color:#0f172a;padding:14px 40px 12px;border-bottom:1px solid var(--border);}
  .hero{position:relative;overflow:hidden;}
  .hero::before{content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,0.08) 0%,transparent 70%);border-radius:50%;pointer-events:none;}
  .hero-content{max-width:var(--layout-max,1200px);margin:0 auto;position:relative;z-index:1;display:flex;align-items:center;gap:28px;flex-wrap:wrap;}
  .hero h1{font-size:1.05rem;font-weight:800;letter-spacing:-0.01em;margin:0;line-height:1.15;color:#0f172a;}
  .hero p{font-size:0.72rem;color:#64748b;margin:2px 0 0;font-style:italic;}
  .hero-info{flex:1;min-width:220px;display:flex;flex-direction:column;align-items:center;text-align:center;}
  .hero-customer{display:flex;flex-direction:column;gap:4px;min-width:180px;}
  .hero-customer .hc-name{font-size:1.05rem;font-weight:800;color:#0f172a;line-height:1.15;}
  .hero-customer .hc-code{font-size:0.72rem;color:#64748b;font-weight:600;letter-spacing:0.04em;}
  .hero-customer .hc-label{font-size:0.58rem;color:#94a3b8;text-transform:uppercase;letter-spacing:0.08em;font-weight:600;}
  .hero-meta{display:flex;gap:22px;flex-wrap:wrap;margin-left:auto;padding-left:22px;border-left:1px solid var(--border);}
  .hero-meta-item{display:flex;flex-direction:column;gap:2px;}
  .hero-meta-item .label{font-size:0.58rem;color:#94a3b8;text-transform:uppercase;letter-spacing:0.08em;font-weight:600;}
  .hero-meta-item .value{font-size:0.9rem;font-weight:700;color:#1e293b;}
  :root{--layout-max:1200px;}
  @media(min-width:1440px){:root{--layout-max:1360px;}}
  @media(min-width:1680px){:root{--layout-max:1560px;}}
  @media(min-width:1920px){:root{--layout-max:1760px;}}
  @media(min-width:2400px){:root{--layout-max:2000px;}}
  .container{max-width:var(--layout-max,1200px);margin:0 auto;padding:0 20px 20px;}
  .fixed-header{position:sticky;top:44px;z-index:55;box-shadow:0 2px 8px rgba(0,0,0,0.1);background:var(--bg);pointer-events:none;isolation:isolate;}
  .fixed-header *{pointer-events:auto;}
  .tab-content{isolation:isolate;}
  .tabs{display:flex;gap:2px;background:#e2e8f0;border-radius:10px;padding:3px;margin-bottom:8px;overflow-x:auto;overflow-y:hidden;}
  .tab-btn{padding:7px 12px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-family:inherit;font-size:0.78rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;transition:all 0.2s;}
  .tab-btn.active{background:white;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,0.1);}
  .tab-btn:hover:not(.active){color:var(--text);}
  .tabs-row{display:flex;align-items:stretch;gap:6px;position:relative;margin-bottom:8px;}
  .tabs-row > .tabs{flex:1;min-width:0;margin-bottom:0;}
  .tabs-cog-btn{flex-shrink:0;width:38px;border-radius:8px;border:1px solid var(--border);background:white;cursor:pointer;font-size:0.95rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all 0.15s;align-self:stretch;}
  .tabs-cog-btn:hover{background:#f1f5f9;color:var(--text);}
  .tabs-cog-popover{position:absolute;top:calc(100% + 4px);right:0;background:white;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,0.18);padding:8px;min-width:240px;max-height:60vh;overflow-y:auto;z-index:60;}
  .tabs-cog-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:0.84rem;color:var(--text);user-select:none;}
  .tabs-cog-row:hover{background:#f1f5f9;}
  .tabs-cog-row input{cursor:pointer;}
  .tab-content{display:none;}.tab-content.active{display:block;}
  body.notes-fullwidth .container{max-width:none;padding:0 40px 20px;}
  /* SOW read-only: disable modifying controls; keep view toggles/sub-tabs clickable */
  #tab-modules.sow-readonly input,
  #tab-modules.sow-readonly textarea,
  #tab-modules.sow-readonly select{pointer-events:none!important;opacity:0.55;cursor:not-allowed!important;}
  #tab-modules.sow-readonly button:not([data-sow-view]):not(.tab-btn){pointer-events:none!important;opacity:0.4;cursor:not-allowed!important;}
  #tab-modules.sow-readonly .sow-readonly-banner{display:flex!important;}
  body.notes-fullwidth .fixed-header .hero,
  body.notes-fullwidth .fixed-header .hero *,
  body.notes-fullwidth .fixed-header .stats-row,
  body.notes-fullwidth .fixed-header .stats-row *{pointer-events:none!important;}
  #tab-notes.active{position:relative;z-index:30;isolation:isolate;}
  #boardNotesList > *{position:relative;z-index:1;pointer-events:auto;}
  #boardNotesList button{position:relative;z-index:2;pointer-events:auto;}
  .bn-row{position:relative;z-index:1;}
  .bn-row button,.bn-row input{position:relative;z-index:2;pointer-events:auto!important;}
  .stats-row{display:flex;gap:6px;margin-bottom:4px;flex-wrap:wrap;}
  .stat-card{background:white;border:1px solid var(--border);border-radius:6px;padding:4px 8px;text-align:center;flex:1;min-width:70px;}
  .stat-value{font-size:0.95rem;font-weight:800;color:var(--primary);}
  .stat-label{font-size:0.6rem;color:var(--text-secondary);margin-top:0;}
  /* Priority-tinted stat cards — brighter = more important */
  .stat-card.sc-progress{background:linear-gradient(180deg,#ecfdf5,#d1fae5);border-color:#6ee7b7;}
  .stat-card.sc-progress .stat-value{color:#047857;}
  .stat-card.sc-progress .stat-label{color:#065f46;}
  .stat-card.sc-milestones{background:linear-gradient(180deg,#fffbeb,#fef3c7);border-color:#fcd34d;}
  .stat-card.sc-milestones .stat-value{color:#b45309;}
  .stat-card.sc-milestones .stat-label{color:#92400e;}
  .stat-card.sc-phases{background:#eff6ff;border-color:#bfdbfe;}
  .stat-card.sc-phases .stat-value{color:#1d4ed8;}
  .stat-card.sc-phases .stat-label{color:#1e40af;}
  .stat-card.sc-duration{background:#f0fdfa;border-color:#99f6e4;}
  .stat-card.sc-duration .stat-value{color:#0f766e;}
  .stat-card.sc-duration .stat-label{color:#115e59;}
  .stat-card.sc-scope{background:#f8fafc;border-color:#e2e8f0;}
  .stat-card.sc-scope .stat-value{color:#475569;}
  .stat-card.sc-scope .stat-label{color:#64748b;}
  .progress-bar-bg{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-top:6px;}
  .progress-bar-fill{height:100%;border-radius:4px;transition:width 0.5s;}
  .section-title{font-size:1.25rem;font-weight:700;margin-bottom:18px;display:flex;align-items:center;gap:10px;}
  .section-title::before{content:'';width:4px;height:24px;background:var(--primary);border-radius:2px;}

  /* Gantt */
  .gantt-wrap{overflow-x:auto;overflow-y:visible;background:var(--card);border-radius:16px;padding:24px;border:1px solid var(--border);position:relative;}
  .gantt-grid{display:grid;grid-template-columns:210px 1fr;font-size:0.82rem;}
  .gantt-header-label{font-weight:600;color:var(--text-secondary);padding:6px 0;border-bottom:2px solid var(--border);}
  .gantt-header-months{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:2px solid var(--border);}
  .gantt-month{text-align:center;font-weight:600;color:var(--text-secondary);padding:6px 0;}
  .gantt-row-label{display:flex;align-items:center;gap:8px;padding:7px 10px 7px 0;font-weight:600;border-bottom:1px solid #f1f5f9;}
  .gantt-row-label .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
  .gantt-row-bars{position:relative;border-bottom:1px solid #f1f5f9;height:38px;overflow:visible;}
  .gantt-bar{position:absolute;top:5px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:600;color:white;cursor:pointer;transition:transform 0.15s,box-shadow 0.15s;z-index:1;}
  .gantt-bar:hover{transform:scaleY(1.18);box-shadow:0 4px 14px rgba(0,0,0,0.2);z-index:3;}
  /* Gantt tooltip — fixed position via JS */
  .gantt-tip{display:none;position:fixed;background:#1e293b;color:white;padding:14px 18px;border-radius:12px;font-size:0.76rem;white-space:normal;min-width:420px;max-width:600px;z-index:9999;box-shadow:0 8px 30px rgba(0,0,0,0.35);line-height:1.55;pointer-events:none;}
  .gantt-tip.show{display:block;}
  .gantt-tip .tip-title{font-weight:700;font-size:0.84rem;margin-bottom:6px;border-bottom:1px solid rgba(255,255,255,0.2);padding-bottom:5px;}
  .gantt-tip .tip-del{display:flex;align-items:center;gap:5px;margin-top:3px;font-size:0.72rem;opacity:0.9;}
  .gantt-tip .tip-del .td{width:5px;height:5px;border-radius:50%;flex-shrink:0;}

  /* Milestone diamond on chart */
  .gantt-ms{position:absolute;top:50%;z-index:5;cursor:pointer;transition:transform 0.15s;}
  .gantt-ms:hover{transform:translateY(-50%) scale(1.25);z-index:15;}
  .gantt-ms .ms-shape{width:16px;height:16px;transform:rotate(45deg);border-radius:3px;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 6px rgba(0,0,0,0.25);}
  .gantt-ms .ms-tip{display:none;position:absolute;bottom:170%;left:50%;transform:translateX(-50%);background:#1e293b;color:white;padding:6px 12px;border-radius:6px;font-size:0.76rem;white-space:nowrap;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,0.3);}
  .gantt-ms:hover .ms-tip{display:block;}

  /* Milestone row inside phase */
  .milestone-bar{display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,#fef3c7,#fef9c3);border:1px solid #fde68a;border-radius:10px;padding:10px 16px;margin-top:16px;margin-bottom:4px;}
  .milestone-bar .ms-icon{width:20px;height:20px;background:var(--phase4);transform:rotate(45deg);border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
  .milestone-bar .ms-icon span{transform:rotate(-45deg);color:white;font-size:0.6rem;font-weight:800;}
  .milestone-bar .ms-text{font-size:0.84rem;font-weight:600;color:#92400e;}
  .milestone-bar .ms-week{font-size:0.74rem;color:#b45309;font-weight:500;}
  .milestone-bar.critical{background:linear-gradient(90deg,#fef2f2,#fee2e2);border-color:#fca5a5;}
  .milestone-bar.critical .ms-icon{background:#ef4444;}
  .milestone-bar.critical .ms-text{color:#991b1b;}
  .milestone-bar.critical .ms-week{color:#b91c1c;}
  .milestone-bar.green{background:linear-gradient(90deg,#ecfdf5,#d1fae5);border-color:#6ee7b7;}
  .milestone-bar.green .ms-icon{background:var(--phase5);}
  .milestone-bar.green .ms-text{color:#065f46;}
  .milestone-bar.green .ms-week{color:#047857;}

  /* Phase Cards */
  .phase-card{background:var(--card);border-radius:16px;padding:28px;margin-bottom:20px;border:1px solid var(--border);box-shadow:0 1px 3px rgba(0,0,0,0.04);}
  .phase-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.08);}
  .phase-header{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap;}
  .phase-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
  .phase-title-group{flex:1;min-width:200px;}
  .phase-title{font-size:1.12rem;font-weight:700;}
  .phase-subtitle{font-size:0.8rem;color:var(--text-secondary);}
  .phase-duration-badge{background:#f1f5f9;padding:6px 14px;border-radius:8px;font-size:0.82rem;font-weight:600;color:var(--text-secondary);}
  .sub-section{margin-top:18px;margin-bottom:14px;}
  .sub-section-title{font-size:0.9rem;font-weight:700;color:var(--text);margin-bottom:10px;padding-left:12px;border-left:3px solid;display:flex;align-items:center;gap:8px;}
  .sub-section-title .week-badge{font-size:0.72rem;font-weight:600;background:#f1f5f9;color:var(--text-secondary);padding:2px 8px;border-radius:4px;}
  .task-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:10px;}
  .task-item{display:flex;align-items:flex-start;gap:10px;padding:11px 12px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0;}
  .task-check{width:20px;height:20px;border-radius:6px;border:2px solid #cbd5e1;flex-shrink:0;margin-top:1px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}
  .task-check.checked{background:var(--success);border-color:var(--success);}
  .task-check.checked::after{content:'✓';color:white;font-size:0.7rem;font-weight:700;}
  .task-text{font-size:0.84rem;line-height:1.5;}
  .task-text strong{display:block;font-weight:600;margin-bottom:1px;}
  .task-text span{color:var(--text-secondary);font-size:0.78rem;}
  .deliverable-tag{display:inline-block;padding:3px 10px;border-radius:6px;font-size:0.74rem;font-weight:500;margin:2px;}
  .deliverables-row{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);}
  .deliverables-label{font-size:0.76rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.04em;}

  /* Deliverables Tab */
  .del-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:16px;}
  .del-card-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
  .del-phase-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
  .del-phase-name{font-weight:700;font-size:1rem;}
  .del-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:10px;overflow:hidden;border:1px solid var(--border);font-size:0.84rem;}
  .del-table thead{background:#f1f5f9;}
  .del-table th{padding:10px 14px;text-align:left;font-size:0.76rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.03em;}
  .del-table td{padding:12px 14px;border-top:1px solid var(--border);vertical-align:top;}
  .del-table tr:hover td{background:#f8fafc;}
  .status-badge{display:inline-block;padding:2px 8px;border-radius:5px;font-size:0.72rem;font-weight:600;}
  .status-pending{background:#f1f5f9;color:var(--text-secondary);}
  .status-required{background:#fef2f2;color:var(--danger);}
  .status-signoff{background:#fffbeb;color:#b45309;}
  /* Deliverable inline edit */
  .del-btn-add{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:2px dashed var(--border);border-radius:10px;background:transparent;color:var(--primary);font-family:inherit;font-size:0.82rem;font-weight:600;cursor:pointer;transition:all 0.2s;margin-top:8px;}
  .del-btn-add:hover{background:#eff6ff;border-color:var(--primary);}
  .del-btn-rm{width:28px;height:28px;border:none;background:#fee2e2;color:#ef4444;border-radius:6px;cursor:pointer;font-size:0.85rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0;}
  .del-btn-rm:hover{background:#ef4444;color:white;}
  .del-edit-input{border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:0.82rem;width:100%;background:#f8fafc;transition:border-color 0.2s;}
  .del-edit-input:focus{outline:none;border-color:var(--primary);background:white;}
  .del-edit-select{border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:0.82rem;background:#f8fafc;cursor:pointer;}
  .del-edit-select:focus{outline:none;border-color:var(--primary);}

  /* Module / Risk / Team */
  .module-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);}
  .module-table thead{background:#f1f5f9;}
  .module-table th{padding:12px 16px;text-align:left;font-size:0.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.04em;}
  .module-table td{padding:14px 16px;font-size:0.88rem;border-top:1px solid var(--border);vertical-align:top;}
  .module-table tr:hover td{background:#f8fafc;}
  .module-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;font-size:0.9rem;margin-right:8px;vertical-align:middle;}
  .risk-card{display:flex;gap:14px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:10px;border-left:4px solid;}
  .risk-card.high{border-color:var(--danger);}.risk-card.medium{border-color:var(--warning);}.risk-card.low{border-color:var(--success);}
  .risk-level{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;padding:2px 8px;border-radius:4px;white-space:nowrap;height:fit-content;}
  .risk-level.high{background:#fef2f2;color:var(--danger);}.risk-level.medium{background:#fffbeb;color:#d97706;}.risk-level.low{background:#f0fdf4;color:#16a34a;}
  .team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;}
  .team-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;display:flex;gap:14px;align-items:flex-start;cursor:pointer;transition:all 0.15s;}
  .team-card:hover{box-shadow:0 4px 12px rgba(0,0,0,0.08);border-color:var(--primary);}
  .team-card .tc-assigned{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px;}
  .team-card .tc-person{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;font-size:0.74rem;font-weight:600;color:var(--primary);}
  .team-card .tc-empty{font-size:0.76rem;color:#cbd5e1;font-style:italic;margin-top:6px;}
  .ra-user-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;margin-bottom:6px;cursor:pointer;transition:all 0.15s;}
  .ra-user-item:hover{background:#f8fafc;}
  .ra-user-item.selected{background:#eef2ff;border-color:var(--primary);}
  .ra-user-item .ra-check{width:20px;height:20px;border:2px solid #cbd5e1;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.15s;}
  .ra-user-item.selected .ra-check{background:var(--primary);border-color:var(--primary);}
  .ra-user-item.selected .ra-check::after{content:'✓';color:white;font-size:0.7rem;font-weight:700;}
  .ra-user-item .ra-info{flex:1;}
  .ra-user-item .ra-name{font-weight:600;font-size:0.88rem;}
  .ra-user-item .ra-detail{font-size:0.76rem;color:var(--text-secondary);}
  .team-avatar{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
  .team-name{font-weight:600;font-size:0.95rem;}.team-role{font-size:0.82rem;color:var(--text-secondary);}.team-resp{font-size:0.8rem;color:var(--text-secondary);margin-top:4px;}

  /* Setup Form */
  .setup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;}
  .setup-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;}
  .setup-card-title{font-size:0.95rem;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
  .setup-card-title .sc-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;}
  .form-group{margin-bottom:14px;}
  .form-label{display:block;font-size:0.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.03em;}
  .form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:0.88rem;color:var(--text);background:white;transition:border 0.2s;outline:none;}
  .form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,112,243,0.1);}
  .form-textarea{resize:vertical;min-height:70px;}
  .form-select{cursor:pointer;appearance:auto;}
  .form-hint{font-size:0.72rem;color:var(--text-secondary);margin-top:3px;}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .module-toggle{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f8fafc;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;transition:all 0.2s;margin-bottom:6px;}
  .module-toggle:hover{border-color:#94a3b8;}
  .module-toggle.active{border-color:var(--primary);background:#eef2ff;}
  .module-toggle .mt-dot{width:18px;height:18px;border-radius:6px;border:2px solid #cbd5e1;display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0;}
  .module-toggle.active .mt-dot{background:var(--primary);border-color:var(--primary);}
  .module-toggle.active .mt-dot::after{content:'✓';color:white;font-size:0.65rem;font-weight:700;}
  .module-toggle .mt-text{font-size:0.84rem;font-weight:500;}
  .team-row{display:grid;grid-template-columns:1fr 1fr 0.7fr auto;gap:8px;margin-bottom:8px;align-items:end;}
  .team-row.header{margin-bottom:4px;}
  .team-row.header span{font-size:0.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.03em;}
  .btn-add{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;background:var(--primary);color:white;border:none;border-radius:8px;font-family:inherit;font-size:0.82rem;font-weight:600;cursor:pointer;transition:background 0.2s;}
  .btn-add:hover{background:var(--primary-dark,#005bb5);}
  .btn-remove{width:30px;height:30px;border:1.5px solid #fca5a5;background:#fef2f2;color:var(--danger);border-radius:6px;cursor:pointer;font-size:0.85rem;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}
  .btn-remove:hover{background:var(--danger);color:white;}
  .setup-full{grid-column:1/-1;}
  .save-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 20px;margin-bottom:20px;}
  .save-bar .save-text{font-size:0.84rem;color:var(--text-secondary);}
  .save-bar .save-text strong{color:var(--text);}
  .btn-save{padding:9px 22px;background:var(--primary);color:white;border:none;border-radius:8px;font-family:inherit;font-size:0.88rem;font-weight:600;cursor:pointer;transition:background 0.2s;}
  .btn-save:hover{background:#005bb5;}
  .btn-outline{padding:9px 22px;background:white;color:var(--text);border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:0.88rem;font-weight:500;cursor:pointer;transition:all 0.2s;}
  .btn-outline:hover{border-color:var(--primary);color:var(--primary);}
  .saved-toast{position:fixed;top:20px;right:20px;background:linear-gradient(135deg,#065f46,#047857);color:white;padding:14px 22px;border-radius:14px;font-size:0.88rem;font-weight:600;z-index:9999;opacity:0;transform:translateY(-10px) scale(0.96);transition:all 0.3s cubic-bezier(0.34,1.3,0.64,1);pointer-events:none;box-shadow:0 12px 32px rgba(6,95,70,0.32),0 2px 6px rgba(0,0,0,0.12);display:flex;align-items:center;gap:10px;max-width:420px;}
  .saved-toast.show{opacity:1;transform:translateY(0) scale(1);}
  .saved-toast.toast-error{background:linear-gradient(135deg,#991b1b,#b91c1c);box-shadow:0 12px 32px rgba(185,28,28,0.32),0 2px 6px rgba(0,0,0,0.12);}
  .saved-toast.toast-info{background:linear-gradient(135deg,#1e3a8a,#1d4ed8);box-shadow:0 12px 32px rgba(29,78,216,0.32),0 2px 6px rgba(0,0,0,0.12);}

  /* ============================================================
     NOTIFY POPUP — modal-style success/error/info dialog
     ============================================================ */
  .notify-pop-bg{position:fixed;inset:0;background:rgba(15,23,42,0.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;opacity:0;pointer-events:none;transition:opacity 0.22s ease;}
  .notify-pop-bg.show{opacity:1;pointer-events:auto;}
  .notify-pop{background:#fff;border-radius:20px;width:100%;max-width:380px;padding:28px 26px 22px;box-shadow:0 24px 70px rgba(15,23,42,0.32),0 4px 14px rgba(15,23,42,0.12);text-align:center;transform:translateY(20px) scale(0.92);opacity:0;transition:transform 0.32s cubic-bezier(0.34,1.4,0.64,1),opacity 0.22s ease;}
  .notify-pop-bg.show .notify-pop{transform:translateY(0) scale(1);opacity:1;}
  .np-icon{width:68px;height:68px;border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;color:#fff;position:relative;}
  .np-icon svg{width:34px;height:34px;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;}
  .np-icon::before{content:'';position:absolute;inset:-8px;border-radius:50%;opacity:0.18;}
  .notify-pop.np-success .np-icon{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 24px rgba(16,185,129,0.36);}
  .notify-pop.np-success .np-icon::before{background:#10b981;animation:npRipple 0.8s ease-out;}
  .notify-pop.np-success .np-icon svg path{stroke-dasharray:48;stroke-dashoffset:48;animation:npDraw 0.5s 0.15s ease-out forwards;}
  .notify-pop.np-error .np-icon{background:linear-gradient(135deg,#f43f5e,#dc2626);box-shadow:0 8px 24px rgba(220,38,38,0.36);}
  .notify-pop.np-error .np-icon::before{background:#dc2626;animation:npShake 0.5s ease-out;}
  .notify-pop.np-info .np-icon{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 8px 24px rgba(29,78,216,0.36);}
  @keyframes npRipple{0%{transform:scale(0.6);opacity:0.5;}100%{transform:scale(1.3);opacity:0;}}
  @keyframes npShake{0%,100%{transform:scale(1);}25%{transform:scale(1.06) translateX(-3px);}50%{transform:scale(1.06) translateX(3px);}75%{transform:scale(1.06) translateX(-2px);}}
  @keyframes npDraw{to{stroke-dashoffset:0;}}
  .np-title{font-size:1.18rem;font-weight:800;color:var(--text);margin:0 0 6px;letter-spacing:-0.01em;}
  .np-msg{font-size:0.9rem;color:var(--text-secondary);line-height:1.55;margin:0 0 22px;white-space:pre-wrap;}
  .np-btn{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:11px 22px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary),#4f46e5);color:#fff;font-family:inherit;font-size:0.92rem;font-weight:700;cursor:pointer;transition:transform 0.15s ease,box-shadow 0.15s ease;box-shadow:0 4px 12px rgba(99,102,241,0.32);}
  .np-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(99,102,241,0.45);}
  .notify-pop.np-error .np-btn{background:linear-gradient(135deg,#f43f5e,#dc2626);box-shadow:0 4px 12px rgba(220,38,38,0.32);}
  .notify-pop.np-error .np-btn:hover{box-shadow:0 8px 20px rgba(220,38,38,0.45);}
  .notify-pop.np-success .np-btn{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px rgba(16,185,129,0.32);}
  .notify-pop.np-success .np-btn:hover{box-shadow:0 8px 20px rgba(16,185,129,0.45);}
  /* Confirm / Prompt: two-button row + input */
  .np-btn-row{display:flex;gap:10px;}
  .np-btn-row .np-btn{flex:1;}
  .np-btn.np-btn-cancel{background:#f1f5f9;color:var(--text);box-shadow:none;border:1px solid var(--border);}
  .np-btn.np-btn-cancel:hover{background:#e2e8f0;box-shadow:none;transform:translateY(-1px);}
  .notify-pop.np-confirm .np-icon{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 8px 24px rgba(217,119,6,0.36);}
  .notify-pop.np-danger .np-icon{background:linear-gradient(135deg,#f43f5e,#dc2626);box-shadow:0 8px 24px rgba(220,38,38,0.36);}
  .notify-pop.np-danger .np-btn{background:linear-gradient(135deg,#f43f5e,#dc2626);box-shadow:0 4px 12px rgba(220,38,38,0.32);}
  .notify-pop.np-danger .np-btn:hover{box-shadow:0 8px 20px rgba(220,38,38,0.45);}
  .np-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:0.92rem;color:var(--text);margin:0 0 18px;outline:none;transition:border 0.15s ease,box-shadow 0.15s ease;background:#fff;}
  .np-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,0.18);}
  textarea.np-input{resize:vertical;min-height:80px;}
  /* Inline button spinner */
  .btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btnSpin 0.7s linear infinite;vertical-align:-2px;margin-right:8px;}
  @keyframes btnSpin{to{transform:rotate(360deg);}}
  .btn-save:disabled,.btn-save.is-loading{opacity:0.75;cursor:not-allowed;pointer-events:none;}
  .btn-save.is-success{background:linear-gradient(135deg,#059669,#10b981) !important;}

  /* Gantt Gear Button */
  .gantt-title-row{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:50;margin-bottom:12px;}
  .gantt-title-btns{display:flex;gap:6px;position:relative;z-index:51;pointer-events:auto;}
  .gantt-gear,.gantt-fs{width:38px;height:38px;border-radius:10px;border:1.5px solid var(--border);background:white;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;font-size:1.2rem;color:var(--text-secondary);position:relative;z-index:52;pointer-events:auto;}
  .gantt-gear:hover,.gantt-fs:hover{border-color:var(--primary);color:var(--primary);background:#eef2ff;}
  .gantt-gear:hover{transform:rotate(30deg);}
  /* Fullscreen Gantt */
  .gantt-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:var(--bg);overflow:auto;padding:24px 32px;animation:gfsFade 0.2s ease;}
  @keyframes gfsFade{from{opacity:0;}to{opacity:1;}}
  .gantt-fullscreen .gantt-title-row{margin-bottom:16px;}
  .gantt-fullscreen .gantt-wrap{border:none;box-shadow:none;padding:16px 20px;}
  .gantt-fullscreen .gantt-grid{grid-template-columns:220px 1fr!important;}
  .gantt-fullscreen .gantt-row-bars{height:48px!important;}
  .gantt-fullscreen .gantt-bar{top:6px!important;height:36px!important;font-size:0.82rem!important;}
  .gantt-fullscreen .gantt-ms .ms-shape{width:20px!important;height:20px!important;}
  .gantt-fullscreen .gantt-row-label{font-size:0.9rem!important;}
  /* Gantt Editor */
  .gantt-editor-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.45);z-index:1000;justify-content:center;align-items:flex-start;padding:30px 16px;overflow-y:auto;}
  .gantt-editor-overlay.open{display:flex;}
  .gantt-editor{background:white;border-radius:18px;padding:30px;width:100%;max-width:820px;box-shadow:0 25px 70px rgba(0,0,0,0.28);animation:geSlide 0.25s ease;overflow:hidden;}
  @keyframes geSlide{from{opacity:0;transform:translateY(-20px);}to{opacity:1;transform:translateY(0);}}
  .gantt-editor h3{font-size:1.15rem;margin:0 0 4px;color:var(--text);}
  .gantt-editor .hint{font-size:0.8rem;color:var(--text-secondary);margin-bottom:18px;}
  .ge-tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:2px solid var(--border);padding-bottom:0;}
  .ge-tab{padding:9px 18px;font-size:0.84rem;font-weight:600;cursor:pointer;border:none;background:none;color:var(--text-secondary);border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all 0.15s;font-family:inherit;}
  .ge-tab:hover{color:var(--text);}
  .ge-tab.active{color:var(--primary);border-bottom-color:var(--primary);}
  .ge-panel{display:none;}
  .ge-panel.active{display:block;}
  .ge-section{margin-bottom:16px;padding:16px;border:1px solid var(--border);border-radius:12px;background:#fafbfc;}
  .ge-section-title{font-size:0.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:10px;display:flex;align-items:center;gap:6px;}
  .ge-row{display:grid;grid-template-columns:1fr 1fr 65px 65px 30px;gap:8px;align-items:end;margin-bottom:8px;padding:10px 12px;background:white;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
  .ge-row label{font-size:0.7rem;font-weight:600;color:var(--text-secondary);margin-bottom:2px;display:block;}
  .ge-row input,.ge-row select{padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:0.82rem;font-family:inherit;background:white;width:100%;min-width:0;box-sizing:border-box;}
  .ge-row input:focus,.ge-row select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,112,243,0.1);}
  .ge-del{width:30px;height:30px;border-radius:6px;border:1px solid #fca5a5;background:#fef2f2;color:var(--danger);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0;}
  .ge-del:hover{background:var(--danger);color:white;}
  .ge-btn-add{padding:7px 16px;border-radius:8px;font-family:inherit;font-size:0.82rem;font-weight:600;cursor:pointer;border:1.5px dashed var(--border);background:white;color:var(--text-secondary);transition:all 0.15s;margin-top:8px;}
  .ge-btn-add:hover{border-color:var(--primary);color:var(--primary);background:#eef2ff;}
  .ge-actions{display:flex;gap:8px;justify-content:space-between;align-items:center;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}
  .ge-actions-left{display:flex;gap:8px;}
  .ge-actions-right{display:flex;gap:8px;justify-content:flex-end;margin-left:auto;}
  .ge-btn{padding:9px 22px;border-radius:8px;font-family:inherit;font-size:0.86rem;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:white;color:var(--text);transition:all 0.15s;}
  .ge-btn:hover{border-color:var(--primary);color:var(--primary);}
  .ge-btn.primary{background:var(--primary);color:white;border-color:var(--primary);}
  .ge-btn.primary:hover{background:#005bb5;}
  .ge-btn.danger{color:var(--danger);border-color:var(--danger);}
  .ge-btn.danger:hover{background:var(--danger);color:white;}
  /* Milestone Grid Editor */
  .ms-grid-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px;background:#fafbfc;}
  .ms-grid{display:grid;min-width:600px;}
  .ms-grid-corner{background:#f1f5f9;padding:8px;font-size:0.72rem;font-weight:700;color:var(--text-secondary);border-right:1px solid var(--border);border-bottom:1px solid var(--border);position:sticky;left:0;z-index:2;}
  .ms-grid-wk{background:#f8fafc;padding:4px 2px;font-size:0.68rem;font-weight:600;color:var(--text-secondary);text-align:center;border-bottom:1px solid var(--border);border-right:1px solid #f1f5f9;}
  .ms-grid-phase{background:#f1f5f9;padding:8px 10px;font-size:0.76rem;font-weight:600;color:var(--text);border-right:1px solid var(--border);border-bottom:1px solid #f1f5f9;position:sticky;left:0;z-index:2;white-space:nowrap;display:flex;align-items:center;gap:6px;}
  .ms-grid-phase .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
  .ms-grid-cell{border-right:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9;position:relative;min-height:36px;cursor:pointer;transition:background 0.1s;}
  .ms-grid-cell:hover{background:#eef2ff;}
  .ms-grid-cell.in-range{background:#f0f4ff;}
  .ms-grid-cell .ms-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);width:14px;height:14px;border-radius:2px;border:2px solid white;box-shadow:0 1px 5px rgba(0,0,0,0.3);cursor:pointer;z-index:3;transition:transform 0.15s;}
  .ms-grid-cell .ms-dot:hover{transform:translate(-50%,-50%) rotate(45deg) scale(1.3);}
  .ms-grid-cell .ms-dot-tip{display:none;position:absolute;bottom:110%;left:50%;transform:translateX(-50%);background:#1e293b;color:white;padding:5px 10px;border-radius:6px;font-size:0.72rem;white-space:nowrap;z-index:10;box-shadow:0 3px 10px rgba(0,0,0,0.3);}
  .ms-grid-cell .ms-dot:hover+.ms-dot-tip,.ms-grid-cell .ms-dot-tip:hover{display:block;}
  .ms-edit-form{padding:16px;border-top:1px solid var(--border);background:white;border-radius:0 0 12px 12px;}
  .ms-edit-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap;margin-bottom:8px;}
  .ms-edit-row label{font-size:0.72rem;font-weight:600;color:var(--text-secondary);display:block;margin-bottom:3px;}
  .ms-edit-row input,.ms-edit-row select{padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:0.82rem;font-family:inherit;}
  .ms-edit-row input:focus,.ms-edit-row select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,112,243,0.1);}

  /* Dashboard & Multi-Project */
  .view-dashboard{min-height:100vh;}
  .dash-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);color:white;padding:24px 40px;text-align:left;position:fixed;top:0;left:0;right:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
  #viewDashboard{padding-top:var(--dash-hero-h,140px);}
  .dash-hero h1{font-size:2.2rem;font-weight:800;margin-bottom:8px;}
  .dash-hero p{color:#94a3b8;font-size:1rem;max-width:600px;margin:0;}
  /* Single-row hero on wide screens; wraps on narrow viewports */
  @media (max-width: 1100px) {
    .dash-hero-row { flex-wrap: wrap !important; }
    .dash-hero-row > div { flex-wrap: wrap !important; overflow: visible !important; }
    .dash-hero h1 { font-size: 1.4rem !important; }
  }
  .dash-container{max-width:var(--layout-max,1200px);margin:0 auto;padding:30px 20px;}
  .dash-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px;}
  .dash-toolbar h2{font-size:1.15rem;font-weight:700;}
  .dash-toolbar-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
  .dash-view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#f8fafc;}
  .dash-view-toggle button{border:0;background:transparent;padding:6px 10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#64748b;transition:background 0.15s,color 0.15s;font-family:inherit;}
  .dash-view-toggle button.active{background:var(--primary);color:#fff;}
  .dash-view-toggle button:hover:not(.active){background:#eef2ff;color:var(--primary);}
  .dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:28px;}
  .dash-stat{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center;}
  .dash-stat .ds-val{font-size:1.5rem;font-weight:800;color:var(--primary);}
  .dash-stat .ds-lbl{font-size:0.78rem;color:var(--text-secondary);margin-top:2px;}
  .project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
  .project-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;cursor:pointer;transition:box-shadow 0.2s,transform 0.2s,border-color 0.2s;position:relative;overflow:hidden;}
  .project-card:hover{box-shadow:0 8px 24px rgba(0,0,0,0.1);transform:translateY(-2px);}
  .project-card .pc-drag-handle{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#64748b;cursor:grab;opacity:0.45;transition:opacity 0.15s,background 0.15s,color 0.15s;user-select:none;z-index:2;font-size:14px;letter-spacing:-1px;font-weight:700;line-height:1;}
  .project-card .pc-drag-handle:hover{background:#eef2ff;color:var(--primary);opacity:1;}
  .project-card .pc-drag-handle:active{cursor:grabbing;}
  .project-card:hover .pc-drag-handle{opacity:1;}
  .project-card.pc-dragging{opacity:0.4;transform:scale(0.98);}
  .project-card.pc-drag-over-before{border-left:3px solid var(--primary);box-shadow:-4px 0 12px rgba(0,90,200,0.15);}
  .project-card.pc-drag-over-after{border-right:3px solid var(--primary);box-shadow:4px 0 12px rgba(0,90,200,0.15);}
  .project-card .pc-accent{position:absolute;top:0;left:0;right:0;height:4px;}
  .project-card .pc-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;}
  .project-card .pc-name{font-size:1.05rem;font-weight:700;margin-bottom:2px;}
  .project-card .pc-code{font-size:0.76rem;color:var(--text-secondary);}
  .project-card .pc-meta{font-size:0.8rem;color:var(--text-secondary);margin-bottom:12px;}
  .project-card .pc-progress{margin-top:8px;}
  .project-card .pc-progress-label{display:flex;justify-content:space-between;font-size:0.76rem;color:var(--text-secondary);margin-bottom:4px;}
  .project-card .pc-progress-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;}
  .project-card .pc-progress-fill{height:100%;border-radius:3px;transition:width 0.4s;}
  .project-card .pc-actions{display:flex;gap:6px;margin-top:14px;justify-content:flex-end;}
  .pc-btn{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:white;font-size:0.76rem;font-weight:600;cursor:pointer;transition:all 0.15s;font-family:inherit;}
  .pc-btn:hover{border-color:var(--primary);color:var(--primary);}
  .pc-btn.open{background:var(--primary);color:white;border-color:var(--primary);}
  .pc-btn.open:hover{background:#005bb5;}
  .pc-btn.danger:hover{border-color:var(--danger);color:var(--danger);}
  .project-list{display:flex;flex-direction:column;gap:10px;}
  .project-row{display:grid;grid-template-columns:28px 6px minmax(220px,1.5fr) minmax(140px,0.9fr) minmax(180px,1fr) 86px auto;gap:16px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:border-color 0.15s,box-shadow 0.15s,transform 0.15s;position:relative;overflow:hidden;}
  .project-row:hover{border-color:var(--primary);box-shadow:0 4px 14px rgba(0,0,0,0.06);}
  .project-row .pr-handle{color:#94a3b8;cursor:grab;display:flex;align-items:center;justify-content:center;}
  .project-row .pr-handle:hover{color:var(--primary);}
  .project-row .pr-handle:active{cursor:grabbing;}
  .project-row .pr-accent{height:36px;border-radius:3px;}
  .project-row .pr-title .pr-comp{font-size:0.78rem;font-weight:600;color:var(--primary);margin-bottom:2px;}
  .project-row .pr-title .pr-code{font-size:0.72rem;color:var(--text-secondary);margin-bottom:1px;}
  .project-row .pr-title .pr-name{font-weight:700;font-size:0.98rem;line-height:1.3;}
  .project-row .pr-meta{font-size:0.78rem;color:var(--text-secondary);line-height:1.45;}
  .project-row .pr-prog-wrap{display:flex;align-items:center;gap:10px;min-width:0;}
  .project-row .pr-prog-bar{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;min-width:60px;}
  .project-row .pr-prog-fill{height:100%;border-radius:3px;transition:width 0.4s;}
  .project-row .pr-prog-label{font-size:0.76rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:34px;text-align:right;}
  .project-row.pc-dragging{opacity:0.4;}
  .project-row.pc-drag-over-before{box-shadow:0 -3px 0 var(--primary),0 4px 14px rgba(0,90,200,0.12);}
  .project-row.pc-drag-over-after{box-shadow:0 3px 0 var(--primary),0 4px 14px rgba(0,90,200,0.12);}
  @media(max-width:900px){.project-row{grid-template-columns:24px 6px 1fr auto;}.project-row .pr-meta,.project-row .pr-prog-wrap,.project-row .pr-status{display:none;}}
  .dash-groups{display:flex;flex-direction:column;gap:22px;}
  .dash-group{display:flex;flex-direction:column;gap:12px;}
  .dash-group-header{display:flex;align-items:center;gap:10px;padding-bottom:6px;border-bottom:1px dashed var(--border);}
  .dash-group-header .status-pill{font-size:0.72rem;padding:3px 12px;}
  .dash-group-count{color:var(--text-secondary);font-size:0.82rem;font-weight:600;font-variant-numeric:tabular-nums;}
  .dash-group-body{min-height:72px;position:relative;}
  .dash-group-body.empty{display:flex;align-items:center;justify-content:center;min-height:64px;border:1.5px dashed var(--border);border-radius:12px;color:var(--text-secondary);font-size:0.82rem;opacity:0.75;}
  .dash-group-body.dash-group-drop{background:rgba(0,90,200,0.05);outline:2px dashed var(--primary);outline-offset:-4px;border-radius:12px;}
  .status-pill{display:inline-block;padding:2px 10px;border-radius:10px;font-size:0.7rem;font-weight:600;text-transform:uppercase;}
  .status-pill.active{background:#ecfdf5;color:#059669;}
  .status-pill.on-hold{background:#fffbeb;color:#d97706;}
  .status-pill.completed{background:#eef2ff;color:var(--primary);}
  .status-pill.presales{background:#eff6ff;color:#1d4ed8;}
  .status-pill.lost{background:#f1f5f9;color:#64748b;}
  /* Presales section visual separation */
  .dash-section-divider{margin:32px 0 18px;padding:18px 22px;border-radius:14px;background:linear-gradient(135deg,#eff6ff 0%,#e0e7ff 100%);border:1px dashed #93c5fd;}
  .dash-section-divider .ds-title{font-size:1.05rem;font-weight:700;color:#1d4ed8;margin:0 0 4px;display:flex;align-items:center;gap:8px;}
  .dash-section-divider .ds-desc{font-size:0.8rem;color:#475569;margin:0;}
  .dash-section-divider .ds-stats{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap;}
  .dash-section-divider .ds-stat{background:white;border:1px solid #bfdbfe;border-radius:8px;padding:8px 14px;min-width:80px;text-align:center;}
  .dash-section-divider .ds-stat-val{font-size:1.4rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;}
  .dash-section-divider .ds-stat-lbl{font-size:0.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px;}
  .dash-section-divider .ds-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;}
  .dash-section-divider .btn-presales{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:white;border:none;padding:8px 18px;border-radius:8px;font-family:inherit;font-size:0.84rem;font-weight:600;cursor:pointer;box-shadow:0 2px 6px rgba(29,78,216,0.25);transition:all 0.15s;}
  .dash-section-divider .btn-presales:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(29,78,216,0.35);}
  /* Convert/Lost buttons on presales card */
  .pc-btn.convert{background:#10b981;color:white;border-color:#10b981;}
  .pc-btn.convert:hover{background:#059669;border-color:#059669;}
  .pc-btn.lost{background:#fff;color:#64748b;border-color:#cbd5e1;}
  .pc-btn.lost:hover{background:#f8fafc;color:#475569;}
  .project-bar{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);border-bottom:1px solid rgba(148,163,184,0.15);padding:10px 40px;display:flex;align-items:center;justify-content:space-between;gap:12px;position:fixed;top:0;left:0;right:0;z-index:60;box-shadow:0 2px 8px rgba(0,0,0,0.15);color:#fff;}
  #viewProject{padding-top:var(--project-bar-h,64px);}
  .project-bar .pb-back{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid rgba(255,255,255,0.2);border-radius:8px;background:rgba(255,255,255,0.08);cursor:pointer;font-family:inherit;font-size:0.82rem;font-weight:500;color:#e2e8f0;transition:all 0.15s;}
  .project-bar .pb-back:hover{border-color:#a5b4fc;color:#fff;background:rgba(99,102,241,0.2);}
  .project-bar .pb-info{font-weight:600;font-size:0.9rem;color:#fff;}
  .project-bar .pb-status select{padding:4px 10px;border:1px solid var(--border);border-radius:6px;font-size:0.78rem;font-family:inherit;cursor:pointer;}
  /* Modal */
  .modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.45);z-index:1001;justify-content:center;align-items:center;padding:20px;overflow-y:auto;}
  .modal-overlay.open{display:flex;}
  .modal-box{background:white;border-radius:18px;padding:30px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 70px rgba(0,0,0,0.28);animation:geSlide 0.25s ease;}
  .modal-box h3{font-size:1.1rem;font-weight:700;margin-bottom:16px;}
  .modal-box .modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;}
  .color-picker{display:flex;gap:8px;margin-top:6px;}
  .color-dot{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all 0.15s;}
  .color-dot:hover,.color-dot.active{border-color:var(--text);transform:scale(1.15);}
  .dash-empty{text-align:center;padding:60px 20px;color:var(--text-secondary);}
  .dash-empty .de-icon{font-size:3rem;margin-bottom:12px;opacity:0.5;}
  .dash-empty p{font-size:0.95rem;}

  /* ===== Auth (Login/Register) ===== */
  .auth-view{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);padding:20px;position:relative;overflow:hidden;}
  .auth-view::before{content:'';position:absolute;top:-30%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,0.12) 0%,transparent 70%);border-radius:50%;}
  .auth-view::after{content:'';position:absolute;bottom:-20%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(16,185,129,0.08) 0%,transparent 70%);border-radius:50%;}
  .auth-box{background:white;border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 25px 60px rgba(0,0,0,0.3);position:relative;z-index:1;}
  .auth-box .auth-logo{text-align:center;margin-bottom:28px;}
  .auth-box .auth-logo .al-badge{display:inline-block;background:linear-gradient(135deg,var(--primary),var(--phase2));color:white;padding:6px 16px;border-radius:10px;font-size:0.78rem;font-weight:700;letter-spacing:0.04em;margin-bottom:10px;}
  .auth-box .auth-logo h2{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:4px;}
  .auth-box .auth-logo p{font-size:0.84rem;color:var(--text-secondary);}
  .auth-box .auth-form .form-group{margin-bottom:16px;}
  .auth-box .auth-form .form-label{font-size:0.8rem;font-weight:600;color:var(--text);margin-bottom:6px;display:block;}
  .auth-box .auth-form .auth-input{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:0.9rem;outline:none;transition:border 0.2s;box-sizing:border-box;}
  .auth-box .auth-form .auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,112,243,0.1);}
  .auth-btn{width:100%;padding:13px;border:none;border-radius:10px;font-family:inherit;font-size:0.95rem;font-weight:700;cursor:pointer;transition:all 0.2s;}
  .auth-btn.primary{background:linear-gradient(135deg,var(--primary),var(--phase2));color:white;box-shadow:0 4px 14px rgba(0,112,243,0.3);}
  .auth-btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,112,243,0.4);}
  .auth-switch{text-align:center;margin-top:20px;font-size:0.84rem;color:var(--text-secondary);}
  .auth-switch a{color:var(--primary);font-weight:600;cursor:pointer;text-decoration:none;}
  .auth-switch a:hover{text-decoration:underline;}
  .auth-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:0.82rem;font-weight:500;margin-bottom:14px;display:none;}
  .auth-error.show{display:block;}
  .auth-success{background:#f0fdf4;color:#059669;padding:10px 14px;border-radius:8px;font-size:0.82rem;font-weight:500;margin-bottom:14px;display:none;}
  .auth-success.show{display:block;}
  .auth-user-bar{display:flex;align-items:center;gap:8px;font-size:0.82rem;}
  .auth-user-bar .aub-avatar{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#4f46e5);color:white;display:flex;align-items:center;justify-content:center;font-size:0.78rem;font-weight:700;box-shadow:0 2px 6px rgba(0,0,0,0.25),inset 0 1px 0 rgba(255,255,255,0.2);}
  .auth-user-bar .aub-name{font-weight:600;color:var(--text);padding:0 4px;}
  .auth-user-bar .aub-name-pill{display:inline-flex;align-items:center;height:36px;padding:0 14px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#4f46e5);color:white;font-weight:600;font-size:0.82rem;box-shadow:0 2px 6px rgba(0,0,0,0.25),inset 0 1px 0 rgba(255,255,255,0.15);white-space:nowrap;}
  .auth-user-bar .aub-logout{padding:4px 12px;border:1px solid var(--border);border-radius:6px;background:white;cursor:pointer;font-family:inherit;font-size:0.76rem;color:var(--text-secondary);transition:all 0.15s;}
  .auth-user-bar .aub-logout:hover{border-color:var(--danger);color:var(--danger);}
  .project-bar .auth-user-bar .aub-name{color:#fff;}
  .project-bar .auth-user-bar .aub-logout{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.2);color:#e2e8f0;}
  .project-bar .auth-user-bar .aub-logout:hover{background:rgba(239,68,68,0.15);border-color:#fca5a5;color:#fecaca;}
  /* Unified hero nav button — used in dash-hero */
  .hero-nav-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border:1px solid rgba(255,255,255,0.18);border-radius:10px;background:rgba(255,255,255,0.08);color:#fff;cursor:pointer;font-family:inherit;font-size:0.82rem;font-weight:500;transition:background 0.15s,border-color 0.15s,transform 0.1s;box-shadow:0 2px 6px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
  .hero-nav-btn:hover{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.35);}
  .hero-nav-btn:active{transform:translateY(1px);box-shadow:0 1px 3px rgba(0,0,0,0.25),inset 0 1px 2px rgba(0,0,0,0.1);}
  .hero-nav-btn.icon-only{width:36px;padding:0;}
  .hero-nav-btn.tong-btn{background:linear-gradient(135deg,rgba(251,191,36,0.28),rgba(245,158,11,0.4));border-color:rgba(251,191,36,0.65);color:#fef3c7;font-weight:700;padding:0 12px 0 10px;box-shadow:0 2px 8px rgba(245,158,11,0.35),inset 0 1px 0 rgba(255,255,255,0.2);}
  .hero-nav-btn.tong-btn:hover{background:linear-gradient(135deg,rgba(251,191,36,0.4),rgba(245,158,11,0.55));border-color:rgba(251,191,36,0.85);}
  .hero-nav-btn .hnb-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;border-radius:9px;background:#ef4444;color:white;font-size:0.62rem;font-weight:700;padding:0 5px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,0.4);}
  .dash-hero .auth-user-bar .aub-name{color:#fff;}
  .dash-hero .auth-user-bar .aub-logout{height:36px;padding:0 14px;border-radius:10px;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.08);color:#e2e8f0;font-size:0.82rem;font-weight:500;box-shadow:0 2px 6px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
  .dash-hero .auth-user-bar .aub-logout:hover{background:rgba(239,68,68,0.18);border-color:#fca5a5;color:#fecaca;}

  /* ===== System Settings ===== */
  .settings-view{min-height:100vh;background:var(--bg);}
  .settings-hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);color:white;padding:14px 40px 0;position:fixed;top:0;left:0;right:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
  #viewSettings{padding-top:var(--settings-hero-h,130px);}
  .settings-hero-inner{max-width:1400px;margin:0 auto;padding-left:60px;display:flex;align-items:center;justify-content:space-between;}
  .settings-hero h1{font-size:1.3rem;font-weight:800;}
  .settings-hero p{color:#94a3b8;font-size:0.8rem;}
  .settings-container{max-width:1400px;margin:0 auto;padding:30px 20px;}
  .settings-nav{display:flex;gap:4px;background:white;border-radius:10px;padding:4px;margin-bottom:20px;overflow-x:auto;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
  .settings-nav-btn{padding:8px 16px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-family:inherit;font-size:0.82rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;transition:all 0.2s;}
  .settings-nav-btn.active{background:var(--primary);color:white;font-weight:600;box-shadow:0 2px 6px rgba(0,112,243,0.3);}
  .settings-nav-btn:hover:not(.active){color:var(--text);background:#f1f5f9;}
  .settings-section{display:none;}.settings-section.active{display:block;}
  .settings-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:16px;}
  .settings-card-title{font-size:0.95rem;font-weight:700;margin-bottom:4px;}
  .settings-card-desc{font-size:0.8rem;color:var(--text-secondary);margin-bottom:16px;}
  .settings-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f1f5f9;}
  .settings-row:last-child{border-bottom:none;}
  .settings-row .sr-label{font-size:0.88rem;font-weight:500;}
  .settings-row .sr-desc{font-size:0.76rem;color:var(--text-secondary);margin-top:2px;}
  .settings-row .sr-control{flex-shrink:0;}
  .settings-toggle{position:relative;width:44px;height:24px;background:#cbd5e1;border-radius:12px;cursor:pointer;transition:background 0.2s;border:none;}
  .settings-toggle.on{background:var(--primary);}
  .settings-toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;background:white;border-radius:50%;transition:transform 0.2s;box-shadow:0 1px 3px rgba(0,0,0,0.2);}
  .settings-toggle.on::after{transform:translateX(20px);}
  .settings-danger-zone{border:1px solid #fca5a5;border-radius:14px;padding:24px;background:#fef2f2;}
  .settings-danger-zone .settings-card-title{color:var(--danger);}

  /* ===== Task Board ===== */
  .tb-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px;position:relative;z-index:2;}
  .tb-toolbar select,.tb-toolbar input{padding:7px 12px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:0.82rem;}
  .tb-toolbar input{flex:1;min-width:160px;}
  .tb-view-toggle{display:flex;gap:2px;background:#e2e8f0;border-radius:8px;padding:2px;}
  .tb-view-btn{padding:6px 14px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-family:inherit;font-size:0.8rem;font-weight:600;color:var(--text-secondary);transition:all 0.15s;}
  .tb-view-btn.active{background:white;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,0.1);}
  .kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;min-height:300px;}
  @media(max-width:1100px){.kanban-board{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:720px){.kanban-board{grid-template-columns:1fr;}}
  .kanban-col{background:#f8fafc;border-radius:12px;padding:14px;border:1px solid var(--border);}
  .kanban-col-header{font-size:0.82rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;}
  .kanban-col-header .kc-count{background:#e2e8f0;color:var(--text-secondary);padding:2px 8px;border-radius:10px;font-size:0.72rem;}
  .task-card-kb{background:white;border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px;cursor:grab;transition:all 0.15s;}
  .task-card-kb:hover{box-shadow:0 4px 12px rgba(0,0,0,0.08);transform:translateY(-1px);}
  .task-card-kb .tc-del{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:6px;border:none;background:transparent;color:#94a3b8;cursor:pointer;font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;transition:all 0.15s;}
  .task-card-kb .tc-del:hover{background:#fef2f2;color:#dc2626;}
  .task-card-kb.dragging{opacity:0.4;transform:rotate(2deg);}
  .kanban-col.drag-over{background:#eef2ff;border:2px dashed var(--primary);}
  /* ===== Consult <-> Dev workflow board (6 columns) ===== */
  .kanban-board.cd6{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;}
  @media(max-width:1400px){.kanban-board.cd6{grid-template-columns:repeat(3,1fr);}}
  @media(max-width:900px){.kanban-board.cd6{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:600px){.kanban-board.cd6{grid-template-columns:1fr;}}
  .kanban-board.cd6 .kanban-col{padding:10px;}
  .kanban-board.cd6 .kanban-col-header{font-size:0.76rem;}
  .cd-col-rail{height:3px;border-radius:3px;margin-bottom:10px;}
  .cd-card-ac{display:inline-flex;align-items:center;gap:3px;font-size:0.7rem;font-weight:700;padding:2px 7px;border-radius:10px;background:#f1f5f9;color:#475569;}
  .cd-card-ac.pass{background:#f0fdf4;color:#16a34a;}
  .cd-card-ac.fail{background:#fef2f2;color:#dc2626;}
  .cd-track-badge{display:inline-flex;align-items:center;gap:4px;font-size:0.66rem;font-weight:700;padding:2px 8px;border-radius:5px;background:#eef2ff;color:#4338ca;text-transform:uppercase;letter-spacing:0.3px;}
  /* ===== Spec / Dev / Test blocks inside task modal ===== */
  #tm-cd-section{border-top:1px solid var(--border);margin-top:14px;padding-top:14px;}
  .cd-block{border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:12px;background:#fafbfc;}
  .cd-block-title{font-size:0.82rem;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:7px;}
  .cd-block.spec{border-left:4px solid #6366f1;} .cd-block.spec .cd-block-title{color:#4338ca;}
  .cd-block.dev{border-left:4px solid #f59e0b;}  .cd-block.dev .cd-block-title{color:#b45309;}
  .cd-block.test{border-left:4px solid #10b981;} .cd-block.test .cd-block-title{color:#047857;}
  .cd-ac-row{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px dashed var(--border);}
  .cd-ac-row:last-child{border-bottom:none;}
  .cd-ac-row input[type=checkbox]{margin-top:4px;width:16px;height:16px;cursor:pointer;flex-shrink:0;}
  .cd-ac-row .cd-ac-text{flex:1;font-size:0.84rem;line-height:1.4;}
  .cd-ac-row.done .cd-ac-text{text-decoration:line-through;color:#94a3b8;}
  .cd-ac-row .cd-ac-del{background:none;border:none;color:#ef4444;cursor:pointer;font-size:1rem;padding:0 4px;flex-shrink:0;}
  .task-card-kb .tc-title{font-size:0.88rem;font-weight:600;margin-bottom:6px;}
  .task-card-kb .tc-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center;font-size:0.74rem;}
  .priority-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:0.68rem;font-weight:700;text-transform:uppercase;}
  .priority-badge.critical{background:#fef2f2;color:#dc2626;}
  .priority-badge.high{background:#fff7ed;color:#ea580c;}
  .priority-badge.medium{background:#fffbeb;color:#d97706;}
  .priority-badge.low{background:#f0fdf4;color:#16a34a;}
  .task-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);font-size:0.84rem;}
  .task-table thead{background:#f1f5f9;}
  .task-table th{padding:10px 14px;text-align:left;font-size:0.76rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;}
  .task-table td{padding:12px 14px;border-top:1px solid var(--border);vertical-align:middle;}
  .task-table tr:hover td{background:#f8fafc;}
  .task-status-select{padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-size:0.78rem;font-family:inherit;cursor:pointer;}
  .phase-task-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0;margin-bottom:4px;transition:transform 0.1s,box-shadow 0.1s;}
  .phase-task-item.pt-dragging{opacity:0.4;transform:scale(0.98);}
  .phase-task-item.pt-drag-over{border-top:3px solid var(--primary);margin-top:-1px;}
  .pt-drag-handle{cursor:grab;color:#cbd5e1;font-size:0.9rem;flex-shrink:0;padding:0 2px;user-select:none;}
  .pt-drag-handle:active{cursor:grabbing;}
  .phase-task-item.done{opacity:0.6;background:#f0fdf4;border-color:#bbf7d0;}
  .phase-task-item.done .pt-title{text-decoration:line-through;}
  .phase-task-item.milestone{border-left:3px solid #d97706;background:#fffdf5;}
  .phase-task-item .pt-status{flex-shrink:0;}
  .phase-task-item .pt-status select{padding:3px 6px;border-radius:5px;border:1px solid var(--border);font-size:0.72rem;font-family:inherit;cursor:pointer;font-weight:600;}
  .phase-task-item .pt-status select.st-notstart{background:#f1f5f9;color:#64748b;}
  .phase-task-item .pt-status select.st-progress{background:#eff6ff;color:var(--primary);}
  .phase-task-item .pt-status select.st-done{background:#f0fdf4;color:#16a34a;}
  .phase-task-item .pt-body{flex:1;min-width:0;}
  .phase-task-item .pt-title{font-size:0.86rem;font-weight:600;}
  .phase-task-item .pt-desc{font-size:0.76rem;color:var(--text-secondary);margin-top:1px;}
  .phase-task-item .pt-del{width:26px;height:26px;border:1px solid #fca5a5;background:#fef2f2;color:var(--danger);border-radius:6px;cursor:pointer;font-size:0.8rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.15s;}
  .phase-task-item .pt-del:hover{background:var(--danger);color:white;}
  .setup-section-header{grid-column:1/-1;display:flex;align-items:center;gap:12px;margin:10px 0 -4px;padding:0;}
  .setup-section-header h3{font-size:1.05rem;font-weight:700;color:var(--text);white-space:nowrap;}
  .setup-section-header .ssh-line{flex:1;height:1px;background:var(--border);}
  .setup-section-header .ssh-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
  .cr-status-badge{display:inline-block;padding:2px 10px;border-radius:6px;font-size:0.72rem;font-weight:700;text-transform:uppercase;}
  .cr-status-badge.pending{background:#fffbeb;color:#d97706;}
  .cr-status-badge.approved{background:#f0fdf4;color:#16a34a;}
  .cr-status-badge.rejected{background:#fef2f2;color:var(--danger);}
  .cr-status-badge.implemented{background:#eff6ff;color:var(--primary);}
  .sow-step-dot{padding:8px 16px;border-radius:8px;font-size:0.78rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:white;color:var(--text-secondary);transition:all 0.2s;flex:1;text-align:center;}
  .sow-step-dot.active{background:var(--primary);color:white;border-color:var(--primary);}
  .sow-step-dot.completed{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0;}
  .sow-card{background:var(--card);border-radius:14px;border:1px solid var(--border);padding:22px;margin-bottom:16px;}
  .sow-card-title{font-size:0.95rem;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
  .sow-check-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;margin-bottom:14px;}
  .sow-check-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#f8fafc;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all 0.15s;}
  .sow-check-item:hover{border-color:var(--primary);background:#eef2ff;}
  .sow-check-item.checked{border-color:var(--primary);background:#eef2ff;}
  .sow-check-item input[type="checkbox"]{margin-top:2px;cursor:pointer;}
  .sow-check-label{font-size:0.84rem;font-weight:500;}
  .sow-check-desc{font-size:0.72rem;color:var(--text-secondary);margin-top:2px;}
  .sow-sub-fields{padding:12px 16px;background:#f8fafc;border:1px solid var(--border);border-radius:8px;margin-top:8px;margin-bottom:12px;}
  .sow-preview{background:#1e293b;color:#e2e8f0;border-radius:14px;padding:24px;font-family:monospace;font-size:0.82rem;line-height:1.8;white-space:pre-wrap;max-height:600px;overflow-y:auto;}
  .sow-review-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;margin-bottom:4px;}
  .sow-review-item.ok{background:#f0fdf4;color:#16a34a;}
  .sow-review-item.warn{background:#fffbeb;color:#d97706;}
  .sow-manday-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f8fafc;border-radius:8px;margin-bottom:4px;}
  .sow-manday-row .md-label{font-size:0.84rem;font-weight:500;}
  .sow-manday-row .md-value{font-size:0.88rem;font-weight:700;color:var(--primary);}
  .sap-tree .mod-item{cursor:pointer;user-select:none;}
  .sap-tree .mod-header{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;transition:background 0.15s;}
  .sap-tree .mod-header:hover{background:#f1f5f9;}
  .sap-tree .mod-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;}
  .sap-tree .mod-name{font-size:0.88rem;font-weight:600;color:var(--text);}
  .sap-tree .mod-arrow{font-size:0.6rem;color:#94a3b8;transition:transform 0.2s;width:16px;text-align:center;}
  .sap-tree .mod-arrow.open{transform:rotate(90deg);}
  .sap-tree .mod-children{display:none;padding-left:20px;border-left:1px solid var(--border);margin-left:20px;}
  .sap-tree .mod-children.open{display:block;}
  .sap-tree .sub-item{display:flex;align-items:center;gap:6px;padding:4px 10px;font-size:0.82rem;color:var(--text-secondary);border-radius:6px;transition:background 0.15s;}
  .sap-tree .sub-item:hover{background:#f8fafc;color:var(--text);}
  .sap-tree .sub-item .sub-dash{color:var(--primary);font-weight:700;font-size:0.7rem;}
  .sap-tree .sub-folder{cursor:pointer;user-select:none;}
  .sap-tree .sub-folder-header{display:flex;align-items:center;gap:6px;padding:4px 10px;font-size:0.82rem;color:var(--text);font-weight:600;border-radius:6px;cursor:pointer;transition:background 0.15s;}
  .sap-tree .sub-folder-header:hover{background:#f1f5f9;}
  .sap-tree .sub-folder-children{display:none;padding-left:18px;border-left:1px solid #e2e8f0;margin-left:10px;}
  .sap-tree .sub-folder-children.open{display:block;}
  .phase-section-divider{border-top:1px dashed var(--border);margin:20px 0 16px;position:relative;}
  .phase-section-label{font-size:0.82rem;font-weight:700;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
  .pt-add-form{display:flex;gap:8px;align-items:center;margin-top:8px;flex-wrap:wrap;}
  .pt-add-form input{padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-size:0.82rem;font-family:inherit;}
  .pt-add-form input:focus{outline:none;border-color:var(--primary);}
  .pt-add-btn{padding:7px 14px;border:1.5px dashed var(--border);border-radius:8px;background:white;color:var(--text-secondary);font-size:0.8rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s;}
  .pt-add-btn:hover{border-color:var(--primary);color:var(--primary);background:#eef2ff;}
  .phase-progress-mini{display:flex;align-items:center;gap:8px;font-size:0.76rem;color:var(--text-secondary);}
  .phase-progress-mini .ppm-bar{flex:1;max-width:120px;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;}
  .phase-progress-mini .ppm-fill{height:100%;border-radius:3px;}

  /* ===== Users & Permissions ===== */
  .perm-matrix{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);font-size:0.8rem;}
  .perm-matrix thead{background:#f1f5f9;}
  .perm-matrix th{padding:10px 12px;text-align:center;font-size:0.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;white-space:nowrap;}
  .perm-matrix th:first-child{text-align:left;position:sticky;left:0;background:#f1f5f9;z-index:2;}
  .perm-matrix td{padding:8px 10px;border-top:1px solid var(--border);text-align:center;}
  .perm-matrix td:first-child{text-align:left;font-weight:600;position:sticky;left:0;background:white;z-index:2;}
  .perm-matrix tr:hover td{background:#f8fafc;}
  .perm-matrix select{padding:3px 6px;border:1px solid var(--border);border-radius:4px;font-size:0.72rem;font-family:inherit;cursor:pointer;}
  .perm-none{background:#f8fafc;}.perm-view{background:#eff6ff;}.perm-edit{background:#fffbeb;}.perm-full{background:#f0fdf4;}
  .user-badge-active{display:inline-block;padding:2px 8px;border-radius:10px;font-size:0.7rem;font-weight:600;background:#ecfdf5;color:#059669;}
  .user-badge-inactive{display:inline-block;padding:2px 8px;border-radius:10px;font-size:0.7rem;font-weight:600;background:#f1f5f9;color:#94a3b8;}
  .web-role-badge{display:inline-block;padding:3px 10px;border-radius:6px;font-size:0.72rem;font-weight:700;text-transform:uppercase;}
  .web-role-badge.admin{background:#fef2f2;color:#dc2626;}
  .web-role-badge.dept_manager{background:#fff7ed;color:#ea580c;}
  .web-role-badge.project_manager{background:#fffbeb;color:#d97706;}
  .web-role-badge.senior_consultant{background:#eef2ff;color:var(--primary);}
  .web-role-badge.consultant{background:#ecfeff;color:#0891b2;}
  .web-role-badge.intern{background:#f5f3ff;color:#7c3aed;}
  .web-role-badge.viewer{background:#f0fdf4;color:#16a34a;}
  .web-role-badge.manager{background:#fff7ed;color:#ea580c;}
  .web-role-badge.member{background:#eef2ff;color:var(--primary);}
  .web-perm-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);font-size:0.8rem;}
  .web-perm-table thead{background:#f1f5f9;}
  .web-perm-table th{padding:10px 14px;text-align:center;font-size:0.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;}
  .web-perm-table th:first-child{text-align:left;}
  .web-perm-table td{padding:10px 14px;border-top:1px solid var(--border);text-align:center;}
  .web-perm-table td:first-child{text-align:left;font-weight:600;}
  .web-perm-table tr:hover td{background:#f8fafc;}
  .perm-yes{color:var(--success);font-weight:700;}.perm-no{color:#cbd5e1;}

  /* ===== Reports Dashboard ===== */
  .report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:24px;}
  .report-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:22px;}
  .report-card-title{font-size:0.9rem;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
  .report-card-title .rc-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;flex-shrink:0;}
  .pie-chart{width:120px;height:120px;border-radius:50%;margin:0 auto 12px;}
  .pie-legend{display:flex;flex-wrap:wrap;gap:8px 16px;justify-content:center;font-size:0.76rem;}
  .pie-legend span{display:flex;align-items:center;gap:4px;}
  .pie-legend .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
  .bar-chart{display:flex;flex-direction:column;gap:8px;}
  .bar-row{display:flex;align-items:center;gap:10px;font-size:0.8rem;}
  .bar-label{min-width:100px;font-weight:500;text-align:right;color:var(--text-secondary);font-size:0.76rem;}
  .bar-track{flex:1;height:20px;background:#e2e8f0;border-radius:4px;overflow:hidden;position:relative;}
  .bar-fill{height:100%;border-radius:4px;transition:width 0.4s;display:flex;align-items:center;justify-content:flex-end;padding-right:6px;font-size:0.68rem;font-weight:700;color:white;}
  .health-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px;}
  .health-green{background:#22c55e;}.health-yellow{background:#f59e0b;}.health-red{background:#ef4444;}

  /* ===== Activity & Notes ===== */
  .note-form{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:18px;}
  .note-form textarea{width:100%;min-height:60px;padding:10px 14px;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:0.88rem;resize:vertical;outline:none;box-sizing:border-box;}
  .note-form textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,112,243,0.1);}
  .note-form-actions{display:flex;gap:8px;align-items:center;margin-top:10px;}
  .activity-feed{display:flex;flex-direction:column;gap:10px;}
  .activity-item{display:flex;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:12px;position:relative;}
  .activity-item.pinned{background:#fffbeb;border-color:#fde68a;}
  .activity-item .ai-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;}
  .activity-item .ai-content{flex:1;min-width:0;}
  .activity-item .ai-text{font-size:0.88rem;line-height:1.5;margin-bottom:4px;}
  .activity-item .ai-meta{font-size:0.74rem;color:var(--text-secondary);}
  .activity-item .ai-actions{display:flex;gap:4px;position:absolute;top:10px;right:10px;}
  .ai-btn{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;background:white;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.75rem;transition:all 0.15s;}
  .ai-btn:hover{border-color:var(--primary);color:var(--primary);}
  .activity-filter{display:flex;gap:4px;margin-bottom:14px;background:#e2e8f0;border-radius:8px;padding:3px;width:fit-content;}
  .af-btn{padding:5px 14px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-family:inherit;font-size:0.78rem;font-weight:600;color:var(--text-secondary);transition:all 0.15s;}
  .af-btn.active{background:white;color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,0.1);}

  /* ===== Timesheet ===== */
  .ts-week-nav{display:flex;align-items:center;gap:14px;margin-bottom:18px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 18px;}
  .ts-nav-btn{width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:white;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all 0.15s;}
  .ts-nav-btn:hover{border-color:var(--primary);color:var(--primary);}
  .ts-week-label{font-weight:700;font-size:0.95rem;}
  .ts-grid{width:100%;border-collapse:separate;border-spacing:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);font-size:0.82rem;}
  .ts-grid thead{background:#f1f5f9;}
  .ts-grid th{padding:10px 8px;text-align:center;font-size:0.74rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;}
  .ts-grid th:first-child{text-align:left;min-width:140px;}
  .ts-grid td{padding:6px 4px;border-top:1px solid var(--border);text-align:center;}
  .ts-grid td:first-child{text-align:left;padding-left:12px;font-weight:500;}
  .ts-grid .ts-total-row td{background:#f1f5f9;font-weight:700;}
  .ts-grid .ts-grand-total td{background:#eef2ff;font-weight:800;color:var(--primary);}
  .ts-input{width:50px;padding:5px 4px;border:1px solid var(--border);border-radius:4px;text-align:center;font-family:inherit;font-size:0.82rem;}
  .ts-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(0,112,243,0.1);}
  .ts-summary{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px;}
  .ts-add-row{display:flex;gap:8px;align-items:end;margin-bottom:14px;flex-wrap:wrap;}
  .ts-add-row select,.ts-add-row input{padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:0.82rem;}

  @media(max-width:768px){.hero h1{font-size:1.6rem;}.hero{padding:30px 20px;}.task-grid{grid-template-columns:1fr;}.gantt-grid{grid-template-columns:130px 1fr;}.setup-grid{grid-template-columns:1fr;}.form-row{grid-template-columns:1fr;}.team-row{grid-template-columns:1fr;}.ge-row{grid-template-columns:1fr 1fr;}.ms-edit-row{flex-direction:column;}}
  @media print{.tabs{display:none;}.tab-content{display:block!important;page-break-inside:avoid;}.hero{padding:30px;}}

  /* ===== Template Editor ===== */
  .tpl-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:1100;display:none;align-items:center;justify-content:center;padding:20px;}
  .tpl-editor-overlay.open{display:flex;}
  .tpl-editor-box{background:white;border-radius:16px;width:100%;max-width:960px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.3);}
  .tpl-editor-header{position:sticky;top:0;z-index:2;background:linear-gradient(135deg,#0f172a,#1e3a5f);color:white;padding:20px 28px;border-radius:16px 16px 0 0;display:flex;align-items:center;justify-content:space-between;gap:12px;}
  .tpl-editor-header h3{margin:0;font-size:1.1rem;font-weight:700;}
  .tpl-editor-header .tpl-header-actions{display:flex;gap:8px;}
  .tpl-editor-header .tpl-header-actions button{padding:7px 18px;border:none;border-radius:8px;font-family:inherit;font-size:0.82rem;font-weight:600;cursor:pointer;transition:all 0.15s;}
  .tpl-editor-body{padding:24px 28px;}
  .tpl-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;}
  .tpl-meta-row .form-group{margin-bottom:0;}
  .tpl-section{margin-bottom:24px;}
  .tpl-section-title{font-size:0.92rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px;justify-content:space-between;}
  .tpl-section-title::before{content:'';width:4px;height:20px;background:var(--primary);border-radius:2px;}
  .tpl-phase-card{background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;position:relative;}
  .tpl-phase-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap;}
  .tpl-phase-header .tpl-phase-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
  .tpl-phase-header input{flex:1;min-width:140px;}
  .tpl-phase-header .tpl-phase-weeks{display:flex;align-items:center;gap:4px;font-size:0.78rem;color:var(--text-secondary);}
  .tpl-phase-header .tpl-phase-weeks input{width:50px;text-align:center;}
  .tpl-phase-remove{position:absolute;top:10px;right:10px;width:28px;height:28px;border:1px solid #fca5a5;background:#fef2f2;color:var(--danger);border-radius:6px;cursor:pointer;font-size:0.8rem;display:flex;align-items:center;justify-content:center;transition:all 0.15s;}
  .tpl-phase-remove:hover{background:var(--danger);color:white;}
  .tpl-sub-section{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border);}
  .tpl-sub-title{font-size:0.76rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;}
  .tpl-task-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:white;border:1px solid var(--border);border-radius:8px;margin-bottom:4px;font-size:0.82rem;}
  .tpl-task-row input{flex:1;border:none;background:transparent;font-family:inherit;font-size:0.82rem;outline:none;padding:2px 0;}
  .tpl-task-row input:focus{border-bottom:1px solid var(--primary);}
  .tpl-task-row .tpl-item-del{width:22px;height:22px;border:none;background:transparent;color:#cbd5e1;cursor:pointer;font-size:0.8rem;transition:color 0.15s;flex-shrink:0;}
  .tpl-task-row .tpl-item-del:hover{color:var(--danger);}
  .tpl-add-small{padding:4px 12px;border:1.5px dashed var(--border);border-radius:6px;background:white;color:var(--text-secondary);font-size:0.74rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s;}
  .tpl-add-small:hover{border-color:var(--primary);color:var(--primary);}
  .tpl-del-row{display:grid;grid-template-columns:60px 1fr 1fr 100px 60px 70px 28px;gap:6px;align-items:center;padding:6px 8px;background:white;border:1px solid var(--border);border-radius:8px;margin-bottom:4px;font-size:0.78rem;}
  .tpl-del-row input,.tpl-del-row select{border:none;background:transparent;font-family:inherit;font-size:0.78rem;outline:none;padding:2px 0;}
  .tpl-del-row input:focus{border-bottom:1px solid var(--primary);}
  .tpl-ms-row{display:grid;grid-template-columns:50px 1fr 70px 28px;gap:6px;align-items:center;padding:6px 8px;background:white;border:1px solid var(--border);border-radius:8px;margin-bottom:4px;font-size:0.78rem;}
  .tpl-ms-row input{border:none;background:transparent;font-family:inherit;font-size:0.78rem;outline:none;padding:2px 0;}
  .tpl-ms-row input:focus{border-bottom:1px solid var(--primary);}
  .tpl-version-list{margin-top:12px;}
  .tpl-version-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:white;border:1px solid var(--border);border-radius:10px;margin-bottom:6px;transition:all 0.15s;}
  .tpl-version-item:hover{border-color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,0.06);}
  .tpl-version-item.active{border-color:var(--primary);background:#eef2ff;}
  .tpl-version-badge{padding:3px 10px;border-radius:6px;font-size:0.72rem;font-weight:700;background:#e2e8f0;color:var(--text-secondary);flex-shrink:0;}
  .tpl-version-badge.latest{background:#eef2ff;color:var(--primary);}
  .tpl-version-info{flex:1;min-width:0;}
  .tpl-version-info .vname{font-weight:600;font-size:0.84rem;}
  .tpl-version-info .vmeta{font-size:0.72rem;color:var(--text-secondary);}
  .tpl-version-actions{display:flex;gap:4px;flex-shrink:0;}
  .tpl-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:12px;transition:all 0.15s;}
  .tpl-card:hover{box-shadow:0 4px 12px rgba(0,0,0,0.06);}
  .tpl-card-header{display:flex;align-items:center;gap:14px;}
  .tpl-card-icon{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--primary),#8b5cf6);color:white;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
  .tpl-card-icon.default{background:linear-gradient(135deg,#10b981,#06b6d4);}
  .tpl-card-body{flex:1;min-width:0;}
  .tpl-card-name{font-weight:700;font-size:0.92rem;}
  .tpl-card-desc{font-size:0.78rem;color:var(--text-secondary);margin-top:2px;}
  .tpl-card-stats{font-size:0.72rem;color:var(--text-secondary);margin-top:4px;display:flex;gap:8px;flex-wrap:wrap;}
  .tpl-card-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap;}
  .tpl-btn{padding:6px 14px;border:1px solid var(--border);border-radius:8px;background:white;font-family:inherit;font-size:0.78rem;font-weight:600;cursor:pointer;transition:all 0.15s;}
  .tpl-btn:hover{border-color:var(--primary);color:var(--primary);background:#eef2ff;}
  .tpl-btn.primary{background:var(--primary);color:white;border-color:var(--primary);}
  .tpl-btn.primary:hover{background:#005bd3;}
  .tpl-btn.danger{border-color:#fca5a5;color:var(--danger);}
  .tpl-btn.danger:hover{background:var(--danger);color:white;border-color:var(--danger);}
  .tpl-collapse-toggle{background:none;border:none;cursor:pointer;font-size:0.72rem;color:var(--text-secondary);font-family:inherit;font-weight:600;padding:2px 6px;transition:color 0.15s;}
  .tpl-collapse-toggle:hover{color:var(--primary);}
  @media(max-width:768px){.tpl-meta-row{grid-template-columns:1fr;}.tpl-del-row{grid-template-columns:1fr 1fr;}.tpl-ms-row{grid-template-columns:1fr 1fr;}}

  /* Language Toggle Button */
  .lang-toggle-btn{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--primary);color:white;border:2px solid white;font-size:0.85rem;font-weight:800;cursor:pointer;z-index:9998;box-shadow:0 4px 14px rgba(0,0,0,0.25);display:flex;align-items:center;justify-content:center;transition:all 0.2s;font-family:inherit;}
  .lang-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(0,0,0,0.35);}

  /* ===== TONG COIN (viewCoin) ===== */
  #viewCoin{min-height:100vh;background:var(--bg);}
  #viewCoin .c-hero{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 50%,#fbbf24 100%);padding:18px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:0 4px 16px rgba(251,191,36,0.25);}
  #viewCoin .c-hero .c-back{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid rgba(146,64,14,0.3);border-radius:8px;background:rgba(255,255,255,0.4);color:#78350f;cursor:pointer;font-family:inherit;font-size:0.84rem;font-weight:600;text-decoration:none;}
  #viewCoin .c-hero .c-back:hover{background:rgba(255,255,255,0.7);}
  #viewCoin .c-hero .c-brand{display:flex;align-items:center;gap:8px;font-weight:800;color:#78350f;font-size:1.1rem;}
  #viewCoin .c-hero .c-brand .c-icn{font-size:1.6rem;}
  #viewCoin .c-tabs{display:flex;gap:2px;background:#fff;border-bottom:1px solid var(--border);padding:0 24px;overflow-x:auto;position:sticky;top:0;z-index:40;}
  #viewCoin .c-tab{padding:12px 16px;border:none;background:transparent;font-family:inherit;font-size:0.86rem;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;white-space:nowrap;}
  #viewCoin .c-tab.active{color:var(--primary);border-color:var(--primary);}
  #viewCoin .c-tab.c-boss{color:#8b5cf6;}
  #viewCoin .c-tab.c-boss.active{border-color:#8b5cf6;}
  #viewCoin .c-container{max-width:1200px;margin:0 auto;padding:20px;}
  #viewCoin .c-view{display:none;} #viewCoin .c-view.active{display:block;}
  #viewCoin .c-coinhero{position:relative;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 50%,#fbbf24 100%);border-radius:18px;padding:22px 28px;display:flex;align-items:center;gap:28px;box-shadow:0 4px 20px rgba(251,191,36,0.22),inset 0 1px 0 rgba(255,255,255,0.6);margin-bottom:18px;flex-wrap:wrap;overflow:hidden;}
  /* Rotating rays behind coin */
  #viewCoin .c-coinhero::before{content:'';position:absolute;left:-40px;top:50%;width:320px;height:320px;transform:translateY(-50%);background:conic-gradient(from 0deg,rgba(255,255,255,0) 0deg,rgba(255,248,176,0.35) 12deg,rgba(255,255,255,0) 26deg,rgba(255,255,255,0) 90deg,rgba(255,248,176,0.28) 102deg,rgba(255,255,255,0) 116deg,rgba(255,255,255,0) 180deg,rgba(255,248,176,0.32) 192deg,rgba(255,255,255,0) 206deg,rgba(255,255,255,0) 270deg,rgba(255,248,176,0.25) 282deg,rgba(255,255,255,0) 296deg,rgba(255,255,255,0) 360deg);border-radius:50%;filter:blur(2px);animation:tongRays 38s linear infinite;pointer-events:none;opacity:0.65;z-index:0;}
  #viewCoin .c-coinhero > *{position:relative;z-index:1;}
  @keyframes tongRays{from{transform:translateY(-50%) rotate(0deg);}to{transform:translateY(-50%) rotate(360deg);}}
  #viewCoin .c-coinhero .c-big{position:relative;font-size:4.2rem;line-height:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,0.12));perspective:900px;}
  #viewCoin .c-coinhero .c-big svg{animation:tongCoinFlip 16s cubic-bezier(0.4,0,0.2,1) infinite;transform-style:preserve-3d;transform-origin:50% 50%;}
  #viewCoin .c-coinhero:hover .c-big svg{animation-duration:9s;}
  @keyframes tongCoinFlip{
    0%    {transform:rotateY(0deg)    scale(1);}
    35%   {transform:rotateY(0deg)    scale(1);}
    50%   {transform:rotateY(180deg)  scale(1.05);}
    65%   {transform:rotateY(360deg)  scale(1);}
    100%  {transform:rotateY(360deg)  scale(1);}
  }
  @keyframes coinSpinEmoji{
    0%   {transform:rotate(0deg)   scale(1);}
    50%  {transform:rotate(180deg) scale(1.1);}
    100% {transform:rotate(360deg) scale(1);}
  }
  #viewCoin .c-coinhero .c-lbl{font-size:0.74rem;color:#92400e;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;}
  #viewCoin .c-coinhero .c-bal{font-size:2.6rem;font-weight:800;color:#78350f;line-height:1.1;}
  #viewCoin .c-coinhero .c-sub{font-size:0.82rem;color:#92400e;margin-top:4px;}
  #viewCoin .c-coinhero .c-streak{margin-left:auto;text-align:center;background:rgba(255,255,255,0.5);padding:12px 20px;border-radius:12px;}
  #viewCoin .c-coinhero .c-streak .c-flame{font-size:2.2rem;}
  #viewCoin .c-coinhero .c-streak .c-days{font-size:1.6rem;font-weight:800;color:#78350f;}
  #viewCoin .c-coinhero .c-streak .c-txt{font-size:0.68rem;color:#92400e;font-weight:600;}
  #viewCoin .c-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:14px;box-shadow:0 1px 3px rgba(0,0,0,0.04);}
  #viewCoin .c-card h3{font-size:0.98rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
  #viewCoin .c-card h3 .c-count{background:var(--danger);color:#fff;border-radius:10px;padding:2px 10px;font-size:0.72rem;font-weight:700;}
  #viewCoin .c-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
  @media (max-width:768px){#viewCoin .c-grid-2{grid-template-columns:1fr;}}
  #viewCoin .c-cal-wrap{overflow-x:auto;}
  #viewCoin .c-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;min-width:300px;}
  #viewCoin .c-cal-head{font-size:0.66rem;color:var(--text-secondary);text-align:center;font-weight:600;padding:4px 0;}
  #viewCoin .c-cal-cell{aspect-ratio:1;border-radius:6px;background:#f1f5f9;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:0.72rem;font-weight:600;cursor:pointer;transition:transform 0.1s;}
  #viewCoin .c-cal-cell:hover{transform:scale(1.06);}
  #viewCoin .c-cal-cell.c-empty{background:transparent;cursor:default;}
  #viewCoin .c-cal-cell.c-future{background:#f8fafc;color:#cbd5e1;}
  #viewCoin .c-cal-cell.c-early15{background:#166534;color:#fff;}
  #viewCoin .c-cal-cell.c-early{background:#22c55e;color:#fff;}
  #viewCoin .c-cal-cell.c-ontime{background:#fde68a;color:#78350f;}
  #viewCoin .c-cal-cell.c-late{background:#ef4444;color:#fff;}
  #viewCoin .c-cal-cell .c-d{font-size:0.7rem;} #viewCoin .c-cal-cell .c-c{font-size:0.58rem;opacity:0.9;}
  #viewCoin .c-legend{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;font-size:0.7rem;}
  #viewCoin .c-legend-item{display:flex;align-items:center;gap:4px;}
  #viewCoin .c-legend-dot{width:12px;height:12px;border-radius:3px;}
  #viewCoin .c-ledger-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid #f1f5f9;}
  #viewCoin .c-ledger-row:last-child{border:none;}
  #viewCoin .c-ledger-reason{font-size:0.82rem;font-weight:600;}
  #viewCoin .c-ledger-note{font-size:0.7rem;color:var(--text-secondary);margin-top:2px;}
  #viewCoin .c-ledger-amount{font-size:0.94rem;font-weight:800;}
  #viewCoin .c-ledger-amount.c-pos{color:var(--success);}
  #viewCoin .c-ledger-amount.c-neg{color:var(--danger);}

  /* ===== TONG Tier colors (used by assets/tong-tier.js) =====
     Tier ranges: 1-49=gray, 50-99=blue, 100-499=red, 500-999=purple, 1000+=gold */
  .tong-amount { font-weight: 800; font-variant-numeric: tabular-nums; letter-spacing: 0.2px; }
  .tong-amount .tong-unit { font-weight: 700; font-size: 0.78em; opacity: 0.85; margin-left: 2px; letter-spacing: 0.5px; }
  .tong-tier-gray   { color: #6b7280; }
  .tong-tier-blue   { color: #2563eb; }
  .tong-tier-red    { color: #dc2626; }
  .tong-tier-purple { color: #9333ea; }
  .tong-tier-gold   { color: #b8860b; }
  #viewCoin .c-shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;}
  #viewCoin .c-shop-item{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px;text-align:center;transition:all 0.15s;}
  #viewCoin .c-shop-item:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,0.07);border-color:#f59e0b;}
  #viewCoin .c-shop-item .c-icn{font-size:2.6rem;margin-bottom:6px;}
  #viewCoin .c-shop-item .c-nm{font-weight:700;font-size:0.92rem;margin-bottom:4px;}
  #viewCoin .c-shop-item .c-dsc{font-size:0.72rem;color:var(--text-secondary);margin-bottom:10px;min-height:30px;}
  #viewCoin .c-shop-item .c-cost{color:#f59e0b;font-weight:800;font-size:1.05rem;margin-bottom:10px;}
  #viewCoin .c-shop-item button{width:100%;padding:7px;border:none;background:var(--primary);color:#fff;border-radius:8px;font-family:inherit;font-weight:600;font-size:0.8rem;cursor:pointer;}
  #viewCoin .c-shop-item button:disabled{background:#cbd5e1;cursor:not-allowed;}
  #viewCoin .c-shop-item button:hover:not(:disabled){background:#0057c7;}
  #viewCoin .c-lb-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;margin-bottom:6px;background:#f8fafc;}
  #viewCoin .c-lb-row.c-top1{background:linear-gradient(90deg,#fef3c7,#fde68a);}
  #viewCoin .c-lb-row.c-top2{background:linear-gradient(90deg,#f1f5f9,#e2e8f0);}
  #viewCoin .c-lb-row.c-top3{background:linear-gradient(90deg,#fed7aa,#fdba74);}
  #viewCoin .c-lb-rank{font-size:1.1rem;font-weight:800;min-width:40px;}
  #viewCoin .c-lb-name{flex:1;font-weight:600;}
  #viewCoin .c-lb-dept{font-size:0.7rem;color:var(--text-secondary);}
  #viewCoin .c-lb-total{font-weight:800;color:#f59e0b;font-size:1.05rem;}
  #viewCoin .c-boss-panel{background:linear-gradient(135deg,#faf5ff,#f5f3ff);border:2px solid #c4b5fd;border-radius:14px;padding:14px 20px;margin-bottom:14px;}
  #viewCoin .c-boss-panel h2{color:#8b5cf6;font-size:0.95rem;display:flex;align-items:center;gap:8px;margin-bottom:6px;}
  #viewCoin .c-boss-panel .c-intro{font-size:0.8rem;color:#6b21a8;}
  #viewCoin .c-alert{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;margin-bottom:8px;background:#fffbeb;border-left:4px solid var(--warning);}
  #viewCoin .c-alert.c-danger{background:#fef2f2;border-color:var(--danger);}
  #viewCoin .c-alert.c-success{background:#f0fdf4;border-color:var(--success);}
  #viewCoin .c-alert.c-info{background:#eff6ff;border-color:var(--primary);}
  #viewCoin .c-alert .c-icn{font-size:1.5rem;}
  #viewCoin .c-alert .c-text{flex:1;}
  #viewCoin .c-alert .c-ttl{font-weight:700;font-size:0.9rem;}
  #viewCoin .c-alert .c-det{font-size:0.76rem;color:var(--text-secondary);margin-top:2px;}
  #viewCoin .c-alert button{padding:6px 12px;border:none;background:var(--primary);color:#fff;border-radius:8px;font-family:inherit;font-weight:600;font-size:0.76rem;cursor:pointer;white-space:nowrap;}
  #viewCoin .c-gauge{background:#f1f5f9;border-radius:10px;height:12px;overflow:hidden;margin-top:6px;}
  #viewCoin .c-gauge-fill{height:100%;background:linear-gradient(90deg,var(--success) 0%,var(--warning) 60%,var(--danger) 100%);transition:width 0.4s;}
  #viewCoin .c-thank-list{display:flex;flex-direction:column;gap:8px;}
  #viewCoin .c-thank{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:10px;}
  #viewCoin .c-thank .c-medal{font-size:1.4rem;}
  #viewCoin .c-thank .c-info{flex:1;}
  #viewCoin .c-thank .c-nm{font-weight:700;font-size:0.86rem;}
  #viewCoin .c-thank .c-rsn{font-size:0.72rem;color:var(--text-secondary);}
  #viewCoin .c-thank button{padding:5px 10px;font-size:0.7rem;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer;font-family:inherit;}
  #viewCoin .c-thank button:hover{background:#f1f5f9;}
  #viewCoin table.c-std{width:100%;border-collapse:collapse;font-size:0.82rem;}
  #viewCoin table.c-std th{background:#f1f5f9;text-align:left;padding:9px 12px;font-size:0.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;}
  #viewCoin table.c-std td{padding:9px 12px;border-top:1px solid var(--border);}
  #viewCoin table.c-std input{border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:0.82rem;}
  #viewCoin .c-btn{padding:7px 14px;border:none;border-radius:8px;font-family:inherit;font-weight:600;font-size:0.82rem;cursor:pointer;}
  #viewCoin .c-btn-primary{background:var(--primary);color:#fff;}
  #viewCoin .c-btn-primary:hover{background:#0057c7;}
  #viewCoin .c-btn-ghost{background:#f1f5f9;color:var(--text);}
  #viewCoin .c-btn-danger{background:var(--danger);color:#fff;}
  #viewCoin .c-empty{text-align:center;padding:26px;color:var(--text-secondary);font-size:0.84rem;}
  #viewCoin .c-hint{font-size:0.7rem;color:var(--text-secondary);margin-top:4px;}
  #coinModalBg{position:fixed;inset:0;background:rgba(15,23,42,0.6);display:none;align-items:center;justify-content:center;z-index:1100;padding:20px;}
  #coinModalBg.show{display:flex;}
  #coinModalBg .c-modal{background:#fff;border-radius:14px;padding:22px;max-width:600px;width:100%;max-height:90vh;overflow:auto;}
  #coinModalBg .c-close{float:right;background:transparent;border:none;font-size:1.4rem;cursor:pointer;color:var(--text-secondary);}

  /* ============================================================
     USER MENU — modern avatar pill + dropdown
     ============================================================ */
  .user-menu{position:relative;display:inline-block;}
  .um-trigger{display:inline-flex;align-items:center;gap:9px;height:40px;padding:3px 14px 3px 4px;border-radius:999px;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-family:inherit;font-size:0.84rem;font-weight:600;cursor:pointer;transition:all 0.18s ease;box-shadow:0 2px 6px rgba(0,0,0,0.18),inset 0 1px 0 rgba(255,255,255,0.08);}
  .um-trigger:hover{background:rgba(255,255,255,0.16);border-color:rgba(255,255,255,0.32);transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,0.28),inset 0 1px 0 rgba(255,255,255,0.12);}
  .um-trigger:active{transform:translateY(0);}
  .um-trigger .um-avatar{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:0.78rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 6px rgba(0,0,0,0.32),inset 0 1px 0 rgba(255,255,255,0.25);letter-spacing:0.02em;flex-shrink:0;overflow:hidden;}
  .um-trigger .um-avatar img{width:100%;height:100%;object-fit:cover;}
  .um-trigger .um-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .um-trigger .um-caret{opacity:0.85;transition:transform 0.2s ease;flex-shrink:0;}
  .um-trigger[aria-expanded="true"] .um-caret{transform:rotate(180deg);}

  .um-panel{position:absolute;right:0;top:calc(100% + 10px);min-width:280px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 16px 50px rgba(15,23,42,0.22),0 4px 12px rgba(15,23,42,0.08);padding:8px;z-index:120;color:var(--text);opacity:0;transform:translateY(-8px) scale(0.96);transform-origin:top right;pointer-events:none;transition:opacity 0.18s ease,transform 0.18s ease;}
  .um-panel.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
  .um-panel::before{content:'';position:absolute;top:-6px;right:22px;width:12px;height:12px;background:#fff;border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg);}

  .um-header{display:flex;align-items:center;gap:12px;padding:14px 12px 14px 12px;border-radius:12px;background:linear-gradient(135deg,rgba(99,102,241,0.07),rgba(139,92,246,0.05));margin-bottom:6px;}
  .um-avatar-lg{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 12px rgba(99,102,241,0.32),inset 0 1px 0 rgba(255,255,255,0.25);flex-shrink:0;letter-spacing:0.02em;overflow:hidden;}
  .um-avatar-lg img{width:100%;height:100%;object-fit:cover;display:block;}
  .um-avatar.um-has-img,.um-avatar-lg.um-has-img{padding:0;background:#1e293b !important;}
  .um-avatar.um-has-img img{width:100%;height:100%;object-fit:cover;display:block;}
  .um-h-info{flex:1;min-width:0;}
  .um-h-name{font-weight:700;font-size:0.92rem;color:var(--text);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .um-h-sub{font-size:0.74rem;color:var(--text-secondary);line-height:1.3;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .um-h-role{margin-top:6px;font-size:0.7rem;}

  .um-section{padding:2px 0;}
  .um-divider{height:1px;background:var(--border);margin:6px 4px;border:0;}
  .um-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 12px;border:none;background:transparent;border-radius:10px;cursor:pointer;font-family:inherit;font-size:0.85rem;font-weight:500;color:var(--text);text-align:left;transition:background 0.12s ease,color 0.12s ease;position:relative;}
  .um-item:hover{background:#f1f5f9;}
  .um-item .um-i-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:#f1f5f9;color:var(--primary);flex-shrink:0;transition:background 0.12s ease,color 0.12s ease;}
  .um-item:hover .um-i-icon{background:rgba(99,102,241,0.14);color:var(--primary);}
  .um-item .um-i-text{flex:1;min-width:0;}
  .um-item .um-i-badge{font-size:0.6rem;font-weight:800;letter-spacing:0.06em;padding:2px 7px;border-radius:999px;background:linear-gradient(135deg,#ec4899,#f43f5e);color:#fff;box-shadow:0 1px 3px rgba(244,63,94,0.4);}
  .um-item.um-danger{color:var(--danger);}
  .um-item.um-danger .um-i-icon{background:#fef2f2;color:var(--danger);}
  .um-item.um-danger:hover{background:#fef2f2;}
  .um-item.um-danger:hover .um-i-icon{background:#fee2e2;}

  /* ============================================================
     INVENTORY VIEW
     ============================================================ */
  .view-inventory{min-height:100vh;background:var(--bg);}
  .inv-hero{position:relative;background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#312e81 100%);color:#fff;padding:36px 40px 110px;overflow:hidden;}
  .inv-hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(900px 420px at 80% 0%,rgba(139,92,246,0.32),transparent 60%),radial-gradient(700px 320px at 0% 100%,rgba(236,72,153,0.22),transparent 60%);}
  .inv-back{position:absolute;left:24px;top:22px;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid rgba(255,255,255,0.22);border-radius:10px;background:rgba(255,255,255,0.08);color:#fff;cursor:pointer;transition:all 0.15s ease;backdrop-filter:blur(10px);z-index:2;}
  .inv-back:hover{background:rgba(255,255,255,0.16);transform:translateY(-1px);}
  .inv-hero-inner{position:relative;max-width:var(--layout-max,1200px);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;z-index:1;}
  .inv-title-block{min-width:240px;}
  .inv-eyebrow{font-size:0.66rem;font-weight:700;letter-spacing:0.18em;color:rgba(255,255,255,0.62);margin-bottom:8px;}
  .inv-title-block h1{font-size:2.2rem;font-weight:800;letter-spacing:-0.02em;margin:0;line-height:1.05;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
  .inv-title-block p{margin:8px 0 0;color:rgba(255,255,255,0.7);font-size:0.92rem;}
  .inv-stats{display:flex;gap:14px;flex-wrap:wrap;}
  .inv-stat{display:flex;align-items:center;gap:12px;padding:14px 18px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);border-radius:14px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);min-width:170px;transition:all 0.18s ease;}
  .inv-stat:hover{background:rgba(255,255,255,0.1);transform:translateY(-2px);}
  .inv-stat .is-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 6px 16px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,0.18);flex-shrink:0;}
  .inv-stat .is-val{font-size:1.3rem;font-weight:800;line-height:1;color:#fff;font-variant-numeric:tabular-nums;}
  .inv-stat .is-lbl{font-size:0.68rem;font-weight:600;letter-spacing:0.06em;color:rgba(255,255,255,0.65);margin-top:4px;text-transform:uppercase;}

  .inv-container{max-width:var(--layout-max,1200px);margin:-78px auto 40px;padding:0 24px;position:relative;z-index:5;}
  .inv-toolbar{background:#fff;border:1px solid var(--border);border-radius:16px;padding:14px 16px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;box-shadow:0 8px 24px rgba(15,23,42,0.08);margin-bottom:24px;}
  .inv-search-wrap{position:relative;flex:1;min-width:220px;display:flex;align-items:center;}
  .inv-search-wrap svg{position:absolute;left:14px;color:var(--text-secondary);pointer-events:none;}
  .inv-search{width:100%;height:40px;padding:0 14px 0 40px;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:0.86rem;color:var(--text);background:#f8fafc;transition:all 0.15s ease;outline:none;}
  .inv-search:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(99,102,241,0.12);}
  .inv-filter{display:inline-flex;gap:4px;background:#f1f5f9;border-radius:10px;padding:4px;flex-wrap:wrap;}
  .inv-fbtn{padding:7px 14px;border:none;background:transparent;border-radius:7px;cursor:pointer;font-family:inherit;font-size:0.78rem;font-weight:600;color:var(--text-secondary);transition:all 0.15s ease;white-space:nowrap;}
  .inv-fbtn:hover:not(.active){color:var(--text);background:rgba(255,255,255,0.6);}
  .inv-fbtn.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px rgba(15,23,42,0.12);}
  .inv-sort-sel{height:40px;padding:0 14px;border:1px solid var(--border);border-radius:10px;background:#f8fafc;color:var(--text);font-family:inherit;font-size:0.84rem;font-weight:500;cursor:pointer;outline:none;transition:all 0.15s ease;}
  .inv-sort-sel:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,0.12);}

  .inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;}
  .inv-card{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform 0.2s ease,box-shadow 0.2s ease,border-color 0.2s ease;position:relative;}
  .inv-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(15,23,42,0.14);border-color:rgba(99,102,241,0.4);}
  .inv-card .ic-img{position:relative;aspect-ratio:1/1;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;align-items:center;justify-content:center;overflow:hidden;}
  .inv-card .ic-img img{width:78%;height:78%;object-fit:contain;transition:transform 0.4s ease;}
  .inv-card:hover .ic-img img{transform:scale(1.06);}
  .inv-card .ic-fallback{font-size:2.8rem;font-weight:800;color:#fff;width:78%;height:78%;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);}
  .inv-card .ic-rarity{position:absolute;top:10px;left:10px;font-size:0.62rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;padding:3px 9px;border-radius:999px;background:rgba(255,255,255,0.94);color:#475569;backdrop-filter:blur(6px);box-shadow:0 1px 4px rgba(15,23,42,0.1);}
  .inv-card.rarity-rare .ic-rarity{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:#fff;}
  .inv-card.rarity-epic .ic-rarity{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;}
  .inv-card.rarity-legendary .ic-rarity{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;animation:invShimmer 2.4s ease-in-out infinite;}
  .inv-card.rarity-rare{border-color:rgba(59,130,246,0.4);}
  .inv-card.rarity-epic{border-color:rgba(168,85,247,0.45);box-shadow:0 0 0 1px rgba(168,85,247,0.12) inset;}
  .inv-card.rarity-legendary{border-color:rgba(245,158,11,0.55);box-shadow:0 0 0 1px rgba(245,158,11,0.18) inset,0 4px 18px rgba(245,158,11,0.18);}
  @keyframes invShimmer{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,0.6);}50%{box-shadow:0 0 0 4px rgba(245,158,11,0);}}
  .inv-card .ic-body{padding:14px 14px 12px;display:flex;flex-direction:column;gap:6px;flex:1;}
  .inv-card .ic-type{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--primary);}
  .inv-card .ic-name{font-size:0.94rem;font-weight:700;color:var(--text);line-height:1.25;}
  .inv-card .ic-desc{font-size:0.76rem;color:var(--text-secondary);line-height:1.45;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
  .inv-card .ic-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:8px;margin-top:4px;border-top:1px dashed var(--border);}
  .inv-card .ic-date{font-size:0.7rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;}
  .inv-card .ic-use{padding:5px 12px;border:none;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-family:inherit;font-size:0.74rem;font-weight:700;cursor:pointer;transition:all 0.15s ease;box-shadow:0 2px 6px rgba(99,102,241,0.3);}
  .inv-card .ic-use:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.5);}

  .inv-empty{text-align:center;padding:60px 24px;background:#fff;border:1px dashed var(--border);border-radius:18px;}
  .inv-empty-icon{font-size:3.4rem;margin-bottom:12px;}
  .inv-empty-title{font-size:1.05rem;font-weight:700;color:var(--text);}
  .inv-empty-desc{font-size:0.85rem;color:var(--text-secondary);margin:6px 0 18px;}
  .inv-empty-btn{padding:10px 22px;border:none;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-family:inherit;font-size:0.86rem;font-weight:700;cursor:pointer;transition:all 0.15s ease;box-shadow:0 4px 12px rgba(99,102,241,0.32);}
  .inv-empty-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(99,102,241,0.45);}

  @media(max-width:640px){
    .inv-hero{padding:28px 20px 90px;}
    .inv-title-block h1{font-size:1.7rem;}
    .inv-stat{flex:1;min-width:130px;}
    .inv-container{padding:0 16px;margin-top:-66px;}
    .inv-toolbar{padding:12px;}
    .um-trigger .um-name{max-width:100px;}
    .um-panel{min-width:260px;}
  }

  /* ===== Multi-tenant: Company switcher ===== */
  .company-switcher{position:relative;display:inline-block;}
  .cs-trigger{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 12px;border-radius:10px;border:1px solid rgba(255,255,255,0.22);background:rgba(255,255,255,0.10);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-family:inherit;font-size:0.86rem;font-weight:600;cursor:pointer;transition:background 0.15s,border-color 0.15s,transform 0.1s;box-shadow:0 2px 6px rgba(0,0,0,0.18),inset 0 1px 0 rgba(255,255,255,0.08);max-width:280px;}
  .cs-trigger:hover{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.38);}
  .cs-trigger:active{transform:translateY(1px);}
  .cs-trigger .cs-icon{font-size:1rem;line-height:1;flex-shrink:0;}
  .cs-trigger .cs-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .cs-trigger .cs-caret{opacity:0.85;transition:transform 0.2s ease;flex-shrink:0;}
  .cs-trigger[aria-expanded="true"] .cs-caret{transform:rotate(180deg);}
  .cs-panel{position:absolute;left:0;top:calc(100% + 8px);min-width:300px;max-width:360px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 50px rgba(15,23,42,0.22),0 4px 12px rgba(15,23,42,0.08);padding:6px;z-index:130;color:var(--text);opacity:0;transform:translateY(-8px) scale(0.97);transform-origin:top left;pointer-events:none;transition:opacity 0.18s ease,transform 0.18s ease;}
  .cs-panel.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
  .cs-panel-header{font-size:0.66rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.08em;padding:8px 12px 4px;}
  .cs-list{max-height:280px;overflow-y:auto;padding:2px 0;}
  .cs-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background 0.12s;border:none;background:none;width:100%;text-align:left;font-family:inherit;color:var(--text);}
  .cs-item:hover{background:#f1f5f9;}
  .cs-item.active{background:#eef2ff;}
  .cs-item .cs-i-avatar{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:0.78rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);flex-shrink:0;letter-spacing:0.02em;}
  .cs-item .cs-i-info{flex:1;min-width:0;}
  .cs-item .cs-i-name{font-size:0.86rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .cs-item .cs-i-meta{display:flex;align-items:center;gap:6px;margin-top:2px;flex-wrap:wrap;}
  .cs-item .cs-i-role{font-size:0.66rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.04em;}
  .cs-item .cs-i-check{color:var(--primary);font-weight:700;flex-shrink:0;}
  .cs-divider{height:1px;background:var(--border);margin:4px 6px;}
  .cs-action{display:flex;align-items:center;gap:6px;padding:9px 12px;border-radius:8px;cursor:pointer;transition:background 0.12s;border:none;background:none;width:100%;text-align:left;font-family:inherit;font-size:0.84rem;font-weight:500;color:var(--text);}
  .cs-action:hover{background:#f1f5f9;}

  /* ===== MY WEEK VIEW ===== */
  .view-myweek{min-height:100vh;background:var(--bg);}
  .mw-hero{position:relative;background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 50%,#1e40af 100%);color:#fff;padding:28px 40px 32px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
  .mw-back{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid rgba(255,255,255,0.22);border-radius:10px;background:rgba(255,255,255,0.08);color:#fff;cursor:pointer;transition:all 0.15s ease;backdrop-filter:blur(10px);flex-shrink:0;}
  .mw-back:hover{background:rgba(255,255,255,0.16);}
  .mw-hero-inner{flex:1;min-width:0;}
  .mw-title{margin:0 0 4px;font-size:1.7rem;font-weight:700;letter-spacing:0.01em;}
  .mw-sub{font-size:0.88rem;opacity:0.85;}
  .mw-hero-actions{display:flex;gap:6px;flex-wrap:nowrap;flex-shrink:0;}
  .mw-nav-btn{padding:7px 14px;border:1px solid rgba(255,255,255,0.22);border-radius:8px;background:rgba(255,255,255,0.08);color:#fff;cursor:pointer;font-size:0.86rem;font-weight:600;transition:all 0.15s ease;backdrop-filter:blur(10px);}
  .mw-nav-btn:hover{background:rgba(255,255,255,0.18);}
  .mw-modebar{max-width:1200px;margin:0 auto;padding:14px 28px 0;display:flex;gap:6px;flex-wrap:wrap;}
  .mw-mode-btn{padding:7px 14px;border:1px solid var(--border);border-radius:10px;background:var(--card);color:var(--text-secondary);cursor:pointer;font-size:0.84rem;font-weight:600;transition:all 0.15s ease;font-family:inherit;}
  .mw-mode-btn:hover{border-color:var(--primary);color:var(--text);}
  .mw-mode-btn.active{background:linear-gradient(135deg,#1e40af,#0070f3);border-color:#0070f3;color:#fff;box-shadow:0 2px 6px rgba(0,112,243,0.25);}
  .mw-container{max-width:1200px;margin:0 auto;padding:18px 28px 60px;}
  .mw-section{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,0.04);}
  .mw-section h2{margin:0 0 14px;font-size:1.04rem;font-weight:700;display:flex;align-items:center;gap:8px;}
  .mw-count-pill{display:inline-block;font-size:0.7rem;font-weight:700;padding:2px 8px;border-radius:10px;background:#eef2ff;color:var(--primary);margin-left:4px;}
  .mw-section.today h2{color:#0070f3;}
  .mw-section.overdue h2{color:#dc2626;}
  .mw-section.overdue .mw-count-pill{background:#fee2e2;color:#dc2626;}
  .mw-section.waiting h2{color:#f97316;}
  .mw-section.waiting .mw-count-pill{background:#ffedd5;color:#c2410c;}
  .mw-section.nodate h2{color:#7c3aed;}
  .mw-section.nodate .mw-count-pill{background:#ede9fe;color:#7c3aed;}
  .mw-empty{font-size:0.86rem;color:var(--text-secondary);padding:10px 4px;text-align:center;}
  .mw-task-row{display:flex;align-items:center;gap:10px;padding:9px 8px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background 0.12s;border-radius:6px;}
  .mw-task-row:hover{background:#f8fafc;}
  .mw-task-row:last-child{border-bottom:none;}
  .mw-task-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
  .mw-task-body{flex:1;min-width:0;}
  .mw-task-title{font-size:0.9rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .mw-task-meta{font-size:0.72rem;color:var(--text-secondary);margin-top:2px;}
  .mw-task-due{font-size:0.7rem;font-weight:700;padding:2px 8px;border-radius:8px;white-space:nowrap;flex-shrink:0;}
  .mw-task-due.today{background:#dbeafe;color:#1e40af;}
  .mw-task-due.overdue{background:#fee2e2;color:#dc2626;}
  .mw-task-due.future{background:#f1f5f9;color:var(--text-secondary);}
  .mw-pri-chip{font-size:0.66rem;font-weight:700;padding:2px 7px;border-radius:6px;flex-shrink:0;}
  .mw-pri-chip.critical{background:#fef2f2;color:#dc2626;}
  .mw-pri-chip.high{background:#fff7ed;color:#c2410c;}
  .mw-pri-chip.medium{background:#eff6ff;color:#1d4ed8;}
  .mw-pri-chip.low{background:#f1f5f9;color:var(--text-secondary);}
  .mw-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:6px;}
  .mw-day{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:10px 8px;min-height:120px;display:flex;flex-direction:column;}
  .mw-day.today{background:#eff6ff;border-color:#bfdbfe;box-shadow:0 0 0 1px #bfdbfe inset;}
  .mw-day.past{opacity:0.62;}
  .mw-day-head{font-size:0.7rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.05em;text-align:center;margin-bottom:6px;}
  .mw-day.today .mw-day-head{color:#1d4ed8;}
  .mw-day-date{font-size:0.84rem;font-weight:700;color:var(--text);text-align:center;margin-bottom:8px;}
  .mw-day-item{font-size:0.74rem;padding:5px 7px;border-radius:5px;margin-bottom:4px;cursor:pointer;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:3px solid var(--primary);background:#fff;}
  .mw-day-item.gcal{border-left-color:#10b981;background:#ecfdf5;}
  .mw-day-item:hover{background:#f1f5f9;}
  .mw-day-item.gcal:hover{background:#d1fae5;}
  .mw-day-empty{font-size:0.7rem;color:var(--text-secondary);text-align:center;opacity:0.5;flex:1;display:flex;align-items:center;justify-content:center;}
  .mw-cr-row{display:flex;align-items:center;gap:10px;padding:9px 8px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background 0.12s;border-radius:6px;}
  .mw-cr-row:hover{background:#f8fafc;}
  .mw-cr-row:last-child{border-bottom:none;}
  .mw-cr-number{font-size:0.72rem;font-weight:800;color:var(--primary);background:#eef2ff;padding:2px 8px;border-radius:6px;flex-shrink:0;}
  .mw-mention-row{padding:9px 8px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background 0.12s;border-radius:6px;}
  .mw-mention-row:hover{background:#f8fafc;}
  .mw-mention-row:last-child{border-bottom:none;}
  .mw-mention-head{font-size:0.82rem;font-weight:600;color:var(--text);}
  .mw-mention-meta{font-size:0.7rem;color:var(--text-secondary);margin-top:2px;}
  .mw-mention-body{font-size:0.8rem;color:var(--text-secondary);margin-top:4px;font-style:italic;line-height:1.4;}
  .mw-proj-tag{display:inline-block;font-size:0.66rem;font-weight:700;padding:2px 8px;border-radius:6px;background:#f1f5f9;color:var(--text-secondary);}
  /* Month grid — 7 cols × N rows */
  .mw-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:6px;}
  .mw-month-head{font-size:0.7rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.05em;text-align:center;padding:6px 4px;}
  .mw-month-cell{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:6px 6px 4px;min-height:78px;font-size:0.74rem;display:flex;flex-direction:column;gap:2px;overflow:hidden;}
  .mw-month-cell.today{background:#eff6ff;border-color:#bfdbfe;box-shadow:0 0 0 1px #bfdbfe inset;}
  .mw-month-cell.past{opacity:0.55;}
  .mw-month-cell.other{opacity:0.35;background:transparent;}
  .mw-month-date{font-size:0.78rem;font-weight:700;color:var(--text);}
  .mw-month-cell.today .mw-month-date{color:#1d4ed8;}
  .mw-month-task{font-size:0.66rem;padding:2px 5px;border-radius:4px;background:#fff;border-left:3px solid var(--primary);cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2;}
  .mw-month-task.gcal{border-left-color:#10b981;background:#ecfdf5;}
  .mw-month-more{font-size:0.62rem;color:var(--text-secondary);text-align:center;margin-top:2px;}
  /* Project view */
  .mw-proj-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px;}
  .mw-proj-head{display:flex;align-items:center;gap:10px;margin-bottom:10px;cursor:pointer;}
  .mw-proj-color{width:6px;height:28px;border-radius:3px;flex-shrink:0;}
  .mw-proj-name{font-size:0.96rem;font-weight:700;color:var(--text);}
  .mw-proj-count{font-size:0.7rem;color:var(--text-secondary);margin-left:auto;}
  @media (max-width: 900px){
    .mw-hero{padding:22px 18px;}
    .mw-title{font-size:1.4rem;}
    .mw-container{padding:18px 14px 40px;}
    .mw-week-grid{grid-template-columns:repeat(2,1fr);}
    .mw-month-cell{min-height:60px;}
    .mw-month-task{font-size:0.6rem;padding:1px 4px;}
  }

  /* Plan badges */
  .plan-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:0.66rem;font-weight:800;text-transform:uppercase;letter-spacing:0.06em;line-height:1.5;}
  .plan-badge.plan-free{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;}
  .plan-badge.plan-pro{background:#dbeafe;color:#1d4ed8;border:1px solid #93c5fd;}
  .plan-badge.plan-enterprise{background:linear-gradient(135deg,#fde68a,#fbbf24);color:#78350f;border:1px solid #d97706;}
  .cs-trigger .cs-plan-badge{padding:1px 6px;border-radius:999px;font-size:0.60rem;font-weight:800;letter-spacing:0.06em;line-height:1.4;background:rgba(255,255,255,0.18);color:#fff;border:1px solid rgba(255,255,255,0.3);text-transform:uppercase;}

  /* Trial banner */
  .trial-banner{position:relative;padding:10px 20px;text-align:center;font-size:0.86rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;}
  .trial-banner.warn{background:linear-gradient(135deg,#fef9c3,#fde68a);color:#78350f;border-bottom:1px solid #fbbf24;}
  .trial-banner.expired{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#7f1d1d;border-bottom:1px solid #ef4444;}
  .trial-banner .tb-cta{padding:5px 14px;border-radius:8px;border:none;font-family:inherit;font-size:0.80rem;font-weight:700;cursor:pointer;background:#1d4ed8;color:#fff;transition:background 0.15s;}
  .trial-banner .tb-cta:hover{background:#1e40af;}
  .trial-banner.expired .tb-cta{background:#dc2626;}
  .trial-banner.expired .tb-cta:hover{background:#b91c1c;}

  /* Company settings card extras */
  #cs-planArea .ps-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
  #cs-planArea .ps-trial{font-size:0.84rem;color:var(--text-secondary);}
  #cs-planArea .ps-trial.expired{color:#b91c1c;font-weight:600;}
  #cs-membersArea .csm-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f1f5f9;}
  #cs-membersArea .csm-row:last-child{border-bottom:none;}
  #cs-membersArea .csm-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:0.82rem;flex-shrink:0;}
  #cs-membersArea .csm-info{flex:1;min-width:0;}
  #cs-membersArea .csm-name{font-size:0.88rem;font-weight:600;color:var(--text);}
  #cs-membersArea .csm-email{font-size:0.74rem;color:var(--text-secondary);}

  @media(max-width:640px){
    .cs-trigger{max-width:200px;}
    .cs-trigger .cs-name{max-width:100px;}
    .cs-panel{min-width:280px;}
  }
