:root{color-scheme:light;--bg: #f3f6fb;--surface: #ffffff;--surface-muted: #f8faff;--surface-strong: #eef4ff;--border: #dce5f2;--text: #132238;--text-muted: #4f6280;--primary: #1664e8;--primary-strong: #0f4ebf;--danger: #be2242;--success: #17875f;--warning: #b86700;--radius: 14px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0 10px 30px rgba(13, 29, 52, .08)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:radial-gradient(1200px 500px at 50% -100px,#dbe8ff 0%,var(--bg) 50%,var(--bg) 100%);color:var(--text)}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:10;border-bottom:1px solid var(--border);background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-header-inner{max-width:1160px;margin:0 auto;padding:.85rem 1.1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{display:flex;flex-direction:column;gap:.1rem}.brand h1{margin:0;font-size:1.15rem;letter-spacing:.01em}.brand p{margin:0;color:var(--text-muted);font-size:.82rem}.app-nav{display:flex;align-items:center;gap:.55rem}.app-nav a{border:1px solid transparent;border-radius:999px;padding:.38rem .72rem;font-weight:600;color:var(--text-muted)}.app-nav a:hover{text-decoration:none;color:var(--primary);border-color:#c9daf8;background:#f2f7ff}.app-content{max-width:1160px;margin:0 auto;padding:1.1rem}.page-stack{display:grid;gap:1rem}.page-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.8rem}.page-header h2{margin:0;font-size:1.3rem}.page-header p{margin:.2rem 0 0;color:var(--text-muted);font-size:.92rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-sm)}.card h3,.card h4{margin-top:0}.card-subtle{background:var(--surface-muted)}.grid-2{display:grid;gap:1rem;grid-template-columns:repeat(2,minmax(0,1fr))}.stack{display:grid;gap:.72rem}label{display:grid;gap:.34rem;font-size:.88rem;color:var(--text-muted);font-weight:600}input,textarea,select{border:1px solid #c6d6ee;border-radius:10px;padding:.56rem .65rem;font-size:.95rem;color:var(--text);background:#fff}input:focus,textarea:focus,select:focus{outline:none;border-color:#5d98ff;box-shadow:0 0 0 3px #1664e824}button{background:var(--primary);color:#fff;border:0;border-radius:10px;padding:.58rem .88rem;font-size:.92rem;font-weight:600;cursor:pointer;transition:.12s ease-in-out}button:hover:not(:disabled){background:var(--primary-strong)}button:disabled{opacity:.62;cursor:not-allowed}.button-secondary{background:#edf4ff;color:#1d4f9a;border:1px solid #cadcf7}.button-secondary:hover:not(:disabled){background:#deebff}.button-danger{background:#ffeaf0;color:#9e1735;border:1px solid #f4c5d4}.pill{border-radius:999px;display:inline-flex;align-items:center;padding:.2rem .56rem;font-size:.76rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.pill-success{color:#0f6e4e;background:#e5f8f0}.pill-warning{color:#8b5205;background:#fff3de}.pill-neutral{color:#33445d;background:#eaf0f8}.error{color:var(--danger);font-size:.9rem}.empty{color:var(--text-muted);padding:1rem;border:1px dashed #c7d6eb;border-radius:10px;background:#f7faff}.booking-item,.attachment-item,.invoice-item{border:1px solid var(--border);border-radius:12px;padding:.82rem;background:#fbfdff}.booking-item:hover,.invoice-item:hover{box-shadow:var(--shadow-sm)}.booking-title{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.4rem}.booking-meta{color:var(--text-muted);font-size:.88rem;margin-bottom:.18rem}.diary-toolbar{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.diary-toolbar input[type=date]{height:36px}.planner-board{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow-x:auto}.planner-grid{display:grid;min-width:100%}.planner-corner{border-bottom:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface-strong)}.planner-header{display:flex;align-items:center;gap:.45rem;padding:0 .7rem;font-weight:700;font-size:.92rem;border-bottom:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface-strong);color:var(--text)}.planner-header-unassigned{color:var(--text-muted);font-style:italic}.planner-column-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.planner-time-cell{border-right:1px solid var(--border);border-bottom:1px dashed #e1e9f4;padding:0 .45rem;font-size:.78rem;color:var(--text-muted);display:flex;align-items:flex-start;justify-content:flex-end;background:var(--surface-muted)}.planner-time-cell-major{border-bottom-style:solid;font-weight:600}.planner-column{border-right:1px solid var(--border);background:repeating-linear-gradient(to bottom,transparent 0,transparent 27px,#eef3fb 27px,#eef3fb 28px,transparent 28px,transparent 55px,#dce5f2 55px,#dce5f2 56px)}.planner-column-cells{width:100%;height:100%}.planner-cell{background:transparent;border:0;border-radius:0;padding:0;margin:0;cursor:pointer;width:100%;height:100%;transition:background .1s ease}.planner-cell:hover{background:#1664e80f}.planner-cell-active{background:#1664e81f}.planner-booking{position:absolute;left:4px;right:4px;background:#fff;border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:8px;padding:.32rem .45rem;box-shadow:var(--shadow-sm);font-size:.82rem;cursor:grab;overflow:hidden;display:flex;flex-direction:column;gap:.15rem;z-index:1}.planner-booking:active{cursor:grabbing}.planner-booking-paid{background:#f0faf5}.planner-booking-in_progress{background:#fff7ea}.planner-booking-cancelled{opacity:.55;text-decoration:line-through}.planner-booking-title{display:flex;align-items:center;justify-content:space-between;gap:.4rem}.planner-booking-title strong{font-size:.86rem}.planner-booking-meta{color:var(--text-muted);font-size:.78rem}.planner-booking-reason{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planner-booking-actions{display:flex;gap:.3rem;align-items:center;margin-top:auto}.planner-booking-actions a{font-size:.78rem;font-weight:600}.planner-booking-nudge{padding:.18rem .4rem;font-size:.74rem}.inline-create-panel{border:1px dashed #c9d8ef;border-radius:10px;background:#f8fbff;padding:.65rem;display:grid;gap:.5rem}.attachment-row{display:flex;align-items:center;justify-content:space-between;gap:.7rem;margin-top:.34rem}.share-text{margin-top:.42rem;font-size:.84rem;color:#2c466a;word-break:break-all}.file-label{display:grid;gap:.44rem;margin-bottom:.75rem}.invoice-editor{border:1px solid var(--border);border-radius:12px;background:var(--surface-muted);padding:.75rem;margin-bottom:.75rem}.invoice-editor-line{border:1px dashed #cfdcf1;border-radius:10px;padding:.56rem;background:#fff}.invoice-line-grid{display:grid;gap:.5rem;grid-template-columns:1.5fr .5fr .7fr auto auto;align-items:center}.checkbox-label{display:inline-flex;align-items:center;gap:.35rem;color:var(--text-muted);font-weight:600}.template-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.62rem}.line-preview-total{margin-top:.3rem;font-size:.85rem;color:var(--text-muted)}.item-editor-row{display:grid;grid-template-columns:1fr auto;gap:.5rem}.item-editor-grid{display:grid;grid-template-columns:1fr 140px auto;gap:.5rem}.drop-zone{border:1px dashed #b7c9e5;border-radius:10px;padding:.45rem .55rem;color:var(--text-muted);font-size:.83rem;text-align:center;background:#f5f9ff}.drop-zone-active{border-color:#5e96f5;background:#eaf2ff;color:#204f94}.invoice-line{border-bottom:1px dashed #d9e4f4;padding-bottom:.35rem;margin-bottom:.35rem}.stat-grid{display:grid;gap:.7rem;grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card{border:1px solid var(--border);border-radius:10px;background:#fff;padding:.7rem}.stat-label{margin:0 0 .2rem;color:var(--text-muted);font-size:.82rem}.stat-value{margin:0;font-size:1.05rem;font-weight:700}pre{overflow:auto;background:#f4f8fe;border:1px solid var(--border);border-radius:10px;padding:.7rem}@media(max-width:960px){.grid-2,.stat-grid,.invoice-line-grid,.item-editor-grid{grid-template-columns:1fr}.planner-board{border-radius:10px}}.toast-stack{position:fixed;top:1.2rem;right:1.2rem;display:flex;flex-direction:column;gap:.6rem;width:min(360px,calc(100vw - 2rem));z-index:9999;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:.7rem;padding:.75rem .85rem;border-radius:12px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);border-left:4px solid var(--primary)}.toast-info{border-left-color:var(--primary)}.toast-success{border-left-color:var(--success)}.toast-warning{border-left-color:var(--warning)}.toast-error{border-left-color:var(--danger)}.toast-body{flex:1;display:flex;flex-direction:column;gap:.2rem}.toast-title{font-size:.92rem;color:var(--text)}.toast-description{margin:0;font-size:.85rem;color:var(--text-muted);white-space:pre-wrap}.toast-close{border:0;background:transparent;color:var(--text-muted);font-size:.85rem;cursor:pointer;padding:.1rem .35rem;border-radius:6px}.toast-close:hover{background:var(--surface-strong);color:var(--text)}.upload-progress{display:flex;flex-direction:column;gap:.4rem;padding:.55rem .7rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-muted);font-size:.85rem}.upload-progress-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.upload-progress-bar{height:6px;border-radius:999px;background:var(--surface-strong);overflow:hidden}.upload-progress-bar-fill{height:100%;background:var(--primary);transition:width .15s ease-out}.upload-progress-failed .upload-progress-bar-fill{background:var(--danger)}.upload-progress-actions{display:flex;gap:.4rem}.branding-row{display:flex;gap:1rem;align-items:center;margin:.6rem 0 1rem}.branding-logo-preview{width:96px;height:96px;border-radius:14px;border:1px dashed var(--border);background:var(--surface-muted);display:flex;align-items:center;justify-content:center;overflow:hidden}.branding-logo-preview img{max-width:88px;max-height:88px;object-fit:contain}.branding-logo-empty{font-size:.78rem;color:var(--text-muted);text-align:center;padding:.4rem}.branding-logo-actions{display:flex;gap:.5rem;flex-wrap:wrap}.branding-color-row{display:flex;align-items:center;gap:.45rem}.branding-color-row input[type=color]{width:44px;height:36px;padding:0;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer}.branding-color-row input[type=text]{width:110px;font-family:ui-monospace,SFMono-Regular,monospace}.settings-subhead{margin:.8rem 0 .3rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.notifications-head{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem;margin-bottom:.4rem}.notification-row{border:1px solid var(--border);border-radius:12px;padding:.7rem .85rem;background:var(--surface-muted)}.notification-row.notification-failed{border-color:#f4c0cc;background:#fff1f4}.notification-row.notification-skipped{border-color:var(--border);background:var(--surface);opacity:.85}.notification-row-head{display:flex;gap:.5rem;align-items:center;font-size:.8rem;color:var(--text-muted);margin-bottom:.3rem}.notification-channel{font-weight:700;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em;color:var(--primary);background:var(--surface-strong);padding:.1rem .5rem;border-radius:999px}.notification-status{padding:.1rem .5rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase}.notification-status-sent{background:#d4ebde;color:#0c6e44}.notification-status-failed{background:#fbecef;color:#9e1735}.notification-status-skipped{background:var(--surface-strong);color:var(--text-muted)}.notification-status-queued{background:#fff3d6;color:#79520a}.notification-time{margin-left:auto;font-variant-numeric:tabular-nums}.notification-row-body{display:flex;flex-direction:column;gap:.25rem;font-size:.88rem}.notification-label{display:inline-block;width:60px;color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.notification-value{color:var(--text)}.notification-body{margin:.35rem 0 0;color:var(--text);white-space:pre-wrap;font-size:.86rem}.notification-meta{font-size:.75rem;color:var(--text-muted)}.notification-meta.notification-error{color:var(--danger)}.dashboard-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.9rem;margin-bottom:.4rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.25rem;box-shadow:var(--shadow-sm)}.kpi-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.kpi-value{font-size:1.7rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text)}.kpi-sub{font-size:.82rem;color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:.9rem}.dashboard-list{display:flex;flex-direction:column;gap:.4rem}.dashboard-row{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:10px;background:var(--surface-muted);border:1px solid transparent;text-decoration:none;color:inherit}.dashboard-row-link:hover{border-color:var(--border);background:var(--surface-strong)}.dashboard-row-time{display:flex;flex-direction:column;align-items:flex-start;min-width:70px;font-variant-numeric:tabular-nums}.dashboard-row-main{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.dashboard-row-title{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-row-sub{font-size:.82rem;color:var(--text-muted)}.dashboard-amount{font-weight:700;font-variant-numeric:tabular-nums}.dashboard-pill{padding:.18rem .6rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.dashboard-pill.tone-booked{background:var(--surface-strong);color:var(--primary)}.dashboard-pill.tone-progress{background:#fff3d6;color:#79520a}.dashboard-pill.tone-complete{background:#d4ebde;color:#0c6e44}.dashboard-pill.tone-paid{background:#cfeadb;color:#0c6e44}.dashboard-pill.tone-muted{background:var(--surface-strong);color:var(--text-muted)}
