:root{--bg: #f6f7fb;--bg-tint: #eef0fb;--card: #ffffff;--border: #e9eaf2;--border-strong: #dcdef0;--text: #1d2130;--muted: #6b7280;--primary: #6366f1;--primary-dark: #4f46e5;--accent: #8b5cf6;--gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--sidebar: linear-gradient(180deg, #4f46e5 0%, #6d28d9 100%);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #0ea5e9;--critical: #c2410c;--vip: #b45309;--radius: 14px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(20, 23, 40, .06), 0 1px 3px rgba(20, 23, 40, .05);--shadow-md: 0 4px 16px rgba(40, 30, 90, .08);--shadow-lg: 0 12px 40px rgba(40, 30, 90, .16);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text)}a{color:var(--primary-dark);text-decoration:none}a:hover{text-decoration:underline}button{background:var(--gradient);color:#fff;border:none;border-radius:var(--radius-sm);padding:.55rem 1rem;cursor:pointer;font-size:.9rem;font-weight:600;font-family:inherit;box-shadow:0 1px 2px #4f46e540;transition:transform .1s ease,box-shadow .12s ease,filter .12s ease}button:hover{filter:brightness(1.05);box-shadow:0 4px 14px #6366f159;transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none;filter:none}button.small{padding:.3rem .7rem;font-size:.8rem;background:var(--bg-tint);color:var(--primary-dark);box-shadow:none}button.small:hover{background:#e2e5fb;box-shadow:none}button.danger{background:var(--danger);box-shadow:0 1px 2px #ef44444d}button.danger:hover{background:#dc2626;box-shadow:0 4px 14px #ef444459}button.small.danger{background:#fee2e2;color:#b91c1c}button.small.danger:hover{background:#fecaca}button.critical{background:var(--critical);border:1px solid #7c2d12;font-weight:700}button.critical:hover{background:#9a3412}button.secondary{background:#eef1f6;color:var(--text);box-shadow:none}button.secondary:hover{background:#e3e7ee;box-shadow:none}input,select,textarea{padding:.5rem .7rem;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;width:100%;background:#fff;color:var(--text);transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f12e}textarea{resize:vertical}select{cursor:pointer}.muted{color:var(--muted)}.error{color:var(--danger)}.info{color:#0a7d32}.customer-line{margin:.25rem 0 .85rem;font-size:1.05rem}.odoo-link{display:inline-flex;align-items:center;gap:.15rem;font-size:.76rem;font-weight:600;color:#714b67;background:#f3eef2;border:1px solid #e4d8e1;border-radius:999px;padding:.08rem .5rem;white-space:nowrap}.odoo-link:hover{background:#ead9e6;text-decoration:none}.odoo-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin:.25rem 0 1rem}.odoo-actions a{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;font-weight:600;color:#714b67;background:#f3eef2;border:1px solid #e4d8e1;border-radius:var(--radius-sm);padding:.4rem .8rem}.odoo-actions a:hover{background:#ead9e6;text-decoration:none}.center{display:grid;place-items:center;height:100vh}.app{display:flex;min-height:100vh}.sidebar{width:252px;flex-shrink:0;background:var(--sidebar);color:#fff;display:flex;flex-direction:column;padding:1rem .7rem .85rem;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.05rem;padding:.4rem .75rem 1rem;letter-spacing:-.01em}.brand-mark{color:#c7d2fe;font-size:1.1rem}.sidebar-nav{display:flex;flex-direction:column;gap:.12rem;flex:1;overflow-y:auto}.nav-section{font-size:.68rem;text-transform:uppercase;letter-spacing:.09em;opacity:.55;padding:1rem .85rem .4rem}.nav-link{display:flex;align-items:center;gap:.7rem;padding:.55rem .8rem;border-radius:var(--radius-sm);color:#ffffffd1;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .12s,color .12s}.nav-link:hover{background:#ffffff1a;color:#fff;text-decoration:none}.nav-link .nav-icon{color:var(--nav-accent, #c7d2fe);flex-shrink:0}.nav-link.active{background:#ffffff2e;color:#fff;font-weight:600}.sidebar-foot{border-top:1px solid rgba(255,255,255,.16);padding-top:.75rem;margin-top:.5rem}.sidebar-user{display:flex;align-items:center;gap:.6rem;padding:.25rem .6rem .7rem}.avatar{width:34px;height:34px;border-radius:50%;background:#ffffff38;display:grid;place-items:center;font-weight:700;font-size:.95rem;flex-shrink:0}.sidebar-user-text{display:flex;flex-direction:column;line-height:1.2;overflow:hidden}.sidebar-user-text strong{font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-text small{font-size:.72rem;opacity:.65;text-transform:capitalize}.logout-btn{width:100%;background:#ffffff24;box-shadow:none;font-weight:600}.logout-btn:hover{background:#ffffff3d;box-shadow:none;transform:none}.main-wrap{flex:1;min-width:0;display:flex;flex-direction:column}.content{padding:1.85rem 2.1rem;max-width:1200px;margin:0 auto;width:100%}.content section>h2{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .4rem}.login-wrap{display:grid;place-items:center;min-height:100vh;background:var(--sidebar);padding:1rem}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}.login-card{width:340px;display:flex;flex-direction:column;gap:.8rem;box-shadow:var(--shadow-lg);border:none;padding:2rem}.login-card h1{margin:0;font-size:1.4rem;font-weight:800;letter-spacing:-.02em}.login-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:var(--muted);font-weight:500}.toolbar{display:flex;gap:.5rem;margin:1rem 0;max-width:520px;flex-wrap:wrap}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem}.stat{display:flex;flex-direction:column;gap:.3rem;padding:1.1rem 1.2rem;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--gradient)}.stat-label{color:var(--muted);font-size:.82rem;font-weight:500}.stat-value{font-size:1.7rem;font-weight:800;letter-spacing:-.02em}.stat-hint{font-size:.78rem;color:var(--muted)}a.stat-link{text-decoration:none;color:var(--text);transition:box-shadow .13s,transform .13s}a.stat-link:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}.stat-warn:before{background:var(--warning)}.stat-warn .stat-hint{color:var(--vip);font-weight:600}.stat-alert:before{background:var(--danger)}.stat-alert .stat-hint{color:var(--danger);font-weight:600}.dash-lists{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem;margin-top:1rem}.dash-list{list-style:none;margin:0 0 .75rem;padding:0}.dash-list li{padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.9rem}.dash-list li:last-child{border-bottom:none}table.data{width:100%;border-collapse:separate;border-spacing:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}table.data th,table.data td{text-align:left;padding:.7rem .85rem;border-bottom:1px solid var(--border);font-size:.9rem}table.data th{background:#fbfbfe;color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}table.data tbody tr{transition:background .1s}table.data tbody tr:hover{background:#fafaff}table.data tbody tr:last-child td{border-bottom:none}table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}table.data tfoot .sum-row td{border-top:2px solid var(--border-strong);border-bottom:none;font-weight:700;background:#fbfbfe}table.data td.table-state{text-align:center;padding:1.25rem;color:var(--muted)}.badge{display:inline-block;padding:.15rem .6rem;border-radius:999px;background:var(--bg-tint);color:var(--primary-dark);font-size:.74rem;font-weight:600}.badge.vip{background:#fef3c7;color:var(--vip)}.badge.state-open{background:#dbeafe;color:#1e40af}.badge.state-done{background:#dcfce7;color:#166534}.badge.state-cancelled{background:#fee2e2;color:#991b1b}.badge.state-exported{background:#ede9fe;color:#5b21b6}.badge.maint-overdue{background:#fee2e2;color:#991b1b}.badge.maint-due_soon{background:#fef3c7;color:#92400e}.badge.maint-not_due{background:#dcfce7;color:#166534}.badge.maint-none{background:#e5e7eb;color:#4b5563}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem;flex-wrap:wrap}.tab{background:none;color:var(--muted);box-shadow:none;border-radius:0;border-bottom:2px solid transparent;padding:.6rem .95rem;font-weight:600}.tab:hover{background:none;color:var(--text);box-shadow:none;transform:none}.tab.active{color:var(--primary-dark);border-bottom-color:var(--primary)}.card-head{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.5rem}.card-head h3{margin:0}.tag-list{display:inline-flex;flex-wrap:wrap;gap:.25rem}.recipient-list{list-style:none;margin:.35rem 0 .5rem;padding:0}.recipient-list li{padding:.3rem 0;font-size:.9rem;display:flex;align-items:center;gap:.4rem}.device-list{list-style:none;margin:0 0 .5rem;padding:0}.device-line{padding:.5rem 0;border-bottom:1px solid var(--border)}.device-line:last-child{border-bottom:none}.device-line-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-weight:600}.device-note{margin-top:.35rem;font-size:.85rem}.cal-nav{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.cal-label{font-weight:700;font-size:1.05rem;margin-left:.3rem}.agenda-day{margin-bottom:.6rem;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.agenda-head{display:flex;justify-content:space-between;align-items:center;padding:.5rem .85rem;font-weight:600}.agenda-head.past{background:#f1f2f6;color:var(--muted)}.agenda-head.today{background:var(--bg-tint);color:var(--primary-dark)}.agenda-head.future{background:#fff}.agenda-slots{background:#fff;padding:.15rem .6rem}.agenda-slot{display:flex;align-items:center;gap:.6rem;padding:.45rem .2rem;border-bottom:1px solid var(--border);font-size:.9rem}.agenda-slot:last-child{border-bottom:none}.agenda-time{font-variant-numeric:tabular-nums;font-weight:700;min-width:46px}.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.cal-col{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;min-height:170px;overflow:hidden}.cal-col-head{padding:.45rem .4rem;text-align:center;font-size:.78rem;font-weight:600;border-bottom:1px solid var(--border)}.cal-col-head.past{background:#f6f7fb;color:var(--muted)}.cal-col-head.today{background:var(--bg-tint);color:var(--primary-dark)}.cal-col-body{display:flex;flex-direction:column;gap:.3rem;padding:.4rem}.cal-month{display:grid;grid-template-columns:repeat(7,1fr);gap:.4rem}.cal-weekday{text-align:center;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;padding:.2rem 0}.cal-cell{border:1px solid var(--border);border-radius:8px;background:#fff;min-height:96px;padding:.3rem;display:flex;flex-direction:column;gap:.2rem}.cal-cell.out{background:#f8f9fc}.cal-cell.today{border-color:var(--primary);box-shadow:inset 0 0 0 1px var(--primary)}.cal-daynum{font-size:.78rem;font-weight:700;color:var(--muted)}.cal-cell.out .cal-daynum{opacity:.5}.slot-chip{display:block;font-size:.74rem;padding:.12rem .4rem;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge.slot-free,.slot-free{background:#dbeafe;color:#1e40af}.badge.slot-requested,.slot-requested{background:#fef3c7;color:#92400e}.badge.slot-confirmed,.slot-confirmed{background:#dcfce7;color:#166534}.badge.slot-cancelled,.slot-cancelled{background:#f1f2f6;color:#9aa0ad}.badge.slot-order,.slot-order{background:#ede9fe;color:#5b21b6}a.slot-chip{text-decoration:none}a.slot-chip:hover{filter:brightness(.97);text-decoration:none}.section{margin-bottom:1.25rem}.section h3{margin-top:0;font-size:1.05rem;font-weight:700}.section h4{margin:1rem 0 .4rem;color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}.order-head{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:.5rem 0 .75rem}.order-head h2{margin:0;font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.btn-row{display:flex;gap:.5rem;flex-wrap:wrap}.form-row{margin-bottom:.5rem}.form-row label,.section label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.25rem;font-weight:500}.cell-num{width:90px;padding:.3rem .45rem}.dt-field{margin-bottom:.6rem}.dt-row{display:flex;align-items:center;gap:.4rem}.dt-row input{width:auto}.icon-btn{padding:.4rem .55rem;font-size:1rem;line-height:1;background:var(--bg-tint);color:var(--text);box-shadow:none}.icon-btn:hover{background:#e2e5fb;box-shadow:none;transform:none}.icon-btn.danger{background:#fee2e2;color:#b91c1c}.icon-btn.danger:hover{background:#fecaca}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem 1rem;max-width:540px}.form-grid label.check{display:flex;flex-direction:row;align-items:center;gap:.45rem}label.check{display:inline-flex;flex-direction:row;align-items:center;gap:.45rem}label.check input{width:auto}.picker{position:relative}.picker-selected{display:flex;align-items:center;gap:.75rem}.picker-list{list-style:none;margin:.25rem 0;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;max-width:480px;box-shadow:var(--shadow-md);overflow:hidden}.picker-list li button{width:100%;text-align:left;background:none;color:var(--text);border-radius:0;box-shadow:none;font-weight:500}.picker-list li button:hover{background:#f3f4ff;box-shadow:none;transform:none}.toast-stack{position:fixed;bottom:1.25rem;right:1.25rem;display:flex;flex-direction:column;gap:.5rem;z-index:1100}.toast{padding:.6rem 1rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;color:#fff;box-shadow:var(--shadow-lg);animation:toast-in .16s ease-out}.toast-success{background:#0a7d32}.toast-error{background:var(--danger)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#17143280;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:1rem;z-index:1000}.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:460px;padding:1.5rem}.modal h3{margin:0 0 .6rem;font-size:1.12rem;font-weight:700}.modal-body{font-size:.92rem;line-height:1.5;margin-bottom:1.25rem}.modal-body .muted{display:block;margin-top:.5rem;font-size:.85rem}.modal-actions{justify-content:flex-end}.modal-critical{border-top:4px solid var(--critical)}.modal-danger{border-top:4px solid var(--danger)}@media (max-width: 820px){.app{flex-direction:column}.sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;flex-wrap:wrap;padding:.6rem .8rem}.sidebar-brand{padding:.2rem .5rem}.sidebar-nav{flex-direction:row;flex-wrap:wrap;flex:1 1 100%;gap:.25rem;order:3}.nav-section{display:none}.sidebar-foot{border-top:none;margin:0;padding:0;display:flex;align-items:center;gap:.6rem}.sidebar-user{padding:0}.content{padding:1.25rem}}
