@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--teal: #0B9E9E;--teal-dark: #088a8a;--teal-light: #f0fafa;--teal-mid: #d0eded;--navy: #0D2535;--gold: #C9922A;--bg: #f6f8f9;--surface: #ffffff;--surface2: #f9fafb;--surface3: #f1f4f6;--border: #e8ecee;--border2: #d8e0e4;--ink: #111827;--ink2: #374151;--ink3: #6b7280;--ink4: #9ca3af;--green: #059669;--green-bg: #ecfdf5;--green-border:#a7f3d0;--amber: #d97706;--amber-bg: #fffbeb;--amber-border:#fde68a;--red: #dc2626;--red-bg: #fef2f2;--red-border: #fecaca;--blue: #2563eb;--blue-bg: #eff6ff;--blue-border: #bfdbfe;--sidebar-w: 252px;--radius-xs: 4px;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--font-ui: "Plus Jakarta Sans", -apple-system, sans-serif;--font-body: "Inter", -apple-system, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 4px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 8px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 24px rgba(0,0,0,.08), 0 4px 8px rgba(0,0,0,.04);--sidebar-bg: #0D2535;--sidebar-text:#ffffff;--sidebar-sub: rgba(255,255,255,.45);--sidebar-item-hover: rgba(255,255,255,.06);--sidebar-item-active: rgba(11,158,158,.18);--sidebar-border: rgba(255,255,255,.07)}[data-theme=dark]{--bg: #0f1117;--surface: #1a1d23;--surface2: #21252d;--surface3: #282c36;--border: #2d3139;--border2: #363b45;--ink: #f9fafb;--ink2: #d1d5db;--ink3: #9ca3af;--ink4: #6b7280;--green-bg: rgba(5,150,105,.12);--green-border:rgba(167,243,208,.2);--amber-bg: rgba(217,119,6,.12);--amber-border:rgba(253,230,138,.2);--red-bg: rgba(220,38,38,.12);--red-border: rgba(254,202,202,.2);--blue-bg: rgba(37,99,235,.12);--blue-border: rgba(191,219,254,.2);--teal-light: rgba(11,158,158,.1);--teal-mid: rgba(11,158,158,.2);--shadow-xs: 0 1px 2px rgba(0,0,0,.3);--shadow-sm: 0 1px 4px rgba(0,0,0,.3);--shadow: 0 4px 8px rgba(0,0,0,.4);--shadow-lg: 0 12px 24px rgba(0,0,0,.5);--sidebar-bg: #0d1117;--sidebar-border: rgba(255,255,255,.05);--sidebar-item-hover: rgba(255,255,255,.04)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-text-size-adjust:100%}body{height:100%;font-family:var(--font-body);font-size:14px;line-height:1.6;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;overscroll-behavior:none;transition:background .2s,color .2s}#root{height:100%;display:flex;flex-direction:column}img,svg{display:block;max-width:100%}button{cursor:pointer;font-family:var(--font-ui)}input,select,textarea{font-family:var(--font-body)}a{color:var(--teal);text-decoration:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-family:var(--font-ui);font-size:13px;font-weight:600;line-height:1;transition:all .15s ease;white-space:nowrap;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;letter-spacing:-.01em}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--teal);color:#fff;border-color:var(--teal)}.btn-primary:hover:not(:disabled){background:var(--teal-dark);border-color:var(--teal-dark)}.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}.btn-navy:hover:not(:disabled){background:#162d3d}.btn-ghost{background:transparent;color:var(--ink2);border-color:var(--border);background:var(--surface)}.btn-ghost:hover:not(:disabled){background:var(--surface3);color:var(--ink);border-color:var(--border2)}.btn-danger{background:var(--red-bg);color:var(--red);border-color:var(--red-border)}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-success{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.btn-success:hover:not(:disabled){background:#a7f3d0}.btn-sm{padding:5px 11px;font-size:12px;border-radius:var(--radius-xs)}.btn-lg{padding:11px 22px;font-size:14px}.btn-xl{padding:14px 28px;font-size:15px}.btn-icon{padding:7px;border-radius:var(--radius-sm)}.btn-full{width:100%}.field{display:flex;flex-direction:column;gap:4px}.field label{font-family:var(--font-ui);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3)}.field input,.field select,.field textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--ink);padding:9px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s;width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #0b9e9e1a}.field input::placeholder,.field textarea::placeholder{color:var(--ink4)}.field textarea{resize:vertical;min-height:80px}.field-hint{font-size:11px;color:var(--ink4);margin-top:2px}.field-error{font-size:11px;color:var(--red);margin-top:2px}.field-group{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-group.three{grid-template-columns:1fr 1fr 1fr}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-xs)}.card-title{font-family:var(--font-ui);font-size:14px;font-weight:700;color:var(--ink);margin-bottom:2px;letter-spacing:-.02em}.card-sub{font-size:12px;color:var(--ink4)}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid transparent}.badge-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge-new{background:#ede9fe;color:#6d28d9;border-color:#c4b5fd}.badge-confirmed{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}.badge-onroute{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.badge-done{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.badge-cancelled{background:var(--surface3);color:var(--ink3);border-color:var(--border)}.badge-paid{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}.badge-unpaid{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .15s ease}@media (min-width: 640px){.modal-overlay{align-items:center}}.modal{background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;border:1px solid var(--border)}@media (min-width: 640px){.modal{border-radius:var(--radius-xl)}}.modal-header{padding:20px 20px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--surface);z-index:1;border-bottom:1px solid var(--border)}.modal-title{font-family:var(--font-ui);font-size:16px;font-weight:700;letter-spacing:-.02em}.modal-body{padding:20px;display:flex;flex-direction:column;gap:14px}.modal-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}.toast-container{position:fixed;bottom:24px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:calc(100vw - 32px)}.toast{background:#1a2535;color:#fff;border-radius:var(--radius-lg);padding:12px 16px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:0 8px 24px #00000040;animation:slideUp .2s ease;pointer-events:all;max-width:360px;border:1px solid rgba(255,255,255,.1)}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}.toast.info{border-left:3px solid var(--teal)}.toast.warn{border-left:3px solid var(--amber)}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}table.data-table{width:100%;border-collapse:collapse;font-size:13px}table.data-table thead th{background:var(--surface2);color:var(--ink4);font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}table.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .08s;cursor:pointer}table.data-table tbody tr:last-child{border-bottom:none}table.data-table tbody tr:hover{background:var(--surface2)}table.data-table tbody tr.selected{background:var(--teal-light)}table.data-table tbody td{padding:12px 14px;vertical-align:middle}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:10px;color:var(--ink4);text-align:center}.empty-icon{font-size:32px;opacity:.4}.empty-title{font-family:var(--font-ui);font-size:15px;font-weight:700;color:var(--ink2)}.empty-sub{font-size:13px;max-width:280px;line-height:1.6}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border2);border-top-color:var(--teal);border-radius:50%;animation:spin .65s linear infinite}.spinner.sm{width:14px;height:14px;border-width:2px}.spinner.lg{width:32px;height:32px;border-width:3px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.flex-1{flex:1}.w-full{width:100%}.text-sm{font-size:12px}.text-xs{font-size:11px}.font-bold{font-weight:700;font-family:var(--font-ui)}.text-dim{color:var(--ink4)}.text-teal{color:var(--teal)}.text-red{color:var(--red)}.text-green{color:var(--green)}.mono{font-family:var(--font-mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day-header{text-align:center;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink4);padding:6px 0}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;position:relative;transition:background .1s;min-height:36px;gap:2px}.cal-day:hover{background:var(--surface3)}.cal-day.today{background:var(--teal-light)}.cal-day.today .cal-day-num{color:var(--teal);font-weight:700}.cal-day.selected{background:var(--teal)}.cal-day.selected .cal-day-num{color:#fff;font-weight:700}.cal-day.selected .cal-day-dot{background:#fff9}.cal-day.other-month .cal-day-num{color:var(--ink4)}.cal-day-num{font-size:13px;font-weight:500;color:var(--ink);line-height:1}.cal-day-dot{width:4px;height:4px;border-radius:50%;background:var(--teal)}.cal-day-count{font-size:9px;font-weight:700;color:var(--teal);background:var(--teal-light);border-radius:10px;padding:1px 5px;line-height:1.4}.cal-day.selected .cal-day-count{background:#fff3;color:#fff}.week-strip{display:flex;gap:4px;overflow-x:auto;padding:0 2px 4px;scrollbar-width:none}.week-strip::-webkit-scrollbar{display:none}.week-strip-day{flex:0 0 auto;min-width:44px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px;border-radius:var(--radius);cursor:pointer;transition:background .1s}.week-strip-day:hover{background:var(--surface3)}.week-strip-day.active{background:var(--teal)}.week-strip-day .dow{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink4)}.week-strip-day.active .dow{color:#ffffffb3}.week-strip-day .dom{font-size:16px;font-weight:700;font-family:var(--font-ui);color:var(--ink)}.week-strip-day.active .dom{color:#fff}.week-strip-day .daydot{width:4px;height:4px;border-radius:50%;background:var(--teal)}.week-strip-day.active .daydot{background:#fff9}.week-strip-day.today-strip .dom{color:var(--teal)}.week-strip-day.today-strip.active .dom{color:#fff}@media (max-width: 640px){.field-group,.field-group.three{grid-template-columns:1fr}.hide-mobile{display:none!important}}@media (min-width: 641px){.hide-desktop{display:none!important}}@media (max-width: 640px){.booking-panel{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;min-width:0!important;z-index:100;border-left:none!important}}
