@import url("./calculator-form-fields.css");

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p:#7B52CC;--pl:#EDE8F9;--pm:#C4B3EF;--pd:#4A2E8A;
  --n:#2D3680;--nl:#E8EAF4;
  --t:#7B52CC;--tl:#EDE8F9;--td:#4A2E8A;
  --bg:var(--color-background-tertiary,#F4F3FA);
  --card:var(--color-background-primary,#fff);
  --border:var(--color-border-tertiary,rgba(0,0,0,0.12));
  --txt:var(--color-text-primary,#1C1B2E);
  --txt2:var(--color-text-secondary,#5A5870);
  --txt3:var(--color-text-tertiary,#9896B0);
}
html,body{height:100%;font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:#F4F3FA;color:#1C1B2E;}

.app{display:flex;height:100vh;overflow:hidden;}

/* SIDEBAR */
.sb{width:210px;background:#fff;border-right:1px solid rgba(0,0,0,0.1);display:flex;flex-direction:column;flex-shrink:0;height:100vh;transition:width 0.2s ease,margin-left 0.2s ease;}
/* v70b: Collapsible sidebars. When collapsed, panel slides away (margin-left negative)
   so the main content gets the space back. A floating toggle button stays visible. */
.sb.collapsed{margin-left:-210px;}
.bos-nav.collapsed{margin-left:-180px;}
.sb-toggle-btn{position:fixed;top:14px;left:14px;z-index:600;width:28px;height:28px;border-radius:7px;background:#7B52CC;color:white;border:none;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.15);display:none;align-items:center;justify-content:center;transition:background 0.15s;}
.sb-toggle-btn:hover{background:#6A45B8;}
.sb-toggle-btn.visible{display:flex;}
.bos-nav-toggle{position:absolute;top:8px;right:-28px;width:22px;height:36px;border-radius:0 7px 7px 0;background:#7B52CC;color:white;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:50;box-shadow:2px 0 4px rgba(0,0,0,0.08);transition:background 0.15s;}
.bos-nav-toggle:hover{background:#6A45B8;}
.sb-brand{padding:0.875rem;border-bottom:1px solid rgba(0,0,0,0.08);display:flex;align-items:center;gap:8px;}
.sb-brand svg{width:34px;height:34px;flex-shrink:0;}
#brandLogoImg{display:none!important;}
.sb-platform-brand{flex:1;min-width:0;}
.sb-brand-name{font-size:15px;font-weight:600;color:#1C1B2E;}
.sb-brand-sub{font-size:10px;color:#25318D;letter-spacing:0;text-transform:none;font-weight:700;}
.mypracticehq-main{font-weight:800;color:#25318D;letter-spacing:0;}
.mypracticehq-blue{color:#25318D;}
.mypracticehq-purple{color:#7B52CC;}
.mypracticehq-by{font-size:11px;font-weight:700;color:#25318D;line-height:1.2;}
.sb-brand-name.mypracticehq-main{font-size:15px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-client{padding:0.625rem 0.875rem;border-bottom:1px solid rgba(0,0,0,0.08);}
.sb-client-row{display:flex;align-items:center;gap:7px;margin-bottom:6px;}
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:white;flex-shrink:0;background:#7B52CC;}
/* v109b.8: Force monochrome purple avatars globally. Overrides inline backgrounds. */
.av, span.av, div.av { background:#7B52CC !important; color:#FFFFFF !important; }
.sb-client-name{font-size:13px;font-weight:500;color:#1C1B2E;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-client-sub{font-size:11px;color:#9896B0;}
.plan-badge{display:inline-flex;align-items:center;background:#7B52CC;border-radius:5px;padding:2px 7px;}
.plan-badge span{font-size:11px;font-weight:500;color:white;}
.sb-nav{flex:1;overflow-y:auto;padding:0.5rem;}
.sb-lbl{font-size:11px;color:#9896B0;padding:4px 8px 2px;letter-spacing:0.06em;text-transform:uppercase;}
.ivms-os-sidebar-heading{font-size:12px;font-weight:800;letter-spacing:0;text-transform:none;color:#25318D;padding-top:9px;}
.ivms-os-blue{color:#25318D;}
.ivms-os-purple{color:#7B52CC;}
.ivms-os-pro-sidebar-heading{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:0;text-transform:none;color:#25318D;padding-top:9px;}
.ivms-os-pro-sidebar-badge{font-size:8px;line-height:1;background:#2D3680;color:white;padding:2px 5px;border-radius:8px;font-weight:700;letter-spacing:0;}
.ni{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;cursor:pointer;color:#5A5870;font-size:14px;transition:all 0.15s;user-select:none;}
.ni:hover{background:#F4F3FA;color:#1C1B2E;}
.ni.active{background:#7B52CC;color:white;font-weight:500;}
.community-channel-ni{margin-left:26px;padding:6px 9px;font-size:13px;line-height:1.15;min-height:30px;}
.ivms-sidebar-teaser-list{margin:2px 0 7px 26px;display:grid;gap:4px;}
.ivms-sidebar-teaser-item{display:flex;align-items:center;justify-content:space-between;gap:7px;padding:5px 7px;border-radius:6px;color:#5A5870;font-size:11px;line-height:1.2;cursor:pointer;opacity:.74;}
.ivms-sidebar-teaser-item:hover{background:#F4F3FA;color:#1C1B2E;opacity:1;}
.ivms-sidebar-teaser-item span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ivms-sidebar-teaser-pill{font-size:8px;font-weight:800;color:#4A2E8A;background:#EDE8F9;border-radius:999px;padding:2px 5px;flex-shrink:0;}
.sb-div{height:1px;background:rgba(0,0,0,0.07);margin:6px 4px;}
.sb-footer{padding:0.625rem;border-top:1px solid rgba(0,0,0,0.08);}
.admin-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.admin-lbl{font-size:12px;font-weight:500;color:#5A5870;}
.toggle{width:30px;height:17px;background:#ccc;border-radius:9px;cursor:pointer;position:relative;transition:background 0.2s;flex-shrink:0;}
.toggle.on{background:#7B52CC;}
.toggle-thumb{position:absolute;top:2px;left:2px;width:13px;height:13px;border-radius:50%;background:white;transition:transform 0.2s;}
.toggle.on .toggle-thumb{transform:translateX(13px);}
.cs-wrap{display:none;border-top:1px solid rgba(0,0,0,0.08);padding-top:6px;}
.cs-wrap.show{display:block;}
.cs-lbl{font-size:11px;color:#9896B0;margin-bottom:4px;text-transform:uppercase;letter-spacing:0.05em;}
#csClinicList{position:relative;}
.practice-directory-sidebar-trigger{width:100%;min-height:38px;align-items:center;gap:7px;border:1px solid #E2DDF1;background:#fff;color:#343049;text-align:left;}
.practice-directory-sidebar-trigger:hover{border-color:#BDA8EE;background:#FBFAFF;color:#1C1B2E;}
.practice-directory-sidebar-trigger.active{background:#7B52CC;border-color:#7B52CC;color:#fff;}
.practice-directory-sidebar-trigger .practice-selector-current{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.2;}
.practice-directory-sidebar-trigger.active .practice-row-action{color:#fff;}
.practice-directory-sidebar-trigger.active .practice-row-action:hover{background:rgba(255,255,255,0.16);color:#fff;}
.practice-selector{position:relative;}
.practice-selector-trigger{width:100%;min-height:36px;display:flex;align-items:center;gap:7px;padding:7px 8px;border:1px solid #E2DDF1;border-radius:8px;background:#fff;color:#343049;font-size:12px;text-align:left;cursor:pointer;}
.practice-selector-trigger:hover{border-color:#BDA8EE;background:#FBFAFF;}
.practice-selector-current{min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;}
.practice-selector-caret{color:#7B52CC;font-size:10px;line-height:1;}
.practice-selector-menu{display:none;position:absolute;left:0;right:0;bottom:calc(100% + 6px);max-height:360px;overflow:auto;z-index:1000;padding:8px;background:#fff;border:1px solid #D8CEF6;border-radius:10px;box-shadow:0 16px 36px rgba(28,27,46,0.18);}
.practice-selector.open .practice-selector-menu{display:block;}
.practice-selector-search{width:100%;height:30px;border:1px solid #E2DDF1;border-radius:7px;padding:0 8px;margin-bottom:8px;font-size:12px;color:#343049;background:#fff;}
.practice-selector-section-title{padding:6px 4px 4px;font-size:10px;color:#9896B0;text-transform:uppercase;letter-spacing:0.06em;}
.practice-selector-empty{padding:9px 8px;font-size:11px;color:#9896B0;}
.practice-plan-pill,.practice-lifecycle-pill{font-size:8px;color:#9896B0;background:#F4F3FA;padding:1px 5px;border-radius:6px;white-space:nowrap;text-transform:lowercase;}
.practice-lifecycle-pill{color:#9A6500;background:#FFF3D5;}
.practice-row-action{width:20px;height:20px;border-radius:4px;background:transparent;border:none;cursor:pointer;color:#9896B0;font-size:14px;flex-shrink:0;}
.practice-row-action:hover{background:#F4F3FA;color:#7B52CC;}
.practice-selector-trigger-action{display:inline-flex;align-items:center;justify-content:center;}
.practice-pin-button{width:20px;height:20px;border-radius:4px;background:transparent;border:none;cursor:pointer;color:#B8B3C8;font-size:14px;line-height:1;flex-shrink:0;}
.practice-pin-button:hover{background:#F4F3FA;color:#7B52CC;}
.practice-pin-button.is-pinned{color:#7B52CC;background:#EDE8F9;}
.cs-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:6px;cursor:pointer;font-size:13px;color:#5A5870;}
.cs-item:hover{background:#F4F3FA;}
.cs-item.on{background:#EDE8F9;color:#4A2E8A;font-weight:500;}
.cs-item.is-archived{cursor:default;opacity:0.82;}
.cs-item.is-archived:hover{background:transparent;}
.cs-dot{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:7px;color:white;font-weight:600;flex-shrink:0;}
.cs-move-btn{width:17px;height:17px;border-radius:4px;background:transparent;border:1px solid transparent;color:#9896B0;font-size:10px;line-height:1;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
.cs-move-btn:hover{background:white;border-color:#D8CEF6;color:#7B52CC;}
.cs-item-name{min-width:0;overflow:hidden;text-overflow:ellipsis;}
.practice-directory-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;}
.practice-directory-add{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border:1px solid #7B52CC;border-radius:7px;background:#7B52CC;color:#fff;font-size:12px;font-weight:600;cursor:pointer;}
.practice-directory-add:hover{background:#6A45B8;border-color:#6A45B8;}
.practice-directory-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px;max-width:520px;}
.practice-directory-search{width:100%;height:34px;border:1px solid #D8CEF6;border-radius:8px;background:#fff;color:#1C1B2E;font-size:13px;padding:0 10px;}
.practice-directory-search:focus{outline:none;border-color:#7B52CC;box-shadow:0 0 0 3px rgba(123,82,204,0.12);}
.practice-directory-content{display:grid;gap:14px;max-width:920px;}
.practice-directory-section{display:grid;gap:8px;}
.practice-directory-section-title{font-size:10px;color:#9896B0;text-transform:uppercase;letter-spacing:0.07em;font-weight:700;padding:0 2px;}
.practice-directory-row{display:flex;align-items:center;gap:10px;padding:11px 12px;border:1px solid rgba(0,0,0,0.09);border-radius:8px;background:#fff;color:#343049;min-height:58px;}
.practice-directory-row:hover{border-color:#C4B3EF;background:#FBFAFF;}
.practice-directory-row.on{border-color:#7B52CC;background:#F8F4FF;color:#1C1B2E;font-weight:400;}
.practice-directory-row.is-switching{border-color:#7B52CC;background:#F4F0FF;box-shadow:0 0 0 2px rgba(123,82,204,0.08) inset;}
.practice-directory-row.is-archived{cursor:default;opacity:0.8;}
.practice-directory-row.is-archived:hover{background:#fff;border-color:rgba(0,0,0,0.09);}
.practice-directory-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;}
.practice-directory-copy{min-width:0;flex:1;}
.practice-directory-name{font-size:13px;font-weight:700;color:#1C1B2E;line-height:1.25;word-break:break-word;}
.practice-directory-meta{font-size:11px;color:#9896B0;margin-top:2px;line-height:1.3;}
.practice-directory-actions{display:flex;align-items:center;gap:5px;flex-shrink:0;}
.practice-directory-open{padding:5px 9px;border:1px solid #D8CEF6;border-radius:6px;background:#fff;color:#4A2E8A;font-size:11px;font-weight:600;cursor:pointer;}
.practice-directory-open:hover{border-color:#7B52CC;background:#EDE8F9;}
.practice-directory-open:disabled{opacity:0.55;cursor:not-allowed;}
.practice-current-pill{font-size:10px;font-weight:700;color:#4A2E8A;background:#EDE8F9;border-radius:999px;padding:3px 7px;white-space:nowrap;}
.practice-switching-pill{color:#1E7B4B;background:#E4F8EC;}
.practice-directory-empty{padding:16px;border:1px dashed #D8CEF6;border-radius:8px;background:#fff;color:#9896B0;font-size:12px;}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;overflow:hidden;}
.topbar{background:#fff;border-bottom:1px solid rgba(0,0,0,0.08);padding:0 1.25rem;height:48px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.topbar-title{font-size:14px;font-weight:500;color:white;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.live-dot{display:flex;align-items:center;gap:5px;}
.live-dot .dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.7);}
.live-dot span{font-size:11px;color:rgba(255,255,255,0.7);}
.content{flex:1;overflow-y:auto;overflow-x:hidden;}

/* VIEWS */
.view{display:none;padding:1.25rem;}
.view.show{display:block;}
#v-bos.show{display:flex !important;}
#v-calcs.show{display:flex !important;flex-direction:column;height:calc(100vh - 48px);}

/* CALC VIEW */
#v-calcs{padding:0;}
.calc-cards-view{padding:1.25rem;}
.calc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.calc-header p{font-size:12px;color:#5A5870;}
.calc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;}
.calc-card{background:#fff;border:1px solid rgba(0,0,0,0.1);border-radius:12px;padding:1.1rem;cursor:pointer;transition:all 0.15s;}
.calc-card:hover{border-color:#C4B3EF;box-shadow:0 2px 12px rgba(123,82,204,0.12);transform:translateY(-1px);}
.calc-card-icon{width:36px;height:36px;border-radius:9px;background:#EDE8F9;display:flex;align-items:center;justify-content:center;margin-bottom:10px;}
.calc-card-title{font-size:13px;font-weight:600;color:#1C1B2E;margin-bottom:3px;}
.calc-card-sub{font-size:11px;color:#9896B0;margin-bottom:10px;line-height:1.4;}
.active-badge{font-size:10px;background:#EDE8F9;color:#4A2E8A;padding:2px 8px;border-radius:20px;display:inline-block;}

/* CALC EMBEDDED VIEW */
.calc-embed-view{display:none;height:calc(100vh - 48px);flex-direction:column;}
.calc-embed-view.show{display:flex;}
.calc-embed-topbar{background:#fff;border-bottom:1px solid rgba(0,0,0,0.08);padding:0 1.25rem;height:44px;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.back-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;background:#EDE8F9;color:#4A2E8A;border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:background 0.15s;}
.back-btn:hover{background:#C4B3EF;}
.calc-embed-title{font-size:13px;font-weight:500;color:#1C1B2E;}
.calc-iframe{flex:1;border:none;width:100%;height:100%;}

/* BOS WRAP */
.bos-wrap{display:flex;height:calc(100vh - 48px);width:100%;}
.bos-nav{width:180px;background:#fff;border-right:1px solid rgba(0,0,0,0.08);padding:0.5rem 0;display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;transition:margin-left 0.2s ease;position:relative;}
.bos-nav-hdr{padding:8px 14px 10px;border-bottom:1px solid rgba(0,0,0,0.08);margin-bottom:6px;}
.bos-nav-hdr .title{font-size:13px;font-weight:600;color:#7B52CC;}
.bos-nav-hdr .title.ivms-os-title{font-weight:800;letter-spacing:0;color:#25318D;}
.bos-nav-hdr .sub{font-size:12px;color:#9896B0;}
.bni{display:flex;align-items:center;gap:8px;padding:8px 14px;cursor:pointer;color:#5A5870;font-size:14px;border-left:2px solid transparent;transition:all 0.15s;user-select:none;}
.bni:hover{background:#EDE8F9;color:#4A2E8A;}
.bni.active{color:#7B52CC;font-weight:500;border-left-color:#7B52CC;background:#EDE8F9;}
.bni svg{flex-shrink:0;opacity:0.6;}
.bni.active svg{opacity:1;}
.bnhr{height:1px;background:rgba(0,0,0,0.07);margin:5px 0;}
.bos-content{flex:1;min-width:0;overflow:auto;padding:1.1rem 1.5rem;background:#F4F3FA;scrollbar-width:none;}
.bos-content::-webkit-scrollbar{display:none;}
.bos-nav::-webkit-scrollbar{display:none;}
.bos-nav{scrollbar-width:none;}
.bos-mobile-seg-btn{display:none;}
.os-mobile-team-switcher{display:none;}
.bp{display:none;}.bp.show{display:block;}
.pg-title{font-size:19px;font-weight:600;color:#1C1B2E;margin-bottom:2px;}
.pg-sub{font-size:13px;color:#9896B0;margin-bottom:1rem;}
.card{background:#fff;border:1px solid rgba(0,0,0,0.09);border-radius:11px;padding:1rem;}
.tabs{display:flex;border-bottom:1px solid rgba(0,0,0,0.09);margin-bottom:1rem;}
.tb{padding:7px 14px;font-size:12px;color:#5A5870;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;}
.tb.active{color:#7B52CC;border-bottom-color:#7B52CC;font-weight:500;}
.tc{display:none;}.tc.show{display:block;}
.bon{background:#EDE8F9;color:#4A2E8A;font-size:10px;padding:2px 8px;border-radius:20px;display:inline-block;white-space:nowrap;flex-shrink:0;}
.boff{background:#FCEBEB;color:#A32D2D;font-size:10px;padding:2px 8px;border-radius:20px;display:inline-block;white-space:nowrap;flex-shrink:0;}
.bdone{background:#EAF3DE;color:#3B6D11;font-size:10px;padding:2px 8px;border-radius:20px;display:inline-block;white-space:nowrap;flex-shrink:0;}
.tbl{width:100%;border-collapse:collapse;font-size:11px;}
.tbl th{padding:7px 10px;font-size:10px;font-weight:500;color:#9896B0;border-bottom:1px solid rgba(0,0,0,0.09);text-align:left;background:#F4F3FA;}
.tbl td{padding:7px 10px;border-bottom:1px solid rgba(0,0,0,0.07);color:#1C1B2E;}
.tbl tr:last-child td{border-bottom:none;}
.cr{background:#FCEBEB;color:#C0392B;text-align:center;}
.cg{background:#EAF3DE;color:#3B6D11;text-align:center;}
.cn{text-align:center;color:#9896B0;}
.bav{border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:600;color:white;background:#7B52CC;flex-shrink:0;}
.bav-t{background:#7B52CC;}
.bav-n{background:#2D3680;}
.prog{height:4px;background:#E4E1F0;border-radius:3px;overflow:hidden;min-width:70px;}
.prog-f{height:100%;background:#7B52CC;border-radius:3px;}
.swot-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.si{padding:5px 9px;background:#F4F3FA;border-radius:6px;font-size:11px;margin-bottom:4px;color:#1C1B2E;}
.org-node{background:#fff;border:1px solid rgba(0,0,0,0.09);border-radius:11px;padding:0.875rem;min-width:130px;text-align:center;}
.res-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:10px;}
.res-card{background:#fff;border:1px solid rgba(0,0,0,0.09);border-radius:11px;padding:1rem;cursor:pointer;}
.res-card:hover{border-color:#C4B3EF;}
.post-card{background:#fff;border:1px solid rgba(0,0,0,0.09);border-radius:11px;padding:1rem;margin-bottom:10px;max-width:680px;}
.event-row{display:flex;align-items:flex-start;gap:12px;padding:0.75rem 0;border-bottom:1px solid rgba(0,0,0,0.07);}
.event-row:last-child{border-bottom:none;}
.evbadge{font-size:10px;padding:2px 8px;border-radius:20px;white-space:nowrap;}

/* hub */

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p:#7B52CC;--pl:#EDE8F9;--pm:#C4B3EF;--pd:#4A2E8A;
  --n:#2D3680;--nl:#E8EAF4;
  --g:#7B52CC;--gl:#EDE8F9;--gd:#4A2E8A;
  --border:#E4DFF5;--bg:#F7F5FD;
  --warn:#F57C00;--warnl:#FFF3E0;
  --err:#C62828;--errl:#FEEBEE;
  --ok:#2E7D32;--okl:#E8F5E9;
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);font-size:13px;display:flex;flex-direction:column;height:100vh;overflow:hidden;}

/* ─── TOP BAR ─── */
.topbar{background:var(--p);color:white;padding:10px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.topbar-title{font-size:15px;font-weight:700;letter-spacing:0.02em;}
.topbar-sub{font-size:10px;opacity:0.7;margin-top:1px;}
.country-btn{padding:4px 12px;font-size:11px;font-weight:600;cursor:pointer;color:rgba(255,255,255,0.65);border:none;background:transparent;border-radius:20px;transition:all 0.15s;}
.country-btn.active{background:white;color:var(--p);}
.country-wrap{background:rgba(255,255,255,0.15);border-radius:20px;display:flex;}

/* ─── LAYOUT ─── */
.shell{display:flex;flex:1;overflow:hidden;}

/* ─── LEFT SIDEBAR ─── */
.lnav{width:210px;background:white;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;}
.lnav-head{padding:12px 14px 8px;font-size:9px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:0.08em;border-bottom:1px solid var(--border);}
.model-card{padding:10px 14px;cursor:pointer;border-left:3px solid transparent;transition:all 0.15s;border-bottom:0.5px solid var(--border);}
.model-card:hover{background:var(--pl);border-left-color:var(--pm);}
.model-card.active{background:var(--pl);border-left-color:var(--p);}
.mc-name{font-size:12px;font-weight:700;color:#2a2a2a;}
.model-card.active .mc-name{color:var(--p);}
.mc-desc{font-size:10px;color:#888;margin-top:2px;line-height:1.4;}
.mc-badge{display:inline-block;font-size:9px;font-weight:700;padding:1px 7px;border-radius:10px;margin-top:4px;}
.badge-prosal{background:var(--pl);color:var(--pd);}
.badge-salary{background:var(--nl);color:var(--n);}
.badge-prod{background:var(--gl);color:var(--gd);}
.badge-base{background:#FFF3E0;color:#E65100;}
.badge-blend{background:#F3E5F5;color:#6A1B9A;}

/* ─── MAIN CONTENT ─── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.model-page{display:none;flex:1;flex-direction:column;overflow:hidden;}
.model-page.active{display:flex;}

/* ─── TABS ─── */
.tabs{background:white;border-bottom:1px solid var(--border);padding:0 18px;display:flex;gap:0;flex-shrink:0;}
.tab{padding:9px 16px;font-size:12px;cursor:pointer;color:#888;border-bottom:2.5px solid transparent;transition:all 0.15s;}
.tab.active{color:var(--p);border-bottom-color:var(--p);font-weight:700;}

/* ─── CALC CONTENT ─── */
.calc-scroll{flex:1;overflow-y:auto;padding:16px 18px;}
.pg{display:none;}.pg.active{display:block;}

/* ─── SECTION CARDS ─── */
.sec{background:white;border-radius:10px;border:1px solid var(--border);padding:14px 16px;margin-bottom:12px;}
.sec-title{font-size:10px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:0.07em;padding-bottom:7px;border-bottom:2px solid var(--pl);margin-bottom:10px;}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.four-col{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:12px;margin-bottom:12px;}

/* ─── FIELDS ─── */
.field{display:flex;align-items:center;padding:4px 0;border-bottom:0.5px solid #f5f2fc;gap:6px;}
.field:last-child{border-bottom:none;}
.fl{font-size:11px;color:#555;flex:1;line-height:1.4;}
.step{font-size:9px;font-weight:700;color:var(--p);opacity:0.55;display:block;}
.fv{background:white;border:1.5px solid var(--pm);border-radius:5px;padding:4px 7px;font-size:12px;font-weight:500;color:#2a2a2a;text-align:right;width:120px;transition:border-color 0.15s,box-shadow 0.15s;}
.fv:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px rgba(123,82,204,0.12);}
select.fv{text-align:left;cursor:pointer;}
.cv{background:var(--pl);border-radius:5px;padding:4px 8px;font-size:12px;font-weight:600;color:var(--pd);text-align:right;min-width:120px;font-variant-numeric:tabular-nums;}
.cv.g{background:var(--gl);color:var(--gd);}
.cv.hi{background:var(--p);color:white;}
.cv.warn{background:var(--warnl);color:var(--warn);}
.cv.err{background:var(--errl);color:var(--err);}
.cv.ok{background:var(--okl);color:var(--ok);}
.divider{height:1px;background:var(--border);margin:8px 0;}
.sub-label{font-size:9px;font-weight:700;color:var(--p);opacity:0.6;margin:8px 0 4px;text-transform:uppercase;letter-spacing:0.05em;}

/* ─── ALERT BOX ─── */
.alert{border-radius:8px;padding:10px 14px;font-size:11px;line-height:1.6;margin-bottom:12px;display:flex;gap:8px;align-items:flex-start;}
.alert-warn{background:var(--warnl);color:#5D2C00;}
.alert-info{background:var(--gl);color:var(--gd);}

/* ─── TRACKER TABLE ─── */
.tbl-wrap{background:white;border-radius:10px;border:1px solid var(--border);overflow-x:auto;margin-bottom:12px;}
.tbl{border-collapse:collapse;min-width:900px;width:100%;font-size:11px;}
.tbl th{background:var(--p);color:white;padding:6px 8px;text-align:center;font-weight:600;white-space:nowrap;}
.tbl th.qh{background:var(--pd);}
.tbl th.yh{background:#1a1a3e;}
.tbl th.lh{text-align:left;min-width:140px;}
.tbl td{padding:5px 7px;border-bottom:0.5px solid #f0eefa;white-space:nowrap;}
.tbl td.lbl{font-weight:600;color:#444;background:#faf9ff;border-right:1px solid var(--border);}
.tbl td.inp{background:white;}
.tbl td.cal{background:var(--pl);color:var(--pd);font-weight:500;text-align:right;}
.tbl td.qc{background:#ddd8f8;color:var(--pd);font-weight:600;text-align:right;}
.tbl td.yc{background:#2a2a4a;color:white;font-weight:700;text-align:right;}
.tbl td.bon{background:var(--gl);color:var(--gd);font-weight:600;text-align:right;}
input.ti{border:1px solid var(--pm);border-radius:3px;padding:2px 5px;font-size:11px;width:85px;text-align:right;}
input.ti:focus{outline:none;border-color:var(--p);}

/* ─── REF BOX ─── */
.ref-box{background:white;border-radius:10px;border:1px solid var(--border);padding:16px;max-width:760px;margin-bottom:12px;}
.ref-title{font-size:13px;font-weight:700;color:var(--p);margin-bottom:10px;}
.ref-body{font-size:12px;line-height:1.7;color:#444;}
.mult-tbl{width:100%;border-collapse:collapse;font-size:12px;margin-top:10px;}
.mult-tbl th{background:var(--pl);color:var(--pd);padding:6px 10px;text-align:left;font-weight:600;}
.mult-tbl td{padding:5px 10px;border-bottom:0.5px solid var(--border);}
.highlight-box{border-radius:8px;padding:12px 14px;margin:10px 0;font-size:12px;line-height:1.7;}

/* bonus */

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p:#7B52CC;--pl:#EDE8F9;--pm:#C4B3EF;--pd:#4A2E8A;
  --n:#2D3680;--nl:#E8EAF4;
  --g:#7B52CC;--gl:#EDE8F9;--gd:#4A2E8A;
  --border:#E4DFF5;--bg:#F7F5FD;
  --warn:#F57C00;--warnl:#FFF3E0;
  --ok:#2E7D32;--okl:#E8F5E9;
  --err:#C62828;--errl:#FEEBEE;
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);font-size:13px;min-height:100vh;}
.hdr{background:var(--p);color:white;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;}
.hdr-title{font-size:16px;font-weight:700;}
.hdr-sub{font-size:10px;opacity:0.7;margin-top:2px;}
.tabs{background:white;border-bottom:1px solid var(--border);padding:0 24px;display:flex;}
.tab{padding:10px 18px;font-size:12px;cursor:pointer;color:#888;border-bottom:2.5px solid transparent;transition:all 0.15s;}
.tab.active{color:var(--p);border-bottom-color:var(--p);font-weight:700;}
.pg{display:none;padding:20px 24px;}.pg.active{display:block;}
.sec{background:white;border-radius:10px;border:1px solid var(--border);padding:16px;margin-bottom:14px;box-shadow:0 1px 3px rgba(123,82,204,0.05);}
.sec-title{font-size:11px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:0.07em;border-bottom:2px solid var(--pl);padding-bottom:7px;margin-bottom:12px;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.grid4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px;}
.field{display:flex;align-items:center;padding:5px 0;border-bottom:0.5px solid #f5f2fc;gap:8px;}
.field:last-child{border-bottom:none;}
.fl{font-size:11px;color:#555;flex:1;line-height:1.4;}
.step-tag{font-size:9px;font-weight:700;color:var(--p);opacity:0.55;display:block;margin-bottom:1px;}
input.fv,select.fv{background:white;border:1.5px solid var(--pm);border-radius:5px;padding:4px 7px;font-size:12px;font-weight:500;color:#2a2a2a;text-align:right;width:130px;transition:border-color 0.15s;}
input.fv:focus,select.fv:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px rgba(123,82,204,0.1);}
select.fv{text-align:left;cursor:pointer;}
.cv{background:var(--pl);border-radius:5px;padding:4px 8px;font-size:12px;font-weight:600;color:var(--pd);text-align:right;min-width:130px;font-variant-numeric:tabular-nums;}
.cv.hi{background:var(--p);color:white;}
.cv.g{background:var(--gl);color:var(--gd);}
.cv.ok{background:var(--okl);color:var(--ok);}
.cv.warn{background:var(--warnl);color:var(--warn);}
.cv.err{background:var(--errl);color:var(--err);}
.divider{height:1px;background:var(--border);margin:8px 0;}
.sub-lbl{font-size:9px;font-weight:700;color:var(--p);opacity:0.6;margin:8px 0 4px;text-transform:uppercase;letter-spacing:0.05em;}

/* Goals table */
.goals-tbl{width:100%;border-collapse:collapse;font-size:12px;}
.goals-tbl th{background:var(--p);color:white;padding:7px 10px;text-align:left;font-weight:600;}
.goals-tbl td{padding:5px 8px;border-bottom:0.5px solid var(--border);}
.goals-tbl tr:last-child td{border-bottom:none;}
.yn-input{width:60px;border:1.5px solid var(--pm);border-radius:5px;padding:4px 6px;font-size:12px;font-weight:600;text-align:center;text-transform:uppercase;}
.yn-input:focus{outline:none;border-color:var(--p);}
.yn-y{background:#E8F5E9;color:#2E7D32;border-color:#81C784;}
.yn-n{background:var(--errl);color:var(--err);border-color:#E57373;}
.goal-name-inp{width:100%;border:1px solid var(--border);border-radius:5px;padding:4px 8px;font-size:12px;background:white;color:#2a2a2a;}
.goal-name-inp:focus{outline:none;border-color:var(--p);}

/* Trigger status */
.trigger-box{border-radius:10px;padding:16px;margin-bottom:14px;display:flex;gap:16px;align-items:center;}
.trigger-box.triggered{background:var(--okl);border:1px solid #81C784;}
.trigger-box.not-triggered{background:var(--errl);border:1px solid #E57373;}
.trigger-box.pending{background:var(--warnl);border:1px solid #FFB74D;}
.trigger-num{font-size:36px;font-weight:700;}
.trigger-info{flex:1;}

/* Tier table */
.tier-tbl{width:100%;border-collapse:collapse;font-size:12px;}
.tier-tbl th{background:var(--pl);color:var(--pd);padding:6px 10px;text-align:left;font-weight:600;}
.tier-tbl td{padding:5px 10px;border-bottom:0.5px solid var(--border);vertical-align:middle;}
.tier-tbl tr:last-child td{border-bottom:none;}
input.tier-inp{width:70px;border:1.5px solid var(--pm);border-radius:4px;padding:3px 6px;font-size:12px;font-weight:500;text-align:right;}
input.tier-inp:focus{outline:none;border-color:var(--p);}

/* Employee table */
.emp-wrap{overflow-x:auto;margin-bottom:14px;}
.emp-tbl{border-collapse:collapse;font-size:11px;min-width:900px;width:100%;}
.emp-tbl th{background:var(--p);color:white;padding:7px 8px;text-align:center;font-weight:600;white-space:nowrap;}
.emp-tbl th.lh{text-align:left;}
.emp-tbl td{padding:5px 6px;border-bottom:0.5px solid var(--border);vertical-align:middle;white-space:nowrap;}
.emp-tbl tr:hover td{background:#faf9ff;}
.emp-tbl td.cal{background:var(--pl);color:var(--pd);font-weight:500;text-align:right;}
.emp-tbl td.bonus{background:var(--gl);color:var(--gd);font-weight:700;text-align:right;}
.emp-tbl td.totrow{background:#2a2a4a;color:white;font-weight:700;text-align:right;}
input.ei{border:1px solid var(--pm);border-radius:4px;padding:3px 5px;font-size:11px;width:100%;}
input.ei:focus{outline:none;border-color:var(--p);}
input.ei-date{width:110px;}
input.ei-name{width:130px;}
input.ei-hours{width:65px;text-align:right;}
.btn-add{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--p);border:1px dashed var(--pm);border-radius:6px;padding:6px 14px;background:transparent;cursor:pointer;margin-top:8px;}
.btn-add:hover{background:var(--pl);}
.btn-del{width:22px;height:22px;border-radius:4px;border:none;background:transparent;cursor:pointer;color:#ccc;font-size:14px;line-height:1;}
.btn-del:hover{color:var(--err);background:var(--errl);}

/* Hours tracker table */
.ht-wrap{overflow-x:auto;margin-bottom:14px;}
.ht-tbl{border-collapse:collapse;font-size:11px;min-width:800px;width:100%;}
.ht-tbl th{background:var(--n);color:white;padding:6px 8px;text-align:center;font-weight:600;white-space:nowrap;}
.ht-tbl th.grp{background:var(--pd);}
.ht-tbl td{padding:5px 7px;border-bottom:0.5px solid var(--border);vertical-align:middle;white-space:nowrap;}
.ht-tbl td.lbl{font-weight:600;background:#faf9ff;color:#444;border-right:1px solid var(--border);}
.ht-tbl td.cal{background:var(--pl);color:var(--pd);font-weight:500;text-align:right;}
input.ht-inp{border:1px solid var(--pm);border-radius:3px;padding:2px 5px;font-size:11px;width:72px;text-align:right;}
input.ht-inp:focus{outline:none;border-color:var(--p);}
/* Hide the native number-input spinner arrows so typed digits aren't cropped. */
input.ht-inp::-webkit-outer-spin-button, input.ht-inp::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input.ht-inp[type="number"] { -moz-appearance: textfield; appearance: textfield; }

/* Budget tracker */
.budget-tbl{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:10px;}
.budget-tbl th{background:var(--pl);color:var(--pd);padding:7px 10px;text-align:right;font-weight:600;}
.budget-tbl th:first-child{text-align:left;}
.budget-tbl td{padding:6px 10px;border-bottom:0.5px solid var(--border);}
.budget-tbl td.val{text-align:right;font-weight:500;font-variant-numeric:tabular-nums;}
input.budget-inp{border:1.5px solid var(--pm);border-radius:5px;padding:4px 8px;font-size:12px;font-weight:500;text-align:right;width:110px;}
input.budget-inp:focus{outline:none;border-color:var(--p);}
.badge-ok{background:var(--okl);color:var(--ok);font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;display:inline-block;}
.badge-warn{background:var(--warnl);color:var(--warn);font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;display:inline-block;}
.badge-err{background:var(--errl);color:var(--err);font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;display:inline-block;}

/* retention */

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p:#7B52CC;--pl:#EDE8F9;--pm:#C4B3EF;--pd:#4A2E8A;
  --n:#2D3680;--nl:#E8EAF4;
  --g:#7B52CC;--gl:#EDE8F9;--gd:#4A2E8A;
  --border:#E4DFF5;--bg:#F7F5FD;
  --warn:#F57C00;--warnl:#FFF3E0;
  --ok:#2E7D32;--okl:#E8F5E9;
  --err:#C62828;--errl:#FEEBEE;
  --gold:#B8860B;--goldl:#FFFDE7;
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);font-size:13px;}
.hdr{background:var(--p);color:white;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.hdr-title{font-size:16px;font-weight:700;}
.hdr-sub{font-size:10px;opacity:0.7;margin-top:2px;}
.summary-pills{display:flex;gap:10px;}
.pill{background:rgba(255,255,255,0.15);border-radius:8px;padding:6px 14px;text-align:center;}
.pill-val{font-size:18px;font-weight:700;}
.pill-lbl{font-size:9px;opacity:0.75;margin-top:1px;}
.tabs{background:white;border-bottom:1px solid var(--border);padding:0 24px;display:flex;}
.tab{padding:10px 18px;font-size:12px;cursor:pointer;color:#888;border-bottom:2.5px solid transparent;transition:all 0.15s;}
.tab.active{color:var(--p);border-bottom-color:var(--p);font-weight:700;}
.pg{display:none;padding:18px 24px;}.pg.active{display:block;}
.sec{background:white;border-radius:10px;border:1px solid var(--border);padding:14px 16px;margin-bottom:14px;}
.sec-title{font-size:11px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:0.07em;border-bottom:2px solid var(--pl);padding-bottom:7px;margin-bottom:12px;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.field{display:flex;align-items:center;padding:4px 0;border-bottom:0.5px solid #f5f2fc;gap:8px;}
.field:last-child{border-bottom:none;}
.fl{font-size:11px;color:#555;flex:1;line-height:1.4;}
input.fv,select.fv{background:white;border:1.5px solid var(--pm);border-radius:5px;padding:4px 7px;font-size:12px;font-weight:500;color:#2a2a2a;text-align:right;width:120px;transition:border-color 0.15s;}
input.fv:focus,select.fv:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px rgba(123,82,204,0.1);}
select.fv{text-align:left;cursor:pointer;}
.cv{background:var(--pl);border-radius:5px;padding:4px 8px;font-size:12px;font-weight:600;color:var(--pd);text-align:right;min-width:120px;font-variant-numeric:tabular-nums;}
.cv.hi{background:var(--p);color:white;}
.cv.g{background:var(--gl);color:var(--gd);}
.cv.ok{background:var(--okl);color:var(--ok);}
.cv.warn{background:var(--warnl);color:var(--warn);}
.cv.err{background:var(--errl);color:var(--err);}
.cv.gold{background:var(--goldl);color:var(--gold);}
.divider{height:1px;background:var(--border);margin:8px 0;}

/* Milestone config */
.ms-config{display:flex;gap:12px;flex-wrap:wrap;}
.ms-card{background:white;border:1.5px solid var(--border);border-radius:10px;padding:14px;min-width:180px;flex:1;}
.ms-card.active-ms{border-color:var(--p);background:var(--pl);}
.ms-yr{font-size:28px;font-weight:700;color:var(--p);line-height:1;}
.ms-pct-inp{width:80px;border:1.5px solid var(--pm);border-radius:5px;padding:4px 7px;font-size:14px;font-weight:600;text-align:right;color:var(--pd);}
.ms-pct-inp:focus{outline:none;border-color:var(--p);}
.ms-type{font-size:10px;color:#888;margin-top:4px;}

/* Employee table */
.emp-wrap{overflow-x:auto;margin-bottom:12px;}
.emp-tbl{border-collapse:collapse;width:100%;font-size:11px;}
.emp-tbl th{background:var(--p);color:white;padding:7px 8px;text-align:center;white-space:nowrap;font-weight:600;}
.emp-tbl th.lh{text-align:left;min-width:110px;}
.emp-tbl th.ms5{background:#1565C0;}
.emp-tbl th.ms7{background:#2E7D32;}
.emp-tbl th.ms10{background:#6A1B9A;}
.emp-tbl td{padding:5px 6px;border-bottom:0.5px solid var(--border);vertical-align:middle;white-space:nowrap;}
.emp-tbl tr:hover td{background:#faf9ff;}
.emp-tbl td.cal{background:var(--pl);color:var(--pd);font-weight:500;text-align:right;}
.emp-tbl td.ms5c{background:#E3F2FD;color:#1565C0;font-weight:500;text-align:right;}
.emp-tbl td.ms7c{background:#E8F5E9;color:#2E7D32;font-weight:500;text-align:right;}
.emp-tbl td.ms10c{background:#F3E5F5;color:#6A1B9A;font-weight:500;text-align:right;}
.emp-tbl td.wk5c{background:#BBDEFB;color:#0D47A1;font-weight:500;text-align:right;}
.emp-tbl td.wk7c{background:#C8E6C9;color:#1B5E20;font-weight:600;text-align:right;}
.emp-tbl td.wk10c{background:#E1BEE7;color:#4A148C;font-weight:600;text-align:right;}
.emp-tbl td.tot{background:#2a2a4a;color:white;font-weight:700;text-align:right;}
.emp-tbl td.tot-wk{background:var(--g);color:white;font-weight:700;text-align:right;}
input.ei{border:1px solid var(--pm);border-radius:4px;padding:3px 5px;font-size:11px;}
input.ei:focus{outline:none;border-color:var(--p);}
input.ei-name{width:110px;}
input.ei-date{width:100px;}
input.ei-num{width:60px;text-align:right;}
select.ei-sel{border:1px solid var(--pm);border-radius:4px;padding:3px 5px;font-size:11px;cursor:pointer;background:white;}
select.ei-sel:focus{outline:none;border-color:var(--p);}
.btn-del{width:22px;height:22px;border-radius:4px;border:none;background:transparent;cursor:pointer;color:#ccc;font-size:14px;}
.btn-del:hover{color:var(--err);background:var(--errl);}
.btn-add{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--p);border:1px dashed var(--pm);border-radius:6px;padding:6px 14px;background:transparent;cursor:pointer;margin-top:8px;}
.btn-add:hover{background:var(--pl);}

/* Timeline */
.timeline{position:relative;padding-left:30px;}
.tl-line{position:absolute;left:13px;top:0;bottom:0;width:2px;background:var(--border);}
.tl-item{position:relative;margin-bottom:16px;}
.tl-dot{position:absolute;left:-21px;width:16px;height:16px;border-radius:50%;border:2px solid white;top:3px;}
.tl-dot.yr5{background:#1565C0;}
.tl-dot.yr7{background:#2E7D32;}
.tl-dot.yr10{background:#6A1B9A;}
.tl-dot.past{background:#ccc;}
.tl-date{font-size:11px;font-weight:600;color:var(--color-text-primary,#2a2a2a);}
.tl-name{font-size:12px;color:#444;margin-top:2px;}
.tl-amounts{display:flex;gap:8px;margin-top:4px;flex-wrap:wrap;}
.tl-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;}

/* Summary cards */
.sum-card{background:white;border-radius:10px;border:1px solid var(--border);padding:14px;text-align:center;}
.sum-val{font-size:22px;font-weight:700;margin-bottom:3px;}
.sum-lbl{font-size:10px;color:#888;text-transform:uppercase;letter-spacing:0.05em;}
.sum-sub{font-size:11px;color:#666;margin-top:4px;}

/* Countdown chips */
.countdown{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600;}
.countdown.soon{background:#FFF3E0;color:#E65100;}
.countdown.future{background:var(--pl);color:var(--pd);}
.countdown.past{background:#f0f0f0;color:#888;}

/* Flag */
.flag-box{border-radius:8px;padding:10px 14px;font-size:11px;line-height:1.6;margin-bottom:12px;border-left:4px solid;}
.flag-warn{background:var(--warnl);border-color:var(--warn);color:#5D2C00;}
.flag-info{background:var(--gl);border-color:var(--g);color:var(--gd);}

/* budget */

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p:#7B52CC;--pl:#EDE8F9;--pm:#C4B3EF;--pd:#4A2E8A;
  --n:#2D3680;--nl:#E8EAF4;
  --g:#7B52CC;--gl:#EDE8F9;--gd:#4A2E8A;
  --border:#E4DFF5;--bg:#F7F5FD;
  --warn:#F57C00;--warnl:#FFF3E0;
  --ok:#2E7D32;--okl:#E8F5E9;
  --err:#C62828;--errl:#FEEBEE;
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);font-size:13px;}
.hdr{background:var(--p);color:white;padding:11px 20px;display:flex;align-items:center;justify-content:space-between;}
.hdr-title{font-size:15px;font-weight:700;}
.hdr-sub{font-size:10px;opacity:0.7;margin-top:1px;}
.kpi-pills{display:flex;gap:8px;}
.kpill{background:rgba(255,255,255,0.15);border-radius:8px;padding:5px 12px;text-align:center;min-width:90px;}
.kpill-val{font-size:16px;font-weight:700;}
.kpill-lbl{font-size:9px;opacity:0.7;margin-top:1px;}
.tabs{background:white;border-bottom:1px solid var(--border);padding:0 20px;display:flex;}
.tab{padding:9px 16px;font-size:12px;cursor:pointer;color:#888;border-bottom:2.5px solid transparent;transition:all 0.15s;}
.tab.active{color:var(--p);border-bottom-color:var(--p);font-weight:700;}
.pg{display:none;padding:16px 20px;}.pg.active{display:block;}
.sec{background:white;border-radius:10px;border:1px solid var(--border);padding:14px 16px;margin-bottom:14px;}
.sec-title{font-size:11px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:0.07em;border-bottom:2px solid var(--pl);padding-bottom:6px;margin-bottom:10px;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.field{display:flex;align-items:center;padding:4px 0;border-bottom:0.5px solid #f5f2fc;gap:8px;}
.field:last-child{border-bottom:none;}
.fl{font-size:11px;color:#555;flex:1;line-height:1.4;}
.fv{background:white;border:1.5px solid var(--pm);border-radius:5px;padding:4px 7px;font-size:12px;font-weight:500;color:#2a2a2a;text-align:right;width:110px;transition:border-color 0.15s;}
.fv:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px rgba(123,82,204,0.1);}
select.fv{text-align:left;cursor:pointer;}
.cv{background:var(--pl);border-radius:5px;padding:4px 8px;font-size:12px;font-weight:600;color:var(--pd);text-align:right;min-width:110px;font-variant-numeric:tabular-nums;}
.cv.hi{background:var(--p);color:white;}
.cv.g{background:var(--gl);color:var(--gd);}
.cv.ok{background:var(--okl);color:var(--ok);}
.cv.warn{background:var(--warnl);color:var(--warn);}
.cv.err{background:var(--errl);color:var(--err);}
.cv.n{background:var(--nl);color:var(--n);}
.sub-lbl{font-size:9px;font-weight:700;color:var(--p);opacity:0.6;margin:8px 0 4px;text-transform:uppercase;letter-spacing:0.05em;}
.divider{height:1px;background:var(--border);margin:8px 0;}

/* Staff table */
.staff-wrap{overflow-x:auto;margin-bottom:10px;}
.staff-tbl{border-collapse:collapse;font-size:11px;}
.staff-tbl th{background:var(--p);color:white;padding:6px 7px;white-space:nowrap;font-weight:600;text-align:center;}
.staff-tbl th.row-lbl{text-align:left;background:#3a2a6a;min-width:160px;position:sticky;left:0;z-index:2;}
.staff-tbl th.role-hdr{min-width:120px;position:relative;}
.staff-tbl td{padding:4px 6px;border-bottom:0.5px solid var(--border);white-space:nowrap;vertical-align:middle;}
.staff-tbl td.row-lbl{font-size:11px;color:#444;font-weight:500;background:#faf9ff;border-right:1px solid var(--border);position:sticky;left:0;z-index:1;}
.staff-tbl td.sec-hdr{background:var(--pl);color:var(--pd);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:0.05em;}
.staff-tbl td.cal{background:var(--pl);color:var(--pd);font-weight:500;text-align:right;}
.staff-tbl td.cal-g{background:var(--gl);color:var(--gd);font-weight:600;text-align:right;}
.staff-tbl td.cal-hi{background:var(--p);color:white;font-weight:700;text-align:right;}
.staff-tbl td.cal-n{background:var(--nl);color:var(--n);font-weight:500;text-align:right;}
.staff-tbl td.tot{background:#2a2a4a;color:white;font-weight:700;text-align:right;}
input.si{border:1.5px solid var(--pm);border-radius:4px;padding:3px 5px;font-size:11px;text-align:right;background:white;}
input.si:focus{outline:none;border-color:var(--p);}
input.si-sm{width:55px;}
input.si-md{width:75px;}
select.si-sel{border:1.5px solid var(--pm);border-radius:4px;padding:3px 5px;font-size:10px;cursor:pointer;background:white;width:90px;}
select.si-sel:focus{outline:none;border-color:var(--p);}
/* v99: Role header — make name + category obviously editable on existing rows.
   Previous styling (transparent input, translucent white-on-white dropdown) hid
   the editing affordance, so users assumed they could only modify roles via
   "+ Add Role". Name now has a dashed underline (suggesting type-to-edit), and
   the dropdown is solid white with dark text and a clear border. */
input.role-name{background:transparent;border:none;border-bottom:1px dashed rgba(255,255,255,0.45);color:white;font-size:11px;font-weight:700;text-align:center;width:100%;cursor:text;padding:2px 0;}
input.role-name:hover{background:rgba(255,255,255,0.08);border-bottom-color:rgba(255,255,255,0.85);}
input.role-name:focus{outline:none;border:1px solid rgba(255,255,255,0.7);border-radius:3px;background:rgba(255,255,255,0.18);border-bottom-style:solid;}
/* v99: Category dropdown — solid white pill so it's clearly a control, not background noise */
.role-menu-wrap{position:relative;margin-top:5px;}
.role-menu-btn{width:95%;min-height:22px;background:rgba(255,255,255,0.95);color:#1C1B2E;border:1px solid rgba(255,255,255,0.42);border-radius:4px;font-size:10px;font-weight:700;padding:3px 16px 3px 6px;cursor:pointer;text-align:center;position:relative;font-family:inherit;}
.role-menu-btn:after{content:"";position:absolute;right:7px;top:50%;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid #5A5870;transform:translateY(-35%);}
.role-menu-btn:hover,.role-menu-wrap.open .role-menu-btn{background:white;box-shadow:0 0 0 1px rgba(255,255,255,0.5);}
.role-menu{display:none;position:absolute;top:calc(100% + 5px);left:50%;transform:translateX(-50%);width:132px;background:white;border:1px solid rgba(0,0,0,0.12);border-radius:7px;box-shadow:0 10px 26px rgba(28,27,46,0.18);padding:5px;z-index:120;text-align:left;}
.role-menu-wrap.open .role-menu{display:block;}
.role-menu-item{width:100%;display:block;border:0;background:transparent;color:#1C1B2E;text-align:left;border-radius:5px;font-size:10px;font-weight:600;line-height:1.2;padding:6px 7px;cursor:pointer;font-family:inherit;}
.role-menu-item:hover{background:#F4F3FA;}
.role-menu-item.active{background:#EDE8F9;color:#4A2E8A;}
.role-menu-item.danger{color:#C0392B;}
.role-menu-item.danger:hover{background:#FEEBEE;}
.role-menu-sep{height:1px;background:rgba(0,0,0,0.08);margin:4px 2px;}
.role-hdr > div[style*="position:absolute"][style*="top:2px"]{display:none!important;}
.role-hdr select.role-cat-sel{background:rgba(255,255,255,0.95);color:#1C1B2E;border:1px solid rgba(255,255,255,0.42);border-radius:4px;font-size:10px;font-weight:700;padding:3px 4px;cursor:pointer;width:95%;margin-top:5px;text-align:center;text-align-last:center;}
.role-hdr select.role-cat-sel:hover{background:white;box-shadow:0 0 0 1px rgba(255,255,255,0.5);}
.role-hdr select.role-cat-sel:focus{outline:none;background:white;box-shadow:0 0 0 2px rgba(255,255,255,0.6);}
.role-hdr select.role-cat-sel option{background:white;color:#1C1B2E;}
.role-hdr select.role-cat-sel option.role-menu-danger{color:#C0392B;}
.kpi-badge{font-size:9px;font-weight:500;padding:1px 6px;border-radius:8px;display:inline-block;margin-left:4px;}
.kpi-ok{background:#E8F5E9;color:#2E7D32;}
.kpi-warn{background:#FFF3E0;color:#E65100;}
.kpi-bad{background:#FEEBEE;color:#C62828;}

/* Revenue allocation table */
.alloc-tbl{width:100%;border-collapse:collapse;font-size:12px;}
.alloc-tbl th{background:var(--p);color:white;padding:7px 10px;text-align:center;font-weight:600;white-space:nowrap;}
.alloc-tbl th.lh{text-align:left;}
.alloc-tbl td{padding:5px 8px;border-bottom:0.5px solid var(--border);vertical-align:middle;}
.alloc-tbl td.cat{font-weight:600;color:#2a2a2a;padding-left:12px;}
.alloc-tbl td.subcat{color:#555;padding-left:22px;font-size:11px;}
.alloc-tbl td.sec-row{background:var(--pl);color:var(--pd);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:0.05em;padding-left:8px;}
.alloc-tbl td.tot-row{background:#2a2a4a;color:white;font-weight:700;}
.alloc-tbl td.num{text-align:right;font-variant-numeric:tabular-nums;}
.alloc-tbl td.kpi-cell{font-size:10px;color:#888;text-align:center;}
/* v101: Full Revenue Allocation table only — center-align data so it lines up under
   the centered headers, and let the Category column hold long custom labels.
   Payroll Breakdown + Staff Cost Per Day tables keep right-aligned numbers (they
   don't have this scope). */
.fra-tbl td.num{text-align:center;}
.fra-tbl td.cat,
.fra-tbl td.subcat{white-space:normal;word-break:break-word;}
.fra-tbl input.alloc-label-edit{max-width:100%;}
input.pct-inp{width:65px;border:1.5px solid var(--pm);border-radius:4px;padding:3px 6px;font-size:12px;font-weight:500;text-align:right;}
input.pct-inp:focus{outline:none;border-color:var(--p);}
/* v93: Editable allocation row labels — show subtle hint that they're inputs */
input.alloc-label-edit{transition:background 0.12s,box-shadow 0.12s;border-radius:3px;}
input.alloc-label-edit:hover{background:rgba(123,82,204,0.08) !important;box-shadow:0 0 0 1px rgba(123,82,204,0.25);}
input.alloc-label-edit:focus{background:rgba(123,82,204,0.05) !important;box-shadow:0 0 0 1.5px var(--p) !important;outline:none !important;}
.alloc-calc{font-size:12px;font-weight:600;color:var(--pd);font-variant-numeric:tabular-nums;}
.alloc-calc.g{color:var(--gd);}
.alloc-calc.warn{color:var(--warn);}
.alloc-calc.err{color:var(--err);}
.alloc-calc.auto{color:#888;font-style:italic;}

/* Dashboard cards */
.dash-card{background:white;border-radius:10px;border:1px solid var(--border);padding:14px;text-align:center;}
.dash-val{font-size:20px;font-weight:700;margin-bottom:3px;}
.dash-lbl{font-size:10px;color:#888;text-transform:uppercase;letter-spacing:0.05em;}
.dash-sub{font-size:11px;color:#666;margin-top:3px;}
.progress-bar{height:8px;background:#f0edf8;border-radius:4px;overflow:hidden;margin-top:6px;}
.progress-fill{height:100%;border-radius:4px;transition:width 0.3s;}

/* CC table */
.cc-tbl{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:10px;}
.cc-tbl th{background:var(--n);color:white;padding:7px 10px;text-align:left;font-weight:600;}
.cc-tbl td{padding:6px 10px;border-bottom:0.5px solid var(--border);}

.flag-box{border-radius:8px;padding:10px 14px;font-size:11px;line-height:1.6;margin-bottom:12px;border-left:4px solid;}
.flag-info{background:var(--gl);border-color:var(--g);color:var(--gd);}
.flag-warn{background:var(--warnl);border-color:var(--warn);color:#5D2C00;}

/* v100: Budget Calc form-field tightening — labels were wrapping into 2-3 lines
   ("Total / yearly / deposits") because the input column was too wide. Scoped to
   #cp-budget so other calc panels keep their existing layout. Changes:
     - .fl: bigger font (11→12px) and slightly bolder so labels read as primary content
     - .fv / .cv: narrower (110→90px) so the label column gets back ~20px of room
     - .field: vertical centering already on the parent — explicit here for clarity
   Net effect: "Total yearly deposits", "Online sales / year", "Sales tax %",
   "This week's deposit" all fit on one line, and the value sits dead-centre with the label. */
#cp-budget .field{align-items:center;}
#cp-budget .fl{font-size:12px;color:#444;line-height:1.35;font-weight:500;}
#cp-budget .fv{width:90px;}
#cp-budget .cv{min-width:90px;}
#cp-budget #rev-this-week{width:132px;min-width:132px;}
#cp-budget #o-week-after-tax{min-width:132px;}

/* fringe */

:root{
  --p:#7B52CC;--pl:#EDE8F9;--pm:#C4B3EF;--pd:#4A2E8A;
  --n:#2D3680;--nl:#E8EAF4;--nd:#1A2060;
  --bg:#F4F3FA;--card:#FFFFFF;
  --border:#E4E1F0;
  --txt:#1C1B2E;--txt2:#5A5870;--txt3:#9896B0;
  --red:#C0392B;--redl:#FDEEEC;
  --green:#1E7B4B;--greenl:#E8F7EF;
  --amber:#9A6500;--amberl:#FEF3DC;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--txt);min-height:100vh;}
.topbar{background:var(--n);padding:0 2.5rem;height:56px;display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:10px;}
.brand svg{width:34px;height:34px;}
.brand-name{color:white;font-size:14px;font-weight:600;}
.brand-sub{color:rgba(255,255,255,0.45);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.yr-group{display:flex;background:rgba(255,255,255,0.1);border-radius:7px;overflow:hidden;}
.yr-btn{padding:5px 13px;font-size:12px;color:rgba(255,255,255,0.6);border:none;background:transparent;cursor:pointer;}
.yr-btn.active{background:var(--p);color:white;font-weight:500;}
.export-btn{display:flex;align-items:center;gap:6px;padding:7px 16px;background:var(--p);color:white;border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;}
.export-btn:hover{background:var(--pd);}
.hero{background:var(--n);padding:1.75rem 2.5rem 2rem;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:-40px;right:-40px;width:220px;height:220px;background:var(--p);border-radius:50%;opacity:0.15;}
.hero-title{font-size:20px;font-weight:700;color:white;margin-bottom:5px;position:relative;}
.hero-sub{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.6;max-width:500px;position:relative;}
.hero-chips{display:flex;gap:8px;margin-top:1.1rem;position:relative;}
.chip{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);border-radius:20px;padding:5px 14px;font-size:11px;color:rgba(255,255,255,0.8);}
.chip strong{color:white;}
.page{max-width:1000px;margin:0 auto;padding:1.75rem 1.5rem;}
.layout{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;align-items:start;}
.panel{background:var(--card);border-radius:12px;border:1px solid var(--border);overflow:hidden;margin-bottom:1.25rem;}
.panel:last-child{margin-bottom:0;}
.ph{display:flex;align-items:center;gap:10px;padding:0.875rem 1.1rem;border-bottom:1px solid var(--border);}
.ph-icon{width:30px;height:30px;border-radius:7px;background:var(--pl);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ph-icon.navy{background:var(--nl);}
.ph-icon.red-bg{background:var(--redl);}
.ph-title{font-size:13px;font-weight:600;color:var(--txt);}
.ph-sub{font-size:11px;color:var(--txt3);}
.pb{padding:1.1rem;}
label{display:block;font-size:10px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px;}
input[type=number],input[type=text],input[type=date],select{width:100%;padding:8px 11px;border:1px solid var(--border);border-radius:7px;font-size:13px;color:var(--txt);background:white;outline:none;transition:border-color 0.15s;}
input:focus,select:focus{border-color:var(--p);box-shadow:0 0 0 3px var(--pl);}
.suf{position:relative;}.suf span{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--txt3);}.suf input{padding-right:26px;}
.pre{position:relative;}.pre span{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--txt3);}.pre input{padding-left:22px;}
.hint{font-size:11px;color:var(--txt3);margin-top:4px;line-height:1.5;}
.hce-card{background:var(--amberl);border:1px solid #F5CB5B;border-radius:8px;padding:0.875rem;margin-top:0.75rem;}
.hce-title{font-size:10px;font-weight:700;color:var(--amber);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:5px;}
.hce-body{font-size:11px;color:var(--amber);line-height:1.6;margin-bottom:8px;}
.hce-row{display:flex;align-items:flex-start;gap:7px;cursor:pointer;}
.hce-row input[type=checkbox]{width:13px;height:13px;accent-color:var(--amber);margin-top:2px;cursor:pointer;}
.hce-row span{font-size:11px;font-weight:500;color:var(--amber);line-height:1.4;}
.divider{height:1px;background:var(--border);margin:1rem 0;}
.rule-block{border-radius:8px;padding:0.75rem;margin-bottom:0.625rem;}
.rule-block:last-child{margin-bottom:0;}
.rule-block.svc{background:var(--pl);border-left:3px solid var(--p);}
.rule-block.merch{background:var(--nl);border-left:3px solid var(--n);}
.rbt{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:4px;}
.rule-block.svc .rbt{color:var(--pd);}
.rule-block.merch .rbt{color:var(--nd);}
.rbf{font-size:11px;font-family:monospace;background:rgba(0,0,0,0.06);border-radius:4px;padding:4px 7px;margin-bottom:4px;}
.rule-block.svc .rbf{color:var(--pd);}
.rule-block.merch .rbf{color:var(--nd);}
.rbn{font-size:11px;line-height:1.5;}
.rule-block.svc .rbn{color:var(--pd);opacity:0.8;}
.rule-block.merch .rbn{color:var(--nd);opacity:0.8;}
.add-area{background:var(--bg);border-radius:9px;padding:1rem;margin-bottom:1.1rem;}
.add-area-lbl{font-size:10px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.75rem;}
.add-grid{display:grid;grid-template-columns:1fr 110px 115px 115px auto;gap:8px;align-items:end;}
.add-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:0 14px;background:var(--p);color:white;border:none;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;height:36px;}
.add-btn:hover{background:var(--pd);}
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead th{padding:8px 10px;font-size:10px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:0.05em;text-align:left;border-bottom:2px solid var(--border);}
tbody td{padding:9px 10px;font-size:13px;border-bottom:1px solid var(--border);color:var(--txt);}
tbody tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:#FAFAF9;}
.badge{display:inline-flex;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:500;}
.bs{background:var(--pl);color:var(--pd);}
.bm{background:var(--nl);color:var(--nd);}
.pill{display:inline-flex;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;}
.py{background:var(--redl);color:var(--red);}
.pn{background:var(--greenl);color:var(--green);}
.del{width:26px;height:26px;border-radius:5px;background:transparent;border:1px solid var(--border);cursor:pointer;color:var(--txt3);font-size:15px;display:flex;align-items:center;justify-content:center;}
.del:hover{background:var(--redl);border-color:#F5A89E;color:var(--red);}
.empty-row{text-align:center;padding:2rem;color:var(--txt3);font-size:13px;}
.results-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:1rem;}
.rc{border-radius:10px;padding:1rem 1.1rem;position:relative;}
.rc.disc{background:var(--nl);}
.rc.exempt{background:var(--greenl);}
.rc.tax{background:var(--redl);}
.rc-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:5px;}
.rc.disc .rc-lbl{color:var(--nd);}
.rc.exempt .rc-lbl{color:var(--green);}
.rc.tax .rc-lbl{color:var(--red);}
.rc-val{font-size:24px;font-weight:700;}
.rc.disc .rc-val{color:var(--n);}
.rc.exempt .rc-val{color:var(--green);}
.rc.tax .rc-val{color:var(--red);}
.rc-note{font-size:11px;margin-top:3px;opacity:0.7;}
.rc.disc .rc-note{color:var(--n);}
.rc.exempt .rc-note{color:var(--green);}
.rc.tax .rc-note{color:var(--red);}
.w2-tag{position:absolute;top:8px;right:10px;font-size:9px;font-weight:700;letter-spacing:0.06em;background:var(--red);color:white;padding:2px 6px;border-radius:20px;}
.guidance{border-left:3px solid var(--p);background:var(--pl);border-radius:0 8px 8px 0;padding:0.875rem 1rem;font-size:12px;color:var(--pd);line-height:1.75;}
.guidance strong{font-weight:600;}
.inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
.inv-grid:last-of-type{margin-bottom:0;}
.disclaimer{background:var(--bg);border-radius:8px;padding:0.875rem;font-size:11px;color:var(--txt3);line-height:1.7;border:1px solid var(--border);}
.clear-lnk{font-size:11px;color:var(--red);background:transparent;border:none;cursor:pointer;margin-left:auto;}
.fld{margin-bottom:0.875rem;}.fld:last-child{margin-bottom:0;}
@media print{
  .topbar,.export-btn,.add-area,.del,.no-print{display:none!important;}
  .hero::before{display:none;}
  body{background:white;}
  .layout{grid-template-columns:1fr;}
}

.calc-panel{background:#F4F3FA;}


/* IVMS OS Editable Styles */
.editable{outline:none;border-radius:5px;transition:all 0.15s;min-width:20px;display:inline-block;padding:2px 6px;background:rgba(244,243,250,0.5);border:1px solid rgba(123,82,204,0.15);}
.editable:hover{background:rgba(123,82,204,0.07);border-color:rgba(123,82,204,0.35);}
.editable:focus{background:var(--pl,#EDE8F9);box-shadow:0 0 0 2px #C4B3EF;border-color:#7B52CC;}
.editable-block{outline:none;border-radius:6px;transition:all 0.15s;width:100%;min-height:32px;padding:6px 8px;border:1px solid rgba(123,82,204,0.15);background:rgba(244,243,250,0.3);}
.editable-block:hover{background:rgba(123,82,204,0.05);border-color:rgba(123,82,204,0.3);}
.editable-block:focus{background:#EDE8F9;box-shadow:0 0 0 2px #C4B3EF;border-color:#7B52CC;}
.shared-foundation-note{background:#F4F3FA;border:1px solid rgba(123,82,204,0.18);border-left:4px solid #7B52CC;border-radius:8px;padding:9px 12px;margin:0 0 12px;font-size:12px;line-height:1.45;color:#5A5870;}
.shared-foundation-readonly .editable,
.shared-foundation-readonly .editable-block,
.shared-foundation-readonly [contenteditable="true"]{pointer-events:none!important;background:#fff!important;border-color:rgba(0,0,0,0.07)!important;box-shadow:none!important;color:#1C1B2E!important;}
.shared-foundation-readonly button,
.shared-foundation-readonly input[type="file"]{display:none!important;}
.add-row-btn{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:#7B52CC;background:transparent;border:none;cursor:pointer;padding:4px 0;margin-top:6px;}
.add-row-btn:hover{color:#4A2E8A;}
.del-row-btn{width:22px;height:22px;border-radius:5px;background:transparent;border:1px solid rgba(0,0,0,0.1);cursor:pointer;color:#9896B0;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.15s;line-height:1;}
.del-row-btn:hover{background:#FDEEEC;border-color:#F5A89E;color:#C0392B;}
.status-sel{font-size:10px;font-weight:500;padding:2px 8px;border-radius:20px;border:none;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;}
.status-ontrack{background:#EDE8F9;color:#4A2E8A;white-space:nowrap;display:inline-block;text-align:center;min-width:70px;}
.status-offtrack{background:#FCEBEB;color:#A32D2D;white-space:nowrap;display:inline-block;text-align:center;min-width:70px;}
.status-complete{background:#EAF3DE;color:#3B6D11;white-space:nowrap;display:inline-block;text-align:center;min-width:70px;}
.os-section-title{font-size:18px;font-weight:600;color:#1C1B2E;margin-bottom:4px;}
.os-section-sub{font-size:13px;color:#9896B0;margin-bottom:1.25rem;}
.os-card{background:#fff;border:1px solid rgba(0,0,0,0.09);border-radius:11px;padding:1rem;}
.os-card-table{width:100%;border-collapse:collapse;font-size:13px;}
.os-card-table th{padding:11px 14px;font-size:11px;font-weight:500;color:#9896B0;border-bottom:1px solid rgba(0,0,0,0.09);text-align:left;background:#F4F3FA;text-transform:uppercase;letter-spacing:0.04em;}
.os-card-table td{padding:13px 14px;border-bottom:1px solid rgba(0,0,0,0.07);color:#1C1B2E;vertical-align:middle;}
.os-card-table tr:last-child td{border-bottom:none;}
.os-card-table tr:hover td{background:#FAFAF9;}
.os-tabs{display:flex;border-bottom:1px solid rgba(0,0,0,0.09);margin-bottom:1.25rem;}
.os-tab{padding:9px 18px;font-size:13px;color:#5A5870;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;}
.os-tab.active{color:#7B52CC;border-bottom-color:#7B52CC;font-weight:500;}
.os-pil{display:inline-flex;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:500;}
.pil-svc{background:#EDE8F9;color:#4A2E8A;}
.pil-nm{background:#E8EAF4;color:#2D3680;}
.save-toast{position:fixed;bottom:20px;right:20px;background:#1C1B2E;color:white;padding:8px 16px;border-radius:8px;font-size:12px;font-weight:500;z-index:9999;opacity:0;transition:opacity 0.3s;pointer-events:none;}
.save-toast.show{opacity:1;}
.save-conflict-banner{position:fixed;right:20px;bottom:58px;width:min(420px,calc(100vw - 40px));background:#fff;border:1px solid #F3B6AF;border-left:4px solid #C0392B;border-radius:8px;box-shadow:0 12px 34px rgba(28,27,46,0.18);z-index:10000;padding:14px 14px 12px;font-family:inherit;color:#1C1B2E;}
.save-conflict-banner.is-info{border-color:#B9C5F3;border-left-color:#2D3680;}
.save-conflict-title{font-size:13px;font-weight:700;margin:0 0 5px;color:#1C1B2E;}
.save-conflict-msg{font-size:12px;line-height:1.45;margin:0;color:#5A5870;}
.save-conflict-meta{font-size:10px;line-height:1.4;margin-top:8px;color:#9896B0;}
.save-conflict-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;}
.save-conflict-btn{border:1px solid rgba(0,0,0,0.12);border-radius:6px;background:#fff;color:#5A5870;padding:6px 10px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;}
.save-conflict-btn.primary{background:#7B52CC;border-color:#7B52CC;color:#fff;}
.save-conflict-btn:disabled{opacity:0.55;cursor:wait;}
.recovery-modal{position:fixed;inset:0;background:rgba(28,27,46,0.52);z-index:10020;display:flex;align-items:center;justify-content:center;padding:20px;}
.recovery-panel{width:min(760px,calc(100vw - 40px));max-height:86vh;background:#fff;border-radius:10px;box-shadow:0 18px 60px rgba(0,0,0,0.24);display:flex;flex-direction:column;overflow:hidden;color:#1C1B2E;}
.recovery-head{padding:16px 18px;border-bottom:1px solid rgba(0,0,0,0.08);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.recovery-title{font-size:15px;font-weight:700;}
.recovery-sub{font-size:11px;color:#9896B0;margin-top:2px;}
.recovery-close{width:30px;height:30px;border-radius:7px;background:#F4F3FA;border:none;color:#5A5870;font-size:18px;cursor:pointer;}
.recovery-tabs{display:flex;gap:8px;padding:12px 18px 0;}
.recovery-tab{border:1px solid rgba(0,0,0,0.1);background:#fff;color:#5A5870;border-radius:7px;padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;}
.recovery-tab.active{background:#7B52CC;border-color:#7B52CC;color:#fff;}
.recovery-body{padding:14px 18px 18px;overflow:auto;}
.recovery-list{display:grid;gap:8px;}
.recovery-row{border:1px solid rgba(0,0,0,0.09);border-radius:8px;padding:10px 12px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;background:#fff;}
.recovery-row:hover{background:#FAFAFC;border-color:#C4B3EF;}
.recovery-row-title{font-size:12px;font-weight:700;color:#1C1B2E;}
.recovery-row-meta{font-size:10px;color:#9896B0;margin-top:3px;line-height:1.4;}
.recovery-row-summary{font-size:11px;color:#5A5870;margin-top:6px;}
.recovery-btn{border:1px solid rgba(0,0,0,0.12);border-radius:6px;background:#fff;color:#5A5870;padding:7px 11px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;}
.recovery-btn.primary{background:#7B52CC;border-color:#7B52CC;color:#fff;}
.recovery-btn.danger{background:#C0392B;border-color:#C0392B;color:#fff;}
.recovery-btn:disabled{opacity:0.55;cursor:wait;}
.recovery-preview{margin-top:12px;border:1px solid #C4B3EF;background:#FAF8FF;border-radius:8px;padding:12px;}
.recovery-empty{padding:22px;text-align:center;color:#9896B0;font-size:12px;background:#FAFAFC;border:1px dashed rgba(0,0,0,0.12);border-radius:8px;}
.inline-form{background:#F4F3FA;border-radius:8px;padding:0.75rem;margin-top:8px;display:grid;gap:8px;}
.inline-form input,.inline-form select{padding:7px 10px;border:1px solid rgba(0,0,0,0.15);border-radius:6px;font-size:12px;color:#1C1B2E;background:white;outline:none;}
.inline-form input:focus,.inline-form select:focus{border-color:#7B52CC;box-shadow:0 0 0 2px #EDE8F9;}
.inline-form-actions{display:flex;gap:8px;}
.btn-save-sm{padding:6px 14px;background:#7B52CC;color:white;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;}
.btn-cancel-sm{padding:6px 14px;background:transparent;color:#5A5870;border:1px solid rgba(0,0,0,0.15);border-radius:6px;font-size:12px;cursor:pointer;}
.cr-cell{background:#FCEBEB;color:#C0392B;text-align:center;}
.cg-cell{background:#EAF3DE;color:#3B6D11;text-align:center;}
.cn-cell{text-align:center;color:#9896B0;}
.os-av{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600;color:white;font-size:7px;flex-shrink:0;}
.prog-bar{height:4px;background:#E4E1F0;border-radius:3px;overflow:hidden;min-width:60px;}
.prog-fill{height:100%;background:#7B52CC;border-radius:3px;}
.chk-circle{width:15px;height:15px;border-radius:50%;border:1.5px solid #ccc;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0;}
.chk-circle.done{background:#7B52CC;border-color:#7B52CC;}
.swot-item-row{display:flex;align-items:center;gap:6px;padding:5px 9px;background:#F4F3FA;border-radius:6px;margin-bottom:4px;}


/* ─── ADMIN MODE ─────────────────────────────────────────── */
.calc-toggle-wrap{display:none;margin-top:8px;}
.admin-on .calc-toggle-wrap{display:flex;align-items:center;gap:6px;}
.calc-disabled .calc-card-title{color:#9896B0;}
.calc-disabled .active-badge{background:#F4F3FA;color:#9896B0;}
.brand-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:2000;align-items:center;justify-content:center;}
.brand-modal-bg.open{display:flex;}
.brand-modal{background:white;border-radius:14px;padding:1.5rem;width:400px;max-height:88vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.2);}
.bm-title{font-size:14px;font-weight:600;color:#1C1B2E;margin-bottom:1.1rem;display:flex;align-items:center;justify-content:space-between;}
.bm-close{width:26px;height:26px;border-radius:6px;background:#F4F3FA;border:none;cursor:pointer;font-size:16px;color:#5A5870;}
.bm-field{margin-bottom:0.875rem;}
.bm-lbl{display:block;font-size:10px;font-weight:600;color:#5A5870;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px;}
.bm-inp{width:100%;padding:8px 11px;border:1px solid rgba(0,0,0,0.15);border-radius:7px;font-size:13px;color:#1C1B2E;outline:none;box-sizing:border-box;}
.bm-inp:focus{border-color:#7B52CC;box-shadow:0 0 0 3px #EDE8F9;}
.bm-save{width:100%;padding:9px;background:#7B52CC;color:white;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;margin-top:0.25rem;}
.bm-save:hover{background:#4A2E8A;}
.logo-preview-box{width:56px;height:56px;border-radius:9px;border:1px solid rgba(0,0,0,0.12);background:#F4F3FA;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;}
.color-swatches{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px;}
.cswatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;}
.cswatch.active{border-color:#1C1B2E;transform:scale(1.15);}
.plan-opts{display:flex;gap:6px;}
.plan-opt{padding:5px 12px;border-radius:20px;border:1px solid rgba(0,0,0,0.15);font-size:11px;font-weight:500;cursor:pointer;}
.plan-opt.active{background:#7B52CC;color:white;border-color:#7B52CC;}
.cs-item-gear{margin-left:auto;font-size:9px;color:#7B52CC;background:#EDE8F9;border:none;border-radius:4px;padding:2px 6px;cursor:pointer;display:none;}
.admin-on .cs-item-gear{display:inline-block;}


/* ─── ACCOUNT SETTINGS ───────────────────────────────────── */
.ac-section{background:#fff;border:1px solid rgba(0,0,0,0.09);border-radius:12px;margin-bottom:1.1rem;overflow:hidden;}
.ac-section-hdr{display:flex;align-items:center;gap:10px;padding:0.875rem 1.1rem;border-bottom:1px solid rgba(0,0,0,0.07);}
.ac-section-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ac-section-title{font-size:13px;font-weight:600;color:#1C1B2E;}
.ac-section-sub{font-size:11px;color:#9896B0;}
.ac-body{padding:1.1rem;}
.ac-field{margin-bottom:0;}
.ac-label{display:block;font-size:10px;font-weight:600;color:#5A5870;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px;}
.ac-input{width:100%;padding:8px 11px;border:1px solid rgba(0,0,0,0.14);border-radius:7px;font-size:13px;color:#1C1B2E;outline:none;box-sizing:border-box;background:white;}
.ac-input:focus{border-color:#7B52CC;box-shadow:0 0 0 3px #EDE8F9;}
.ac-save-btn{padding:8px 18px;background:#7B52CC;color:white;border:none;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;}
.ac-save-btn:hover{background:#4A2E8A;}
.ac-secondary-btn{padding:8px 14px;background:transparent;color:#5A5870;border:1px solid rgba(0,0,0,0.15);border-radius:7px;font-size:12px;cursor:pointer;}
.ac-secondary-btn:hover{background:#F4F3FA;}


/* ─── EVENTS ─────────────────────────────────────────────── */
.ev-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:3000;align-items:flex-start;justify-content:center;padding-top:60px;}
.ev-modal-bg.open{display:flex;}
.ev-modal{background:white;border-radius:14px;width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.2);padding:1.5rem;}
.ev-modal input:focus,.ev-modal select:focus,.ev-modal textarea:focus{border-color:#7B52CC !important;box-shadow:0 0 0 3px #EDE8F9;}


/* ─── COLOR SETTINGS MODAL ──────────────────────────────── */
.color-settings-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:4000;align-items:center;justify-content:center;}
.color-settings-modal-bg.open{display:flex;}
.csm{background:white;border-radius:14px;padding:1.5rem;width:440px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.2);}
.csm-title{font-size:14px;font-weight:700;color:#1C1B2E;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:space-between;}
.csm-close{width:26px;height:26px;border-radius:6px;background:#F4F3FA;border:none;cursor:pointer;font-size:17px;color:#5A5870;}
.csm-section{margin-bottom:1.1rem;}
.csm-section-title{font-size:10px;font-weight:700;color:#5A5870;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:8px;}
.csm-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.csm-label{font-size:12px;color:#1C1B2E;font-weight:500;}
.csm-sub{font-size:10px;color:#9896B0;}
.csm-controls{display:flex;align-items:center;gap:8px;}
.csm-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform 0.15s;flex-shrink:0;}
.csm-swatch.active{border-color:#1C1B2E;transform:scale(1.2);}
.csm-hex{width:90px;padding:5px 8px;border:1px solid rgba(0,0,0,0.14);border-radius:6px;font-size:12px;font-family:monospace;outline:none;}
.csm-hex:focus{border-color:#7B52CC;}
.csm-preview{background:#F4F3FA;border-radius:10px;padding:10px 12px;margin-bottom:1rem;}
.csm-preview-title{font-size:10px;font-weight:600;color:#9896B0;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:8px;}
.csm-apply{width:100%;padding:10px;background:#7B52CC;color:white;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;margin-top:0.5rem;}
.csm-apply:hover{background:#4A2E8A;}
.csm-reset{width:100%;padding:8px;background:transparent;color:#9896B0;border:1px solid rgba(0,0,0,0.12);border-radius:8px;font-size:12px;cursor:pointer;margin-top:6px;}


/* ═══ Auth Screen ═══ */
.auth-overlay{position:fixed;inset:0;z-index:99999;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Segoe UI',system-ui,sans-serif;}
.auth-overlay.hidden{display:none;}
.auth-box{background:#fff;border-radius:20px;padding:2.5rem;width:min(480px,calc(100vw - 32px));border:1px solid rgba(0,0,0,0.08);box-shadow:0 4px 24px rgba(0,0,0,0.06);}
.auth-brand-block{text-align:center;margin-bottom:1.5rem;}
.auth-wordmark{margin-bottom:14px;}
.auth-wordmark .mypracticehq-main{font-size:30px;line-height:1.05;}
.auth-wordmark .mypracticehq-by{font-size:12px;margin-top:4px;}
.auth-brand-block h1{margin:0 0 6px;font-size:24px;line-height:1.18;color:#25318D;letter-spacing:0;}
.auth-subtitle{margin:0 0 6px;color:#1C1B2E;font-size:14px;font-weight:700;line-height:1.4;}
.auth-supporting{margin:0 auto;color:#5A5870;font-size:13px;line-height:1.45;max-width:340px;}
.auth-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:2px solid #F4F3FA;}
.auth-tab{flex:1;text-align:center;padding:10px;font-size:13px;font-weight:500;color:#9896B0;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;}
.auth-tab.active{color:#7B52CC;border-bottom-color:#7B52CC;font-weight:600;}
.auth-field{margin-bottom:1rem;}
.auth-field label{display:block;font-size:11px;font-weight:600;color:#5A5870;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:5px;}
.auth-field input{width:100%;padding:10px 14px;border:1px solid rgba(0,0,0,0.15);border-radius:9px;font-size:13px;outline:none;box-sizing:border-box;font-family:inherit;}
.auth-field input:focus{border-color:#7B52CC;box-shadow:0 0 0 3px rgba(123,82,204,0.1);}
.auth-btn{width:100%;padding:12px;background:#7B52CC;color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;}
.auth-btn:hover{background:#4A2E8A;}
.auth-btn:disabled{opacity:0.6;cursor:not-allowed;}
.auth-error{background:#FFEBEE;color:#C0392B;font-size:12px;padding:8px 12px;border-radius:7px;margin-bottom:1rem;display:none;}
.auth-panel-copy{display:flex;flex-direction:column;gap:3px;margin:-4px 0 14px;color:#5A5870;font-size:12px;line-height:1.45;}
.auth-panel-copy strong{font-size:14px;color:#1C1B2E;}
.auth-panel-copy span{display:block;}

/* Fullscreen meeting */
.meeting-fullscreen .main{position:relative;}
.meeting-fullscreen #meetingRunnerWrap{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4000;background:#F4F3FA;overflow:hidden;}
.meeting-fullscreen #meetingRunnerWrap>div{height:100vh !important;border-radius:0 !important;border:none !important;width:100vw !important;}
.meeting-fullscreen .topbar{display:none;}
.meeting-fullscreen .sb{display:none;}
.meeting-fullscreen .bos-nav{display:none;}
.meeting-fullscreen .bos-content{padding:0;}
.meeting-fullscreen #l10Content>*{max-width:100%;}
.meeting-fullscreen #l10Content div[style*='border-radius:11px']{width:100%;}
.meeting-fullscreen #l10Content table{width:100%;}

/* Issue detail modal */
.issue-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:9998;display:flex;align-items:center;justify-content:center;}
.issue-modal{background:white;border-radius:14px;width:580px;max-height:85vh;overflow-y:auto;box-shadow:0 12px 48px rgba(0,0,0,0.25);padding:0;}
.issue-modal-hdr{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(0,0,0,0.08);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.issue-modal-body{padding:1.25rem 1.5rem;}
.issue-note{background:#F4F3FA;border-radius:8px;padding:10px 12px;margin-bottom:8px;}
.issue-note-meta{font-size:10px;color:#9896B0;margin-bottom:4px;}
.issue-note-text{font-size:12px;color:#1C1B2E;line-height:1.5;}

/* Cash Cow Clinic Hub page */
.cashcow-view{padding:1.1rem;background:#F4F3FA;overflow-x:hidden;}
.cashcow-page{width:100%;max-width:1120px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.cashcow-page>*{min-width:0;}
.cashcow-hero{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);gap:22px;align-items:center;min-height:430px;padding:34px;border-radius:8px;background:#1A1724;color:#fff;overflow:hidden;position:relative;}
.cashcow-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(123,82,204,.18),rgba(20,109,74,.25) 48%,rgba(244,189,75,.16));pointer-events:none;}
.cashcow-hero-copy,.cashcow-hero-media{position:relative;z-index:1;min-width:0;}
.cashcow-eyebrow,.cashcow-section-kicker{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:0;color:#D8C96A;margin-bottom:8px;}
.cashcow-hero h1{font-size:54px;line-height:.98;margin:0;color:#fff;font-weight:900;letter-spacing:0;max-width:620px;overflow-wrap:break-word;}
.cashcow-lede{font-size:20px;line-height:1.35;font-weight:800;color:#FFFFFF;margin:14px 0 8px;max-width:560px;}
.cashcow-body{font-size:14px;line-height:1.7;color:#E8E4F2;margin:0;max-width:620px;}
.cashcow-hero-actions{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px;}
.cashcow-btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border-radius:6px;border:1px solid rgba(255,255,255,.35);background:#fff;color:#1A1724;font-size:12px;font-weight:900;line-height:1;padding:10px 13px;text-decoration:none;cursor:pointer;}
.cashcow-btn.primary{background:#7B52CC;border-color:#7B52CC;color:#fff;}
.cashcow-hero-media{width:100%;max-width:100%;min-height:330px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;}
.cashcow-hero-media img{order:1;width:100%;max-width:350px;height:auto;display:block;filter:drop-shadow(0 22px 34px rgba(0,0,0,.35));}
.cashcow-offer-card{order:2;display:flex;align-items:center;gap:10px;min-width:0;padding:10px 13px;border-radius:8px;background:#FFF8D8;color:#1A1724;border:1px solid rgba(244,189,75,.8);box-shadow:0 14px 30px rgba(0,0,0,.22);z-index:2;}
.cashcow-offer-card span,.cashcow-offer-card small{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:0;color:#805400;}
.cashcow-offer-card strong{font-size:28px;line-height:1;color:#166342;}
.cashcow-proof-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;}
.cashcow-proof-strip div{background:#fff;border:1px solid #E5E1F2;border-radius:8px;padding:13px 14px;}
.cashcow-proof-strip span,.cashcow-card span{display:block;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:0;color:#9896B0;margin-bottom:4px;}
.cashcow-proof-strip strong{font-size:16px;color:#1C1B2E;line-height:1.2;}
.cashcow-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;}
.cashcow-panel,.cashcow-card,.cashcow-use-case{background:#fff;border:1px solid #E5E1F2;border-radius:8px;padding:22px;}
.cashcow-dark-panel{background:#102D25;border-color:#1B654A;color:#fff;}
.cashcow-panel h2,.cashcow-use-case h2{font-size:28px;line-height:1.14;margin:0;color:#1C1B2E;letter-spacing:0;}
.cashcow-dark-panel h2{color:#fff;}
.cashcow-panel p{font-size:14px;line-height:1.65;color:#5A5870;margin:12px 0 0;}
.cashcow-dark-panel p{color:#D8EFE5;}
.cashcow-leak-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
.cashcow-leak-grid span{display:flex;align-items:center;min-height:42px;border-radius:8px;background:#F8F6FD;border:1px solid #E7DFF8;color:#2E2740;font-size:13px;font-weight:800;padding:9px 10px;}
.cashcow-gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.cashcow-gallery img{width:100%;aspect-ratio:1.12/1;object-fit:cover;border-radius:8px;border:1px solid #E5E1F2;background:#fff;}
.cashcow-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;}
.cashcow-card h3{font-size:16px;line-height:1.25;color:#1C1B2E;margin:0 0 8px;letter-spacing:0;}
.cashcow-card p{font-size:13px;line-height:1.55;color:#5A5870;margin:0;}
.cashcow-use-case{display:flex;align-items:center;justify-content:space-between;gap:18px;background:#F8FBFA;border-color:#CDEBDD;}
.cashcow-use-case .cashcow-section-kicker{color:#166342;}
.cashcow-use-case h2{max-width:720px;}

/* v111.17: Launch hardening for invite linking, email API auth, and stamped direct OS writes. */
.bos-phone-only{display:none;}
.os-phone-mini-dashboard{display:none;}
.os-mobile-inline-status{display:none;}
@media (max-width: 700px) {
  html,body{height:100dvh;overflow:hidden;}
  .app{height:100dvh;width:100%;overflow:hidden;}
  .sb{position:fixed;top:0;left:0;bottom:0;width:min(82vw,280px);height:100dvh;z-index:700;box-shadow:8px 0 28px rgba(0,0,0,0.18);margin-left:0;transform:translateX(0);transition:transform 0.2s ease;}
  .sb.collapsed{margin-left:0;transform:translateX(-105%);}
  .sb-toggle-btn,.sb-toggle-btn.visible{display:flex;top:10px;left:10px;z-index:720;}
  .main{height:100dvh;width:100%;min-width:0;}
  .topbar,.hdr{height:auto;min-height:48px;padding:8px 10px 8px 48px;gap:8px;align-items:center;flex-wrap:wrap;}
  .topbar-right,.kpi-pills,.summary-pills,.hero-chips{gap:6px;flex-wrap:wrap;justify-content:flex-end;}
  .content,.bos-content,.calc-scroll,.pg-wrap{overflow:auto;-webkit-overflow-scrolling:touch;}
  .view{padding:12px;}
  #v-calcs.show,.calc-embed-view,.bos-wrap{height:calc(100dvh - 48px);}
  .bos-wrap{flex-direction:column;position:relative;}
  .bos-mobile-seg-btn{display:flex;align-items:center;gap:8px;height:42px;margin:8px 10px 0;padding:0 12px;border:1px solid #C4B3EF;border-radius:9px;background:white;color:#4A2E8A;font-size:13px;font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,0.06);cursor:pointer;}
  .bos-mobile-seg-btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .os-mobile-team-switcher{display:block;margin:8px 10px 0;}
  .os-mobile-team-switcher select{width:100%;height:40px;border:1px solid #C4B3EF;border-radius:9px;background:white;color:#1C1B2E;font-size:13px;font-weight:700;font-family:inherit;padding:0 12px;outline:none;box-shadow:0 1px 4px rgba(0,0,0,0.05);}
  .bos-nav{display:none;position:absolute;top:56px;left:10px;right:10px;width:auto;max-height:min(70dvh,520px);flex-direction:column;overflow-y:auto;overflow-x:hidden;border:1px solid rgba(0,0,0,0.1);border-radius:10px;background:white;padding:6px;z-index:640;box-shadow:0 12px 32px rgba(0,0,0,0.18);scrollbar-width:none;}
  .bos-nav.mobile-open{display:flex;}
  .os-maintenance-tools{display:none!important;}
  #calcsSidebarSection{display:none!important;}
  #calcsSidebarSection[data-pro-teaser="true"],#osSidebarSection[data-pro-teaser="true"]{display:block!important;}
  .bos-nav::-webkit-scrollbar,.tabs::-webkit-scrollbar,.calc-embed-topbar::-webkit-scrollbar{display:none;}
  .bos-nav.collapsed{margin-left:0;}
  .bos-nav-hdr,.bos-nav-toggle{display:none!important;}
  #bosInnerNav .bni[data-phone-hidden="true"]{display:none!important;}
  #bosInnerNav .bni.bos-phone-only{display:flex;}
  #bosInnerNav .bnhr{display:none!important;}
  .bni{white-space:nowrap;border-left:0;border-bottom:0;flex:0 0 auto;padding:10px 12px;border-radius:8px;width:100%;}
  .bni.active{border-left-color:transparent;border-bottom-color:transparent;background:#EDE8F9;}
  .bos-content{padding:12px;}
  #bp-my90 > div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:minmax(0,1fr)!important;}
  #bp-my90 .os-card{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  #bp-my90 .os-card-table{min-width:520px;}
  .os-phone-mini-dashboard{display:block;margin-bottom:12px;}
  .os-mini-hero{background:#1C1B2E;color:white;border-radius:10px;padding:14px 15px;margin-bottom:10px;}
  .os-mini-hero-title{font-size:16px;font-weight:700;line-height:1.25;}
  .os-mini-hero-sub{font-size:12px;color:#DCD6F2;margin-top:2px;}
  .os-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
  .os-mini-tile{background:white;border:1px solid rgba(0,0,0,0.08);border-radius:10px;padding:11px 12px;min-height:76px;cursor:pointer;}
  .os-mini-tile-label{font-size:10px;font-weight:700;color:#5A5870;text-transform:uppercase;letter-spacing:0;}
  .os-mini-tile-value{font-size:24px;font-weight:800;color:#7B52CC;margin-top:5px;line-height:1;}
  .os-mini-tile-meta{font-size:11px;color:#9896B0;margin-top:4px;line-height:1.25;}
  .os-mini-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;margin-top:10px;}
  .os-mini-action{min-height:36px;border:1px solid #C4B3EF;background:#FFFFFF;color:#7B52CC;border-radius:8px;font-size:12px;font-weight:700;font-family:inherit;cursor:pointer;padding:7px 8px;}
  .os-mini-action.primary{background:#7B52CC;color:white;border-color:#7B52CC;}
  #bp-rocks .os-card-table th:nth-child(1),
  #bp-rocks .os-card-table td:nth-child(1),
  #bp-rocks .os-card-table th:nth-child(4),
  #bp-rocks .os-card-table td:nth-child(4),
  #bp-todos .os-card-table th:nth-child(3),
  #bp-todos .os-card-table td:nth-child(3),
  #bp-issues .os-card-table th:nth-child(2),
  #bp-issues .os-card-table td:nth-child(2){display:none!important;}
  #bp-rocks .os-card-table th:nth-child(2),
  #bp-rocks .os-card-table td:nth-child(2),
  #bp-todos .os-card-table th:nth-child(2),
  #bp-todos .os-card-table td:nth-child(2),
  #bp-issues .os-card-table th:nth-child(1),
  #bp-issues .os-card-table td:nth-child(1){width:auto!important;min-width:0!important;}
  #bp-rocks .os-card-table td:nth-child(2) span,
  #bp-todos .os-card-table td:nth-child(2) span,
  #bp-issues .os-card-table td:nth-child(1) span{max-width:none!important;white-space:normal!important;overflow:visible!important;text-overflow:clip!important;}
  #bp-rocks .os-card-table td:nth-child(2)>div,
  #bp-todos .os-card-table td:nth-child(2)>div,
  #bp-issues .os-card-table td:nth-child(1)>div{align-items:flex-start!important;}
  #bp-rocks .os-card-table td:nth-child(2)>div>div{display:flex!important;align-items:flex-start!important;gap:6px!important;flex-wrap:wrap!important;}
  #bp-rocks .os-card-table td:nth-child(2) .os-mobile-inline-status{display:inline-flex!important;align-items:center;flex-shrink:0;font-size:10px;padding:2px 8px;border-radius:20px;margin-top:1px;white-space:nowrap!important;}
  #bp-data .os-card-table th:first-child,
  #bp-data .os-card-table td:first-child{min-width:320px!important;}
  #bp-data .os-card-table td:first-child span{white-space:normal!important;overflow:visible!important;text-overflow:clip!important;}
  .tabs,.calc-embed-topbar{overflow-x:auto;white-space:nowrap;padding-left:12px;padding-right:12px;}
  .tab,.tb{flex:0 0 auto;}
  .calc-grid,.res-cards-grid{grid-template-columns:minmax(0,1fr);}
  .swot-grid,.three-col,.two-col,.four-col,.grid2,.grid3,.grid4,.layout,.inv-grid,.results-row,.add-grid{grid-template-columns:minmax(0,1fr)!important;}
  .post-card{max-width:none;}
  .cashcow-view{padding:10px;}
  .cashcow-page{max-width:100%;overflow-x:hidden;}
  .cashcow-hero{grid-template-columns:minmax(0,1fr);width:100%;max-width:100%;min-height:0;padding:24px 18px;gap:18px;}
  .cashcow-hero-copy{width:100%;max-width:100%;}
  .cashcow-hero h1{font-size:34px;line-height:1.04;}
  .cashcow-lede{font-size:18px;max-width:320px;}
  .cashcow-body{font-size:13px;max-width:320px;}
  .cashcow-hero-actions{display:grid;grid-template-columns:minmax(0,1fr);max-width:240px;}
  .cashcow-hero-media{min-height:240px;}
  .cashcow-hero-media img{max-width:290px;}
  .cashcow-offer-card{align-self:flex-start;max-width:240px;width:100%;}
  .cashcow-proof-strip,.cashcow-split,.cashcow-gallery,.cashcow-card-grid{grid-template-columns:minmax(0,1fr);}
  .cashcow-panel h2,.cashcow-use-case h2{font-size:22px;}
  .cashcow-use-case{align-items:flex-start;flex-direction:column;}
  .event-row{flex-direction:column;gap:8px;}
  .card,.sec,.os-card,.panel{padding:12px;}
  .staff-wrap,.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .staff-tbl{min-width:900px;}
  .staff-tbl th.row-lbl,.staff-tbl td.row-lbl{min-width:124px;max-width:150px;white-space:normal;}
  .alloc-tbl,.cc-tbl,.tbl,.ref-table,.mult-tbl{min-width:620px;}
  .issue-modal{width:min(96vw,720px);max-height:92dvh;}
  .issue-modal-hdr,.issue-modal-body{padding:14px;}
}
@media (max-width: 520px) {
  .topbar,.hdr{padding-left:44px;}
  .topbar-title,.hdr-title,.pg-title,.os-section-title{font-size:15px;}
  .topbar-sub,.hdr-sub,.pg-sub,.os-section-sub{font-size:11px;}
  .view,.bos-content,.calc-scroll,.pg{padding:10px;}
  .field{align-items:stretch;flex-wrap:wrap;}
  .fl{min-width:100%;}
  .fv,.cv{width:100%;min-width:0;}
  .kpill{min-width:78px;padding:5px 8px;}
  .kpill-val,.dash-val,.sum-val{font-size:16px;}
  .calc-card,.res-card,.post-card{border-radius:8px;padding:12px;}
  #communityLibraryDrop{min-height:48px;}
}

.mobile-header-overflow-btn,
.mobile-header-overflow-menu{display:none;}

@media (max-width: 1024px) {
  html.ivms-mobile-header-preview .topbar{
    height:48px;
    min-height:48px;
    padding:0 8px 0 48px;
    gap:8px;
    align-items:center;
    flex-wrap:nowrap;
    overflow:visible;
    position:relative;
  }
  html.ivms-mobile-header-preview .topbar-title{
    color:#fff;
    flex:1 1 auto;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:14px;
    font-weight:800;
    letter-spacing:0;
  }
  html.ivms-mobile-header-preview .topbar-right{
    flex:0 0 auto;
    min-width:0;
    gap:6px;
    flex-wrap:nowrap;
    justify-content:flex-end;
  }
  html.ivms-mobile-header-preview .topbar .live-dot,
  html.ivms-mobile-header-preview .topbar #refreshBtn,
  html.ivms-mobile-header-preview .topbar #platformAdminBadge,
  html.ivms-mobile-header-preview .topbar #tAv,
  html.ivms-mobile-header-preview .topbar > #saveStatusPill{
    display:none!important;
  }
  html.ivms-mobile-header-preview #manualSaveBtn{
    width:30px!important;
    min-width:30px!important;
    height:30px!important;
    padding:0!important;
    border-radius:50%!important;
    background:rgba(255,255,255,0.16)!important;
    flex:0 0 30px;
    overflow:hidden;
    position:relative;
  }
  html.ivms-mobile-header-preview #manualSaveBtn svg,
  html.ivms-mobile-header-preview #manualSaveBtn [data-manual-save-label]{
    display:none!important;
  }
  html.ivms-mobile-header-preview #manualSaveBtn::before{
    content:"";
    display:block;
    width:7px;
    height:7px;
    border-radius:50%;
    background:rgba(255,255,255,0.92);
  }
  html.ivms-mobile-header-preview #manualSaveBtn[data-mobile-save-state="saved"]::before{
    width:13px;
    height:7px;
    border-radius:0;
    background:transparent;
    border-left:2px solid #fff;
    border-bottom:2px solid #fff;
    transform:rotate(-45deg) translate(1px,-1px);
  }
  html.ivms-mobile-header-preview #manualSaveBtn[data-mobile-save-state="busy"]::before{
    width:13px;
    height:13px;
    background:transparent;
    border:2px solid rgba(255,255,255,0.35);
    border-top-color:#fff;
    animation:ivmsMobileSaveSpin 0.8s linear infinite;
  }
  html.ivms-mobile-header-preview #manualSaveBtn[data-mobile-save-state="error"]::before{
    content:"!";
    width:16px;
    height:16px;
    border-radius:50%;
    background:#FFE3E0;
    color:#B42318;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:12px;
    font-weight:900;
    line-height:1;
  }
  html.ivms-mobile-header-preview #manualSaveBtn[data-mobile-save-state="locked"]::before{
    width:12px;
    height:9px;
    border-radius:2px;
    background:transparent;
    border:2px solid #fff;
    box-shadow:0 -5px 0 -2px #fff;
  }
  html.ivms-mobile-header-preview .topbar #notifBell,
  html.ivms-mobile-header-preview .mobile-header-overflow-btn{
    display:inline-flex!important;
    width:30px!important;
    height:30px!important;
    border-radius:50%!important;
    background:rgba(255,255,255,0.14)!important;
    color:#fff;
    flex:0 0 30px;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-btn{
    border:0;
    padding:0;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    font-family:inherit;
  }
  html.ivms-mobile-header-preview .topbar > #userBadge{
    display:flex!important;
    align-items:center!important;
    gap:0!important;
    margin-left:0!important;
    height:30px;
    flex:0 0 auto;
  }
  html.ivms-mobile-header-preview .topbar > #userBadge > span,
  html.ivms-mobile-header-preview .topbar > #userBadge > button{
    display:none!important;
  }
  html.ivms-mobile-header-preview #topRightAvatar{
    width:30px!important;
    height:30px!important;
    font-size:10px!important;
    flex:0 0 30px;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu{
    position:absolute;
    top:44px;
    right:8px;
    width:min(92vw,292px);
    max-height:min(72dvh,420px);
    overflow-y:auto;
    background:#fff;
    color:#1C1B2E;
    border:1px solid rgba(0,0,0,0.08);
    border-radius:8px;
    box-shadow:0 14px 38px rgba(28,27,46,0.22);
    z-index:9100;
    padding:7px;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu.open{
    display:block;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu button,
  html.ivms-mobile-header-preview .mobile-header-menu-plan,
  html.ivms-mobile-header-preview .mobile-header-menu-status{
    width:100%;
    min-height:36px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    border:0;
    border-radius:7px;
    padding:8px 10px;
    background:#fff;
    color:#1C1B2E;
    font-family:inherit;
    font-size:12px;
    font-weight:750;
    line-height:1.25;
    text-align:left;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu button{
    cursor:pointer;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu button:hover,
  html.ivms-mobile-header-preview .mobile-header-overflow-menu button:focus{
    background:#F4F3FA;
    outline:none;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu button span{
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    color:#5A5870;
    font-weight:700;
  }
  html.ivms-mobile-header-preview .mobile-header-overflow-menu .danger{
    color:#B42318;
  }
  html.ivms-mobile-header-preview .mobile-header-menu-status{
    min-height:32px;
    background:#F7F5FD;
    color:#5A5870;
    font-size:11px;
    font-weight:800;
    text-transform:none;
  }
  html.ivms-mobile-header-preview .mobile-header-menu-status span{
    display:inline-flex;
    align-items:center;
    gap:6px;
    min-width:0;
  }
  html.ivms-mobile-header-preview .mobile-header-live-dot{
    width:6px;
    height:6px;
    border-radius:50%;
    background:#37D67A;
    box-shadow:0 0 0 3px rgba(55,214,122,0.13);
    flex:0 0 auto;
  }
  html.ivms-mobile-header-preview .mobile-header-menu-plan{
    background:#F8F6FD;
    color:#4A2E8A;
  }
  html.ivms-mobile-header-preview #notifPanel{
    top:44px!important;
    right:8px!important;
    width:min(92vw,340px)!important;
    max-height:min(72dvh,400px)!important;
  }
  html.ivms-mobile-header-preview .content,
  html.ivms-mobile-header-preview #v-calcs.show,
  html.ivms-mobile-header-preview .calc-embed-view,
  html.ivms-mobile-header-preview .bos-wrap{
    height:calc(100dvh - 48px);
  }
}

@media (max-width: 700px) {
  html.ivms-mobile-header-preview .sb-toggle-btn,
  html.ivms-mobile-header-preview .sb-toggle-btn.visible{
    width:26px;
    height:26px;
    top:12px;
    left:10px;
  }
  html.ivms-mobile-header-preview .sb:not(.collapsed) .sb-brand{
    min-height:52px;
    padding:10px 10px 10px 48px;
    gap:8px;
  }
  html.ivms-mobile-header-preview .sb:not(.collapsed) .sb-platform-brand{
    min-width:0;
  }
  html.ivms-mobile-header-preview .sb:not(.collapsed) .sb-brand-name.mypracticehq-main{
    font-size:14px;
    line-height:1.08;
  }
}

@keyframes ivmsMobileSaveSpin{
  to{transform:rotate(360deg);}
}
