/* ══════════════════════════════════════════
   XBrief Design v5 — Unified & Consistent
   Single card style · consistent fonts · clean colors
   ══════════════════════════════════════════ */

:root {
  --bg:          #fafafa;
  --surface:     #ffffff;
  --sidebar:     #0f172a;
  --sbar-hover:  #1e293b;
  --sbar-active: #1e3a5f;
  --sbar-text:   #94a3b8;
  --sbar-bright: #e2e8f0;
  --primary:     #3b82f6;
  --primary-hv:  #2563eb;
  --primary-bg:  #eff6ff;
  --accent:      #8b5cf6;
  --text:        #18181b;
  --text2:       #52525b;
  --text3:       #a1a1aa;
  --border:      #e4e4e7;
  --hover:       #f4f4f5;
  --danger:      #ef4444;
  --danger-bg:   #fef2f2;
  --success:     #22c55e;
  --success-bg:  #f0fdf4;
  --warning:     #f59e0b;
  --warning-bg:  #fffbeb;
  --radius:      6px;
  --font:        -apple-system,BlinkMacSystemFont,'SF Pro Display','Segoe UI','PingFang SC','Microsoft YaHei','Helvetica Neue',sans-serif;
  --font-mono:   'SF Mono','Fira Code','Cascadia Code','Consolas',monospace;
}

*{margin:0;padding:0;box-sizing:border-box;}
body{
  font-family:var(--font);font-size:13px;font-weight:400;
  background:var(--bg);color:var(--text);line-height:1.5;
  min-height:100vh;-webkit-font-smoothing:antialiased;
}

/* ═══ LOGIN ═══ */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;}
.login-card{background:var(--surface);padding:44px 44px;border-radius:16px;width:400px;max-width:100%;text-align:center;box-shadow:0 1px 3px rgba(0,0,0,.04),0 12px 48px rgba(0,0,0,.08);}
.login-card h1{font-size:23px;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;align-items:center;justify-content:center;gap:9px;line-height:1.2;}
.login-card h1 span{color:var(--primary);}
.brand-mark{width:30px;height:30px;border-radius:7px;display:inline-block;vertical-align:middle;}
.login-brand-copy{margin-bottom:28px;}
.login-subtitle{font-size:13px;font-weight:500;color:var(--text2);line-height:1.5;}
.login-ai-line{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px;font-size:11px;color:#71717a;line-height:1.4;}
.login-ai-line span{display:inline-flex;align-items:center;justify-content:center;height:18px;padding:0 6px;border-radius:4px;background:var(--primary-bg);color:var(--primary-hv);font-size:10px;font-weight:700;}
.login-card form{display:grid;gap:14px;}
.login-card label{display:block;text-align:left;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;}
.login-card input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:var(--font);color:var(--text);background:var(--surface);margin:0;transition:all .15s;}
.login-card input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg);}
.login-card button{width:100%;padding:10px 16px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;height:40px;}
.login-card button:hover{background:var(--primary-hv);}
.login-hint{margin-top:20px;font-size:12px;color:var(--text3);}

/* ═══ SHELL ═══ */
#app-shell{display:flex;min-height:100vh;}
#sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:949;}
#sidebar{width:124px;min-width:124px;background:var(--sidebar);color:var(--sbar-text);display:flex;flex-direction:column;transition:width .15s;user-select:none;}
.sidebar-brand{padding:12px 8px;display:flex;align-items:center;gap:6px;}
.brand-icon{width:22px;height:22px;border-radius:6px;display:block;flex-shrink:0;}
.brand-text{font-size:13px;font-weight:700;color:#f1f5f9;}
#sidebar-collapse{background:none;border:none;color:var(--sbar-text);cursor:pointer;font-size:13px;padding:4px 6px;border-radius:4px;margin-left:auto;width:24px;height:26px;}
#sidebar-collapse:hover{background:var(--sbar-hover);color:#fff;}
#sidebar-close{display:none;}
#sidebar-nav{flex:1;padding:0 5px;overflow-y:auto;}
.nav-item{display:flex;align-items:center;gap:6px;padding:6px 7px;margin-bottom:2px;border-radius:6px;font-size:12px;font-weight:450;color:var(--sbar-text);text-decoration:none;height:32px;cursor:pointer;}
.nav-item:hover{background:var(--sbar-hover);color:var(--sbar-bright);}
.nav-item.active{background:var(--sbar-active);color:#fff;font-weight:500;}
.nav-icon{font-size:14px;width:17px;text-align:center;opacity:.8;flex-shrink:0;}
.nav-section-label{font-size:9px;font-weight:600;color:rgba(148,163,184,.45);text-transform:uppercase;letter-spacing:.8px;padding:8px 7px 3px;margin-top:2px;user-select:none;}
.sidebar-footer{padding:8px;border-top:1px solid rgba(255,255,255,.06);font-size:12px;display:flex;flex-direction:column;gap:7px;}
#current-user-display{color:var(--sbar-text);font-size:12px;}
#logout-btn{background:transparent;border:none;color:var(--sbar-text);padding:4px 0;cursor:pointer;font-size:12px;font-family:var(--font);text-align:left;opacity:.7;}
#logout-btn:hover{opacity:1;color:var(--sbar-bright);}
#sidebar.collapsed{width:52px;min-width:52px;}
#sidebar.collapsed .brand-text,#sidebar.collapsed .nav-item span:not(.nav-icon),#sidebar.collapsed #current-user-display,#sidebar.collapsed #logout-btn{display:none;}
#sidebar.collapsed #sidebar-collapse{display:block;}
#sidebar.collapsed .nav-item{justify-content:center;padding:7px 0;}
#sidebar.collapsed .sidebar-brand{justify-content:center;padding:14px 0;}

/* ═══ MAIN ═══ */
#main-content{flex:1;display:flex;flex-direction:column;min-width:0;}
#topbar{padding:0 24px;height:48px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;}
#menu-toggle{display:none;background:none;border:none;font-size:20px;cursor:pointer;color:var(--text);}
#topbar h2{font-size:13px;font-weight:600;color:var(--text);}
#topbar-back{background:none;border:none;color:var(--primary);cursor:pointer;font-size:12px;padding:2px 6px;border-radius:4px;}
#topbar-back:hover{background:var(--hover);}
.topbar-actions{display:flex;align-items:center;gap:8px;}
#topbar-user{font-size:12px;color:var(--text2);margin-right:4px;}
#topbar-logout-btn{background:none;border:1px solid var(--border);color:var(--text2);padding:3px 10px;border-radius:4px;cursor:pointer;font-size:12px;}
#topbar-logout-btn:hover{background:var(--hover);}
.api-status{font-size:10px;opacity:.5;}
#page-container{flex:1;padding:20px 24px;overflow-y:auto;}

/* ═══ BUTTONS — unified size ═══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 12px;border-radius:var(--radius);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;border:1px solid transparent;white-space:nowrap;height:28px;line-height:1;}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-primary:hover{background:var(--primary-hv);}
.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border);}
.btn-secondary:hover{background:var(--hover);}
.btn-danger{background:none;color:var(--danger);border-color:var(--danger-bg);}
.btn-danger:hover{background:var(--danger-bg);}
.btn-sm{padding:3px 8px;font-size:11px;height:24px;}
.btn:disabled{opacity:.58;cursor:not-allowed;}
.btn-primary:disabled:hover{background:var(--primary);}
.btn-secondary:disabled:hover{background:var(--surface);}
.btn-danger:disabled:hover{background:none;}

/* ═══ PAGE TOOLBARS ═══ */
.page-header{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap;}
.page-header h3{font-size:15px;font-weight:650;color:var(--text);}
.page-header-split{justify-content:space-between;}
.page-header-actions-only{justify-content:flex-start;}
.page-header-actions,.row-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.filter-input,.filter-select{height:32px;padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:var(--font);color:var(--text);background:var(--surface);}
.filter-input{width:200px;max-width:100%;}
.filter-select{max-width:160px;}
.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg);}
.filter-summary{min-height:18px;margin:-4px 0 10px;color:var(--text3);font-size:12px;}
.loading{padding:40px 20px;text-align:center;color:var(--text3);font-size:13px;}
.form-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;}
.form-panel h3{font-size:15px;font-weight:650;margin-bottom:14px;}
.form-panel form>.btn,.form-panel form>.btn+button{margin-top:4px;}
.muted-note{margin-top:12px;font-size:11px;color:var(--text3);}

/* ═══ FORMS ═══ */
.form-group{margin-bottom:12px;}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:4px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:var(--font);color:var(--text);background:var(--surface);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg);}
.form-group textarea{resize:vertical;min-height:80px;}
.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;}

/* ═══ TABLE ═══ */
.data-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;line-height:1.28;}
.data-table th{padding:5px 7px;text-align:left;font-size:11px;font-weight:600;color:var(--text3);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;}
.data-table td{padding:5px 7px;font-size:12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:var(--hover);}
.col-title{min-width:180px;max-width:320px;}
.col-content{min-width:200px;max-width:360px;}
.col-nowrap{white-space:nowrap;}
.col-narrow{width:1%;white-space:nowrap;}
.col-actions{width:1%;white-space:nowrap;}
.col-preview{min-width:120px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.data-table .row-actions{flex-wrap:nowrap;width:auto;gap:4px;}
.data-table .row-actions .btn{flex:0 0 auto;height:22px;min-width:34px;padding:2px 7px;font-size:11px;}
.data-table .col-actions{min-width:116px;}
/* Project table — PC optimized */
.project-table{table-layout:fixed;width:100%;}
.project-table thead th{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;padding:7px 10px;}
.project-table tbody td{padding:9px 10px;border-bottom:1px solid #f0f0f0;}
.project-table tbody tr{transition:background .12s;}
.project-table tbody tr:hover td{background:#fafcff;}
.project-table tbody tr:hover td:first-child{border-left:2px solid var(--primary);padding-left:8px;}
.project-table .col-title{width:22%;min-width:160px;}
.project-table .col-content{width:34%;min-width:220px;}
.project-table .col-nowrap{width:10%;min-width:72px;}
.project-table .col-narrow{width:10%;min-width:80px;}
.project-table .col-actions{width:14%;min-width:120px;}
.project-table .project-description-cell{
  max-width:100%;
  color:var(--text2);
  font-size:13px;
  line-height:1.5;
  white-space:normal;
  overflow:hidden;
  overflow-wrap:anywhere;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
}
.project-table .task-link{font-weight:600;font-size:13px;color:var(--text);cursor:pointer;text-decoration:none;}
.project-table .task-link:hover{color:var(--primary);}
.data-table .row-actions{gap:6px;}
.data-table .row-actions .btn{padding:3px 10px;font-size:11px;height:26px;border-radius:5px;}

/* ═══ BADGES ═══ */
.badge-pill{display:inline-block;padding:1px 7px;border-radius:10px;font-size:11px;font-weight:500;white-space:nowrap;}
.badge-pill.status-done,.badge-pill.status-active,.badge-pill.status-completed{background:var(--success-bg);color:#16a34a;}
.badge-pill.status-in_progress{background:var(--primary-bg);color:var(--primary);}
.badge-pill.status-blocked{background:var(--danger-bg);color:var(--danger);}
.badge-pill.status-todo{background:var(--bg);color:var(--text3);}
.badge-pill.status-urgent{background:var(--warning-bg);color:#d97706;}
.badge-pill.status-cancelled,.badge-pill.status-archived{background:var(--bg);color:var(--text3);}

/* ═══ MODAL ═══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:500;padding:20px;}
.modal{background:var(--surface);border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.12);width:560px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);}
.modal-header h3{font-size:14px;font-weight:600;}
.modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text3);padding:4px 8px;border-radius:4px;}
.modal-close:hover{background:var(--hover);color:var(--text);}
.modal-body{padding:20px;overflow-y:auto;}
.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap;min-width:0;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;}
.detail-header h2{font-size:17px;font-weight:650;flex:1;min-width:0;}
.detail-desc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:14px;white-space:pre-wrap;color:var(--text2);overflow-wrap:anywhere;font-size:13px;line-height:1.6;}
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:16px;min-width:0;}
.detail-item{padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);min-width:0;}
.detail-item label{display:block;font-size:10px;color:var(--text3);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px;}
.detail-item .value{font-size:13px;font-weight:500;color:var(--text);overflow-wrap:break-word;}
.priority-low{color:var(--text3);}
.priority-medium{color:var(--text2);}
.priority-high{color:#d97706;}
.priority-urgent{color:var(--danger);font-weight:600;}
.comment-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;}
.comment-item{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);padding:10px 12px;color:var(--text2);white-space:pre-wrap;}
.comment-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--text3);font-size:11px;margin-bottom:5px;}
.comment-meta strong{color:var(--text);font-size:12px;}
.comment-type{background:var(--bg);border-radius:4px;padding:1px 5px;color:var(--text2);}
.type-progress{background:var(--primary-bg);color:var(--primary);}
.type-status_change{background:var(--warning-bg);color:#d97706;}
.comment-form{display:flex;align-items:center;gap:8px;margin-top:12px;}
.comment-form input{flex:1;height:32px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13px;}
.comment-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg);}

/* ═══ TOAST ═══ */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);padding:8px 18px;border-radius:var(--radius);font-size:13px;font-weight:500;z-index:600;box-shadow:0 4px 20px rgba(0,0,0,.15);background:var(--text);color:#fff;}

/* ═══ EMPTY ═══ */
.empty-state{text-align:center;padding:48px 20px;color:var(--text3);font-size:13px;}
.empty-state p{margin-bottom:10px;}
.empty-actions{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:8px;}

/* ═══ UNIFIED CARD ═══ */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);}
.card-title{font-size:12px;font-weight:600;margin-bottom:8px;color:var(--text);}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;flex:1;min-width:120px;}
.stat-label{font-size:11px;color:var(--text2);margin-bottom:2px;}
.stat-val{font-size:22px;font-weight:700;color:var(--text);}
.list-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-bottom:6px;min-width:0;}
.list-card.clickable{cursor:pointer;}
.list-card:hover{border-color:#d4d4d8;box-shadow:0 1px 4px rgba(15,23,42,.05);}
.list-card-title{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.list-card-meta{font-size:11px;color:var(--text3);margin-top:2px;}
.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:9px 10px;cursor:pointer;min-width:0;}
.task-card:hover{border-color:#d4d4d8;}
.task-card-top{display:flex;align-items:center;gap:6px;}
.task-card-title{font-size:13px;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.task-card-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3);margin-top:2px;}
.task-card-info{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;}
.task-card-actions{display:flex;align-items:center;gap:4px;margin-top:4px;}

/* Card grid — responsive columns */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:8px;align-items:start;}
.ideas-grid{grid-template-columns:repeat(auto-fit,minmax(min(340px,100%),1fr));gap:8px;align-items:start;}
.idea-card{cursor:pointer;min-width:0;transition:border-color .15s,box-shadow .15s,background .15s;}
.idea-card:hover{box-shadow:0 1px 4px rgba(15,23,42,.06);}
.idea-header{cursor:pointer;}
.idea-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.idea-title-wrap{flex:1;min-width:0;}
.idea-index{color:var(--text2);font-size:12px;font-weight:500;margin-right:4px;}
.idea-title{font-size:13px;font-weight:600;color:var(--text);}
.idea-preview{font-size:12px;color:var(--text3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.idea-meta{display:flex;gap:6px;align-items:center;flex-shrink:0;color:var(--text3);font-size:11px;white-space:nowrap;}
.idea-closed-note{font-size:11px;color:var(--text3);margin-top:2px;}
.idea-body{display:none;padding:12px 0 0;border-top:1px solid var(--border);margin-top:8px;min-width:0;}
.idea-tags{display:flex;gap:5px;align-items:center;flex-wrap:wrap;margin-bottom:10px;}
.idea-text,.idea-analysis-text{font-size:13px;line-height:1.6;white-space:pre-wrap;color:var(--text);overflow-wrap:anywhere;}
.idea-text{margin-bottom:12px;}
.idea-analysis{margin-bottom:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);}
.idea-analysis-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;}
.idea-analysis-head.no-content{margin-bottom:0;}
.idea-analysis-head strong{font-size:13px;font-weight:600;color:var(--text);}
.idea-analysis-placeholder{font-size:13px;color:var(--text3);}
.idea-reference{font-size:13px;line-height:1.55;color:var(--text2);margin-bottom:12px;overflow-wrap:anywhere;}
.idea-card.expanded .idea-preview{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.idea-card.expanded .idea-body{display:block;}
.idea-card.expanded .idea-body>.row-actions{border-top:1px solid var(--border);padding-top:10px;}
@media(min-width:900px){
  .idea-card.expanded .idea-body{
    display:grid;
    grid-template-columns:minmax(0,1.05fr) minmax(280px,.95fr);
    gap:0 14px;
  }
  .idea-card.expanded .idea-tags,
  .idea-card.expanded .idea-reference,
  .idea-card.expanded .idea-body>.row-actions{grid-column:1/-1;}
  .idea-card.expanded .idea-text{grid-column:1;margin-bottom:12px;}
  .idea-card.expanded .idea-analysis{grid-column:2;grid-row:2 / span 2;align-self:start;}
}

/* ═══ SPACES ═══ */
.space-page{max-width:980px;margin:0 auto;}
.space-entry-card{display:flex;align-items:center;gap:12px;}
.space-entry-index{font-size:11px;color:var(--text3);min-width:28px;flex-shrink:0;}
.space-entry-main{flex:1;min-width:0;}
.space-entry-meta{display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.space-entry-meta span{flex-shrink:0;}
.space-entry-actions{flex-shrink:0;flex-wrap:nowrap;width:auto;}
.space-entry-deleted{opacity:.58;}
.space-entry-deleted .space-entry-main{text-decoration:line-through;font-size:12px;color:var(--text2);}
.space-deleted{margin-top:18px;padding-top:12px;border-top:1px solid var(--border);}
.space-deleted-title{font-size:11px;color:var(--text3);margin-bottom:8px;}
.space-detail-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;margin-bottom:14px;}
.space-detail-title{min-width:0;text-align:center;}
.space-detail-title h3{font-size:16px;font-weight:650;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.space-title-input{font-size:15px;font-weight:600;border:1px solid var(--border);border-radius:var(--radius);padding:5px 8px;width:100%;max-width:360px;outline:none;font-family:var(--font);}
.space-detail-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap;min-width:0;}
.space-select{height:24px;padding:2px 6px;border-radius:var(--radius);border:1px solid var(--border);font-size:11px;max-width:120px;background:var(--surface);font-family:var(--font);}
.space-select.compact{max-width:100px;}
.space-detail-shell{max-width:900px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.space-editor{width:100%;min-height:420px;padding:16px;border:0;font-size:13px;font-family:var(--font-mono);line-height:1.7;resize:vertical;background:var(--surface);color:var(--text);outline:none;}
.space-preview{min-height:320px;padding:18px;font-size:14px;line-height:1.75;overflow-wrap:anywhere;}
.space-preview table{width:100%;display:block;overflow-x:auto;}
.space-preview img{max-width:100%;height:auto;}
.space-save-status{text-align:center;font-size:11px;margin:8px 0 12px;}

/* ═══ MEMO ═══ */
.memo-grid{grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:8px;}
.memo-card{cursor:default;}
.memo-card-head{display:flex;justify-content:space-between;gap:8px;margin-bottom:5px;cursor:pointer;font-size:11px;color:var(--text3);min-width:0;}
.memo-card-meta{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.memo-index{color:var(--text2);font-weight:500;margin-right:4px;}
.memo-closed-label{flex-shrink:0;}
.memo-mobile-order{display:none;align-items:center;gap:4px;margin-left:auto;}
.memo-mobile-order .btn{width:30px;min-width:30px;padding:0;}
.memo-preview{font-size:12px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:14px;}
.memo-body{min-width:0;}
.memo-content{font-size:13px;line-height:1.55;white-space:pre-wrap;margin-bottom:7px;overflow-wrap:anywhere;}
.memo-tags{display:flex;gap:5px;align-items:center;flex-wrap:wrap;margin-bottom:6px;}
.memo-card.drag-over{border-top:2px solid var(--primary);}

/* Status dot */
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.dot.status-todo{background:var(--text3);}
.dot.status-in_progress{background:var(--primary);}
.dot.status-blocked{background:var(--danger);}
.dot.status-done{background:var(--success);}
.dot.status-cancelled{background:var(--text3);opacity:.4;}
.dot-done{background:var(--success);}.dot-active{background:var(--primary);}.dot-pending{background:var(--text3);}.dot-blocked{background:var(--danger);}

/* ═══ DASHBOARD ═══ */
.dm-stats{display:flex;gap:0;margin-bottom:12px;}
.dm-stat{flex:1;text-align:center;padding:6px 4px;background:var(--surface);border:1px solid var(--border);border-right:none;}
.dm-stat:last-child{border-right:1px solid var(--border);}
.dm-stat:first-child{border-radius:var(--radius) 0 0 var(--radius);}
.dm-stat:last-child{border-radius:0 var(--radius) var(--radius) 0;}
.dm-stat-num{font-size:15px;font-weight:700;color:var(--text);line-height:1;}
.dm-stat-label{font-size:10px;color:var(--text3);margin-top:1px;}
.dm-stat.dm-warn .dm-stat-num{color:#d97706;}
.dm-stat.dm-danger .dm-stat-num{color:var(--danger);}
.dm-section-hd{font-size:11px;font-weight:600;color:var(--text3);margin:10px 0 4px;}
.quick-launch{margin-bottom:12px;}
.quick-launch-hd{display:flex;align-items:center;justify-content:space-between;margin-top:0;}
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));gap:8px;}
.quick-card{display:flex;align-items:center;gap:11px;min-width:0;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 13px;font-family:var(--font);cursor:pointer;color:var(--text);}
.quick-card:hover{border-color:#d4d4d8;box-shadow:0 1px 4px rgba(15,23,42,.06);}
.quick-icon{width:32px;height:32px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px;}
.quick-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;}
.quick-main strong{font-size:13px;font-weight:650;line-height:1.25;}
.quick-main small{font-size:11px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

.dm-prj{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.dm-prj-hd{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px solid var(--border);}
.dm-prj-hd:hover{background:var(--hover);}
.dm-prj-hd strong{font-size:12px;}
.dm-prj-owner{font-size:11px;color:var(--text3);}
.dm-prj-arrow{font-size:11px;color:var(--text3);margin-left:auto;}
.dm-prj-ms{display:flex;flex-direction:column;}
.dm-prj-ms{display:flex;flex-wrap:wrap;}
.dm-ms-item{display:flex;align-items:center;gap:6px;padding:5px 10px;cursor:pointer;text-decoration:none;color:inherit;font-size:11px;}
.dm-ms-item:hover{background:var(--hover);}
.dm-ms-name{font-size:12px;font-weight:500;white-space:nowrap;}
.dm-ms-date{font-size:10px;color:var(--text2);white-space:nowrap;}
.dm-ms-date.actual{color:var(--success);}
.dm-dot-s{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0;}
.dm-ms-risk{background:var(--danger-bg);}

/* Risk badges */
.risk-low{color:var(--text3);background:var(--bg);font-size:10px;font-weight:500;padding:0 4px;border-radius:3px;}
.risk-medium{color:#d97706;background:var(--warning-bg);font-size:10px;font-weight:500;padding:0 4px;border-radius:3px;}
.risk-high{color:var(--danger);background:var(--danger-bg);font-size:10px;font-weight:500;padding:0 4px;border-radius:3px;}
.risk-critical{color:#991b1b;background:#fee2e2;font-size:10px;font-weight:600;padding:0 4px;border-radius:3px;}

/* Detail pills */
.dm-detail-status{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:14px;}
.dm-detail-pill{font-size:11px;font-weight:600;padding:1px 7px;border-radius:4px;}
.dm-detail-pill.status-pending{background:var(--bg);color:var(--text3);}
.dm-detail-pill.status-in_progress{background:var(--primary-bg);color:var(--primary);}
.dm-detail-pill.status-completed{background:var(--success-bg);color:#16a34a;}
.dm-detail-pill.status-blocked{background:var(--danger-bg);color:var(--danger);}
.dm-detail-pill.overdue{background:var(--danger-bg);color:var(--danger);}
.dm-detail-date{font-size:11px;color:var(--text2);}
.dm-empty{text-align:center;padding:24px;color:var(--text3);font-size:13px;}

/* Milestone page */
.ms-section{margin-top:24px;}
.ms-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.ms-section-header h3{font-size:14px;font-weight:600;color:var(--text);}
/* ═══ SETTINGS ═══ */
.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:14px;}
.settings-page{max-width:760px;}
.settings-section h3{font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text);}
.settings-section pre{line-height:1.5;font-size:11px;}
.settings-section td,.settings-section th{font-size:12px;}
.settings-section code{background:var(--bg);padding:1px 5px;border-radius:3px;font-size:11px;}
.token-display{background:var(--bg);padding:10px 14px;border-radius:var(--radius);font-family:var(--font-mono);font-size:12px;word-break:break-all;color:var(--text2);}

/* ═══ MEMO ═══ */
.memo-closed{opacity:.5;}

/* ═══ PROJECT CARDS (mobile) ═══ */
.project-card-list{display:none;flex-direction:column;gap:8px;}
.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;cursor:pointer;min-width:0;}
.project-card:hover{border-color:#d4d4d8;box-shadow:0 1px 4px rgba(0,0,0,.04);}
.project-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px;}
.project-card-name{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;}
.project-card-desc{font-size:12px;color:var(--text2);line-height:1.45;margin-bottom:8px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.project-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--text3);}
.project-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.project-card-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;}

/* ═══ MILESTONE GRID ═══ */
.ms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:10px;align-items:start;}
.ms-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:border-color .15s,box-shadow .15s;}
.ms-card:hover{border-color:#c7d2fe;box-shadow:0 2px 8px rgba(59,130,246,.08);}
.ms-card.ms-risk{border-left:3px solid var(--danger);padding-left:13px;}
.ms-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.ms-stage{font-size:11px;color:var(--text3);font-weight:500;background:var(--bg);padding:2px 8px;border-radius:4px;}
.ms-risk-badge{font-size:10px;font-weight:500;padding:1px 6px;border-radius:3px;}
.ms-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;}
.ms-status-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.ms-date{font-size:11px;color:var(--text3);}
.ms-tasks-bar{height:5px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin:2px 0;}
.ms-tasks-progress{height:100%;border-radius:3px;transition:width .4s ease;}
.ms-tasks-info{font-size:11px;color:var(--text2);font-weight:500;}
.ms-actions{display:flex;align-items:center;gap:6px;margin-top:2px;padding-top:4px;border-top:1px solid var(--border);}

/* ═══ RESPONSIVE ═══ */
@media(min-width:769px) and (max-width:1024px){
  #sidebar{width:118px;min-width:118px;}
  #page-container{padding:14px 16px;}
  #topbar{padding:0 16px;}
  .data-table th,.data-table td{padding:5px 7px;font-size:12px;}
  .project-table .col-title{width:20%;}
  .project-table .col-content{width:36%;}
  .ms-grid{grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:8px;}
  .ms-card{padding:10px 12px;gap:8px;}
  .detail-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  #app-shell{flex-direction:column;}
  #menu-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);}
  #menu-toggle:hover{background:var(--hover);}
  #sidebar{position:fixed;top:0;left:0;bottom:0;width:216px;min-width:216px;z-index:950;transform:translateX(-100%);transition:transform .2s;box-shadow:4px 0 24px rgba(0,0,0,.15);}
  #sidebar.open{transform:translateX(0);}
  #sidebar-overlay.show{display:block;}
  #sidebar.collapsed{display:none;}
  #main-content{width:100%;}
  #topbar{padding:0 12px;height:48px;position:sticky;top:0;z-index:100;}
  #page-container{padding:12px 10px;overflow-x:hidden;}
  .data-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;border-radius:var(--radius);}
  .data-table th,.data-table td{padding:6px 8px;font-size:12px;}
  .col-title{min-width:140px;max-width:none;}
  .col-content{min-width:140px;max-width:none;}
  /* Project list: hide table, show cards on mobile */
  .project-table{display:none;}
  .project-card-list{display:flex;}
  .project-card-head{align-items:flex-start;}
  .project-card-meta{flex-direction:column;align-items:flex-start;gap:2px;}

  /* Project detail - mobile */
  .detail-header{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px;}
  .detail-header h2{font-size:14px;width:100%;}
  .detail-header .btn{align-self:flex-start;}
  .detail-desc{font-size:12px;line-height:1.5;padding:10px 12px;}
  .detail-grid{grid-template-columns:1fr;gap:6px;}
  .detail-item{padding:8px 10px;}
  .ms-grid{grid-template-columns:1fr;gap:6px;}
  .ms-card{padding:10px 12px;gap:6px;}
  .ms-card-top{flex-wrap:wrap;}
  .ms-section-header{flex-direction:column;align-items:flex-start;gap:8px;}
  .ms-section-header h3{font-size:13px;}
  .ms-section-header .btn{width:100%;justify-content:center;}
  .login-card{padding:32px 24px;border-radius:14px;}
  .modal{width:100vw;max-width:100vw;max-height:100vh;height:100vh;border-radius:0;}
  .modal-body{padding:16px;}
  .toast{left:12px;right:12px;bottom:12px;transform:none;}
  .dm-prj-ms{flex-direction:column;}
  .dm-ms-item{min-width:100%;border-right:none;}
  .quick-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;}
  .quick-card{display:flex;align-items:center;gap:8px;padding:11px 9px;min-height:56px;}
  .quick-icon{width:30px;height:30px;font-size:16px;}
  .quick-main strong{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .quick-main small{display:block;font-size:10px;line-height:1.25;}
  .card-grid,.memo-grid,.ideas-grid{grid-template-columns:1fr;}
  .detail-grid{grid-template-columns:1fr;}
  .comment-form{align-items:stretch;flex-direction:column;}
  .comment-form .btn{width:100%;}
  .filter-input,.filter-select{width:100%;max-width:none;}
  .btn-sm{height:30px;padding:5px 10px;font-size:12px;min-width:44px;}
  .badge-pill{padding:4px 9px;font-size:12px;}
  .task-card{padding:10px 12px;}
  .task-card-meta{flex-wrap:wrap;gap:6px;}
  .task-card-info{min-width:0;}
  .page-header{flex-direction:column;align-items:stretch;}
  .page-header-split{justify-content:flex-start;}
  .page-header-actions,.row-actions{width:100%;}
  .page-header-actions .btn,.row-actions .btn{flex:1;}
  .page-header .btn{justify-content:center;}
  .form-panel{padding:16px 14px;border-left:none;border-right:none;border-radius:0;margin-left:-10px;margin-right:-10px;max-width:none!important;}
  .space-page{max-width:none;}
  .space-entry-card{
    display:grid;
    grid-template-columns:24px minmax(0,1fr) auto;
    align-items:center;
    gap:6px;
    padding:9px 10px;
  }
  .space-entry-index{min-width:auto;padding-top:0;grid-column:1;}
  .space-entry-main{grid-column:2;min-width:0;}
  .space-entry-actions{grid-column:3;width:auto;flex-wrap:nowrap;}
  .space-entry-actions .btn{flex:0 0 auto;min-width:40px;padding:4px 8px;}
  .space-entry-meta{gap:6px;font-size:11px;}
  .space-entry-deleted{grid-template-columns:minmax(0,1fr) auto;opacity:.62;}
  .space-entry-deleted .space-entry-main{grid-column:1;}
  .space-entry-deleted .space-entry-actions{grid-column:2;}
  .space-detail-header{grid-template-columns:1fr;align-items:stretch;}
  .space-detail-title{text-align:left;order:-1;}
  .space-detail-title h3{white-space:normal;}
  .space-detail-actions{justify-content:flex-start;width:100%;}
  .space-detail-actions .btn,.space-detail-actions .space-select{flex:1 1 auto;min-width:96px;}
  .space-detail-shell{border-left:none;border-right:none;border-radius:0;margin-left:-10px;margin-right:-10px;}
  .space-preview{padding:14px;font-size:13px;line-height:1.7;}
  .space-editor{min-height:360px;padding:14px;}
  .memo-card-head{align-items:center;flex-wrap:nowrap;}
  .memo-card-meta{white-space:nowrap;}
  .memo-mobile-order{display:flex;}
  .memo-preview{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
  .memo-card .row-actions{width:100%;}
  .data-table .row-actions{width:auto;flex-wrap:nowrap;}
  .data-table .row-actions .btn{flex:0 0 auto;min-width:34px;}
  /* Ideas cards: wrap header + feasibility on mobile */
  .idea-header-row{flex-wrap:wrap;}
  .idea-meta{white-space:normal;}
  .idea-analysis-head{align-items:stretch;flex-direction:column;}
  .idea-analysis-head .row-actions{width:100%;}
  .idea-card .idea-body{overflow-wrap:break-word;word-break:break-word;}
}
@media(max-width:400px){
  #page-container{padding:10px 6px;}
  #topbar{padding:0 8px;}
  .login-card{padding:24px 18px;}
  .quick-card{padding:10px 8px;gap:7px;}
  .quick-main strong{font-size:11px;}
  .quick-main small{display:none;}
}
.memo-card.drag-over { border-top: 2px solid var(--primary); }

/* ── Idea version management ── */
.idea-version-badge{cursor:pointer;font-size:11px;color:var(--primary);background:var(--hover);padding:1px 6px;border-radius:10px;white-space:nowrap;}
.idea-version-badge:hover{background:var(--primary);color:#fff;}
.idea-version-history{position:absolute;right:0;top:100%;z-index:10;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.1);min-width:180px;max-height:200px;overflow-y:auto;}
.idea-version-item{cursor:pointer;display:flex;justify-content:space-between;padding:6px 10px;font-size:12px;color:var(--text);border-bottom:1px solid var(--border);}
.idea-version-item:last-child{border-bottom:none;}
.idea-version-item:hover{background:var(--hover);}
.idea-analysis-head{position:relative;}
.idea-refine{margin-top:8px;display:flex;gap:4px;}
.idea-refine input{flex:1;font-size:12px;}

/* Expanded idea card — article layout */
.idea-card.expanded .idea-body { display: block; }
.idea-card.expanded .idea-preview { white-space: normal; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.idea-section { margin-bottom: 16px; }
.idea-section-title { font-size: 14px; font-weight: 600; color: var(--text); margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.idea-analysis-section { background: var(--hover); border-radius: 8px; padding: 14px; }
.idea-analysis-controls { display: flex; align-items: center; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.idea-saved-links{font-size:11px;color:var(--text3);margin-top:2px;padding-left:14px;}
.idea-saved-links a{color:var(--primary);text-decoration:none;}
.idea-saved-links a:hover{text-decoration:underline;}
.idea-saved-del{cursor:pointer;color:var(--text3);margin-left:6px;font-weight:bold;}
.idea-saved-del:hover{color:#e74c3c;}

/* ═══ WORK MODULE ═══ */
.work-tabs{display:flex;gap:0;margin-bottom:12px;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;}
.work-tabs::-webkit-scrollbar{display:none;}
.work-tab,.work-subtab{appearance:none;border:0;background:transparent;color:var(--text2);font-family:var(--font);cursor:pointer;white-space:nowrap;}
.work-tab{height:36px;padding:0 18px;border-bottom:2px solid transparent;font-size:13px;}
.work-tab:hover{color:var(--text);background:var(--hover);}
.work-tab.active{color:var(--primary-hv);border-bottom-color:var(--primary);font-weight:600;}
.work-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.work-toolbar-actions{display:flex;align-items:center;gap:6px;margin-left:auto;}
.work-view-menu{position:relative;font-size:12px;color:var(--text2);}
.work-view-toggle{height:30px;display:flex;align-items:center;padding:0 9px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-size:12px;color:var(--text2);}
.work-view-drop{position:absolute;z-index:20;top:34px;right:0;min-width:110px;padding:8px;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 24px rgba(0,0,0,.1);}
.work-view-menu label{display:flex;align-items:center;gap:6px;padding:4px;white-space:nowrap;cursor:pointer;}
.work-view-tabs button{transition:background .15s;}
.bg-l1-group{transition:box-shadow .15s;}
.bg-l1-group:hover{box-shadow:0 1px 4px rgba(0,0,0,.05);}
.bg-l1-head:hover{background:var(--surface)!important;}
.bg-l1-body table th,.bg-l1-body table td{white-space:nowrap;}
.bg-l1-body table input[type=number]::-webkit-outer-spin-button,
.bg-l1-body table input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.bg-l1-body table input[type=number]{-moz-appearance:textfield;}
.work-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;}
.work-metric{min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:10px 12px;}
.work-metric>div:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.work-table-scroll{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:6px;}
.work-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.work-template-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;align-items:center;}
.form-group small{display:block;margin-top:4px;color:var(--text3);font-size:10px;line-height:1.4;}
.work-field-head{display:flex!important;align-items:center;justify-content:space-between;gap:8px;}
.budget-sheet{margin-bottom:12px;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:var(--surface);}
.budget-sheet-head{padding:8px 10px;background:var(--hover);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.budget-sheet-total{margin-left:auto;font-size:11px;white-space:nowrap;}
.budget-detail-table{min-width:900px;font-size:11px;}
.budget-detail-table th,.budget-detail-table td{border-bottom:1px solid var(--border);}
.budget-detail-table .num-cell{text-align:right;font-variant-numeric:tabular-nums;}
.budget-item-row{display:flex;gap:4px;align-items:center;flex-wrap:wrap;padding:4px 0;border-bottom:1px solid #f0f0f0;font-size:11px;}
.budget-item-row select,.budget-item-row input{font-size:10px;}
.budget-monthly-inputs input::-webkit-outer-spin-button,
.budget-monthly-inputs input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.budget-monthly-inputs input[type=number]{-moz-appearance:textfield;}
.work-subtabs{display:flex;gap:2px;margin-bottom:12px;border-bottom:1px solid var(--border);}
.work-subtab{height:32px;padding:0 12px;border-bottom:2px solid transparent;font-size:12px;}
.work-subtab.active{color:var(--primary-hv);border-bottom-color:var(--primary);font-weight:600;}
.work-empty-inline{padding:16px;text-align:center;color:var(--text3);border:1px dashed var(--border);border-radius:0 0 6px 6px;}
.personnel-table{width:100%;min-width:860px;border-collapse:collapse;font-size:11px;border:1px solid var(--border);}
.person-name-cell{position:sticky;left:0;z-index:2;background:var(--surface);min-width:110px;}
.person-action-cell{position:sticky;right:0;z-index:2;background:var(--surface);}
.personnel-detail-head{padding:8px 10px;background:var(--hover);font-weight:600;font-size:12px;display:flex;justify-content:space-between;align-items:center;gap:10px;}
.personnel-detail-head+div table{min-width:680px;}
.personnel-detail-head~div td:first-child{position:sticky;left:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:5px;min-width:110px;background:var(--surface);}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:0;border-radius:4px;background:transparent;color:var(--text3);cursor:pointer;font-size:17px;}
.icon-btn:hover{background:var(--danger-bg);color:var(--danger);}
.rm-title-cell{position:sticky;left:0;z-index:2;min-width:140px;}
.rm-action-cell{position:sticky;right:0;z-index:2;}
.ms-quarter{min-height:52px;display:flex;flex-direction:column;gap:5px;}
.ms-edit-row{display:grid;grid-template-columns:minmax(120px,1fr) 82px 28px;gap:6px;align-items:center;background:var(--hover);padding:6px 8px;border-radius:4px;}
.ms-empty{font-size:10px;color:var(--text3);padding:12px;text-align:center;width:100%;}

/* ═══ ALLOCATION MATRIX ═══ */
.alloc-grid { overflow-x: auto; }
.alloc-table { border-collapse: collapse; width: 100%; min-width: 800px; }
.alloc-table th, .alloc-table td {
  border: 1px solid var(--border); padding: 4px 6px;
  font-size: 11px; text-align: center; min-width: 52px;
}
.alloc-table th { background: var(--hover); font-weight: 600; position: sticky; top: 0; }
.alloc-table .alloc-cell { cursor: pointer; transition: background .15s; }
.alloc-table .alloc-cell:hover { background: var(--primary-bg); }
.alloc-table .alloc-ok { color: var(--success); }
.alloc-table .alloc-warn { color: var(--warning); }
.alloc-table .alloc-over { color: var(--danger); font-weight: 600; }
.alloc-table .alloc-total { font-weight: 600; background: var(--hover); }

.rm-table { border-radius: 8px; }
.rm-row:hover td { background: #fafcff; }
.rm-row td:first-child { border-right: 1px solid var(--border); }
@media (max-width: 768px) {
  .rm-table th, .rm-table td { padding: 6px 8px !important; font-size: 11px !important; }
  .work-tab{flex:1;padding:0 12px;}
  .work-toolbar{align-items:stretch;}
  .work-toolbar>.filter-select{flex:1;min-width:105px;}
  .work-toolbar-actions{width:100%;margin-left:0;justify-content:flex-end;}
  .work-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .work-metric>div:last-child{font-size:17px!important;}
  .budget-sheet-head{align-items:flex-start;flex-wrap:wrap;}
  .budget-sheet-total{order:3;width:100%;margin-left:0;white-space:normal;line-height:1.6;}
  .work-form-grid{grid-template-columns:1fr;gap:0;}
  .budget-detail-table{min-width:720px;}
  .budget-item-row{gap:2px;}
  .budget-item-row [data-bit-name]{width:100px!important;}
  .budget-item-row select{width:70px!important;}
  .budget-monthly-group{max-width:100%!important;}
  .personnel-detail-head{align-items:flex-start;flex-direction:column;}
  .bg-l1-group{font-size:11px;}
  .bg-l1-head{padding:6px 8px!important;}
  .bg-l1-body table{font-size:9px;}
  .bg-l1-body table th,.bg-l1-body table td{padding:2px!important;}
  .bg-l1-body table input{width:48px!important;font-size:9px!important;}
  .budget-sheet{overflow-x:auto;}
  .budget-sheet .budget-sheet-head{border-radius:0!important;}
}

/* Print/PDF export */
@media print {
  #sidebar, #topbar, .work-tabs, .work-subtabs, .page-header, .btn { display: none !important; }
  #main-content { margin: 0; padding: 0; }
  #page-container { padding: 10px; }
  .rm-table { border: 1px solid #000; font-size: 10px; }
  .rm-table th, .rm-table td { padding: 4px 6px !important; border: 1px solid #ccc !important; }
}

/* Milestone editor - wider quarters on mobile */
@media (max-width: 768px) {
  .stat-card{min-width:45%;flex:0 0 45%;padding:8px 10px;}
  .stat-val{font-size:17px!important;}
  .work-view-tabs button{font-size:10px!important;padding:4px 8px!important;}
  .bg-l1-head{font-size:11px!important;}
  .bg-l1-head span{font-size:10px!important;}
  .bg-l1-subtotal{font-size:10px!important;}
  .budget-sheet-head>div{width:100%;}
  .budget-sheet-head>button{margin-left:auto;}
  .ms-edit-row { grid-template-columns:minmax(100px,1fr) 76px 28px; }
  .ms-edit-row input { min-width: 100px; }
}

@media (max-width: 400px) {
  .stat-card{min-width:100%;flex:0 0 100%;}
  .work-view-tabs button{font-size:9px!important;padding:3px 6px!important;}
}


/* Roadmap edit form - 2-column responsive */
.rm-edit-layout { display: flex; gap: 20px; }
.rm-edit-left { width: 260px; flex-shrink: 0; }
@media (max-width: 768px) {
  .rm-edit-layout { flex-direction: column; }
  .rm-edit-left { width: 100% !important; }
}

/* Full-width form panel */
.form-panel { width: 100%; box-sizing: border-box; }

/* ═══ Dashboard v7 — Module Cards ═══ */
.dash-module-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin: 8px 0;
}
@media (max-width: 768px) {
  .dash-module-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 400px) {
  .dash-module-grid { grid-template-columns: 1fr; }
}

.dash-module-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 13px;
  transition: box-shadow .15s, border-color .15s;
  text-align: left;
  font-family: var(--font);
  color: var(--text);
}
.dash-module-card:hover {
  border-color: var(--primary);
  box-shadow: 0 2px 8px rgba(59,130,246,.1);
}
.dash-module-icon { font-size: 22px; flex-shrink: 0; }
.dash-module-name {
  font-weight: 600;
  color: var(--text);
  flex-shrink: 0;
}
.dash-module-count {
  margin-left: auto;
  font-size: 12px;
  color: var(--text3);
  background: var(--hover);
  padding: 2px 8px;
  border-radius: 10px;
  font-weight: 500;
  white-space: nowrap;
}

/* Todo list in dashboard */
.dash-todo-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dash-todo-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--text);
  transition: border-color .15s;
  font-size: 13px;
}
.dash-todo-item:hover { border-color: var(--primary); }
.dash-todo-title { flex: 1; font-weight: 500; }
.dash-todo-project {
  font-size: 11px;
  color: var(--accent, var(--primary));
  background: var(--primary-bg);
  padding: 1px 6px;
  border-radius: 4px;
}
.dash-todo-date {
  font-size: 11px;
  color: var(--text3);
  white-space: nowrap;
}
