/* ── TOKENS ── */
:root{
  --navy:#0D1B2A;--navy-mid:#1A3A5C;--navy-light:#1B5FA8;
  --slate:#5A7A9A;--slate-light:#8BACC8;
  --accent:#1A73E8;--accent-bright:#1A73E8;--mint:#2BC48A;--mint-hi:#59FFC1;
  --surface:#FFFFFF;--surface2:#F0F4F8;--surface3:#E6EEF5;
  --border:#D5E2EF;--border2:#C4D6EA;
  --text:#0A2240;--text2:#4A6580;--text3:#8A9CB0;
  --success:#16A34A;--success-light:#22C55E;
  --error:#DC2626;--warning:#D97706;
  --gold:#C9A84C;
  --rail-w:48px;--sidebar-w:268px;
  --radius:10px;--radius-sm:7px;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;--font-head:'Onest',sans-serif;
  --shadow-sm:0 2px 8px rgba(10,34,64,.08);
  --shadow-md:0 4px 20px rgba(10,34,64,.13);
  --shadow-lg:0 8px 40px rgba(10,34,64,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--surface2);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}
body.ext-mode{height:auto;overflow-y:auto;overflow-x:hidden;display:block}

/* ── HEADER ── */
.app-header{height:56px;background:var(--navy);display:flex;align-items:center;padding:0 20px 0 0;gap:0;flex-shrink:0;box-shadow:0 2px 16px rgba(0,0,0,.4);z-index:50;position:relative;border-bottom:1px solid rgba(255,255,255,.07)}
.app-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#1A73E8 0%,#2BC48A 50%,#59FFC1 100%)}
.header-logo{height:56px;display:flex;align-items:center;justify-content:flex-start;flex-shrink:0;padding:0 24px 0 16px;position:relative}
.header-logo::after{content:'';position:absolute;right:0;top:12px;bottom:12px;width:1px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.1),transparent)}
.logo-mark-sm{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent-bright));border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:14px;color:#fff;letter-spacing:-.5px}
.header-brand{display:flex;flex-direction:column;gap:1px}
.header-brand .brand{font-family:var(--font-head);font-size:14px;font-weight:700;color:#fff}
.header-brand .sub{font-family:var(--font-head);font-size:9px;font-weight:500;color:var(--slate-light);letter-spacing:1.2px;text-transform:uppercase}
.header-right{margin-left:auto;display:flex;align-items:center;gap:12px;padding-right:4px}
.lic-text{font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--slate-light);letter-spacing:.8px;text-transform:uppercase}
.role-toggle{display:flex;align-items:center;gap:5px;padding:4px 11px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:20px;cursor:pointer;font-family:var(--font-head);font-size:11px;font-weight:600;color:#fff;transition:all .2s;user-select:none}
.role-toggle:hover{background:rgba(255,255,255,.15)}
.role-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0;transition:background .2s}
.role-dot.field{background:#60A5FA}

/* ── LAYOUT ── */
.app-body{flex:1;display:flex;overflow:hidden;height:calc(100vh - 56px);min-height:0}

/* ── RAIL ── */
.rail{width:var(--rail-w);background:#0D1B2E;display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:4px;flex-shrink:0;border-right:1px solid rgba(255,255,255,.07);height:100%}
.rail-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--slate-light);position:relative}
.rail-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.rail-btn.active{background:rgba(26,115,232,.25);border-left:2px solid #2BC48A;color:#fff;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.rail-btn svg{width:17px;height:17px}
.rail-tip{position:absolute;left:calc(var(--rail-w) + 6px);background:var(--navy);color:#fff;font-family:var(--font-head);font-size:11px;font-weight:600;padding:4px 8px;border-radius:5px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:200}
.rail-btn:hover .rail-tip{opacity:1}
.rail-divider{width:24px;height:1px;background:rgba(255,255,255,.1);margin:4px 0}

/* ── SIDEBAR ── */
.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;height:100%;overflow:hidden;min-height:0}
.sidebar-head{padding:10px 10px 8px;border-bottom:2px solid var(--accent);flex-shrink:0;display:flex;flex-direction:column;gap:7px}
.search-wrap{position:relative}
.search-ico{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}
.sidebar-search{width:100%;padding:6px 8px 6px 27px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:12px;color:var(--text);outline:none;transition:border-color .2s}
.sidebar-search:focus{border-color:var(--accent);background:#fff}
.quick-filters{display:flex;gap:4px}
.qf-btn{flex:1;padding:4px 0;font-family:var(--font-head);font-size:10.5px;font-weight:700;background:var(--surface2);border:1.5px solid var(--border);border-radius:5px;cursor:pointer;color:var(--text3);transition:all .2s;letter-spacing:.3px}
.qf-btn:hover{border-color:var(--accent);color:var(--accent)}
.qf-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:800}
.sidebar-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0;min-height:0}
.sidebar-body::-webkit-scrollbar{width:3px}
.sidebar-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ── SIDEBAR TREE ── */
.tree-node{user-select:none}
.tree-year{padding:5px 10px 4px;font-family:var(--font-head);font-size:10px;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:1.2px;cursor:pointer;display:flex;align-items:center;gap:5px;border-left:3px solid var(--accent);margin:4px 0 2px;background:rgba(13,27,46,.04)}
.tree-month{padding:4px 10px 4px 18px;font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.8px;cursor:pointer;display:flex;align-items:center;gap:5px;border-left:3px solid var(--gold);margin-left:4px}
.tree-week{padding:4px 10px 4px 28px;font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--slate);cursor:pointer;display:flex;align-items:center;gap:5px;border-left:3px solid var(--accent-bright);margin-left:8px}
.tree-client{margin:2px 0 2px 12px;border-radius:var(--radius-sm);overflow:hidden}
.tree-client-head{padding:6px 10px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:background .15s;border-left:2px solid transparent}
.tree-client-head:hover{background:var(--surface2)}
.tree-client-head.active{background:rgba(37,99,235,.07);border-left-color:var(--accent)}
.client-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--mint));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:10px;color:#fff;flex-shrink:0}
.client-meta{flex:1;min-width:0}
.client-name{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-sub-info{font-size:10.5px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-forms-count{font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--slate);background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:1px 6px;flex-shrink:0}
.tree-client-body{padding:2px 0 4px 0;display:none}
.tree-client-body.open{display:block}
.tree-form-item{padding:5px 10px 5px 44px;cursor:pointer;display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text2);transition:background .15s;border-radius:0}
.tree-form-item:hover{background:var(--surface3)}
.tree-form-item.active{background:rgba(37,99,235,.08);color:var(--navy);font-weight:600}
.tree-form-item .fi-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.fi-dot-0{background:#1B4F8A}
.fi-dot-1{background:#16A34A}
.fi-dot-2{background:var(--gold)}
.fi-dot-attach{background:var(--slate)}
.tree-form-item .fi-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11.5px}
.fi-date{font-size:10px;color:var(--text3);flex-shrink:0}
.tree-caret{font-size:9px;color:var(--text3);transition:transform .2s;flex-shrink:0}
.tree-caret.open{transform:rotate(90deg)}

/* ── SIDEBAR FOOTER - NEW FORM BUTTONS ── */
.sidebar-footer{border-top:1px solid var(--border);padding:8px;flex-shrink:0;display:flex;flex-direction:column;gap:5px}
.new-form-btn{display:flex;align-items:center;gap:7px;padding:7px 10px;border-radius:var(--radius-sm);border:1.5px dashed var(--border2);background:none;cursor:pointer;font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--slate);transition:all .2s;text-align:left;width:100%}
.new-form-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(37,99,235,.04)}
.new-form-btn .nfb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── MAIN PANEL ── */
.main-panel{flex:1;overflow:hidden;display:flex;flex-direction:column;height:100%;min-width:0}
.view{display:none;flex:1;overflow-y:auto;flex-direction:column}
.view.active{display:flex}

/* ── FORM VIEW ── */
.form-topbar{padding:14px 24px 12px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}
.form-topbar-title{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--navy)}
.form-topbar-sub{font-size:12px;color:var(--text3);margin-top:1px}

/* ── CLIENT PICKER BAR ── */
.client-picker-bar{background:linear-gradient(90deg,rgba(10,34,64,.04),rgba(37,99,235,.04));border-bottom:1px solid var(--border);padding:10px 24px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.cpb-label{font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.cpb-search-wrap{flex:1;max-width:320px;position:relative}
.cpb-input{width:100%;padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;color:var(--text);background:#fff;outline:none;transition:all .2s}
.cpb-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.cpb-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid var(--accent);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:var(--shadow-md);z-index:100;max-height:180px;overflow-y:auto;display:none}
.cpb-opt{padding:8px 12px;font-size:13px;cursor:pointer;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;transition:background .15s}
.cpb-opt:last-child{border-bottom:none}
.cpb-opt:hover{background:var(--surface2)}
.cpb-opt .cpb-av{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--accent));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:9px;color:#fff;flex-shrink:0}
.cpb-opt .cpb-info{flex:1;min-width:0}
.cpb-opt .cpb-name{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--navy)}
.cpb-opt .cpb-contact{font-size:11px;color:var(--text3)}
.cpb-new-opt{padding:8px 12px;font-size:12px;font-family:var(--font-head);font-weight:700;color:var(--accent);cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s}
.cpb-new-opt:hover{background:rgba(37,99,235,.06)}
.cpb-selected-chip{display:flex;align-items:center;gap:7px;background:rgba(37,99,235,.08);border:1.5px solid rgba(37,99,235,.25);border-radius:20px;padding:4px 10px 4px 6px}
.cpb-chip-av{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--accent));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:9px;color:#fff}
.cpb-chip-name{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--navy)}
.cpb-chip-x{font-size:14px;color:var(--text3);cursor:pointer;line-height:1;padding:0 2px}
.cpb-chip-x:hover{color:var(--error)}

/* ── FORM CONTENT AREA ── */
.form-content-scroll{flex:1;overflow-y:auto;padding:0}
.form-inner{max-width:780px;margin:0 auto;padding:24px 24px 80px}

/* ── FORM CARD (from v3) ── */
.form-card{background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden;margin-bottom:16px}
.form-header{background:linear-gradient(90deg,var(--navy),var(--navy-mid));padding:18px 24px;display:flex;align-items:center;gap:12px}
.sec-icon{width:34px;height:34px;background:rgba(255,255,255,.12);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.sec-title{color:#fff}
.sec-title h3{font-family:var(--font-head);font-size:13.5px;font-weight:700}
.sec-title p{font-size:11.5px;color:var(--slate-light);margin-top:2px}
.form-id{margin-left:auto;font-family:var(--font-head);font-size:10px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:1px;text-transform:uppercase}
.form-body{padding:24px}
.section-label{font-family:var(--font-head);font-size:10.5px;font-weight:800;color:var(--navy);letter-spacing:1.3px;text-transform:uppercase;background:linear-gradient(90deg,rgba(37,99,235,.09) 0%,rgba(37,99,235,.02) 100%);border:none;border-left:3px solid var(--mint);border-radius:0 7px 7px 0;padding:9px 14px 9px 13px;margin-bottom:18px;margin-top:26px;display:block;width:100%}
.section-label:first-child{margin-top:0}
.grid{display:grid;gap:14px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:1fr 1fr 1fr}
.full{grid-column:1/-1}
@media(max-width:600px){.g2,.g3{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:var(--font-head);font-size:10.5px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.field label .req{color:var(--accent);margin-left:2px}
.req-error{border-color:var(--error)!important;box-shadow:0 0 0 3px rgba(220,38,38,.15)!important}
.field input,.field select,.field textarea{border:1.5px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-family:var(--font);font-size:13.5px;color:var(--text);background:#fff;outline:none;width:100%;transition:all .2s;box-shadow:inset 0 1px 3px rgba(10,34,64,.06)}
.field input::placeholder,.field textarea::placeholder{color:var(--text3)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.12),inset 0 1px 3px rgba(10,34,64,.04)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath fill='%235A7A9A' d='M0 0l5 7 5-7z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:32px;cursor:pointer}
.field textarea{resize:vertical;min-height:80px}
input[readonly]{background:var(--surface2);color:var(--slate);font-weight:600;cursor:default}
.check-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.cb-opt{display:flex;align-items:center;gap:7px;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:8px 14px;cursor:pointer;font-size:13px;color:var(--text2);transition:all .18s;user-select:none;box-shadow:0 1px 3px rgba(10,34,64,.06)}
.cb-opt input{display:none}
.cb-opt:hover{background:#fff;border-color:var(--accent-bright);box-shadow:0 3px 10px rgba(37,99,235,.12);transform:translateY(-1px)}
.cb-opt:has(input:checked){background:rgba(37,99,235,.1);border-color:var(--accent);color:var(--navy);font-weight:700;box-shadow:0 3px 10px rgba(37,99,235,.18);transform:translateY(-1px)}
.cb-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border);transition:all .18s;flex-shrink:0}
.cb-opt:has(input[type="radio"]:checked) .cb-dot{border-color:var(--accent);background:radial-gradient(circle,var(--accent) 55%,rgba(37,99,235,.15) 100%);box-shadow:0 0 0 2px rgba(37,99,235,.2)}
.cb-square{width:14px;height:14px;border-radius:3px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .18s;flex-shrink:0;font-size:9px}
.cb-opt:has(input[type="checkbox"]:checked) .cb-square{border-color:var(--accent);background:linear-gradient(135deg,var(--accent),var(--accent-bright));color:#fff;box-shadow:0 1px 4px rgba(37,99,235,.3)}
.address-wrapper{position:relative}
.pac-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1.5px solid var(--accent);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-md);z-index:200;max-height:200px;overflow-y:auto;display:none}
.pac-item{padding:10px 14px;font-size:13px;color:var(--text);cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.pac-item:last-child{border-bottom:none}
.pac-item:hover{background:var(--surface2)}
.input-prefix-wrap{position:relative;display:flex;align-items:center}
.input-prefix-wrap .prefix-symbol{position:absolute;left:13px;font-size:13.5px;color:var(--slate);font-weight:600;pointer-events:none;z-index:1}
.input-prefix-wrap input{padding-left:26px}
.input-suffix-wrap{position:relative;display:flex;align-items:center}
.input-suffix-wrap .suffix-symbol{position:absolute;right:13px;font-size:13.5px;color:var(--slate);font-weight:600;pointer-events:none}
.input-suffix-wrap input{padding-right:30px}
.doc-upload-grid{display:grid;gap:8px;margin-top:4px}
.doc-upload-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--surface2);transition:all .2s;cursor:pointer}
.doc-upload-item:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}
.doc-upload-item.uploaded{border-color:var(--success);background:rgba(22,163,74,.06)}
.doc-upload-item.empty{border-color:var(--error);background:rgba(220,38,38,.04)}
.doc-status-icon{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;transition:all .2s}
.doc-status-icon.ok{background:var(--success);color:#fff}
.doc-status-icon.no{background:var(--error);color:#fff}
.doc-upload-label{flex:1;font-size:13px;color:var(--text);font-weight:500}
.doc-upload-btn{font-family:var(--font-head);font-size:11px;font-weight:700;padding:5px 12px;border-radius:6px;border:1.5px solid var(--accent);background:rgba(37,99,235,.07);color:var(--accent);cursor:pointer;transition:all .2s;white-space:nowrap}
.doc-upload-btn:hover{background:var(--accent);color:#fff;box-shadow:0 3px 10px rgba(37,99,235,.22)}
.doc-upload-btn.uploaded{border-color:var(--success);color:var(--success);background:rgba(22,163,74,.08)}
input[type="file"].hidden-file{display:none}
.dep-table{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.dep-row{display:grid;grid-template-columns:2fr 1.2fr 1.2fr auto;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);align-items:end;background:#fff}
.dep-row:nth-child(even){background:var(--surface2)}
.dep-row:last-child{border-bottom:none}
.dep-row input,.dep-row select{font-size:13px;padding:7px 10px}
.dep-del-btn{width:28px;height:28px;border-radius:6px;border:none;background:rgba(220,38,38,.1);color:var(--error);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.dep-del-btn:hover{background:var(--error);color:#fff;box-shadow:0 3px 8px rgba(220,38,38,.25)}
.add-row-btn{width:100%;padding:10px;background:none;border:1.5px dashed var(--slate-light);border-radius:var(--radius);color:var(--slate);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;margin-top:8px;transition:all .2s;letter-spacing:.3px}
.add-row-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(37,99,235,.04);box-shadow:0 2px 8px rgba(37,99,235,.1)}
.datetime-range-wrap{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.datetime-range-wrap .dr-block{display:flex;flex-direction:column;gap:5px}
.datetime-range-wrap .dr-label{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.5px}
.datetime-range-wrap input{border:1.5px solid var(--border);border-radius:var(--radius);padding:8px 12px;font-size:13px;font-family:var(--font);width:100%;outline:none;transition:border-color .2s}
.datetime-range-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.sig-container{border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff}
.sig-tabs{display:flex;border-bottom:1px solid var(--border)}
.sig-tab{flex:1;padding:8px;font-family:var(--font-head);font-size:11px;font-weight:700;text-align:center;cursor:pointer;background:var(--surface2);color:var(--text3);border:none;letter-spacing:.5px;text-transform:uppercase;transition:all .2s}
.sig-tab.active{background:#fff;color:var(--navy);border-bottom:2px solid var(--accent)}
.sig-type-area{padding:12px;display:none}
.sig-type-area.active{display:block}
.sig-type-area input{border:none;border-bottom:1.5px solid var(--border);border-radius:0;padding:8px 4px;font-size:15px;font-style:italic;font-family:'Georgia',serif;color:var(--navy);width:100%;outline:none;transition:border-color .2s}
.sig-type-area input:focus{border-bottom-color:var(--accent)}
.sig-draw-area{padding:12px;display:none}
.sig-draw-area.active{display:block}
.sig-canvas{width:100%;height:120px;border:1px dashed var(--border);border-radius:8px;cursor:crosshair;touch-action:none;display:block;background:#FAFCFF}
.sig-draw-controls{display:flex;justify-content:flex-end;margin-top:6px}
.sig-clear-btn{font-family:var(--font-head);font-size:11px;font-weight:600;padding:5px 12px;border-radius:6px;border:1.5px solid var(--border);background:#fff;color:var(--text3);cursor:pointer;transition:all .2s}
.sig-clear-btn:hover{border-color:var(--error);color:var(--error)}
.conditional-reveal{display:none;margin-top:10px;padding:12px;background:rgba(37,99,235,.04);border:1px solid rgba(37,99,235,.15);border-radius:var(--radius)}
.conditional-reveal.show{display:block}
.divider{height:1px;background:linear-gradient(90deg,transparent 0%,var(--border2) 20%,var(--border2) 80%,transparent 100%);margin:22px 0;border:none}
.info-box{background:rgba(37,99,235,.05);border:1px solid rgba(37,99,235,.2);border-left:3px solid var(--accent);border-radius:var(--radius);padding:11px 15px;font-size:12.5px;color:var(--navy-mid);line-height:1.55;margin-bottom:18px}
.notice{font-size:11.5px;color:var(--text3);line-height:1.6;font-style:italic;border-top:1px solid var(--border);padding-top:14px;margin-top:14px}
.submit-row{display:flex;justify-content:flex-end;gap:10px;padding:20px 24px;background:linear-gradient(90deg,var(--surface2) 0%,#fff 100%);border-top:2px solid var(--border)}
.btn{font-family:var(--font-head);font-size:12.5px;font-weight:700;padding:11px 26px;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s;letter-spacing:.3px;display:flex;align-items:center;gap:7px}
.btn:active{transform:scale(.97)!important;box-shadow:none!important}
.btn-ghost{background:#fff;color:var(--text2);border:1.5px solid var(--border);box-shadow:0 1px 4px rgba(10,34,64,.07)}
.btn-ghost:hover{background:var(--surface2);border-color:var(--slate);box-shadow:0 3px 10px rgba(10,34,64,.11);transform:translateY(-1px)}
.btn-success{background:linear-gradient(135deg,#15803D,var(--success-light));color:#fff;box-shadow:0 4px 16px rgba(34,197,94,.32)}
.btn-success:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(34,197,94,.38)}
.btn-preview{background:linear-gradient(135deg,#374151,#4B5563);color:#fff;box-shadow:0 4px 14px rgba(55,65,81,.25)}
.btn-preview:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(55,65,81,.3)}
.btn-primary{background:linear-gradient(135deg,var(--navy-light),var(--accent));color:#fff;box-shadow:0 4px 14px rgba(37,99,235,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,99,235,.36)}

/* ── OVERVIEW VIEW ── */
.overview-scroll{flex:1;overflow-y:auto;padding:24px}
.ov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.ov-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:16px 18px;box-shadow:var(--shadow-sm)}
.ov-card .ov-label{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.ov-card .ov-val{font-family:var(--font-head);font-size:28px;font-weight:800;color:var(--navy)}
.ov-card .ov-sub{font-size:11.5px;color:var(--text3);margin-top:3px}
.ov-section{background:#fff;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.ov-section-head{padding:12px 18px;background:linear-gradient(90deg,var(--navy),var(--navy-mid));display:flex;align-items:center;gap:8px}
.ov-section-head span{font-family:var(--font-head);font-size:12px;font-weight:700;color:#fff;letter-spacing:.3px}
.ov-table{width:100%;border-collapse:collapse}
.ov-table th{padding:8px 14px;font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface2)}
.ov-table td{padding:10px 14px;font-size:12.5px;color:var(--text);border-bottom:1px solid var(--border)}
.ov-table tr:last-child td{border-bottom:none}
.ov-table tr:hover td{background:var(--surface2)}

/* ── DASHBOARD ── */
.dash-scroll{flex:1;overflow-y:auto;padding:20px 22px;background:var(--bg2)}
.dash-greeting-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}
.dash-greeting h1{font-size:21px;font-weight:500;color:var(--navy);line-height:1.2}
.dash-greeting p{font-size:12px;color:var(--text3);margin-top:3px}
.dash-sec-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:9px;font-family:var(--font-head)}
.dash-priority-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:20px}
.dash-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:20px}
.dash-widgets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:20px}
.dc{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:13px 15px;box-shadow:var(--shadow-sm)}
.dc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dc-title{display:flex;align-items:center;gap:6px;font-family:var(--font-head);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text2)}
.dc-title svg{width:13px;height:13px;flex-shrink:0}
.dc-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}
.dc-badge-blue{background:rgba(27,127,204,.12);color:#185FA5}
.dc-badge-amber{background:rgba(234,179,8,.15);color:#854F0B}
.dc-badge-green{background:rgba(34,197,94,.12);color:#166534}
.dc-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:0.5px solid var(--border);font-size:12px}
.dc-row:last-child{border-bottom:none;padding-bottom:0}
.dc-row-name{color:var(--text);font-size:12px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.dc-row-name:hover{color:var(--accent);text-decoration:underline}
.dc-rdate{font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;white-space:nowrap;flex-shrink:0}
.dc-rdate-red{background:rgba(220,38,38,.1);color:#A32D2D}
.dc-rdate-amber{background:rgba(234,179,8,.15);color:#854F0B}
.dc-rdate-green{background:rgba(34,197,94,.12);color:#166534}
.dc-task-filter{display:flex;border:1px solid var(--border);border-radius:5px;overflow:hidden}
.dc-tf-btn{padding:3px 9px;cursor:pointer;color:var(--text3);background:#fff;border:none;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:.2px;transition:all .15s}
.dc-tf-btn.active{background:var(--navy);color:#fff}
.dc-task-item{padding:7px 9px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px}
.dc-task-item:last-child{margin-bottom:0}
.dc-task-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:3px;gap:6px}
.dc-task-text{font-size:12px;font-weight:600;color:var(--text);line-height:1.3}
.dc-task-who{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;flex-shrink:0}
.dc-who-me{background:rgba(27,127,204,.12);color:#185FA5}
.dc-who-other{background:rgba(139,92,246,.12);color:#6D28D9}
.dc-task-meta{display:flex;align-items:center}
.dc-task-client{font-size:11px;color:var(--accent);display:flex;align-items:center;gap:3px;cursor:pointer}
.dc-task-client:hover{text-decoration:underline}
.dc-task-due{font-size:10px;color:var(--text3);margin-left:auto;padding-left:8px;white-space:nowrap}
.dc-task-overdue{font-size:10px;color:#A32D2D;font-weight:700;margin-left:auto;padding-left:8px;white-space:nowrap}
.dc-doc-tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;white-space:nowrap;flex-shrink:0}
.dc-doc-enr{background:rgba(34,197,94,.12);color:#166534}
.dc-doc-aor{background:rgba(27,127,204,.12);color:#185FA5}
.dc-doc-id{background:rgba(220,38,38,.1);color:#A32D2D}
.dc-doc-other{background:var(--surface2);color:var(--text2)}
.dc-sub-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dc-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dc-stat-cell{background:var(--surface2);border-radius:var(--radius-sm);padding:10px 12px;border:1px solid var(--border)}
.dc-stat-num{font-family:var(--font-head);font-size:24px;font-weight:800;color:var(--navy)}
.dc-stat-lbl{font-size:11px;color:var(--text3);margin-top:2px}
.dc-cust-btn{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text2);background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;cursor:pointer;font-family:var(--font-head);transition:all .15s;white-space:nowrap}
.dc-cust-btn:hover{border-color:var(--accent);color:var(--accent)}
.dc-cust-btn svg{width:13px;height:13px}
.dc-empty{font-size:12px;color:var(--text3);padding:8px 0}
.dc-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.dc-bar-row:last-child{margin-bottom:0}
.dc-bar-label{font-size:11px;color:var(--text);width:90px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dc-bar-track{flex:1;height:7px;background:var(--surface2);border-radius:4px;overflow:hidden;border:1px solid var(--border)}
.dc-bar-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .4s}
.dc-bar-count{font-size:10px;font-weight:700;color:var(--text3);min-width:18px;text-align:right}
/* Customize slide-over */
.dash-panel-overlay{position:fixed;inset:0;background:rgba(5,15,30,.35);z-index:2000;display:none}
.dash-panel-overlay.open{display:block}
.dash-panel{position:fixed;top:0;right:0;width:350px;height:100%;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.15);display:flex;flex-direction:column;z-index:2001;transform:translateX(100%);transition:transform .25s ease;overflow:hidden}
.dash-panel.open{transform:translateX(0)}
.dash-panel-hd{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--navy);color:#fff;flex-shrink:0}
.dash-panel-title{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:.3px}
.dash-panel-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.7);font-size:20px;line-height:1;padding:0;transition:color .15s}
.dash-panel-close:hover{color:#fff}
.dash-panel-body{flex:1;overflow-y:auto;padding:14px}
.dash-panel-sec-label{font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:7px;margin-top:14px;font-family:var(--font-head)}
.dash-panel-sec-label:first-child{margin-top:0}
.dwt{display:flex;align-items:flex-start;justify-content:space-between;padding:8px 10px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:5px;cursor:pointer;transition:border-color .15s}
.dwt:hover{border-color:var(--accent)}
.dwt.locked{cursor:default;opacity:.75}
.dwt.locked:hover{border-color:var(--border)}
.dwt-info{flex:1;min-width:0;padding-right:8px}
.dwt-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.3}
.dwt-src{font-size:10px;color:var(--text3);margin-top:1px;font-family:var(--font-head)}
.dwt-sw{width:30px;height:17px;border-radius:9px;border:none;cursor:pointer;transition:background .2s;flex-shrink:0;position:relative;margin-top:2px;outline:none}
.dwt-sw::after{content:'';position:absolute;top:2px;left:2px;width:13px;height:13px;border-radius:50%;background:#fff;transition:transform .2s}
.dwt-sw.on{background:var(--accent)}
.dwt-sw.on::after{transform:translateX(13px)}
.dwt-sw.off{background:var(--border)}
.dwt-sw.locked-sw{background:#b0bec5;cursor:default}
.dwt-sw.locked-sw::after{transform:translateX(13px)}
.dash-panel-footer{padding:11px 14px;border-top:1px solid var(--border);background:var(--surface2);flex-shrink:0}
.dash-panel-save{width:100%;padding:9px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:background .15s}
.dash-panel-save:hover{background:var(--navy)}
.dash-locked-note{font-size:10px;color:var(--text3);text-align:center;margin-top:5px}
/* Reporting customize panel reuses dash-panel classes — no extra CSS needed */
.rep-sec-toggle-row{display:flex;align-items:flex-start;justify-content:space-between;padding:9px 11px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px;cursor:pointer;transition:border-color .15s}
.rep-sec-toggle-row:hover{border-color:var(--accent)}
.rep-st-info{flex:1;min-width:0;padding-right:8px}
.rep-st-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.3}
.rep-st-src{font-size:10px;color:var(--text3);margin-top:1px;font-family:var(--font-head)}
.form-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-family:var(--font-head);font-size:10px;font-weight:700}
.fb-0{background:rgba(27,79,138,.12);color:var(--navy-light)}
.fb-1{background:rgba(22,163,74,.12);color:#15803D}
.fb-2{background:rgba(201,168,76,.15);color:#92670A}

/* ── SETTINGS VIEW ── */
.settings-scroll{flex:1;overflow-y:auto;padding:24px}
.settings-section{background:#fff;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.settings-section-head{padding:12px 18px;background:linear-gradient(90deg,var(--navy),var(--navy-mid));font-family:var(--font-head);font-size:12px;font-weight:700;color:#fff}
.settings-tabs{display:flex;gap:4px;padding:10px 20px 0;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.settings-tab{font-family:var(--font-head);font-size:12px;font-weight:700;padding:9px 16px;border:none;background:none;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.settings-tab:hover{color:var(--text2)}
.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.atype-NOTE_ADDED{background:#EEF2FF;color:#4338CA}
.atype-TASK_COMPLETED,.atype-TASK_UPDATED,.atype-TASK_DELETED,.atype-TASK_REOPENED{background:#ECFDF5;color:#047857}
.atype-PINNED_ADDED,.atype-PINNED_DELETED{background:#FEF3C7;color:#92400E}
.atype-USER_CREATED,.atype-USER_UPDATED,.atype-USER_DELETED,.atype-USER_PERMS_UPDATED,.atype-USER_ACTIVATED,.atype-USER_DEACTIVATED{background:#F5F3FF;color:#7c3aed}
.atype-ROLE_SWITCHED,.atype-LOGIN,.atype-SA_ACCESS_GRANTED{background:#F1F5F9;color:#475569}
.atype-DATA_EXPORTED,.atype-DATA_IMPORTED,.atype-DRAFT_DELETED{background:#F0F9FF;color:#0369A1}
.settings-body{padding:18px}
.settings-field{margin-bottom:14px}
.settings-field label{font-family:var(--font-head);font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:5px}
.settings-field input,.settings-field textarea{width:100%;padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13.5px;color:var(--text);outline:none;transition:all .2s}
.settings-field input:focus,.settings-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}

/* ══════════ SESSION E · PASS 1 ══════════ */
/* Item 1 — rail hamburger + side-panel collapse (desktop) */
.rail-btn.rail-ham{color:var(--slate-light)}
.rail-btn.rail-ham.is-collapsed{background:rgba(43,196,138,.18);color:var(--mint-hi)}
.sidebar{transition:width .26s cubic-bezier(.4,0,.2,1),opacity .2s}
@media(min-width:1024px){ .app-body.sp-collapsed .sidebar{width:0;min-width:0;opacity:0;border-right:none;pointer-events:none} }
@media(max-width:1023px){ .rail-btn.rail-ham{display:none} }
/* Item 2 — redesigned Command Center header */
.cc-topbar{align-items:flex-start}
.cc-identity{display:flex;flex-direction:column;gap:6px;min-width:0}
.cc-identity .cc-ctx-label{font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.6px}
.cc-identity .cc-ctx-name{font-family:var(--font-head);font-size:18px;font-weight:800;color:var(--navy);line-height:1.1;cursor:pointer}
.cc-identity .cc-ctx-name:hover{color:var(--accent)}
.cc-chips{display:flex;flex-wrap:wrap;gap:8px;margin-left:auto;align-items:flex-start;justify-content:flex-end;max-width:100%}
.cc-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5px 14px;min-width:60px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm)}
.cc-chip .cc-chip-num{font-family:var(--font-head);font-size:15px;font-weight:800;color:var(--navy);line-height:1.15}
.cc-chip .cc-chip-lbl{font-size:8.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;margin-top:1px}
.cc-chip.warn .cc-chip-num{color:var(--warning)}
.cc-chip.alert .cc-chip-num{color:var(--error)}
/* Item 3 — Settings vertical sub-nav */
.cfg-wrap{display:flex;gap:20px;align-items:flex-start}
.cfg-subnav{width:184px;flex-shrink:0;position:sticky;top:0;display:flex;flex-direction:column;gap:2px}
.cfg-subnav-lbl{font-family:var(--font-head);font-size:9px;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;padding:2px 10px 6px}
.cfg-nav-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:12.5px;font-weight:700;color:var(--text2);cursor:pointer;border:none;background:none;text-align:left;width:100%}
.cfg-nav-item:hover{background:var(--surface2)}
.cfg-nav-item.active{background:rgba(26,115,232,.1);color:var(--accent)}
.cfg-nav-item .cfg-ico{width:16px;text-align:center;flex-shrink:0}
.cfg-nav-item .cfg-sa{margin-left:auto;font-size:8px;background:var(--navy);color:#fff;padding:1px 5px;border-radius:8px;letter-spacing:.4px}
.cfg-groups{flex:1;min-width:0}
.cfg-group{display:none}
.cfg-group.active{display:block}
@media(max-width:1023px){ .cfg-wrap{flex-direction:column} .cfg-subnav{width:100%;flex-direction:row;flex-wrap:wrap;position:static} .cfg-subnav-lbl{display:none} .cfg-nav-item{width:auto} }
.clients-table{width:100%;border-collapse:collapse}
.clients-table th{padding:8px 14px;font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface2)}
.clients-table td{padding:10px 14px;font-size:12.5px;border-bottom:1px solid var(--border);vertical-align:middle}
.clients-table tr:last-child td{border-bottom:none}
.del-btn{padding:4px 10px;border-radius:5px;border:1px solid rgba(220,38,38,.2);background:rgba(220,38,38,.06);color:var(--error);font-family:var(--font-head);font-size:10px;font-weight:700;cursor:pointer;transition:all .2s}
.del-btn:hover{background:var(--error);color:#fff;border-color:var(--error)}
/* ── AUDIT LOG ── */
.audit-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.audit-search{flex:1;min-width:160px;padding:7px 11px;font-family:var(--font);font-size:12px;color:var(--text);background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .2s}
.audit-search:focus{border-color:var(--accent);background:#fff}
.audit-type-sel{padding:7px 10px;font-family:var(--font);font-size:12px;color:var(--text);background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);outline:none;cursor:pointer;appearance:none;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath fill='%235A7A9A' d='M0 0l5 7 5-7z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
.audit-export-btn{padding:7px 14px;font-family:var(--font-head);font-size:11.5px;font-weight:700;background:var(--navy);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background .2s;letter-spacing:.3px}
.audit-export-btn:hover{background:var(--accent)}
.audit-count{font-size:11px;color:var(--text3);white-space:nowrap}
.audit-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}
.audit-tbl{width:100%;border-collapse:collapse;font-size:11.5px}
.audit-tbl thead th{background:var(--navy);color:#fff;padding:8px 12px;font-size:9.5px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;text-align:left;white-space:nowrap}
.audit-tbl tbody tr.audit-main-row{border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}
.audit-tbl tbody tr.audit-main-row:hover{background:var(--surface2)}
.audit-tbl tbody td{padding:8px 12px;vertical-align:top}
.audit-ts{font-family:monospace;font-size:10.5px;color:var(--text2);white-space:nowrap}
.audit-type-pill{display:inline-block;padding:2px 8px;border-radius:4px;font-size:9.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap}
.audit-detail{font-size:10.5px;color:var(--text2);line-height:1.5;max-width:320px}
.audit-detail strong{color:var(--navy)}
.audit-expand{display:none;padding:8px 12px 10px;background:var(--surface2);border-top:1px solid var(--border)}
.audit-expand.open{display:block}
.audit-json{font-family:monospace;font-size:10px;color:var(--slate);background:var(--surface);padding:8px;border-radius:4px;border:1px solid var(--border);white-space:pre-wrap;word-break:break-all;max-height:160px;overflow-y:auto}
.audit-empty{padding:32px 20px;text-align:center;color:var(--text3);font-size:12px}
/* Audit type colors */
.atype-FORM_SUBMITTED{background:#DCFCE7;color:#15803D}
.atype-DRAFT_SAVED{background:#FEF9C3;color:#A16207}
.atype-FORM_DELETED{background:#FEE2E2;color:#DC2626}
.atype-LINK_GENERATED{background:#DBEAFE;color:#1D4ED8}
.atype-LINK_SENT{background:#E0F2FE;color:#0369A1}
.atype-ATTACHMENT_ADDED{background:#CCFBF1;color:#0F766E}
.atype-ATTACHMENT_DELETED{background:#FFE4E6;color:#BE123C}
.atype-CLIENT_CREATED{background:rgba(37,99,235,.1);color:var(--accent)}
.atype-FORM_VIEWED{background:#F1F5F9;color:#475569}
.atype-SETTINGS_UPDATED{background:#EDE9FE;color:#6D28D9}
.atype-EMAIL_SENT{background:#F0FDF4;color:#166534}
/* Active submission highlight */
.tree-form-item.active{background:rgba(37,99,235,.1);color:var(--navy);font-weight:700;border-left:3px solid var(--accent);padding-left:41px}
.fi-new-badge{background:var(--success);color:#fff;font-family:var(--font-head);font-size:8.5px;font-weight:800;padding:1px 5px;border-radius:3px;letter-spacing:.5px;text-transform:uppercase;flex-shrink:0;animation:newPulse 2s ease-in-out infinite}
@keyframes newPulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(22,163,74,.5)}50%{opacity:.85;box-shadow:0 0 0 4px rgba(22,163,74,0)}}
.client-forms-count.has-new{background:var(--success);color:#fff;border-color:var(--success);animation:newPulse 2s ease-in-out infinite}
.tree-client-head.active{background:rgba(37,99,235,.08);border-left:3px solid var(--gold) !important;box-shadow:inset 0 0 0 1px rgba(201,168,76,.2)}
.tree-client-head.active .client-name{color:var(--navy);font-weight:800}
.tree-client-head.active .client-avatar{background:linear-gradient(135deg,var(--gold),#E5C46B) !important}
/* Submission read-only banner */
.sub-read-banner{background:linear-gradient(90deg,rgba(10,34,64,.06),rgba(37,99,235,.04));border-bottom:1.5px solid var(--border);padding:10px 24px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.sub-read-banner .banner-ref{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--navy)}
.sub-read-banner .banner-meta{font-size:11.5px;color:var(--text3)}
.sub-read-badge{background:var(--success);color:#fff;font-family:var(--font-head);font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.5px;text-transform:uppercase}

/* ── EMPTY STATE ── */
.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:var(--text3)}
.fb-hidden{display:none!important}
.empty-state svg{width:48px;height:48px;margin-bottom:16px;opacity:.35}
.empty-state h3{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--text2);margin-bottom:6px}
.empty-state p{font-size:13px;line-height:1.6;max-width:320px}

/* ── SUCCESS MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(5,15,30,.6);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-box{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:480px;overflow:hidden;animation:popIn .35s cubic-bezier(.175,.885,.32,1.275)}
@keyframes popIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.modal-header{background:linear-gradient(135deg,var(--navy),var(--navy-light));padding:18px 22px;display:flex;align-items:center;gap:10px}
.modal-header h3{font-family:var(--font-head);font-size:14px;font-weight:700;color:#fff}
.modal-body{padding:22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--surface2)}
.modal-field{margin-bottom:14px}
.modal-field label{font-family:var(--font-head);font-size:10.5px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:5px}
.modal-field input{width:100%;padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13.5px;color:var(--text);outline:none;transition:all .2s}
.modal-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.success-icon-lg{width:64px;height:64px;background:linear-gradient(135deg,#15803D,var(--success-light));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px;box-shadow:0 8px 24px rgba(34,197,94,.3);animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}
.link-box{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-family:'Courier New',monospace;font-size:12px;color:var(--navy);word-break:break-all;margin-bottom:10px}
.link-meta{font-size:11.5px;color:var(--text3);margin-top:6px;display:flex;align-items:center;gap:5px}
.expiry-badge{background:rgba(217,119,6,.12);color:var(--warning);border:1px solid rgba(217,119,6,.25);border-radius:10px;padding:2px 8px;font-family:var(--font-head);font-size:10px;font-weight:700}

/* ── NEW FORM MODAL options ── */
.nf-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.nf-option{border:2px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s;text-align:center;background:#fff}
.nf-option:hover{border-color:var(--accent);background:rgba(37,99,235,.04)}
.nf-option.selected{border-color:var(--accent);background:rgba(37,99,235,.07)}
.nf-option-icon{font-size:26px;margin-bottom:8px}
.nf-option-title{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--navy);margin-bottom:4px}
.nf-option-desc{font-size:11px;color:var(--text3);line-height:1.5}

/* ── EXTERNAL/TOKEN MODE ── */
.ext-shell{min-height:100vh;background:var(--surface2);display:flex;flex-direction:column}
.ext-header{background:linear-gradient(90deg,#071A30 0%,#0A2240 60%);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 0 rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.3)}
.ext-footer{background:var(--navy);padding:10px 24px;text-align:center;font-family:var(--font-head);font-size:10px;font-weight:500;color:var(--slate-light);letter-spacing:.5px}
.ext-content{max-width:780px;margin:0 auto;padding:24px 20px 60px;width:100%}

/* ── PRINT ── */
/* ══════════════════════════════════════════
   RESPONSIVE — TABLET (768-1023px)
   ══════════════════════════════════════════ */
@media(max-width:1023px){
  :root{ --sidebar-w:260px; }
  .hamburger-btn{display:flex}
  .sidebar{
    position:fixed;left:0;top:56px;bottom:0;z-index:200;
    transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:4px 0 24px rgba(0,0,0,.18);
  }
  .sidebar.mobile-open{transform:translateX(0)}
  #mobileSidebarOverlay{
    display:none;position:fixed;inset:0;top:56px;
    background:rgba(5,15,30,.45);backdrop-filter:blur(2px);z-index:199;
  }
  #mobileSidebarOverlay.visible{display:block}
  .form-inner{padding:20px 16px 80px}
  .form-topbar{padding:12px 16px 10px}
  .submit-row{padding:14px 16px;gap:8px}
  .cpb-bar{padding:8px 12px}
  .modal-box{max-width:94vw}
  .settings-body{padding:14px}
  .audit-table-wrap{overflow-x:auto}
}

/* ══════════════════════════════════════════
   RESPONSIVE — PHONE (< 768px)
   ══════════════════════════════════════════ */
@media(max-width:767px){
  :root{ --rail-w:0px; --sidebar-w:88vw; }

  /* Header */
  .app-header{padding:0 12px 0 0;height:52px}
  .header-logo img{height:30px;width:auto;mix-blend-mode:screen}
  .lic-text{display:none}
  .header-right{gap:8px}
  .role-toggle{padding:5px 10px;font-size:11px}
  .hamburger-btn{display:flex}

  /* Hide rail — replaced by bottom tab bar */
  .rail{display:none}

  /* Bottom tab bar */
  .bottom-tab-bar{
    display:flex;position:fixed;bottom:0;left:0;right:0;
    background:var(--navy);border-top:1px solid rgba(255,255,255,.1);
    height:56px;z-index:100;
    box-shadow:0 -4px 20px rgba(0,0,0,.3);
  }
  .bottom-tab{
    flex:1;display:flex;flex-direction:column;align-items:center;
    justify-content:center;gap:3px;border:none;background:none;
    cursor:pointer;color:var(--slate-light);font-family:var(--font-head);
    font-size:9.5px;font-weight:700;letter-spacing:.3px;
    transition:color .2s;padding:6px 0;
  }
  .bottom-tab svg{width:18px;height:18px}
  .bottom-tab.active{color:#fff}
  .bottom-tab.active svg{filter:drop-shadow(0 0 6px rgba(59,130,246,.8))}

  /* App body — account for bottom tabs */
  .app-body{height:calc(100vh - 52px - 56px)}

  /* Sidebar drawer */
  .sidebar{
    position:fixed;left:0;top:52px;bottom:56px;z-index:200;
    transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:4px 0 24px rgba(0,0,0,.2);width:88vw;max-width:320px;
  }
  .sidebar.mobile-open{transform:translateX(0)}
  #mobileSidebarOverlay{
    display:none;position:fixed;inset:0;top:52px;bottom:56px;
    background:rgba(5,15,30,.5);backdrop-filter:blur(2px);z-index:199;
  }
  #mobileSidebarOverlay.visible{display:block}

  /* Main panel */
  .main-panel{width:100%}

  /* Form */
  .form-inner{padding:16px 12px 80px}
  .form-topbar{padding:10px 14px 8px;flex-wrap:wrap}
  .form-topbar-title{font-size:14px}
  #formTopActions{width:100%;margin-top:6px}
  #formTopActions .btn{font-size:11px;padding:7px 12px}

  /* Client Picker Bar */
  .cpb-bar{padding:8px 12px;flex-wrap:wrap;gap:6px}
  .cpb-label{font-size:10px}
  .cpb-search-wrap{max-width:none;width:100%}

  /* Submit row */
  .submit-row{padding:12px 14px;gap:6px;flex-wrap:wrap;justify-content:stretch}
  .submit-row .btn{flex:1;min-width:0;font-size:11.5px;padding:10px 8px;text-align:center}

  /* Sub read banner */
  .sub-read-banner{padding:10px 14px;flex-wrap:wrap;gap:8px}
  .sub-read-banner > div:last-child{width:100%}

  /* Modals — full screen sheet */
  .modal-overlay{padding:0;align-items:flex-end}
  .modal-box{
    max-width:100%;width:100%;border-radius:16px 16px 0 0;
    max-height:90vh;overflow-y:auto;
    animation:slideUp .3s cubic-bezier(.4,0,.2,1);
  }
  @keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

  /* Signature canvas */
  .sig-canvas{height:110px}

  /* Audit log — scroll */
  .audit-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .audit-toolbar{flex-wrap:wrap}
  .audit-search{min-width:0;width:100%}

  /* Settings */
  .settings-body{padding:12px}
  .settings-field input,.settings-field select{font-size:14px}

  /* PDF preview */
  #previewModal{padding:0}
  #previewModal > div{border-radius:0;min-height:100vh}
  #pdfPage{font-size:10.5px}
  .pdf-header{padding:16px 16px 12px}
  .pdf-section-title{font-size:10px}

  /* Overview cards */
  .kpi-grid{grid-template-columns:1fr 1fr}

  /* Form grids */
  .g2,.g3,.g4{grid-template-columns:1fr}
  .field label{font-size:10.5px}
  .field input,.field select,.field textarea{font-size:14px;padding:8px 10px}

  /* New form footer buttons */
  .sidebar-footer{gap:4px}
  .new-form-btn{font-size:11px;padding:9px 10px}
}

/* ══════════════════════════════════════════
   HAMBURGER BUTTON (hidden on desktop)
   ══════════════════════════════════════════ */
.hamburger-btn{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:40px;height:52px;background:none;border:none;cursor:pointer;
  padding:0 10px;flex-shrink:0;
}
.hamburger-btn span{
  display:block;width:20px;height:2px;background:rgba(255,255,255,.8);
  border-radius:2px;transition:all .25s;transform-origin:center;
}
.hamburger-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ══════════════════════════════════════════
   BOTTOM TAB BAR (hidden on desktop/tablet)
   ══════════════════════════════════════════ */
.bottom-tab-bar{display:none}

@media print{body>*:not(#previewModal){display:none!important}#previewModal{position:static!important;background:#fff!important;backdrop-filter:none!important;padding:0!important}#previewModal>div>div:first-child,#previewModal>div>div:last-child{display:none!important}#pdfPage{box-shadow:none!important}}

/* ══════════════════════════════════════════════
   COMMAND CENTER (S1)
══════════════════════════════════════════════ */
.cc-view-wrap{display:flex;flex-direction:column;height:100%;overflow:hidden}
.cc-topbar{padding:11px 20px;background:var(--surface);border-bottom:2px solid var(--mint);display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:wrap}
.cc-ctx-label{font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.cc-ctx-name{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--navy)}
.cc-toggle{display:flex;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.cc-toggle-btn{padding:4px 12px;font-family:var(--font-head);font-size:10.5px;font-weight:700;color:var(--slate);cursor:pointer;background:var(--surface2);border:none;transition:all .2s}
.cc-toggle-btn.active{background:var(--accent);color:#fff;border-radius:3px}
.cc-cols{display:flex;flex:1;overflow:hidden;min-height:0}
.cc-col{overflow-y:auto;padding:12px;height:100%}
.cc-col::-webkit-scrollbar{width:3px}
.cc-col::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.cc-col1{width:272px;flex-shrink:0;border-right:1px solid var(--border);background:#fff;overflow-y:auto;overflow-x:hidden}
/* ── SECTION DIVIDERS ── */
.cc-col1-divider{height:2px;background:linear-gradient(90deg,var(--accent) 0%,var(--mint) 55%,rgba(43,196,138,0) 100%);flex-shrink:0}
.cc-col2-divider{height:2px;background:linear-gradient(90deg,var(--accent) 0%,var(--mint) 55%,rgba(43,196,138,0) 100%);margin:2px -10px 10px;flex-shrink:0}
/* ── AOR SECTION ── */
.aor-card{border:2px solid var(--accent);border-radius:var(--radius);overflow:hidden;margin-top:14px;background:rgba(26,115,232,.03)}
.aor-card-hdr{background:linear-gradient(90deg,var(--navy) 0%,var(--navy-mid) 100%);color:#fff;padding:9px 14px;font-family:var(--font-head);font-size:10.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;display:flex;align-items:center;gap:7px}
.aor-card-body{padding:16px;display:flex;flex-direction:column;gap:14px}
.aor-logo-zone{border:2px dashed var(--border2);border-radius:var(--radius-sm);padding:16px;text-align:center;cursor:pointer;transition:all .2s;background:#fff}
.aor-logo-zone:hover{border-color:var(--accent);background:rgba(26,115,232,.04)}
.aor-logo-label{font-family:var(--font-head);font-size:10.5px;font-weight:700;color:var(--text2);letter-spacing:.3px}
.aor-logo-sub{font-size:11px;color:var(--text3);margin-top:3px}
.aor-cov-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);margin-bottom:5px}
.aor-auto-badge{background:rgba(22,163,74,.1);color:#16a34a;border:1px solid rgba(22,163,74,.25);padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700;font-family:var(--font-head);letter-spacing:.3px;vertical-align:middle;margin-left:6px}
.aor-pg-break{margin-top:40px;padding-top:0}
.aor-pg-hdr{background:linear-gradient(90deg,#0A2240,#1B4F8A);border-radius:5px 5px 0 0;padding:10px 16px;display:flex;align-items:center;justify-content:space-between}
.aor-pg-hdr-title{font-family:Montserrat,sans-serif;font-size:11px;font-weight:800;color:#fff;letter-spacing:.5px;text-transform:uppercase}
.aor-pg-hdr-sub{font-family:Montserrat,sans-serif;font-size:9.5px;color:rgba(255,255,255,.6)}
.cc-col2{flex:1;min-width:0;background:var(--surface2)}
.cc-col3{width:215px;flex-shrink:0;border-left:1px solid var(--border);background:var(--surface2);display:flex;flex-direction:column;overflow:hidden}
/* ── COL3 SECTION CARDS ── */
.cc-col3-section{display:flex;flex-direction:column;flex:1;min-height:120px;margin:6px 8px 0;border-radius:var(--radius);border:2px solid var(--border2);overflow:hidden;box-shadow:0 1px 4px rgba(10,34,64,.07)}
.cc-col3-section:last-child{margin-bottom:6px}
.cc-col3-sec-hdr{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--navy);color:#fff;font-family:var(--font-head);font-size:9.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;flex-shrink:0}
.cc-col3-sec-body{flex:1;overflow-y:auto;padding:7px 9px;background:#fff;min-height:0}
.cc-col3-sec-body::-webkit-scrollbar{width:3px}
.cc-col3-sec-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.cc-col3-sec-footer{display:flex;gap:5px;padding:5px 8px;border-top:1.5px solid var(--border2);background:var(--surface2);flex-shrink:0}
.cc-col3-sec-btn{flex:1;padding:4px 0;font-family:var(--font-head);font-size:9.5px;font-weight:700;border-radius:5px;border:1.5px solid var(--border2);background:var(--surface);cursor:pointer;color:var(--text2);transition:all .15s;letter-spacing:.2px}
.cc-col3-sec-btn:hover{background:var(--navy-mid);color:#fff;border-color:var(--navy-mid)}
.cc-col3-sec-btn.c3-add{background:var(--accent);color:#fff;border-color:var(--accent)}
.cc-col3-sec-btn.c3-add:hover{background:var(--navy);border-color:var(--navy)}
/* ── COL3 VIEW-ALL MODE ── */
.cc-col3-back-bar{display:flex;align-items:center;gap:8px;padding:8px 11px;background:rgba(13,27,46,.07);border-bottom:2px solid var(--border2);flex-shrink:0}
.cc-col3-back-btn{padding:3px 10px;border-radius:var(--radius-sm);border:1.5px solid var(--border2);background:#fff;cursor:pointer;font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--accent);transition:all .15s}
.cc-col3-back-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.cc-col3-va-title{font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--navy)}
/* ── TASK TRUNCATION ── */
.cc-task-trunc{overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;cursor:pointer}
.cc-task-trunc.expanded{display:block;-webkit-line-clamp:unset}
.cc-see-more-lnk{font-family:var(--font-head);font-size:9.5px;font-weight:700;color:var(--accent);cursor:pointer;margin-left:3px;white-space:nowrap}
/* ── PINNED NOTE ITEMS ── */
.cc-pin-item{background:#FFFCEB;border:1px solid #FDE68A;border-radius:6px;padding:7px 24px 7px 8px;margin-bottom:5px;position:relative}
.cc-pin-text{font-size:11.5px;color:#78350F;line-height:1.4;word-break:break-word}
.cc-pin-del{position:absolute;top:4px;right:5px;background:none;border:none;cursor:pointer;color:#B45309;font-size:11px;padding:0;opacity:.6;transition:opacity .15s}
.cc-pin-del:hover{opacity:1}
.cc-col3>*{flex-shrink:0}
.cc-contact-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:10px}
.cc-card-hero{background:linear-gradient(135deg,var(--navy),var(--navy-mid));padding:14px 12px 12px;text-align:center}
.cc-card-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--mint));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:15px;color:#fff;margin:0 auto 7px;border:2.5px solid rgba(255,255,255,.25)}
.cc-card-name{font-family:var(--font-head);font-size:12.5px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.3px;line-height:1.2;margin-bottom:2px}
.cc-card-role{font-size:11px;color:var(--slate-light);margin-bottom:6px}
.cc-card-status{display:inline-flex;align-items:center;gap:4px;background:rgba(43,196,138,.15);border:1px solid rgba(43,196,138,.35);border-radius:20px;padding:3px 10px;font-family:var(--font-head);font-size:10px;font-weight:600;color:#2BC48A}
.cc-status-dot{width:6px;height:6px;border-radius:50%;background:#2BC48A;flex-shrink:0}
.cc-card-fields{padding:0 0 4px}
.cc-field-row{display:flex;align-items:center;gap:7px;padding:6px 11px;border-bottom:1px solid var(--surface3)}
.cc-field-row:last-child{border-bottom:none}
.cc-field-icon{width:15px;display:flex;align-items:center;justify-content:center;color:var(--slate);flex-shrink:0}
.cc-field-icon svg{width:13px;height:13px}
.cc-field-value{flex:1;font-size:11.5px;color:var(--text);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-copy-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--border2);cursor:pointer;border-radius:4px;flex-shrink:0;transition:all .15s;border:none;background:none;font-size:12px;font-weight:700}
.cc-copy-btn:hover{color:var(--accent);background:rgba(37,99,235,.08)}
.cc-date-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}
.cc-date-pill{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 7px;text-align:center}
.cc-date-pill .dp-lbl{font-family:var(--font-head);font-size:8px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.cc-date-pill .dp-emoji{font-size:14px;margin:2px 0;display:block;line-height:1.2}
.cc-date-pill .dp-val{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--navy);line-height:1.3}
.cc-date-pill.warn .dp-val{color:var(--warning)}
.cc-date-pill.alert .dp-val{color:var(--error)}
.cc-sec-label{font-family:var(--font-head);font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.9px;margin-bottom:7px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.cc-tree-node{display:flex;align-items:center;gap:7px;padding:4px 0}
.cc-tree-node.l2{padding-left:13px}
.cc-tree-node.l3{padding-left:24px}
.cc-tree-status{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.cc-tree-status.g{background:var(--success)}
.cc-tree-status.y{background:var(--warning)}
.cc-tree-status.r{background:var(--error)}
.cc-tree-name{font-family:var(--font-head);font-size:11px;font-weight:600;color:var(--navy);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-tree-role{font-size:10px;color:var(--text3);white-space:nowrap}
.cc-log-widget{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:9px;flex-shrink:0;transition:border-color .2s,box-shadow .2s}
.cc-log-widget.has-content{border-color:var(--accent);box-shadow:0 0 0 2px rgba(26,115,232,.1)}
.cc-unsaved-pill{display:none;align-items:center;font-family:var(--font-head);font-size:9.5px;font-weight:700;color:var(--warning);background:rgba(217,119,6,.09);border:1px solid rgba(217,119,6,.28);border-radius:10px;padding:2px 8px;margin-left:4px;flex-shrink:0}
.cc-resize-handle{width:4px;flex-shrink:0;background:var(--border);cursor:col-resize;transition:background .15s;position:relative;z-index:2}
.cc-resize-handle:hover,.cc-resize-handle.dragging{background:var(--accent)}
.cc-log-input{width:100%;padding:9px 12px;border:none;outline:none;font-family:var(--font);font-size:12.5px;color:var(--text);resize:none;min-height:52px;background:#fff}
.cc-log-input[contenteditable]{min-height:52px;max-height:140px;overflow-y:auto;line-height:1.55;word-break:break-word;resize:none}
.cc-log-input[contenteditable]:empty:before{content:attr(data-placeholder);color:var(--text3);pointer-events:none}
.cc-note-html-body{font-size:12.5px;color:var(--text2);line-height:1.55;max-height:80px;overflow:hidden;transition:max-height .35s ease}
.cc-note-html-body.cc-note-exp{max-height:600px}
.cc-note-html-body table{border-collapse:collapse;width:100%;font-size:11px;margin:4px 0}
.cc-note-html-body td,.cc-note-html-body th{padding:3px 6px;border:1px solid var(--border)}
.cc-note-html-body a{color:var(--accent);text-decoration:underline}
.cc-note-html-body ul,.cc-note-html-body ol{margin:4px 0;padding-left:18px}
.cc-note-html-body blockquote{border-left:3px solid var(--border2);margin:4px 0 4px 4px;padding:4px 8px;color:var(--text3);background:var(--surface2)}
.cc-note-html-body p{margin:3px 0}
.cc-note-html-body b,.cc-note-html-body strong{font-weight:700;color:var(--text)}
.cc-log-actions{padding:6px 9px;border-top:1px solid var(--border);display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.cc-log-tag{padding:3px 10px;border-radius:20px;font-family:var(--font-head);font-size:10px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all .15s}
.cc-log-tag.urg{background:#FEE2E2;color:#DC2626;border-color:#FECACA}
.cc-log-tag.gen{background:#F0FDF4;color:#166534;border-color:#BBF7D0}
.cc-log-tag.int{background:var(--surface2);color:var(--slate);border-color:var(--border)}
.cc-log-tag.pol{background:#FEF3C7;color:#92400E;border-color:#FDE68A}
.cc-log-tag.cli{background:#DBEAFE;color:#1D4ED8;border-color:#BFDBFE}
.cc-log-tag.cc-tag-active{font-weight:800;box-shadow:0 0 0 2px currentColor}
.cc-log-tag.int.cc-tag-active{background:rgba(26,115,232,.1);border-color:rgba(26,115,232,.55);color:var(--accent)}
.cc-log-save{margin-left:auto;padding:5px 14px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:11px;font-weight:700;cursor:pointer;transition:all .2s}
.cc-log-save:hover{background:var(--navy)}
.cc-timeline-filter{display:flex;gap:4px;margin-bottom:9px;flex-wrap:wrap;flex-shrink:0}
.cc-tf-btn{padding:3px 9px;border-radius:20px;font-family:var(--font-head);font-size:10px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);color:var(--text3);background:#fff;transition:all .15s}
.cc-tf-btn.active{background:rgba(37,99,235,.1);border-color:var(--accent);color:var(--accent)}
.cc-tl-entry{display:flex;gap:9px;margin-bottom:9px}
.cc-tl-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border);background:#fff}
.cc-tl-icon svg{width:13px;height:13px}
.cc-tl-icon.email{color:#1A73E8;background:#E6F1FB;border-color:#C3DEFF}
.cc-tl-icon.phone{color:#0F6E56;background:#E1F5EE;border-color:#B8E8D8}
.cc-tl-icon.note{color:#854F0B;background:#FAEEDA;border-color:#FBCC87}
.cc-tl-icon.doc{color:#6930B0;background:#F0ECFC;border-color:#D4C5F9}
.cc-tl-icon.system{color:var(--slate);background:var(--surface2)}
.cc-tl-body{flex:1;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:7px 11px;min-width:0}
.cc-tl-title{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--navy)}
.cc-tl-desc{font-size:11.5px;color:var(--text2);margin-top:2px;line-height:1.4}
.cc-tl-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.cc-tl-time{font-size:10px;color:var(--text3)}
.cc-tl-acts{display:flex;gap:8px}
.cc-tl-act{font-size:10px;color:var(--text3);cursor:pointer;transition:color .15s}
.cc-tl-act:hover{color:var(--accent)}
.cc-sticky{background:#FFFCEB;border:1px solid #FDE68A;border-radius:var(--radius-sm) var(--radius-sm) 0 var(--radius-sm);padding:11px 11px 22px;position:relative;margin:12px 10px 8px}
.cc-sticky::after{content:'';position:absolute;bottom:0;right:0;width:0;height:0;border-style:solid;border-width:0 0 18px 18px;border-color:transparent transparent var(--surface2) transparent}
.cc-sticky-hdr{display:flex;align-items:center;gap:5px;font-family:var(--font-head);font-size:10px;font-weight:700;color:#92400E;margin-bottom:5px}
.cc-sticky-input{width:100%;border:none;outline:none;background:transparent;font-family:var(--font);font-size:12px;color:#78350F;resize:none;min-height:52px;line-height:1.5}
.cc-util-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin:0 10px 10px}
.cc-util-hdr{padding:6px 11px;border-bottom:1px solid var(--border);background:var(--surface2);display:flex;align-items:center;gap:5px}
.cc-util-hdr-title{font-family:var(--font-head);font-size:9.5px;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.7px}
.cc-util-body{padding:9px 11px}
.cc-udoc{background:#FEF2F2;border:1px solid #FECACA;border-radius:var(--radius-sm);padding:7px 9px;margin-bottom:6px}
.cc-udoc:last-child{margin-bottom:0}
.cc-udoc-name{font-family:var(--font-head);font-size:11px;font-weight:700;color:#991B1B;display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.cc-udoc-miss{font-size:9px;font-weight:700;color:#DC2626;background:#FEE2E2;padding:1px 6px;border-radius:3px}
.cc-udoc-btns{display:flex;gap:5px}
.cc-udoc-btn{flex:1;padding:4px;text-align:center;border-radius:4px;font-family:var(--font-head);font-size:9.5px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);color:var(--slate);background:#fff;transition:all .2s}
.cc-udoc-btn:hover{border-color:var(--accent);color:var(--accent)}
.cc-nudge-btn{color:#7C3AED;border-color:#DDD6FE;background:#F5F3FF}
.cc-nudge-btn:hover{border-color:#7C3AED}
.cc-tasks-wrap{flex:1;margin:0 10px 10px;display:flex;flex-direction:column;min-height:180px}
.cc-task-add-row{display:flex;gap:5px;margin-bottom:8px;flex-shrink:0}
.cc-task-add-input{flex:1;padding:5px 8px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:11.5px;color:var(--text);background:var(--surface2);outline:none;transition:all .2s;min-width:0}
.cc-task-add-input:focus{border-color:var(--accent);background:#fff}
.cc-task-add-btn{padding:5px 9px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:10.5px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0}
.cc-task-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}
.cc-task-item:last-child{border-bottom:none}
.cc-task-cb{width:15px;height:15px;border-radius:4px;border:1.5px solid var(--border2);flex-shrink:0;margin-top:1px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}
.cc-task-cb.done{background:var(--accent);border-color:var(--accent)}
.cc-task-text{font-size:12px;color:var(--text);flex:1;line-height:1.35}
.cc-task-text.done{text-decoration:line-through;color:var(--text3)}
.cc-task-due{font-family:var(--font-head);font-size:10px;font-weight:600;color:var(--error);margin-top:1px}
.cc-task-due.ok{color:var(--text3)}
.cc-task-due.done-lbl{color:var(--success)}
.cc-client-link{cursor:pointer!important;transition:color .15s}
.cc-client-link:hover{color:var(--accent)!important;text-decoration:underline}
.cc-back-bar{padding:7px 12px;background:rgba(37,99,235,.06);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px;font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--accent);cursor:pointer;flex-shrink:0}
.cc-back-bar:hover{background:rgba(37,99,235,.12)}
.cc-back-bar svg{width:13px;height:13px;flex-shrink:0}
.rail-user-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--accent));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:10px;color:#fff;cursor:pointer;margin-top:auto;margin-bottom:6px;border:2px solid rgba(255,255,255,.15);transition:all .2s;flex-shrink:0}
.rail-user-av:hover{border-color:rgba(255,255,255,.45)}

/* ── CLIENT DETAILS FORM ── */
.cc-extra-form{display:flex;flex-direction:column;gap:0}
.cc-extra-lbl{font-family:var(--font-head);font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:3px}
.cc-extra-inp{width:100%;padding:5px 8px;border:1.5px solid var(--border);border-radius:5px;font-family:var(--font);font-size:12px;color:var(--text);background:#fff;outline:none;box-sizing:border-box;transition:border-color .15s}
.cc-extra-inp:focus{border-color:var(--accent)}
.cc-extra-save{font-family:var(--font-head);font-size:10px;font-weight:700;padding:7px 14px;border:none;border-radius:5px;background:var(--accent);color:#fff;cursor:pointer;margin-top:4px;width:100%;letter-spacing:.3px}
.cc-extra-save:hover{opacity:.9}

/* ── COLLAPSIBLE SECTION TOGGLE ── */
.cc-sec-toggle{cursor:pointer;user-select:none;display:flex;align-items:center;justify-content:space-between}
.cc-sec-toggle:hover{color:var(--accent)}
.cc-sec-caret{font-size:13px;font-weight:700;opacity:.5;line-height:1;margin-left:4px}

/* ── KEY FIELDS ── */
.cc-key-fields{padding:8px 10px;border-top:1px solid var(--border)}
.cc-kf-label{font-family:var(--font-head);font-size:8px;font-weight:700;color:var(--text3);letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px}
.cc-kf-row{display:flex;justify-content:space-between;align-items:center;padding:2px 0;font-size:10px}
.cc-kf-key{color:var(--text3)}
.cc-kf-val{color:var(--navy);font-weight:600}
.cc-kf-val.kf-blue{color:var(--accent);font-weight:700}

/* ── LINKED CLIENTS ── */
.cc-linked-list{display:flex;flex-direction:column;gap:3px;margin:4px 0 5px}
.cc-linked-empty{font-size:11px;color:var(--text3);padding:4px 0;font-style:italic}
.cc-unlink-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text3);font-size:10px;padding:2px 5px;border-radius:3px;flex-shrink:0}
.cc-unlink-btn:hover{color:var(--error);background:rgba(220,38,38,.06)}
.cc-link-actions{display:flex;gap:6px;margin-top:4px;padding-bottom:4px}
.cc-link-btn{font-family:var(--font-head);font-size:10px;font-weight:700;padding:4px 10px;border:1.5px dashed var(--border2);background:none;border-radius:4px;color:var(--slate);cursor:pointer;transition:all .15s}
.cc-link-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── TYPE BADGE ── */
.cc-type-badge{display:inline-block;font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.4px;vertical-align:middle;margin-left:5px}
.cc-type-badge.business{background:#EFF6FF;color:#1A73E8}
.cc-type-badge.individual{background:#EDFBF4;color:#1B7A52}

/* ── LINK PICKER ── */
.link-picker-item{display:flex;align-items:center;gap:10px;padding:8px 10px;cursor:pointer;transition:background .15s}
.link-picker-item:hover{background:var(--surface2)}
.link-picker-item:not(:last-child){border-bottom:1px solid var(--border)}

/* ── NOTE ATTACH ── */
.cc-attach-row{display:flex;gap:5px;padding:4px 8px 6px;background:var(--surface2);border-top:1px solid var(--border);flex-wrap:wrap;align-items:center}
.cc-attach-btn{font-family:var(--font-head);font-size:10px;font-weight:700;padding:3px 8px;border:1.5px solid var(--border);background:#fff;border-radius:4px;cursor:pointer;color:var(--slate);transition:all .15s}
.cc-attach-btn:hover,.cc-attach-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(26,115,232,.06)}
.cc-attach-preview{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--text2);background:#fff;border:1px solid var(--border);border-radius:4px;padding:3px 7px}
.cc-tl-img{width:80px;height:60px;object-fit:cover;border-radius:5px;margin-top:4px;margin-right:4px;border:1px solid var(--border);cursor:pointer;display:inline-block;vertical-align:top;transition:opacity .15s}
.cc-tl-img:hover{opacity:.82}
.cc-tl-img-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.confirm-modal-overlay{position:fixed;inset:0;background:rgba(5,15,30,.65);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}
.confirm-modal-box{background:#fff;border-radius:var(--radius);width:min(440px,92vw);box-shadow:0 16px 48px rgba(0,0,0,.28);overflow:hidden}
.confirm-modal-hd{background:linear-gradient(135deg,var(--navy),var(--navy-mid));padding:16px 20px;display:flex;align-items:center;gap:10px}
.confirm-modal-title{font-family:var(--font-head);font-size:13.5px;font-weight:800;color:#fff;flex:1}
.confirm-modal-body{padding:18px 20px;font-size:13px;color:var(--text2);line-height:1.6}
.confirm-modal-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--surface2)}
.sb-drafts-section{margin:8px 10px 0;border-top:1px solid var(--border)}
.sb-drafts-head{display:flex;align-items:center;padding:8px 4px 6px;cursor:pointer;user-select:none}
.sb-drafts-label{font-family:var(--font-head);font-size:10.5px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;flex:1}
.sb-drafts-count{background:rgba(217,119,6,.18);color:var(--warning);font-family:var(--font-head);font-size:9.5px;font-weight:700;padding:1px 6px;border-radius:8px;margin-right:4px}
.sb-draft-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:6px;cursor:pointer;transition:background .15s;margin-bottom:2px}
.sb-draft-item:hover{background:rgba(37,99,235,.06)}
.sb-draft-icon{font-size:14px;flex-shrink:0}
.sb-draft-meta{flex:1;min-width:0}
.sb-draft-name{font-family:var(--font-head);font-size:11.5px;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-draft-sub{font-size:10.5px;color:var(--text3);margin-top:1px}
.sb-draft-del{font-size:13px;color:var(--text3);cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s;flex-shrink:0}
.sb-draft-del:hover{color:var(--error)}
.draft-pending-badge{display:inline-flex;align-items:center;background:rgba(217,119,6,.15);color:var(--warning);border:1px solid rgba(217,119,6,.3);border-radius:8px;font-family:var(--font-head);font-size:9px;font-weight:700;padding:1px 6px;margin-left:4px;vertical-align:middle;cursor:pointer}
.cc-tl-alert{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;border-radius:8px;margin-bottom:6px;border:1px solid transparent}
.cc-tl-alert.alert-red{background:rgba(220,38,38,.06);border-color:rgba(220,38,38,.18)}
.cc-tl-alert.alert-yellow{background:rgba(217,119,6,.06);border-color:rgba(217,119,6,.18)}
.cc-tl-alert.alert-blue{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.15)}
.cc-tl-alert.alert-green{background:rgba(22,163,74,.06);border-color:rgba(22,163,74,.15)}
.cc-tl-alert-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.cc-tl-alert-body{flex:1;min-width:0}
.cc-tl-alert-title{font-family:var(--font-head);font-size:11.5px;font-weight:700;color:var(--navy)}
.cc-tl-alert-sub{font-size:11px;color:var(--text3);margin-top:2px}
.cc-file-chip{display:inline-flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:11px;color:var(--text2);margin:2px}
.cc-file-chip-x{cursor:pointer;color:var(--text3);font-size:13px;line-height:1}
.cc-file-chip-x:hover{color:var(--error)}
.cc-tl-file-link{display:inline-flex;align-items:center;gap:4px;margin-top:5px;padding:4px 9px;background:var(--surface2);border:1px solid var(--border);border-radius:5px;font-size:11px;color:var(--accent);text-decoration:none}

/* ── RENEWAL PIP ── */
.renewal-pip{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-left:4px;vertical-align:middle}
.renewal-pip.red{background:#DC2626}.renewal-pip.amber{background:#F59E0B}.renewal-pip.green{background:#2BC48A}

/* ── SIDEBAR SORT TOOLBAR ── */
.sb-sort-row{display:flex;gap:4px;padding:4px 8px 5px;border-top:1px solid var(--border)}
.sb-sort-sel{flex:1;font-family:var(--font-head);font-size:10.5px;font-weight:600;color:var(--text2);background:var(--surface2);border:1.5px solid var(--border);border-radius:5px;padding:3px 5px;cursor:pointer;outline:none;min-width:0}
.sb-group-hdr{padding:4px 10px 2px;font-family:var(--font-head);font-size:9.5px;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;background:var(--surface2);border-bottom:1px solid var(--border)}

/* ── PENDING DOCS ── */
.cc-udoc-status{font-size:9.5px;font-weight:700;padding:2px 6px;border-radius:3px;margin-left:5px;flex-shrink:0}
.cc-udoc-status.miss{background:#FEE2E2;color:#DC2626}
.cc-udoc-status.done{background:#DCFCE7;color:#16A34A}

/* ── REPORTING ── */
.rep-view{padding:20px 22px;overflow-y:auto;height:100%;box-sizing:border-box}
.rep-title{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--navy);margin-bottom:14px}
.rep-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:20px}
.rep-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;display:flex;flex-direction:column;gap:3px}
.rep-card-val{font-family:var(--font-head);font-size:26px;font-weight:800;color:var(--navy)}
.rep-card-lbl{font-size:10.5px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.rep-section{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden}
.rep-sec-hdr{padding:9px 14px;border-bottom:1px solid var(--border);font-family:var(--font-head);font-size:11.5px;font-weight:800;color:var(--navy)}
.rep-table{width:100%;border-collapse:collapse;font-size:12px}
.rep-table th{padding:7px 12px;background:var(--surface2);color:var(--text3);font-family:var(--font-head);font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;text-align:left;border-bottom:1px solid var(--border)}
.rep-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.rep-table tr:last-child td{border-bottom:none}
.rep-table tr:hover td{background:var(--surface2)}
.rep-sec-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:linear-gradient(90deg,var(--navy),var(--navy-mid));color:#fff}
.rep-sec-title{font-family:var(--font-head);font-size:11.5px;font-weight:700;color:#fff;letter-spacing:.3px}
.rep-export-btns{display:flex;gap:5px;flex-shrink:0}
.rep-exp-btn{padding:3px 9px;font-family:var(--font-head);font-size:9.5px;font-weight:700;border-radius:4px;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.1);color:#fff;cursor:pointer;letter-spacing:.2px;transition:background .15s}
.rep-exp-btn:hover{background:rgba(255,255,255,.25)}
.rep-exp-btn.pdf{border-color:rgba(255,200,100,.5);color:#FFD580}
.rep-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.rep-title{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--navy)}
.rep-badge{font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:3px;white-space:nowrap}
.rep-badge.red{background:#FEE2E2;color:#DC2626}
.rep-badge.amber{background:#FEF3C7;color:#D97706}
.rep-badge.green{background:#DCFCE7;color:#16A34A}
.rep-empty{padding:18px;text-align:center;font-size:12px;color:var(--text3)}

/* ── SPRINT 1: LOGIN OVERLAY ── */
.login-overlay{position:fixed;inset:0;background:#0A1828;z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column}
.login-card{background:#0F2236;border:1px solid rgba(26,115,232,.25);border-radius:16px;padding:40px 36px;width:360px;max-width:92vw;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.5)}
.login-logo-wrap{margin:0 auto 8px;display:flex;align-items:center;justify-content:center}
.login-logo-wrap span{display:none}
.login-title{font-family:var(--font-head);font-size:19px;font-weight:700;color:#fff;margin-bottom:4px}
.login-sub{font-size:12px;color:var(--slate-light);margin-bottom:28px;line-height:1.5}
.login-pin-row{display:flex;gap:12px;justify-content:center;margin-bottom:24px}
.login-pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.25);transition:all .2s;background:transparent}
.login-pin-dot.filled{background:#1A73E8;border-color:#1A73E8;box-shadow:0 0 8px rgba(26,115,232,.5)}
.login-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.kp-btn{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-family:var(--font-head);font-size:18px;font-weight:600;padding:14px 0;cursor:pointer;transition:all .15s;line-height:1}
.kp-btn:hover{background:rgba(26,115,232,.2);border-color:rgba(26,115,232,.4)}
.kp-btn:active{transform:scale(.94);background:rgba(26,115,232,.3)}
.login-error{color:#F87171;font-size:12px;font-family:var(--font-head);min-height:18px;margin-top:6px;transition:opacity .2s}
.login-shake .login-pin-row{animation:loginShake .35s ease}
@keyframes loginShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
.login-lockout{font-size:12px;color:#FBBF24;font-family:var(--font-head);margin-top:8px}

/* ── SPRINT 1: TEAM MEMBERS ── */
.team-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;min-height:4px}
.team-item{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm)}
.team-item-info{flex:1}
.team-item-name{font-size:13px;font-weight:600;color:var(--text);font-family:var(--font-head)}
.team-item-role{font-size:11px;color:var(--text3);margin-top:1px}
.team-remove{background:none;border:none;color:var(--text3);font-size:14px;cursor:pointer;padding:3px 7px;border-radius:4px;transition:all .15s;line-height:1}
.team-remove:hover{color:var(--error);background:rgba(220,38,38,.08)}
.team-add-row{display:flex;gap:8px;margin-top:6px;flex-wrap:wrap}
.team-add-row input{flex:1;min-width:140px;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:12px;background:var(--surface);color:var(--text);outline:none;transition:border-color .2s}
.team-add-row input:focus{border-color:var(--accent)}

.pill-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;font-family:var(--font-head)}
/* ── B1 · USER MANAGEMENT ── */
.fb-users-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px}
.fb-user-row{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s}
.fb-user-row:hover{border-color:var(--accent)}
.fb-user-row.inactive{opacity:.55}
.fb-user-av{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:12px;color:#fff;background:linear-gradient(135deg,var(--navy-light),var(--accent))}
.fb-user-main{flex:1;min-width:0}
.fb-user-name{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.fb-user-email{font-size:11px;color:var(--text3);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fb-role-badge{font-family:var(--font-head);font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:.3px;text-transform:uppercase}
.fb-role-superadmin{background:rgba(124,58,237,.12);color:#7c3aed}
.fb-role-admin{background:rgba(27,127,204,.12);color:var(--accent)}
.fb-role-field{background:rgba(100,116,139,.14);color:#475569}
.fb-user-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.fb-uact{font-family:var(--font-head);font-size:10px;font-weight:700;padding:5px 11px;border-radius:5px;border:1px solid var(--border);background:#fff;color:var(--text2);cursor:pointer;transition:all .15s}
.fb-uact:hover{border-color:var(--accent);color:var(--accent)}
.fb-uact.danger:hover{border-color:var(--error);color:var(--error)}
.fb-modal-box{background:var(--surface);border-radius:var(--radius);max-width:540px;width:100%;max-height:88vh;overflow:auto;box-shadow:0 20px 60px rgba(5,15,30,.3)}
.fb-modal-hd{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.fb-modal-hd-t{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--navy)}
.fb-modal-x{background:none;border:none;font-size:22px;color:var(--text3);cursor:pointer;line-height:1}
.fb-modal-body{padding:18px 20px}
.fb-modal-foot{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
.fb-fld{margin-bottom:14px}
.fb-fld label{font-family:var(--font-head);font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.4px;display:block;margin-bottom:5px}
.fb-fld input,.fb-fld select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13.5px;color:var(--text);outline:none;background:var(--surface)}
.fb-fld input:focus,.fb-fld select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fb-perm-cat{margin-bottom:14px}
.fb-perm-cat-h{font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.fb-perm-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:12.5px;color:var(--text2);gap:12px}
.fb-perm-row input{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}
.fb-perm-note{font-size:11.5px;color:var(--text3);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;margin-bottom:14px;line-height:1.4}
.fb-readonly-note{font-size:11px;color:var(--text3);font-style:italic;padding:6px 0}
.settings-inline-label{display:flex;align-items:center;gap:8px;margin-bottom:4px}

/* ── SPRINT 1: DATA MANAGEMENT ── */
.data-action-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.btn-data{padding:8px 16px;border-radius:var(--radius-sm);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;border:1.5px solid;display:inline-flex;align-items:center;gap:6px}
.btn-data-export{background:rgba(22,163,74,.08);color:var(--success);border-color:rgba(22,163,74,.25)}
.btn-data-export:hover{background:rgba(22,163,74,.15);border-color:var(--success)}
.btn-data-import{background:rgba(26,115,232,.08);color:var(--accent);border-color:rgba(26,115,232,.25)}
.btn-data-import:hover{background:rgba(26,115,232,.15);border-color:var(--accent)}
.data-restore-input{display:none}
.backup-note{font-size:11px;color:var(--text3);margin-top:6px;line-height:1.5;padding:8px 10px;background:rgba(217,119,6,.04);border-left:2px solid rgba(217,119,6,.3);border-radius:0 4px 4px 0}

/* ── SPRINT 2 ── */
.cc-renewal-banner{padding:7px 20px;font-family:var(--font-head);font-size:12px;font-weight:700;display:flex;align-items:center;gap:8px;flex-shrink:0}
.cc-renewal-banner.amber{background:rgba(217,119,6,.1);color:#92400E;border-bottom:1px solid rgba(217,119,6,.2)}
.cc-renewal-banner.red{background:rgba(220,38,38,.1);color:#991B1B;border-bottom:1px solid rgba(220,38,38,.2)}
.cc-stat-inline{display:flex;align-items:center;gap:0;background:var(--surface2);border-radius:7px;overflow:hidden;border:1px solid var(--border);flex-shrink:0}
.cc-stat-pill{display:flex;flex-direction:column;align-items:center;padding:4px 12px;border-right:1px solid var(--border);min-width:48px;cursor:default}
.cc-stat-pill:last-child{border-right:none}
.cc-stat-num{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--navy);line-height:1.2}
.cc-stat-lbl{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.cc-stat-pill.warn .cc-stat-num{color:var(--warning)}
.cc-stat-pill.alert .cc-stat-num{color:var(--error)}
.sub-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:12px;font-family:var(--font-head);cursor:pointer;transition:opacity .15s;user-select:none;white-space:nowrap}
.sub-status-badge:hover{opacity:.75}
.ss-form{background:rgba(90,122,154,.12);color:#3D5C73;border:1px solid rgba(90,122,154,.2)}
.ss-aor-gen{background:rgba(26,115,232,.1);color:#1A52A0;border:1px solid rgba(26,115,232,.2)}
.ss-aor-sent{background:rgba(217,119,6,.1);color:#92400E;border:1px solid rgba(217,119,6,.2)}
.ss-enrolled{background:rgba(22,163,74,.1);color:#14532D;border:1px solid rgba(22,163,74,.2)}
.task-assignee{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--text3);background:var(--surface3);border-radius:10px;padding:1px 7px;margin-top:2px;font-family:var(--font-head)}
.cc-pin-edit-btn{background:none;border:none;color:var(--text3);font-size:11px;cursor:pointer;padding:2px 5px;border-radius:3px;transition:all .15s;line-height:1}
.cc-pin-edit-btn:hover{color:var(--accent);background:rgba(26,115,232,.08)}
.cc-pin-edit-area{width:100%;min-height:48px;resize:vertical;font-size:12px;font-family:var(--font);border:1.5px solid var(--accent);border-radius:5px;padding:6px 8px;outline:none;box-sizing:border-box;color:var(--text);background:var(--surface)}
.cc-pin-edit-actions{display:flex;gap:6px;margin-top:5px}


/* ---- TechStack conversion overrides ---- */
#loginOverlay{display:none!important}
#fb-portal-root{display:contents}
