/* --- DESIGN TOKENS --- */
:root{
  --dark:#0D1117;
  --blue:#1D4ED8;
  --blue-hover:#1A44C2;
  --blue-tint:#EFF2FE;
  --surface:#FFFFFF;
  --bg:#F2F4F7;
  --border:#E4E6EA;
  --text:#111827;
  --text-2:#6B7280;
  --text-3:#9CA3AF;
  --green:#059669;
  --amber:#D97706;
  --red:#DC2626;
  --radius:8px;
  --radius-sm:5px;
  --radius-lg:12px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);display:flex;flex-direction:column;font-size:13px}
button{cursor:pointer;font-family:inherit;border:none;background:none}
a{text-decoration:none;color:inherit}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:4px}

/* --- TOPBAR --- */
#topbar{background:var(--dark);height:48px;padding:0 16px;display:flex;align-items:center;gap:0;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.07)}
.brand{font-size:13px;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px;margin-right:16px;letter-spacing:.2px;white-space:nowrap;flex-shrink:0}
.brand-mark{width:20px;height:20px;background:var(--blue);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand-mark svg{display:block}
.brand-name{color:#fff}
.brand-sub{color:rgba(255,255,255,.3);font-weight:400;font-size:12px;margin-left:4px}
.nav-tabs{display:flex;align-items:center;gap:1px;flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.nav-tabs::-webkit-scrollbar{display:none}
.nav-tab{padding:6px 12px;font-size:12px;font-weight:500;color:rgba(255,255,255,.45);border-radius:var(--radius-sm);display:flex;align-items:center;gap:6px;transition:color .12s,background .12s;white-space:nowrap;cursor:pointer;background:none;border:none;letter-spacing:.1px;flex-shrink:0}
.nav-tab:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.06)}
.nav-tab.active{color:#fff;background:rgba(255,255,255,.1)}
.nav-badge{background:var(--blue);color:#fff;font-size:10px;border-radius:10px;padding:1px 6px;font-family:'DM Mono',monospace;font-weight:600}
.nav-badge.zero{background:rgba(255,255,255,.1);color:rgba(255,255,255,.35)}
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:8px}
.status-pill{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:11px;color:rgba(255,255,255,.4);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
#sdot{width:6px;height:6px;border-radius:50%;background:var(--amber);flex-shrink:0;transition:background .3s}
#sdot.live{background:var(--green)}
#sdot.cached{background:var(--amber)}

/* --- LAYOUT --- */
#app{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.view{display:none;flex:1;overflow:hidden;min-height:0;flex-direction:column}
.view.active{display:flex}
#v-portfolio{flex-direction:row!important}

/* --- FOOTER --- */
#footer{background:var(--dark);border-top:1px solid rgba(255,255,255,.07);padding:10px 24px;display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(255,255,255,.35);flex-shrink:0}
#footer a{color:rgba(255,255,255,.55);font-weight:500;transition:color .12s}
#footer a:hover{color:#fff}
.footer-sep{color:rgba(255,255,255,.15)}

/* --- SETUP BANNER (legacy) --- */
#fb-setup-banner{background:#1a2744;color:#93C5FD;padding:10px 24px;font-size:12px;display:flex;align-items:center;gap:12px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.08)}
#fb-setup-banner strong{color:#fff}
#fb-setup-banner a{color:#60A5FA;font-weight:600;margin-left:6px}
#fb-setup-banner button{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.6);padding:3px 10px;border-radius:4px;font-size:11px;cursor:pointer}
#fb-setup-banner code{background:rgba(255,255,255,.1);padding:1px 5px;border-radius:3px;font-family:'DM Mono',monospace}

/* --- KPI CARDS --- */
.main-pane{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px;min-width:0}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;flex-shrink:0}
.kpi-card{background:var(--surface);border-radius:var(--radius);padding:14px 16px;border:1px solid var(--border);position:relative;overflow:hidden}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--blue)}
.kpi-lbl{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-3);margin-bottom:8px;font-weight:600}
.kpi-val{font-size:24px;font-weight:700;font-family:'DM Mono',monospace;color:var(--text);line-height:1}
.kpi-sub{font-size:10px;color:var(--text-3);margin-top:6px}
.demo-card{background:var(--surface);border-radius:var(--radius);padding:12px 16px;border:1px solid var(--border);position:relative;overflow:hidden}
.demo-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:#D97706}
.demo-list{margin-top:4px}
.demo-item{display:inline-flex;align-items:center;gap:8px;padding:5px 0;font-size:12px;margin-right:20px}
.demo-client{font-weight:600;color:var(--text)}
.demo-date{background:#FEF3C7;color:#92400E;padding:2px 10px;border-radius:10px;font-size:10px;font-weight:600;white-space:nowrap}
.demo-del{background:none;border:none;color:#D1D5DB;cursor:pointer;font-size:12px;padding:0 2px;transition:color .12s}
.demo-del:hover{color:#EF4444}
.demo-add-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.demo-add-row input,.demo-add-row select{padding:6px 10px;font-size:11px;border:1px solid #E5E7EB;border-radius:6px;outline:none}
.demo-add-row input:focus,.demo-add-row select:focus{border-color:#1D4ED8}
.demo-add-btn{padding:6px 14px;background:#111827;color:#fff;font-size:11px;font-weight:600;border:none;border-radius:6px;cursor:pointer;white-space:nowrap}
.kpi-sub{font-size:11px;color:var(--text-3);margin-top:6px}

/* --- FILTER BAR --- */
.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}
.stage-filters{display:flex;align-items:center;gap:4px}
.f-btn{padding:5px 12px;font-size:12px;font-weight:500;color:var(--text-2);border-radius:var(--radius-sm);border:1px solid transparent;display:flex;align-items:center;gap:4px;transition:all .12s;cursor:pointer;background:none}
.f-btn:hover:not(.active){background:var(--surface);border-color:var(--border);color:var(--text)}
.f-btn.active{background:var(--text);color:#fff;border-color:var(--text)}
.f-cnt{font-size:10px;opacity:.45;font-family:'DM Mono',monospace}
.filter-divider{width:1px;height:16px;background:var(--border);flex-shrink:0}
.f-select{padding:5px 10px;font-size:12px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;outline:none}
.f-select:focus{border-color:var(--blue)}
.search-wrap{position:relative;margin-left:auto}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}
.search-icon svg{display:block}
.search-input{padding:5px 10px 5px 30px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:180px;color:var(--text);transition:all .15s;outline:none}
.search-input:focus{border-color:var(--blue);width:220px}
.btn-new{padding:6px 16px;font-size:12px;font-weight:600;background:var(--blue);color:#fff;border-radius:var(--radius-sm);transition:background .15s;white-space:nowrap;cursor:pointer;border:none;letter-spacing:.1px}
.btn-new:hover{background:var(--blue-hover)}

/* --- TABLE --- */
.table-wrap{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;flex:1;display:flex;flex-direction:column;min-height:0}
.T{display:grid;grid-template-columns:minmax(130px,1fr) 36px 76px 85px minmax(0,2.2fr) 88px 64px 42px;gap:8px;padding:10px 18px;align-items:start}
.t-head{background:#F8F9FB;border-bottom:1px solid var(--border)}
.th{font-size:10px;letter-spacing:.9px;text-transform:uppercase;color:var(--text-3);font-weight:600;display:flex;align-items:center;gap:3px;cursor:pointer;user-select:none;white-space:nowrap}
.th:hover{color:var(--text-2)}
.th .sort-arrow{opacity:.3;font-size:9px}
.th.sort-asc .sort-arrow::after{content:'↑';opacity:1}
.th.sort-desc .sort-arrow::after{content:'↓';opacity:1}
.th .sort-arrow::after{content:'↕';font-size:10px}
.t-body{overflow-y:auto;flex:1;min-height:0}
.t-row{border-bottom:1px solid #F3F4F6;cursor:pointer;transition:background .1s}
.t-row:hover{background:#F8F9FB}
.t-row.sel{background:var(--blue-tint);border-left:2px solid var(--blue)}
.r-name{font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.r-vert{font-size:10px;color:var(--text-3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.r-owner{font-size:11px;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.r-sum{font-size:11px;color:var(--text-2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
.tag{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:600;letter-spacing:.1px}
.pri-dot{display:inline-flex;width:22px;height:22px;border-radius:50%;font-size:9px;font-weight:700;color:#fff;align-items:center;justify-content:center}
.pill{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:500;color:var(--blue);background:var(--blue-tint);border-radius:4px;padding:2px 8px}
.pill:hover{opacity:.8}
.no-link{font-size:11px;color:#D1D5DB}
.t-empty{padding:48px;text-align:center;color:var(--text-3);font-size:13px}
.t-footer{padding:8px 16px;display:flex;justify-content:space-between;font-size:11px;color:var(--text-3);border-top:1px solid #F3F4F6;background:#F8F9FB;flex-shrink:0}
.action-btn{padding:3px 8px;font-size:11px;font-weight:500;border-radius:4px;border:1px solid var(--border);color:var(--text-2);background:var(--surface);cursor:pointer;transition:all .1s}
.action-btn:hover{border-color:var(--blue);color:var(--blue)}
.pt-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}

/* --- PROJECT TYPE --- */
.pt-internal{background:#EEF2FF;color:#3730A3}
.pt-client{background:#ECFDF5;color:#065F46}
.pt-innovation{background:#FEF9C3;color:#713F12}

/* --- PROJECT DETAIL PANEL --- */
.pm-header{background:var(--dark);padding:24px 28px 20px;display:flex;align-items:flex-start;gap:16px;flex-shrink:0}
.pm-header-left{flex:1;min-width:0}
.pm-title{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px;line-height:1.25}
.pm-sub{font-size:12px;color:rgba(255,255,255,.4);line-height:1.5}
.pm-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.pm-chip{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;background:rgba(255,255,255,.1);color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.1)}
.pm-close{width:32px;height:32px;border-radius:var(--radius-sm);font-size:16px;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;background:none;border:none;transition:all .15s;line-height:1}
.pm-close:hover{background:rgba(255,255,255,.1);color:#fff}
.pm-body{overflow-y:auto;max-height:65vh}
.pm-pane{display:block;padding:24px 28px}
.pm-pane+.pm-pane{border-top:6px solid var(--bg)}
.pm-pane-hdr{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.pm-pane-hdr::after{content:'';flex:1;height:1px;background:var(--border)}
.pm-section{margin-bottom:18px}
.pm-section-lbl{font-size:9px;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-3);font-weight:700;margin-bottom:8px}
.pm-text{font-size:13px;color:var(--text-2);line-height:1.7}
.pm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.pm-kv{background:var(--bg);border-radius:var(--radius-sm);padding:10px 14px;border:1px solid var(--border)}
.pm-kv-lbl{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-weight:600}
.pm-kv-val{font-size:13px;font-weight:600;color:var(--text)}
.pm-links{display:flex;gap:8px;flex-wrap:wrap}
.pm-link{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text);transition:all .12s}
.pm-link:hover{background:var(--blue-tint);border-color:var(--blue);color:var(--blue)}
.pm-footer{padding:14px 28px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0;background:#F8F9FB}
.pm-edit-btn{padding:8px 20px;font-size:12px;font-weight:600;border-radius:var(--radius-sm);background:var(--blue);color:#fff;cursor:pointer;border:none;transition:background .15s}
.pm-edit-btn:hover{background:var(--blue-hover)}
.pm-wu-btn{padding:8px 20px;font-size:12px;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text);cursor:pointer;background:var(--surface);transition:all .15s}
.pm-wu-btn:hover{border-color:var(--blue);color:var(--blue)}
.tl-empty{padding:28px;text-align:center;color:var(--text-3);font-size:13px;background:var(--bg);border-radius:var(--radius-sm)}

/* --- TIMELINE --- */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:1px;background:var(--border)}
.tl-item{position:relative;margin-bottom:18px}
.tl-dot{position:absolute;left:-20px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--blue);border:2px solid var(--surface);box-shadow:0 0 0 2px var(--blue)}
.tl-dot.green{background:var(--green);box-shadow:0 0 0 2px var(--green)}
.tl-dot.amber{background:var(--amber);box-shadow:0 0 0 2px var(--amber)}
.tl-dot.red{background:var(--red);box-shadow:0 0 0 2px var(--red)}
.tl-dot.gray{background:var(--text-3);box-shadow:0 0 0 2px var(--text-3)}
.tl-date{font-size:10px;color:var(--text-3);font-family:'DM Mono',monospace;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.tl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}
.tl-card-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:4px}
.tl-card-text{font-size:12px;color:var(--text-2);line-height:1.6}
.tl-sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}
.tl-sub-box{background:var(--bg);border-radius:4px;padding:7px 10px}
.tl-sub-lbl{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px;font-weight:600}
.tl-sub-val{font-size:11px;color:var(--text-2)}

/* --- MODALS (edit / wu) --- */
.overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.5);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center}
.overlay.open{display:flex}
.modal{background:var(--surface);border-radius:var(--radius-lg);width:580px;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal-hdr{padding:20px 24px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--dark)}
.modal-title{font-size:14px;font-weight:700;color:#fff}
.modal-x{width:28px;height:28px;border-radius:4px;font-size:16px;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;background:none;border:none;transition:all .12s}
.modal-x:hover{background:rgba(255,255,255,.1);color:#fff}
.modal-body{padding:20px 24px;overflow-y:auto;flex:1;min-height:0;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal-body.single{grid-template-columns:1fr}
.modal-field{display:flex;flex-direction:column;gap:5px}
.modal-field.full{grid-column:span 2}
.modal-lbl{font-size:11px;font-weight:600;color:var(--text);letter-spacing:.1px}
.modal-lbl span{color:var(--text-3);font-weight:400}
.modal-inp,.modal-sel,.modal-ta{padding:8px 11px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:border .15s;background:var(--surface);outline:none}
.modal-inp:focus,.modal-sel:focus,.modal-ta:focus{border-color:var(--blue)}
.modal-ta{resize:vertical;min-height:72px;font-family:'DM Sans',sans-serif;line-height:1.6}
.modal-ftr{padding:14px 24px;display:flex;gap:8px;justify-content:flex-end;border-top:1px solid var(--border);flex-shrink:0;background:#F8F9FB}
.modal-cancel{padding:8px 16px;font-size:12px;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-2);cursor:pointer;background:var(--surface);transition:all .12s}
.modal-cancel:hover{background:var(--bg)}
.modal-submit{padding:8px 20px;font-size:12px;font-weight:600;border-radius:var(--radius-sm);background:var(--blue);color:#fff;cursor:pointer;border:none;transition:background .15s}
.modal-submit:hover{background:var(--blue-hover)}
.modal-submit:disabled{opacity:.45;cursor:not-allowed}
.modal-status{font-size:12px;min-height:16px;padding:0 2px;grid-column:span 2}
.modal-status.ok{color:var(--green)}
.modal-status.err{color:var(--red)}

/* --- WEEKLY VIEW --- */
.wk-hdr{padding:16px 24px 14px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap}
.wk-title{font-size:15px;font-weight:700;flex:1}
.wk-sub{font-size:11px;color:var(--text-3);margin-top:2px}
.wk-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.wk-input{padding:6px 11px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);outline:none;color:var(--text)}
.wk-input:focus{border-color:var(--blue)}
.btn-add-wu{padding:6px 16px;font-size:12px;font-weight:600;background:var(--blue);color:#fff;border-radius:var(--radius-sm);white-space:nowrap;cursor:pointer;border:none;transition:background .15s}
.btn-add-wu:hover{background:var(--blue-hover)}
#wk-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:10px}
.wk-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border)}
.wk-card-hdr{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);background:#F8F9FB}
.wk-card-name{font-size:13px;font-weight:600;flex:1;color:var(--text)}
.wk-card-date{font-size:11px;color:var(--text-3);font-family:'DM Mono',monospace}
.wk-card-body{padding:14px 16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.wk-item-lbl{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);font-weight:600;margin-bottom:4px}
.wk-item-val{font-size:12px;color:var(--text-2);line-height:1.6}
.wk-empty{padding:60px;text-align:center;color:var(--text-3);font-size:13px}
.wk-milestone{display:inline-flex;align-items:center;gap:4px;background:#FEF9C3;color:#713F12;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;margin-left:8px}

/* --- DATA STUDIO --- */
.ds-wrap{flex:1;overflow-y:auto;padding:24px}
.ds-page-hdr{margin-bottom:20px}
.ds-page-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:2px}
.ds-page-sub{font-size:12px;color:var(--text-3)}
.ds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.ds-kpi{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px;position:relative;overflow:hidden}
.ds-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--blue)}
.ds-kpi-lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);font-weight:600;margin-bottom:6px}
.ds-kpi-val{font-size:24px;font-weight:700;font-family:'DM Mono',monospace;color:var(--text)}
.ds-kpi-sub{font-size:11px;color:var(--text-3);margin-top:4px}
.ds-section{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px 16px;margin-bottom:10px}
.ds-section-title{font-size:13px;font-weight:700;margin-bottom:14px;color:var(--text);display:flex;align-items:center;gap:8px}
.ds-label-badge{font-size:10px;font-weight:600;background:var(--blue-tint);color:var(--blue);padding:2px 8px;border-radius:4px}
.ds-table{width:100%;border-collapse:collapse}
.ds-table th{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-3);font-weight:600;text-align:left;padding:6px 10px;border-bottom:1px solid var(--border)}
.ds-table td{font-size:12px;color:var(--text-2);padding:9px 10px;border-bottom:1px solid #F3F4F6}
.ds-table tr:last-child td{border-bottom:none}
.ds-table tr:hover td{background:#F8F9FB}
.ds-bar-wrap{background:#F3F4F6;border-radius:4px;height:5px;flex:1;overflow:hidden}
.ds-bar{height:100%;border-radius:4px;background:var(--blue)}
.ds-notice{background:#FEFCE8;border:1px solid #FDE68A;border-radius:var(--radius-sm);padding:12px 16px;font-size:12px;color:#713F12;display:flex;align-items:flex-start;gap:8px;margin-bottom:16px}
.ds-row{display:flex;gap:12px;margin-bottom:14px}
.ds-row .ds-section{flex:1;margin-bottom:0}

/* --- RESOURCES --- */
.res-wrap{flex:1;overflow-y:auto;padding:24px}
.res-section-hdr{font-size:13px;font-weight:700;margin-bottom:14px;color:var(--text)}
.res-section-hdr span{font-size:11px;font-weight:400;color:var(--text-3);margin-left:6px}
.res-divider{height:1px;background:var(--border);margin:24px 0}
.res-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin-bottom:8px}
.res-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:10px;transition:border-color .12s}
.res-card:hover{border-color:var(--blue)}
.res-card-top{display:flex;align-items:flex-start;gap:12px}
.res-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--bg)}
.res-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.res-desc{font-size:11px;color:var(--text-2);line-height:1.5}
.res-link{padding:6px 12px;font-size:11px;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text);display:inline-flex;align-items:center;gap:5px;transition:all .12s;align-self:flex-start}
.res-link:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-tint)}
.res-tba{font-size:11px;color:var(--text-3);padding:4px 0}

/* --- PROJECT RESOURCES PANE --- */
.pr-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.pr-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color .12s}
.pr-item:hover{border-color:#CBD5E1}
.pr-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;background:var(--surface)}
.pr-info{flex:1;min-width:0}
.pr-name{font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}
.pr-type-tag{font-size:10px;color:var(--text-3);font-weight:500}
.pr-open{padding:5px 12px;font-size:11px;font-weight:600;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text);background:var(--surface);cursor:pointer;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center;gap:4px;flex-shrink:0;transition:all .12s}
.pr-open:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-tint)}
.pr-del-btn{width:26px;height:26px;border-radius:4px;border:1px solid #FECACA;background:#FEF2F2;color:var(--red);font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
.pr-del-btn:hover{background:#FEE2E2}
.pr-add-row{background:var(--bg);border-radius:var(--radius-sm);border:1px dashed var(--border);padding:16px;margin-top:4px}
.pr-add-hdr{font-size:11px;font-weight:700;color:var(--text);margin-bottom:12px}
.pr-add-fields{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.pr-add-inp{padding:7px 11px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);min-width:0;outline:none}
.pr-add-inp:focus{border-color:var(--blue)}
.pr-add-btn{padding:7px 16px;font-size:12px;font-weight:600;border-radius:var(--radius-sm);background:var(--blue);color:#fff;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s}
.pr-add-btn:hover{background:var(--blue-hover)}
.pr-save-status{font-size:11px;min-height:16px;color:var(--green);margin-top:8px}
.pr-empty{padding:24px;text-align:center;color:var(--text-3);font-size:12px;background:var(--bg);border-radius:var(--radius-sm);margin-bottom:12px;border:1px dashed var(--border)}
.pr-full-note{font-size:11px;color:var(--green);font-weight:600;padding:8px 0}

/* --- ASK ANYTHING --- */
.ask-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;background:var(--bg)}
.ask-msgs{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:14px}
.ask-bubble{max-width:72%;padding:12px 16px;border-radius:var(--radius);font-size:13px;line-height:1.7}
.ask-bubble.user{background:var(--blue);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ask-bubble.bot{background:var(--surface);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px;border:1px solid var(--border)}
.ask-bubble.bot a{color:var(--blue);text-decoration:underline}
.ask-bubble.thinking{background:#F3F4F6;color:var(--text-3);font-style:italic}
.ask-input-row{padding:12px 24px;background:var(--surface);border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}
.ask-input{flex:1;padding:9px 14px;font-size:13px;border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;color:var(--text)}
.ask-input:focus{border-color:var(--blue)}
.ask-send{padding:9px 20px;background:var(--blue);color:#fff;font-size:12px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;border:none;transition:background .15s}
.ask-send:hover{background:var(--blue-hover)}
.ask-send:disabled{opacity:.45;cursor:not-allowed}
.ask-refresh{padding:9px 14px;background:var(--surface);color:var(--text-2);font-size:12px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border);transition:all .15s}
.ask-refresh:hover{border-color:var(--blue);color:var(--blue)}
.ask-copy-btn{position:absolute;top:6px;right:6px;padding:2px 8px;font-size:10px;background:rgba(0,0,0,.04);border:1px solid var(--border);border-radius:4px;cursor:pointer;color:var(--text-3);opacity:0;transition:opacity .15s}
.ask-bubble.bot{position:relative}
.ask-bubble.bot:hover .ask-copy-btn{opacity:1}
.ask-chips{display:flex;gap:6px;flex-wrap:wrap;padding:0 24px 12px}
.ask-chip{padding:4px 12px;border-radius:20px;font-size:11px;background:var(--surface);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all .12s}
.ask-chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-tint)}
.ask-model-badge{font-size:10px;color:var(--text-3);text-align:center;padding:4px 0;flex-shrink:0;letter-spacing:.2px}
/* Ask AI — response rendering */
.ask-link{color:var(--blue);text-decoration:underline;font-weight:500;word-break:break-word}
.ask-link:hover{opacity:.8}
.ask-h2{font-size:13px;font-weight:700;color:var(--text);margin:10px 0 4px;border-bottom:1px solid var(--border);padding-bottom:3px;display:block}
.ask-h3{font-size:11px;font-weight:700;color:var(--text-2);margin:8px 0 3px;text-transform:uppercase;letter-spacing:.6px;display:block}
.ask-list{margin:4px 0 6px 16px;padding:0;list-style:disc}
.ask-list li{margin-bottom:4px;line-height:1.65}
.ask-spacer{height:7px;display:block}
.ask-line{display:block;line-height:1.75}
.ask-wiki-badge{font-size:10px;color:#059669;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:4px;opacity:.8}
.ask-web-badge{font-size:10px;color:#2563eb;font-weight:600;margin-bottom:4px;display:flex;align-items:center;gap:4px;opacity:.85}

/* --- KNOWLEDGE BASE --- */
.kb-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.kb-toolbar{display:flex;align-items:center;gap:10px;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap}
.kb-toolbar-title{font-size:14px;font-weight:700;color:var(--text);margin-right:4px}
.kb-toolbar-title span{font-size:11px;font-weight:400;color:var(--text-3);margin-left:6px}
.kb-search{flex:1;min-width:180px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text);background:var(--bg);outline:none}
.kb-search:focus{border-color:var(--blue);background:var(--surface)}
.kb-filter-sel{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text);background:var(--bg);cursor:pointer;outline:none}
.kb-login-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);background:#0078D4;color:#fff;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:background .15s}
.kb-login-btn:hover{background:#006BB8}
.kb-logout-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);color:var(--text-2);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s}
.kb-logout-btn:hover{border-color:var(--red);color:var(--red)}
.kb-user-pill{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;background:var(--blue-tint);border-radius:20px;border:1px solid #BFDBFE}
.kb-user-avatar{width:26px;height:26px;border-radius:50%;background:var(--blue);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kb-user-name{font-size:11px;font-weight:600;color:var(--blue)}
.kb-breadcrumb{display:flex;align-items:center;gap:4px;padding:10px 24px;background:#F8F9FB;border-bottom:1px solid var(--border);font-size:12px;flex-shrink:0;flex-wrap:wrap}
.kb-breadcrumb-item{color:var(--blue);cursor:pointer;font-weight:600}
.kb-breadcrumb-item:hover{text-decoration:underline}
.kb-breadcrumb-sep{color:var(--text-3);margin:0 2px}
.kb-breadcrumb-cur{color:var(--text-2)}
.kb-body{flex:1;overflow-y:auto;padding:24px}
.kb-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:320px;text-align:center;gap:14px;padding:48px}
.kb-state-title{font-size:17px;font-weight:700;color:var(--text)}
.kb-state-sub{font-size:13px;color:var(--text-3);max-width:400px;line-height:1.7}
.kb-state-notice{background:#FEF9C3;border:1px solid #FDE68A;border-radius:var(--radius-sm);padding:14px 18px;font-size:12px;color:#713F12;max-width:440px;line-height:1.6;text-align:left}
.kb-pending-banner{background:#FEF9C3;border:1px solid #FDE047;border-radius:var(--radius-sm);padding:12px 16px;font-size:12px;color:#713F12;margin-bottom:16px;display:flex;gap:10px;line-height:1.6}
.kb-stats-bar{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.kb-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px}
.kb-stat-val{font-size:20px;font-weight:700;font-family:'DM Mono',monospace;color:var(--text);line-height:1}
.kb-stat-lbl{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;margin-top:3px}
.kb-section-hdr{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);margin:16px 0 10px;display:flex;align-items:center;gap:7px}
.kb-section-hdr::after{content:'';flex:1;height:1px;background:var(--border)}
.kb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.kb-list{display:flex;flex-direction:column;gap:5px}
.kb-view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}
.kb-view-btn{padding:6px 11px;font-size:12px;background:var(--surface);border:none;cursor:pointer;color:var(--text-3);transition:all .12s}
.kb-view-btn.active{background:var(--blue-tint);color:var(--blue)}
.kb-file-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:7px;transition:all .15s}
.kb-file-card:hover{border-color:var(--blue);box-shadow:0 4px 12px rgba(29,78,216,.1)}
.kb-file-card.is-folder{border-left:3px solid var(--amber);cursor:pointer}
.kb-file-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.4;word-break:break-word;flex:1}
.kb-file-meta{font-size:10px;color:var(--text-3);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.kb-ext-tag{display:inline-flex;padding:2px 6px;border-radius:3px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.kb-open-btn{padding:4px 12px;border-radius:var(--radius-sm);background:var(--blue-tint);color:var(--blue);font-size:11px;font-weight:600;border:none;cursor:pointer;align-self:flex-start;transition:all .12s;text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.kb-open-btn:hover{background:var(--blue);color:#fff}
.kb-file-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;display:flex;align-items:center;gap:12px;transition:all .12s}
.kb-file-row:hover{border-color:var(--blue)}
.kb-file-row.is-folder{border-left:3px solid var(--amber);cursor:pointer}
.kb-file-row-icon{font-size:18px;flex-shrink:0;width:26px;text-align:center}
.kb-file-row-info{flex:1;min-width:0}
.kb-file-row-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kb-file-row-meta{font-size:10px;color:var(--text-3);margin-top:2px}
.kb-no-results{text-align:center;color:var(--text-3);font-size:13px;padding:40px;background:var(--bg);border-radius:var(--radius-sm)}

/* --- ADO SETTINGS --- */
#ado-settings-panel{background:#F0F7FF;border:1px solid #BFDBFE;border-radius:var(--radius);padding:16px;margin-bottom:16px}

@keyframes spin{to{transform:rotate(360deg)}}

/* ── RESPONSIVE ─────────────────────────────────────────────────────────── */

/* Tablet & small desktop (≤1024px) */
@media(max-width:1024px){
  .T{grid-template-columns:minmax(120px,1.4fr) 36px 76px minmax(0,2fr) 88px 64px 42px;gap:6px}
  .ds-grid{grid-template-columns:repeat(2,1fr)}
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .pp-sidebar{width:240px}
  .ask-bubble{max-width:82%}
  .status-pill{display:none}
  .nav-tab{padding:5px 9px;font-size:11px}
  .brand-sub{display:none}
}

/* Mobile landscape & tablet portrait (≤768px) */
@media(max-width:768px){
  /* Topbar */
  #topbar{flex-wrap:wrap;padding:8px 12px;height:auto;gap:0;row-gap:0}
  .brand{margin-right:0;order:0;flex:1}
  .brand-sub{display:none}
  .topbar-right{gap:6px;order:1;margin-left:auto;flex-shrink:0}
  .topbar-divider{display:none!important}
  .nav-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;gap:1px;flex:0 0 100%;order:2;margin-top:0;padding:5px 0 4px;border-top:1px solid rgba(255,255,255,.07);scrollbar-width:none;width:100%}
  .nav-tabs::-webkit-scrollbar{display:none}
  .nav-tab{font-size:11px;padding:5px 9px}
  .status-pill{display:none}

  /* Main layout */
  html,body{overflow:auto}
  #app{overflow:auto}
  .view{overflow:auto}
  .main-pane{padding:12px 14px;gap:12px}

  /* KPI */
  .kpi-row{grid-template-columns:repeat(2,1fr);gap:8px}
  .kpi-val{font-size:20px}

  /* Portfolio table */
  .filter-bar{flex-wrap:wrap;gap:6px;padding:10px 14px}
  .search-wrap{width:100%;margin-left:0}
  .search-input{width:100%!important}
  .search-input:focus{width:100%!important}
  .btn-new{font-size:11px;padding:6px 13px}
  .T{grid-template-columns:minmax(100px,1.5fr) 34px 70px minmax(0,1.8fr) 72px 50px 36px!important;gap:4px;padding:8px 10px;font-size:11px}
  .T .th:nth-child(4),.T div:nth-child(4){display:none}

  /* Weekly */
  .wk-hdr{padding:12px 14px}
  .wk-filters{gap:6px}
  .wk-input{font-size:11px;padding:5px 8px}
  #wk-body{padding:12px 14px;gap:8px}
  .wk-card-body{grid-template-columns:1fr 1fr}

  /* Project detail panel */
  .pp-body{flex-direction:column}
  .pp-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding:16px 14px;max-height:300px;overflow-y:auto}
  .pp-main{padding:16px 14px}

  /* Modals */
  .modal{width:96vw;max-height:94vh}
  .modal-body{grid-template-columns:1fr}
  .modal-field.full{grid-column:span 1}
  .modal-status{grid-column:span 1}
  .demo-modal-grid{grid-template-columns:1fr;grid-column:span 1}
  .demo-modal-grid .full{grid-column:span 1}
  .demo-modal-grid .modal-status{grid-column:span 1}
  .reminder-modal{width:96vw;max-height:90vh}

  /* Ask AI */
  .ask-msgs{padding:14px}
  .ask-bubble{max-width:92%}
  .ask-input-row{padding:10px 14px}
  .ask-chips{padding:0 14px 10px}

  /* Data Studio */
  .ds-wrap{padding:14px}
  .ds-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .ds-row{flex-direction:column}
  .ds-kpi-val{font-size:20px}

  /* Knowledge Base */
  .kb-toolbar{padding:10px 14px;gap:8px}
  .kb-body{padding:14px}
  .kb-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}

  /* Resources */
  .res-wrap{padding:14px}
  .res-cards{grid-template-columns:1fr}

  /* Demos */
  .demos-wrap{padding:14px}
  .demos-toolbar{gap:8px}
  .dcal-grid{gap:1px}
  .dcal-cell{min-height:52px;padding:3px}
  .dcal-ev-pill{display:none}

  /* Demo add row */
  .demo-add-row{flex-direction:column}
  .demo-add-row input,.demo-add-row select{width:100%}

  /* Settings dropdown */
  #settings-dropdown{min-width:220px}

  /* Expense */
  .exp-add-row{flex-direction:column}
  .exp-field{width:100%}
  .exp-totals{gap:8px}
  .exp-total-card{flex:1;min-width:100px}

  /* Login */
  .login-card{padding:36px 24px}
  .login-logo{font-size:28px}
}

/* Small mobile (≤480px) */
@media(max-width:480px){
  /* Topbar */
  .brand-mark{width:18px;height:18px}
  .brand-name{font-size:12px}
  .nav-tab{font-size:10px;padding:5px 7px}

  /* KPI */
  .kpi-row{grid-template-columns:1fr 1fr;gap:6px}
  .kpi-val{font-size:18px}
  .kpi-card{padding:10px 12px}

  /* Portfolio table — show only name + stage + status */
  .T{grid-template-columns:1fr 66px 80px!important;gap:4px;padding:7px 10px;font-size:11px}
  .T .th:nth-child(n+2):not(:nth-child(3)):not(:nth-child(6)),
  .T div:nth-child(n+2):not(:nth-child(3)):not(:nth-child(6)){display:none}
  .T .th:nth-child(1),.T div:nth-child(1),
  .T .th:nth-child(3),.T div:nth-child(3),
  .T .th:nth-child(6),.T div:nth-child(6){display:block}
  .r-name{font-size:11px}
  .r-sum{-webkit-line-clamp:2;line-clamp:2}

  /* Weekly */
  .wk-card-body{grid-template-columns:1fr}
  .wk-hdr{flex-direction:column;align-items:flex-start;gap:8px}

  /* Data Studio */
  .ds-grid{grid-template-columns:1fr 1fr;gap:6px}
  .ds-kpi{padding:12px}
  .ds-kpi-val{font-size:18px}

  /* KB */
  .kb-grid{grid-template-columns:1fr}
  .kb-stats-bar{gap:6px}
  .kb-stat{flex:1}

  /* Ask AI */
  .ask-bubble{max-width:96%;font-size:12px}
  .ask-input{font-size:12px}

  /* Modals */
  .modal-hdr{padding:14px 16px 12px}
  .modal-body{padding:14px 16px;gap:10px}
  .modal-ftr{padding:10px 16px}

  /* Demos calendar */
  .dcal-cell{min-height:36px;padding:2px}
  .dcal-day{font-size:10px}
  .dcal-dow{font-size:9px}

  /* Project page */
  .pp-sidebar{max-height:240px}
  .pp-name{font-size:14px}

  /* Footer */
  #footer{flex-wrap:wrap;gap:4px;padding:8px 12px;font-size:10px}

  /* Login */
  .login-card{padding:28px 18px;border-radius:12px}
  .login-logo{font-size:24px}
  .login-btn{font-size:13px;padding:11px 24px}
}

@keyframes seedpulse{0%,100%{box-shadow:0 0 0 3px rgba(5,150,105,.35)}50%{box-shadow:0 0 0 6px rgba(5,150,105,.0)}}
/* --- RAG CHIP IN TABLE --- */
.rag-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;border-radius:20px;padding:3px 9px}
.rag-pill.green{background:#D1FAE5;color:#065F46}
.rag-pill.amber{background:#FEF3C7;color:#92400E}
.rag-pill.red{background:#FEE2E2;color:#991B1B}
.rag-pill.none{background:var(--bg);color:var(--text-3);border:1px solid var(--border)}
/* --- LINK BUTTONS IN TABLE --- */
.tbl-links{display:flex;flex-direction:row;gap:6px;align-items:center}
.tbl-link{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--blue);text-decoration:none;padding:2px 0;white-space:nowrap}
.tbl-link:hover{text-decoration:underline}
/* --- PROJECT PAGE --- */
#v-project{flex-direction:column!important}
.pp-topbar{background:var(--dark);padding:0 24px;height:44px;display:flex;align-items:center;gap:12px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.08)}
.pp-back{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:rgba(255,255,255,.55);cursor:pointer;background:none;border:none;padding:0;transition:color .12s}
.pp-back:hover{color:#fff}
.pp-back svg{flex-shrink:0}
.pp-back-sep{color:rgba(255,255,255,.2);margin:0 4px}
.pp-proj-name{font-size:13px;font-weight:700;color:#fff;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pp-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.pp-body{flex:1;overflow-y:auto;display:flex;min-height:0}
.pp-sidebar{width:280px;flex-shrink:0;border-right:1px solid var(--border);padding:24px 20px;overflow-y:auto;background:var(--surface)}
.pp-main{flex:1;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:0;min-width:0}
/* --- sidebar --- */
.pp-name{font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.3}
.pp-stage-row{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.pp-divider{height:1px;background:var(--border);margin:16px 0}
.pp-meta-section{margin-bottom:0}
.pp-meta-title{font-size:9px;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--text-3);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.pp-edit-meta-btn{font-size:10px;font-weight:600;color:var(--blue);cursor:pointer;background:none;border:none;padding:0;letter-spacing:0;text-transform:none}
.pp-edit-meta-btn:hover{text-decoration:underline}
.pp-kv-list{display:flex;flex-direction:column;gap:10px}
.pp-kv{display:flex;flex-direction:column;gap:2px}
.pp-kv-lbl{font-size:9px;letter-spacing:.9px;text-transform:uppercase;color:var(--text-3);font-weight:600}
.pp-kv-val{font-size:12px;color:var(--text);font-weight:500}
.pp-kv-empty{color:var(--text-3)!important;font-weight:400!important}
.pp-kv-inp{font-size:12px;color:var(--text);border:1px solid var(--blue);border-radius:4px;padding:4px 8px;background:var(--surface);outline:none;width:100%}
.pp-kv-inp:focus{border-color:var(--blue)}
.pp-kv-sel{font-size:12px;color:var(--text);border:1px solid var(--blue);border-radius:4px;padding:4px 8px;background:var(--surface);outline:none;width:100%}
.pp-meta-save{margin-top:12px;display:none}
.pp-meta-save-btn{padding:6px 16px;font-size:11px;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}
.pp-meta-save-btn:hover{background:var(--blue-hover)}
.pp-meta-cancel-btn{padding:6px 12px;font-size:11px;font-weight:600;background:none;color:var(--text-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;margin-left:6px}
/* --- links section --- */
.pp-links{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.pp-link-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text);text-decoration:none;transition:all .12s}
.pp-link-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-tint)}
/* --- main content --- */
.pp-section{margin-bottom:28px}
.pp-section-hdr{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.pp-section-hdr::after{content:'';flex:1;height:1px;background:var(--border)}
.pp-section-hdr span:last-child{flex-shrink:0}
.pp-summary-text{font-size:13px;color:var(--text-2);line-height:1.8}
.pp-wu-add{padding:5px 12px;font-size:11px;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;flex-shrink:0}
.pp-wu-add:hover{background:var(--blue-hover)}

/* --- INLINE EDIT FIELDS (project page) --- */
.pp-field-edit-btn{font-size:10px;font-weight:600;color:var(--blue);cursor:pointer;background:none;border:none;padding:0;letter-spacing:0;text-transform:none;flex-shrink:0}
.pp-field-edit-btn:hover{text-decoration:underline}
.pp-inline-ta{width:100%;padding:9px 12px;font-size:13px;font-family:'DM Sans',sans-serif;border:1px solid var(--blue);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);outline:none;resize:vertical;line-height:1.7;min-height:80px}
.pp-inline-inp{width:100%;padding:8px 12px;font-size:13px;border:1px solid var(--blue);border-radius:var(--radius-sm);color:var(--text);background:var(--surface);outline:none}
.pp-inline-ta:focus,.pp-inline-inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.08)}
.pp-inline-actions{display:flex;gap:8px;margin-top:8px;align-items:center}
.pp-inline-save{padding:5px 14px;font-size:11px;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}
.pp-inline-save:hover{background:var(--blue-hover)}
.pp-inline-cancel{padding:5px 10px;font-size:11px;font-weight:600;background:none;color:var(--text-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}
.pp-inline-msg{font-size:11px;color:var(--green)}
.pp-inline-hint{font-size:10px;color:var(--text-3);margin-top:6px;line-height:1.6}
.pp-empty-prompt{font-size:12px;color:var(--text-3);font-style:italic;cursor:pointer;padding:10px 14px;border:1px dashed var(--border);border-radius:var(--radius-sm);text-align:center;transition:all .12s}
.pp-empty-prompt:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-tint)}

/* --- CONTRIBUTORS SECTION --- */
.pp-con-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.pp-con-item{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:10px}
.pp-con-info{flex:1;min-width:0}
.pp-con-name{font-size:12px;font-weight:600;color:var(--text);margin-right:6px}
.pp-con-email{font-size:10px;color:var(--text-3);margin-top:2px}
.pp-con-badge{display:inline-block;font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;margin-right:4px;text-transform:capitalize}
.pp-con-badge.primary{background:#D1FAE5;color:#065F46}
.pp-con-badge.role{background:#EEF2FF;color:#4338CA}
.pp-con-del{background:#FEF2F2;border:1px solid #FECACA;color:#DC2626;border-radius:5px;padding:2px 8px;font-size:11px;cursor:pointer;flex-shrink:0;transition:all .12s}
.pp-con-del:hover{background:#FEE2E2}

/* --- FEEDBACK FLOATING BUTTON & MODAL --- */
.fb-float-btn{position:fixed;bottom:24px;right:24px;z-index:1200;background:#1D4ED8;color:#fff;border:none;border-radius:50px;padding:9px 18px;font-size:12px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px rgba(29,78,216,.3);display:flex;align-items:center;gap:6px;transition:all .15s}
.fb-float-btn:hover{background:#1E40AF;transform:translateY(-1px)}
.fb-type-btn{padding:6px 13px;font-size:11px;font-weight:600;border:1px solid #E5E7EB;border-radius:20px;cursor:pointer;background:#F9FAFB;color:#374151;transition:all .12s}
.fb-type-btn.active{background:#1D4ED8;color:#fff;border-color:#1D4ED8}
.fb-type-btn:hover:not(.active){border-color:#93C5FD;color:#1E40AF}

/* --- BRAND --- */
.brand-dot{display:none} /* --- replaced by brand-mark --- */
/* --- VIEW HEADERS --- */
.view-hdr{padding:20px 24px 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.view-hdr-title{font-size:15px;font-weight:700;color:var(--text)}
.view-hdr-sub{font-size:11px;color:var(--text-3);margin-top:2px}
/* --- DATA STUDIO PAGE HDR --- */
.ds-page-hdr{padding:20px 24px 0;flex-shrink:0}
.ds-page-hdr-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:2px}
.ds-page-hdr-sub{font-size:11px;color:var(--text-3)}
/* --- EXPENSE TRACKER --- */
.exp-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.exp-hdr-text{flex:1}
.exp-hdr-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:1px}
.exp-hdr-sub{font-size:11px;color:var(--text-3)}
.exp-settings-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text);cursor:pointer;transition:all .12s}
.exp-settings-btn:hover{border-color:var(--blue);color:var(--blue)}
.exp-sync-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);background:var(--blue);color:#fff;border:none;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}
.exp-sync-btn:hover{background:var(--blue-hover)}
.exp-add-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;margin-bottom:8px;padding:14px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}
.exp-field{display:flex;flex-direction:column;gap:3px}
.exp-field-lbl{font-size:10px;font-weight:600;color:var(--text-3);letter-spacing:.7px;text-transform:uppercase}
.exp-msg{font-size:11px;min-height:14px;margin-bottom:8px;color:var(--green)}
.exp-totals{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.exp-total-card{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);padding:10px 16px;min-width:120px}
.exp-total-lbl{font-size:10px;font-weight:600;color:var(--text-3);letter-spacing:.8px;display:block;margin-bottom:4px;text-transform:uppercase}
.exp-total-val{font-size:18px;font-family:'DM Mono',monospace;color:var(--text);font-weight:700}
/* --- ADO SETTINGS PANEL --- */
#ado-settings-panel{display:none;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.ado-panel-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:12px}
.ado-fields{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.ado-field{display:flex;flex-direction:column;gap:3px;min-width:180px}
.ado-field.wide{flex:2;min-width:200px}
.ado-field.grow{flex:1}
.ado-field-lbl{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.7px}
.ado-footer{display:flex;gap:8px;align-items:center}
.ado-save-btn{padding:7px 16px;border-radius:var(--radius-sm);background:var(--blue);color:#fff;font-size:12px;font-weight:600;border:none;cursor:pointer;transition:background .15s}
.ado-save-btn:hover{background:var(--blue-hover)}
.ado-test-btn{padding:7px 14px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}
.ado-test-btn:hover{border-color:var(--green);color:var(--green)}
.ado-test-msg{font-size:11px;color:var(--green)}
.ado-hint{margin-top:10px;font-size:11px;color:var(--text-2);line-height:1.7;background:var(--surface);border-radius:var(--radius-sm);padding:10px 12px;border:1px solid var(--border)}
/* --- KB STATE ICONS (text-based) --- */
.kb-state-icon{width:48px;height:48px;border-radius:12px;background:var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:4px}
.kb-state-icon svg{display:block}
/* --- T-FOOTER hint --- */
.t-hint{color:var(--text-3)}
/* --- WEEKLY HDR sub --- */
.wk-hdr-inner{flex:1}

/* --- TEST NUDGE BUTTON --- */
.btn-nudge-test{padding:6px 13px;font-size:12px;font-weight:600;background:transparent;color:var(--text-2);border:1px solid var(--border);border-radius:var(--radius-sm);white-space:nowrap;cursor:pointer;transition:all .15s}
.btn-nudge-test:hover{background:var(--bg);color:var(--text);border-color:#9CA3AF}
.btn-nudge-test.sending{opacity:.6;pointer-events:none}

/* --- REMINDER SETTINGS MODAL --- */
.reminder-modal{background:var(--surface);border-radius:var(--radius-lg);width:680px;max-width:96vw;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.18)}
.reminder-modal-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.reminder-modal-body{flex:1;overflow-y:auto;padding:20px 24px}
.reminder-section-lbl{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.reminder-table{width:100%;border-collapse:collapse;font-size:12px}
.reminder-table th{text-align:left;padding:6px 10px;color:var(--text-3);font-weight:600;font-size:11px;border-bottom:1px solid var(--border);background:var(--bg)}
.reminder-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.reminder-table tr:last-child td{border-bottom:none}
.reminder-table tbody tr:hover td{background:var(--bg)}
.reminder-editable{border:none;background:transparent;width:100%;font-size:12px;color:var(--text);font-family:inherit;outline:none;padding:0}
.reminder-editable:focus{border-bottom:1px solid var(--blue)}
.reminder-toggle{width:34px;height:18px;background:#D1D5DB;border-radius:9px;border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;display:block}
.reminder-toggle.on{background:var(--green)}
.reminder-toggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:left .2s}
.reminder-toggle.on::after{left:18px}
.reminder-add-row{display:flex;gap:6px;align-items:center;margin-top:8px}
.reminder-inp{padding:6px 10px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;flex:1}
.reminder-inp:focus{border-color:var(--blue)}
.reminder-save-btn{padding:6px 14px;font-size:12px;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer}
.reminder-cancel-btn{padding:6px 10px;font-size:12px;color:var(--text-2);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}
.reminder-add-btn{margin-top:10px;font-size:12px;color:var(--blue);background:none;border:none;cursor:pointer;font-weight:500;padding:0}
.reminder-add-btn:hover{text-decoration:underline}


/* --- LOGIN SCREEN --- */
#login-screen{position:fixed;inset:0;z-index:9999;background:#EDF0F5;display:flex;align-items:center;justify-content:center;transition:opacity .3s}
#login-screen.hidden{opacity:0;pointer-events:none}
.login-card{background:#fff;border-radius:18px;padding:52px 56px;box-shadow:0 8px 40px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);text-align:center;max-width:420px;width:90vw}
.login-logo{font-family:'DM Sans',sans-serif;font-size:36px;font-weight:700;color:#1a1a2e;letter-spacing:-.5px;margin-bottom:2px}
.login-logo span{color:#E8590C}
.login-sub{font-size:11px;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;color:#9CA3AF;margin-bottom:28px}
.login-desc{font-size:14px;color:#6B7280;margin-bottom:32px;line-height:1.5}
.login-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:13px 36px;width:100%;max-width:320px;border-radius:8px;background:#1D4ED8;color:#fff;font-size:15px;font-weight:600;border:none;cursor:pointer;transition:background .15s,transform .1s;box-shadow:0 2px 8px rgba(29,78,216,.25)}
.login-btn:hover{background:#1A44C2;transform:translateY(-1px);box-shadow:0 4px 14px rgba(29,78,216,.3)}
.login-btn:active{transform:translateY(0)}
.login-btn svg{flex-shrink:0}
.user-pill{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);cursor:default;font-size:11px;color:rgba(255,255,255,.7)}
.user-avatar{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;letter-spacing:.5px}
.user-logout{padding:2px 8px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);font-size:10px;cursor:pointer;transition:all .15s}
.user-logout:hover{background:rgba(255,255,255,.12);color:#fff}
.login-error{margin-top:18px;font-size:12px;color:#DC2626;min-height:18px}
.login-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
#dashboard-wrap{display:none;flex-direction:column;flex:1;height:100%;overflow:hidden}
#dashboard-wrap.visible{display:flex}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── GRANOLA INTEGRATION ─────────────────────────────────────────────────── */
.granola-section{margin-top:28px;border-top:1px solid var(--border);padding-top:20px}
.granola-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.granola-section-title{font-size:13px;font-weight:700;color:var(--text-1)}
.granola-sync-btn{display:inline-flex;align-items:center;padding:7px 14px;background:#7C3AED;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}
.granola-sync-btn:hover{background:#6D28D9}
.granola-sync-btn:disabled{background:#9CA3AF;cursor:not-allowed}
.granola-sync-status{font-size:11px;color:var(--text-3)}
.granola-week{margin-bottom:20px}
.granola-week-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:10px}
.granola-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;position:relative}
.granola-card-hdr{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.granola-title{font-size:13px;font-weight:600;color:var(--text-1);flex:1}
.granola-date{font-size:11px;color:var(--text-3)}
.granola-link{font-size:11px;color:#7C3AED;text-decoration:none;font-weight:500}
.granola-link:hover{text-decoration:underline}
.granola-participants{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.granola-person{font-size:10px;padding:2px 8px;background:#EDE9FE;color:#6D28D9;border-radius:10px;font-weight:500}
.granola-summary{font-size:12px;color:var(--text-2);line-height:1.55;max-height:120px;overflow:hidden;mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}
.granola-actions{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.granola-actions-lbl{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:4px}
.granola-action{font-size:11.5px;color:var(--text-2);padding:2px 0}
.granola-use-btn{margin-top:10px;font-size:11px;font-weight:600;color:#7C3AED;background:none;border:1px solid #DDD6FE;border-radius:6px;padding:5px 12px;cursor:pointer;transition:all .15s}
.granola-use-btn:hover{background:#F5F3FF;border-color:#7C3AED}
.granola-empty{text-align:center;padding:32px 20px;color:var(--text-3);font-size:13px}
.modal-status.info{color:#6D28D9;background:#F5F3FF;border:1px solid #DDD6FE;padding:8px 12px;border-radius:6px;font-size:12px;display:block;margin-bottom:10px}
/* ── DEMO CALENDAR ───────────────────────────────────────────── */
.demos-wrap{padding:20px 24px;max-width:1100px;margin:0 auto}
.demos-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.demos-filters{display:flex;align-items:center;gap:6px;flex:1;flex-wrap:wrap}
.demos-view-toggle{display:flex;gap:4px;background:#F3F4F6;border-radius:7px;padding:3px}
.demos-view-toggle button{padding:5px 12px;font-size:11px;font-weight:600;border:none;border-radius:5px;cursor:pointer;background:none;color:var(--text-2);transition:all .12s}
.demos-view-toggle button.active{background:#fff;color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.demo-ev-card{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid #1D4ED8;border-radius:10px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:box-shadow .12s}
.demo-ev-card:hover{box-shadow:0 2px 10px rgba(0,0,0,.07)}
.demo-ev-left{flex-shrink:0}
.demo-ev-date{min-width:80px;text-align:center;padding:6px 10px;border-radius:7px;font-size:11px;font-weight:700;line-height:1.3}
.demo-ev-body{flex:1;min-width:0}
.demo-ev-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}
.demo-ev-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px}
.demo-ev-notes{font-size:11px;color:var(--text-3);line-height:1.4;margin-top:4px;max-height:36px;overflow:hidden}
.demo-ev-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
.demo-ev-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:13px;cursor:pointer;color:var(--text-2);transition:all .12s;text-decoration:none;display:inline-flex;align-items:center}
.demo-ev-btn:hover{background:var(--bg);border-color:#9CA3AF}
/* Calendar view */
.dcal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dcal-nav{background:none;border:1px solid var(--border);border-radius:6px;padding:5px 10px;cursor:pointer;font-size:14px;color:var(--text-2);transition:all .12s}
.dcal-nav:hover{background:var(--surface);color:var(--text)}
.dcal-month{font-size:14px;font-weight:700;color:var(--text)}
.dcal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dcal-dow{text-align:center;font-size:10px;font-weight:700;color:var(--text-3);padding:4px 0;text-transform:uppercase;letter-spacing:.05em}
.dcal-cell{min-height:72px;border:1px solid var(--border);border-radius:6px;padding:5px;background:var(--surface);cursor:default;transition:background .1s}
.dcal-cell.empty{background:transparent;border-color:transparent}
.dcal-cell.today{border-color:#1D4ED8;background:#EFF2FE}
.dcal-day{font-size:11px;font-weight:600;color:var(--text-2);margin-bottom:3px}
.dcal-cell.today .dcal-day{color:#1D4ED8}
.dcal-events{display:flex;gap:2px;flex-wrap:wrap;margin-bottom:3px}
.dcal-dot{width:7px;height:7px;border-radius:50%}
.dcal-evlist{display:flex;flex-direction:column;gap:2px}
.dcal-ev-pill{font-size:10px;padding:1px 5px;border-radius:3px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.dcal-ev-pill:hover{filter:brightness(.95)}
/* Demo modal */
.demo-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px;grid-column:span 2;width:100%}
.demo-modal-grid .full{grid-column:span 2}
.demo-modal-grid .modal-status{grid-column:span 2}
/* Portfolio widget upgrade */
.demo-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}

