:root{--primary:#2f6bff;--primary-dark:#2456d6;--primary-soft:#edf4ff;--primary-tint:#cfe0ff;--primary-shadow:rgba(47,107,255,.24);--app-bg:#f5f6fb;--surface:#fff;--surface-muted:#f8f9ff;--border:#e5e7f2;--text-main:#1f2544;--text-muted:#8a90a8;--input-bg:#fff;--input-border:#d9deef;--table-head-bg:#fbfbfe;--active-bg:#edf4ff;--badge-bg:#eff1f8}
*{box-sizing:border-box}
body{margin:0;background:var(--app-bg);font-family:Inter,Arial,sans-serif;color:#38415d}
body.theme-purple{--primary:#696cff;--primary-dark:#5b5fef;--primary-soft:#eeefff;--primary-tint:#cbcfff;--primary-shadow:rgba(105,108,255,.28);--app-bg:#f6f6ff}
body.theme-blue{--primary:#2f6bff;--primary-dark:#2456d6;--primary-soft:#edf4ff;--primary-tint:#cfe0ff;--primary-shadow:rgba(47,107,255,.24);--app-bg:#f5f6fb}
body.theme-green{--primary:#22a06b;--primary-dark:#158458;--primary-soft:#ecfaf3;--primary-tint:#cdeedd;--primary-shadow:rgba(34,160,107,.24);--app-bg:#f3faf6}
body.theme-teal{--primary:#0f9fb7;--primary-dark:#0b7f93;--primary-soft:#ebfbfd;--primary-tint:#c8f0f5;--primary-shadow:rgba(15,159,183,.24);--app-bg:#f2fafc}
body.theme-indigo{--primary:#5562ea;--primary-dark:#3f4ad2;--primary-soft:#eff1ff;--primary-tint:#d5d9ff;--primary-shadow:rgba(85,98,234,.25);--app-bg:#f4f5ff}
body.theme-slate{--primary:#4f5d75;--primary-dark:#364154;--primary-soft:#f2f5f8;--primary-tint:#dde3ee;--primary-shadow:rgba(79,93,117,.22);--app-bg:#f4f6fa}
.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;background:var(--app-bg)}.sidebar-shell{min-height:100vh;background:var(--surface);border-right:1px solid var(--border)}.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;padding:18px 14px;display:grid;gap:12px}.page-shell{min-width:0;min-height:100vh;display:flex;flex-direction:column}.topbar{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 28px;background:color-mix(in srgb,var(--app-bg) 90%,#fff);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.content-area{flex:1;min-width:0;padding:28px;background:var(--app-bg)}
.topbar-main,.topbar-actions{display:flex;align-items:center;gap:12px}.topbar-title{font-size:22px;font-weight:700;color:var(--text-main)}.sidebar-toggle{display:none}
.brand-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:20px;background:var(--surface-muted);border:1px solid var(--border)}.brand-logo{width:34px;height:34px;border-radius:12px;background:var(--primary);color:#fff;display:grid;place-items:center}.brand-copy span{font-size:12px;color:var(--text-muted)}
.nav-item strong{font-size:16px;font-weight:700}
.nav-title{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#a0a5bc;padding:0 8px}.nav-list{display:grid;gap:6px}.nav-item{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;border:1px solid transparent;text-decoration:none;color:#6d748d;font-weight:700}.nav-item.active{background:var(--active-bg);border-color:var(--primary-tint);color:var(--primary-dark)}.nav-icon{width:22px;height:22px;display:grid;place-items:center;font-size:19px;color:var(--text-main)}.nav-copy span{font-size:11px;color:var(--text-muted)}
.chip,.content-card-counter{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--primary-tint);background:var(--primary-soft);color:var(--primary-dark);font-size:12px;font-weight:700}.chip-dot{width:8px;height:8px;border-radius:99px;background:currentColor}
.profile-menu{position:relative}.profile-trigger{display:inline-flex;align-items:center;gap:10px;height:46px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface)}.user-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:var(--primary-tint);color:var(--primary-dark);font-weight:800}.profile-panel{position:absolute;top:calc(100% + 10px);right:0;width:280px;padding:12px;border-radius:18px;border:1px solid var(--border);background:var(--surface);display:none;box-shadow:0 10px 32px rgba(47,43,61,.12)}.profile-menu.is-open .profile-panel{display:block}.profile-panel__head{padding:10px 12px;border-bottom:1px solid var(--border)}.profile-panel__head span{font-size:12px;color:var(--text-muted)}.profile-panel__body{padding-top:8px;display:grid;gap:6px}.profile-link{display:block;width:100%;padding:10px 12px;border-radius:14px;border:0;background:transparent;text-align:left;text-decoration:none;color:#38415d}.profile-link-danger{color:#d92d20}
.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.page-title{margin:0;color:var(--text-main);font-size:34px}.page-description{margin:10px 0 0;color:var(--text-muted)}.page-actions{display:flex;gap:10px;align-items:center}
.content-card,.card,.panel{background:var(--surface);border:1px solid var(--border);border-radius:24px}.content-card-header,.card-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.content-card-title,.card-title{margin:0;color:var(--text-main)}.content-card-description{margin:6px 0 0;color:var(--text-muted)}.card-body{padding:16px}
.table-wrapper,.table-shell{padding:8px;border-radius:22px;background:var(--surface);border:1px solid var(--border)}.table-scroll{overflow:auto}.data-table,.table{width:100%;border-collapse:separate;border-spacing:0}.data-table th,.data-table td,.table th,.table td{padding:14px 12px;border-bottom:1px solid #edf0f7}.data-table th,.table th{text-transform:uppercase;font-size:11px;letter-spacing:.14em;color:#9aa1b8;background:var(--table-head-bg)}
.actions-cell{text-align:right}.inline-actions{display:inline-flex;justify-content:flex-end;gap:8px;align-items:center;flex-wrap:nowrap}
.badge{display:inline-flex;padding:7px 11px;border-radius:999px;font-size:12px;font-weight:800;background:var(--badge-bg)}.badge-success{background:#edfbe3;color:#3d8f13}.badge-danger{background:#fff1ef;color:#d92d20}.badge-muted{background:var(--badge-bg);color:#6d748d}.badge-warning{background:#fff7ed;color:#c2410c}.badge-alert{background:#fef9c3;color:#a16207}
.btn{display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);font-weight:700}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-secondary{background:var(--surface-muted)}.btn-danger{background:#fff1ef;border-color:#ffd7d0;color:#d92d20}.btn-light{background:#f8f8fc}.btn-sm{height:36px;padding:0 12px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.form-control,.form-select,textarea,input,select{min-height:46px;padding:11px 14px;border:1px solid var(--input-border);border-radius:12px;background:var(--input-bg)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%, transparent)}
.theme-layout{display:grid;grid-template-columns:2fr 1.2fr;gap:20px}.palette-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.palette-card{display:grid;gap:10px;padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface-muted);cursor:pointer}.palette-card.selected{background:var(--surface);border-color:var(--primary-tint);box-shadow:0 6px 16px var(--primary-shadow)}.palette-card input{display:none}.palette-card__top span{font-size:12px;color:var(--text-muted)}.palette-swatches{display:flex;gap:8px}.palette-swatches span{display:block;width:36px;height:36px;border-radius:12px;border:1px solid rgba(0,0,0,.05)}
.swatch-purple-1{background:#696cff}.swatch-purple-2{background:#a9b0ff}.swatch-purple-3{background:#e6e9ff}.swatch-blue-1{background:#2f6bff}.swatch-blue-2{background:#9fc1ff}.swatch-blue-3{background:#e6f0ff}.swatch-green-1{background:#22a06b}.swatch-green-2{background:#9ddbc0}.swatch-green-3{background:#e5f6ee}.swatch-teal-1{background:#0f9fb7}.swatch-teal-2{background:#9cdbe5}.swatch-teal-3{background:#e7f8fb}.swatch-indigo-1{background:#5562ea}.swatch-indigo-2{background:#b4bbf8}.swatch-indigo-3{background:#eceeff}.swatch-slate-1{background:#4f5d75}.swatch-slate-2{background:#bdc5d5}.swatch-slate-3{background:#edf0f5}
.preview-box{padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface-muted);margin-bottom:12px}.preview-box span{display:block;font-size:12px;color:var(--text-muted)}.preview-box strong{display:block;color:var(--text-main);margin-top:6px}
.sidebar-overlay{display:none}
@media (max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar-shell{position:fixed;inset:0 auto 0 0;width:280px;transform:translateX(-100%);transition:transform .2s ease;z-index:40}.app-shell.sidebar-open .sidebar-shell{transform:translateX(0)}.sidebar-toggle{display:inline-flex}.content-area{padding:20px}.sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.45);opacity:0;pointer-events:none}.app-shell.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto}.theme-layout,.palette-grid,.form-grid{grid-template-columns:1fr}}

.profile-panel__head strong{display:block;color:var(--text-main)} .profile-panel__head span{display:block;margin-top:4px}
.login-body{min-height:100vh;display:grid;place-items:center;background:linear-gradient(180deg,var(--app-bg),#eef2ff)}.login-shell{width:min(460px,94vw)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:28px;box-shadow:0 14px 30px rgba(31,37,68,.08)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:12px}.login-brand h1{margin:0;color:var(--text-main);font-size:26px}.login-brand p{margin:2px 0 0;color:var(--text-muted)}.login-sub{color:var(--text-muted);margin-top:0}.remember-line{display:flex;align-items:center;gap:8px;margin:14px 0;color:var(--text-muted)}.login-btn{width:100%;height:46px}

.form-card{max-width:620px}.form-stack{display:grid;gap:14px;max-width:100%}.form-group{display:grid;gap:8px;width:100%}.form-label{display:block;font-weight:700;color:var(--text-main)}.form-control{width:100%}.form-check{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:14px}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.full-width{width:100%}.auth-card{width:min(460px,94vw);background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:28px;box-shadow:0 14px 30px rgba(31,37,68,.08)}.auth-form{margin-top:10px}.auth-form .form-actions{justify-content:stretch}

.modal-backdrop[hidden]{display:none !important}.modal-backdrop{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,.45)}.modal-card{position:relative;z-index:1;width:min(760px,calc(100vw - 32px));max-height:calc(100vh - 48px);overflow:auto;background:#fff;border-radius:20px;padding:0}


.flow-modal[hidden]{display:none !important}
.flow-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}
.flow-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.48)}
.flow-modal-panel{position:relative;z-index:1;width:min(820px,calc(100vw - 48px));max-height:calc(100vh - 48px);overflow:auto;background:#fff;border-radius:20px;padding:0;box-shadow:0 24px 80px rgba(15,23,42,.22)}
.flow-modal-sm .flow-modal-panel{width:min(460px,calc(100vw - 48px))}
.flow-modal-header,.flow-modal-body,.flow-modal-footer{padding:20px 24px}
.flow-modal-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.flow-modal-header h2{margin:0;color:var(--text-main)}
.flow-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;border-top:1px solid var(--border)}
.flow-modal-footer form{margin:0}
body.modal-open{overflow:hidden}
.location-map-modal{z-index:1085}
.location-map-modal .flow-modal-backdrop{z-index:1080}
.location-map-modal .flow-modal-panel{z-index:1085}

.appointment-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.appointment-card--wide{grid-column:1/-1}
@media (max-width:1024px){.appointment-grid{grid-template-columns:1fr}}

.action-btn{width:34px;height:34px;padding:0;border-radius:10px;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;background:#fff;color:#4b556f}
.action-btn .material-icon{width:18px;height:18px}
.action-btn--view{background:#eef4ff;color:#2858d6;border-color:#d7e4ff}
.action-btn--edit{background:#f1efff;color:#5345d9;border-color:#ddd8ff}
.action-btn--danger{background:#fff1ef;color:#d92d20;border-color:#ffd7d0}
.action-btn--success{background:#edfbe3;color:#2d8a0f;border-color:#d6f4c8}
.action-btn--warning{background:#fff7ed;color:#b45309;border-color:#fed7aa}

.toast-root{position:fixed;top:24px;right:24px;z-index:1200;display:flex;flex-direction:column;gap:12px;width:min(380px,calc(100vw - 32px));pointer-events:none}
.toast{pointer-events:auto;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;background:#fff;border:1px solid var(--border);box-shadow:0 18px 50px rgba(15,23,42,.18);color:var(--text-main);animation:toast-in 180ms ease-out}
.toast-content{display:flex;flex-direction:column;gap:4px}.toast-content strong{font-size:13px;font-weight:800}.toast-content span{font-size:13px;color:var(--text-muted);line-height:1.4}
.toast-close{border:0;background:transparent;cursor:pointer;font-size:18px;line-height:1;color:var(--text-muted)}
.toast-success{border-left:4px solid #16a34a}.toast-error{border-left:4px solid #dc2626}.toast-warning{border-left:4px solid #f59e0b}.toast-info{border-left:4px solid var(--primary)}
@keyframes toast-in{from{opacity:0;transform:translateY(-8px) translateX(12px)}to{opacity:1;transform:translateY(0) translateX(0)}}
@keyframes toast-out{from{opacity:1;transform:translateY(0) translateX(0)}to{opacity:0;transform:translateY(-8px) translateX(12px)}}
.toast.is-leaving{animation:toast-out 160ms ease-in forwards}

.snackbar-root{position:fixed;right:24px;bottom:24px;z-index:1200;pointer-events:none}
.snackbar{pointer-events:auto;display:flex;align-items:center;gap:12px;background:#111827;color:#fff;padding:12px 14px;border-radius:12px;box-shadow:0 18px 50px rgba(15,23,42,.25);min-width:240px;max-width:min(420px,calc(100vw - 32px));animation:toast-in 180ms ease-out}
.snackbar-action{border:0;background:transparent;color:#93c5fd;font-weight:700;cursor:pointer}
.snackbar.is-leaving{animation:toast-out 160ms ease-in forwards}


.form-control.is-invalid,
.form-select.is-invalid,
textarea.is-invalid {
  border-color: #dc2626 !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.10);
}
.field-error { margin-top: 6px; font-size: 12px; font-weight: 600; color: #dc2626; }
.field-help { margin-top: 6px; font-size: 12px; color: var(--text-muted,#6b7280); }

.table-responsive,.table-wrapper{width:100%;overflow-x:auto}.actions-cell{text-align:right}.table-actions,.actions-cell .inline-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap;min-width:max-content}.table-actions form,.actions-cell form{display:inline-flex;margin:0}

.installation-layout{display:grid;gap:16px}
.installation-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 16px}
.kv-label{display:block;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#8b93ad;margin-bottom:2px}
.kv-value{display:block;font-size:14px;color:#2b334f;line-height:1.3}
.kv-inline{font-size:13px;color:#2b334f;line-height:1.35;margin-bottom:4px}
.formula-box{padding:10px 12px;border:1px solid var(--border);background:var(--surface-muted);border-radius:12px;font-size:13px;color:#38415d;margin-bottom:10px}
.calc-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 16px}
.compact-errors{margin:8px 0 0;padding-left:18px}
.compact-table-card .card-body{padding:10px 12px}
.compact-table th,.compact-table td{padding:9px 10px}
@media (max-width:1024px){.installation-grid-2,.kv-grid,.calc-grid{grid-template-columns:1fr}}

.form-field-error {
  margin-top: .35rem;
  font-size: .8125rem;
  color: #dc2626;
  font-weight: 600;
}

.is-invalid,
input.is-invalid,
select.is-invalid,
textarea.is-invalid {
  border-color: #dc2626 !important;
}

.invalid-feedback {
  display: block;
  margin-top: .35rem;
  font-size: .8125rem;
  color: #dc2626;
  font-weight: 600;
}

.action-buttons{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}
.action-buttons form{display:inline-flex;margin:0}
.action-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #d6dbe3;border-radius:8px;background:#fff;color:#475569;text-decoration:none;cursor:pointer;padding:0}
.action-btn:hover{filter:brightness(.97);text-decoration:none}
.action-btn svg{width:16px;height:16px}
.action-btn--view{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}
.action-btn--edit{color:#4338ca;background:#eef2ff;border-color:#c7d2fe}
.action-btn--delete,.action-btn--danger{color:#b91c1c;background:#fef2f2;border-color:#fecaca}
.action-btn--success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}
.action-btn--warning{color:#b45309;background:#fffbeb;border-color:#fde68a}
.action-btn--neutral{color:#334155;background:#f8fafc;border-color:#e2e8f0}
.action-btn--schedule{color:#5b21b6;background:#f5f3ff;border-color:#ddd6fe}


.action-buttons{display:inline-flex !important;flex-direction:row !important;align-items:center !important;justify-content:flex-end !important;gap:6px;flex-wrap:nowrap !important;white-space:nowrap !important}
.actions-cell,.table-actions{text-align:right !important;white-space:nowrap !important}
.actions-cell .action-buttons,.table-actions.action-buttons{width:100%;justify-content:flex-end !important}
.action-buttons form{display:inline-flex !important;margin:0 !important;padding:0 !important}
.material-icon{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem;flex:0 0 1rem}.material-icon svg{width:100%;height:100%;display:block}.pagination .material-icon{width:14px;height:14px}
.table-toolbar{display:grid;grid-template-columns:2fr repeat(3,minmax(150px,1fr)) auto;gap:10px;align-items:end;margin-bottom:10px}@media (max-width:1100px){.table-toolbar{grid-template-columns:1fr 1fr}}
.flow-pagination{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}.flow-pagination__meta{font-size:12px;color:#6d748d}.flow-pagination__list{display:flex;list-style:none;gap:6px;padding:0;margin:0}.flow-pagination__list li span,.flow-pagination__list li a{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border:1px solid #d9deef;border-radius:8px;background:#fff;color:#374151;text-decoration:none}.flow-pagination__list li.is-active span{background:#edf4ff;border-color:#bfd4ff;color:#1d4ed8;font-weight:700}.flow-pagination__list li.is-disabled span{opacity:.45}
.table-columns-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:6px 0 10px 0}.table-options-footer{display:flex;justify-content:space-between;align-items:center;gap:8px}.table-options-footer-right{display:flex;gap:8px;align-items:center}

.table-order-list{display:flex;flex-direction:column;gap:8px;margin:8px 0 12px}
.table-order-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid #dbe0f0;border-radius:8px;background:#fff}
.table-order-actions{display:flex;gap:6px}


.flow-th-resizable{position:relative;padding-right:14px !important}
.th-sort-link{display:inline-flex;align-items:center;gap:6px;color:inherit;text-decoration:none;position:relative;z-index:1}
.col-resizer{position:absolute;top:4px;bottom:4px;right:0;width:12px;cursor:col-resize;z-index:3}
.col-resizer::after{content:'';position:absolute;top:2px;bottom:2px;left:50%;width:1px;background:#bcc6dc;transform:translateX(-50%)}
.col-resizer:hover::after,.col-resizer.is-active::after{width:2px;background:#4b6cb7}
.col-resizing,.col-resizing *{cursor:col-resize !important;user-select:none}


.selection-cell{width:42px;min-width:42px;max-width:42px;text-align:center;}
.bulk-actions-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;margin:0 0 10px;background:#f8f3f3;border:1px solid #e6d1d1;border-radius:10px;}
.bulk-actions-bar .btn{margin-left:auto;}
