:root{--color-navy: #025158;--color-navy-light: #036b74;--color-accent: #b2e069;--color-white: #ffffff;--color-bg: #f2f4f8;--color-surface: #ffffff;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-border: #e5e7eb;--color-border-strong: #d1d5db;--color-error: #dc2626;--color-error-bg: #fee2e2;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--transition-fast: .12s ease;--transition-base: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;height:100dvh;background:var(--color-navy)}body{font-family:var(--font-family);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;position:relative}body:before{content:"";position:fixed;inset:0;z-index:-1;background:var(--app-bg, var(--color-navy))}#root{height:100%;display:flex;flex-direction:column}.app-header{background:var(--color-navy);color:#fff;padding:14px 24px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}.app-header__logo{width:36px;height:36px;background:var(--color-accent);color:var(--color-navy);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex-shrink:0}.app-header__title{font-size:18px;font-weight:700;letter-spacing:-.3px}.app-header__back{margin-right:4px;background:#ffffff26;border:none;color:#fff;width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.app-header__back:hover{background:#ffffff40}.app-header__board-title{font-size:16px;font-weight:600;color:#ffffffe6}.app-header__spacer{flex:1}.app-header__left,.app-header__right{display:flex;align-items:center;gap:10px;flex:1 1 0}.app-header__right{justify-content:flex-end}.app-header__icon-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:8px;background:#ffffff24;font-size:17px;line-height:1;cursor:pointer;transition:background var(--transition-fast)}.app-header__icon-btn:hover{background:#ffffff42}.app-header__center{display:flex;justify-content:center;flex:0 1 520px;min-width:0}.search-box{position:relative;display:flex;align-items:center;width:100%;max-width:520px}.search-box__icon{position:absolute;left:12px;font-size:16px;color:#fff9;pointer-events:none}.search-box__input{width:100%;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:14px;padding:8px 36px 8px 34px;border-radius:var(--radius-sm);outline:none;font-family:inherit;transition:background var(--transition-fast),border-color var(--transition-fast)}.search-box__input::placeholder{color:#ffffff8c}.search-box__input:focus{background:#fff3;border-color:#fff6}.search-box__clear{position:absolute;right:8px;background:none;border:none;color:#fff9;cursor:pointer;font-size:20px;line-height:1;padding:2px 6px;border-radius:var(--radius-sm)}.search-box__clear:hover{background:#ffffff26;color:#fff}.search-box__dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;color:var(--color-text-primary);border-radius:var(--radius-md);box-shadow:0 12px 36px #0000002e;border:1px solid var(--color-border);max-height:420px;overflow-y:auto;z-index:200}.search-box__empty{padding:14px 16px;font-size:13px;color:var(--color-text-muted);text-align:center}.search-results{list-style:none;padding:4px 0;margin:0}.search-result{padding:8px 14px;cursor:pointer;display:flex;flex-direction:column;gap:2px;border-left:3px solid transparent}.search-result--active,.search-result:hover{background:var(--color-bg);border-left-color:var(--color-navy)}.search-result__title{font-size:14px;font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;gap:8px}.search-result__archived-tag{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#92400e;background:#fde68a;padding:1px 6px;border-radius:3px;flex-shrink:0}.search-result__sub{font-size:12px;color:var(--color-text-secondary);display:flex;gap:6px;align-items:baseline;flex-wrap:wrap}.search-result__list{background:var(--color-border);color:var(--color-text-secondary);padding:1px 6px;border-radius:3px;font-size:11px;font-weight:500}.search-result__sep{color:var(--color-text-muted)}.search-result__meta{color:var(--color-text-secondary)}.search-match{background:#fef3c7;color:inherit;padding:0 2px;border-radius:2px;font-weight:600}@media(max-width:720px){.app-header__center{flex:1 1 auto}.app-header__left{flex:0 0 auto}.app-header__right{flex:0 0 auto;gap:6px}.app-header__title{display:none}.app-header__icon-btn{width:30px;height:30px;font-size:15px}.search-box__input{font-size:13px;padding:7px 28px}.search-box__icon{left:9px;font-size:14px}}.btn-sync{display:inline-flex;align-items:center;gap:8px;background:var(--color-accent);color:var(--color-navy);border:none;font-weight:600;font-size:13px;padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast),transform var(--transition-fast);white-space:nowrap}.btn-sync:hover:not(:disabled){background:#c4ec80}.btn-sync:active:not(:disabled){transform:translateY(1px)}.btn-sync--ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.45)}.btn-sync--ghost:hover:not(:disabled){background:#ffffff26}.btn-sync:disabled{opacity:.7;cursor:progress}.btn-sync__icon{font-size:15px;line-height:1;display:inline-block}.btn-sync__spinner{width:14px;height:14px;border:2px solid rgba(2,81,88,.3);border-top-color:var(--color-navy);border-radius:50%;animation:btn-sync-spin .8s linear infinite}@keyframes btn-sync-spin{to{transform:rotate(360deg)}}.sync-status{font-size:13px;padding:5px 10px;border-radius:var(--radius-sm);font-weight:500;white-space:nowrap}.sync-status--ok{background:#b2e06933;color:var(--color-accent);border:1px solid rgba(178,224,105,.4)}.sync-status--err{background:#dc262626;color:#fca5a5;border:1px solid rgba(220,38,38,.4)}@media(max-width:600px){.btn-sync{padding:6px 10px;font-size:12px}.sync-status{display:none}}.btn-dup{position:relative}.btn-dup__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:2px;border-radius:9px;background:var(--color-accent);color:var(--color-navy);font-size:11px;font-weight:700;line-height:1}.dup-modal{max-width:720px}.dup-modal__sub{font-size:13px;color:var(--color-text-secondary);margin-top:4px;max-width:56ch}.dup-modal__body{gap:12px}.dup-empty{text-align:center;padding:32px 12px;color:var(--color-text-secondary);font-size:15px}.dup-list{display:flex;flex-direction:column;gap:12px}.dup-row{border:1px solid var(--color-border);border-radius:var(--radius-md, 10px);padding:12px 14px;display:flex;flex-direction:column;gap:10px;background:var(--color-bg)}.dup-reason{align-self:flex-start;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:#94a3b82e;color:var(--color-text-secondary)}.dup-reason--high{background:#b2e06940;color:#3f6212}.dup-pair{display:flex;align-items:stretch;gap:10px}.dup-side{flex:1;min-width:0;text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.dup-side:hover{border-color:var(--color-accent);box-shadow:0 2px 8px #0000000f}.dup-side__tag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);margin-bottom:4px}.dup-side__tag--lead{color:#0d9488}.dup-side__name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dup-side__meta{font-size:12px;color:var(--color-text-secondary);margin-top:2px;word-break:break-word}.dup-side__labels{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.dup-label{font-size:10px;font-weight:600;color:#fff;padding:1px 6px;border-radius:4px}.dup-arrow{align-self:center;color:var(--color-text-secondary);font-size:18px;flex:0 0 auto}.dup-actions{display:flex;gap:8px;justify-content:flex-end}@media(max-width:600px){.dup-pair{flex-direction:column}.dup-arrow{transform:rotate(90deg)}}.sync-menu{position:relative}.sync-menu__toggle{font-size:18px;line-height:1;padding:6px 12px}.sync-menu__dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:120;min-width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md, 10px);box-shadow:0 12px 32px #0000002e;padding:6px;display:flex;flex-direction:column;gap:2px}.sync-menu__item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;cursor:pointer;font-size:14px;color:var(--color-text-primary);padding:9px 10px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.sync-menu__item:hover:not(:disabled){background:var(--color-bg)}.sync-menu__item:disabled{opacity:.5;cursor:progress}.sync-menu__divider{height:1px;background:var(--color-border);margin:4px 2px}.sync-menu__status{display:flex;align-items:center;gap:8px;padding:6px 10px;font-size:12px;color:var(--color-text-secondary)}.xero-panel{display:flex;flex-direction:column;gap:8px}.xero-panel__org{font-weight:500;color:var(--color-text-secondary);text-transform:none;letter-spacing:0}.xero-panel__hint{font-size:13px;color:var(--color-text-secondary);margin:0}.xero-panel__total{font-size:14px;color:var(--color-text-primary)}.xero-panel__gst{font-size:12px;color:var(--color-text-secondary)}.xero-panel__discount{font-size:12px;color:#059669;font-weight:500}.xero-panel__warn{font-size:12px;color:#b45309;margin-top:2px}.xero-panel__actions{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:16px}.xero-panel__action-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.xero-panel__actions .xero-panel__btn--quote{background:#43a047;border-color:#43a047;color:#fff}.xero-panel__actions .xero-panel__btn--quote:hover:not(:disabled){background:#388e3c;border-color:#388e3c}.xero-panel__actions .xero-panel__btn--invoice{background:#1b5e20;border-color:#1b5e20;color:#fff}.xero-panel__actions .xero-panel__btn--invoice:hover:not(:disabled){background:#154a19;border-color:#154a19}.xero-panel__confirm-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.4px;min-width:54px}.xero-panel__msg{font-size:13px;padding:8px 10px;border-radius:var(--radius-sm)}.xero-panel__msg--ok{background:#ecfdf5;color:#047857}.xero-panel__msg--error{background:#fef2f2;color:#b91c1c}.xero-panel__docs{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.xero-panel__docs li{display:flex;align-items:center;gap:8px;font-size:13px}.xero-panel__docs a{color:var(--color-primary, #025158);font-weight:600}.xero-panel__badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}.xero-panel__badge--quote{background:#eef2ff;color:#4338ca}.xero-panel__badge--invoice{background:#ecfdf5;color:#047857}.xero-panel__doc-status{color:var(--color-text-secondary);font-size:12px}.xero-panel__doc-total{margin-left:auto;font-variant-numeric:tabular-nums}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--color-navy);color:#fff}.btn-primary:hover{background:var(--color-navy-light)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text-primary)}.btn-danger{background:transparent;color:var(--color-error);border:1px solid var(--color-error)}.btn-danger:hover{background:var(--color-error-bg)}.btn-sm{padding:5px 10px;font-size:13px}.dashboard{padding:32px 24px;max-width:1200px}.dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.dashboard__title{font-size:22px;font-weight:700;color:var(--color-text-primary)}.boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.board-card{border-radius:var(--radius-md);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast);background:var(--color-surface)}.board-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.board-card__color{height:80px;display:flex;align-items:flex-start;padding:12px}.board-card__body{padding:12px}.board-card__title{font-weight:600;font-size:15px;color:var(--color-text-primary)}.board-card__meta{font-size:12px;color:var(--color-text-muted);margin-top:2px}.board-card-new{border-radius:var(--radius-md);border:2px dashed var(--color-border-strong);height:130px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--color-text-secondary);font-weight:500;gap:8px;transition:all var(--transition-fast)}.board-card-new:hover{border-color:var(--color-navy);color:var(--color-navy);background:#0251580a}.modal-overlay{position:fixed;inset:0;background:#00000073;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0003;width:100%;max-width:520px;max-height:90vh;max-height:90dvh;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}.modal__header{padding:20px 24px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal__title{font-size:18px;font-weight:700}.modal__close{width:32px;height:32px;border:none;background:none;cursor:pointer;font-size:20px;color:var(--color-text-secondary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.modal__close:hover{background:var(--color-bg)}.modal__body{padding:20px 24px;display:flex;flex-direction:column;gap:16px}.modal__footer{padding:16px 24px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:8px}.card-modal__archived-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 24px;padding:10px 14px;background:#fef3c7;border:1px solid #fcd34d;border-radius:var(--radius-sm);font-size:13px;color:#92400e;font-weight:500}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.form-input,.form-textarea{padding:9px 12px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast);outline:none}.form-input:focus,.form-textarea:focus{border-color:var(--color-navy)}.form-textarea{resize:vertical;min-height:80px}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;border:3px solid transparent;transition:transform var(--transition-fast)}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:#000}.board-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.board-view__inner{flex:1;overflow-x:auto;overflow-y:hidden;padding:20px;display:flex;align-items:flex-start;gap:12px}.list-column{width:272px;flex-shrink:0;background:#ebecf0;border-radius:var(--radius-md);display:flex;flex-direction:column;max-height:calc(100vh - 104px)}.list-column.is-dragging-over{background:#dfe1e6}.list-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px;gap:8px}.list-title{font-weight:600;font-size:14px;flex:1;cursor:pointer;padding:3px 6px;border-radius:var(--radius-sm);border:1px solid transparent}.list-title:hover{background:#00000014}.list-title-input{flex:1;font-weight:600;font-size:14px;padding:3px 6px;border-radius:var(--radius-sm);border:1px solid var(--color-navy);outline:none;background:#fff;font-family:inherit}.list-menu-btn{width:28px;height:28px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:16px;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.list-menu-btn:hover{background:#0000001a}.list-cards{flex:1;overflow-y:auto;padding:0 8px 8px;display:flex;flex-direction:column;gap:8px;min-height:8px}.list-add-card{padding:6px 8px;border:none;background:none;cursor:pointer;text-align:left;font-size:13px;color:var(--color-text-secondary);border-radius:var(--radius-sm);display:flex;align-items:center;gap:6px;margin:4px 8px 8px;transition:background var(--transition-fast),color var(--transition-fast)}.list-add-card:hover{background:#00000014;color:var(--color-text-primary)}.list-add-card-form{padding:0 8px 8px;display:flex;flex-direction:column;gap:6px}.list-add-card-form textarea{padding:8px;border:none;border-radius:var(--radius-sm);font-size:14px;font-family:inherit;resize:none;outline:none;box-shadow:var(--shadow-sm);min-height:60px}.list-add-card-form-actions{display:flex;gap:6px;align-items:center}.card{background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:10px 12px;cursor:pointer;transition:box-shadow var(--transition-fast);position:relative}.card:hover{box-shadow:0 4px 8px #0000001f}.card.is-dragging{box-shadow:0 8px 20px #0003;opacity:.9}.card__labels{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.card__label{height:8px;border-radius:4px;min-width:40px}.card__title{font-size:14px;color:var(--color-text-primary);line-height:1.4}.card__meta{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.card__due{font-size:11px;padding:2px 6px;border-radius:3px;font-weight:500;display:flex;align-items:center;gap:3px}.card__due--overdue{background:#fecaca;color:#b91c1c}.card__due--soon{background:#fef3c7;color:#b45309}.card__due--ok{background:#dcfce7;color:#15803d}.card__checklist-badge{font-size:11px;color:var(--color-text-secondary);display:flex;align-items:center;gap:3px}.card__checklist-badge--done{color:#15803d}.add-list-btn{width:272px;flex-shrink:0;background:#ffffff40;border:none;border-radius:var(--radius-md);padding:12px 16px;cursor:pointer;font-size:14px;font-weight:500;color:#fff;display:flex;align-items:center;gap:8px;transition:background var(--transition-fast);text-shadow:0 1px 2px rgba(0,0,0,.2);align-self:flex-start}.add-list-btn:hover{background:#ffffff59}.add-list-form{width:272px;flex-shrink:0;background:#ebecf0;border-radius:var(--radius-md);padding:10px;display:flex;flex-direction:column;gap:8px;align-self:flex-start}.add-list-form input{padding:8px 10px;border:none;border-radius:var(--radius-sm);font-size:14px;font-family:inherit;outline:none;font-weight:600;box-shadow:var(--shadow-sm)}.add-list-form-actions{display:flex;gap:6px;align-items:center}.card-modal{max-width:980px}.card-modal__layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:20px;align-items:start}.card-modal__main{display:flex;flex-direction:column;gap:16px;min-width:0}.card-modal__sidebar{display:flex;flex-direction:column;min-width:0;background:var(--color-bg);border-radius:var(--radius-md);padding:14px;border:1px solid var(--color-border);max-height:calc(90vh - 200px);overflow-y:auto;position:sticky;top:0}.activity-stream{display:flex;flex-direction:column;gap:12px}.activity-stream__header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--color-text-primary);padding-bottom:4px}.activity-stream__icon{font-size:16px}.activity-stream__compose{display:flex;flex-direction:column;gap:8px}.activity-stream__input{width:100%;resize:vertical;min-height:38px;background:#fff}.activity-stream__compose-actions{display:flex;gap:6px}.activity-stream__empty{font-size:13px;color:var(--color-text-muted);padding:16px 0;text-align:center}.activity-stream__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.activity-entry{display:grid;grid-template-columns:24px 1fr;gap:10px;align-items:start}.activity-entry__avatar{width:24px;height:24px;border-radius:50%;background:var(--color-border-strong);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;margin-top:2px}.activity-entry--comment .activity-entry__avatar{background:var(--color-navy);color:#fff}.activity-entry__body{display:flex;flex-direction:column;gap:4px;min-width:0}.activity-entry__meta{font-size:12px;color:var(--color-text-secondary);display:flex;align-items:baseline;gap:8px}.activity-entry__author{font-weight:600;color:var(--color-text-primary)}.activity-entry__time{font-size:12px;color:var(--color-text-muted)}.activity-entry__bubble{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;font-size:14px;color:var(--color-text-primary);word-break:break-word;white-space:pre-wrap}.activity-entry__actions{display:flex;gap:10px;padding-left:2px}.activity-entry__action-btn{background:none;border:none;padding:0;cursor:pointer;font-size:12px;color:var(--color-text-secondary);text-decoration:underline}.activity-entry__action-btn:hover{color:var(--color-error)}.activity-entry__text{font-size:13px;color:var(--color-text-secondary);line-height:1.5}.activity-entry__text strong{color:var(--color-text-primary);font-weight:600}.activity-label-chip{display:inline-block;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;color:#fff;vertical-align:middle;margin:0 2px}@media(max-width:820px){.card-modal__layout{grid-template-columns:1fr}.card-modal__sidebar{position:static;max-height:none}}.card-modal__list-name{font-size:12px;color:var(--color-text-muted);margin-top:2px;position:relative}.card-modal__list-name-btn{display:inline-flex;align-items:center;gap:4px;border:none;background:transparent;font:inherit;color:inherit;padding:1px 4px;margin-left:-4px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.card-modal__list-name-btn:hover:not(:disabled){background:var(--color-bg-muted, rgba(0, 0, 0, .05))}.card-modal__list-name-btn:disabled{cursor:default}.card-modal__list-name-caret{font-size:9px;opacity:.6}.card-modal__list-menu{position:absolute;top:100%;left:0;margin-top:4px;z-index:30;min-width:200px;max-height:320px;overflow-y:auto;background:var(--color-bg-surface, #fff);border:1px solid var(--color-border, rgba(0, 0, 0, .12));border-radius:var(--radius-md, 8px);box-shadow:0 8px 24px #00000029;padding:4px}.card-modal__list-menu-item{display:flex;align-items:center;gap:6px;width:100%;text-align:left;border:none;background:transparent;font:inherit;font-size:13px;color:var(--color-text-primary);padding:7px 8px;border-radius:var(--radius-sm);cursor:pointer}.card-modal__list-menu-item:hover{background:var(--color-bg-muted, rgba(0, 0, 0, .06))}.card-modal__list-menu-item.is-current{font-weight:600}.card-modal__list-menu-check{color:var(--color-primary, #2563eb)}.card-modal__title-input{font-size:18px;font-weight:700;border:1px solid transparent;border-radius:var(--radius-sm);padding:4px 8px;width:100%;font-family:inherit;outline:none;background:transparent;color:var(--color-text-primary);transition:border-color var(--transition-fast),background var(--transition-fast)}.card-modal__title-input:hover{background:var(--color-bg)}.card-modal__title-input:focus{border-color:var(--color-navy);background:#fff}.card-modal__section{display:flex;flex-direction:column;gap:8px}.card-modal__section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.card-modal__hint{font-size:13px;color:var(--color-text-secondary);margin:2px 0}.job-panel{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface);margin-bottom:10px;overflow:hidden}.job-panel--archived{opacity:.6}.job-panel__header{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--color-bg);border:0;cursor:pointer;text-align:left;font-size:13px}.job-panel__header:hover{background:var(--color-border)}.job-panel__caret{color:var(--color-text-secondary);width:12px}.job-panel__number{font-weight:700;color:var(--color-navy)}.job-panel__summary{color:var(--color-text-primary);flex:1}.job-panel__assignee{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;border:1.5px solid var(--color-navy);color:var(--color-navy)}.job-panel__status--archived{font-size:11px;color:var(--color-text-secondary);font-style:italic}.job-panel__body{display:flex;flex-direction:column;gap:14px;padding:12px}.job-panel__pills{display:flex;flex-wrap:wrap;gap:6px}.job-panel__pill{padding:5px 12px;border:1px solid var(--color-border-strong);border-radius:20px;background:var(--color-surface);font-size:13px;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.job-panel__pill:hover{border-color:var(--color-navy)}.job-panel__pill.is-active{background:var(--color-navy);border-color:var(--color-navy);color:#fff}.job-panel__check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-primary);cursor:pointer}.job-panel__billing-readout{font-size:13px;color:var(--color-text-secondary);padding:6px 0}.job-panel__footer{display:flex;justify-content:flex-end}.dates-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.dates-btn:hover{border-color:var(--color-navy);background:var(--color-bg)}.dates-btn__icon{font-size:15px;color:var(--color-text-secondary)}.dates-picker-backdrop{position:fixed;inset:0;z-index:490}.dates-picker{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:500;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0003;width:320px;max-width:calc(100vw - 24px);max-height:calc(100dvh - 24px);overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.dates-picker__header{display:flex;align-items:center;justify-content:space-between}.dates-picker__title{font-size:16px;font-weight:700}.dates-picker__close{width:28px;height:28px;border:none;border-radius:50%;background:transparent;cursor:pointer;font-size:20px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;line-height:1}.dates-picker__close:hover{background:var(--color-bg);color:var(--color-text-primary)}.dates-picker__nav{display:flex;align-items:center;justify-content:space-between;gap:4px}.dates-picker__nav-btn{width:30px;height:30px;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:16px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center}.dates-picker__nav-btn:hover{background:var(--color-bg);color:var(--color-text-primary)}.dates-picker__month-label{font-size:15px;font-weight:700;flex:1;text-align:center}.dates-picker__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dates-picker__day-header{text-align:center;font-size:11px;font-weight:600;color:var(--color-text-secondary);padding:4px 0;text-transform:uppercase;letter-spacing:.3px}.dates-picker__day{aspect-ratio:1;border:none;border-radius:50%;background:transparent;cursor:pointer;font-size:13px;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.dates-picker__day:hover{background:var(--color-bg)}.dates-picker__day--other{color:var(--color-text-muted)}.dates-picker__day--today{text-decoration:underline;font-weight:600}.dates-picker__day--selected{background:var(--color-navy)!important;color:#fff!important;font-weight:600}.dates-picker__fields{display:flex;gap:10px}.dates-picker__field{flex:1;display:flex;flex-direction:column;gap:4px}.dates-picker__label{font-size:12px;font-weight:600;color:var(--color-text-secondary)}.dates-picker__actions{display:flex;flex-direction:column}.label-list{display:flex;flex-wrap:wrap;gap:6px}.label-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;color:#fff}.label-pill__remove{background:none;border:none;cursor:pointer;color:#fffc;font-size:14px;padding:0;line-height:1;display:flex;align-items:center}.label-pill__remove:hover{color:#fff}.label-add-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.label-color-btn{width:28px;height:28px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform var(--transition-fast)}.label-color-btn:hover{transform:scale(1.15)}.label-color-btn.selected{border-color:var(--color-text-primary)}.label-add-btn{font-size:12px;padding:4px 10px;border-radius:20px;border:1px dashed var(--color-border-strong);background:transparent;cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast)}.label-add-btn:hover{border-color:var(--color-navy);color:var(--color-navy)}.checklist-item{display:flex;align-items:center;gap:8px;padding:4px 0}.checklist-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-navy)}.checklist-item__text{flex:1;font-size:14px;color:var(--color-text-primary)}.checklist-item__text--checked{text-decoration:line-through;color:var(--color-text-muted)}.checklist-item__del{width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--color-text-muted);font-size:14px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast),background var(--transition-fast)}.checklist-item:hover .checklist-item__del{opacity:1}.checklist-item__del:hover{background:var(--color-error-bg);color:var(--color-error)}.checklist-progress{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden;margin-bottom:4px}.checklist-progress__bar{height:100%;background:var(--color-navy);border-radius:3px;transition:width .3s ease}.checklist-add-row{display:flex;gap:6px;margin-top:4px}.checklist-add-row input{flex:1;padding:7px 10px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;outline:none}.checklist-add-row input:focus{border-color:var(--color-navy)}.area-tag{display:inline-flex;align-items:center;align-self:flex-start;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.card__detail{display:flex;align-items:flex-start;gap:5px;margin-top:5px}.card__detail-icon{font-size:11px;flex-shrink:0;margin-top:1px}.card__detail-text{font-size:11px;color:var(--color-text-secondary);line-height:1.4;word-break:break-word}.card__services-badge{font-size:11px;color:var(--color-text-secondary);display:flex;align-items:center;gap:3px}.card__hours-badge{font-size:11px;color:var(--color-navy);background:#e0f2f1;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-weight:600}.card__twoman-badge{font-size:11px;color:#b45309;background:#fef3c7;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-weight:600}.card__quote-badge{font-size:11px;color:#047857;background:#d1fae5;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-weight:600}.service-option__hours{margin-left:auto;font-size:12px;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.service-option__price{margin-left:auto;font-size:12px;font-weight:600;color:#047857;font-variant-numeric:tabular-nums}.service-option__price+.service-option__hours{margin-left:8px}.service-option__twoman{font-size:10px;font-weight:600;color:#b45309;background:#fef3c7;padding:1px 6px;border-radius:8px;margin-left:6px}.service-select__summary{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;padding:8px 10px;background:var(--color-bg);border-radius:var(--radius-sm);font-size:13px;color:var(--color-text-secondary)}.service-select__total strong{color:var(--color-navy)}.service-select__quote{color:#047857;font-weight:600}.service-select__quote strong{color:#047857;font-size:15px}.service-select__quote-was{color:var(--color-text-secondary);font-weight:500;font-size:12px}.service-select__twoman-flag{color:#b45309;font-weight:600}.form-input--error{border-color:var(--color-error)!important}.form-error{font-size:12px;color:var(--color-error);margin-top:2px}.address-fields{display:flex;flex-direction:column;gap:10px}.address-fields__row{display:flex;gap:8px;align-items:flex-end}.address-input,.address-input__wrap{position:relative}.address-input__wrap .form-input{padding-right:32px;width:100%}.address-input__spinner{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-navy);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}.address-input__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:400;overflow:hidden}.address-input__option{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;cursor:pointer;transition:background var(--transition-fast)}.address-input__option:hover{background:var(--color-bg)}.address-input__icon{font-size:13px;flex-shrink:0;margin-top:1px}.address-input__text{font-size:13px;color:var(--color-text-primary);line-height:1.4}.address-input__attribution{padding:5px 14px;font-size:10px;color:var(--color-text-muted);border-top:1px solid var(--color-border);text-align:right}.service-select{position:relative}.service-select__box{min-height:42px;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:6px 8px;display:flex;flex-wrap:wrap;gap:6px;align-items:center;cursor:text;background:var(--color-surface);transition:border-color var(--transition-fast)}.service-select__box--open{border-color:var(--color-navy)}.service-select__input{border:none;outline:none;font-size:13px;font-family:inherit;flex:1;min-width:120px;background:transparent;color:var(--color-text-primary)}.service-select__input::placeholder{color:var(--color-text-muted)}.service-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:300;max-height:240px;overflow-y:auto}.service-select__option{display:flex;align-items:baseline;gap:8px;padding:9px 14px;cursor:pointer;transition:background var(--transition-fast)}.service-select__option:hover{background:var(--color-bg)}.service-option__abbrev{font-size:12px;font-weight:700;color:var(--color-navy);white-space:nowrap;min-width:90px}.service-option__name{font-size:13px;color:var(--color-text-primary)}.service-select__more,.service-select__empty{padding:10px 14px;font-size:12px;color:var(--color-text-muted);text-align:center}.service-select__option--new{border-top:1px solid var(--color-border);color:var(--color-navy);font-weight:600;font-size:13px}.service-select__new-plus{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--color-navy);color:#fff;font-weight:700;font-size:14px}.new-service-modal__body{padding:18px 24px 22px;display:flex;flex-direction:column;gap:14px}.new-service-modal__field{display:flex;flex-direction:column;gap:4px}.new-service-modal__label{font-size:12px;font-weight:600;color:var(--color-text-secondary)}.new-service-modal__checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-primary)}.new-service-modal__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.new-service-modal__error{font-size:12px;color:var(--color-error);background:#fbeaea;padding:8px 10px;border-radius:4px}.new-service-modal__warn{font-size:12px;color:#b45309;background:#fef3c7;padding:8px 10px;border-radius:4px}.service-tag-wrap{position:relative;display:inline-flex;max-width:100%}.service-tag{display:inline-flex;align-items:center;gap:4px;background:#e8f0fe;border:1px solid transparent;border-radius:4px;padding:3px 8px;max-width:100%;cursor:pointer;font:inherit;color:inherit;text-align:left}.service-tag:hover{background:#d9e6fd}.service-tag--editing{background:#d9e6fd;border-color:var(--color-navy)}.service-tag__abbrev{font-size:11px;font-weight:700;color:var(--color-navy);white-space:nowrap}.service-tag__name{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.service-tag__qty{font-size:11px;font-weight:700;color:#fff;background:var(--color-navy);border-radius:10px;padding:1px 7px;margin-left:2px;line-height:1.3}.service-tag__popover{position:absolute;top:calc(100% + 4px);left:0;z-index:30;display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--color-border);border-radius:6px;padding:6px 8px;box-shadow:0 6px 18px #0000001f}.service-tag__qty-btn{width:24px;height:24px;border:1px solid var(--color-border);background:#fff;border-radius:4px;font-size:16px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--color-text)}.service-tag__qty-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-navy)}.service-tag__qty-btn:disabled{opacity:.4;cursor:not-allowed}.service-tag__qty-value{font-size:13px;font-weight:600;min-width:18px;text-align:center}.service-tag__price{font-size:12px;font-weight:600;color:#047857;font-variant-numeric:tabular-nums;padding-right:4px;margin-right:2px;border-right:1px solid var(--color-border)}.service-tag__edit-btn,.service-tag__remove-btn{margin-left:4px;padding:4px 8px;border:none;background:none;font-size:12px;font-weight:500;cursor:pointer;border-radius:4px}.service-tag__edit-btn{color:var(--color-navy)}.service-tag__edit-btn:hover{background:#02515814}.service-tag__remove-btn{color:var(--color-error);margin-left:0}.service-tag__remove-btn:hover{background:#fbeaea}.new-service-modal__hint{font-weight:400;color:var(--color-text-muted)}.new-service-modal__field input:disabled{background:var(--color-bg);color:var(--color-text-muted);cursor:not-allowed}.drag-overlay-card{background:#fff;border-radius:var(--radius-sm);box-shadow:0 12px 30px #00000040;padding:10px 12px;width:256px;font-size:14px;rotate:3deg}.loading{padding:60px;text-align:center;color:var(--color-text-secondary);font-size:15px}.empty-boards{padding:60px;text-align:center;color:var(--color-text-secondary)}.empty-boards p{margin-bottom:16px;font-size:15px}.dropdown{position:relative}.dropdown__menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:160px;z-index:150;overflow:hidden}.dropdown__item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;cursor:pointer;color:var(--color-text-primary);transition:background var(--transition-fast);border:none;background:none;width:100%;text-align:left}.dropdown__item:hover{background:var(--color-bg)}.dropdown__item--danger{color:var(--color-error)}.dropdown__item--danger:hover{background:var(--color-error-bg)}.card__title-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.card__postcode{font-size:11px;font-weight:600;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:1px 5px;white-space:nowrap}.card__age{font-size:11px;font-weight:700;border-radius:10px;padding:1px 8px;white-space:nowrap;letter-spacing:.02em}.card__age--fresh{background:#dcfce7;color:#15803d}.card__age--neutral{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.card__age--aging{background:#fef3c7;color:#b45309}.card__age--stale{background:#fecaca;color:#b91c1c}.label-toggle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.label-toggle{display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 10px;border-radius:var(--radius-sm);border:2px solid transparent;background:#f3f4f6;color:var(--color-text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.label-toggle:hover{background:var(--label-bg);color:var(--label-text);opacity:.85}.label-toggle--active{background:var(--label-bg);color:var(--label-text);border-color:#00000026}.label-toggle__check{font-size:11px;flex-shrink:0}.board-list-tabs{display:none}@media(max-width:640px){input,textarea,select,.form-input,.form-textarea,.search-box__input,.list-title-input,.card-modal__title-input,.activity-stream__input{font-size:16px}.app-header{padding:10px 16px}.app-header__logo{width:28px;height:28px}.board-list-tabs{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:10px 12px;background:#0000002e;flex-shrink:0;scrollbar-width:none}.board-list-tabs::-webkit-scrollbar{display:none}.board-list-tabs__tab{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:#ffffff1f;color:#ffffffd9;font-size:13px;font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap}.board-list-tabs__tab:hover{background:#fff3}.board-list-tabs__tab--active{background:#fff;color:var(--color-text-primary);border-color:#fff;font-weight:600}.board-list-tabs__count{font-size:11px;font-weight:600;padding:1px 7px;border-radius:999px;background:#00000026;color:inherit}.board-list-tabs__tab--active .board-list-tabs__count{background:#0000001a}.board-view__inner{padding:12px 0 12px 16px;gap:16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.list-column{flex:0 0 calc(100% - 32px);scroll-snap-align:start;scroll-margin-left:16px;max-height:calc(100vh - 175px)}.card{padding:10px 12px}.list-add-card{padding:10px 12px;font-size:14px;min-height:44px}.modal-overlay{align-items:flex-end;justify-content:stretch;padding:0}.modal{border-radius:16px 16px 0 0;max-width:100%;max-height:92vh;max-height:92dvh;width:100%}.card-modal{max-width:100%}.modal__header{padding:16px 16px 12px}.modal__body{padding:14px 16px;gap:14px}.modal__footer{padding:12px 16px}.label-toggle-grid{grid-template-columns:repeat(2,1fr)}.modal__body [style*=gridTemplateColumns]{display:flex!important;flex-direction:column}.btn{min-height:40px}}.view-switcher{position:relative}.view-switcher__button{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;display:inline-flex;align-items:center;gap:4px;padding:6px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.view-switcher__button:hover{background:#ffffff38}.view-switcher__panel{position:absolute;top:calc(100% + 8px);left:0;background:#fff;color:var(--color-text-primary);border-radius:var(--radius-md);box-shadow:0 12px 36px #0000002e;border:1px solid var(--color-border);min-width:240px;z-index:300;padding:8px 0}.view-switcher__panel-header{display:flex;align-items:center;justify-content:space-between;padding:6px 14px 10px;font-weight:600;font-size:14px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);margin-bottom:4px}.view-switcher__close{background:none;border:none;font-size:18px;color:var(--color-text-muted);cursor:pointer;line-height:1;padding:0 4px}.view-switcher__close:hover{color:var(--color-text-primary)}.view-switcher__option{display:flex;align-items:center;gap:12px;width:100%;padding:8px 14px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--color-text-primary);text-align:left}.view-switcher__option:hover{background:var(--color-bg)}.view-switcher__option--active{background:var(--color-bg);font-weight:600}.calendar-view{flex:1;display:flex;flex-direction:column;background:#fff;min-height:0}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--color-border);background:#fff;flex-wrap:wrap;gap:10px}.calendar-toolbar__left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.calendar-toolbar__right{display:flex;align-items:center;gap:8px}.calendar-toolbar__heading{font-size:16px;font-weight:600;color:var(--color-text-primary);margin-right:8px;min-width:160px}.calendar-toolbar__nav{background:#fff;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;color:var(--color-text-primary)}.calendar-toolbar__nav:hover{background:var(--color-bg)}.calendar-toolbar__today{background:#fff;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:6px 12px;cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-primary)}.calendar-toolbar__today:hover{background:var(--color-bg)}.calendar-filter{position:relative}.calendar-filter__button{background:#fff;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);height:32px;padding:0 10px;cursor:pointer;color:var(--color-text-primary);display:inline-flex;align-items:center;gap:5px}.calendar-filter__button:hover{background:var(--color-bg)}.calendar-filter__button.is-active{border-color:var(--color-navy);color:var(--color-navy)}.calendar-filter__count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-navy);color:#fff;font-size:11px;font-weight:700;line-height:1}.calendar-filter__menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:200;min-width:200px;padding:4px 0}.calendar-filter__menu-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px 8px;border-bottom:1px solid var(--color-border);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted, #6b7280)}.calendar-filter__clear{border:none;background:none;padding:0;font-size:12px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--color-navy);cursor:pointer;text-decoration:underline}.calendar-filter__item{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;padding:8px 12px;cursor:pointer;font-size:13px;color:var(--color-text-primary);text-align:left}.calendar-filter__item:hover{background:var(--color-bg)}.calendar-filter__item.is-checked{font-weight:600}.calendar-filter__check{width:14px;flex-shrink:0;color:var(--color-navy);font-size:12px}.calendar-filter__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.calendar-filter__text{flex:1}.calendar-view--mobile{background:var(--color-bg)}.mcal{display:flex;flex-direction:column;flex:1;min-height:0}.mcal-header{flex-shrink:0;background:#fff;border-bottom:1px solid var(--color-border);padding:12px 16px 8px}.mcal-titlebar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.mcal-month{font-size:20px;color:var(--color-text-primary)}.mcal-month strong{font-weight:700}.mcal-titlebar__right{display:flex;align-items:center;gap:10px}.mcal-today{background:none;border:none;padding:4px;color:var(--color-navy);font-size:15px;font-weight:600;cursor:pointer}.mcal-tabs{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:10px}.mcal-tabs::-webkit-scrollbar{display:none}.mcal-tab{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-secondary);font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.mcal-tab.is-active{background:var(--color-navy);border-color:var(--color-navy);color:#fff}.mcal-tab__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.mcal-strip{display:flex;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.mcal-strip::-webkit-scrollbar{display:none}.mcal-day{flex:0 0 auto;width:54px;display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;padding:4px 0}.mcal-day__dow{font-size:12px;font-weight:600;color:var(--color-text-muted)}.mcal-day__num{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;font-size:17px;font-weight:600;color:var(--color-text-primary)}.mcal-day.is-active .mcal-day__dow{color:var(--color-navy)}.mcal-day.is-active .mcal-day__num{background:var(--color-navy);color:#fff}.mcal-day__dots{display:flex;gap:3px;height:5px}.mcal-day__dots i{width:4px;height:4px;border-radius:50%;background:var(--color-border-strong)}.mcal-day.is-active .mcal-day__dots i{background:var(--color-navy)}.mcal-feed{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative;padding:0 16px 50vh}.mcal-section{padding-top:18px}.mcal-section__title{font-size:15px;font-weight:700;color:var(--color-text-primary);margin:0 0 10px;display:flex;align-items:center;gap:8px}.mcal-section__today{background:var(--color-navy);color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:20px}.mcal-empty{margin:0;padding:4px 2px;font-size:13px;color:var(--color-text-muted)}.mcal-empty--feed{padding:40px 16px;text-align:center;font-size:15px}.agenda-card{display:block;width:100%;text-align:left;background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:12px 14px;margin-bottom:10px;cursor:pointer;box-shadow:var(--shadow-sm)}.agenda-card:active{background:var(--color-bg)}.agenda-card__top{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px}.agenda-card__warning{display:block;margin-bottom:8px;padding:5px 9px;border-radius:8px;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:12px;font-weight:600;line-height:1.3}.agenda-card__booked{font-size:11px;font-weight:700;color:#047857;background:#ecfdf5;padding:2px 7px;border-radius:20px}.agenda-card__assignee{font-size:11px;font-weight:700;padding:2px 9px;border:1.5px solid;border-radius:20px;background:#fff}.agenda-card__bars{display:inline-flex;gap:5px}.agenda-card__bars span{height:8px;width:28px;border-radius:4px}.agenda-card__title{font-size:16px;font-weight:600;color:var(--color-text-primary);line-height:1.3}.agenda-card__detail{display:flex;align-items:flex-start;gap:6px;margin-top:6px;font-size:14px;color:var(--color-text-secondary, #4b5563);line-height:1.35}.agenda-card__detail-icon{flex-shrink:0}.agenda-card__meta{display:flex;align-items:center;gap:10px;margin-top:6px;font-size:14px}.agenda-card__time{font-weight:600;color:var(--color-text-primary)}.calendar-mode{position:relative}.calendar-mode__button{background:#fff;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:6px 12px;cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-primary);display:inline-flex;align-items:center;gap:6px}.calendar-mode__button:hover{background:var(--color-bg)}.calendar-mode__menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:200;min-width:120px;padding:4px 0}.calendar-mode__item{display:block;width:100%;background:none;border:none;padding:7px 14px;cursor:pointer;font-size:13px;color:var(--color-text-primary);text-align:left}.calendar-mode__item:hover{background:var(--color-bg)}.calendar-mode__item--active{font-weight:600;background:var(--color-bg)}.calendar-grid{flex:1;overflow:auto;min-height:0;background:#fff}.cal-hours{width:60px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--color-border);background:#fafafa}.cal-hour-row{flex:1;position:relative;border-bottom:1px solid var(--color-border);font-size:11px;color:var(--color-text-muted)}.cal-hour-label{position:absolute;top:-7px;right:6px;background:#fafafa;padding:0 2px}.cal-grid-line{position:absolute;left:0;right:0;border-bottom:1px solid var(--color-border);pointer-events:none}.calendar-grid--day{display:flex;flex-direction:column}.cal-day-content{display:flex;flex:1;min-height:480px}.cal-day-header{position:sticky;top:0;background:#fff;z-index:5;border-bottom:1px solid var(--color-border)}.cal-day-header__day{padding:10px 16px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.cal-day-header__day--today{color:var(--color-navy)}.cal-day-header__date{font-weight:400;color:var(--color-text-secondary)}.cal-day-body{flex:1;position:relative;min-height:480px}.calendar-grid--week{display:flex;flex-direction:column;overflow:hidden}.cal-week-header{display:grid;grid-template-columns:60px repeat(5,1fr);border-bottom:1px solid var(--color-border);background:#fff;position:sticky;top:0;z-index:6}.cal-week-header__gutter{border-right:1px solid var(--color-border)}.cal-week-header__day{padding:10px 8px;text-align:center;border-right:1px solid var(--color-border)}.cal-week-header__day:last-child{border-right:none}.cal-week-header__weekday{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.cal-week-header__date{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-top:2px}.cal-week-header__day--today .cal-week-header__date{background:var(--color-navy);color:#fff;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px}.cal-week-scroll{flex:1;overflow:auto;min-height:0;display:flex}.cal-week-body{display:grid;grid-template-columns:60px repeat(5,1fr);position:relative;flex:1;min-height:480px}.cal-week-day-column{position:relative;border-right:1px solid var(--color-border)}.cal-week-day-column:last-child{border-right:none}.calendar-grid--month{display:flex;flex-direction:column}.cal-month-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--color-border);background:#fafafa}.cal-month-header__day{padding:8px;text-align:center;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);border-right:1px solid var(--color-border)}.cal-month-header__day:last-child{border-right:none}.cal-month-body{display:flex;flex-direction:column}.cal-month-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--color-border);min-height:120px}.cal-month-row:last-child{border-bottom:none}.cal-month-cell{border-right:1px solid var(--color-border);padding:6px 6px 8px;display:flex;flex-direction:column;gap:4px;overflow:hidden}.cal-month-cell:last-child{border-right:none}.cal-month-cell--outside{background:#fafbfc}.cal-month-cell--outside .cal-month-cell__date{color:var(--color-text-muted)}.cal-month-cell--today .cal-month-cell__date{background:var(--color-navy);color:#fff;width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.cal-month-cell__date{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.cal-month-cell__cards{display:flex;flex-direction:column;gap:3px;overflow:hidden}.cal-month-cell__time-row{display:flex;gap:2px;min-width:0}.cal-month-cell__time-row>.cal-card--chip{flex:1 1 0;min-width:0}.cal-card{position:relative;border-radius:4px;font-size:12px;cursor:pointer;overflow:visible;box-shadow:0 1px 2px #00000014}.cal-card--block{padding:6px 8px;display:flex;flex-direction:column;gap:4px;box-sizing:border-box;background:#fff;color:var(--color-text-primary);border:1px solid var(--color-border);border-left:4px solid var(--color-navy);overflow:hidden;cursor:grab;transition:box-shadow var(--transition-fast);min-height:28px}.cal-card--block:hover{box-shadow:0 4px 10px #0000001f}.cal-card--block:active{cursor:grabbing}.cal-card--tile{flex-shrink:0;padding:6px 8px;display:flex;flex-direction:column;gap:4px;background:#fff;color:var(--color-text-primary);border:1px solid var(--color-border);border-left:4px solid var(--color-navy);border-radius:4px;box-shadow:0 1px 2px #00000014;cursor:grab;transition:box-shadow var(--transition-fast)}.cal-card--tile:hover{box-shadow:0 4px 10px #0000001f}.cal-card--tile:active{cursor:grabbing}.cal-card--tile .cal-card__title{-webkit-line-clamp:1;font-size:12px}.cal-card--tile .cal-card__detail-text{-webkit-line-clamp:1}.cal-card--tray{flex-shrink:0;padding:6px 8px;display:flex;flex-direction:column;gap:4px;box-sizing:border-box;background:#fff;color:var(--color-text-primary);border:1px solid var(--color-border);border-left:4px solid var(--color-navy);border-radius:4px;box-shadow:0 1px 2px #00000014;overflow:hidden;cursor:grab;transition:box-shadow var(--transition-fast)}.cal-card--tray:hover{box-shadow:0 4px 10px #0000001f}.cal-card--tray:active{cursor:grabbing}.calendar-body{flex:1;display:flex;min-height:0}.calendar-main{flex:1;display:flex;min-width:0}.cal-tobook-tray{width:240px;flex-shrink:0;display:flex;flex-direction:column;min-height:0;border-left:1px solid var(--color-border);background:#f7f8fa}.cal-tobook-tray__header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--color-border);flex-shrink:0}.cal-tobook-tray__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.cal-tobook-tray__count{font-size:11px;font-weight:600;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:1px 7px}.cal-tobook-tray__list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:10px}.cal-card--chip{padding:3px 6px;display:flex;flex-direction:column;gap:1px;font-size:11px;cursor:grab;min-width:0;border-left:4px solid var(--color-navy)}.cal-card--chip:active{cursor:grabbing}.cal-card__booked-tag{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:700;color:#15803d;background:#dcfce7;padding:1px 6px;border-radius:10px;letter-spacing:.2px;white-space:nowrap}.cal-card__booked-check{color:#15803d;font-weight:700}.cal-card__row{display:flex;align-items:flex-start;justify-content:space-between;gap:4px}.cal-card__header{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0}.cal-card__warning{font-size:12px;line-height:1;cursor:help;flex-shrink:0}.cal-card__assignee{font-size:10px;font-weight:700;padding:1px 7px;border:1.5px solid;border-radius:10px;background:#fff;white-space:nowrap}.cal-card__time{font-size:11px;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.cal-card__title-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.cal-card__title{flex:1;font-weight:600;line-height:1.25;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.cal-card--block .cal-card__title,.cal-card--tray .cal-card__title{font-size:13px;color:var(--color-text-primary)}.cal-card__postcode{font-size:10px;font-weight:600;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:1px 5px;white-space:nowrap}.cal-card__detail{display:flex;align-items:flex-start;gap:4px;font-size:11px;color:var(--color-text-secondary);line-height:1.3}.cal-card__detail-icon{flex-shrink:0;font-size:10px;margin-top:1px}.cal-card__detail-text{word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.cal-card__badges{display:flex;align-items:center;flex-wrap:wrap;gap:5px;margin-top:2px}.cal-card__badge{font-size:10px;color:var(--color-text-secondary);display:inline-flex;align-items:center;gap:3px}.cal-card__badge--hours{color:var(--color-navy);background:#e0f2f1;padding:1px 6px;border-radius:10px;font-weight:600}.cal-card__badge--twoman{color:#b45309;background:#fef3c7;padding:1px 6px;border-radius:10px;font-weight:600}.cal-card__badge--quote{color:#047857;background:#d1fae5;padding:1px 6px;border-radius:10px;font-weight:600}.cal-card__menu-btn{flex-shrink:0;background:#ffffff40;border:none;color:inherit;cursor:pointer;font-size:12px;line-height:1;padding:0 4px;border-radius:3px;opacity:0;transition:opacity var(--transition-fast)}.cal-card:hover .cal-card__menu-btn{opacity:1}.cal-card__menu-btn:hover{background:#fff6}.cal-card__meta,.cal-card__chip-meta{font-size:11px;opacity:.92;display:flex;gap:4px;flex-wrap:wrap}.cal-card__twoman{background:#ffffff40;padding:0 4px;border-radius:3px;font-weight:600}.cal-card__menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;color:var(--color-text-primary);border-radius:var(--radius-sm);box-shadow:0 8px 24px #0000002e;border:1px solid var(--color-border);z-index:20;min-width:160px;padding:4px 0;font-style:normal}.cal-card__menu-header{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);padding:6px 12px 4px;font-weight:600}.cal-card__menu-item{display:block;width:100%;background:none;border:none;padding:7px 12px;cursor:pointer;font-size:13px;color:var(--color-text-primary);text-align:left}.cal-card__menu-item:hover{background:var(--color-bg)}.cal-card__menu-item--current{font-weight:600}.cal-card__menu-current{font-size:11px;color:var(--color-text-muted);font-weight:400}.login-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px;background:linear-gradient(135deg,var(--color-navy),var(--color-navy-light))}.login-screen__brand{display:flex;align-items:center;gap:12px}.login-screen__logo{width:44px;height:44px;font-size:22px}.login-screen__title{font-size:28px;font-weight:800;color:var(--color-white);letter-spacing:-.5px}.no-access{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:420px;padding:28px;background:var(--color-white);border-radius:14px;box-shadow:0 12px 40px #00000040;text-align:center}.no-access__title{font-size:18px;font-weight:700;color:var(--color-text-primary)}.no-access__msg{font-size:14px;color:var(--color-text-secondary);line-height:1.5}.members-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#00000080}.members-modal{position:relative;max-width:100%;max-height:90vh;overflow:auto;border-radius:14px;background:var(--color-white);box-shadow:0 12px 40px #0000004d}.members-modal__close{position:absolute;top:10px;right:12px;z-index:1;width:30px;height:30px;border:none;border-radius:50%;background:#0000000f;font-size:20px;line-height:1;cursor:pointer}.members-modal__close:hover{background:#0000001f}.whatsnew-overlay{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:24px;background:#00000080}.whatsnew-modal{position:relative;width:100%;max-width:440px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;border-radius:16px;background:var(--color-white);box-shadow:0 16px 48px #00000059}.whatsnew-modal__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;background:linear-gradient(135deg,var(--color-navy),#1f3a5f);color:#fff}.whatsnew-modal__kicker{font-size:16px;font-weight:700;letter-spacing:.2px}.whatsnew-modal__close{width:30px;height:30px;border:none;border-radius:50%;background:#ffffff2e;color:#fff;font-size:20px;line-height:1;cursor:pointer}.whatsnew-modal__close:hover{background:#ffffff4d}.whatsnew-modal__body{padding:18px 20px 4px;overflow-y:auto}.whatsnew-entry{margin-bottom:18px}.whatsnew-entry__headline{margin:0 0 8px;font-size:16px;font-weight:700;color:var(--color-text-primary)}.whatsnew-entry__list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.whatsnew-entry__list li{font-size:14px;line-height:1.45;color:var(--color-text-secondary)}.whatsnew-modal__footer{padding:14px 20px 20px;border-top:1px solid var(--color-border)}.whatsnew-modal__cta{width:100%;padding:11px;border:none;border-radius:10px;background:var(--color-navy);color:#fff;font-size:15px;font-weight:600;cursor:pointer}.whatsnew-modal__cta:hover{filter:brightness(1.08)}
