:root{color-scheme:light;--bg: #f3f6fb;--bg-2: #e8eef8;--ink: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-2: #0ea5e9;--panel: #ffffff;--border: #dce5f1;--shadow: 0 12px 34px rgba(15, 23, 42, .08);--card: #ffffff}:root[data-theme=dark]{color-scheme:dark;--bg: #0f1824;--bg-2: #152335;--ink: #e3f1ef;--muted: #9eb4bd;--accent: #14b8a6;--accent-2: #5eead4;--panel: #172838;--border: #2f495d;--shadow: 0 18px 40px rgba(5, 12, 22, .45);--card: #1a2d3f}*{box-sizing:border-box}body{margin:0;font-family:Plus Jakarta Sans,Segoe UI,Inter,sans-serif;color:var(--ink);background:var(--bg);min-height:100vh;font-size:13px;line-height:1.4}body.nav-open{overflow:hidden}:root[data-theme=dark] body{background:var(--bg)}.page{max-width:1200px;margin:0 auto;padding:48px 24px 64px;display:grid;gap:24px}.page.center{min-height:60vh;place-items:center}.loading{font-weight:700}.logo{height:40px}.logo-dark{display:none}:root[data-theme=dark] .logo-light{display:none}:root[data-theme=dark] .logo-dark{display:inline-block}.login-shell{height:100dvh;min-height:100dvh;display:grid;grid-template-columns:minmax(360px,520px) 1fr;grid-template-areas:"panel media";background:radial-gradient(circle at 5% 10%,rgba(56,189,248,.2),transparent 45%),radial-gradient(circle at 95% 5%,rgba(30,64,175,.35),transparent 55%),linear-gradient(145deg,#050912,#0b1220 45%,#111c33);color:#e2e8f0;position:relative;overflow:hidden}.login-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 80% 70%,rgba(59,130,246,.16),transparent 50%)}.login-panel{grid-area:panel;height:100dvh;min-height:100dvh;padding:48px clamp(20px,3vw,48px);display:flex;justify-content:center;align-items:center;border-right:1px solid rgba(148,163,184,.2);background:linear-gradient(175deg,#080d17e6,#09101df0);color:#f8fafc;position:relative;z-index:1;overflow-y:auto}.login-panel:before{content:"";position:absolute;inset:auto auto -130px -120px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.22),transparent 70%);filter:blur(6px)}.login-card{width:min(100%,430px);padding:26px;border-radius:18px;border:1px solid rgba(148,163,184,.28);background:#080e18b8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 24px 60px #02061766;display:grid;gap:18px;position:relative;z-index:1;margin:auto 0}.login-brand{display:flex;align-items:center;justify-content:space-between;gap:10px}.login-brand .logo{height:38px}.login-pill{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#dbeafe;font-weight:700;border:1px solid rgba(147,197,253,.45);background:#1e40af59;border-radius:999px;padding:5px 10px}.login-head h1{margin:0 0 8px;font-size:clamp(32px,4vw,44px);letter-spacing:-.03em;line-height:1.06}.login-head p{margin:0;color:#e2e8f0c7;font-size:14px;line-height:1.5}.login-media{grid-area:media;position:relative;height:100dvh;min-height:100dvh;overflow:hidden}.login-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.03);animation:mediaDrift 24s ease-in-out infinite}.login-media:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#060a122e,#060a12cc)}.media-overlay{position:absolute;inset:auto 0 0 0;padding:32px 40px 38px;display:grid;gap:14px;color:#f8fafc;z-index:1;max-width:620px}.media-overlay .eyebrow{color:#bfdbfeeb;font-weight:700}.login-panel .field{color:#e2e8f0e0;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.login-panel input,.login-panel select{height:44px;padding:10px 12px;border-radius:12px;background:#060c16e6;border:1px solid rgba(148,163,184,.28);color:#f8fafc!important;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease}.login-panel input:focus,.login-panel select:focus{outline:none;border-color:#7dd3fcd9;box-shadow:0 0 0 3px #38bdf838}.login-panel input::placeholder{color:#cbd5e18c}.eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}.media-overlay h2{margin:0;font-size:clamp(24px,3vw,36px);letter-spacing:-.01em;line-height:1.2}.media-overlay p{margin:0;color:#e2e8f0e6;max-width:460px;font-size:15px;line-height:1.55}.media-highlights{display:flex;flex-wrap:wrap;gap:10px}.media-chip{border:1px solid rgba(148,163,184,.4);background:#0f172a73;color:#e2e8f0f2;padding:7px 11px;border-radius:999px;font-size:12px;font-weight:600}.login-form{display:grid;gap:14px;margin-top:4px}.login-caption{margin:4px 0 0;color:#cbd5e1ad;font-size:12px}.field{display:grid;gap:8px;font-weight:600;color:var(--muted)}.field-error input,.field-error select,.field-error textarea{border-color:#b91c1c;box-shadow:0 0 0 2px #b91c1c26}.field-error-text{color:#b91c1c;font-size:11px;font-weight:600}.button-row{display:flex;flex-direction:column;gap:10px;align-items:stretch}.login-panel button{min-height:44px;border-radius:12px;border:1px solid rgba(148,163,184,.28);font-size:14px;font-weight:700}.login-panel button[type=submit]{background:linear-gradient(120deg,#2563eb,#0ea5e9);color:#f8fafc;border-color:#7dd3fc73}.login-panel button[type=submit]:not(:disabled):hover{box-shadow:0 16px 28px #1e40af52}.login-panel button.ghost{background:#0f172a73;border-color:#94a3b873;color:#f8fafc}.login-panel button.ghost:disabled{background:#0f172a59;color:#f8fafcd9}.login-panel button.link{min-height:auto;align-self:flex-start;color:#7dd3fcfa;font-size:13px;font-weight:600}.login-panel .error,.login-panel .info{margin:0;border-radius:10px;padding:10px 12px;font-size:12px}.login-panel .error{background:#b91c1c29;border:1px solid rgba(248,113,113,.32)}.login-panel .info{background:#0e74902b;border:1px solid rgba(56,189,248,.34)}.app-header h1{margin:0 0 8px;font-size:18px}.app-header p{margin:0;color:var(--muted)}.app-root{min-height:100vh;display:grid;grid-template-columns:var(--nav-width, 220px) 1fr;gap:0}.app-root.nav-collapsed{--nav-width: 76px}.side-nav{position:sticky;top:0;height:100vh;padding:10px 8px;display:flex;flex-direction:column;gap:10px;border-right:1px solid #808080;background:#e5e5e5;width:var(--nav-width, 220px);transition:width .3s ease}:root[data-theme=dark] .side-nav{background:var(--panel)}.side-brand{display:flex;align-items:center;justify-content:space-between;gap:12px}.brand-left{display:flex;align-items:center;gap:12px}.side-brand .logo{height:24px}.side-brand .logo-compact{height:20px;width:20px;object-fit:contain}.side-menu{display:grid;gap:4px}.side-group{display:grid;gap:6px}.side-group-title{display:flex;align-items:center;gap:8px;padding:4px 8px 2px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#4b4b4b}.side-group.active .side-group-title{color:#0a246a;font-weight:700}.side-submenu{display:grid;gap:4px;padding-left:18px}.side-subitem{position:relative;border:1px solid #b2b2b2;background:#f0f0f0;color:var(--ink);padding:6px 8px;border-radius:2px;text-align:left;font-weight:600;font-size:12px;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease;display:flex;align-items:center;gap:8px}.side-subitem:hover{background:#e3e3e3}.side-subitem.active{background:#0a246a;color:#fff;border-color:#0a246a}.side-item{position:relative;border:1px solid #a0a0a0;background:#e6e6e6;color:var(--ink);padding:6px 8px;border-radius:2px;text-align:left;font-weight:600;font-size:12px;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease;display:flex;align-items:center;gap:8px;box-shadow:none}.side-item:before{content:none}.side-item:hover{background:#dcdcdc}.side-item.active{background:#0a246a;color:#fff;border-color:#0a246a}.nav-dot{display:none}.nav-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.nav-icon svg{width:18px;height:18px}.nav-label{white-space:nowrap}.side-footer{margin-top:auto;display:grid;gap:10px}.status-chip{align-self:flex-start;padding:6px 12px;border-radius:999px;border:1px solid var(--border);font-size:12px;background:#287fc01f;color:var(--accent-2)}.side-user{display:flex;align-items:center;gap:10px}.side-user small{color:var(--muted);text-transform:capitalize}.side-actions{display:grid;gap:8px;width:100%}.side-actions-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%}.side-action{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:transparent;color:inherit;font-weight:600;cursor:pointer;transition:transform .2s ease,border-color .2s ease,background .2s ease}.side-action svg{width:18px;height:18px;flex-shrink:0}.side-action.icon{justify-content:center;padding:10px}.side-action.collapse svg{transition:transform .2s ease}.side-action:hover{transform:translateY(-1px);border-color:#287fc059;background:#287fc014}.side-action.danger{border-color:#b91c1c59;color:#b91c1c}.side-action.danger:hover{background:#b91c1c1a}.avatar{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;display:grid;place-items:center;font-size:12px}.user-meta{display:grid;gap:2px}.side-nav.collapsed .nav-label,.side-nav.collapsed .user-meta,.side-nav.collapsed .status-chip,.side-nav.collapsed .side-action span{display:none}.side-nav.collapsed .brand-left{justify-content:center;width:100%}.side-nav.collapsed .logo{height:20px}.side-nav.collapsed .side-item{justify-content:center;padding:12px}.side-nav.collapsed .side-group-title{justify-content:center}.side-nav.collapsed .side-submenu{padding-left:0;justify-items:center}.side-nav.collapsed .side-subitem{justify-content:center;padding:10px}.side-nav.collapsed .side-menu{justify-items:center}.side-nav.collapsed .nav-dot{width:18px;height:18px}.side-nav.collapsed .side-footer{align-items:center}.side-nav.collapsed .side-action{justify-content:center;padding:10px}.side-nav.collapsed .side-actions-row{grid-template-columns:1fr;justify-items:center}.side-nav.collapsed .side-item:before{left:50%;width:6px;height:6px;border-radius:50%;transform:translate(-50%,-50%)}.side-nav.collapsed .side-action.collapse svg{transform:rotate(180deg)}.app-main{position:relative;padding:16px 18px 24px}.app-header{position:relative;z-index:1;display:flex;justify-content:space-between;gap:24px;align-items:center;margin-bottom:28px}.header-text{display:grid;gap:8px}.header-text h1{margin:0 0 8px;font-size:clamp(26px,3vw,36px)}.header-text p{margin:0;color:var(--muted)}.mobile-nav-toggle{display:none;width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:#ffffffdb;color:var(--ink);place-items:center;cursor:pointer}:root[data-theme=dark] .mobile-nav-toggle{background:#0c1218e6}.mobile-nav-toggle svg{width:20px;height:20px}.nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c1273;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:9}.nav-overlay.show{opacity:1;pointer-events:auto}.header-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:flex-end}.dashboard{position:relative;z-index:1;display:grid;gap:24px}.account-page{display:grid;gap:20px}.account-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.account-header h2{margin:0 0 6px;font-size:clamp(22px,2.4vw,30px)}.account-header p{margin:0;color:var(--muted)}.account-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.account-card{padding:20px;border-radius:2px;border:1px solid var(--border);background:#f0f0f0;display:grid;gap:16px}:root[data-theme=dark] .account-card{background:var(--panel)}.account-card-header h4{margin:0;font-size:16px}.account-card-header p{margin:6px 0 0;color:var(--muted);font-size:13px}.form-actions{display:flex;justify-content:flex-start;gap:12px}.account-span{grid-column:1 / -1}.passkey-list{display:grid;gap:10px}.passkey-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);background:#ffffff73}:root[data-theme=dark] .passkey-item{background:#0c12188c}@media (max-width: 640px){.passkey-item{flex-direction:column;align-items:flex-start}}.muted{color:var(--muted)}.empty-state{min-height:240px}.clients-page,.service-page{display:grid;gap:12px}.service-placeholder{border:1px dashed #b0b0b0;background:#f8f8f8;padding:12px;font-size:12px}.service-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.service-form.stacked{grid-template-columns:1fr}.service-card{border:1px solid #a0a0a0;background:#fff;padding:10px;display:grid;gap:8px}.service-card h3{margin:0;font-size:13px}.service-prices{display:grid;gap:8px}.total-row{display:flex;justify-content:space-between;padding-top:6px;border-top:1px dotted #c0c0c0;font-size:12px}.service-form .location-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));align-items:start}.modal-actions.compact button{padding:6px 12px;font-size:12px;min-width:96px}.stack{display:grid;gap:2px}.data-table tr.clickable{cursor:pointer}.data-table tr.clickable:hover{background:#f3f6ff}.table-actions{display:flex;gap:6px;flex-wrap:wrap}.serviced-button{background:#b91c1c;border-color:#7f1d1d;color:#fff;box-shadow:0 0 0 1px #7f1d1d40,0 0 12px #dc262659}.serviced-button:not(:disabled):hover{box-shadow:0 0 0 1px #7f1d1d40,0 0 20px #dc262680}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.calendar-actions{display:flex;gap:8px;flex-wrap:wrap}.calendar-modal{width:min(1120px,96vw)}.calendar-modal .calendar-scroll .calendar-weekdays,.calendar-modal .calendar-scroll .calendar-grid{min-width:860px}.calendar-scroll{overflow-x:auto}.calendar-scroll .calendar-weekdays,.calendar-scroll .calendar-grid{min-width:720px}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.calendar-weekdays span{text-align:left;padding:4px 6px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.calendar-cell{border:1px solid #bcbcbc;background:#fff;min-height:110px;padding:6px;display:grid;gap:6px}.calendar-cell.empty{background:#f4f4f4;border-style:dashed}.day-number{font-weight:700;font-size:12px;color:#333}.calendar-items{display:grid;gap:6px}.calendar-item{border:1px solid #c2c2c2;background:#f6f6f6;padding:6px;border-radius:2px;text-align:left;display:grid;gap:2px;font-size:11px;cursor:pointer;width:100%}.calendar-item:hover{background:#e9eefb;border-color:#9fb2e5}.calendar-time{font-weight:700;font-size:11px}.calendar-client{font-weight:600}.clients-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.clients-header-actions{display:flex;gap:8px;flex-wrap:wrap}.parts-used-list{display:grid;gap:8px}.history-tag-list{display:flex;flex-wrap:wrap;gap:8px}.history-parts-list{display:grid;gap:10px}.history-part-item{display:grid;gap:4px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#ffffff9e}:root[data-theme=dark] .history-part-item{background:#111c30b8}.history-signature-wrap{padding:10px;border:1px dashed #94a3b8;border-radius:12px;background:#fff}:root[data-theme=dark] .history-signature-wrap{background:#0f172a}.history-signature-image{display:block;width:100%;max-width:540px;max-height:220px;object-fit:contain}.part-row{display:grid;grid-template-columns:minmax(220px,1.3fr) minmax(80px,.4fr) minmax(180px,1fr) auto;gap:8px;align-items:end}.photo-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.photo-preview{border:1px solid #b0b0b0;padding:6px;background:#fff;display:grid;gap:6px}.photo-preview img{width:100%;height:120px;object-fit:cover;border:1px solid #d0d0d0}.signature-wrap{display:grid;gap:8px}.signature-canvas{width:100%;max-width:540px;border:2px dashed #9ca3af;background:#fff;border-radius:2px;touch-action:none}.signature-actions{display:flex;justify-content:flex-start}.clients-header h2{margin:0 0 4px;font-size:16px}.clients-header p{margin:0;color:var(--muted)}.clients-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:8px;border:1px solid #a0a0a0;background:#f0f0f0}.clients-filters input[type=search]{flex:1;min-width:220px}.table-wrap{border:1px solid #a0a0a0;background:#fff}.configurable-table{display:grid;gap:8px}.configurable-table-toolbar{position:relative;display:flex;justify-content:flex-end}.columns-panel{position:absolute;right:0;top:calc(100% + 6px);width:min(320px,90vw);padding:10px;border:1px solid var(--border);background:var(--card);z-index:5;display:grid;gap:8px;box-shadow:0 8px 24px #0f172a33}.columns-panel-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.columns-list{display:grid;gap:6px;max-height:320px;overflow:auto;padding-right:4px}.column-item{display:grid;grid-template-columns:auto auto 1fr;gap:8px;align-items:center;border:1px solid var(--border);background:#ffffff73;padding:6px 8px;cursor:move}:root[data-theme=dark] .column-item{background:#0c12188c}.drag-handle{color:var(--muted);letter-spacing:-2px;font-size:12px}.data-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:12px}.data-table th,.data-table td{border:1px solid #b0b0b0;padding:6px 8px;text-align:left}.data-table th{background:#dcdcdc;font-weight:700;position:relative;vertical-align:middle}.data-table th.sortable{cursor:pointer}.th-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.sort-indicator{color:var(--muted);font-size:11px}.col-resizer{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:col-resize;-webkit-user-select:none;user-select:none}.col-resizer:hover{background:#0a246a40}.cell-content{display:block}.cell-ellipsis{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table tbody tr:nth-child(2n){background:#f6f6f6}.data-table tbody tr:hover{background:#e9f1ff}.data-table tbody tr.clickable{cursor:pointer}.data-table td:before{content:none}.row-actions{display:flex;flex-wrap:wrap;gap:6px}.client-detail{display:grid;gap:12px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.detail-card{border:1px solid #a0a0a0;background:#fff;padding:10px;display:grid;gap:6px}.detail-card.full{grid-column:1 / -1}.detail-card h4{margin:0 0 6px;font-size:13px}.detail-row{display:flex;justify-content:space-between;gap:12px;font-size:12px;border-bottom:1px dotted #c0c0c0;padding:4px 0}.detail-row span{color:var(--muted)}.detail-list{display:grid;gap:8px}.detail-item{display:flex;justify-content:space-between;gap:12px;font-size:12px;padding:6px;background:#f6f6f6;border:1px solid #d0d0d0}.detail-item a{margin-left:8px}.detail-empty{padding:16px;font-size:12px}.audit-list{display:grid;gap:8px}.audit-item{display:flex;justify-content:space-between;gap:12px;font-size:12px;padding:6px;background:#f6f6f6;border:1px solid #d0d0d0}@media (max-width: 900px){.app-root{grid-template-columns:1fr}.app-main{padding:14px}.clients-header{flex-direction:column;align-items:flex-start}.clients-filters{flex-direction:column;align-items:stretch}.clients-filters input[type=search]{width:100%}.table-wrap{border:none;background:transparent}.configurable-table-toolbar{justify-content:flex-start}.columns-panel{left:0;right:auto}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tr{border:1px solid #b0b0b0;margin-bottom:8px;background:#fff}.data-table td{border:none;border-bottom:1px dotted #c0c0c0;display:grid;grid-template-columns:120px 1fr;gap:8px;padding:6px 10px}.data-table td:last-child{border-bottom:none}.data-table td:before{content:attr(data-label);font-weight:700;color:#333}.row-actions{gap:4px}.location-row{grid-template-columns:1fr}.pricing-toggle{display:grid;grid-template-columns:1fr}.toggle-pill{width:100%;min-width:0}.part-row,.form-grid,.detail-grid{grid-template-columns:1fr}.detail-row{flex-direction:column;align-items:flex-start}}@media (max-width: 600px){.modal{width:100vw;height:100vh;max-height:100vh;border-radius:0}.modal-header{position:sticky;top:0;z-index:2}.modal-actions{position:sticky;bottom:0;background:#f0f0f0;padding:12px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:grid;place-items:center;z-index:50}.modal{width:min(860px,92vw);max-height:90vh;background:#f0f0f0;border:1px solid #7f7f7f;overflow:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:#dcdcdc;border-bottom:1px solid #7f7f7f}.modal-header h3{margin:0;font-size:14px}.icon-close{border:1px solid #7f1d1d;background:linear-gradient(135deg,#b91c1c,#ef4444);color:#fff;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:10px;line-height:0;cursor:pointer;box-shadow:0 10px 24px #b91c1c47;transition:transform .16s ease,box-shadow .16s ease,filter .16s ease}.icon-close svg{width:16px;height:16px;display:block;flex:0 0 auto}.icon-close:hover{filter:brightness(1.06);box-shadow:0 12px 26px #b91c1c59;transform:translateY(-1px)}.icon-close:active{transform:translateY(0);filter:brightness(.95)}.modal-body{padding:12px;display:grid;gap:12px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px 12px}.field.full{grid-column:1 / -1}.location-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin-bottom:8px}.radio-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}.pricing-toggle{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.toggle-pill{min-width:170px;min-height:40px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--ink);font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;text-align:center;box-shadow:none}:root[data-theme=dark] .toggle-pill{background:#1a2b3d;border-color:#35536b;color:#dbe8f8}.toggle-pill.active{background:linear-gradient(125deg,var(--app-primary, #0f766e),var(--app-primary-strong, #14b8a6));border-color:#14b8a680;color:#f8fafc;box-shadow:0 10px 20px #0f766e38}.option-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px;margin-top:6px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:6px;border-top:1px solid #b0b0b0}.hero-panel{padding:14px;border-radius:2px;border:1px solid #a0a0a0;background:#f0f0f0;box-shadow:none;display:grid;gap:24px;grid-template-columns:minmax(240px,1.2fr) minmax(240px,.8fr)}:root[data-theme=dark] .hero-panel{background:var(--panel)}.hero-content h2{margin:10px 0;font-size:16px}.hero-content p{margin:0;color:var(--muted)}.hero-actions{margin-top:16px;display:flex;gap:12px;flex-wrap:wrap}.pill{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:#287fc01f;color:var(--accent-2);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.hero-metrics{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.metric-card{padding:10px;border-radius:2px;border:1px solid #a0a0a0;background:#fff;display:grid;gap:6px}:root[data-theme=dark] .metric-card{background:var(--panel)}.metric-card span{font-size:12px;color:var(--muted)}.metric-card strong{font-size:16px}.metric-card small{color:var(--muted)}.grid-two{display:grid;grid-template-columns:minmax(260px,1.2fr) minmax(240px,.8fr);gap:20px}.panel.glass{background:var(--panel)}:root[data-theme=dark] .panel.glass{background:var(--panel)}.panel-title{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.tag{padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;color:var(--muted)}.activity-list{display:grid;gap:16px}.activity-item{display:grid;grid-template-columns:18px 1fr;gap:12px;align-items:start}.activity-item strong{display:block;margin-bottom:4px}.activity-item p{margin:0;color:var(--muted)}.dot{width:10px;height:10px;margin-top:6px;border-radius:50%;background:linear-gradient(120deg,var(--accent),var(--accent-2))}.security-grid{display:grid;gap:12px;margin-bottom:16px}.security-card{padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#ffffffd9;display:grid;gap:6px}:root[data-theme=dark] .security-card{background:#0c1218e0}.security-card span{font-size:12px;color:var(--muted)}.security-card strong{font-size:18px}.topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px}.brand{display:flex;align-items:center;gap:16px}.brand h1{margin:0 0 4px;font-size:22px}.brand p{margin:0;font-size:13px;color:var(--muted)}.menu{display:flex;gap:12px;justify-content:center}.menu-item{border:1px solid transparent;background:transparent;color:var(--ink);padding:8px 14px;border-radius:999px;font-weight:600;cursor:pointer}.menu-item:hover{border-color:var(--border);background:#fff3}.top-actions{display:flex;gap:12px;align-items:center}.icon-button{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:#fffc;display:flex;align-items:center;justify-content:center;color:var(--ink);cursor:pointer}:root[data-theme=dark] .icon-button{background:#10161dcc}.icon-button svg{width:18px;height:18px;display:block}.panel{padding:16px 18px;border-radius:2px;background:var(--panel);border:1px solid #a0a0a0;box-shadow:none}.panel h2{margin-top:0}.form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;align-items:end}.form.vertical{grid-template-columns:1fr}label{display:grid;gap:8px;font-weight:600;color:var(--muted)}input,select,textarea{padding:6px 8px;border-radius:2px;border:1px solid #7f9db9;font-size:13px;font-family:inherit;background:#fff;color:var(--ink)}:root[data-theme=dark] input,:root[data-theme=dark] select,:root[data-theme=dark] textarea{background:#142232}button{padding:4px 10px;border-radius:2px;border:1px solid #7f7f7f;font-weight:600;background:#e6e6e6;color:#000;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:none}button.ghost{background:#e6e6e6;border:1px solid #7f7f7f;color:#000;box-shadow:none}:root[data-theme=dark] button{background:#14b8a6;color:#05201d;border-color:#14b8a6}:root[data-theme=dark] button.ghost{background:transparent;border-color:#35536b;color:#d6e7ef}button.link{padding:0;background:none;border:none;box-shadow:none;color:var(--accent-2);font-weight:600}button.link:hover{text-decoration:underline;transform:none;box-shadow:none}button:disabled{opacity:.6;cursor:not-allowed}button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 14px 26px #0f172233}.error{margin-top:16px;color:#b42318;font-weight:600}.info{margin-top:12px;color:#0f766e;font-weight:600}.success{padding:18px;border-radius:14px;background:#0f766e1f}.account-panel{position:fixed;top:0;right:0;width:min(520px,100%);height:100vh;background:#ffffffeb;border-left:1px solid var(--border);box-shadow:-20px 0 40px #00000040;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transform:translate(100%);transition:transform .3s ease;display:flex;flex-direction:column;z-index:10}:root[data-theme=dark] .account-panel{background:#0c1218f5}.account-panel.open{transform:translate(0)}.panel-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.panel-body{padding:20px 24px;overflow-y:auto;display:grid;gap:24px}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.switch{position:relative;display:inline-block;width:52px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.2s;border-radius:999px}.slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%}.switch input:checked+.slider{background-color:var(--accent-2)}.switch input:checked+.slider:before{transform:translate(24px)}.user-list{display:grid;gap:16px}.user-card{border:1px solid var(--border);border-radius:14px;padding:16px;background:var(--card)}.user-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.user-actions{display:flex;gap:12px;margin-top:12px;grid-column:1 / -1}.checkbox{display:flex;align-items:center;gap:8px;font-weight:600}.app-root{--app-primary: #0f766e;--app-primary-strong: #14b8a6;--app-accent: #0f766e;background:radial-gradient(circle at 14% 0%,rgba(20,184,166,.1),transparent 35%),radial-gradient(circle at 100% 0%,rgba(45,212,191,.1),transparent 34%),var(--bg)}:root[data-theme=dark] .app-root{--app-primary: #0f766e;--app-primary-strong: #14b8a6;--app-accent: #5eead4}.app-main{padding:24px 28px 32px}.app-header{margin-bottom:24px}.app-alert-stack{position:fixed;top:18px;right:18px;z-index:80;display:grid;gap:10px;width:min(460px,calc(100vw - 36px))}.app-alert{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-radius:12px;border:1px solid transparent;padding:11px 12px;box-shadow:0 18px 36px #0f172a33;font-weight:600;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.app-alert span{flex:1 1 auto}.app-alert-error{background:#fef2f2f7;border-color:#f87171a6;color:#b91c1c}.app-alert-info{background:#ecfdf5fa;border-color:#2dd4bf8c;color:#0f766e}.app-alert-close{width:24px;min-height:24px;height:24px;padding:0;border-radius:8px;border:1px solid transparent;background:transparent;box-shadow:none;font-size:17px;line-height:1;display:inline-flex;align-items:center;justify-content:center;color:inherit}.app-alert-close:hover{transform:none;box-shadow:none;background:#0f172a14}:root[data-theme=dark] .app-alert-error{background:#450a0aeb;border-color:#f8717180;color:#fecaca}:root[data-theme=dark] .app-alert-info{background:#064e3beb;border-color:#2dd4bf73;color:#a7f3d0}.header-text h1{letter-spacing:-.02em}.side-nav{border-right:1px solid var(--border);background:linear-gradient(180deg,#ffffffed,#f8fafcf2);box-shadow:inset -1px 0 #94a3b814;padding:14px 10px}:root[data-theme=dark] .side-nav{background:linear-gradient(180deg,#162332f7,#121f2df5)}.side-group-title{color:var(--muted);font-size:10px;letter-spacing:.14em;padding:4px 10px 1px}.side-item,.side-subitem{border-radius:12px;border:1px solid transparent;background:transparent;font-size:13px;padding:9px 10px}.side-item:hover,.side-subitem:hover{background:#14b8a617;border-color:#0f766e38}.side-item.active,.side-subitem.active{background:linear-gradient(130deg,var(--app-primary),var(--app-primary-strong));border-color:#0f766e73;color:#f8fafc;box-shadow:0 10px 20px #0f766e42}:root[data-theme=dark] .side-item.active,:root[data-theme=dark] .side-subitem.active{border-color:#5eead473;box-shadow:0 10px 20px #0f766e59}.side-action{border-radius:12px}.status-chip{background:#0f766e1f;border-color:#0f766e47;color:#0f766e;font-weight:700}:root[data-theme=dark] .status-chip{color:#5eead4}.panel,.account-card,.detail-card,.service-card,.clients-filters,.hero-panel,.metric-card,.table-wrap,.user-card,.passkey-item,.security-card,.calendar-cell,.photo-preview{border-radius:16px;border-color:var(--border);background:var(--panel);box-shadow:0 14px 30px #0f172a1a}.clients-filters{padding:12px}.hero-panel{padding:18px}.metric-card{border-radius:14px;padding:12px}.service-card,.detail-card,.account-card{padding:14px}.calendar-item{border-radius:10px;border-color:var(--border);background:#f7faffe6}:root[data-theme=dark] .calendar-item{background:#182838e0}.table-wrap{overflow:hidden}.data-table{font-size:13px}.data-table th,.data-table td{border-color:var(--border);padding:10px 12px}.data-table th{background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#64748b}:root[data-theme=dark] .data-table th{background:#213448;color:#bdd0da}.data-table tbody tr:nth-child(2n){background:#f8fafcc2}:root[data-theme=dark] .data-table tbody tr:nth-child(2n){background:#1828388f}.data-table tbody tr:hover{background:#14b8a617}:root[data-theme=dark] .data-table tbody tr:hover{background:#2dd4bf24}.app-root input,.app-root select,.app-root textarea{border-radius:12px;border:1px solid var(--border);background:#fff;min-height:40px;padding:8px 12px}.app-root textarea{min-height:92px}:root[data-theme=dark] .app-root input,:root[data-theme=dark] .app-root select,:root[data-theme=dark] .app-root textarea{background:#1a2b3d;border-color:#35536b}.app-root input:focus,.app-root select:focus,.app-root textarea:focus{outline:none;border-color:#0f766e8c;box-shadow:0 0 0 3px #14b8a633}:root[data-theme=dark] .app-root input:focus,:root[data-theme=dark] .app-root select:focus,:root[data-theme=dark] .app-root textarea:focus{border-color:#5eead49e;box-shadow:0 0 0 3px #2dd4bf3d}.app-root button{min-height:38px;border-radius:12px;border:1px solid var(--app-primary);background:linear-gradient(135deg,var(--app-primary),var(--app-primary-strong));color:#f8fafc;font-weight:700;padding:8px 14px;box-shadow:0 10px 22px #0f766e33}.app-root .toggle-pill{min-height:40px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:var(--ink);box-shadow:none}:root[data-theme=dark] .app-root .toggle-pill{background:#1e3145;border-color:#35536b;color:#dbe8f8}.app-root .toggle-pill:not(.active):hover{background:#eef7f6;border-color:#0f766e6b;transform:translateY(-1px);box-shadow:0 8px 16px #0f766e1f}:root[data-theme=dark] .app-root .toggle-pill:not(.active):hover{background:#264058;border-color:#5eead475}.app-root .toggle-pill.active{border-color:#14b8a699;background:linear-gradient(125deg,var(--app-primary),var(--app-primary-strong));color:#f8fafc;box-shadow:0 10px 20px #0f766e42}.app-root button.ghost{background:#f8fafc;color:var(--ink);border-color:#cbd5e1;box-shadow:none}:root[data-theme=dark] .app-root button.ghost{background:#1e3145;color:#dbe8f8;border-color:#35536b}.app-root button.link{background:none;border:none;color:var(--app-accent);min-height:auto;box-shadow:none;padding:0}.app-root .serviced-button{background:linear-gradient(125deg,#b91c1c,#ef4444);border-color:#7f1d1db3}.app-root .icon-close{min-height:34px;width:34px;height:34px;padding:0;border-radius:10px;border:1px solid #7f1d1d;background:linear-gradient(135deg,#b91c1c,#ef4444);color:#fff;box-shadow:0 10px 24px #b91c1c47}.app-root .icon-close:hover{border-color:#7f1d1d;background:linear-gradient(135deg,#991b1b,#dc2626);box-shadow:0 12px 26px #b91c1c59;transform:translateY(-1px)}.app-root .icon-close:active{transform:translateY(0);filter:brightness(.95)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a6b}.modal{border-radius:18px;border-color:var(--border);background:var(--panel);box-shadow:0 26px 70px #0f172a40}.modal-header{background:transparent;border-bottom:1px solid var(--border);padding:14px 18px}.modal-body{padding:16px 18px}.modal-actions{border-top:1px solid var(--border)}.service-schedule-modal{width:min(1260px,96vw);max-height:92vh}.service-schedule-form{grid-template-columns:minmax(260px,1fr) minmax(260px,1fr) minmax(320px,1.1fr);gap:14px;align-items:start}.service-schedule-form>.error,.service-schedule-form>.info{grid-column:1 / -1;margin:0}.service-schedule-form .service-card{height:100%}.service-section-client{grid-column:1;grid-row:1}.service-section-type{grid-column:2;grid-row:1}.service-section-pricing{grid-column:3;grid-row:1 / span 2}.service-section-pricing .service-prices{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.service-section-pricing .total-row{grid-column:1 / -1}.service-section-schedule{grid-column:1 / span 2;grid-row:2;display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px 12px;align-items:end}.service-section-schedule h3,.service-section-actions{grid-column:1 / -1}.service-page .configurable-table .table-wrap{overflow-x:auto;overflow-y:hidden}.service-page .configurable-table .data-table{width:max-content;min-width:100%}@media (max-width: 1280px){.service-schedule-modal{width:min(1120px,97vw)}.service-schedule-form{grid-template-columns:repeat(2,minmax(260px,1fr))}.service-section-client{grid-column:1;grid-row:1}.service-section-type{grid-column:2;grid-row:1}.service-section-pricing{grid-column:1 / -1;grid-row:2}.service-section-schedule{grid-column:1 / -1;grid-row:3}}@media (max-width: 980px){.service-schedule-modal{width:min(100vw,98vw)}.service-schedule-form{grid-template-columns:1fr;gap:12px}.service-section-client,.service-section-type,.service-section-pricing,.service-section-schedule{grid-column:auto;grid-row:auto}.service-section-schedule{grid-template-columns:1fr}}@media (max-width: 1100px){.app-alert-stack{top:10px;right:10px;width:min(420px,calc(100vw - 20px))}.app-root{grid-template-columns:1fr}.side-nav{position:fixed;inset:0 auto 0 0;height:100vh;width:min(82vw,320px);transform:translate(-105%);transition:transform .25s ease;z-index:10}.app-root.nav-open .side-nav{transform:translate(0)}.side-menu,.side-footer{width:100%}.app-main{padding:24px}.mobile-nav-toggle{display:grid}.side-nav.collapsed{width:min(82vw,320px)}.side-nav.collapsed .nav-label,.side-nav.collapsed .user-meta,.side-nav.collapsed .status-chip,.side-nav.collapsed .side-action span{display:inline-flex}.side-nav.collapsed .side-item,.side-nav.collapsed .side-subitem,.side-nav.collapsed .side-group-title,.side-nav.collapsed .side-action,.side-nav.collapsed .brand-left{justify-content:flex-start}}@media (max-width: 900px){.service-page .configurable-table .table-wrap{overflow:visible}.service-page .configurable-table .data-table{width:100%;min-width:0}}@media (max-width: 900px){.login-shell{grid-template-columns:1fr;grid-template-areas:"panel";height:100dvh;min-height:100dvh}.login-panel{padding:28px 20px;height:100dvh;min-height:100dvh;border-right:none;border-bottom:none;overflow-y:auto}.login-card{width:min(100%,460px);padding:22px 18px;border-radius:14px}.login-media{display:none}.topbar{grid-template-columns:1fr;justify-items:start}.menu{justify-content:flex-start;flex-wrap:wrap}.hero-panel,.grid-two{grid-template-columns:1fr}.app-header{flex-direction:column;align-items:flex-start}.header-actions{justify-content:flex-start}}@media (max-width: 720px){.login-panel{padding:18px 14px;align-items:flex-start;justify-content:flex-start}.login-card{width:100%;padding:18px 14px;gap:14px}.login-brand .logo{height:30px}.login-pill{font-size:9px;padding:4px 8px}.login-head h1{font-size:clamp(26px,8vw,34px);margin-bottom:6px}.login-panel input,.login-panel select,.login-panel button{min-height:40px;height:40px}.row{grid-template-columns:1fr}.row.header{display:none}}@media (max-height: 760px) and (min-width: 901px){.login-panel{padding-top:22px;padding-bottom:22px}.login-card{padding:18px;gap:12px}.login-head h1{font-size:clamp(26px,3vw,36px)}.login-form{gap:10px}.login-caption,.login-pill{display:none}}@media (max-height: 860px){.media-highlights{display:none}}@media (prefers-reduced-motion: reduce){.side-nav,.side-item,.login-panel:before,.login-media img{transition:none;animation:none}}@keyframes floatIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes glowShift{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(-20px,30px,0) scale(1.1)}to{transform:translateZ(0) scale(1)}}@keyframes mediaDrift{0%,to{transform:scale(1.04) translateY(0)}50%{transform:scale(1.08) translateY(-2%)}}
