@charset "UTF-8";:root{--sat: env(safe-area-inset-top, 0px);--sar: env(safe-area-inset-right, 0px);--sab: env(safe-area-inset-bottom, 0px);--sal: env(safe-area-inset-left, 0px);--collapsed-header-h: calc(var(--sat) + 52.5px);--expanded-header-h: calc(var(--sat) + 115px);--tabbar-h: calc(var(--sab) + 50px);--mobile-max-width: 430px;--color-primary: #E63A3A;--color-primary-rgb: 230, 58, 58;--color-primary-hover: #d32f2f;--color-primary-soft: #fff5f5;--color-primary-soft-2: #fee2e2;--color-secondary: #667eea;--color-bg: #f5f5f5;--color-background: var(--color-bg);--color-surface: #ffffff;--color-surface-muted: #f9fafb;--color-surface-soft: #f3f4f6;--color-surface-sunken: #f1f5f9;--color-border: #e5e7eb;--color-border-soft: #f3f4f6;--color-border-strong: #d1d5db;--color-text-strong: #111827;--color-text: #1f2937;--color-text-muted: #374151;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-success: #10b981;--color-success-soft: #d1fae5;--color-warning: #f59e0b;--color-warning-soft: #fef3c7;--color-error: #ef4444;--color-error-soft: #fef2f2;--color-info: #3b82f6;--color-info-soft: #dbeafe;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--spacing-xs: var(--space-1);--spacing-sm: var(--space-2);--spacing-md: var(--space-4);--spacing-lg: var(--space-6);--spacing-xl: var(--space-8);--radius-xs: .25rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-pill: 999px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 8px 24px rgba(15, 23, 42, .12);--shadow-xl: 0 16px 40px rgba(15, 23, 42, .18);--shadow-primary: 0 4px 12px rgba(var(--color-primary-rgb), .3);--shadow-primary-strong: 0 6px 16px rgba(var(--color-primary-rgb), .4);--focus-ring: 0 0 0 3px rgba(var(--color-primary-rgb), .18);--focus-ring-strong: 0 0 0 3px rgba(var(--color-primary-rgb), .32);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-emphasis: .22s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}ul,ol{list-style:none}a{text-decoration:none;color:inherit}img{max-width:100%;height:auto;display:block}html,body{width:100%;max-width:100%;overflow-x:hidden;scrollbar-gutter:stable;line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0 auto;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,Helvetica Neue,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,sans-serif;padding:0;background-color:var(--color-background)}.mobile-header{position:fixed;top:0;max-width:var(--mobile-max-width);width:100%;z-index:1100;color:#fff;background-color:#f8f8f8;display:flex;flex-direction:column}.mobile-header .header-content{position:relative;background:linear-gradient(135deg,#e63a3a,#ff8f8f);padding:calc(var(--sat, 0px) + 5px) 24px 75px;box-shadow:0 10px 30px #ff5e6226;opacity:1;transition:padding .4s cubic-bezier(.4,0,.2,1)}.mobile-header .header-content.header-collapsed{padding:calc(var(--sat, 0px) + 5px) 24px 5px}.mobile-header .header-content .header-top{display:flex;align-items:center;position:relative;width:100%}.mobile-header .header-content .back-button{position:absolute;left:0;top:50%;transform:translateY(-50%);background:none;border:none;padding:8px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:50%;transition:background-color .2s ease;width:40px;height:40px}.mobile-header .header-content .back-button:hover{background-color:#ffffff1a}.mobile-header .header-content .back-button:active{background-color:#fff3;transform:translateY(-50%) scale(.95)}.mobile-header .header-content .back-button svg{width:24px;height:24px}.mobile-header .header-content .greeting-box{display:flex;align-items:center;justify-content:center;gap:0rem;width:100%;position:relative}.mobile-header .header-content .greeting-box .greeting-box-link{display:inline-flex;align-items:center;justify-content:center;gap:inherit;text-decoration:none;color:inherit;cursor:pointer}.mobile-header .header-content .greeting-box img{width:auto;height:2rem;filter:brightness(0) invert(1)}.mobile-header .header-content .greeting-box h1{font-size:clamp(1rem,5.5vw,1.25rem);font-weight:600;color:#fff;margin:0;letter-spacing:.075em;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.1)}.mobile-header .header-content .greeting-box p{font-size:clamp(13px,3.8vw,15px);color:#ffffffd9;margin:8px 0 0;font-weight:400}.mobile-header .search-bar-wrapper{margin:-60px 20px 15px;position:relative;z-index:100;transition:opacity .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1);transform-origin:center top;will-change:opacity,transform}.mobile-header .search-bar-wrapper.visible{opacity:1;transform:translateY(0);pointer-events:auto}.mobile-header .search-bar-wrapper.hidden{opacity:0;transform:translateY(-15px);pointer-events:none}.mobile-header .search-bar-wrapper .search-bar-container{padding:0;background-color:transparent;position:static}.mobile-header .search-bar-wrapper .search-bar-container .search-bar{background-color:#fff;height:45px;border-radius:18px;box-shadow:0 12px 30px #0000001a;padding:13px 20px;border:1px solid rgba(0,0,0,.02)}.mobile-header .search-bar-wrapper .search-bar-container .search-bar input{font-size:16px}.main-container{display:flex;justify-content:center;gap:5rem;margin:0 auto}.main-container .desktop-sidebar{display:none;height:100dvh;position:sticky;top:0;width:var(--mobile-max-width);justify-content:center}.main-container .desktop-sidebar .sidebar-content{display:flex;position:fixed;flex-direction:column;justify-content:center;align-items:center;top:50%;transform:translateY(-50%)}.main-container .desktop-sidebar .app-brand{margin-bottom:24px}.main-container .desktop-sidebar .app-brand .brand-logo{width:140px;height:auto;display:block;border-radius:16px;box-shadow:0 4px 16px #00000026}.main-container .desktop-sidebar .qr-box{display:flex;align-items:center;gap:.7rem;justify-content:space-between;background-color:#fff;border-radius:8px;padding:36px;max-width:420px}.main-container .desktop-sidebar .qr-box .qr-text{display:flex;flex-direction:column;gap:4px;color:#222}.main-container .desktop-sidebar .qr-box .qr-text p{white-space:nowrap;margin:0}.main-container .desktop-sidebar .qr-box .qr-code img{width:10rem}@media (min-width: 1024px){.main-container .desktop-sidebar{display:flex}}.main-container .mobile-area{background-color:#fff;max-width:var(--mobile-max-width);width:100%;min-height:100dvh;overflow-x:hidden;position:relative;flex:1 1 auto;display:flex;flex-direction:column}.main-container .mobile-area .card{margin:0 auto 1rem;width:100%}.main-container .mobile-area .mobile-content{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;padding-top:var(--header-height, 0)}.main-container .mobile-area .mobile-content .page-transition{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;animation:page-fade-in .18s ease-out both;will-change:opacity}@keyframes page-fade-in{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){.page-transition{animation:none!important}}.bottom-tabbar{display:flex;min-height:calc(var(--tabbar-h) + var(--sab, 0px));width:100%;max-width:var(--mobile-max-width);position:fixed;bottom:0;margin:0;background-color:#fff;border-top:none;box-shadow:0 -4px 20px #00000014;z-index:1100;padding-bottom:var(--sab, 0px);padding-top:0;flex-shrink:0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.bottom-tabbar .write-post-fab{position:absolute;top:calc(-1*(clamp(12px,3.5vw,16px) + clamp(48px,13vw,56px)));right:clamp(12px,3.5vw,16px);width:clamp(48px,13vw,56px);height:clamp(48px,13vw,56px);border-radius:50%;background:linear-gradient(135deg,#e63a3a,#ff8f8f);border:none;box-shadow:0 4px 16px #e63a3a4d;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:10}.bottom-tabbar .write-post-fab .write-fab-icon{width:clamp(20px,5.5vw,24px);height:clamp(20px,5.5vw,24px);display:flex;align-items:center;justify-content:center;color:#fff}.bottom-tabbar .write-post-fab .write-fab-icon svg{width:100%;height:100%;display:block}.bottom-tabbar .write-post-fab:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #e63a3a66}.bottom-tabbar .write-post-fab:active{transform:translateY(0) scale(.95);box-shadow:0 2px 12px #e63a3a4d}body.community-modal-open .bottom-tabbar .write-post-fab,.bottom-tabbar.bottom-tabbar--detail .gnb{display:none}.bottom-tabbar.bottom-tabbar--detail .detail-actions{display:flex;gap:12px;width:100%;padding:8px 16px;align-items:center}.bottom-tabbar.bottom-tabbar--detail .detail-actions button{flex:1;padding:14px 1rem;font-size:1rem;font-weight:600;border-radius:18px;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000001a}.bottom-tabbar.bottom-tabbar--detail .detail-actions button:hover{transform:translateY(-2px)}.bottom-tabbar.bottom-tabbar--detail .detail-actions button:active{transform:scale(.98)}.bottom-tabbar.bottom-tabbar--detail .detail-actions .btn-price{background:#fff;color:#ff5e62;border:2px solid #ff5e62}.bottom-tabbar.bottom-tabbar--detail .detail-actions .btn-price:hover{background-color:#fff5f5;box-shadow:0 6px 16px #ff5e6233}.bottom-tabbar.bottom-tabbar--detail .detail-actions .btn-price:active{background-color:#ffe5e5}.bottom-tabbar.bottom-tabbar--detail .detail-actions .btn-booking{background:linear-gradient(135deg,#ff5e62,#f96);color:#fff}.bottom-tabbar.bottom-tabbar--detail .detail-actions .btn-booking:hover{background:linear-gradient(135deg,#ff4a4e,#f85);box-shadow:0 6px 20px #ff5e624d}.bottom-tabbar .gnb{display:flex;justify-content:space-between;align-items:stretch;width:100%;padding:0 8px}.bottom-tabbar .gnb>li{flex:1;display:flex}.bottom-tabbar .tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;height:var(--tabbar-h);max-height:var(--tabbar-h);padding:0;border:0;border-radius:12px;background:none;cursor:pointer;touch-action:manipulation;user-select:none;-webkit-user-select:none;appearance:none;-webkit-appearance:none;outline:none;width:100%;margin:0 4px;color:#666;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.bottom-tabbar .tab-item .nav-icon{width:22px;height:22px;padding-top:0;filter:brightness(0) saturate(100%) invert(40%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%);opacity:.7;flex-shrink:0}.bottom-tabbar .tab-item .nav-icon--component{display:flex;align-items:center;justify-content:center}.bottom-tabbar .tab-item .nav-icon--component svg{display:block;width:22px;height:22px}.bottom-tabbar .tab-item .tab-label{font-size:11px;line-height:1.2;color:inherit;font-weight:500;display:flex;justify-content:center;align-items:center;width:100%;white-space:nowrap;text-overflow:ellipsis;max-width:100%;text-align:center;margin:0}.bottom-tabbar .tab-item:hover{background-color:#ff5e620d;color:#ff5e62}.bottom-tabbar .tab-item:hover .nav-icon{opacity:.9;filter:brightness(0) saturate(100%) invert(47%) sepia(100%) saturate(2000%) hue-rotate(340deg) brightness(105%) contrast(100%)}.bottom-tabbar .tab-item:active{background-color:#ff5e621a}.bottom-tabbar .tab-item.active{background:linear-gradient(135deg,#ff5e621a,#ff99661a);color:#ff5e62;font-weight:600}.bottom-tabbar .tab-item.active .nav-icon{filter:brightness(0) saturate(100%) invert(47%) sepia(100%) saturate(2000%) hue-rotate(340deg) brightness(105%) contrast(100%);opacity:1}.bottom-tabbar .tab-item.active .tab-label{color:#ff5e62;font-weight:600}.bottom-tabbar .tab-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:linear-gradient(135deg,#e63a3a,#ff8f8f);border-radius:0 0 3px 3px}@media (max-width: 768px){.bottom-tabbar .tab-item:active{transform:none}.bottom-tabbar .tab-item:active .nav-icon{transform:scale(.92)}}.booking-nav-btn{flex:1;padding:1.1rem;background:linear-gradient(135deg,#e63a3a,#ff6b6b);color:#fff;border:none;border-radius:16px;font-size:1.05rem;font-weight:700;letter-spacing:-.3px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #e63a3a4d,0 2px 8px #e63a3a33;position:relative;overflow:hidden}.booking-nav-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#fff3,#fff0);opacity:0;transition:opacity .3s ease}.booking-nav-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #e63a3a59,0 4px 12px #e63a3a40}.booking-nav-btn:hover:not(:disabled):before{opacity:1}.booking-nav-btn:active:not(:disabled){transform:translateY(0)}.booking-nav-btn:disabled{background:linear-gradient(135deg,#adb5bd,#ced4da);box-shadow:none;cursor:not-allowed;opacity:.6}.content-area{width:100%;margin-bottom:2rem;display:flex;flex-direction:column;min-height:calc(100dvh - var(--tabbar-h) - var(--sab, 0px) - var(--collapsed-header-h))}.content-section{padding:0;display:flex;flex-direction:column;flex:1}.content-section>.loading-state,.content-section>.error-state{flex:1;min-height:200px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.base-spinner{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.base-spinner__circle{border-radius:50%;animation:spin .8s linear infinite}.base-spinner--xs .base-spinner__circle{width:16px;height:16px;border-width:2px;border-style:solid}.base-spinner--sm .base-spinner__circle{width:24px;height:24px;border-width:2px;border-style:solid}.base-spinner--md .base-spinner__circle{width:32px;height:32px;border-width:3px;border-style:solid}.base-spinner--lg .base-spinner__circle{width:48px;height:48px;border-width:3px;border-style:solid}.base-spinner--xl .base-spinner__circle{width:64px;height:64px;border-width:4px;border-style:solid}.base-spinner--primary .base-spinner__circle{border-color:#e63a3a26;border-top-color:#e63a3a}.base-spinner--secondary .base-spinner__circle{border-color:#ff6b6b26;border-top-color:#ff6b6b}.base-spinner--white .base-spinner__circle{border-color:#ffffff4d;border-top-color:#fff}.base-spinner--gray .base-spinner__circle{border-color:#9993;border-top-color:#999}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;text-align:center;background:rgba(255,255,255,var(--backdrop-opacity, 1));z-index:1000}.loading-overlay--fullscreen{position:fixed;inset:0}.loading-overlay--contained{position:absolute;inset:0}.loading-overlay__content{display:flex;flex-direction:column;align-items:center;gap:20px}.loading-overlay__message{font-size:18px;font-weight:500;color:#333;margin:0;line-height:1.4}.loading-overlay__sub-message{font-size:14px;color:#999;margin:0;line-height:1.5}.loading-state{display:flex;align-items:center;justify-content:center;padding:24px 16px;gap:12px;width:100%;min-height:200px;flex:1;box-sizing:border-box}.loading-state--vertical{flex-direction:column;min-height:calc(100vh - var(--collapsed-header-h, 56px) - var(--tabbar-h, 64px) - var(--sab, 0px) - 100px)}.loading-state--horizontal{flex-direction:row;gap:10px}.loading-state__message{font-size:14px;color:#999;line-height:1.4}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;text-align:center;width:100%;min-height:120px;flex:1;box-sizing:border-box}.error-state--fullscreen{position:fixed;inset:0;background:#fff;min-height:100vh}.error-state__icon{width:64px;height:64px;border-radius:50%;background:#fee;display:flex;align-items:center;justify-content:center;margin-bottom:24px;position:relative}.error-state__icon:before,.error-state__icon:after{content:"";width:24px;height:2px;background:#e74c3c;position:absolute}.error-state__icon:before{transform:rotate(45deg)}.error-state__icon:after{transform:rotate(-45deg)}.error-state__title{font-size:18px;font-weight:500;color:#333;margin:0 0 12px}.error-state__message{font-size:14px;color:#666;margin:0 0 24px;line-height:1.5;max-width:300px}.error-state__action{padding:10px 24px;background:#e63a3a;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 2px 4px #e63a3a33;transition:all .2s ease}.error-state__action:hover{background:#db1c1c;box-shadow:0 4px 8px #e63a3a4d}.error-state__action:active{transform:scale(.98)}.gx-modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:1200;padding:1.5rem}.gx-modal-backdrop.no-backdrop{background:transparent}.gx-modal{width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 16px 40px #0f172a52;padding:1.5rem 1.5rem 1.25rem;animation:gx-modal-pop .18s ease-out;max-height:90vh;display:flex;flex-direction:column}@media (max-width: 480px){.gx-modal{max-width:100%;border-radius:20px;margin:0 .5rem;padding:1.25rem 1.25rem 1rem}}.gx-modal-title{margin:0;margin-bottom:1rem;font-size:1.3rem;font-weight:700;color:#111827;letter-spacing:-.03em;padding-bottom:.9rem;border-bottom:1px solid rgba(15,23,42,.06);display:flex;align-items:center;gap:.5rem}.gx-modal-title:before{content:"";display:inline-block;width:4px;height:1.2em;border-radius:999px;background:linear-gradient(180deg,#e63a3a,#ff8a8a)}.gx-modal-body{font-size:.95rem;line-height:1.6;color:#4b5563;overflow-y:auto;overflow-x:hidden;flex:1;margin-right:-.5rem;padding-right:.5rem}.gx-modal-body::-webkit-scrollbar{width:6px}.gx-modal-body::-webkit-scrollbar-track{background:transparent}.gx-modal-body::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:10px}.gx-modal-body::-webkit-scrollbar-thumb:hover{background:#b0b0b0}.gx-modal-footer{margin-top:1.5rem;display:flex;justify-content:space-between;gap:.75rem;padding-top:1.25rem;border-top:1px solid rgba(0,0,0,.06);flex-shrink:0}@media (max-width: 480px){.gx-modal-footer{flex-direction:row;align-items:stretch;gap:.5rem}}.gx-modal-button{flex:1;padding:.75rem 1.6rem;border-radius:12px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}@media (max-width: 480px){.gx-modal-button{flex:1}}.gx-modal-button.primary{background:linear-gradient(135deg,#e63a3a,#ff6b6b);color:#fff;box-shadow:0 4px 12px #e63a3a4d}.gx-modal-button.primary:hover{background:linear-gradient(135deg,#d32f2f,#ff5252);box-shadow:0 6px 16px #e63a3a66;transform:translateY(-2px)}.gx-modal-button.primary:active{transform:translateY(0);box-shadow:0 2px 8px #e63a3a4d}.gx-modal-button.primary:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.gx-modal-button.primary:disabled:hover{background:linear-gradient(135deg,#e63a3a,#ff6b6b);transform:none;box-shadow:none}.gx-modal-button.secondary{background:#fff;color:#666;border:2px solid #e5e5e5}.gx-modal-button.secondary:hover{background:#f8f8f8;border-color:#d0d0d0;transform:translateY(-1px);box-shadow:0 2px 6px #00000014}.gx-modal-button.secondary:active{background:#f0f0f0;transform:translateY(0)}.gx-modal-main-text{font-size:1.05rem;font-weight:600;color:#111827;margin:0 0 .4rem;line-height:1.5}.gx-modal-sub-text{font-size:.875rem;color:#6b7280;margin:0;line-height:1.6}.gx-modal-section{margin-top:1.25rem}.gx-modal-section:first-child{margin-top:0}.gx-modal-section-title{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem;letter-spacing:.01em}.gx-modal-list{display:flex;flex-direction:column;gap:.5rem;background:#f9fafb;padding:.75rem;border-radius:8px}.gx-modal-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;font-size:.9rem;padding:.4rem 0;border-bottom:1px solid #e5e7eb}.gx-modal-row:last-child{border-bottom:none;padding-bottom:0}.gx-modal-row:first-child{padding-top:0}.gx-modal-label{color:#6b7280;min-width:5rem;font-weight:500;flex-shrink:0}.gx-modal-value{flex:1;text-align:right;color:#111827;font-weight:500;word-break:break-word;line-height:1.5}@keyframes gx-modal-pop{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.reservation-detail-modal .detail-status-section{display:flex;justify-content:center;align-items:center;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid rgba(0,0,0,.06)}.reservation-detail-modal .detail-status-section .detail-status-badge{padding:8px 20px;border-radius:20px;font-size:14px;font-weight:700;box-shadow:0 2px 8px #00000014}.reservation-detail-modal .detail-status-section .detail-status-badge.requested,.reservation-detail-modal .detail-status-section .detail-status-badge.confirmed,.reservation-detail-modal .detail-status-section .detail-status-badge.changed{background:linear-gradient(135deg,#e63a3a,#ff6b6b);color:#fff}.reservation-detail-modal .detail-status-section .detail-status-badge.completed,.reservation-detail-modal .detail-status-section .detail-status-badge.checkin{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.reservation-detail-modal .detail-status-section .detail-status-badge.cancelled,.reservation-detail-modal .detail-status-section .detail-status-badge.noshow,.reservation-detail-modal .detail-status-section .detail-status-badge.checkin_cancel{background:linear-gradient(135deg,#757575,#9e9e9e);color:#fff}.reservation-detail-modal .reservation-id-box{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #E63A3A;border-radius:12px;padding:16px;text-align:center;font-size:20px;font-weight:700;color:#e63a3a;letter-spacing:1px;font-family:Courier New,monospace}.reservation-detail-modal .detail-info-box{background:linear-gradient(135deg,#fff8f0,#ffe8e8);border:1px solid rgba(230,58,58,.2);border-radius:12px;padding:14px 16px;display:flex;align-items:flex-start;gap:12px}.reservation-detail-modal .detail-info-box svg{flex-shrink:0;color:#e63a3a;margin-top:2px}.reservation-detail-modal .detail-info-box p{margin:0;font-size:13px;line-height:1.6;color:#666;font-weight:500}@media (max-width: 480px){.reservation-detail-modal .detail-status-section{margin-bottom:1rem;padding-bottom:1rem}.reservation-detail-modal .detail-status-section .detail-status-badge{font-size:13px;padding:7px 18px}.reservation-detail-modal .reservation-id-box{font-size:18px;padding:14px}.reservation-detail-modal .detail-info-box{padding:12px 14px;gap:10px}.reservation-detail-modal .detail-info-box svg{width:16px;height:16px}.reservation-detail-modal .detail-info-box p{font-size:12px}}.gx-alert-popup{width:100%;max-width:340px;background:#fff;border-radius:20px;box-shadow:0 16px 40px #0f172a52;padding:2rem 1.5rem 1.5rem;animation:gx-alert-pop .25s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;align-items:center;text-align:center}@media (max-width: 480px){.gx-alert-popup{max-width:calc(100% - 2rem);padding:1.75rem 1.25rem 1.25rem}}.gx-alert-popup__icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.gx-alert-popup__icon svg{width:30px;height:30px}.gx-alert-popup--error .gx-alert-popup__icon{background:linear-gradient(135deg,#e63a3a1f,#ff6b6b1f);color:#e63a3a}.gx-alert-popup--success .gx-alert-popup__icon{background:linear-gradient(135deg,#4caf501f,#66bb6a1f);color:#4caf50}.gx-alert-popup--warning .gx-alert-popup__icon{background:linear-gradient(135deg,#ff98001f,#ffb74d1f);color:#ff9800}.gx-alert-popup--info .gx-alert-popup__icon{background:linear-gradient(135deg,#2196f31f,#64b5f61f);color:#2196f3}.gx-alert-popup__title{margin:0 0 .5rem;font-size:1.15rem;font-weight:700;color:#111827;letter-spacing:-.02em;line-height:1.4}.gx-alert-popup__message{margin:0 0 1.5rem;font-size:.9rem;color:#6b7280;line-height:1.6;word-break:keep-all}.gx-alert-popup__button{width:100%;padding:.75rem 1.5rem;border-radius:12px;border:none;font-size:.95rem;font-weight:600;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.gx-alert-popup--error .gx-alert-popup__button{background:linear-gradient(135deg,#e63a3a,#ff6b6b);box-shadow:0 4px 12px #e63a3a4d}.gx-alert-popup--error .gx-alert-popup__button:hover{box-shadow:0 6px 16px #e63a3a66;transform:translateY(-2px)}.gx-alert-popup--error .gx-alert-popup__button:active{transform:translateY(0);box-shadow:0 2px 8px #e63a3a4d}.gx-alert-popup--success .gx-alert-popup__button{background:linear-gradient(135deg,#4caf50,#66bb6a);box-shadow:0 4px 12px #4caf504d}.gx-alert-popup--success .gx-alert-popup__button:hover{box-shadow:0 6px 16px #4caf5066;transform:translateY(-2px)}.gx-alert-popup--success .gx-alert-popup__button:active{transform:translateY(0);box-shadow:0 2px 8px #4caf504d}.gx-alert-popup--warning .gx-alert-popup__button{background:linear-gradient(135deg,#ff9800,#ffb74d);box-shadow:0 4px 12px #ff98004d}.gx-alert-popup--warning .gx-alert-popup__button:hover{box-shadow:0 6px 16px #ff980066;transform:translateY(-2px)}.gx-alert-popup--warning .gx-alert-popup__button:active{transform:translateY(0);box-shadow:0 2px 8px #ff98004d}.gx-alert-popup--info .gx-alert-popup__button{background:linear-gradient(135deg,#2196f3,#64b5f6);box-shadow:0 4px 12px #2196f34d}.gx-alert-popup--info .gx-alert-popup__button:hover{box-shadow:0 6px 16px #2196f366;transform:translateY(-2px)}.gx-alert-popup--info .gx-alert-popup__button:active{transform:translateY(0);box-shadow:0 2px 8px #2196f34d}@keyframes gx-alert-pop{0%{opacity:0;transform:scale(.85) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.base-swiper-wrapper{position:relative;width:100%}.base-swiper-wrapper .swiper{width:100%;height:100%}.base-swiper-wrapper .swiper-slide{display:flex;align-items:center;justify-content:center;will-change:transform;transform:translateZ(0);backface-visibility:hidden}.base-swiper-wrapper .swiper-button-prev,.base-swiper-wrapper .swiper-button-next{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;background:#00000040;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:50%;color:#fff;opacity:.85;transition:all .3s ease}.base-swiper-wrapper .swiper-button-prev:after,.base-swiper-wrapper .swiper-button-next:after{font-size:14px;font-weight:700}.base-swiper-wrapper .swiper-button-prev:hover,.base-swiper-wrapper .swiper-button-next:hover{transform:translateY(-50%) scale(1.1)}.base-swiper-wrapper .swiper-button-prev.swiper-button-disabled,.base-swiper-wrapper .swiper-button-next.swiper-button-disabled{opacity:.3;cursor:not-allowed}.base-swiper-wrapper .swiper-button-prev{left:12px}.base-swiper-wrapper .swiper-button-next{right:12px}.base-swiper-wrapper .swiper-pagination{bottom:12px}.base-swiper-wrapper .swiper-pagination .swiper-pagination-bullet{background:#ffffff80;opacity:1;width:8px;height:8px;transition:all .3s ease}.base-swiper-wrapper .swiper-pagination .swiper-pagination-bullet-active{background:#fff;width:24px;border-radius:4px}.promo-swiper{border-radius:16px;overflow:hidden}.promo-swiper--skeleton{background:#ececec;box-shadow:0 12px 25px #0000000f}.promo-swiper__skeleton{width:100%;aspect-ratio:16/9;border-radius:inherit;background:linear-gradient(90deg,#ececec,#f5f5f5,#ececec);background-size:200% 100%}.promo-swiper .banner-slide{cursor:pointer;width:100%;aspect-ratio:16/9;overflow:hidden;position:relative}.promo-swiper .swiper-slide img{width:100%;height:100%;object-fit:cover;display:block}.promo-swiper .swiper-button-prev,.promo-swiper .swiper-button-next{top:57.5%;width:36px;height:36px;background:#00000040;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:50%;color:#fff;opacity:0;transition:all .3s ease}.promo-swiper .swiper-button-prev:after,.promo-swiper .swiper-button-next:after{font-size:14px;font-weight:700}.promo-swiper .swiper-button-prev.swiper-button-disabled,.promo-swiper .swiper-button-next.swiper-button-disabled{opacity:0!important;cursor:not-allowed}.promo-swiper .swiper-button-prev{left:12px}.promo-swiper .swiper-button-next{right:12px}.promo-swiper:hover .swiper-button-prev,.promo-swiper:hover .swiper-button-next{background:#0006;opacity:.85}.promo-swiper:hover .swiper-button-prev.swiper-button-disabled,.promo-swiper:hover .swiper-button-next.swiper-button-disabled{opacity:.3}.promo-swiper .swiper-pagination{bottom:12px}.promo-swiper .swiper-pagination .swiper-pagination-bullet{background:#ffffff80;opacity:1;width:8px;height:8px;transition:all .3s ease}.promo-swiper .swiper-pagination .swiper-pagination-bullet-active{background:#fff;width:24px;border-radius:4px}.media-swiper{width:100%;height:100%;background:#000}.media-swiper .swiper-slide{background:#000}.media-swiper .modal-image,.media-swiper .modal-video{width:100%;height:100%;object-fit:contain;background:#000}.media-swiper .swiper-nav-btn--prev{left:8px}.media-swiper .swiper-nav-btn--next{right:8px}@media (max-width: 768px){.base-swiper-wrapper .swiper-nav-btn{width:32px;height:32px}.base-swiper-wrapper .swiper-nav-btn svg{width:16px;height:16px}}.review-videos{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0}@media (max-width: 768px){.review-videos{gap:8px}}.video-thumbnail-card{text-decoration:none;color:inherit;display:block}.video-thumbnail-card--embedded{cursor:inherit}.video-thumbnail-card .video-thumbnail{position:relative;width:100%;aspect-ratio:9/16;border-radius:8px;overflow:hidden;background:#f5f5f5;cursor:pointer;transition:transform .2s ease}.video-thumbnail-card .video-thumbnail:hover{transform:scale(1.02)}.video-thumbnail-card .video-thumbnail .thumbnail-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;opacity:0;transition:opacity .22s ease}.video-thumbnail-card .video-thumbnail .thumbnail-poster--ready{opacity:1}.video-thumbnail-card .video-thumbnail .thumbnail-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;opacity:0;transition:opacity .2s ease}.video-thumbnail-card .video-thumbnail .thumbnail-video--ready{opacity:1}.video-thumbnail-card .video-thumbnail .thumbnail-fallback{position:absolute;inset:0;width:100%;height:100%;background:linear-gradient(180deg,#2d2d2d,#1a1a1a);pointer-events:none}.video-thumbnail-card .video-thumbnail .video-thumbnail__spinner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none}.video-thumbnail-card .video-thumbnail .video-thumbnail__spinner--video{background:#00000047}.video-thumbnail-card .video-thumbnail .video-thumbnail__spinner--placeholder{background:transparent}.video-thumbnail-card .video-thumbnail .play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:48px;height:48px;background:#00000080;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.video-thumbnail-card .video-thumbnail .play-icon svg{width:24px;height:24px;margin-left:2px}.video-thumbnail-card .video-thumbnail:hover .play-icon{background:#000000b3;transform:translate(-50%,-50%) scale(1.1)}.video-thumbnail-card .video-thumbnail .video-title-overlay{position:absolute;bottom:0;left:0;right:0;z-index:2;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:12px 8px 8px}.video-thumbnail-card .video-thumbnail .video-title-overlay .video-title{color:#fff;font-size:12px;font-weight:500;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.video-thumbnail-card--embedded .video-thumbnail{cursor:inherit}.video-thumbnail-card--embedded .video-thumbnail:hover{transform:none}.video-thumbnail-card--embedded .video-thumbnail:hover .play-icon{transform:translate(-50%,-50%)}.review-videos-loading,.review-videos-empty{grid-column:1/-1;padding:40px 20px;text-align:center;color:#999;font-size:14px}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.05rem;width:100%;margin:0;box-sizing:border-box;overflow:hidden;place-items:center;justify-items:center;align-items:center}.category-grid--skeleton{pointer-events:none;width:100%;aspect-ratio:4/6;border-radius:inherit;background:linear-gradient(90deg,#ececec,#f5f5f5,#ececec);background-size:200% 100%}.category-grid .icon-button-container{display:flex;flex-direction:column;align-items:center;background:none;border:none;cursor:pointer;padding:.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.category-grid .icon-button-container:active{transform:scale(.9)}.category-grid .icon-button-container:active .icon-box{background-color:#f0f0f0;box-shadow:inset 0 2px 4px #0000000d}.category-grid .icon-button-container .icon-box{display:flex;align-items:center;justify-content:center;width:4rem;height:4rem;border-radius:18px;transition:all .2s}.category-grid .icon-button-container .icon-box img{padding:.25rem;object-fit:contain}.category-grid .icon-button-container .icon-box img.skin-icon{filter:none;opacity:1}.category-grid .icon-button-container .icon-label{font-size:.75rem;font-weight:600;color:#333;white-space:nowrap}.home-container{display:flex;flex-direction:column;min-height:calc(100dvh - var(--collapsed-header-h) - var(--tabbar-h));padding:.75rem 1rem;margin-bottom:var(--tabbar-h);gap:1rem;background-color:#fff}.home-container .section-container{padding:0}.home-container .section-container .section-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .25rem 1.25rem;background-color:transparent}.home-container .section-container .section-header .section-title{display:flex;align-items:center;gap:8px;font-size:1.625rem;font-weight:700;color:#1a1a1a;margin:0;letter-spacing:-.5px}.home-container .section-container .section-header .section-title:before{content:"";width:4px;height:26px;background:linear-gradient(to bottom,#e63a3a,#ff6b6b);border-radius:2px}.home-container .section-container .section-header .more-link{display:flex;align-items:center;gap:2px;font-size:14px;font-weight:500;color:#8e8e93;text-decoration:none;transition:color .2s}.home-container .section-container .section-header .more-link:hover{color:#667eea}.home-container .section-container .section-header .more-link svg{stroke-width:2.5}.home-container .home-bottom-bundle-loading{display:flex;flex:1 1 auto;flex-direction:column;align-items:center;justify-content:center;min-height:0;width:100%}.home-container .home-bottom-bundle-loading .loading-state{flex:0 0 auto;min-height:0}.gx-modal-backdrop.feed-video-modal-layer{display:flex;flex-direction:row;align-items:center;justify-content:center;padding:calc(12px + env(safe-area-inset-top,0)) 12px calc(12px + env(safe-area-inset-bottom,0));background:#000000f0}.feed-video-modal{position:relative;flex:0 0 auto;width:min(100vw - 24px,var(--mobile-max-width));max-width:min(100vw - 24px,var(--mobile-max-width));min-width:0;max-height:min(100dvh - 24px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px),100dvh);display:flex;flex-direction:column;border-radius:14px;overflow-x:hidden;overflow-y:auto;background-color:#000;background:#000;box-shadow:0 12px 40px #0000008c}.feed-video-modal__close{position:absolute;top:6px;right:10px;z-index:2;width:28px;height:28px;border:none;border-radius:50%;background:#00000080;color:#fff;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.feed-video-modal__player{position:relative;flex:0 0 auto;width:100%;min-height:180px;max-height:calc(100dvh - 168px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));aspect-ratio:9/16;box-sizing:border-box;display:flex;align-items:center;justify-content:center;background-color:#000;background:#000;overflow:hidden}.feed-video-modal__player video{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;background-color:#000}.feed-video-modal__meta{flex-shrink:0;padding:8px 10px 12px;background:#1a1a1a;color:#f5f5f5;min-height:72px;max-height:min(220px,36vh);overflow-y:auto}.feed-video-modal__author{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}.feed-video-modal__author-main{display:flex;align-items:center;gap:6px;min-width:0;text-decoration:none;color:inherit}.feed-video-modal__author-main--static{cursor:default}.feed-video-modal__author-logo{width:28px;height:28px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#333}.feed-video-modal__author-logo img{width:100%;height:100%;object-fit:cover}.feed-video-modal__author-name{font-size:clamp(11px,3.4vw,13px);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feed-video-modal__author-cta{flex-shrink:0;font-size:clamp(10px,3vw,11px);font-weight:600;color:#ff6b6b;text-decoration:none;padding:4px 6px;border-radius:6px;border:1px solid rgba(255,107,107,.45)}.feed-video-modal__title{margin:0 0 6px;font-size:clamp(12px,3.6vw,14px);font-weight:700;line-height:1.35;color:#fff}.feed-video-modal__tags{display:flex;flex-wrap:wrap;gap:4px}.feed-video-modal__tag{font-size:clamp(10px,3vw,11px);font-weight:500;color:#ff8a8a}.feed-video-modal__desc-plain{margin:0;font-size:clamp(10px,3vw,11px);line-height:1.45;color:#f5f5f5d1;word-break:break-word}
