:root{
  --teal:#0d7377;--teal-mid:#0f8a8f;--teal-light:#129fa5;
  --teal-pale:#e6f4f5;--teal-pale2:#ceeaeb;
  --page-bg:#f0f4f4;--surface:#ffffff;--surface-2:#f7fafa;
  --border:#d8e4e4;--border-mid:#c0d4d4;
  --text-1:#181818;--text-2:#3a4444;--text-3:#6a7a7a;--text-4:#91a0a0;
  --green:#2a9d5c;--green-pale:#e8f5ee;--green-pale2:#b0ddc0;
  --amber:#e07b00;--amber-pale:#fff3e0;--amber-pale2:#f5c680;
  --red:#cc3333;--red-pale:#fdeaea;--red-pale2:#f0bcbc;
  --blue:#1a5fa5;--blue-pale:#e8f0fb;--blue-pale2:#b8cff0;
  --font-head:'Syne',sans-serif;--font-body:'Inter',sans-serif;
  --r:6px;--r-lg:10px;--r-xl:14px;
  --shadow-sm:0 1px 3px rgba(13,115,119,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(13,115,119,.10),0 2px 4px rgba(0,0,0,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--page-bg);color:var(--text-1);font-family:var(--font-body);font-size:14px;line-height:1.6;min-height:100vh;overflow-x:hidden}
img,svg{max-width:100%}
body::before{content:"";position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-light),var(--teal));z-index:400}
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:2rem;background:radial-gradient(circle at top left,#dff0f1 0,#f3f7f7 42%,#edf3f3 100%)}
.auth-card{width:min(100%,460px);background:rgba(255,255,255,.94);border:1px solid var(--border);border-radius:24px;padding:2rem;box-shadow:0 20px 50px rgba(13,115,119,.12)}
.auth-title{font-family:var(--font-head);font-size:28px;line-height:1.15;margin-bottom:10px}
.auth-copy{font-size:14px;color:var(--text-3);margin-bottom:1rem}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-btn{width:100%;margin-top:6px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:14px 0 4px;color:var(--text-4);font-size:11px;text-transform:uppercase;letter-spacing:1.2px}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--border)}
.error-text{color:var(--red);font-size:12px}
body.portfolio-mode .app-header,body.portfolio-mode .tabs-nav{display:none}
body.portfolio-mode .page-shell{max-width:none;padding:0}
body.portfolio-mode .portfolio-shell{padding:0}
.app-header{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:3px;z-index:300}
.hdr{max-width:none;width:100%;margin:0;padding:0 1.75rem;display:flex;align-items:center;justify-content:space-between;height:64px}
.top-actions{display:flex;align-items:center;gap:10px}
.session-badge{display:flex;flex-direction:column;align-items:flex-end}
.logo-area{display:flex;align-items:center;gap:14px}
.logo-home-btn{border:none;background:none;padding:0;cursor:pointer;text-align:left}
.logo-home-btn:focus-visible{outline:2px solid var(--teal);outline-offset:6px;border-radius:8px}
.logo-area img{height:32px;width:auto}
.fallback-logo{font-family:var(--font-head);font-size:15px;font-weight:800;color:var(--teal)}
.logo-div{width:1px;height:28px;background:var(--border-mid)}
.portal-name{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--teal);letter-spacing:.4px}
.portal-sub{font-size:10px;color:var(--text-4);margin-top:1px}
.tabs-nav{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:67px;z-index:290}
.tabs-inner{max-width:none;width:100%;margin:0;padding:0 1.75rem;display:flex;align-items:flex-end;gap:1rem}
.project-tabs{display:flex;align-items:flex-end;gap:0;overflow-x:auto;flex:1}
.project-tab{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:.3px;padding:14px 22px 12px;border:none;background:none;cursor:pointer;color:var(--text-3);border-bottom:3px solid transparent;white-space:nowrap;transition:color .2s,border-color .2s;display:flex;align-items:center;gap:8px;position:relative;top:1px}
.project-tab:hover{color:var(--teal)}
.project-tab.active{color:var(--teal);border-bottom-color:var(--teal);background:var(--teal-pale)}
.tab-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.tab-planning{background:#9aa0a0}
.tab-execution{background:var(--teal)}
.tab-risk{background:#f5a623}
.tab-launch{background:var(--green)}
.add-project-btn{margin-bottom:8px;flex-shrink:0}
.primary-btn,.secondary-btn{border:none;border-radius:999px;padding:12px 18px;font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:.4px;cursor:pointer}
.primary-btn{background:linear-gradient(90deg,var(--teal),var(--teal-light));color:#fff;box-shadow:var(--shadow-md)}
.secondary-btn{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}
.primary-btn:disabled,.secondary-btn:disabled{opacity:.5;cursor:not-allowed}
.page-shell{max-width:none;width:100%;margin:0;padding:1.6rem 1.75rem 3rem}
.workspace{display:grid;grid-template-columns:minmax(0,1.85fr) minmax(340px,420px);gap:18px}
.workspace-main,.workspace-side{display:flex;flex-direction:column;gap:14px;min-width:0}
.dashboard-header,.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.dashboard-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1rem 1.2rem;box-shadow:var(--shadow-sm)}
.dashboard-project-title{font-family:var(--font-head);font-size:22px;font-weight:800;line-height:1.2;overflow-wrap:anywhere}
.dashboard-project-meta{font-size:12px;color:var(--text-3);margin-top:4px;overflow-wrap:anywhere}
.dashboard-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.panel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.2rem 1.35rem;box-shadow:var(--shadow-sm);min-width:0}
.inner-card{background:var(--surface-2)}
.inner-card h3{font-size:18px;line-height:1.3}
.sticky-card{position:relative;top:auto}
.hidden{display:none!important}
.empty-state{background:var(--surface);border:2px dashed var(--border-mid);border-radius:var(--r-xl);padding:4rem 2rem;text-align:center}
.empty-state h2{font-family:var(--font-head);font-size:18px;font-weight:700;color:var(--text-2);margin-bottom:8px}
.empty-state p{font-size:13px;color:var(--text-4);max-width:520px;margin:0 auto;line-height:1.7}
.section-eyebrow{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--teal);margin-bottom:8px}
.project-form{display:flex;flex-direction:column;gap:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--teal)}
.field input,.field select,.field textarea,.upload-toolbar select,.upload-toolbar input,.row-grid input,.row-grid select,.row-item textarea,#chat-input{width:100%;border:1px solid var(--border-mid);border-radius:10px;padding:12px 13px;background:#fff;color:var(--text-1);font:inherit}
.field textarea,.row-item textarea,#chat-input{min-height:110px;resize:vertical}
.row-list{display:flex;flex-direction:column;gap:12px}
.row-item{border:1px solid var(--border);border-radius:var(--r-lg);padding:12px;background:var(--surface)}
.row-item[data-sortable="true"]{position:relative}
.row-item.row-dragging{opacity:.58;border-color:var(--teal);box-shadow:0 10px 24px rgba(13,115,119,.12)}
.row-list.row-list-sorting{outline:1px dashed rgba(13,115,119,.32);outline-offset:8px;border-radius:18px}
.row-readonly{background:#f5f7f7;border-style:dashed}
.row-readonly [data-key]{background:#f8fbfb;color:var(--text-4)}
.row-grid{display:grid;gap:10px;margin-bottom:10px}
.row-grid-1{grid-template-columns:minmax(0,1fr)}
.row-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.row-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.row-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.row-field-label{font-family:var(--font-head);font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-3);display:flex;align-items:center;justify-content:space-between;gap:8px}
.row-field-invalid input,.row-field-invalid select,.row-field-invalid textarea,.field-invalid{border-color:var(--red)!important;box-shadow:0 0 0 3px rgba(204,51,51,.12)}
.row-field-error{font-size:11px;color:var(--red);line-height:1.45}
.field-mini-action{border:none;background:var(--teal-pale);color:var(--teal);border-radius:999px;min-width:24px;height:24px;padding:0 7px;font:700 13px/1 var(--font-head);cursor:pointer}
.row-actions{display:flex;justify-content:flex-end}
.drag-handle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px dashed var(--border-mid);border-radius:12px;background:#f4faf9;color:var(--teal);cursor:grab;margin-right:auto;font:700 16px/1 var(--font-head)}
.drag-handle:active{cursor:grabbing}
.danger-link{border:none;background:none;color:var(--red);font-weight:700;cursor:pointer}
.date-field{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}
.section-collapsed .row-list,.section-collapsed .upload-toolbar,.section-collapsed .files-list{display:none}
.section-controls{margin-left:auto}
.section-tail-actions{display:flex;justify-content:flex-end;margin-top:12px}
.section-sort-label{display:inline-flex;align-items:center;gap:8px;font:700 10px/1 var(--font-head);letter-spacing:1px;text-transform:uppercase;color:var(--text-3)}
.section-sort-label select{min-width:144px;border:1px solid var(--border-mid);border-radius:999px;padding:7px 10px;background:#fff;color:var(--text-2);font:600 12px/1 var(--font-body);text-transform:none;letter-spacing:0}
.help-tip{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:#eef5f5;color:var(--teal);font:800 11px/1 var(--font-head);margin-left:8px;cursor:help;vertical-align:middle}
.project-form-validation-banner{margin:10px 0 2px;padding:10px 12px;border:1px solid var(--red-pale2);border-radius:12px;background:var(--red-pale);color:var(--red);font-size:12px;line-height:1.55}
.approval-subitem{padding-top:10px;border-top:1px solid var(--border)}
.audit-collapse summary{list-style:none;cursor:pointer}
.audit-collapse summary::-webkit-details-marker{display:none}
.audit-summary-toggle{justify-content:space-between}
.audit-toggle-glyph{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:999px;background:#eef5f5;color:var(--teal);font:800 16px/1 var(--font-head)}
.audit-collapse[open] .audit-toggle-glyph{font-size:18px}
.audit-collapse[open] .audit-toggle-glyph::before{content:"−"}
.audit-collapse:not([open]) .audit-toggle-glyph::before{content:"+"}
.upload-toolbar{display:grid;grid-template-columns:170px 1fr auto;gap:10px;margin-bottom:12px}
.files-list{display:flex;flex-direction:column;gap:10px}
.file-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface-2)}
.file-meta{font-size:11.5px;color:var(--text-3);margin-top:3px}
.file-actions{display:flex;gap:8px;align-items:center}
.file-link{color:var(--teal);text-decoration:none;font-weight:700}
.panel-copy{font-size:13px;color:var(--text-3);line-height:1.6}
.chat-log{display:flex;flex-direction:column;gap:10px;max-height:420px;overflow:auto;margin:8px 0;min-width:0}
.chat-msg{padding:12px;border-radius:var(--r-lg);font-size:13px;line-height:1.6}
.chat-user{background:var(--surface-2);border:1px solid var(--border);align-self:flex-end}
.chat-assistant{background:var(--blue-pale);border:1px solid var(--blue-pale2)}
.chat-markdown{margin-top:6px}
.chat-markdown .md-h2,.chat-markdown .md-h3,.chat-markdown .md-h4{font-family:var(--font-head);font-weight:800;color:var(--text-1);line-height:1.25;margin:0 0 8px}
.chat-markdown .md-h2{font-size:18px}
.chat-markdown .md-h3{font-size:15px}
.chat-markdown .md-h4{font-size:13px}
.chat-markdown .md-p{margin:0 0 10px;color:var(--text-2)}
.chat-markdown .md-list{margin:0 0 10px 18px;padding:0;display:flex;flex-direction:column;gap:6px}
.chat-markdown .md-ol{list-style:decimal}
.chat-markdown strong{color:#0e3031}
.chat-markdown code{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;background:rgba(255,255,255,.7);padding:1px 5px;border-radius:6px;font-size:12px}
.chat-markdown .md-pre{margin:0 0 10px;padding:10px 12px;border-radius:12px;background:#fff;border:1px solid var(--blue-pale2);overflow:auto}
.chat-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}
.mini-btn{padding:8px 12px;font-size:10px}
.chat-suggestions{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.suggestion{padding:8px 10px;border-radius:10px;background:#fff;border:1px dashed var(--blue-pale2);font-size:12px}
.chat-compose{display:flex;flex-direction:column;gap:10px}
.dashboard-output{display:flex;flex-direction:column;gap:14px;min-width:0}
.proj-header{background:var(--teal);border-radius:var(--r-xl);padding:1.6rem 2rem;display:flex;align-items:flex-end;justify-content:space-between;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
.proj-header::after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.05)}
.proj-eyebrow{font-family:var(--font-head);font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:5px;position:relative;z-index:1}
.proj-title{font-family:var(--font-head);font-size:22px;font-weight:800;color:#fff;line-height:1.2;position:relative;z-index:1}
.proj-subtitle{font-size:12px;color:rgba(255,255,255,.72);margin-top:4px;line-height:1.7;max-width:760px;position:relative;z-index:1}
.proj-header-right{text-align:right;flex-shrink:0;position:relative;z-index:1}
.proj-version{font-family:var(--font-head);font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:4px}
.proj-status-large{font-family:var(--font-head);font-size:13px;font-weight:700;color:#ffdd99;letter-spacing:.5px}
.alert{background:#fff8f0;border:1px solid #f5c08a;border-left:3px solid #e07b00;border-radius:var(--r);padding:12px 16px;display:flex;gap:12px;align-items:flex-start}
.alert strong{color:#b85c00}
.kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.2rem 1.35rem;box-shadow:var(--shadow-sm);border-top:3px solid var(--border)}
.kpi-button{appearance:none;text-align:left;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}
.kpi-button:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(13,115,119,.12)}
.kpi.k-teal{border-top-color:var(--teal)}.kpi.k-red{border-top-color:var(--red)}.kpi.k-amber{border-top-color:var(--amber)}.kpi.k-green{border-top-color:var(--green)}
.kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-3);margin-bottom:8px;font-family:var(--font-head);font-weight:600}
.kpi-value{font-family:var(--font-head);font-size:30px;font-weight:800;line-height:1;margin-bottom:5px}
.kpi.k-teal .kpi-value{color:var(--teal)}.kpi.k-red .kpi-value{color:var(--red)}.kpi.k-amber .kpi-value{color:#c07000}.kpi.k-green .kpi-value{color:#1e7a45}
.kpi-sub{font-size:11px;color:var(--text-3);line-height:1.5}
.sect-label{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--teal);display:flex;align-items:center;gap:10px}
.sect-label::after{content:"";flex:1;height:1px;background:var(--border-mid)}
.sow-block{background:#fff8f0;border:1px solid #f5c08a;border-radius:var(--r-lg);padding:1.2rem 1.35rem}
.sow-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:10px}
.sow-title{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#b85c00}
.sow-text{font-size:12.5px;color:#6a3a00;line-height:1.7}
.dashboard-grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:14px}
.dashboard-grid-2.equal{grid-template-columns:1fr 1fr}
.sites-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.site-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.site-card.pp{border-top:3px solid var(--teal)}.site-card.tv{border-top:3px solid var(--red)}
.site-head{padding:.85rem 1.2rem;background:var(--surface-2);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);gap:1rem}
.site-name{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--text-1)}
.site-sub{font-size:11px;color:var(--text-3);margin-top:2px}
.site-body{padding:.85rem 1.2rem}
.ms-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px}
.ms-row:last-child{border-bottom:none}
.ms-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.md-done{background:var(--green)}.md-active{background:var(--teal)}.md-block{background:var(--red)}.md-warn{background:var(--amber)}.md-pend{background:#cccccc}.md-ns{background:var(--red)}
.ms-name{flex:1;color:var(--text-2);line-height:1.3}
.ms-pct{font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--text-3);margin-right:4px}
.tag{font-family:var(--font-head);font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:3px 10px;border-radius:20px;white-space:nowrap}
.t-done{background:#e8f5ee;color:#1a6e3a;border:1px solid #b0ddc0}
.t-active{background:#e6f4f5;color:var(--teal);border:1px solid var(--teal-pale2)}
.t-block{background:#fdeaea;color:#b52828;border:1px solid #f0bcbc}
.t-warn{background:#fff3e0;color:#b85c00;border:1px solid #f5c680}
.t-pend{background:#f4f4f4;color:#666;border:1px solid #ddd}
.t-ns{background:#fdeaea;color:#b52828;border:1px solid #f0bcbc}
.t-part{background:#fff8e6;color:#9a6000;border:1px solid #f5d580}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.3rem 1.35rem;box-shadow:var(--shadow-sm)}
.card-title{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.prog-row{margin-bottom:10px}
.prog-row:last-child{margin-bottom:0}
.prog-label{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--text-2);margin-bottom:4px;gap:1rem}
.prog-label span:last-child{font-family:var(--font-head);font-weight:700;font-size:11px;color:var(--text-3)}
.prog-track{height:6px;background:#e8eeee;border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px}
.pf-teal{background:linear-gradient(90deg,var(--teal),var(--teal-light))}.pf-green{background:linear-gradient(90deg,#1a7a45,#2aba6a)}.pf-amber{background:linear-gradient(90deg,#c06000,#f0a030)}.pf-red{background:linear-gradient(90deg,#aa2020,#dd4444)}.pf-grey{background:#d0d8d8}
.risk-row{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.risk-row:last-child{border-bottom:none}
.risk-sev{font-family:var(--font-head);font-size:9px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;padding:3px 9px;border-radius:3px;white-space:nowrap;margin-top:2px}
.rs-crit{background:#fdeaea;color:#b52828;border:1px solid #f0bcbc}.rs-high{background:#fff3e0;color:#b85c00;border:1px solid #f5c680}.rs-med{background:#fffbe6;color:#8a7000;border:1px solid #f0e080}
.risk-body{flex:1}
.risk-text{font-size:12px;color:var(--text-2);line-height:1.5;margin-bottom:3px;overflow-wrap:anywhere}
.risk-owner{font-size:10.5px;color:var(--text-3)}
.update-row{display:flex;gap:14px;padding:9px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.update-row:last-child{border-bottom:none}
.update-date{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--teal);letter-spacing:.4px;white-space:nowrap;min-width:76px;padding-top:1px}
.update-text{font-size:12px;color:var(--text-2);line-height:1.6;overflow-wrap:anywhere;word-break:break-word}
.update-row.next .update-date{color:#c07000}.update-row.next .update-text{color:#7a5000}
.resp-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:12px;gap:1rem}
.resp-row:last-child{border-bottom:none}
.resp-item{color:var(--text-2)}
.resp-owner{font-family:var(--font-head);font-size:9px;font-weight:700;letter-spacing:.5px;padding:3px 10px;border-radius:20px}
.ro-main{background:var(--teal-pale);color:var(--teal);border:1px solid var(--teal-pale2)}
.ro-support{background:#f4f4f4;color:#555;border:1px solid #ddd}
.ro-shared{background:#fff8e6;color:#9a6000;border:1px solid #f5d580}
.timeline-track{display:flex;flex-direction:column;gap:.7rem}
.timeline-item{display:grid;grid-template-columns:140px minmax(0,1fr) auto;gap:.8rem;align-items:start;font-size:13px}
.timeline-date{font-weight:700;color:var(--teal)}
.timeline-title{font-weight:700}
.timeline-phase{font-size:11px;color:var(--text-4);margin-top:3px}
.status-pill{display:inline-flex;align-items:center;gap:.4rem;border-radius:999px;padding:.2rem .55rem;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.status-planning{background:var(--blue-pale);color:var(--blue)}
.status-risk{background:var(--amber-pale);color:var(--amber)}
.status-go{background:var(--green-pale);color:var(--green)}
.status-hold{background:var(--red-pale);color:var(--red)}
.portfolio-red{background:var(--red-pale);color:var(--red)}
.portfolio-amber{background:var(--amber-pale);color:var(--amber)}
.portfolio-green{background:var(--green-pale);color:var(--green)}
.list-note{font-size:11px;color:var(--text-4);margin-top:4px}
.admin-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;margin-bottom:14px}
.permissions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.permission-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.permission-row span{font-size:12px;color:var(--text-2)}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.users-list{display:flex;flex-direction:column;gap:12px}
.users-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.users-table th,.users-table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
.users-table th{font-family:var(--font-head);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--teal);background:var(--surface-2)}
.users-table tbody tr:hover{background:#f8fbfb}
.users-table tbody tr.active{background:var(--teal-pale)}
.permissions-list{display:flex;flex-direction:column;gap:10px}
.permissions-list-body{display:flex;flex-direction:column;gap:10px}
.permission-item{display:grid;grid-template-columns:minmax(0,1fr) 180px auto;gap:10px;align-items:center;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.danger-btn{color:var(--red);border-color:#f0bcbc;background:#fff5f5}
.portfolio-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.portfolio-card{appearance:none;border:1px solid var(--border);border-radius:16px;padding:16px;background:#fff;box-shadow:var(--shadow-sm);text-align:left;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;min-width:0}
.portfolio-card:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(13,115,119,.12)}
.portfolio-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.portfolio-project-name{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--text-1)}
.portfolio-project-meta{font-size:11px;color:var(--text-3);margin-top:2px}
.portfolio-summary{font-size:12px;color:var(--text-2);line-height:1.6;margin-bottom:10px}
.portfolio-metrics{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.portfolio-next{font-size:11.5px;color:var(--text-2);line-height:1.6}
.approval-item{padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--surface-2);margin-bottom:12px;min-width:0}
.approval-item:last-child{margin-bottom:0}
.approval-detail{margin-top:8px}
.pending-detail-pre{margin:0;white-space:pre-wrap;word-break:break-word;font:12px/1.45 ui-monospace,SFMono-Regular,Consolas,monospace;background:#f7fbfc;border:1px solid var(--border);border-radius:12px;padding:10px 12px;color:var(--ink)}
.muted-value{color:var(--text-3)}
.approval-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px;min-width:0}
.approval-title{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--text-1)}
.audit-row{padding:10px 0;border-bottom:1px solid var(--border)}
.audit-row:last-child{border-bottom:none}
.audit-row summary{list-style:none;cursor:pointer}
.audit-row summary::-webkit-details-marker{display:none}
.audit-summary-toggle-row{display:flex;flex-direction:column;gap:4px}
.audit-meta{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--teal);margin-bottom:4px}
.audit-summary{font-size:12px;color:var(--text-2);line-height:1.6;overflow-wrap:anywhere}
.audit-detail-body{padding:10px 0 2px}
.audit-reason{font-size:12px;color:var(--text-2);margin:0 0 10px}
.audit-human-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px;color:var(--text-2);font-size:12.5px;line-height:1.55}
.command-center-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh;background:#f5f7fa}
.command-sidebar{position:sticky;top:0;align-self:start;height:100vh;background:linear-gradient(180deg,#0b3f42,#0d7377);color:#fff;padding:24px 18px;display:flex;flex-direction:column;gap:24px}
.command-brand{min-height:144px;padding:6px 6px 10px;border-radius:18px;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start}
.command-brand-kicker{font-size:12px;letter-spacing:1.8px;text-transform:uppercase;color:#bfe7e9;font-family:var(--font-head);font-weight:700}
.command-brand-title{font-family:var(--font-head);font-size:22px;font-weight:800;line-height:1.05;color:#fff;margin-top:10px;word-break:break-word}
.command-brand-copy{font-size:12px;line-height:1.55;color:#d7f0f1;margin-top:10px;max-width:100%;overflow-wrap:anywhere}
.command-nav{display:flex;flex-direction:column;gap:8px}
.command-nav-item{height:48px;border:none;border-radius:12px;background:transparent;color:#d7e3f3;padding:0 14px;display:flex;align-items:center;gap:12px;font:600 14px/1 var(--font-body);cursor:pointer;text-align:left;transition:background .18s ease,color .18s ease}
.command-nav-item .chip-icon{color:#d7f0f1}
.command-nav-item.active,.command-nav-item:hover{background:rgba(255,255,255,.12);color:#fff}
.command-nav-item:disabled{opacity:.45;cursor:not-allowed}
.command-sidebar-footer{margin-top:auto;padding:16px 14px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.04)}
.command-user-label{font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:#b9d8da;font-family:var(--font-head);font-weight:700}
.command-user-name{font-size:14px;font-weight:700;color:#fff;margin-top:6px;overflow-wrap:anywhere}
.command-user-role{font-size:12px;color:#d6eff0;margin-top:6px}
.command-main{min-width:0;padding:32px}
.command-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:24px}
.command-title{font-size:32px;font-weight:700;line-height:1.15;color:#111827;font-family:var(--font-head)}
.command-subtitle{font-size:15px;color:#6b7280;margin-top:6px}
.command-role-note{font-size:13px;color:#4b5563;margin-top:10px}
.command-header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.command-header-actions .primary-btn{background:linear-gradient(90deg,var(--teal),var(--teal-light))}
.command-header-actions .secondary-btn{background:#fff;border-color:#e5e7eb}
.command-kpis{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;margin-bottom:18px}
.command-kpis .kpi{min-height:118px;background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.04);padding:18px}
.command-kpis .kpi::after{display:none}
.command-kpis .kpi-label{font-size:13px;letter-spacing:.4px;text-transform:none;font-family:var(--font-body);font-weight:600;color:#6b7280}
.command-kpis .kpi-value{font-size:30px;color:#111827}
.command-kpis .kpi-sub{font-size:12px;color:#9ca3af}
.command-kpis .kpi-button,.cc-mini-button,.dependency-risk-button,.activity-item-button,.ai-insight-card-button{appearance:none;text-align:left;cursor:pointer}
.command-kpis .kpi-button.active-filter,.cc-mini-button.active-filter{border-color:#bfdbfe;box-shadow:0 0 0 3px rgba(37,99,235,.12),0 12px 24px rgba(15,23,42,.06)}
.cc-mini-button{width:100%;background:#fff}
.cc-mini-button:hover,.dependency-risk-button:hover,.activity-item-button:hover,.ai-insight-card-button:hover{transform:translateY(-1px)}
.cc-timing-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:24px}
.cc-mini-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.cc-mini-top{display:flex;align-items:center;gap:10px;font-size:12px;color:#6b7280;margin-bottom:10px}
.cc-mini-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:var(--teal-pale);color:var(--teal)}
.cc-mini-card strong{display:block;font-size:24px;font-family:var(--font-head);color:#111827}
.cc-mini-card p{font-size:12px;color:#6b7280;margin-top:6px;line-height:1.6}
.command-primary-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px}
.command-secondary-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;margin-bottom:24px}
.command-panel{background:#fff;border:1px solid #e5e7eb;border-radius:22px;padding:24px;min-width:0}
.command-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.command-panel-head h2{font-size:22px;line-height:1.2;color:#111827;font-family:var(--font-head);font-weight:700}
.command-panel-head p{font-size:14px;color:#6b7280;margin-top:8px;line-height:1.6}
.timeline-panel-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.timeline-controls{display:grid;grid-template-columns:repeat(2,minmax(0,180px)) auto;gap:12px;align-items:end;margin-bottom:18px}
.timeline-control-field{display:flex;flex-direction:column;gap:6px}
.timeline-control-field label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#6b7280;font-family:var(--font-head);font-weight:700}
.timeline-control-field input{height:42px;border:1px solid #d7e3ea;border-radius:12px;padding:0 12px;background:#fff;color:#111827;font:inherit}
.timeline-control-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.command-panel-tools{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:-4px 0 14px;flex-wrap:wrap}
.filter-note{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:var(--teal-pale);color:var(--teal);font-size:12px;font-weight:700}
.filter-clear-btn{border:none;background:none;color:var(--teal);font-size:12px;font-weight:700;cursor:pointer;padding:0}
.command-panel-body{display:flex;flex-direction:column;gap:14px}
.act-now-panel{border-left:6px solid #dc2626}
.priority-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:16px;align-items:flex-start;padding:16px;border-radius:14px;background:#f9fafb;border:1px solid #e5e7eb}
.priority-badge{display:inline-flex;align-items:center;justify-content:center;min-width:98px;padding:7px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.3px}
.priority-badge.critical{background:#fee2e2;color:#b91c1c}
.priority-badge.high{background:#fef3c7;color:#92400e}
.priority-badge.decision{background:var(--teal-pale);color:var(--teal)}
.priority-content{min-width:0}
.priority-title{font-size:15px;font-weight:700;color:#111827}
.priority-description{font-size:13px;color:#6b7280;line-height:1.6;margin-top:4px}
.priority-project-link{margin-top:8px;border:none;background:none;padding:0;color:#2563eb;font-size:12px;font-weight:700;cursor:pointer}
.priority-meta{font-size:12px;color:#6b7280;line-height:1.6;text-align:right;white-space:nowrap}
.ai-insight-panel{background:linear-gradient(180deg,#0b3f42,#11585c);border:none;color:#fff}
.ai-insight-panel .command-panel-head h2{color:#fff}
.ai-insight-panel .command-panel-head p{color:#cbd5e1}
.ai-insight-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:16px}
.ai-insight-card-button{width:100%;color:inherit;border:none}
.ai-insight-title{font-size:14px;font-weight:700;color:#fff}
.ai-insight-body{font-size:13px;line-height:1.6;color:#cbd5e1;margin-top:6px}
.ai-insight-action{width:100%;height:44px;border:none;border-radius:12px;background:#fff;color:#111827;font-weight:700;font-family:var(--font-head);margin-top:18px;cursor:pointer}
.portfolio-chat-msg{padding:12px 14px;border-radius:16px;color:#fff}
.portfolio-chat-msg p,.portfolio-chat-msg li,.portfolio-chat-msg strong,.portfolio-chat-msg em,.portfolio-chat-msg code,.portfolio-chat-msg span{color:inherit}
.portfolio-chat-msg ul,.portfolio-chat-msg ol{padding-left:18px;margin:8px 0 0}
.portfolio-chat-msg li + li{margin-top:4px}
.portfolio-chat-assistant{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16)}
.portfolio-chat-user{background:rgba(37,99,235,.22);border:1px solid rgba(147,197,253,.3)}
.ai-insight-card:hover,.portfolio-chat-assistant:hover,.portfolio-chat-user:hover{box-shadow:0 10px 24px rgba(15,23,42,.18)}
.portfolio-chat-shell{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.14)}
.portfolio-chat-log{max-height:280px;overflow:auto;display:flex;flex-direction:column;gap:10px}
.portfolio-chat-role{font:700 11px/1 var(--font-head);letter-spacing:1px;text-transform:uppercase;color:#e5eefb;margin-bottom:8px}
.portfolio-chat-compose{display:flex;flex-direction:column;gap:10px;margin-top:14px}
#portfolio-chat-input{width:100%;min-height:96px;border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:12px 13px;background:rgba(255,255,255,.08);color:#fff;font:inherit}
#portfolio-chat-input::placeholder{color:#cbd5e1}
.portfolio-chat-empty{padding:14px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:6px;color:#cbd5e1}
.portfolio-chat-empty strong{color:#fff}
.portfolio-chat-error{padding:10px 12px;border-radius:12px;background:rgba(220,38,38,.18);border:1px solid rgba(248,113,113,.24);color:#fee2e2;font-size:12px}
.report-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.28);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1200}
.report-modal{width:min(420px,100%);background:#fff;border:1px solid #e5e7eb;border-radius:22px;padding:28px 26px;box-shadow:0 24px 64px rgba(15,23,42,.22);display:flex;flex-direction:column;align-items:center;text-align:center}
.report-toast-shell{position:fixed;right:24px;bottom:24px;z-index:1200;pointer-events:none}
.report-toast-panel{width:min(380px,calc(100vw - 32px));background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:20px 18px;box-shadow:0 20px 48px rgba(15,23,42,.18);display:flex;flex-direction:column;align-items:center;text-align:center;pointer-events:auto}
.report-modal h3{font:700 24px/1.15 var(--font-head);color:#111827;margin:14px 0 10px}
.report-modal p{font-size:14px;line-height:1.7;color:#6b7280;max-width:34ch}
.report-toast-panel h3{font:700 20px/1.15 var(--font-head);color:#111827;margin:12px 0 8px}
.report-toast-panel p{font-size:13px;line-height:1.65;color:#6b7280;max-width:32ch}
.report-modal-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:18px}
.report-modal-icon{width:64px;height:64px;border-radius:999px;background:var(--teal-pale);color:var(--teal);display:flex;align-items:center;justify-content:center;font:700 28px/1 var(--font-head)}
.report-modal-icon.is-success{background:#dcfce7;color:#166534}
.report-modal-icon.is-error{background:#fee2e2;color:#b91c1c}
.report-modal-spinner{width:24px;height:24px;border:3px solid rgba(13,115,119,.18);border-top-color:var(--teal);border-radius:999px;display:inline-block;animation:reportSpin .8s linear infinite}
@keyframes reportSpin{to{transform:rotate(360deg)}}
.save-progress-backdrop{z-index:1250}
.save-progress-modal{max-width:440px}
.save-progress-spinner{width:26px;height:26px}
.save-progress-bar{width:min(260px,100%);height:10px;border-radius:999px;background:#e6f4f5;overflow:hidden;margin-top:18px}
.save-progress-bar-fill{display:block;width:42%;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--teal),var(--teal-light));animation:saveProgressSlide 1.15s ease-in-out infinite}
@keyframes saveProgressSlide{
  0%{transform:translateX(-115%)}
  55%{transform:translateX(155%)}
  100%{transform:translateX(155%)}
}
.dependency-risk-item{padding:16px;border-radius:14px;background:#f9fafb;border:1px solid #e5e7eb}
.dependency-risk-button{width:100%;color:inherit;border:none}
.dependency-risk-flow{display:flex;align-items:center;gap:10px;font-size:14px;color:#111827}
.dependency-arrow{color:#6b7280}
.dependency-risk-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:#6b7280;margin-top:10px}
.dependency-risk-copy{font-size:13px;color:#6b7280;line-height:1.6;margin-top:10px}
.activity-item{padding:14px 0;border-bottom:1px solid #e5e7eb}
.activity-item-button{width:100%;background:none;border:none;color:inherit}
.activity-item:last-child{border-bottom:none;padding-bottom:0}
.activity-project{font-size:13px;font-weight:700;color:var(--teal)}
.activity-summary{font-size:14px;color:#111827;line-height:1.6;margin-top:4px}
.activity-meta{font-size:12px;color:#9ca3af;margin-top:6px}
.command-table-wrap{overflow:auto}
.command-table{width:100%;border-collapse:collapse}
.command-table th,.command-table td{padding:14px 12px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:middle}
.command-table th{background:#f9fafb;font-size:12px;letter-spacing:.8px;text-transform:uppercase;color:#6b7280;font-family:var(--font-head)}
.command-project-cell{display:flex;flex-direction:column;gap:4px}
.command-project-cell strong{font-size:14px;color:#111827}
.command-project-cell span{font-size:12px;color:#9ca3af}
.command-open-btn{height:34px;padding:0 12px;border:none;border-radius:10px;background:var(--teal-pale);color:var(--teal);font-weight:700;cursor:pointer}
.integrated-timeline{display:flex;flex-direction:column;gap:12px}
.integrated-timeline-scroll{overflow-x:auto;padding-bottom:4px}
.integrated-timeline-months{display:grid;gap:0;border-radius:16px;overflow:hidden;background:var(--teal)}
.integrated-timeline-corner,.integrated-timeline-month{padding:12px 14px;font:700 12px/1.15 var(--font-head);letter-spacing:2px;text-transform:uppercase;color:#fff}
.integrated-timeline-corner{background:#0b5b5f}
.integrated-timeline-body{display:flex;flex-direction:column;gap:12px}
.integrated-timeline-row{appearance:none;border:1px solid #d7e5ef;border-radius:18px;background:#f7fafc;padding:0;display:grid;grid-template-columns:220px minmax(0,1fr);text-align:left;cursor:pointer;overflow:hidden}
.integrated-timeline-project{padding:18px 16px;background:#eef4f8;border-right:1px solid #d7e5ef;display:flex;flex-direction:column;gap:6px}
.integrated-timeline-project strong{font-size:14px;color:#163a3c}
.integrated-timeline-project span{font-size:12px;color:#6b7280}
.project-id-chip{display:inline-flex;align-self:flex-start;padding:2px 8px;border-radius:999px;background:#dceff1;color:#0b5b5f;font-size:11px;font-weight:700;letter-spacing:.02em}
.integrated-timeline-track{position:relative;min-height:92px;background:linear-gradient(180deg,#f8fbff,#eef5fb)}
.integrated-timeline-divider{position:absolute;top:0;bottom:0;width:1px;border-left:2px dashed rgba(13,115,119,.36)}
.timeline-today-line{position:absolute;top:0;bottom:0;width:0;border-left:2px dotted rgba(192,57,43,.95);pointer-events:none;z-index:2}
.timeline-today-chip{position:absolute;top:8px;transform:translateX(-50%);padding:3px 8px;border-radius:999px;background:#fff0ee;color:#b83226;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 4px 12px rgba(184,50,38,.16);pointer-events:none;z-index:3}
.integrated-timeline-segment{position:absolute;min-height:46px;padding:8px 10px;border-radius:0;display:flex;flex-direction:column;justify-content:center;gap:3px;color:#fff;box-shadow:0 8px 18px rgba(31,41,55,.14);overflow:hidden;min-width:0}
.integrated-timeline-segment strong,.integrated-timeline-segment small{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.integrated-timeline-segment strong{font-size:12px}
.integrated-timeline-segment small{font-size:10px;opacity:.92}
.integrated-timeline-segment[data-rich-tooltip],.project-timeline-marker[data-rich-tooltip]{position:absolute}
.integrated-timeline-segment[data-rich-tooltip]:hover::after,.integrated-timeline-segment[data-rich-tooltip]:focus-visible::after,.project-timeline-marker[data-rich-tooltip]:hover::after,.project-timeline-marker[data-rich-tooltip]:focus-visible::after{content:attr(data-rich-tooltip);position:absolute;left:0;top:calc(100% + 10px);min-width:200px;max-width:280px;padding:10px 12px;border-radius:12px;background:rgba(11,18,32,.96);color:#fff;font-size:12px;line-height:1.45;white-space:pre-line;box-shadow:0 14px 30px rgba(15,23,42,.24);z-index:20;pointer-events:none}
.project-timeline-marker[data-rich-tooltip]:hover::after,.project-timeline-marker[data-rich-tooltip]:focus-visible::after{left:10px;top:12px}
.integrated-timeline-segment.mode-compact{padding:7px 8px}
.integrated-timeline-segment.mode-compact strong{font-size:11px}
.integrated-timeline-segment.mode-compact small{font-size:9px}
.integrated-timeline-segment.mode-name-only{align-items:center;text-align:center;padding:6px 5px}
.integrated-timeline-segment.mode-name-only strong{font-size:10px;font-weight:700;letter-spacing:.2px}
.integrated-timeline-segment.tone-planning{background:#7a8ca5}
.integrated-timeline-segment.tone-execution{background:#2f5ea4}
.integrated-timeline-segment.tone-migration{background:#0d8b8f}
.integrated-timeline-segment.tone-uat{background:#d89a1b}
.integrated-timeline-segment.tone-dryrun{background:#6b56c7}
.integrated-timeline-segment.tone-launch{background:#2a9d5c}
.integrated-timeline-segment.tone-hypercare{background:#1f8b6f}
.integrated-timeline-segment.is-blocked{box-shadow:inset 0 0 0 2px #c0392b,0 8px 18px rgba(31,41,55,.14)}
.integrated-timeline-legend{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:4px 2px 0}
.integrated-timeline-legend-item{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#5f6d79;font-weight:600}
.integrated-timeline-legend-swatch{display:inline-flex;width:16px;height:10px;border-radius:999px}
.integrated-timeline-legend-swatch.tone-planning{background:#7a8ca5}
.integrated-timeline-legend-swatch.tone-execution{background:#2f5ea4}
.integrated-timeline-legend-swatch.tone-migration{background:#0d8b8f}
.integrated-timeline-legend-swatch.tone-uat{background:#d89a1b}
.integrated-timeline-legend-swatch.tone-dryrun{background:#6b56c7}
.integrated-timeline-legend-swatch.tone-launch{background:#2a9d5c}
.integrated-timeline-legend-swatch.tone-hypercare{background:#1f8b6f}
.integrated-timeline-legend-swatch.is-blocked{background:#fff;border:2px solid #c0392b}
.proj-id-line{margin-top:6px;font-size:12px;font-weight:700;color:#0b5b5f;letter-spacing:.02em}
.project-report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.project-report-card{appearance:none;border:1px solid #d7e5ef;background:#f8fbff;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:8px;text-align:left;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.project-report-card:hover{transform:translateY(-1px);border-color:#88cfd3;box-shadow:0 10px 22px rgba(15,23,42,.08)}
.project-report-card:disabled{cursor:not-allowed;opacity:.58;transform:none;box-shadow:none}
.project-report-card strong{font-size:14px;color:#12373a}
.project-report-card span{font-size:12px;color:#5f6d79;line-height:1.45}
.settings-placeholder{display:flex;flex-direction:column;gap:10px;padding:6px 0}
.settings-placeholder p{margin:0;color:#5f6d79}
.settings-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.settings-form-grid .inline-actions,.settings-form-grid .list-note,.settings-form-grid .settings-checkbox{grid-column:1/-1}
.settings-checkbox{display:flex;align-items:center;gap:10px;color:#41515f;font-size:13px}
.settings-verification-card{grid-column:1/-1;border:1px solid var(--border);border-radius:18px;padding:16px;background:#f7fbfc}
.settings-verification-head{justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.settings-verification-meta{display:grid;gap:6px;margin-top:12px;font-size:12px;color:#41515f}
.settings-verification-list{display:grid;gap:10px;margin-top:14px}
.settings-verification-item{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:14px;background:#fff;border:1px solid rgba(18,44,61,.08)}
.timeline-zoom-toolbar{display:flex;align-items:center;gap:8px;justify-content:flex-end;margin-bottom:10px;flex-wrap:wrap}
.timeline-zoom-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#5f6d79}
.project-timeline-card{margin-top:0}
.project-timeline-visual{display:flex;flex-direction:column;gap:14px}
.project-timeline-scroll{overflow-x:auto;padding-bottom:4px}
.project-timeline-months{display:grid;gap:0;border-radius:16px;overflow:hidden;background:var(--teal)}
.project-timeline-corner,.project-timeline-month{padding:12px 14px;font:700 12px/1.15 var(--font-head);letter-spacing:2px;text-transform:uppercase;color:#fff}
.project-timeline-corner{background:#0b5b5f}
.project-timeline-rows{display:flex;flex-direction:column;gap:14px}
.project-timeline-row{display:grid;grid-template-columns:280px minmax(0,1fr);border:1px solid var(--border);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#fbfdfd,#f2f8f8)}
.project-timeline-side{padding:18px 16px;border-right:1px solid var(--border);background:#f5fbfb}
.project-timeline-title{font-size:15px;font-weight:700;color:var(--text-1)}
.project-timeline-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px;font-size:12px;color:var(--text-2)}
.project-timeline-summary{margin-top:8px;font-size:12px;color:var(--text-3);line-height:1.5}
.project-timeline-board{display:grid;grid-template-columns:280px minmax(0,1fr);border:1px solid #d7e5ef;border-radius:18px;overflow:hidden;background:#f7fafc}
.project-timeline-overview{padding:18px 16px;background:#eef4f8;display:flex;flex-direction:column;gap:8px}
.project-timeline-overview-title{font-size:14px;font-weight:700;color:#163a3c}
.project-timeline-overview-copy{font-size:12px;color:#6b7280;line-height:1.6}
.project-timeline-track-visual{position:relative;min-height:112px;background:linear-gradient(180deg,#f8fbff,#eef5fb);overflow:hidden}
.project-timeline-track-visual.board{padding-bottom:12px}
.project-timeline-track-line{position:absolute;left:0;right:0;top:54px;height:2px;background:linear-gradient(90deg,rgba(13,115,119,.18),rgba(13,115,119,.3),rgba(13,115,119,.18))}
.project-timeline-track-line.lane{right:18px}
.project-timeline-divider{position:absolute;top:0;bottom:0;width:1px;border-left:2px dashed rgba(13,115,119,.3)}
.project-timeline-variance{position:absolute;height:12px;border-radius:999px;opacity:.9}
.project-timeline-variance.is-delay{background:rgba(204,51,51,.2)}
.project-timeline-variance.is-early{background:rgba(42,157,92,.22)}
.project-timeline-range{position:absolute;height:10px;border-radius:999px}
.project-timeline-range.is-expected{background:rgba(26,95,165,.14);border:1px dashed rgba(26,95,165,.36)}
.project-timeline-range.is-current.tone-planning{background:rgba(122,140,165,.28)}
.project-timeline-range.is-current.tone-execution{background:rgba(47,94,164,.24)}
.project-timeline-range.is-current.tone-migration{background:rgba(13,139,143,.26)}
.project-timeline-range.is-current.tone-uat{background:rgba(216,154,27,.26)}
.project-timeline-range.is-current.tone-dryrun{background:rgba(107,86,199,.24)}
.project-timeline-range.is-current.tone-launch{background:rgba(42,157,92,.28)}
.project-timeline-range.is-current.tone-hypercare{background:rgba(31,139,111,.28)}
.project-timeline-range.is-current.is-blocked{box-shadow:inset 0 0 0 2px rgba(192,57,43,.6)}
.project-timeline-marker{position:absolute;width:22px;height:22px;border-radius:999px;transform:translateX(-50%);box-shadow:0 6px 14px rgba(15,23,42,.12)}
.project-timeline-marker.is-expected{background:#fff;border:2px solid rgba(26,95,165,.52)}
.project-timeline-marker.is-current{border:3px solid rgba(255,255,255,.92)}
.project-timeline-marker.is-current.tone-planning{background:#7a8ca5}
.project-timeline-marker.is-current.tone-execution{background:#2f5ea4}
.project-timeline-marker.is-current.tone-migration{background:#0d8b8f}
.project-timeline-marker.is-current.tone-uat{background:#d89a1b}
.project-timeline-marker.is-current.tone-dryrun{background:#6b56c7}
.project-timeline-marker.is-current.tone-launch{background:#2a9d5c}
.project-timeline-marker.is-current.tone-hypercare{background:#1f8b6f}
.project-timeline-marker.is-current.is-blocked{box-shadow:0 0 0 3px rgba(192,57,43,.42),0 6px 14px rgba(15,23,42,.12)}
.project-timeline-row-shell{cursor:default}
.project-timeline-board-label{position:absolute}
.project-timeline-board-label strong,.project-timeline-board-label small{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.project-timeline-board-label strong{font-size:12px}
.project-timeline-board-label small{font-size:10px;opacity:.92}
.project-timeline-board-label.mode-compact{padding:7px 8px}
.project-timeline-board-label.mode-compact strong{font-size:11px}
.project-timeline-board-label.mode-compact small{font-size:9px}
.project-timeline-board-label.mode-name-only{align-items:center;text-align:center;padding:6px 5px}
.project-timeline-board-label.mode-name-only strong{font-size:10px;font-weight:700;letter-spacing:.2px}
.project-timeline-board-label.tone-planning{background:#7a8ca5}
.project-timeline-board-label.tone-execution{background:#2f5ea4}
.project-timeline-board-label.tone-migration{background:#0d8b8f}
.project-timeline-board-label.tone-uat{background:#d89a1b}
.project-timeline-board-label.tone-dryrun{background:#6b56c7}
.project-timeline-board-label.tone-launch{background:#2a9d5c}
.project-timeline-board-label.tone-hypercare{background:#1f8b6f}
.project-timeline-board-label.is-blocked{box-shadow:inset 0 0 0 2px #c0392b,0 8px 18px rgba(31,41,55,.14)}
.app-header{backdrop-filter:blur(14px);background:rgba(255,255,255,.92)}
.hdr{height:74px}
.logo-home-btn{padding:8px 12px;border-radius:18px;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}
.logo-home-btn:hover{background:rgba(13,115,119,.06);transform:translateY(-1px);box-shadow:0 8px 20px rgba(13,115,119,.08)}
.top-actions{gap:12px}
.top-actions .secondary-btn{border-radius:999px;padding:10px 14px}
.nav-btn{display:inline-flex;align-items:center;gap:10px}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:var(--surface-2);color:var(--teal);flex:0 0 auto}
.btn-icon svg{width:13px;height:13px}
.session-badge{padding:8px 12px;border-radius:16px;background:linear-gradient(180deg,#f8fbfb,#eef5f5);border:1px solid var(--border)}
.dashboard-header{align-items:flex-start;gap:18px}
.dashboard-actions{gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:18px;background:linear-gradient(180deg,#fbfdfd,#f2f7f7)}
.panel-card{border-radius:22px;padding:1.35rem 1.45rem;box-shadow:0 18px 40px rgba(15,39,41,.06)}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:10px}
.section-eyebrow{letter-spacing:2.2px;color:#0c7d80}
.panel-copy{max-width:70ch}
.kpi-strip{gap:14px}
.kpi{position:relative;border-radius:20px;padding:1.25rem 1.35rem 1.2rem;background:linear-gradient(180deg,#fff,#f8fbfb);overflow:hidden}
.kpi::after{content:"";position:absolute;right:-18px;top:-18px;width:72px;height:72px;border-radius:50%;background:rgba(13,115,119,.05)}
.kpi-top{position:relative;display:flex;align-items:center;gap:10px;margin-bottom:10px;z-index:1}
.kpi-glyph,.sect-badge,.approval-glyph,.chat-role-pill{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:999px;background:#eaf3f4;color:var(--teal)}
.chip-icon,.chat-pill-icon{display:inline-flex;align-items:center;justify-content:center}
.chip-icon svg,.chat-pill-icon svg{width:14px;height:14px}
.kpi-label{margin-bottom:0}
.kpi-value{position:relative;z-index:1;font-size:34px}
.kpi-sub{position:relative;z-index:1;max-width:28ch}
.sect-label{margin-top:2px;margin-bottom:2px;font-size:11px;letter-spacing:2.3px}
.sect-label::after{height:2px;background:linear-gradient(90deg,var(--border-mid),rgba(156,178,179,.15))}
.sow-block,.card,.site-card,.portfolio-card,.approval-item,.auth-card{box-shadow:0 16px 34px rgba(15,39,41,.06)}
.card{border-radius:20px;padding:1.35rem 1.4rem}
.card-title{font-size:11px;letter-spacing:1.8px}
.site-card{border-radius:20px}
.site-head{padding:1rem 1.2rem}
.site-body{padding:1rem 1.2rem}
.portfolio-grid{gap:16px}
.portfolio-card{border-radius:20px;padding:18px 18px 16px;background:linear-gradient(180deg,#fff,#f9fcfc)}
.portfolio-card-kicker{display:flex;align-items:center;gap:8px;font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);margin-bottom:6px;font-family:var(--font-head)}
.portfolio-project-name{font-size:18px}
.portfolio-summary{font-size:12.5px;line-height:1.7}
.portfolio-metrics{gap:7px}
.chat-log{gap:12px}
.chat-msg{border-radius:20px;padding:14px 16px}
.chat-role-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.chat-user .chat-role-pill{background:#e9efef;color:#456}
.chat-assistant .chat-role-pill{background:#fff;color:var(--teal);border:1px solid rgba(78,124,222,.18)}
.chat-actions{padding-top:10px;border-top:1px dashed rgba(13,115,119,.14)}
.chat-compose{gap:12px}
#chat-attachment-input{display:none}
.chat-compose-tools{display:flex;align-items:center;justify-content:flex-start}
.chat-attachments-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 0}
.chat-attachment-chip{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,#fbfdfd,#f3f8f8)}
.chat-attachment-text{font-size:12px;color:var(--text-2);line-height:1.5}
.mini-link{font-size:11px}
.chat-inline-attachments{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 8px}
.chat-inline-attachment{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#eef5f5;color:var(--teal);font-size:11px;font-weight:700;letter-spacing:.2px}
.chat-inline-attachment::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--teal-light)}
#chat-input{border-radius:16px;min-height:124px}
.approval-item{border-radius:18px;padding:14px 14px 8px;background:linear-gradient(180deg,#fbfdfd,#f3f8f8)}
.approval-head{padding-bottom:10px;border-bottom:1px solid var(--border)}
.approval-title{display:flex;align-items:center;gap:8px;font-size:14px}
.approval-subitem{padding-top:14px;margin-top:14px}
.audit-collapse{border-radius:18px}
.audit-collapse summary.card-title{display:flex;align-items:center;gap:10px}
.row-item{border-radius:18px;padding:14px;background:linear-gradient(180deg,#fff,#fafcfc)}
.row-readonly{background:linear-gradient(180deg,#f6f8f8,#eff4f4)}
.row-actions{display:flex;justify-content:flex-end}
.field input,.field select,.field textarea,.upload-toolbar select,.upload-toolbar input,.row-grid input,.row-grid select,.row-item textarea,#chat-input{border-radius:12px}
.auth-card{position:relative;overflow:hidden}
.auth-card::after{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;border-radius:50%;background:rgba(13,115,119,.06)}
.auth-title{max-width:12ch}
.workspace-main{display:flex;flex-direction:column;gap:16px}
@media(max-width:1250px){.workspace,.dashboard-grid-2,.dashboard-grid-2.equal,.sites-grid,.kpi-strip{grid-template-columns:1fr}.sticky-card{position:relative;top:auto}.command-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}.command-primary-grid,.command-secondary-grid,.cc-timing-strip{grid-template-columns:1fr 1fr}}
@media(max-width:980px){.admin-grid,.permissions-grid,.permission-item{grid-template-columns:1fr}}
@media(max-width:980px){
  body.portfolio-mode .page-shell{padding:0}
  .hdr{height:auto;min-height:74px;padding-top:12px;padding-bottom:12px;align-items:flex-start;gap:14px}
  .top-actions{width:100%;flex-wrap:wrap}
  .top-actions .secondary-btn,.top-actions .primary-btn{flex:1 1 calc(50% - 8px);justify-content:center}
  .tabs-inner{padding:0 .9rem .35rem;align-items:stretch;flex-direction:column;gap:.65rem}
  .project-tabs{width:100%;padding-bottom:4px}
  .add-project-btn{width:100%}
  .dashboard-header{flex-direction:column;align-items:flex-start}
  .dashboard-actions{width:100%;justify-content:flex-start}
  .dashboard-actions .secondary-btn,.dashboard-actions .primary-btn{flex:1 1 calc(50% - 10px)}
  .workspace{grid-template-columns:1fr}
  .workspace-side{position:static}
  .workspace-main,.workspace-side{width:100%}
  .portfolio-grid{grid-template-columns:1fr}
  .dashboard-grid-2,.dashboard-grid-2.equal,.sites-grid{grid-template-columns:1fr}
  .file-card{grid-template-columns:1fr}
  .file-actions{justify-content:flex-start;flex-wrap:wrap}
  .panel-copy{max-width:none}
  .command-center-shell{grid-template-columns:1fr}
  .command-sidebar{position:relative;height:auto}
  .command-main{padding:24px}
  .command-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
  .command-primary-grid,.command-secondary-grid,.cc-timing-strip{grid-template-columns:1fr}
  .integrated-timeline-row,.project-timeline-board{grid-template-columns:1fr}
  .integrated-timeline-project,.project-timeline-overview{border-right:none;border-bottom:1px solid var(--border)}
}
@media(max-width:760px){
  .tabs-inner,.page-shell,.hdr{padding:1rem}
  .logo-area{width:100%;align-items:flex-start}
  .logo-area img{max-width:140px;height:auto}
  .portal-name{font-size:18px;line-height:1.2}
  .portal-sub{font-size:12px;line-height:1.5}
  .dashboard-header,.panel-head,.proj-header,.sow-head,.site-head,.top-actions{flex-direction:column;align-items:flex-start}
  .dashboard-actions{padding:10px;gap:8px}
  .dashboard-actions .secondary-btn,.dashboard-actions .primary-btn,.top-actions .secondary-btn,.top-actions .primary-btn{width:100%;flex:1 1 100%}
  .session-badge{width:100%;align-items:flex-start}
  .nav-btn,.primary-btn,.secondary-btn{min-height:44px}
  .grid-2,.row-grid-4,.row-grid-3,.upload-toolbar,.timeline-item,.portfolio-grid,.permission-item{grid-template-columns:1fr}
  .row-grid{margin-bottom:8px}
  .upload-toolbar{gap:8px}
  .project-tabs{padding-right:0;scroll-padding-left:8px}
  .project-tab{max-width:78vw}
  .project-tab{padding:12px 14px 10px;font-size:11px}
  .add-project-btn{margin-bottom:0}
  .proj-header{padding:1.2rem 1.1rem}
  .proj-title{font-size:20px}
  .proj-subtitle{font-size:12px}
  .proj-header-right{text-align:left;min-width:0}
  .session-badge{align-items:flex-start}
  .panel-card{padding:1rem}
  .card,.sow-block{padding:1rem}
  .kpi{padding:1rem}
  .kpi-value{font-size:30px}
  .kpi-sub{max-width:none}
  .approval-head{gap:10px}
  .approval-item{padding:12px}
  .approval-subitem{padding-top:12px;margin-top:12px}
  .inline-actions{width:100%}
  .inline-actions .secondary-btn,.inline-actions .primary-btn{flex:1 1 100%}
  .update-row,.risk-row,.resp-row,.approval-head,.portfolio-card-head{flex-direction:column;align-items:flex-start}
  .update-date{min-width:0}
  .status-pill,.tag,.resp-owner{max-width:100%}
  .users-table{display:block;overflow-x:auto;white-space:nowrap}
  .chat-log{max-height:none}
  .chat-msg{padding:12px 13px}
  .chat-actions{flex-direction:column;align-items:flex-start}
  .chat-actions .secondary-btn,.chat-actions .primary-btn{width:100%}
  #chat-input{min-height:116px}
  .date-field{grid-template-columns:1fr}
  .field input,.field select,.field textarea,.upload-toolbar select,.upload-toolbar input,.row-grid input,.row-grid select,.row-item textarea,#chat-input{padding:11px 12px}
  .command-main{padding:18px 16px}
  .command-header,.command-header-actions,.command-panel-head{flex-direction:column;align-items:flex-start}
  .timeline-controls{grid-template-columns:1fr}
  .command-kpis{grid-template-columns:1fr}
  .command-title{font-size:26px}
  .priority-item{grid-template-columns:1fr}
  .priority-meta{text-align:left;white-space:normal}
  .dependency-risk-flow,.dependency-risk-meta{flex-direction:column;align-items:flex-start}
  .command-table th,.command-table td{padding:12px 10px}
  .project-timeline-row,.project-timeline-board{grid-template-columns:1fr}
  .project-timeline-side,.project-timeline-overview{border-right:none;border-bottom:1px solid var(--border)}
  .project-timeline-months{grid-template-columns:1fr!important}
  .project-timeline-corner{display:none}
}
@media(max-width:520px){
  .auth-shell{padding:1rem}
  .auth-card{padding:1.35rem}
  .auth-title{font-size:24px}
  .page-shell{padding:1rem .85rem 2rem}
  .panel-card,.card,.sow-block{padding:.9rem}
  .dashboard-project-title{font-size:18px}
  .dashboard-project-meta{font-size:11px}
  .kpi{padding:.95rem}
  .kpi-strip{grid-template-columns:1fr}
  .portfolio-project-name{font-size:16px}
  .portfolio-summary{font-size:12px}
  .sect-label{letter-spacing:1.7px}
  .card-title{letter-spacing:1.2px}
  .command-main{padding:16px 12px}
  .command-title{font-size:22px}
  .command-panel{padding:18px}
  .command-nav-item{height:44px}
}
@media(max-width:400px){
  .auth-card{padding:1.1rem}
  .auth-title{font-size:21px}
  .portal-name{font-size:16px}
  .proj-title{font-size:18px}
  .kpi-value{font-size:26px}
  .project-tab{max-width:86vw;padding:11px 12px 9px}
}
