:root{--background: 222 33% 97%;--foreground: 222 31% 17%;--card: 0 0% 100%;--muted: 220 23% 95%;--muted-foreground: 220 13% 42%;--border: 220 18% 86%;--primary: 221 83% 53%;--primary-foreground: 210 40% 98%;--destructive: 0 74% 52%;--desk-pin-size: 28px;--resource-free: #6FCF97;--resource-busy: #EB6A6A;--resource-own: #4C7DFF;--resource-neutral: #D1D5DB;--z-drawer: 1000;--z-modal: 1500;--z-popover: 2000;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;background:hsl(var(--background));color:hsl(var(--foreground))}.app-shell{padding:18px;display:grid;gap:12px;max-width:1480px;margin:0 auto}.app-header{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;gap:16px;align-items:center;border-radius:14px;background:hsl(var(--card));padding:10px 14px;box-shadow:0 1px 2px #0f172a14;border:1px solid hsl(var(--border))}.header-left,.header-right{display:flex;align-items:center;gap:12px}.simplified-header .header-left{min-width:0}.user-menu{position:relative}.user-chip{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 10px;border-radius:12px;border:0;background:transparent;color:inherit}.user-chip:hover,.user-chip[aria-expanded=true]{background:hsl(var(--muted))}.avatar{width:36px;height:36px;border-radius:999px;background:hsl(var(--muted));display:grid;place-items:center;overflow:hidden;font-weight:700;font-size:12px;color:hsl(var(--muted-foreground));flex-shrink:0}.avatar-sm{width:30px;height:30px;font-size:11px}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.app-avatar{border-radius:999px;background:hsl(var(--muted));display:grid;place-items:center;overflow:hidden;font-weight:700;color:hsl(var(--muted-foreground));flex-shrink:0;text-transform:uppercase}.app-avatar img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:2}.user-chip-name{font-size:13px;max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chip-chevron{color:hsl(var(--muted-foreground))}.user-menu-content{background:#fff;border:1px solid hsl(var(--border));border-radius:12px;padding:8px;display:grid;gap:4px;min-width:280px;max-width:320px;box-shadow:0 12px 20px #0f172a1f}.user-menu-summary{display:flex;align-items:center;gap:10px;padding:8px}.user-menu-meta{min-width:0;display:grid;gap:2px}.user-menu-meta strong{font-size:13px}.user-menu-email{margin:0;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.user-menu-separator{margin:4px 0;border:0;border-top:1px solid hsl(var(--border))}.user-menu-item{width:100%;display:flex;align-items:center;gap:8px;border:0;background:transparent;border-radius:10px;padding:8px 10px;cursor:pointer;color:hsl(var(--foreground));font-size:14px;text-align:left}.user-menu-item:hover{background:hsl(var(--muted))}.user-menu-item-danger{color:hsl(var(--destructive))}.layout-grid{display:grid;grid-template-columns:280px minmax(0,1fr) 320px;grid-template-areas:"left center right";gap:12px;align-items:start}.left-col{grid-area:left}.center-col{grid-area:center}.right-col{grid-area:right}.card{background:hsl(var(--card));border-radius:14px;padding:20px;box-shadow:0 1px 2px #0f172a0d;border:1px solid hsl(var(--border))}.stack,.stack-sm{display:grid;gap:12px}.stack-xs{display:grid;gap:6px}.stack-xxs{display:grid;gap:2px}.btn{border:0;border-radius:12px;padding:8px 12px;background:hsl(var(--primary));color:hsl(var(--primary-foreground));font-size:14px;font-weight:500;cursor:pointer}.btn:hover{filter:brightness(.96)}.btn-outline{background:hsl(var(--card));color:hsl(var(--foreground));box-shadow:inset 0 0 0 1px hsl(var(--border))}.btn-ghost{background:transparent;color:hsl(var(--foreground))}.field{display:grid;gap:6px;font-size:14px}.field span,.muted{color:hsl(var(--muted-foreground));font-size:14px}input,select{border:1px solid hsl(var(--border));border-radius:12px;padding:8px 10px;font-size:14px;background:hsl(var(--card));color:inherit}.calendar-header{display:grid;grid-template-columns:32px 1fr 32px;align-items:center}.calendar-header strong{text-align:center;text-transform:capitalize}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.weekday-label{text-align:center;font-size:12px;color:hsl(var(--muted-foreground))}.day-btn{border:0;border-radius:9px;padding:6px 0;background:hsl(var(--muted));cursor:pointer;font-weight:500}.day-btn.selected{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.day-btn.has-bookings{box-shadow:none}.day-btn.availability-many-free{background:color-mix(in srgb,var(--resource-free) 22%,white)}.day-btn.availability-few-free{background:color-mix(in srgb,#f59e0b 48%,white);color:#0f172a}.day-btn.availability-none-free{background:color-mix(in srgb,var(--resource-busy) 40%,white);color:#7f1d1d}.day-btn.today,.day-btn.today.has-bookings{box-shadow:inset 0 0 0 1px hsl(var(--primary))}.day-btn.outside{opacity:.4}.legend{display:grid;gap:8px}.legend span{display:flex;align-items:center;gap:8px;font-size:14px}.dot{width:10px;height:10px;border-radius:999px;display:inline-block}.dot.free{background:var(--resource-free)}.dot.booked{background:var(--resource-busy)}.dot.selected{background:var(--resource-own)}.dot.availability-many{background:color-mix(in srgb,var(--resource-free) 55%,white)}.dot.availability-few{background:#f59e0b}.dot.availability-none{background:color-mix(in srgb,var(--resource-busy) 88%,white)}.toggle{display:flex;align-items:center;gap:8px;font-size:14px}.card-header-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.top-loading-bar{position:fixed;top:0;left:0;width:100%;height:3px;z-index:9999;pointer-events:none;opacity:0;transition:opacity .15s ease}.top-loading-bar.is-visible{opacity:.92}.top-loading-bar-track{display:block;height:100%;width:34%;background:linear-gradient(90deg,#3b82f633,hsl(var(--primary)),#3b82f633);animation:indeterminate 1.1s ease-in-out infinite}.canvas-body{background:hsl(var(--muted)/.45);border-radius:12px;padding:2px;min-height:420px;overflow:hidden}.floorplan-canvas{position:relative;width:100%;height:100%}.floorplan-canvas-contain{display:grid;place-items:center}.floorplan-image{position:relative;display:block;width:100%;height:100%;border-radius:10px;z-index:0;object-fit:contain}.floorplan-image-contain{width:auto;max-width:100%;max-height:100%;object-fit:contain}.floorplan-marker-overlay{position:absolute;z-index:10}.desk-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.floorplan-viewport{position:relative;width:100%;height:100%;min-height:416px;overflow:hidden;border-radius:10px}.floorplan-status-banner{position:absolute;left:12px;top:12px;padding:6px 10px;border-radius:10px;background:#0f172ab3;color:#f8fafc;font-size:12px;line-height:1.25;z-index:15;pointer-events:none;max-width:min(90%,620px);overflow-wrap:anywhere}.floorplan-status-banner.is-error{background:#7f1d1ddb}.floorplan-debug{position:absolute;left:10px;top:10px;padding:8px 10px;border-radius:8px;background:#0f172adb;color:#f8fafc;font-size:11px;line-height:1.35;z-index:25;pointer-events:auto;max-width:min(94%,840px);overflow-wrap:anywhere}.floorplan-debug-toggle{display:flex;align-items:center;gap:6px;margin-top:6px;pointer-events:auto}.desk-pin{--desk-pin-scale:1;position:absolute;left:0;top:0;transform:translate(-50%,-50%) scale(var(--desk-pin-scale));transform-origin:center center;width:44px;height:44px;border:0;border-radius:50%;pointer-events:auto;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;margin:0;padding:0;background:transparent;display:grid;place-items:center;transition:box-shadow .15s ease,transform .15s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.pulseHalo{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:9999px;background:var(--resource-free);opacity:.18;filter:blur(2px);pointer-events:none;z-index:0;animation:resourcePulse 2.8s ease-in-out infinite}.pin-ring-svg{position:absolute;top:4px;right:4px;bottom:4px;left:4px;z-index:1;fill:none;pointer-events:none}.room-marker-ring{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;width:100%;height:100%;fill:none;pointer-events:none}.pin-ring-track{stroke:var(--resource-neutral);stroke-width:5;stroke-linecap:round}.pin-ring-arc{stroke-width:5;stroke-linecap:round}.room-business-ring-track{fill:none;stroke:hsl(var(--muted));stroke-linecap:round}.room-business-ring-night{fill:none;stroke:hsl(var(--muted-foreground)/.3);stroke-linecap:round}.room-business-ring-free{fill:none;stroke:var(--resource-free);stroke-linecap:round}.room-business-ring-booked{fill:none;stroke:var(--resource-busy);stroke-linecap:round}.desk-pin.is-own-desk .room-business-ring-booked{stroke:var(--resource-own)}.room-business-ring-tick{stroke:hsl(var(--muted-foreground)/.45);stroke-width:1.6}.pin-center{position:relative;z-index:2;border-radius:999px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:inset 0 0 0 1px #94a3b88c,0 2px 7px #0f172a24}.room-center-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;line-height:1;color:#1f2937}.room-center-icon{width:18px;height:18px;color:#475569;display:flex;align-items:center;justify-content:center}.room-center-icon svg{width:100%;height:100%;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.room-center-label small{font-size:10px;font-weight:600;letter-spacing:.01em;color:#334155}.desk-pin-count{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:999px;background:#e2e8f0;color:#0f172a;font-weight:700;font-size:13px}.desk-pin.selected,.desk-pin.hovered,.desk-pin.is-highlighted{--desk-pin-scale:1.06;box-shadow:0 0 0 4px #3b82f633,0 8px 18px #0f172a33}.desk-pin.is-selected{box-shadow:0 0 0 5px #3b82f652,0 0 0 10px #3b82f626,0 8px 20px #0f172a3d}.desk-pin.is-click-disabled{cursor:not-allowed;opacity:.9}.desk-pin:hover{--desk-pin-scale:1.05}.desk-pin:hover .pulseHalo,.desk-pin.selected .pulseHalo,.desk-pin.is-selected .pulseHalo,.desk-pin.hovered .pulseHalo,.desk-pin.is-highlighted .pulseHalo{animation-play-state:paused;opacity:.12}.desk-pin-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;z-index:1}.desk-pin-initials{position:relative;display:flex;align-items:center;justify-content:center;inline-size:100%;block-size:100%;font-size:12px;font-weight:600;line-height:1;color:#0f172a;z-index:2;pointer-events:none;opacity:1;transition:opacity .15s ease}.desk-pin-initials.is-hidden{opacity:0}.desk-pin-kind-icon{display:flex;align-items:center;justify-content:center;inline-size:100%;block-size:100%;font-size:13px;font-weight:700;line-height:1;color:#334155;pointer-events:none}.desk-tooltip{position:fixed;transform:translate(-50%,-100%);background:#0f172a;color:#f8fafc;border-radius:10px;padding:8px 10px;display:grid;gap:2px;font-size:12px;z-index:90;pointer-events:none;box-shadow:0 10px 24px #0f172a4d}.desk-tooltip strong{font-size:12px}.desk-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a38;z-index:var(--z-modal)}.desk-popup{position:fixed;top:0;right:0;height:100vh;z-index:1000;width:clamp(520px,40vw,720px);max-width:96vw;min-width:360px;overflow:hidden;display:flex;flex-direction:column;gap:0;padding:0;border-left:1px solid hsl(var(--border));border-radius:0;box-shadow:-18px 0 32px #0f172a33}.desk-popup,.desk-popup *{max-width:100%}.desk-popup h3{margin:0;font-size:16px}.desk-popup p{margin:0}.desk-popup-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid hsl(var(--border));background:hsl(var(--card));flex:0 0 auto}.desk-popup-header .stack-xxs{flex:1;text-align:center}.desk-popup-header>h3{flex:1;text-align:center}.desk-popup-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:20px;display:flex;flex-direction:column;gap:16px}.desk-popup-close{width:30px;height:30px;border-radius:999px;padding:0;display:inline-flex;align-items:center;justify-content:center;color:hsl(var(--muted-foreground));flex-shrink:0}.desk-booking-form{display:flex;flex-direction:column;gap:16px;width:100%;min-width:0;height:100%;overflow:hidden;overflow-x:hidden}.split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.desk-booking-form>*,.desk-booking-form .stack-xs,.desk-booking-form .stack-sm,.desk-booking-form .split,.desk-booking-form .weekday-toggle-group,.desk-booking-form-body{min-width:0;width:100%}.desk-booking-form input,.desk-booking-form select,.desk-booking-form textarea,.desk-booking-form .btn,.desk-booking-form .weekday-toggle,.desk-booking-form .free-slot-chip{max-width:100%;width:100%;box-sizing:border-box}.desk-booking-form .weekday-toggle{white-space:normal;word-break:break-word}.desk-booking-form-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:2px}.desk-booking-form .weekday-toggle-group{display:flex;flex-wrap:wrap;gap:8px;max-height:none;overflow:visible;padding-right:0}.desk-booking-form .weekday-toggle{flex:0 1 auto;width:auto}.recurring-panel{border:1px solid hsl(var(--border));border-radius:12px;padding:20px;background:hsl(var(--muted)/.25)}.recurrence-interval-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.recurrence-interval-row label{margin:0;flex:0 0 auto}.recurrence-interval-row input{flex:0 0 80px;min-width:80px;max-width:80px}.recurrence-interval-row span{flex:0 0 auto;white-space:nowrap}.end-option-row{display:grid;grid-template-columns:20px 120px 1fr;align-items:center;gap:12px;padding:6px 0;cursor:pointer}.end-option-row input[type=radio]{margin:0;align-self:center}.end-option-label{font-size:14px}.end-option-control{width:100%;min-width:0}.end-option-control-with-suffix{display:flex;align-items:center;gap:8px;width:100%}.end-option-control-with-suffix .end-option-control{flex:1 1 auto}.end-option-suffix{flex:0 0 auto;white-space:nowrap;color:hsl(var(--muted-foreground));font-size:13px}.end-option-control:disabled{opacity:.6}.desk-booking-form-footer{flex:0 0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:12px 0 2px;border-top:1px solid hsl(var(--border));background:hsl(var(--card))}.desk-booking-form-footer .btn{justify-content:center;min-height:38px}.room-schedule-block{padding:10px;border-radius:10px;background:hsl(var(--muted)/.45);border:1px solid hsl(var(--border));gap:10px}.room-schedule-title{font-size:13px}.room-schedule-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.occupancy-ring{position:relative;display:inline-flex;width:28px;height:28px;flex-shrink:0}.occupancy-ring-track,.occupancy-ring-fill,.occupancy-ring-hole{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px}.occupancy-ring-track{background:hsl(var(--muted))}.occupancy-ring-fill{background:var(--ring-gradient)}.occupancy-ring-hole{top:5px;right:5px;bottom:5px;left:5px;background:hsl(var(--card))}.room-schedule-ring{width:34px;height:34px;display:block;flex-shrink:0}.room-debug-panel{display:grid;gap:2px;padding:8px;border:1px dashed hsl(var(--border));border-radius:8px;background:hsl(var(--card)/.6);font-size:12px}.room-debug-panel p{margin:0;line-height:1.25}.room-booking-hint{margin-top:-6px;font-size:11px;color:hsl(var(--muted-foreground))}.room-bookings-list{display:grid;gap:6px;max-height:160px;overflow-y:auto;padding-right:2px}.room-booking-row{display:grid;grid-template-columns:minmax(112px,max-content) minmax(0,1fr);align-items:center;gap:10px;font-size:12px;color:#475569;border:0;background:transparent;border-radius:8px;padding:4px 6px;text-align:left;width:100%}.room-booking-time{font-weight:700;color:#0f172a}.room-booking-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.room-booking-person{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-flex;align-items:center;gap:8px;min-width:0}.room-booking-row.is-clickable{cursor:pointer}.room-booking-row.is-clickable:hover:not(:disabled),.room-booking-row.is-clickable:focus-visible{background:hsl(var(--muted)/.95)}.room-booking-row:disabled{opacity:1}.room-booking-badge{font-style:normal;font-size:11px;font-weight:700;color:#0b5bbd;background:#dbeafe;border-radius:999px;padding:2px 7px;white-space:nowrap}.room-booking-action{font-size:11px;font-weight:600;color:#b91c1c;white-space:nowrap}.room-booking-repeat{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.room-free-hint{font-size:12px;color:#166534;background:#dcfce7;border-radius:8px;padding:6px 8px;display:inline-flex;width:max-content}.room-fully-booked-hint{font-size:12px;color:#b45309;background:#fef3c7;border-radius:8px;padding:6px 8px;display:inline-flex;width:max-content}.room-conflict-hint{margin-top:-2px}.room-bookable-hours{font-size:12px;margin-top:4px}.room-free-slots{display:flex;flex-wrap:wrap;gap:8px}.free-slot-chip{border:1px solid hsl(var(--primary)/.3);border-radius:999px;background:hsl(var(--primary)/.09);color:hsl(var(--primary));font-size:12px;padding:5px 11px;cursor:pointer}.free-slot-chip:hover{border-color:hsl(var(--primary)/.6);background:hsl(var(--primary)/.14)}.field-error{margin:0;color:#b91c1c;font-size:12px;line-height:1.3}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.55);border-top-color:#fff;border-radius:999px;display:inline-block;animation:spin .8s linear infinite}.desk-pin.debug-outline{outline:1px dashed rgba(234,88,12,.9);outline-offset:0}.pin-ring.debug-outline{outline:1px dashed rgba(2,132,199,.9)}.pin-avatar-clip.debug-outline{outline:1px dashed rgba(16,185,129,.9)}.compact-topbar .header-left h1{margin:0;font-size:16px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.brand-mark{width:28px;height:28px;border-radius:8px;background:hsl(var(--primary));color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}.brand-logo{width:28px;height:28px;border-radius:8px;object-fit:contain;background:hsl(var(--muted));padding:2px}.field-inline{display:flex;align-items:center;gap:8px;font-size:12px;color:hsl(var(--muted-foreground))}.field-inline select{min-width:160px}.compact-card{padding:20px}.today-compact-panel{padding:12px 16px}.today-summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px}.btn-sm{min-height:30px;padding:6px 10px;font-size:12px}.today-avatar-strip{display:flex;align-items:center;gap:8px;overflow-x:auto;padding-bottom:4px}.today-avatar-item{width:44px;height:44px;border:1px solid hsl(var(--border));border-radius:999px;background:hsl(var(--card));display:grid;place-items:center;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;flex:0 0 auto}.today-avatar-item:hover,.today-avatar-item:focus-visible,.today-avatar-item.is-active{border-color:hsl(var(--primary)/.4);box-shadow:0 4px 12px #0f172a14;background:hsl(var(--muted)/.2)}.today-avatar-item.is-highlighted{border-color:hsl(var(--primary)/.55);box-shadow:0 0 0 1px hsl(var(--primary)/.25)}.today-people-empty-state{text-align:left;padding:12px}.today-people-empty-state p{margin:0}.legend-chip-list{display:flex;flex-wrap:wrap;gap:8px}.legend-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;background:hsl(var(--muted));font-size:12px;color:hsl(var(--muted-foreground));font-weight:600}.field-label{font-size:12px;color:hsl(var(--muted-foreground))}.occupant-desk-label{margin-left:auto;max-width:42%;font-size:11px;padding:3px 8px;border-radius:999px;background:hsl(var(--muted));color:hsl(var(--muted-foreground));font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.inline-alert{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.canvas-body-focus.is-loading{opacity:.8;transition:opacity .18s ease}.summary-row{display:flex;justify-content:space-between;align-items:flex-start}.filter-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.overview-view-select{padding-bottom:2px}.details-panel{padding-right:16px}.table-wrap{max-height:380px;overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:8px 4px;border-bottom:1px solid hsl(var(--border));text-align:left;font-size:14px;vertical-align:top}.table-wrap tr{cursor:pointer;transition:background .15s ease}.table-wrap tr.row-active{background:hsl(var(--muted)/.7)}.table-wrap tr.row-highlighted{background:hsl(var(--primary)/.14)}.table-wrap tr:focus-visible{outline:2px solid hsl(var(--primary));outline-offset:-2px}td p{margin:2px 0 0}.occupant-card{border:1px solid hsl(var(--border));border-radius:12px;padding:14px;background:hsl(var(--muted)/.5)}tr{cursor:pointer}.row-selected{background:hsl(var(--muted))}.people-list{list-style:none;padding:0;margin:0;display:grid;gap:6px}.people-list li{display:flex;justify-content:space-between;padding:8px;border-radius:12px;cursor:pointer}.occupancy-list{display:grid;gap:6px;max-height:300px;overflow-y:auto;overflow-x:hidden;padding-right:2px}.occupant-compact-card{display:flex;align-items:center;justify-content:flex-start;gap:12px;min-height:44px;padding:9px 10px;border-radius:10px;background:hsl(var(--muted)/.45);border:1px solid hsl(var(--border));transition:background .15s ease,border-color .15s ease;overflow-x:hidden}.occupant-compact-card:hover,.occupant-compact-card.is-active{background:hsl(var(--muted)/.85)}.occupant-compact-card.is-highlighted{background:hsl(var(--primary)/.14);border-color:hsl(var(--primary)/.35)}.occupant-card-main{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.occupant-card-text{min-width:0}.occupant-card-text strong{display:block;font-size:13px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.occupant-card-text p{margin:1px 0 0;font-size:11px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-empty-state{padding:10px}.full-width-occupancy-panel h3{margin:0}.empty-state{border:1px dashed hsl(var(--border));border-radius:12px;padding:16px;text-align:center;color:hsl(var(--muted-foreground))}.skeleton{border-radius:16px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f1f5f9);background-size:200% 100%;animation:pulse 1.4s infinite}.h-120{height:120px}.h-420{height:420px}.h-480{height:480px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a4d;display:grid;place-items:center;padding:16px;z-index:var(--z-modal)}.dialog{width:min(560px,100%)}.inline-end{display:flex;justify-content:flex-end;gap:8px}.rebook-dialog{width:min(420px,100%);padding:22px;gap:10px}.rebook-dialog h3{margin:0;font-size:17px;line-height:1.25}.rebook-dialog p{margin:0;font-size:14px;line-height:1.45}.rebook-date{font-weight:700}.rebook-subline{font-size:13px}.rebook-actions{margin-top:2px}.recurring-conflict-dialog{width:min(760px,100%);max-height:min(86vh,760px);display:flex;flex-direction:column;gap:0;padding:0;overflow:hidden}.recurring-conflict-header{padding:18px 20px;border-bottom:1px solid hsl(var(--border));align-items:center}.recurring-conflict-header h3{margin:0}.recurring-conflict-body{padding:16px 20px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.recurring-conflict-table-wrap{border:1px solid hsl(var(--border));border-radius:12px;overflow:hidden}.recurring-conflict-table{width:100%;border-collapse:collapse}.recurring-conflict-table th,.recurring-conflict-table td{padding:10px 12px;text-align:left;border-bottom:1px solid hsl(var(--border));font-size:13px}.recurring-conflict-table tbody tr:last-child td{border-bottom:0}.recurring-conflict-footer{position:sticky;bottom:0;background:hsl(var(--card));border-top:1px solid hsl(var(--border));padding:14px 20px}.recurring-conflict-actions .btn{width:100%;justify-content:flex-start;min-height:44px}.recurring-conflict-footer .muted{font-size:12px;line-height:1.3}.rebook-actions .btn{min-height:38px}.cancel-booking-dialog{width:min(420px,100%);padding:22px;gap:10px}.cancel-booking-dialog h3{margin:0;font-size:17px;line-height:1.25}.cancel-booking-dialog p{margin:0;font-size:14px;line-height:1.45}.cancel-booking-subline{font-size:12px;color:hsl(var(--muted-foreground))}.inline-grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.weekday-toggle-group{display:flex;gap:6px;flex-wrap:wrap}.weekday-toggle{border:1px solid hsl(var(--border));background:hsl(var(--card));padding:6px 10px;border-radius:999px;cursor:pointer}.weekday-toggle.active{background:hsl(var(--primary));border-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.recurring-section{border-top:1px solid hsl(var(--border));padding-top:12px}.recurrence-accordion-toggle{display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:none;border:0;padding:0;cursor:pointer;text-align:left}.recurrence-preview summary{cursor:pointer;font-weight:600}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px}.sheet{position:fixed;left:16px;top:16px;bottom:16px;width:min(360px,calc(100% - 32px));overflow:auto;z-index:var(--z-drawer)}.sheet-right{left:auto;right:16px}.toast-viewport{position:fixed;top:0;right:0;bottom:0;left:0;z-index:340;pointer-events:none}.toast{position:fixed;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-radius:12px;padding:12px 14px;font-size:14px;pointer-events:auto;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:toast-in .18s ease-out both;box-shadow:0 10px 24px #0f172a1f;max-width:min(320px,calc(100vw - 16px))}.toast-enter{opacity:1}.toast-leave{animation:toast-out .18s ease-out forwards}.toast-message-wrap{display:flex;align-items:flex-start;gap:8px;min-width:0}.toast-icon{font-size:12px;line-height:1.5;font-weight:700;opacity:.75;margin-top:1px}.toast-message{margin:0;font-size:13px;line-height:1.35;font-weight:500;word-break:break-word}.toast-success{background:#22c55e33;color:#166534}.toast-error{background:#ef444433;color:#991b1b}.toast-close{border:0;background:transparent;color:inherit;cursor:pointer;padding:0 2px;font-size:13px;line-height:1;opacity:.72;transition:opacity .15s ease}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}.error-inline{color:#b91c1c;font-size:13px;margin:0}.api-base{margin:0;color:hsl(var(--muted-foreground));font-size:12px}.mobile-only{display:none}.down-card{max-width:520px;justify-self:center;width:100%}.ms-login-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;background-color:#fbfbfc;background-image:radial-gradient(circle,rgba(17,24,39,.1) 1px,transparent 1px);background-size:34px 34px}.ms-login-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:26px;padding:36px;box-shadow:0 18px 50px #0000001f;width:min(100%,592px);display:flex;flex-direction:column;align-items:center;gap:20px;justify-content:center}.ms-login-title{margin:0;font-size:clamp(28px,4vw,40px);text-align:center}.ms-login-button{position:relative;width:clamp(420px,72vw,520px);max-width:100%;min-height:60px;border:0;border-radius:12px;background:#2f2f2f;color:#fff;font-size:20px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s ease,background-color .15s ease,box-shadow .15s ease;box-shadow:0 10px 20px #00000038}.ms-login-button-logo{width:30px;height:30px;position:absolute;left:18px;top:50%;transform:translateY(-50%)}.ms-login-button-text{pointer-events:none}.ms-login-button:hover{background:#383838;transform:translateY(-1px)}.ms-login-button:active{transform:translateY(0)}.ms-login-button:focus-visible{outline:3px solid #2563eb;outline-offset:2px}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes indeterminate{0%{transform:translate(-120%)}to{transform:translate(340%)}}@keyframes resourcePulse{0%{transform:scale(1);opacity:.16}50%{transform:scale(1.06);opacity:.26}to{transform:scale(1);opacity:.16}}@media(prefers-reduced-motion:reduce){.pulseHalo{animation:none}}@media(max-width:1100px){.layout-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"left right" "center center"}}@media(max-width:768px){.app-shell{padding:12px}.layout-grid{grid-template-columns:1fr;grid-template-areas:"left" "right" "center"}.inline-grid-two{grid-template-columns:1fr}.compact-topbar{position:static}.field-inline span{display:none}}@media(max-width:900px){.user-chip-name{display:none}.user-menu-content{min-width:260px;max-width:min(320px,calc(100vw - 32px))}}.admin-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:16px}.admin-sidebar{position:sticky;top:20px;height:fit-content}.admin-nav-link{justify-content:flex-start;text-align:left}.admin-nav-link.active{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.admin-content{display:grid;gap:12px}.admin-topbar{display:flex;justify-content:space-between;gap:12px;align-items:center}.inline-between{display:flex;justify-content:space-between;align-items:center;gap:8px}.error-banner{background:#fee2e2;color:#991b1b;border-radius:10px;padding:8px 10px}.success-banner{background:#dcfce7;color:#166534;border-radius:10px;padding:8px 10px}@media(max-width:900px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{position:static}}.admin-shell-v2{display:grid;grid-template-columns:240px minmax(0,1fr);gap:16px}.admin-sidebar-v2{position:sticky;top:20px;height:fit-content}.admin-content-v2{min-width:0}.admin-topbar-v2{display:flex;justify-content:space-between;align-items:center;gap:16px}.admin-toolbar{display:flex;gap:8px;align-items:center}.admin-toolbar-wrap{flex-wrap:wrap}.admin-row-actions{display:flex;gap:4px;justify-content:flex-end;flex-wrap:wrap}.admin-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:hsl(var(--muted));font-size:12px;font-weight:600}.admin-badge-ok{background:#dcfce7;color:#166534}.admin-badge-warn{background:#fef3c7;color:#92400e}.admin-table-skeleton{height:32px;border-radius:8px}.position-picker{position:relative;border:1px solid hsl(var(--border));border-radius:12px;overflow:hidden;min-height:220px;cursor:crosshair;background:hsl(var(--muted))}.position-image{display:block;width:100%;height:auto}.position-pin{position:absolute;width:18px;height:18px;border-radius:999px;background:hsl(var(--primary));border:2px solid white;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 0 2px #3b82f640}@media(max-width:900px){.admin-shell-v2{grid-template-columns:1fr}.admin-sidebar-v2{position:static}.admin-topbar-v2{flex-direction:column;align-items:flex-start}.admin-toolbar{flex-wrap:wrap}}@media(max-width:480px){.ms-login-layout{padding:20px}.ms-login-card{padding:24px}.ms-login-button{width:100%;font-size:18px}}.admin-content-v2{max-width:1280px;width:100%;margin:0 auto}.btn{display:inline-flex;align-items:center;gap:6px}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-icon{padding:6px 8px}.btn-danger{background:#dc2626;color:#fff}.btn-danger-text{color:#b91c1c}.admin-table th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:hsl(var(--muted-foreground));font-weight:700}.admin-table th,.admin-table td{padding:12px 10px;vertical-align:middle}.align-right{text-align:right}.truncate-cell{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.crud-toolbar{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}.list-toolbar{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}.list-toolbar-controls{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.occupant-person-cell{display:flex;align-items:center;gap:10px}.occupant-person-cell p{margin:0}.avatar-col{width:40px}.admin-split-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.9fr);gap:12px;align-items:start}.admin-split-layout>*{min-width:0}.bookings-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.9fr);grid-template-areas:"filters floor" "list floor";gap:12px;align-items:start}.bookings-filter-card{grid-area:filters;padding:18px}.bookings-list-card{grid-area:list;display:flex;flex-direction:column;min-height:0}.bookings-floorplan-card{grid-area:floor;min-height:0}.bookings-filter-toolbar{display:grid;gap:12px}.bookings-filter-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:center}.bookings-filter-row-search{grid-template-columns:minmax(220px,1fr) auto auto}.bookings-filter-row input,.bookings-filter-row select{height:40px}.bookings-new-button{margin-left:auto}.bookings-active-filters{display:flex;flex-wrap:wrap;gap:10px}.booking-table-wrap{max-height:min(62vh,620px);overflow:auto;flex:1}.booking-person-cell{display:flex;align-items:center;gap:8px;max-width:260px}.booking-guest-cell{display:flex;align-items:center;gap:6px;max-width:220px}.booking-guest-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-floor-canvas{min-height:460px}.admin-floor-canvas.is-active-mode{cursor:crosshair}.admin-search{display:flex;align-items:center;gap:8px;border:1px solid hsl(var(--border));border-radius:12px;padding:0 10px;background:#fff;min-width:240px}.admin-search input{border:0;outline:0;padding:8px 0;width:100%}.row-menu-content{background:#fff;border:1px solid hsl(var(--border));border-radius:12px;padding:6px;display:grid;gap:4px;min-width:160px;box-shadow:0 12px 20px #0f172a1f}.row-menu-overlay{z-index:var(--z-popover)}.row-menu-item{justify-content:flex-start}.row-menu-item:hover{background:hsl(var(--muted))}.dashboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dashboard-kpi,.dashboard-main-card,.dashboard-actions-card{padding:24px}.dashboard-kpi{border:1px solid hsl(var(--border));text-align:left;background:#fff;display:grid;gap:12px;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.dashboard-kpi:hover{transform:translateY(-1px);border-color:hsl(var(--primary)/.45);box-shadow:0 8px 20px #0f172a14}.dashboard-kpi strong{font-size:30px;line-height:1.1}.dashboard-kpi p{margin:0;color:hsl(var(--muted-foreground));font-size:13px}.dashboard-kpi-icon{width:36px;height:36px;border-radius:10px;background:hsl(var(--muted));display:grid;place-items:center;font-size:18px}.dashboard-kpi-skeleton{padding:24px;display:grid;gap:10px}.dashboard-kpi-skeleton .skeleton:nth-child(1){height:36px;width:36px;border-radius:10px}.dashboard-kpi-skeleton .skeleton:nth-child(2){height:34px;width:70%}.dashboard-kpi-skeleton .skeleton:nth-child(3){height:14px;width:90%}.dashboard-panels{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:12px;align-items:start}.dashboard-table-wrap{border:1px solid hsl(var(--border));border-radius:12px;overflow:hidden}.dashboard-bookings-table th,.dashboard-bookings-table td{padding-top:10px;padding-bottom:10px}.dashboard-booking-table-row{cursor:pointer;transition:background-color .15s ease}.dashboard-booking-table-row:hover,.dashboard-booking-table-row:focus-visible{background:hsl(var(--muted)/.45);outline:none}.quick-actions-list{display:grid;gap:8px}.quick-action-btn{justify-content:flex-start;width:100%}.quick-action-skeleton{height:38px;border-radius:10px}@media(max-width:1024px){.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-panels{grid-template-columns:1fr}}@media(max-width:900px){.admin-content-v2{max-width:100%}.dashboard-grid{grid-template-columns:1fr}.admin-search{min-width:100%}}@media(max-width:900px){.list-toolbar-controls{width:100%;justify-content:flex-start}}@media(max-width:700px){.dashboard-kpi,.dashboard-main-card,.dashboard-actions-card{padding:16px}}.bulk-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border:1px solid hsl(var(--border));border-radius:10px;background:hsl(var(--muted)/.4)}.floor-thumb-btn{border:0;background:transparent;padding:0;cursor:pointer}.floor-thumb{width:120px;height:80px;object-fit:cover;border-radius:8px;border:1px solid hsl(var(--border));display:block}.admin-split-floor-preview .canvas-body{min-height:380px}.booking-editor-dialog{max-width:min(1240px,96vw)}.booking-editor-meta{display:grid;gap:2px}.booking-editor-meta p{margin:0}.booking-editor-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(380px,.8fr);gap:16px;align-items:start}.booking-editor-plan .canvas-body{min-height:420px}.booking-editor-canvas{height:min(58vh,560px)}.booking-editor-canvas .floorplan-canvas{height:100%}@media(max-width:1024px){.admin-split-layout,.booking-editor-layout{grid-template-columns:1fr}.admin-floor-canvas{min-height:360px}.booking-editor-plan .canvas-body{min-height:340px}}@media(max-width:1024px){.bookings-layout{grid-template-columns:1fr;grid-template-areas:"filters" "floor" "list"}.bookings-filter-row{grid-template-columns:repeat(2,minmax(0,1fr))}.bookings-filter-row-search{grid-template-columns:minmax(0,1fr) auto auto}}@media(max-width:700px){.bookings-layout{grid-template-areas:"filters" "list" "floor"}.bookings-filter-card{padding:16px}.bookings-filter-row,.bookings-filter-row-search{grid-template-columns:1fr}.bookings-new-button{margin-left:0}}.db-editor-textarea{width:100%;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;border:1px solid hsl(var(--border));border-radius:12px;padding:10px;resize:vertical}.inline-start{display:flex;align-items:center;gap:8px}.inline-end{display:flex;align-items:center;gap:8px;justify-content:flex-end}.desks-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.desks-toolbar{display:grid;grid-template-columns:minmax(180px,220px) minmax(220px,1fr) minmax(160px,200px) auto;gap:8px;align-items:center}.table-scroll-area{max-height:560px;overflow:auto}.desks-table thead th{position:sticky;top:0;background:hsl(var(--card));z-index:2}.desks-table td,.desks-table th{padding-top:14px;padding-bottom:14px}.desks-table tbody tr:hover,.row-hovered{background:hsl(var(--muted)/.45)}.desks-split-view{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.floorplan-headline p{margin:0}.desks-legend{display:flex;flex-wrap:wrap;gap:8px}.desk-details-card{border:1px solid hsl(var(--border));background:hsl(var(--card))}.admin-floor-skeleton{height:420px;border-radius:12px}.admin-mobile-nav-toggle{display:none}.mobile-admin-drawer{width:min(320px,90vw);margin:16px;max-height:calc(100vh - 32px);overflow:auto}@media(max-width:1100px){.desks-toolbar{grid-template-columns:1fr 1fr}.desks-toolbar .inline-end{justify-content:flex-start}}@media(max-width:900px){.admin-mobile-nav-toggle{display:inline-flex}.admin-shell-v2>.admin-sidebar-v2{display:none}.desks-page-header{flex-direction:column}.desks-toolbar{grid-template-columns:1fr}}.db-editor-panel{gap:14px}.db-editor-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap}.db-editor-controls{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;justify-content:flex-end}.db-editor-table thead th{position:sticky;top:0;background:#fff;z-index:1}.db-editor-table tbody tr:nth-child(2n){background:#fafafa}.db-editor-table tbody tr:hover{background:hsl(var(--muted))}.db-editor-table th,.db-editor-table td{padding:14px 10px}.db-sort-btn{padding:0;font-weight:700;min-height:auto}.db-id-cell{display:flex;align-items:center;gap:4px;max-width:100%}.db-id-cell span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-col-id,.db-col-deskid{width:140px;max-width:140px}.db-col-useremail{width:220px;max-width:220px}.db-col-date,.db-col-createdat{width:170px;max-width:170px}.db-detail-pre{padding:10px;border:1px solid hsl(var(--border));border-radius:10px;background:hsl(var(--muted));max-height:50vh;overflow:auto}@media(max-width:900px){.db-editor-controls{width:100%;justify-content:flex-start}.db-editor-table .db-col-deskid,.db-editor-table .db-col-createdat,.db-editor-table .db-col-updatedat{display:none}}.subtle-divider{border:0;border-top:1px solid hsl(var(--border));margin:4px 0}.error-debug-pre{margin:0;max-height:220px;overflow:auto;border:1px solid hsl(var(--border));border-radius:8px;padding:8px;background:hsl(var(--surface));font-size:12px;white-space:pre-wrap;word-break:break-word}.recurrence-section-title{font-weight:600;font-size:13px}.recurrence-yearly-row{display:flex;gap:10px;flex-wrap:wrap}.recurrence-yearly-row>div{flex:1 1 180px}.recurrence-monthly-row input{max-width:120px}.recurrence-range-group{border:1px solid hsl(var(--border));border-radius:10px;padding:10px;background:hsl(var(--card))}@media(max-width:480px){.end-option-row{grid-template-columns:20px 1fr}.end-option-control,.end-option-control-with-suffix{grid-column:2 / -1}}.booking-details-panel{padding:20px;gap:16px}.booking-detail-card{border:1px solid hsl(var(--border));border-radius:12px;padding:12px;background:hsl(var(--card))}.booking-detail-card h4{margin:0 0 4px;font-size:14px}.booking-detail-card p{display:flex;flex-direction:column;gap:2px;font-size:14px}.booking-detail-card .muted{font-size:12px}.desk-popup-footer-actions{margin-top:auto;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid hsl(var(--border));padding-top:12px}.cancel-options .btn{width:100%;justify-content:center;min-height:44px;flex-grow:0}
