/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.border{border-style:var(--tw-border-style);border-width:1px}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--purple:#5309c7;--purple-dark:#3d07a0;--purple-mid:#7b2fe0;--purple-faint:#eae0fa;--off-white:#f5f2fa;--white:#fdfbff;--black:#120d1e;--mist:#e5ddef;--ghost:#f0ebf8;--rust:#b85c38;--cream:var(--off-white);--ink:var(--black);--warm-white:var(--white)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;min-height:100svh}body{background-color:var(--off-white);color:var(--black);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif}.serif{letter-spacing:-.02em;font-family:Inter,sans-serif;font-weight:800}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--mist)}::-webkit-scrollbar-thumb{background:var(--purple-mid);border-radius:2px}.app-shell{background:var(--cream);flex-direction:column;min-height:100svh;display:flex}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.content-area{flex:1;padding:32px 36px;overflow:auto}.navbar{z-index:50;background:linear-gradient(90deg,#1d0463 0%,#3508a8 100%);border-radius:999px;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;margin:14px 20px 0;padding:0 22px;display:flex;position:sticky;top:14px;box-shadow:0 4px 24px #1d046359}.navbar-brand{align-items:center;gap:14px;display:flex}.navbar-logo{filter:brightness(0)invert();width:auto;height:34px}.navbar-brand-divider{background:#ffffff26;flex-shrink:0;width:1px;height:28px}.navbar-title{color:#ffffff73;text-transform:uppercase;letter-spacing:.07em;margin:0;font-size:10px;font-weight:600;line-height:1}.navbar-sub{color:#ffffffe0;margin:3px 0 0;font-size:13px;font-weight:500;line-height:1}.navbar-right{align-items:center;gap:8px;display:flex}.navbar-nav{align-items:center;gap:4px;display:flex}.navbar-link{color:#ffffffb8;white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:all .18s;display:flex}.navbar-link:hover{color:#fff;background:#ffffff21;border-color:#ffffff1f}.navbar-link.active{color:var(--purple-dark);background:#fff;font-weight:600;box-shadow:0 2px 8px #0000002e}.navbar-avatar-btn{cursor:pointer;background:0 0;border:none;border-radius:9px;align-items:center;gap:5px;margin-left:6px;padding:5px 6px;transition:background .15s;display:flex}.navbar-avatar-btn:hover{background:#ffffff1a}.navbar-avatar{color:#ffffffeb;letter-spacing:.02em;background:#7b2fe080;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.navbar-avatar-chevron{color:#fff6;transition:transform .2s}.navbar-avatar-chevron.open{transform:rotate(180deg)}.profile-popover{z-index:100;transform-origin:100% 0;background:#fff;border-radius:14px;width:264px;animation:.18s both scaleIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 32px #00000038}.profile-popover-header{border-bottom:1px solid #f0f0f0;align-items:center;gap:10px;padding:14px 16px;display:flex}.profile-popover-avatar{background:var(--purple-faint);width:36px;height:36px;color:var(--purple);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:28px;display:flex}.page-title{color:var(--black);font-size:26px;line-height:1.2}.page-sub{color:#aaa;margin-top:3px;font-size:13px}.tab-bar{background:var(--mist);border-radius:10px;gap:4px;padding:4px;display:flex}.tab-btn{color:#888;cursor:pointer;background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;padding:7px 14px;font-family:Inter,sans-serif;font-size:13px;transition:all .15s;display:flex}.tab-btn.active{background:var(--white);color:var(--black);font-weight:500;box-shadow:0 1px 4px #00000014}.tab-count{background:var(--purple-faint);color:var(--purple);text-align:center;border-radius:20px;min-width:18px;padding:1px 6px;font-size:10px;font-weight:600}.notice-banner{color:#96600a;background:#fff7e6;border:1px solid #f5cfa0;border-radius:10px;margin-bottom:24px;padding:12px 16px;font-size:13px}.booking-layout{grid-template-columns:280px 1fr;align-items:start;gap:24px;display:grid}.booking-col-left{flex-direction:column;display:flex}.booking-col-right{min-width:0}.panel-card{background:var(--warm-white);border:1px solid var(--mist);border-radius:14px;padding:22px}.section-label{color:#aaa;letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:600}.cap-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cap-track{background:var(--mist);border-radius:99px;height:5px;overflow:hidden}.cap-fill{border-radius:99px;height:100%;transition:width .4s,background .3s}.fup-card{background:var(--white);border:1px solid #e0d9f7;border-radius:12px;padding:14px 16px}.fup-mobile-only{display:none}@media (width<=640px){.fup-desktop-only{display:none}.fup-mobile-only{display:block}}.fup-title{letter-spacing:.07em;text-transform:uppercase;color:var(--purple);margin-bottom:10px;font-size:11px;font-weight:800}.fup-list{flex-direction:column;gap:6px;margin:0;padding-left:0;list-style:none;display:flex}.fup-list li{color:#444;padding-left:16px;font-size:12.5px;line-height:1.45;position:relative}.fup-list li:before{content:"›";color:var(--purple);font-size:14px;font-weight:700;line-height:1.3;position:absolute;left:0}.fup-contact{border-top:1px solid #c9b8f8;justify-content:space-between;align-items:center;margin-top:12px;padding-top:10px;display:flex}.fup-contact-name{color:#444;font-size:12.5px;font-weight:700}.fup-contact-num{color:var(--purple);letter-spacing:.01em;background:#fff9;border:1px solid #c9b8f8;border-radius:20px;padding:3px 8px;font-size:12.5px;font-weight:700;text-decoration:none}.fup-contact-num:hover{background:var(--purple);color:#fff;border-color:var(--purple)}.room-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.room-card{background:var(--white);border:1.5px solid var(--mist);text-align:left;cursor:pointer;border-radius:14px;flex-direction:column;gap:10px;padding:18px;transition:all .18s;display:flex}.room-card:hover{border-color:var(--purple-mid);transform:translateY(-2px);box-shadow:0 4px 16px #5309c71f}.room-card-selected{border-color:var(--purple);background:var(--purple-faint);box-shadow:0 0 0 3px #5309c726}.room-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.room-card-name{color:var(--black);font-size:14px;font-weight:600;line-height:1.3}.room-card-loc{color:#aaa;margin-top:2px;font-size:11.5px}.capacity-badge{background:var(--purple-faint);color:var(--purple);white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:flex}.amenity-chips{flex-wrap:wrap;gap:5px;display:flex}.amenity-chip{background:var(--ghost);border:1px solid var(--mist);color:#777;cursor:pointer;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-family:Inter,sans-serif;font-size:11px;transition:all .12s;display:inline-flex}.amenity-chip.selected{background:var(--purple-faint);border-color:var(--purple-mid);color:var(--purple)}.room-card-footer{border-top:1px solid var(--mist);justify-content:space-between;align-items:center;margin-top:auto;padding-top:6px;display:flex}.room-avail-badge{font-size:11.5px}.room-avail-badge.avail{color:#3d8a5c}.room-avail-badge.partial{color:#888}.room-card-cta{color:var(--purple);font-size:11px;font-weight:500}.slot-grid{grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:14px;display:grid}.slot-hint{background:var(--purple-faint);color:var(--black);border-radius:9px;align-items:center;gap:6px;margin-bottom:12px;padding:9px 13px;font-size:12.5px;display:flex}.slot-hint.selected{background:#5309c70f}.slot-clear-btn{color:var(--purple);cursor:pointer;background:0 0;border:none;margin-left:auto;font-family:Inter,sans-serif;font-size:11px;text-decoration:underline}.slot-legend{flex-wrap:wrap;align-items:center;gap:16px;margin-top:14px;display:flex}.slot-available{background:var(--white);border:1.5px solid var(--mist);color:var(--black);cursor:pointer;transition:all .15s}.slot-available:hover{border-color:var(--purple);background:var(--purple-faint);transform:translateY(-1px);box-shadow:0 2px 8px #5309c72e}.slot-selected{background:var(--purple);border:1.5px solid var(--purple);color:var(--white);cursor:pointer}.slot-booked{background:var(--mist);color:#999;cursor:not-allowed;border:1.5px solid #d8d0ea}.slot-past{background:var(--ghost);color:#ccc;cursor:not-allowed;border:1.5px dashed #ddd8ea}.slot-cap-warn{color:var(--rust);cursor:not-allowed;background:#fff3ee;border:1.5px solid #e8b4a0}.slot-booked-own{background:var(--purple-faint);border:1.5px solid var(--purple-mid);color:var(--purple);cursor:not-allowed;opacity:.75}.cal-day{border-radius:8px;justify-content:center;align-items:center;width:min(36px,100%);height:36px;margin:0 auto;font-size:13px;font-weight:400;transition:all .15s;display:flex}.cal-day-available{cursor:pointer}.cal-day-available:hover{background:var(--mist)}.cal-day-selected{background:var(--purple)!important;color:#fff!important}.cal-day-today{color:var(--purple);font-weight:600}.cal-day-past{color:#ccc;cursor:not-allowed}.cal-day-outside{color:#d8d0ea}.cal-day-wrapper{text-align:center;position:relative}.slot-btn{text-align:center;border-radius:8px;padding:8px 6px;font-family:Inter,sans-serif;font-size:12px;line-height:1.3;transition:all .15s}.book-now-btn{background:var(--purple);color:#fff;cursor:pointer;letter-spacing:.01em;border:none;border-radius:10px;width:100%;margin-top:18px;padding:14px 0;font-family:Inter,sans-serif;font-size:14px;font-weight:500;transition:opacity .2s,transform .15s}.book-now-btn:hover{opacity:.88;transform:translateY(-1px)}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:100;background:#120d1e8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--white);border-radius:18px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 24px 60px #0000002e}.login-shell{background:linear-gradient(135deg,#120340 0%,#1d0463 50%,#3508a8 100%);justify-content:center;align-items:center;min-height:100svh;padding:20px;display:flex}.login-card{background:var(--white);border-radius:20px;width:100%;max-width:400px;padding:36px 32px;box-shadow:0 32px 80px #0000004d}.login-brand{text-align:center;margin-bottom:28px}.login-logo{height:52px;margin:0 auto;display:block}.login-title{color:var(--black);margin-top:14px;font-size:28px;font-weight:700}.login-tabs{border-bottom:2px solid var(--mist);gap:0;margin-bottom:24px;display:flex}.login-tab{color:#aaa;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:10px 0;font-family:Inter,sans-serif;font-size:13px;transition:all .15s}.login-tab.active{color:var(--purple);border-bottom-color:var(--purple);font-weight:600}.login-form{flex-direction:column;gap:16px;display:flex}.login-footer-note{text-align:center;color:#ccc;margin-top:20px;font-size:11px}.form-group{flex-direction:column;display:flex}.form-label{color:#777;letter-spacing:.02em;margin-bottom:6px;font-size:12px;font-weight:500}.form-input{border:1.5px solid var(--mist);background:var(--white);color:var(--black);border-radius:9px;outline:none;width:100%;padding:10px 12px;font-family:Inter,sans-serif;font-size:13.5px;transition:border-color .15s}.form-input:focus{border-color:var(--purple-mid);box-shadow:0 0 0 3px #5309c71a}select.form-input{cursor:pointer}.form-row{gap:12px;margin-top:12px;display:flex}.form-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.input-with-icon{position:relative}.input-with-icon .form-input{padding-right:38px}.input-eye-btn{color:#aaa;cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.form-error{color:var(--rust);background:#fff0ed;border:1px solid #fbbcb0;border-radius:8px;padding:10px 13px;font-size:12.5px;line-height:1.5}.form-success{color:#2e7d52;background:#f0fbf5;border:1px solid #9fd7b4;border-radius:8px;padding:10px 13px;font-size:12.5px}.btn-primary{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:11px 20px;font-family:Inter,sans-serif;font-size:13.5px;font-weight:500;transition:opacity .2s}.btn-primary:hover:not(:disabled){opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:#888;border:1.5px solid var(--mist);cursor:pointer;background:0 0;border-radius:9px;padding:10px 16px;font-family:Inter,sans-serif;font-size:13px;transition:all .15s}.btn-ghost:hover{color:#555;border-color:#ccc}.btn-sm-primary{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:5px;padding:7px 13px;font-family:Inter,sans-serif;font-size:12.5px;font-weight:500;transition:opacity .15s;display:inline-flex}.btn-sm-primary:hover{opacity:.88}.icon-btn{border:1.5px solid var(--mist);color:#888;cursor:pointer;background:0 0;border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:flex}.icon-btn:hover{border-color:var(--purple-mid);color:var(--purple)}.icon-btn.danger:hover{border-color:var(--rust);color:var(--rust)}.admin-tabs{flex-wrap:wrap;gap:6px;display:flex}.admin-tab-btn{border:1.5px solid var(--mist);background:var(--white);color:#888;cursor:pointer;border-radius:9px;padding:8px 16px;font-family:Inter,sans-serif;font-size:13px;transition:all .15s}.admin-tab-btn.active{background:var(--purple);border-color:var(--purple);color:#fff;font-weight:500}.admin-section{flex-direction:column;gap:16px;display:flex}.admin-section-hdr{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.admin-form-card{background:var(--white);border:1.5px solid var(--purple-faint);border-radius:12px;padding:20px;box-shadow:0 4px 20px #5309c714}.admin-table{flex-direction:column;gap:2px;display:flex}.admin-row{background:var(--white);border:1px solid var(--mist);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;transition:border-color .15s;display:flex}.admin-row:hover{border-color:#d0c8e8}.admin-row-title{font-size:13.5px;font-weight:500}.admin-row-sub{color:#999;margin-top:2px;font-size:12px}.admin-row-actions{flex-shrink:0;gap:6px;display:flex}.role-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.role-badge.admin{background:var(--purple-faint);color:var(--purple)}.role-badge.user{background:var(--ghost);color:#888}.badge-muted{background:var(--mist);color:#aaa;border-radius:20px;padding:2px 7px;font-size:10px;display:inline-block}.badge-company{background:var(--purple-faint);color:var(--purple);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.users-table{border:1px solid var(--mist);background:var(--white);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.users-row{border-top:1px solid var(--mist);grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px 16px;transition:background .1s;display:grid}.users-row:hover{background:var(--off-white)}.users-row.is-self{background:#5309c708}.users-row-info{align-items:center;gap:10px;min-width:0;display:flex}.users-row-text{min-width:0}.users-row-name-line{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.users-self-tag{color:var(--purple);background:var(--purple-faint);letter-spacing:.02em;border-radius:4px;flex-shrink:0;padding:1px 7px;font-size:10px;font-weight:600}.users-saving-tag{color:#aaa;flex-shrink:0;font-size:11px}.users-row-controls{align-items:center;gap:8px;display:flex}.users-row-controls .inline-select{width:auto;min-width:110px}.user-initials-badge{background:var(--purple-faint);width:34px;height:34px;color:var(--purple);letter-spacing:.02em;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.users-row-name{font-size:13px;font-weight:500}.users-row-email{color:#aaa;white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:11.5px;overflow:hidden}.inline-select{border:1.5px solid var(--mist);background:var(--white);color:var(--black);cursor:pointer;border-radius:8px;outline:none;width:100%;padding:6px 10px;font-family:Inter,sans-serif;font-size:12.5px;transition:border-color .15s}.inline-select:focus{border-color:var(--purple-mid)}.inline-select:disabled{opacity:.45;cursor:not-allowed}.role-select.admin{border-color:var(--purple-mid);background:var(--purple-faint);color:var(--purple);font-weight:600}.role-select.user{border-color:var(--mist);color:#666}.my-bookings-wrap{width:100%}.my-bookings-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.my-bookings-count-pill{background:var(--purple);color:#fff;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700}.my-bookings-list{flex-direction:column;gap:10px;display:flex}.my-booking-card{background:var(--white);border:1.5px solid var(--mist);border-radius:14px;align-items:center;gap:18px;padding:18px 20px;transition:box-shadow .15s;display:flex}.my-booking-card:hover{box-shadow:0 4px 18px #5309c717}.my-booking-date-badge{background:var(--purple-faint);text-align:center;border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;min-width:52px;padding:10px 8px;display:flex}.mbd-weekday{color:var(--purple-mid);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.mbd-day{color:var(--purple);margin-top:1px;font-size:22px;font-weight:700;line-height:1.1}.mbd-month{color:var(--purple-mid);text-transform:uppercase;letter-spacing:.04em;margin-top:1px;font-size:10px;font-weight:500}.my-booking-info{flex:1;min-width:0}.my-booking-room{margin-bottom:3px;font-size:15px;font-weight:600}.my-booking-location{color:#aaa;margin-bottom:5px;font-size:12px}.my-booking-time{color:#555;font-size:13px;font-weight:500}.my-booking-duration{color:#aaa;font-size:12px}.my-booking-cancel{color:var(--rust);cursor:pointer;background:0 0;border:1.5px solid #ffcfc7;border-radius:8px;flex-shrink:0;padding:7px 14px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:all .15s}.my-booking-cancel:hover:not(:disabled){border-color:var(--rust);background:#fff3f1}.my-booking-cancel:disabled{opacity:.5;cursor:not-allowed}.empty-state{color:#bbb;text-align:center;background:var(--white);border:1.5px dashed var(--mist);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;font-size:13.5px;display:flex}.spinner{border:2.5px solid var(--mist);border-top-color:var(--purple);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.anim-fade-in-up{animation:.4s both fadeInUp}.anim-fade-in{animation:.3s both fadeIn}.anim-scale-in{animation:.25s both scaleIn}.anim-slide-in{animation:.35s both slideInRight}.skeleton{background:linear-gradient(90deg, var(--mist) 25%, var(--ghost) 50%, var(--mist) 75%);background-size:200% 100%;animation:1.4s infinite shimmer}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.gap-1\.5{gap:6px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.cal-panel-hdr{align-items:center;gap:8px;margin-bottom:16px;display:flex}.cal-toggle-icon{color:#aaa;flex-shrink:0;transition:transform .25s;display:none}.cal-toggle-icon.open{transform:rotate(180deg)}.cal-date-chip{color:var(--purple);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:12px;font-weight:500;display:none;overflow:hidden}.cal-body{overflow:visible}@media (width<=640px){.cal-body{opacity:1;max-height:500px;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s;overflow:hidden}.cal-body.closed{opacity:0;max-height:0}}.analytics-page{background:#f8fafc;min-height:100vh;padding:32px 36px}@media (width<=900px){.booking-layout{grid-template-columns:1fr}}@media (width<=640px){.content-area{padding:16px 14px}.page-header{flex-direction:column;gap:10px}.tab-bar{justify-content:center;align-self:stretch}.page-title{font-size:22px}.navbar{margin:10px 12px 0;padding:0 12px;top:10px}.navbar-link span{display:none}.navbar-link{padding:7px 9px}.navbar-brand-divider,.navbar-sub{display:none}.profile-popover{width:calc(100vw - 24px);max-width:300px;position:fixed;top:64px;right:12px}.room-grid{grid-template-columns:1fr}.slot-grid{grid-template-columns:repeat(3,1fr);gap:5px}.slot-legend{gap:10px;margin-top:10px}.slot-btn{padding:7px 4px;font-size:11px}.panel-card{border-radius:12px;padding:16px}.cal-panel-hdr{cursor:pointer;justify-content:space-between;margin-bottom:0;padding:2px 0}.cal-panel-hdr:hover .cal-toggle-icon{color:var(--purple)}.cal-toggle-icon{display:flex}.cal-date-chip{display:block}.modal-overlay{align-items:flex-end;padding:0}.modal-panel{border-radius:20px 20px 0 0;max-width:100%}.book-now-btn{position:sticky;bottom:16px;box-shadow:0 4px 20px #5309c759}.admin-tabs{flex-wrap:nowrap;gap:4px;padding-bottom:4px;overflow-x:auto}.admin-tab-btn{white-space:nowrap;flex-shrink:0;padding:6px 12px;font-size:12px}.admin-form-card{padding:16px}.admin-section-hdr{flex-wrap:wrap;gap:8px}.form-row{flex-direction:column}.form-row-2{grid-template-columns:1fr}.users-row{flex-direction:column;gap:10px;padding:14px 16px;display:flex}.users-row-controls{grid-template-columns:1fr 1fr;gap:8px;display:grid}.users-row-controls .inline-select{width:100%;min-width:0}.my-booking-time{font-size:11px}.my-booking-card{gap:12px;padding:14px 16px}.my-booking-date-badge{min-width:44px}.analytics-page{padding:16px 14px}}.bookings-card-list{display:none}@media (width<=640px){.bookings-table-wrap{display:none}.bookings-card-list{flex-direction:column;gap:8px;display:flex}}.analytics-header{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:20px;display:flex}.analytics-header h1{align-items:center;gap:8px;margin:0;font-size:20px;font-weight:600;display:flex}.analytics-controls{align-items:center;gap:16px;margin-bottom:24px;display:flex}.period-toggle{border:1px solid var(--border-color);background:#fff;border-radius:8px;gap:4px;padding:4px;display:flex}.period-toggle button{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.period-toggle button.active{color:#fff;background:#5309c7}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;align-items:flex-start;gap:16px;padding:20px;display:flex}.stat-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-content{flex:1}.stat-label{color:#666;margin:0 0 4px;font-size:12px}.stat-value{color:#111;margin:0 0 4px;font-size:28px;font-weight:600}.stat-sub{color:#888;margin:0;font-size:12px}.analytics-tabs{border-bottom:1px solid var(--border-color);gap:24px;margin-bottom:16px;display:flex}.analytics-tab{color:#666;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 0;font-size:14px;font-weight:500}.analytics-tab.active{color:#5309c7;border-bottom-color:#5309c7}.analytics-filters{gap:12px;margin-bottom:24px;display:flex}.analytics-filter{border:1px solid var(--border-color);color:#444;cursor:pointer;background:#fff;border-radius:6px;padding:8px 12px;font-size:13px}.chart-section{border:1px solid var(--border-color);background:#fff;border-radius:12px;margin-bottom:24px;padding:24px}.chart-header{margin-bottom:24px}.chart-title{margin:0 0 4px;font-size:16px;font-weight:600}.chart-subtitle{color:#666;margin:0;font-size:13px}.data-table-container{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;color:#666;border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border-color);color:#111;padding:16px;font-weight:500}.progress-bar-bg{vertical-align:middle;background:#eee;border-radius:3px;width:100px;height:6px;margin-right:8px;display:inline-block;overflow:hidden}.progress-bar-fill{background:#10b981;border-radius:3px;height:100%}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
