
/* ===== PROJECT INFO SHEET ===== */
/* ===== PROJECT INFO SHEET ===== */
.info-wrap{flex:1;overflow-y:auto;padding:32px 40px;display:flex;flex-direction:column;gap:0;}
.info-hero{display:flex;align-items:flex-start;gap:20px;margin-bottom:36px;padding-bottom:28px;border-bottom:1px solid var(--border);}
.info-emoji{width:60px;height:60px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);}
.info-hero-text{flex:1;}
.info-proj-title{font-family:'DM Sans',sans-serif;font-size:22px;font-weight:700;color:var(--text);line-height:1.2;margin-bottom:6px;}
.info-proj-desc{font-size:13.5px;color:var(--muted);line-height:1.6;max-width:580px;}
.info-proj-desc:empty::before{content:'No description — click to add';color:var(--border);}
.info-status-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:11.5px;font-weight:600;letter-spacing:0.3px;margin-top:10px;cursor:pointer;}
.info-edit-btn{margin-left:auto;padding:7px 16px;border-radius:7px;background:var(--surface2);border:1.5px solid var(--border);color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition);font-family:\"DM Sans\",sans-serif;display:flex;align-items:center;gap:6px;flex-shrink:0;}
.info-edit-btn:hover{border-color:var(--amber-dim);color:var(--amber);background:var(--amber-glow);}
.info-edit-btn.editing{background:var(--amber);border-color:var(--amber);color:#0e0e0f;}

.info-sections{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.info-section{display:flex;flex-direction:column;gap:0;}
.info-section-title{font-size:10px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.info-section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.info-fields{display:flex;flex-direction:column;gap:2px;}
.info-field{display:grid;grid-template-columns:140px 1fr;align-items:start;padding:10px 14px;border-radius:7px;transition:background var(--transition);border:1px solid transparent;}
.info-field:hover{background:var(--surface);border-color:var(--border);}
.info-field-label{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.3px;padding-top:2px;}
.info-field-value{font-size:13.5px;color:var(--text);line-height:1.5;}
.info-field-value:empty::before{content:'—';color:var(--border);}
.info-click-edit:hover{background:var(--surface2);border-radius:5px;outline:1px dashed var(--border);}
.info-field-value a{color:var(--blue);text-decoration:none;}
.info-field-value a:hover{text-decoration:underline;}

/* Editable fields */
.info-field.editable:hover{background:var(--surface2);border-color:var(--border);cursor:text;}
.info-input{background:var(--surface3);border:1.5px solid var(--amber-dim);border-radius:6px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13.5px;padding:5px 10px;outline:none;width:100%;box-shadow:0 0 0 3px var(--amber-glow);}
.info-input::placeholder{color:var(--muted);}
.info-textarea{background:var(--surface3);border:1.5px solid var(--amber-dim);border-radius:6px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13.5px;padding:8px 10px;outline:none;width:100%;resize:vertical;min-height:80px;line-height:1.55;box-shadow:0 0 0 3px var(--amber-glow);}
.info-textarea::placeholder{color:var(--muted);}

/* Phase pill */
.phase-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;cursor:pointer;}

/* Notes section full-width */
.info-notes-section{margin-top:28px;padding-top:24px;border-top:1px solid var(--border);}
.yn-select{background:var(--surface2);border:1.5px solid var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:13px;padding:5px 10px;outline:none;cursor:pointer;transition:border-color var(--transition);}
.yn-select:hover,.yn-select:focus{border-color:var(--amber-dim);box-shadow:0 0 0 3px var(--amber-glow);}
.yn-select option{background:var(--surface2);color:var(--text);}
.info-notes-body{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:18px;font-size:13.5px;color:var(--text);line-height:1.7;min-height:90px;cursor:text;transition:border-color var(--transition);}
.info-notes-body:hover{border-color:var(--surface3);}
.info-notes-body:empty::before{content:'Click to add project notes, context, or important decisions...';color:var(--muted);}

/* Progress ring in hero */
.info-progress-ring{flex-shrink:0;position:relative;width:52px;height:52px;}
.info-progress-ring svg{transform:rotate(-90deg);}
.info-progress-ring .ring-bg{fill:none;stroke:var(--surface3);stroke-width:4;}
.info-progress-ring .ring-fill{fill:none;stroke:var(--amber);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset 0.6s cubic-bezier(0.4,0,0.2,1);}
.info-progress-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;color:var(--amber);}

/* Activity log */
.info-activity{margin-top:28px;padding-top:24px;border-top:1px solid var(--border);}
.activity-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(46,46,51,0.5);}
.activity-row:last-child{border-bottom:none;}
.activity-av{width:26px;height:26px;border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;margin-top:1px;}
.activity-body{flex:1;}
.activity-text{font-size:12.5px;color:var(--text);}
.activity-text strong{font-weight:600;}
.activity-time{font-size:11px;color:var(--muted);margin-top:2px;font-family:'JetBrains Mono',monospace;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:4px;}


/* ===== PROJECT SUMMARY PANEL ===== */
/* ===== PROJECT SUMMARY PANEL ===== */
.proj-summary-panel{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;}
.proj-sum-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;display:flex;flex-direction:column;gap:5px;}
.proj-sum-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);}
.proj-sum-val{font-family:'DM Serif Display',serif;font-size:26px;color:var(--text);line-height:1.1;}
.proj-sum-sub{font-size:11.5px;color:var(--muted);}


/* ===== EXPENSES ===== */
/* ===== EXPENSES ===== */
.expenses-section{margin-bottom:24px;}
.expenses-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.expenses-title{font-family:'DM Serif Display',serif;font-size:16px;color:var(--text);}
.expense-grid{display:grid;grid-template-columns:1fr 160px 100px 100px 36px;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.expense-grid-head{display:contents;}
.expense-head-cell{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:8px 12px;background:var(--surface2);border-bottom:1px solid var(--border);}
.expense-row{display:contents;}
.expense-cell{padding:9px 12px;font-size:13px;border-bottom:1px solid var(--border);display:flex;align-items:center;}
.expense-cell:last-child{border-bottom:none;}
.expense-row:last-child .expense-cell{border-bottom:none;}
.expense-name-input{background:transparent;border:none;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;width:100%;padding:0;}
.expense-name-input:focus{color:var(--amber);}
.expense-amt-input{background:transparent;border:none;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:12.5px;outline:none;width:100%;padding:0;text-align:right;-moz-appearance:textfield;}
.expense-amt-input::-webkit-outer-spin-button,.expense-amt-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.expense-amt-input:focus{color:var(--amber);}
.expense-amt-input::placeholder{color:var(--border);}
.expense-del-btn{background:transparent;border:none;color:transparent;cursor:pointer;font-size:13px;padding:0 8px;transition:color var(--transition);}
.expense-row:hover .expense-del-btn{color:var(--muted);}
.expense-del-btn:hover{color:var(--red) !important;}
.expense-footer{display:grid;grid-template-columns:1fr 160px 100px 100px 36px;background:var(--surface2);border-top:2px solid var(--border);}
.expense-footer-cell{padding:10px 12px;font-size:12px;font-weight:700;font-family:'JetBrains Mono',monospace;}
.expense-add-btn{display:flex;align-items:center;gap:6px;background:transparent;border:1px dashed var(--border);border-radius:7px;color:var(--muted);font-size:12.5px;padding:8px 14px;cursor:pointer;margin-top:8px;transition:all var(--transition);font-family:'DM Sans',sans-serif;width:100%;}
.expense-add-btn:hover{border-color:var(--amber-dim);color:var(--amber);background:var(--amber-glow);}
.exp-over{color:var(--red) !important;}
.exp-under{color:var(--green) !important;}



/* ===== DESCRIPTION CARDS (two-column) ===== */
/* ===== DESCRIPTION CARDS (two-column) ===== */
.desc-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;}
.desc-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.desc-card-header{background:var(--surface3);border-bottom:1px solid var(--border);padding:8px 14px;font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text);}
.desc-card-body{padding:12px 14px;font-size:13px;color:var(--muted);line-height:1.65;min-height:60px;white-space:pre-wrap;word-break:break-word;}
.desc-card-body:empty::before{content:'—';color:var(--border);}
.desc-card-edit textarea{width:100%;background:transparent;border:none;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.65;padding:12px 14px;outline:none;resize:vertical;min-height:80px;}


/* ===== STICKY PROJECT HEADER ===== */
/* ===== STICKY PROJECT HEADER ===== */
.proj-sticky-header{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;}
.proj-sticky-bar{display:flex;align-items:center;gap:10px;padding:10px 24px 8px;overflow-x:auto;}
.proj-sticky-emoji{font-size:20px;flex-shrink:0;}
.proj-sticky-name{font-family:'DM Sans',sans-serif;font-size:17px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px;}
.proj-sticky-tabs{display:flex;gap:0;padding:0 24px;border-top:1px solid var(--border);}
.proj-tab{padding:8px 18px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;font-family:'DM Sans',sans-serif;}
.proj-tab:hover{color:var(--text);}
.proj-tab.active{color:var(--amber);border-bottom-color:var(--amber);font-weight:600;}
#panel-info{flex-direction:column;overflow:hidden;}
#panel-tasks{flex-direction:column;overflow:hidden;}
#panel-expenses{flex-direction:column;overflow:hidden;}
#panel-invoicing{flex-direction:column;overflow:hidden;}


/* ===== STICKY PROJECT HEADER ===== */
/* ===== STICKY PROJECT HEADER ===== */
.proj-sticky-header{background:var(--surface);border-bottom:2px solid var(--border);flex-shrink:0;}
.proj-sticky-bar{display:flex;align-items:center;gap:10px;padding:12px 24px 8px;overflow-x:auto;}
.proj-sticky-name{font-size:17px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px;}
.proj-sticky-tabs{display:flex;gap:0;padding:0 20px;}
.proj-tab{padding:8px 20px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s;white-space:nowrap;font-family:'DM Sans',sans-serif;user-select:none;}
.proj-tab:hover{color:var(--text);}
.proj-tab.active{color:var(--amber);border-bottom-color:var(--amber);font-weight:600;}
#panel-project{overflow:hidden;}
.proj-sub{display:none;flex:1;overflow-y:auto;flex-direction:column;}
.proj-sub.active{display:flex;}


/* ===== CREDIT HOLD ===== */
/* ===== CREDIT HOLD ===== */
.credit-hold-banner{background:#d04040;color:#fff;font-size:12.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:6px 24px;display:flex;align-items:center;gap:8px;flex-shrink:0;}
.credit-hold-checkbox-wrap{display:flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;transition:all .15s;margin-left:8px;}
.credit-hold-checkbox-wrap:hover{border-color:rgba(208,64,64,0.4);background:rgba(208,64,64,0.08);}
.credit-hold-checkbox-wrap.active{background:#d04040;border-color:#d04040;}
.credit-hold-checkbox-wrap.active span{color:#fff;}
.credit-hold-checkbox-wrap span{font-size:11.5px;font-weight:600;color:var(--muted);user-select:none;}
.credit-hold-checkbox-wrap.active span{color:#fff;}
.need-po-checkbox-wrap{display:flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;transition:all .15s;margin-left:8px;}
.need-po-checkbox-wrap:hover{border-color:rgba(192,122,26,0.4);background:rgba(192,122,26,0.08);}
.need-po-checkbox-wrap.active{background:var(--amber);border-color:var(--amber);}
.need-po-checkbox-wrap.active span{color:#0e0e0f;}
.need-po-checkbox-wrap span{font-size:11.5px;font-weight:600;color:var(--muted);user-select:none;}
.need-po-checkbox-wrap.active span{color:#0e0e0f;}
.need-po-banner{background:var(--amber);color:#0e0e0f;font-size:12.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:6px 24px;display:flex;align-items:center;gap:8px;flex-shrink:0;}
.status-pill-select{border-radius:20px;border:1.5px solid;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;padding:3px 8px;outline:none;cursor:pointer;transition:all .15s;}
.status-pill-select option{background:var(--surface);color:var(--text);font-weight:500;}

.inv-table{width:100%;border-collapse:collapse;font-size:13px;}
.inv-table th{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);padding:6px 12px;border-bottom:1px solid var(--border);text-align:left;}
.inv-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;}
.inv-table tr:last-child td{border-bottom:none;}
.inv-table tr:hover td{background:var(--surface2);}
.inv-amount{font-family:'JetBrains Mono',monospace;font-size:12px;}
.inv-mark-btn{font-size:11px;padding:3px 10px;border-radius:12px;border:1.5px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:600;transition:all .15s;}
.inv-mark-btn:hover{background:rgba(192,132,252,0.15);border-color:#c084fc;color:#c084fc;}
.inv-summary-row{display:flex;gap:24px;margin-bottom:20px;flex-wrap:wrap;}
.inv-summary-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 20px;min-width:140px;}
.inv-summary-label{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
.inv-summary-val{font-size:20px;font-weight:700;font-family:'JetBrains Mono',monospace;}
.inv-section-title{font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin:20px 0 8px;}
.inv-empty{text-align:center;padding:32px;color:var(--muted);font-size:13px;}

.reports-tabs{display:flex;gap:2px;}
.reports-tab{padding:8px 18px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;border-radius:6px 6px 0 0;font-family:'DM Sans',sans-serif;}
.reports-tab:hover{color:var(--text);background:var(--surface2);}
.reports-tab.active{color:var(--amber);border-bottom-color:var(--amber);font-weight:600;}
.reports-tab-panel{display:none;}
.reports-tab-panel.active{display:block;}
.ai-prompt-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;color:var(--muted);font-size:11.5px;padding:5px 13px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap;}
.ai-prompt-chip:hover{border-color:var(--amber-dim);color:var(--amber);background:var(--amber-glow);}
.ai-msg{margin-bottom:20px;}
.ai-msg-user{display:flex;justify-content:flex-end;margin-bottom:8px;}
.ai-msg-user-bubble{background:var(--amber-glow);border:1px solid var(--amber-dim);border-radius:14px 14px 4px 14px;padding:10px 16px;font-size:13px;color:var(--text);max-width:600px;line-height:1.5;}
.ai-msg-response{background:var(--surface2);border:1px solid var(--border);border-radius:4px 14px 14px 14px;padding:18px 22px;}
.ai-response-summary{font-size:13.5px;color:var(--text);line-height:1.7;margin-bottom:16px;padding:12px 16px;background:rgba(232,162,52,0.07);border-left:3px solid var(--amber);border-radius:0 8px 8px 0;}
.ai-section{margin-bottom:22px;}
.ai-section-title{font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text);margin-bottom:6px;}
.ai-section-text{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:10px;}
.ai-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:10px;}
.ai-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:10px;}
.report-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:20px;}
.report-card-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.report-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:20px;}
.report-stat{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;}
.report-stat-label{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
.report-stat-val{font-size:22px;font-weight:700;font-family:'JetBrains Mono',monospace;}
.ai-report-section{margin-bottom:24px;}
.ai-report-section h3{font-size:14px;font-weight:700;color:var(--text);margin:0 0 10px;}
.ai-report-section p{font-size:13px;color:var(--muted);line-height:1.7;margin:0 0 8px;}
.ai-report-table{width:100%;border-collapse:collapse;font-size:12.5px;margin-top:8px;}
.ai-report-table th{font-size:10px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;color:var(--muted);padding:6px 10px;border-bottom:1px solid var(--border);text-align:left;}
.ai-report-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);}
.ai-report-table tr:last-child td{border-bottom:none;}
.ai-report-table tr:hover td{background:var(--surface2);}
.ai-thinking{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;padding:20px 0;}
.ai-thinking-dot{width:8px;height:8px;border-radius:50%;background:var(--amber);animation:pulse 1s infinite;}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}

.bq-table{width:100%;border-collapse:collapse;font-size:13px;}
.bq-table th{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);padding:8px 12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;}
.bq-table th.check-col{width:36px;}
.bq-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;}
.bq-table tr:last-child td{border-bottom:none;}
.bq-table tr:hover td{background:var(--surface2);}
.bq-table tr.bq-selected td{background:rgba(192,132,252,0.07);}
.bq-cb{width:15px;height:15px;cursor:pointer;accent-color:#c084fc;}
.bq-summary{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap;}
.bq-sum-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 18px;min-width:130px;}
.bq-sum-label{font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.bq-sum-val{font-size:20px;font-weight:700;font-family:'JetBrains Mono',monospace;}
.bq-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap;}
.bq-sel-info{font-size:12px;color:var(--muted);flex:1;}
.bq-proj-badge{display:inline-block;background:var(--surface2);border:1px solid var(--border);border-radius:10px;font-size:10px;font-weight:600;padding:1px 8px;color:var(--muted);margin-left:4px;vertical-align:middle;}

.dash-charts-row{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:24px;}
.dash-chart-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:18px 20px;}
.dash-chart-title{font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.dash-chart-title span{font-size:16px}
.hidden{display:none!important;}


/* Email Contact button (top row, next to Credit Hold / Need Updated PO) */
.email-contact-btn{
  display:flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;
  border:1.5px solid var(--amber-dim);background:var(--amber-glow);
  cursor:pointer;transition:all .15s;margin-left:8px;
  font-family:'DM Sans',sans-serif;user-select:none;
}
.email-contact-btn:hover{background:var(--amber-dim);border-color:var(--amber);}
.email-contact-btn span{font-size:11.5px;font-weight:600;color:var(--amber);}
.email-contact-btn.disabled{
  opacity:.45;cursor:not-allowed;background:var(--surface2);
  border-color:var(--border);
}
.email-contact-btn.disabled:hover{background:var(--surface2);border-color:var(--border);}
.email-contact-btn.disabled span{color:var(--muted);}
