@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600,700&family=Inter:wght@300,400,500,600,700&display=swap";.animate-up{animation:fadeInUp .6s cubic-bezier(.33,1,.68,1) forwards}.room-card{transition:transform .2s ease,box-shadow .2s ease}.room-card:active{transform:scale(.97)}.hero-section{transition:all .4s ease}.animate-list-item{animation:fadeInUp .5s cubic-bezier(.33,1,.68,1) forwards}.room-card:active{transform:scale(.98);transition:transform .1s}.search-section{padding:8px 16px;background:#fff}.type-filters{display:flex;overflow-x:auto;padding:8px 16px 16px;gap:8px;background:#fff;-webkit-overflow-scrolling:touch}.type-filters::-webkit-scrollbar{display:none}.type-filter-btn{padding:8px 16px;border-radius:20px;border:none;background:#f1f5f9;color:#64748b;font-weight:600;font-size:13px;white-space:nowrap;transition:all .2s ease}.type-filter-btn.active{background:#0077b6;color:#fff;box-shadow:0 4px 12px #0077b633}.rooms-section{padding:16px}.room-card{background:#fff;border-radius:16px;overflow:hidden;margin-bottom:20px;box-shadow:0 4px 20px #0000000f;position:relative}.room-card-image{position:relative;height:200px}.room-card-img{width:100%;height:100%;object-fit:cover}.room-card-placeholder{background:#f1f5f9;display:flex;align-items:center;justify-content:center;font-size:48px}.room-price-badge{position:absolute;bottom:12px;left:12px;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;padding:4px 12px;border-radius:8px;font-weight:700;font-size:14px}.status-badge-mini{position:absolute;top:12px;left:12px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;color:#fff}.status-badge-mini.available{background:#10b981}.status-badge-mini.unavailable{background:#ef4444}.favorite-btn{position:absolute;top:12px;right:12px;background:#ffffffe6;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;cursor:pointer}.room-card-title{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 4px}.room-card-type{font-size:13px;color:#64748b;margin-bottom:8px}.room-card-desc{font-size:14px;color:#475569;line-height:1.5;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.room-amenities{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.amenity-chip{background:#f8fafc;color:#64748b;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500;border:1px solid #F1F5F9}.room-actions{display:flex;gap:10px}.room-btn-outline,.room-btn-primary{flex:1;padding:10px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.room-btn-outline{background:#fff;border:1.5px solid #0077B6;color:#0077b6}.room-btn-primary{background:#0077b6;border:none;color:#fff}.room-btn-primary:active{transform:scale(.96)}.empty-state{text-align:center;padding:60px 24px}.empty-icon{font-size:64px;margin-bottom:16px}.empty-title{font-size:18px;font-weight:700;color:#1e293b;margin-bottom:8px}.empty-subtitle{font-size:14px;color:#64748b}.room-skeleton-text{background:#f1f5f9;height:16px;border-radius:4px;margin-bottom:8px}@keyframes slideInUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.detail-content{animation:slideInUp .6s cubic-bezier(.22,1,.36,1) forwards}.gallery-container{transition:opacity .5s ease-in}.booking-card-animate{animation:fadeInUp .5s ease-out forwards}@keyframes slideFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.profile-content{animation:slideFadeIn .6s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.msg-animate{animation:fadeIn .4s ease-out forwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.notif-card{animation:fadeInUp .5s cubic-bezier(.33,1,.68,1) forwards}html.ios{--ion-default-font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Roboto", sans-serif}html.md{--ion-default-font: "Roboto", "Helvetica Neue", sans-serif}html{--ion-default-dynamic-font: -apple-system-body;--ion-font-family: var(--ion-default-font)}body{background:var(--ion-background-color)}body.backdrop-no-scroll{overflow:hidden}html.ios ion-modal.modal-card ion-header ion-toolbar:first-of-type,html.ios ion-modal.modal-sheet ion-header ion-toolbar:first-of-type,html.ios ion-modal ion-footer ion-toolbar:first-of-type{padding-top:6px}html.ios ion-modal.modal-card ion-header ion-toolbar:last-of-type,html.ios ion-modal.modal-sheet ion-header ion-toolbar:last-of-type{padding-bottom:6px}html.ios ion-modal ion-toolbar{padding-right:calc(var(--ion-safe-area-right) + 8px);padding-left:calc(var(--ion-safe-area-left) + 8px)}@media screen and (min-width: 768px){html.ios ion-modal.modal-card:first-of-type{--backdrop-opacity: .18}}ion-modal.modal-default.show-modal~ion-modal.modal-default{--backdrop-opacity: 0;--box-shadow: none}html.ios ion-modal.modal-card .ion-page{border-top-left-radius:var(--border-radius)}.ion-color-primary{--ion-color-base: var(--ion-color-primary, #3880ff) !important;--ion-color-base-rgb: var(--ion-color-primary-rgb, 56, 128, 255) !important;--ion-color-contrast: var(--ion-color-primary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-primary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-primary-shade, #3171e0) !important;--ion-color-tint: var(--ion-color-primary-tint, #4c8dff) !important}.ion-color-secondary{--ion-color-base: var(--ion-color-secondary, #3dc2ff) !important;--ion-color-base-rgb: var(--ion-color-secondary-rgb, 61, 194, 255) !important;--ion-color-contrast: var(--ion-color-secondary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-secondary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-secondary-shade, #36abe0) !important;--ion-color-tint: var(--ion-color-secondary-tint, #50c8ff) !important}.ion-color-tertiary{--ion-color-base: var(--ion-color-tertiary, #5260ff) !important;--ion-color-base-rgb: var(--ion-color-tertiary-rgb, 82, 96, 255) !important;--ion-color-contrast: var(--ion-color-tertiary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-tertiary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-tertiary-shade, #4854e0) !important;--ion-color-tint: var(--ion-color-tertiary-tint, #6370ff) !important}.ion-color-success{--ion-color-base: var(--ion-color-success, #2dd36f) !important;--ion-color-base-rgb: var(--ion-color-success-rgb, 45, 211, 111) !important;--ion-color-contrast: var(--ion-color-success-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-success-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-success-shade, #28ba62) !important;--ion-color-tint: var(--ion-color-success-tint, #42d77d) !important}.ion-color-warning{--ion-color-base: var(--ion-color-warning, #ffc409) !important;--ion-color-base-rgb: var(--ion-color-warning-rgb, 255, 196, 9) !important;--ion-color-contrast: var(--ion-color-warning-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-warning-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-warning-shade, #e0ac08) !important;--ion-color-tint: var(--ion-color-warning-tint, #ffca22) !important}.ion-color-danger{--ion-color-base: var(--ion-color-danger, #eb445a) !important;--ion-color-base-rgb: var(--ion-color-danger-rgb, 235, 68, 90) !important;--ion-color-contrast: var(--ion-color-danger-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-danger-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-danger-shade, #cf3c4f) !important;--ion-color-tint: var(--ion-color-danger-tint, #ed576b) !important}.ion-color-light{--ion-color-base: var(--ion-color-light, #f4f5f8) !important;--ion-color-base-rgb: var(--ion-color-light-rgb, 244, 245, 248) !important;--ion-color-contrast: var(--ion-color-light-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-light-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-light-shade, #d7d8da) !important;--ion-color-tint: var(--ion-color-light-tint, #f5f6f9) !important}.ion-color-medium{--ion-color-base: var(--ion-color-medium, #92949c) !important;--ion-color-base-rgb: var(--ion-color-medium-rgb, 146, 148, 156) !important;--ion-color-contrast: var(--ion-color-medium-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-medium-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-medium-shade, #808289) !important;--ion-color-tint: var(--ion-color-medium-tint, #9d9fa6) !important}.ion-color-dark{--ion-color-base: var(--ion-color-dark, #222428) !important;--ion-color-base-rgb: var(--ion-color-dark-rgb, 34, 36, 40) !important;--ion-color-contrast: var(--ion-color-dark-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-dark-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-dark-shade, #1e2023) !important;--ion-color-tint: var(--ion-color-dark-tint, #383a3e) !important}.ion-page{left:0;right:0;top:0;bottom:0;display:flex;position:absolute;flex-direction:column;justify-content:space-between;contain:layout size style;z-index:0}ion-modal>.ion-page{position:relative;contain:layout style;height:100%}.split-pane-visible>.ion-page.split-pane-main{position:relative}ion-route,ion-route-redirect,ion-router,ion-select-option,ion-nav-controller,ion-menu-controller,ion-action-sheet-controller,ion-alert-controller,ion-loading-controller,ion-modal-controller,ion-picker-controller,ion-popover-controller,ion-toast-controller,.ion-page-hidden{display:none!important}.ion-page-invisible{opacity:0}.can-go-back>ion-header ion-back-button{display:block}html.plt-ios.plt-hybrid,html.plt-ios.plt-pwa{--ion-statusbar-padding: 20px}@supports (padding-top: 20px){html{--ion-safe-area-top: var(--ion-statusbar-padding)}}@supports (padding-top: env(safe-area-inset-top)){html{--ion-safe-area-top: env(safe-area-inset-top);--ion-safe-area-bottom: env(safe-area-inset-bottom);--ion-safe-area-left: env(safe-area-inset-left);--ion-safe-area-right: env(safe-area-inset-right)}}ion-card.ion-color .ion-inherit-color,ion-card-header.ion-color .ion-inherit-color{color:inherit}.menu-content{transform:translateZ(0)}.menu-content-open{cursor:pointer;touch-action:manipulation;pointer-events:none;overflow-y:hidden}.menu-content-open ion-content{--overflow: hidden}.menu-content-open .ion-content-scroll-host{overflow:hidden}.ios .menu-content-reveal{box-shadow:-8px 0 42px #00000014}[dir=rtl].ios .menu-content-reveal{box-shadow:8px 0 42px #00000014}.md .menu-content-reveal,.md .menu-content-push{box-shadow:4px 0 16px #0000002e}ion-accordion-group.accordion-group-expand-inset>ion-accordion:first-of-type{border-top-left-radius:8px;border-top-right-radius:8px}ion-accordion-group.accordion-group-expand-inset>ion-accordion:last-of-type{border-bottom-left-radius:8px;border-bottom-right-radius:8px}ion-accordion-group>ion-accordion:last-of-type ion-item[slot=header]{--border-width: 0px}ion-accordion.accordion-animated>[slot=header] .ion-accordion-toggle-icon{transition:.3s transform cubic-bezier(.25,.8,.5,1)}@media (prefers-reduced-motion: reduce){ion-accordion .ion-accordion-toggle-icon{transition:none!important}}ion-accordion.accordion-expanding>[slot=header] .ion-accordion-toggle-icon,ion-accordion.accordion-expanded>[slot=header] .ion-accordion-toggle-icon{transform:rotate(180deg)}ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-previous ion-item[slot=header]{--border-width: 0px;--inner-border-width: 0px}ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-expanding:first-of-type,ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-expanded:first-of-type{margin-top:0}ion-input input::-webkit-date-and-time-value{text-align:start}.ion-datetime-button-overlay{--width: fit-content;--height: fit-content}.ion-datetime-button-overlay ion-datetime.datetime-grid{width:320px;min-height:320px}.popover-viewport:has(>ion-content){overflow:hidden}@supports not selector(:has(> ion-content)){.popover-viewport{overflow:hidden}}audio,canvas,progress,video{vertical-align:baseline}audio:not([controls]){display:none;height:0}b,strong{font-weight:700}img{max-width:100%}hr{height:1px;border-width:0;box-sizing:content-box}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}label,input,select,textarea{font-family:inherit;line-height:normal}textarea{overflow:auto;height:auto;font:inherit;color:inherit}textarea::placeholder{padding-left:2px}form,input,optgroup,select{margin:0;font:inherit;color:inherit}html input[type=button],input[type=reset],input[type=submit]{cursor:pointer;-webkit-appearance:button}a,a div,a span,a ion-icon,a ion-label,button,button div,button span,button ion-icon,button ion-label,.ion-tappable,[tappable],[tappable] div,[tappable] span,[tappable] ion-icon,[tappable] ion-label,input,textarea{touch-action:manipulation}a ion-label,button ion-label{pointer-events:none}button{padding:0;border:0;border-radius:0;font-family:inherit;font-style:inherit;font-variant:inherit;line-height:1;text-transform:none;cursor:pointer;-webkit-appearance:button}[tappable]{cursor:pointer}a[disabled],button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}*{box-sizing:border-box;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{width:100%;height:100%;-webkit-text-size-adjust:100%;text-size-adjust:100%}html:not(.hydrated) body{display:none}html.ion-ce body{display:block}html.plt-pwa{height:100vh}body{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin:0;padding:0;position:fixed;width:100%;max-width:100%;height:100%;max-height:100%;transform:translateZ(0);text-rendering:optimizeLegibility;overflow:hidden;touch-action:manipulation;-webkit-user-drag:none;-ms-content-zooming:none;word-wrap:break-word;overscroll-behavior-y:none;-webkit-text-size-adjust:none;text-size-adjust:none}html{font-family:var(--ion-font-family)}@supports (-webkit-touch-callout: none){html{font:var(--ion-dynamic-font, 16px var(--ion-font-family))}}a{background-color:transparent;color:var(--ion-color-primary, #3880ff)}h1,h2,h3,h4,h5,h6{margin-top:16px;margin-bottom:10px;font-weight:500;line-height:1.2}h1{margin-top:20px;font-size:1.625rem}h2{margin-top:18px;font-size:1.5rem}h3{font-size:1.375rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}small{font-size:75%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}.ion-no-padding{--padding-start: 0;--padding-end: 0;--padding-top: 0;--padding-bottom: 0;padding:0}.ion-padding{--padding-start: var(--ion-padding, 16px);--padding-end: var(--ion-padding, 16px);--padding-top: var(--ion-padding, 16px);--padding-bottom: var(--ion-padding, 16px);-webkit-padding-start:var(--ion-padding, 16px);padding-inline-start:var(--ion-padding, 16px);-webkit-padding-end:var(--ion-padding, 16px);padding-inline-end:var(--ion-padding, 16px);padding-top:var(--ion-padding, 16px);padding-bottom:var(--ion-padding, 16px)}.ion-padding-top{--padding-top: var(--ion-padding, 16px);padding-top:var(--ion-padding, 16px)}.ion-padding-start{--padding-start: var(--ion-padding, 16px);-webkit-padding-start:var(--ion-padding, 16px);padding-inline-start:var(--ion-padding, 16px)}.ion-padding-end{--padding-end: var(--ion-padding, 16px);-webkit-padding-end:var(--ion-padding, 16px);padding-inline-end:var(--ion-padding, 16px)}.ion-padding-bottom{--padding-bottom: var(--ion-padding, 16px);padding-bottom:var(--ion-padding, 16px)}.ion-padding-vertical{--padding-top: var(--ion-padding, 16px);--padding-bottom: var(--ion-padding, 16px);padding-top:var(--ion-padding, 16px);padding-bottom:var(--ion-padding, 16px)}.ion-padding-horizontal{--padding-start: var(--ion-padding, 16px);--padding-end: var(--ion-padding, 16px);-webkit-padding-start:var(--ion-padding, 16px);padding-inline-start:var(--ion-padding, 16px);-webkit-padding-end:var(--ion-padding, 16px);padding-inline-end:var(--ion-padding, 16px)}.ion-no-margin{--margin-start: 0;--margin-end: 0;--margin-top: 0;--margin-bottom: 0;margin:0}.ion-margin{--margin-start: var(--ion-margin, 16px);--margin-end: var(--ion-margin, 16px);--margin-top: var(--ion-margin, 16px);--margin-bottom: var(--ion-margin, 16px);-webkit-margin-start:var(--ion-margin, 16px);margin-inline-start:var(--ion-margin, 16px);-webkit-margin-end:var(--ion-margin, 16px);margin-inline-end:var(--ion-margin, 16px);margin-top:var(--ion-margin, 16px);margin-bottom:var(--ion-margin, 16px)}.ion-margin-top{--margin-top: var(--ion-margin, 16px);margin-top:var(--ion-margin, 16px)}.ion-margin-start{--margin-start: var(--ion-margin, 16px);-webkit-margin-start:var(--ion-margin, 16px);margin-inline-start:var(--ion-margin, 16px)}.ion-margin-end{--margin-end: var(--ion-margin, 16px);-webkit-margin-end:var(--ion-margin, 16px);margin-inline-end:var(--ion-margin, 16px)}.ion-margin-bottom{--margin-bottom: var(--ion-margin, 16px);margin-bottom:var(--ion-margin, 16px)}.ion-margin-vertical{--margin-top: var(--ion-margin, 16px);--margin-bottom: var(--ion-margin, 16px);margin-top:var(--ion-margin, 16px);margin-bottom:var(--ion-margin, 16px)}.ion-margin-horizontal{--margin-start: var(--ion-margin, 16px);--margin-end: var(--ion-margin, 16px);-webkit-margin-start:var(--ion-margin, 16px);margin-inline-start:var(--ion-margin, 16px);-webkit-margin-end:var(--ion-margin, 16px);margin-inline-end:var(--ion-margin, 16px)}.ion-float-left{float:left!important}.ion-float-right{float:right!important}.ion-float-start{float:left!important}:host-context([dir=rtl]) .ion-float-start{float:right!important}[dir=rtl] .ion-float-start{float:right!important}@supports selector(:dir(rtl)){.ion-float-start:dir(rtl){float:right!important}}.ion-float-end{float:right!important}:host-context([dir=rtl]) .ion-float-end{float:left!important}[dir=rtl] .ion-float-end{float:left!important}@supports selector(:dir(rtl)){.ion-float-end:dir(rtl){float:left!important}}@media (min-width: 576px){.ion-float-sm-left{float:left!important}.ion-float-sm-right{float:right!important}.ion-float-sm-start{float:left!important}:host-context([dir=rtl]) .ion-float-sm-start{float:right!important}[dir=rtl] .ion-float-sm-start{float:right!important}@supports selector(:dir(rtl)){.ion-float-sm-start:dir(rtl){float:right!important}}.ion-float-sm-end{float:right!important}:host-context([dir=rtl]) .ion-float-sm-end{float:left!important}[dir=rtl] .ion-float-sm-end{float:left!important}@supports selector(:dir(rtl)){.ion-float-sm-end:dir(rtl){float:left!important}}}@media (min-width: 768px){.ion-float-md-left{float:left!important}.ion-float-md-right{float:right!important}.ion-float-md-start{float:left!important}:host-context([dir=rtl]) .ion-float-md-start{float:right!important}[dir=rtl] .ion-float-md-start{float:right!important}@supports selector(:dir(rtl)){.ion-float-md-start:dir(rtl){float:right!important}}.ion-float-md-end{float:right!important}:host-context([dir=rtl]) .ion-float-md-end{float:left!important}[dir=rtl] .ion-float-md-end{float:left!important}@supports selector(:dir(rtl)){.ion-float-md-end:dir(rtl){float:left!important}}}@media (min-width: 992px){.ion-float-lg-left{float:left!important}.ion-float-lg-right{float:right!important}.ion-float-lg-start{float:left!important}:host-context([dir=rtl]) .ion-float-lg-start{float:right!important}[dir=rtl] .ion-float-lg-start{float:right!important}@supports selector(:dir(rtl)){.ion-float-lg-start:dir(rtl){float:right!important}}.ion-float-lg-end{float:right!important}:host-context([dir=rtl]) .ion-float-lg-end{float:left!important}[dir=rtl] .ion-float-lg-end{float:left!important}@supports selector(:dir(rtl)){.ion-float-lg-end:dir(rtl){float:left!important}}}@media (min-width: 1200px){.ion-float-xl-left{float:left!important}.ion-float-xl-right{float:right!important}.ion-float-xl-start{float:left!important}:host-context([dir=rtl]) .ion-float-xl-start{float:right!important}[dir=rtl] .ion-float-xl-start{float:right!important}@supports selector(:dir(rtl)){.ion-float-xl-start:dir(rtl){float:right!important}}.ion-float-xl-end{float:right!important}:host-context([dir=rtl]) .ion-float-xl-end{float:left!important}[dir=rtl] .ion-float-xl-end{float:left!important}@supports selector(:dir(rtl)){.ion-float-xl-end:dir(rtl){float:left!important}}}.ion-text-center{text-align:center!important}.ion-text-justify{text-align:justify!important}.ion-text-start{text-align:start!important}.ion-text-end{text-align:end!important}.ion-text-left{text-align:left!important}.ion-text-right{text-align:right!important}.ion-text-nowrap{white-space:nowrap!important}.ion-text-wrap{white-space:normal!important}@media (min-width: 576px){.ion-text-sm-center{text-align:center!important}.ion-text-sm-justify{text-align:justify!important}.ion-text-sm-start{text-align:start!important}.ion-text-sm-end{text-align:end!important}.ion-text-sm-left{text-align:left!important}.ion-text-sm-right{text-align:right!important}.ion-text-sm-nowrap{white-space:nowrap!important}.ion-text-sm-wrap{white-space:normal!important}}@media (min-width: 768px){.ion-text-md-center{text-align:center!important}.ion-text-md-justify{text-align:justify!important}.ion-text-md-start{text-align:start!important}.ion-text-md-end{text-align:end!important}.ion-text-md-left{text-align:left!important}.ion-text-md-right{text-align:right!important}.ion-text-md-nowrap{white-space:nowrap!important}.ion-text-md-wrap{white-space:normal!important}}@media (min-width: 992px){.ion-text-lg-center{text-align:center!important}.ion-text-lg-justify{text-align:justify!important}.ion-text-lg-start{text-align:start!important}.ion-text-lg-end{text-align:end!important}.ion-text-lg-left{text-align:left!important}.ion-text-lg-right{text-align:right!important}.ion-text-lg-nowrap{white-space:nowrap!important}.ion-text-lg-wrap{white-space:normal!important}}@media (min-width: 1200px){.ion-text-xl-center{text-align:center!important}.ion-text-xl-justify{text-align:justify!important}.ion-text-xl-start{text-align:start!important}.ion-text-xl-end{text-align:end!important}.ion-text-xl-left{text-align:left!important}.ion-text-xl-right{text-align:right!important}.ion-text-xl-nowrap{white-space:nowrap!important}.ion-text-xl-wrap{white-space:normal!important}}.ion-text-uppercase{text-transform:uppercase!important}.ion-text-lowercase{text-transform:lowercase!important}.ion-text-capitalize{text-transform:capitalize!important}@media (min-width: 576px){.ion-text-sm-uppercase{text-transform:uppercase!important}.ion-text-sm-lowercase{text-transform:lowercase!important}.ion-text-sm-capitalize{text-transform:capitalize!important}}@media (min-width: 768px){.ion-text-md-uppercase{text-transform:uppercase!important}.ion-text-md-lowercase{text-transform:lowercase!important}.ion-text-md-capitalize{text-transform:capitalize!important}}@media (min-width: 992px){.ion-text-lg-uppercase{text-transform:uppercase!important}.ion-text-lg-lowercase{text-transform:lowercase!important}.ion-text-lg-capitalize{text-transform:capitalize!important}}@media (min-width: 1200px){.ion-text-xl-uppercase{text-transform:uppercase!important}.ion-text-xl-lowercase{text-transform:lowercase!important}.ion-text-xl-capitalize{text-transform:capitalize!important}}.ion-align-self-start{align-self:flex-start!important}.ion-align-self-end{align-self:flex-end!important}.ion-align-self-center{align-self:center!important}.ion-align-self-stretch{align-self:stretch!important}.ion-align-self-baseline{align-self:baseline!important}.ion-align-self-auto{align-self:auto!important}.ion-wrap{flex-wrap:wrap!important}.ion-nowrap{flex-wrap:nowrap!important}.ion-wrap-reverse{flex-wrap:wrap-reverse!important}.ion-justify-content-start{justify-content:flex-start!important}.ion-justify-content-center{justify-content:center!important}.ion-justify-content-end{justify-content:flex-end!important}.ion-justify-content-around{justify-content:space-around!important}.ion-justify-content-between{justify-content:space-between!important}.ion-justify-content-evenly{justify-content:space-evenly!important}.ion-align-items-start{align-items:flex-start!important}.ion-align-items-center{align-items:center!important}.ion-align-items-end{align-items:flex-end!important}.ion-align-items-stretch{align-items:stretch!important}.ion-align-items-baseline{align-items:baseline!important}.ion-hide,.ion-hide-up,.ion-hide-down{display:none!important}@media (min-width: 576px){.ion-hide-sm-up{display:none!important}}@media (max-width: 575.98px){.ion-hide-sm-down{display:none!important}}@media (min-width: 768px){.ion-hide-md-up{display:none!important}}@media (max-width: 767.98px){.ion-hide-md-down{display:none!important}}@media (min-width: 992px){.ion-hide-lg-up{display:none!important}}@media (max-width: 991.98px){.ion-hide-lg-down{display:none!important}}@media (min-width: 1200px){.ion-hide-xl-up{display:none!important}}@media (max-width: 1199.98px){.ion-hide-xl-down{display:none!important}}:root{--ion-color-primary: #0077B6;--ion-color-primary-rgb: 0,119,182;--ion-color-primary-contrast: #fff;--ion-color-primary-contrast-rgb: 255,255,255;--ion-color-primary-shade: #0069a0;--ion-color-primary-tint: #1a85bd;--ion-color-secondary: #00B4D8;--ion-color-secondary-rgb: 0,180,216;--ion-color-secondary-contrast: #fff;--ion-color-secondary-shade: #009fbe;--ion-color-secondary-tint: #1abcdc;--ion-color-success: #2D9E5F;--ion-color-success-rgb: 45,158,95;--ion-color-success-contrast: #fff;--ion-color-success-shade: #279054;--ion-color-success-tint: #42a86f;--ion-color-warning: #F59E0B;--ion-color-warning-rgb: 245,158,11;--ion-color-warning-contrast: #fff;--ion-color-warning-shade: #d88e0a;--ion-color-warning-tint: #f6a823;--ion-color-danger: #EF4444;--ion-color-danger-rgb: 239,68,68;--ion-color-danger-contrast: #fff;--ion-color-danger-shade: #d23d3d;--ion-color-danger-tint: #f15757;--ion-color-light: #F8FAFC;--ion-color-medium: #94A3B8;--ion-color-dark: #1E293B;--ion-background-color: #F8FAFC;--ion-text-color: #1E293B;--ion-border-color: #E2E8F0;--ion-tab-bar-background: #ffffff;--ion-tab-bar-border-color: #E2E8F0;--ion-tab-bar-color: #94A3B8;--ion-tab-bar-color-selected: #0077B6;--ion-toolbar-background: #fff;--ion-toolbar-color: #1E293B;--ms-sand: #F5ECD7;--ms-ocean: #0077B6;--ms-teal: #00B4D8;--ms-green: #2D9E5F;--ms-card-radius: 16px;--ms-shadow: 0 2px 12px rgba(0,0,0,.08)}*{box-sizing:border-box}body{font-family:Inter,sans-serif}.display-font{font-family:Playfair Display,serif}.room-card{background:#fff;border-radius:var(--ms-card-radius);overflow:hidden;box-shadow:var(--ms-shadow);margin-bottom:16px}.room-card-img{width:100%;height:180px;object-fit:cover;background:linear-gradient(135deg,#0077b6,#00b4d8)}.room-card-body{padding:16px}.room-card-title{font-weight:700;font-size:17px;margin:0 0 4px}.room-card-type{font-size:12px;color:var(--ion-color-medium);margin-bottom:8px}.amenity-chip{display:inline-flex;align-items:center;gap:4px;background:#e8f4fd;color:var(--ms-ocean);padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;margin:2px}.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize}.status-pending{background:#fffbeb;color:#b45309}.status-approved{background:#e8f5ee;color:#2d9e5f}.status-declined{background:#fef2f2;color:#ef4444}.status-completed{background:#e8f4fd;color:#0077b6}.status-cancelled{background:#f1f5f9;color:#94a3b8}.hero-section{background:linear-gradient(160deg,#0077b6,#00b4d8 60%,#90e0ef);padding:48px 24px 64px;color:#fff;position:relative;overflow:hidden}.hero-section:before{content:"";position:absolute;bottom:-40px;left:0;right:0;height:80px;background:var(--ion-background-color);border-radius:50% 50% 0 0/80px 80px 0 0}.section-title{font-family:Playfair Display,serif;font-size:22px;font-weight:700;margin:0 0 16px;color:var(--ion-text-color)}.stars{color:#f59e0b;letter-spacing:2px}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#0077b6,#00b4d8);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff;margin:0 auto}.msg-bubble{max-width:78%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;margin-bottom:8px}.msg-bubble.user{background:var(--ms-ocean);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.msg-bubble.admin{background:#fff;color:var(--ion-text-color);border:1px solid var(--ion-border-color);border-bottom-left-radius:4px;align-self:flex-start}.notif-item{padding:14px 16px;border-bottom:1px solid var(--ion-border-color)}.notif-item.unread{background:#e8f4fd}.notif-dot{width:8px;height:8px;background:var(--ms-ocean);border-radius:50%;flex-shrink:0}.landing-page{background:#fff}.landing-hero{min-height:100vh;background:linear-gradient(160deg,#023e8a,#0077b6,#00b4d8 80%,#90e0ef);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;text-align:center;color:#fff;position:relative;overflow:hidden}.wave-bottom{position:absolute;bottom:0;left:0;right:0;height:80px;background:#fff;clip-path:ellipse(60% 100% at 50% 100%)}ion-content::part(scroll){scrollbar-width:none}ion-content::part(scroll)::-webkit-scrollbar{width:0;height:0}.search-section{padding:8px 16px}.type-filters{padding-left:16px;overflow-x:auto;display:flex;gap:8px;padding-bottom:8px}.type-filter-btn{padding:6px 16px;border-radius:20px;border:1.5px solid;white-space:nowrap;cursor:pointer;font-weight:600;font-size:13px;flex-shrink:0;background:#fff;color:#64748b;border-color:#e2e8f0;transition:all .15s}.type-filter-btn.active,.type-filter-btn:hover{background:#0077b6;color:#fff;border-color:#0077b6}.rooms-section{padding:8px 16px 24px}.room-skeleton-img{height:180px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.room-skeleton-text{height:16px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:8px}.room-skeleton-text.short{width:70%;height:20px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:60px 24px;color:#94a3b8}.empty-icon{font-size:48px;margin-bottom:12px}.empty-title{font-weight:600}.empty-subtitle{font-size:14px;margin-top:4px}.room-card-placeholder{height:180px;display:flex;align-items:center;justify-content:center;font-size:48px}.room-card-image{position:relative}.room-price-badge{position:absolute;top:10px;right:10px;background:#0077b6;color:#fff;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.favorite-btn{position:absolute;top:10px;left:10px;background:#ffffffe6;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center}.room-card-desc{font-size:13px;color:#64748b;margin-bottom:12px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.room-amenities{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.room-actions{display:flex;gap:8px}.room-btn-outline{flex:1;border:1.5px solid #0077B6;color:#0077b6;background:transparent;padding:8px 16px;border-radius:10px;font-size:14px;cursor:pointer}.room-btn-primary{flex:1;background:#0077b6;color:#fff;border:none;padding:8px 16px;border-radius:10px;font-size:14px;cursor:pointer}.ms-input{background:#fff;border:1.5px solid var(--ion-border-color);border-radius:12px;padding:12px 16px;font-size:15px;width:100%;outline:none;font-family:Inter,sans-serif;color:var(--ion-text-color);transition:border-color .15s}.ms-input:focus{border-color:var(--ms-ocean)}.booking-summary{background:linear-gradient(135deg,#e8f4fd,#eff9ff);border-radius:16px;padding:20px;border:1px solid rgba(0,119,182,.15)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-out both}.stat-card-animate,.room-card-animate{animation:fadeInUp .5s ease-out both}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-animate{animation:spin 1s linear infinite}:root{--ocean: #0077B6;--ocean-dk: #005F8E;--ocean-lt: #E8F4FD;--teal: #00B4D8;--sand: #F5ECD7;--sand-dk: #E8D5B0;--green: #2D9E5F;--green-lt: #E8F5EE;--white: #FFFFFF;--grey-50: #F8FAFC;--grey-100: #F1F5F9;--grey-200: #E2E8F0;--grey-400: #94A3B8;--grey-600: #475569;--grey-800: #1E293B;--red: #EF4444;--red-lt: #FEF2F2;--amber: #F59E0B;--amber-lt: #FFFBEB;--sidebar-w: 260px;--topbar-h: 64px;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 10px 40px rgba(0,0,0,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}html,body,#root{height:100vh;width:100%;margin:0;padding:0;overflow:hidden}.login-page,.login-page *{-webkit-overflow-scrolling:touch}body{font-family:Inter,system-ui,sans-serif;background:var(--grey-50);color:var(--grey-800);font-size:14px;line-height:1.5}@keyframes fadeInUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fadeInUp .4s cubic-bezier(.4,0,.2,1) both}.sidebar{transition:transform .3s cubic-bezier(.4,0,.2,1)}.nav-item,.btn,.btn-icon{transition:all .2s ease}.btn:active,.btn-icon:active{transform:scale(.96)}.card,.stat-card{transition:transform .3s ease,box-shadow .3s ease!important}.card:hover,.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px -5px #0000001a}.layout{display:flex;height:100vh;width:100%;margin:0;padding:0;position:fixed;top:0;left:0;right:0;bottom:0}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100vh;margin-left:var(--sidebar-w)}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#1f2937,#111827);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;height:100vh;overflow-y:auto;overflow-x:hidden;z-index:102;transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 16px #0003;will-change:transform}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff40}.sidebar,.sidebar *{pointer-events:auto}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1);flex:0 0 auto;background:linear-gradient(180deg,#1f2937,#111827)}.sidebar-logo{display:flex;align-items:center;gap:14px;flex:1}.sidebar-logo img{display:block}.logo-icon{color:var(--teal)}.logo-title{font-family:Playfair Display,serif;font-size:16px;font-weight:700;color:#fff}.logo-sub{font-size:10px;color:#9ca3af;letter-spacing:.05em;text-transform:uppercase}.sidebar-close{display:none;background:none;border:none;color:#9ca3af;cursor:pointer;padding:6px;border-radius:8px;transition:all .2s}.sidebar-close:hover{background:#ffffff1a;color:#fff}.sidebar-nav{flex:1 1 auto;min-height:0;padding:12px 10px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:#9ca3af;text-decoration:none;font-weight:500;font-size:14px;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:linear-gradient(90deg,#0077b633,#00b4d81a);color:#fff;border-left-color:#0077b6}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px;flex:0 0 auto;background:#ffffff05}.user-info{display:flex;align-items:center;gap:12px;flex:1;overflow:hidden}.user-avatar{width:36px;height:36px;background:var(--ocean);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:#9ca3af;text-transform:capitalize}.btn-logout{background:none;border:none;color:#9ca3af;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s}.btn-logout:hover{background:#ef444433;color:#fca5a5}.topbar{position:fixed;top:0;left:var(--sidebar-w);right:0;width:calc(100% - var(--sidebar-w));height:var(--topbar-h);background:var(--white);border-bottom:1px solid #E5E7EB;display:flex;align-items:center;padding:0 24px;gap:16px;z-index:101;box-shadow:0 1px 3px #0000000f;flex-shrink:0}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;border-radius:10px;color:#6b7280;transition:all .2s}.hamburger:hover{background:#f3f4f6;color:#111827}.page-title{font-family:Playfair Display,serif;font-size:20px;font-weight:700;flex:1;color:#111827}.topbar-right{display:flex;align-items:center;gap:16px}.admin-badge{background:linear-gradient(135deg,#e0f2fe,#f0f9ff);color:#0077b6;padding:6px 14px;border-radius:24px;font-size:12px;font-weight:700;letter-spacing:.5px}.content{flex:1;min-height:0;padding:calc(var(--topbar-h) + 28px) 28px 28px;overflow-y:auto;overflow-x:hidden;height:calc(100vh - var(--topbar-h));position:relative}.content::-webkit-scrollbar{width:8px}.content::-webkit-scrollbar-track{background:#f1f5f9}.content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.content::-webkit-scrollbar-thumb:hover{background:#a0aec0}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));gap:20px;padding-bottom:40px;align-items:start}.room-card-header{min-height:170px;background:linear-gradient(135deg,#0077b6,#00b4d8);position:relative;display:flex;align-items:center;justify-content:center}.room-card-header img,.room-card-img{width:100%;height:100%;object-fit:cover}.room-badge{position:absolute;top:10px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}.room-badge.featured{right:10px;background:#f59e0b;color:#fff}.room-card-body{padding:20px}.room-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.room-card-title{font-weight:700;font-size:16px}.room-card-price{text-align:right}.room-card-price .font-bold{font-size:18px;color:var(--ocean)}.room-card-desc{margin-bottom:12px;color:var(--grey-600);line-height:1.5}.room-card-amenities{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}.room-card-actions{display:flex;gap:8px}.room-detail-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--grey-100)}.room-detail-block{min-width:0}.room-info-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--grey-400);font-weight:700;margin-bottom:4px}.room-info-text{margin:0;color:var(--grey-600);font-size:13px;line-height:1.55;overflow-wrap:anywhere}.room-info-list{display:flex;flex-wrap:wrap;gap:4px}.room-info-empty{color:var(--grey-400);font-size:12px;font-style:italic}.room-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.room-meta-item{background:var(--grey-50);border:1px solid var(--grey-100);border-radius:8px;padding:8px 10px;min-width:0}.room-meta-item span{display:block;font-size:10px;color:var(--grey-400);text-transform:uppercase;letter-spacing:.04em;font-weight:700;margin-bottom:2px}.room-meta-item strong{display:block;font-size:12px;color:var(--grey-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex-1{flex:1}.amenities-grid{display:flex;flex-wrap:wrap;gap:8px}.amenity-btn{padding:5px 12px;border-radius:20px;border:1.5px solid;font-size:12px;cursor:pointer;font-weight:500;background:transparent;color:var(--grey-600);border-color:var(--grey-200);transition:all .15s}.amenity-btn:hover{border-color:var(--ocean)}.amenity-btn.active{background:var(--ocean);color:#fff;border-color:var(--ocean)}.photo-upload{background:#f8fafc;padding:16px;border-radius:12px;border:1.5px dashed #CBD5E1;margin-top:16px}.photo-upload label{font-weight:600;font-size:13px;color:#475569;display:block;margin-bottom:8px}.photo-preview-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.photo-preview{width:96px;height:72px;border-radius:8px;overflow:hidden;position:relative;border:1.5px solid #E2E8F0}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-remove{position:absolute;top:2px;right:2px;background:#00000080;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;padding:0}.photo-upload-controls{display:flex;gap:8px;align-items:center}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--white);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:16px;border-left:4px solid transparent}.stat-card.blue{border-left-color:var(--ocean)}.stat-card.teal{border-left-color:var(--teal)}.stat-card.green{border-left-color:var(--green)}.stat-card.amber{border-left-color:var(--amber)}.stat-card.red{border-left-color:var(--red)}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:var(--ocean-lt);color:var(--ocean)}.stat-icon.teal{background:#e0f7fa;color:var(--teal)}.stat-icon.green{background:var(--green-lt);color:var(--green)}.stat-icon.amber{background:var(--amber-lt);color:var(--amber)}.stat-icon.red{background:var(--red-lt);color:var(--red)}.stat-value{font-size:24px;font-weight:700;line-height:1.1}.stat-label{font-size:12px;color:var(--grey-400);font-weight:500}.table-wrap{overflow-x:auto;border-radius:var(--radius)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{background:var(--grey-50);padding:12px 16px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--grey-600);border-bottom:1px solid var(--grey-200);white-space:nowrap}tbody td{padding:14px 16px;border-bottom:1px solid var(--grey-100);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--grey-50)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.badge.pending{background:var(--amber-lt);color:#b45309}.badge.approved{background:var(--green-lt);color:var(--green)}.badge.declined{background:var(--red-lt);color:var(--red)}.badge.completed{background:var(--ocean-lt);color:var(--ocean)}.badge.cancelled{background:var(--grey-100);color:var(--grey-600)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.btn-primary{background:var(--ocean);color:#fff}.btn-primary:hover{background:var(--ocean-dk)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#238a50}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#dc2626}.btn-amber{background:var(--amber);color:#fff}.btn-outline{background:transparent;border:1.5px solid var(--grey-200);color:var(--grey-600)}.btn-outline:hover{border-color:var(--ocean);color:var(--ocean)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:8px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--grey-600);transition:all .15s}.btn-icon:hover{background:var(--grey-100);color:var(--ocean)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:13px;font-weight:600;color:var(--grey-600)}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1.5px solid var(--grey-200);border-radius:8px;font-size:13px;font-family:inherit;outline:none;transition:border-color .15s;background:var(--white)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--ocean)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal{background:var(--white);border-radius:var(--radius);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--grey-200)}.modal-title{font-family:Playfair Display,serif;font-size:18px;font-weight:600}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--grey-200);display:flex;gap:12px;justify-content:flex-end}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-header h2{font-family:Playfair Display,serif;font-size:22px}.page-header p{margin:2px 0 0}.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:20px}.search-input{padding:9px 14px 9px 38px;border:1.5px solid var(--grey-200);border-radius:8px;font-size:13px;outline:none;min-width:220px}.search-input:focus{border-color:var(--ocean)}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--grey-400)}.login-page{min-height:100vh;background:linear-gradient(135deg,#0077b6,#00b4d8,#90e0ef);padding:24px;position:relative;overflow-y:auto;overflow-x:hidden}.auth-shell{min-height:calc(100vh - 48px);display:flex;align-items:center;justify-content:center}.auth-shell{padding:18px 0}.login-page:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%;top:-200px;right:-200px;pointer-events:none}.login-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);border-radius:50%;bottom:-150px;left:-150px;pointer-events:none}.login-card{background:#ffffff14;border-radius:22px;overflow:visible;width:100%;max-width:520px;box-shadow:0 20px 60px #00000038;z-index:1;position:relative;height:auto;max-height:none;border:1px solid rgba(255,255,255,.22);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.auth-card{padding:0}.auth-card-header{padding:44px 28px 22px;background:linear-gradient(135deg,#0077b6f2,#00b4d8eb);color:#fff;text-align:center;border-top-left-radius:22px;border-top-right-radius:22px}.auth-title{font-family:Playfair Display,serif;font-size:28px;font-weight:800;margin:8px 0 6px}.auth-subtitle{margin:0;color:#ffffffeb;font-size:14px;font-weight:600}.auth-logo{font-size:48px;line-height:1;margin-bottom:6px}.auth-card-body{padding:22px 26px 10px}.auth-card-footer{padding:14px 26px 22px;text-align:center;color:#111827b8}.auth-demo{font-size:13px;line-height:1.6}.login-logo{text-align:center;margin-bottom:32px;color:var(--ocean)}.login-logo h1{font-family:Playfair Display,serif;font-size:28px;margin-top:8px}.login-logo p{color:var(--grey-400);font-size:14px}.login-form .btn-primary{width:100%;padding:12px;font-size:15px;margin-top:8px}.login-hint{text-align:center;color:var(--grey-400);font-size:12px;margin-top:16px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:24px}.chart-card{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.chart-title{font-weight:600;margin-bottom:16px;font-size:15px}.empty-state{text-align:center;padding:48px;color:var(--grey-400)}.empty-state svg{margin-bottom:12px}.loading{text-align:center;padding:48px;color:var(--grey-400)}.section-title{font-weight:700;font-size:15px;margin-bottom:16px;color:var(--grey-800)}.divider{height:1px;background:var(--grey-200);margin:20px 0}.tag{display:inline-block;background:var(--ocean-lt);color:var(--ocean);padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;margin:2px}.avatar{width:36px;height:36px;background:var(--ocean-lt);color:var(--ocean);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.text-sm{font-size:12px}.text-muted{color:var(--grey-400)}.font-bold{font-weight:700}.mt-1{margin-top:4px}.mb-0{margin-bottom:0}@media (max-width: 900px){:root{--sidebar-w: 0px}.sidebar{transform:translate(-100%);z-index:105}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-close{display:flex}.hamburger{display:flex;position:fixed;top:12px;left:12px;z-index:110}.main{margin-left:0}.topbar{left:0;width:100%}.content{padding:calc(var(--topbar-h) + 20px) 20px 20px}.form-grid-2{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.room-meta-grid{grid-template-columns:1fr}}@media (max-width: 480px){.stat-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.rooms-grid{grid-template-columns:1fr}}.auth-brand{display:flex;align-items:center;justify-content:center;gap:14px}.auth-brand-logo{width:46px;height:46px;border-radius:14px;padding:8px;background:#ffffff29;border:1px solid rgba(255,255,255,.25);box-shadow:0 10px 30px #0000001f;object-fit:contain}.auth-brand-text{display:flex;flex-direction:column;align-items:center}.auth-form{width:100%}.auth-form .form-group{margin-bottom:16px}.input-with-icon{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:14px;color:#1118278c;pointer-events:none;font-weight:800}.input-with-icon input{padding-left:42px!important}.password-field{position:relative}.password-field input{width:100%}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:#0000;border:none;cursor:pointer;font-size:18px;color:#111827a6;padding:6px}.password-toggle:hover{color:#0077b6f2}.auth-tabs{display:flex;gap:10px;justify-content:center;margin-bottom:18px}.auth-tab{border:1px solid rgba(0,119,182,.25);background:#ffffff59;color:#111827b3;padding:10px 14px;border-radius:12px;font-weight:800;cursor:pointer;transition:transform .12s ease,background .2s ease,border-color .2s ease,color .2s ease;flex:1;max-width:220px}.auth-tab:hover{transform:translateY(-1px);background:#ffffff8c}.auth-tab.active{background:linear-gradient(135deg,#0077b6,#00b4d8);border-color:#0077b6cc;color:#fff}.auth-card-body{overflow:visible}.auth-form-swap{will-change:transform,opacity}.auth-hint{margin-top:10px;color:#6b7280;font-size:12px;line-height:1.6}.auth-submit{margin-top:10px}@media (max-width: 480px){.auth-brand-logo{width:42px;height:42px}.auth-tabs{margin-bottom:14px}.auth-card-header{padding:36px 18px 18px}.auth-card-body{padding:18px 16px 8px}.auth-card-footer{padding:12px 16px 18px}}
