/* GRAND OCEAN HOTEL */
@charset "utf-8";
:root {
  --brown: #6b5a3e; --brown-dk: #4a3d2a; --brown-lt: #957b52;
  --gold: #b8962e; --gold-lt: #d4b263;
  --cream: #f7f3ee; --cream-dk: #ede8e1; --warm: #faf8f5;
  --text: #1a1a1a; --text2: #555; --text3: #999;
  --bdr: #e0dbd4; --bdr-lt: #eee9e2;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Noto Sans KR', -apple-system, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);font-size:15px;line-height:1.8;color:var(--text);background:#fff;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}

/* ===== PAGE LOADER ===== */
.page-loader{position:fixed;top:0;left:0;right:0;z-index:9999;height:3px;transition:opacity .4s}
.page-loader.hide{opacity:0}
.page-loader-inner{height:100%;width:100%;background:transparent}
.page-loader-line{height:100%;background:var(--brown);animation:loaderSlide 1s cubic-bezier(.4,0,.2,1) forwards}
@keyframes loaderSlide{0%{width:0}70%{width:85%}100%{width:100%}}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .4s}
.header--transparent{background:transparent;border-bottom:1px solid rgba(255,255,255,.12)}
.header:not(.header--transparent){background:#fff;border-bottom:1px solid var(--bdr-lt)}
.header.scrolled{background:rgba(255,255,255,.97)!important;border-bottom-color:var(--bdr-lt)!important;box-shadow:0 1px 30px rgba(0,0,0,.06);backdrop-filter:blur(10px)}
.header-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;padding:0 40px;height:80px;position:relative}
.logo{text-align:center;margin:0 60px;flex-shrink:0}
.logo-en{display:block;font-family:var(--serif);font-size:1.55rem;font-weight:500;letter-spacing:5px;color:var(--brown);transition:color .3s}
.logo-sub{display:block;font-family:var(--serif);font-size:.5rem;letter-spacing:4px;color:var(--text3);margin-top:-8px}
.header--transparent .logo-en{color:#fff}
.header--transparent .logo-sub{color:rgba(255,255,255,.45)}
.header.scrolled .logo-en{color:var(--brown)!important}
.header.scrolled .logo-sub{color:var(--text3)!important}
.gnb{display:flex;gap:36px;flex:1}
.gnb--left{justify-content:flex-end}
.gnb--right{justify-content:flex-start}
.gnb a{font-size:12px;font-weight:400;letter-spacing:2.5px;color:var(--text2);padding:8px 0;position:relative;transition:color .3s}
.header--transparent .gnb a{color:rgba(255,255,255,.85)}
.header.scrolled .gnb a{color:var(--text2)!important}
.gnb a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--brown);transform:scaleX(0);transition:transform .3s}
.gnb a:hover::after,.gnb a.active::after{transform:scaleX(1)}
.gnb a.active{color:var(--brown)}
.header--transparent .gnb a.active{color:var(--gold-lt)}
.gnb-phone{font-family:var(--serif)!important;font-size:14px!important;letter-spacing:1px!important}
.mobile-menu-btn{display:none;position:absolute;right:24px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;width:26px;height:18px;flex-direction:column;justify-content:space-between}
.mobile-menu-btn span{display:block;width:100%;height:1.5px;background:var(--text);transition:.3s}
.header--transparent .mobile-menu-btn span{background:#fff}
.header.scrolled .mobile-menu-btn span{background:var(--text)!important}
.mobile-nav{position:fixed;top:0;right:-100%;width:100%;height:100%;background:#fff;z-index:200;transition:right .4s cubic-bezier(.4,0,.2,1)}
.mobile-nav.open{right:0}
.mobile-nav-close{position:absolute;top:24px;right:28px;background:none;border:none;font-size:28px;color:var(--text);cursor:pointer;font-weight:300}
.mobile-nav-inner{padding:100px 48px}
.mobile-nav-logo{font-family:var(--serif);font-size:1.3rem;letter-spacing:4px;color:var(--brown);margin-bottom:48px}
.mobile-nav nav a{display:block;padding:18px 0;font-size:13px;letter-spacing:3px;color:var(--text);border-bottom:1px solid var(--bdr-lt)}
.mobile-nav-info{margin-top:48px;font-size:13px;color:var(--text3);line-height:2.2}
body.nav-open{overflow:hidden}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:700px;overflow:hidden}
.hero__slider{position:absolute;inset:0}
.hero__slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease-in-out}
.hero__slide.active{opacity:1}
.hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,.35);z-index:1}
.hero__content{position:absolute;z-index:2;left:0;right:0;top:50%;transform:translateY(-50%);text-align:center;padding:0 40px}
.hero__sub{display:block;font-family:var(--serif);font-size:.8rem;letter-spacing:6px;color:rgba(255,255,255,.5);margin-bottom:20px}
.hero__title{font-family:var(--serif);font-size:4.2rem;font-weight:300;color:#fff;letter-spacing:2px;line-height:1.15;margin-bottom:20px}
.hero__desc{font-size:.95rem;color:rgba(255,255,255,.7);margin-bottom:36px;font-weight:300;letter-spacing:.5px}
.hero__btn{display:inline-block;padding:14px 40px;border:1px solid rgba(255,255,255,.35);color:#fff;font-size:12px;letter-spacing:3px;transition:all .3s}
.hero__btn:hover{background:#fff;color:var(--brown);border-color:#fff}

/* Hero Animations */
@keyframes heroFadeUp{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}
@keyframes heroLetterIn{0%{opacity:0;transform:translateY(40px) rotateX(40deg)}100%{opacity:1;transform:translateY(0) rotateX(0)}}
@keyframes heroLineReveal{0%{clip-path:inset(0 100% 0 0)}100%{clip-path:inset(0 0 0 0)}}
.hero-anim{opacity:0;animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) forwards}
.hero-anim-line{display:inline-block;opacity:0;animation:heroFadeUp 1s cubic-bezier(.16,1,.3,1) forwards}
.hero-anim-line .hero-letter{display:inline-block;opacity:0;animation:heroLetterIn .6s cubic-bezier(.16,1,.3,1) forwards}
.hero__btn.hero-anim{animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) forwards,heroLineReveal .6s cubic-bezier(.16,1,.3,1) forwards}
@media(prefers-reduced-motion:reduce){.hero-anim,.hero-anim-line,.hero-anim-line .hero-letter{animation:none;opacity:1}}
.hero__nav{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:12px}
.hero__nav-btn{width:40px;height:3px;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:background .3s;padding:0}
.hero__nav-btn.active{background:#fff}
.hero__nav-btn span{display:none}

/* Floating Reservation */
.qr-fab{position:fixed;bottom:32px;right:32px;z-index:200;width:72px;height:72px;border-radius:50%;background:rgba(107,90,62,.85);color:#fff;border:1px solid rgba(255,255,255,.15);cursor:pointer;box-shadow:0 6px 24px rgba(0,0,0,.25);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;transition:all .3s;opacity:0;transform:scale(.8);pointer-events:none;backdrop-filter:blur(8px)}
.qr-fab.show{opacity:1;transform:scale(1);pointer-events:auto}
.qr-fab:hover{background:rgba(107,90,62,.9);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.qr-fab svg{width:20px;height:20px}
.qr-fab span{font-family:var(--serif);font-size:9px;letter-spacing:1.5px;font-weight:400}
.qr-top{position:fixed;bottom:116px;right:44px;z-index:200;width:40px;height:40px;background:rgba(255,255,255,.85);color:var(--text2);border:1px solid rgba(0,0,0,.06);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;opacity:0;transform:translateY(10px);pointer-events:none;backdrop-filter:blur(8px);box-shadow:0 2px 12px rgba(0,0,0,.08)}
.qr-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
.qr-top:hover{background:#fff;color:var(--brown)}
.qr-top svg{width:14px;height:14px}
.qr-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;visibility:hidden;transition:all .35s}
.qr-overlay.open{opacity:1;visibility:visible}
.qr-panel{position:fixed;bottom:0;right:0;width:360px;max-height:80vh;background:rgba(17,17,17,.92);color:#fff;z-index:301;transition:all .4s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-4px 0 60px rgba(0,0,0,.3);backdrop-filter:blur(20px);transform:translateX(100%);opacity:0}
.qr-panel.open{transform:translateX(0);opacity:1}
.qr-panel-head{display:flex;justify-content:space-between;align-items:center;padding:24px 28px 20px}
.qr-panel-head h3{font-family:var(--serif);font-size:13px;font-weight:400;letter-spacing:4px;color:rgba(255,255,255,.5)}
.qr-panel-close{background:none;border:none;color:rgba(255,255,255,.4);font-size:22px;cursor:pointer;padding:0;line-height:1;transition:color .2s;font-weight:300}
.qr-panel-close:hover{color:#fff}
.qr-panel-body{padding:0 28px 32px}
.qr-panel-notice{margin-bottom:20px;padding:0 14px;background:rgba(129,108,91,.12);border:1px solid rgba(129,108,91,.15);height:36px;overflow:hidden;position:relative}
.qr-pn-track{transition:transform .4s cubic-bezier(.4,0,.2,1)}
.qr-pn-item{display:flex;align-items:center;height:36px;font-size:11px;color:rgba(255,255,255,.55);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}
.qr-pn-item:hover{color:rgba(255,255,255,.9)}
.qr-pn-item::before{content:'·';margin-right:8px;color:rgba(129,108,91,.6);flex-shrink:0}
.qr-panel-hotel{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.08)}
.qr-panel-hotel span{display:block;font-family:var(--serif);font-size:1rem;letter-spacing:4px;color:rgba(255,255,255,.85);font-weight:400}
.qr-panel-hotel small{display:block;font-family:var(--serif);font-size:.45rem;letter-spacing:3px;color:rgba(255,255,255,.25);margin-top:3px}
.qr-field{margin-bottom:18px}
.qr-field label{display:block;font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.35);margin-bottom:8px;font-weight:400}
.qr-field input,.qr-field select{width:100%;padding:12px 0;border:none;border-bottom:1px solid rgba(255,255,255,.12);font-size:14px;font-family:var(--sans);color:#fff;background:transparent;outline:none;transition:border-color .3s}
.qr-field input:focus,.qr-field select:focus{border-bottom-color:rgba(255,255,255,.4)}
.qr-field select option{color:#333;background:#fff}
.qr-field-row{display:flex;gap:24px}
.qr-field-row .qr-field{flex:1}
.qr-date-display,.qr-guest-display{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);cursor:pointer;transition:border-color .3s}
.qr-date-display:hover,.qr-guest-display:hover{border-bottom-color:rgba(255,255,255,.35)}
.qr-date-display svg,.qr-guest-display svg{opacity:.4;flex-shrink:0}
.qr-date-text,.qr-guest-text{font-size:14px;color:rgba(255,255,255,.5);font-family:var(--sans)}
.qr-date-text.filled,.qr-guest-text.filled{color:#fff}
.qr-field--date.active .qr-date-display,.qr-field--guest.active .qr-guest-display{border-bottom-color:rgba(255,255,255,.4)}
/* Sub-panels (pop left of main panel) */
/* Sub-panels (white) */
.qr-sub{position:fixed;bottom:0;right:360px;width:520px;max-height:80vh;background:#fff;color:var(--text);z-index:302;box-shadow:-4px 0 40px rgba(0,0,0,.1);transform:translateX(40px);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;display:flex;flex-direction:column}
.qr-sub-head{flex-shrink:0}
.qr-sub-body{flex:1;overflow-y:auto;padding:0 28px 28px;scrollbar-width:thin;scrollbar-color:var(--bdr) transparent}
.qr-sub-body::-webkit-scrollbar{width:4px}
.qr-sub-body::-webkit-scrollbar-track{background:transparent}
.qr-sub-body::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:2px}
.qr-sub-body::-webkit-scrollbar-thumb:hover{background:var(--text3)}
.qr-sub.open{transform:translateX(0);opacity:1;pointer-events:auto}
.qr-sub-head{display:flex;justify-content:space-between;align-items:center;padding:24px 28px 16px}
.qr-sub-head h4{font-family:var(--serif);font-size:12px;font-weight:400;letter-spacing:3px;color:var(--text3)}
.qr-sub-close{background:none;border:none;color:var(--text3);font-size:20px;cursor:pointer;padding:0;line-height:1;transition:color .2s}
.qr-sub-close:hover{color:var(--text)}
.qr-sub-done{width:100%;padding:14px;margin-top:20px;background:var(--brown);color:#fff;border:none;font-size:12px;letter-spacing:2px;cursor:pointer;transition:background .2s}
.qr-sub-done:hover{background:var(--brown-dk)}
/* Calendar range display */
.qr-cal-range-display{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:16px 20px;background:var(--cream);border:1px solid var(--bdr-lt)}
.qr-cal-range-box{flex:1}
.qr-cal-range-label{display:block;font-size:10px;letter-spacing:2px;color:var(--text3);margin-bottom:4px}
.qr-cal-range-box strong{font-size:14px;color:var(--text2);font-weight:400}
.qr-cal-range-box strong.filled{color:var(--text)}
.qr-cal-range-arrow{color:var(--bdr);font-size:14px;flex-shrink:0}
.qr-cal-range-nights{font-size:11px;color:var(--brown);flex-shrink:0;letter-spacing:1px;font-weight:600}
/* 2-month calendar */
.qr-cal-months{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.qr-cal-month-block{min-width:0}
.qr-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.qr-cal-title{font-size:13px;font-weight:600;letter-spacing:.5px;color:var(--text)}
.qr-cal-nav{background:none;border:none;color:var(--text3);cursor:pointer;padding:6px;transition:all .2s;display:flex;align-items:center}
.qr-cal-nav:hover{color:var(--brown)}
.qr-cal-days{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:6px}
.qr-cal-days span{font-size:10px;letter-spacing:1px;color:var(--text3);padding:4px 0}
.qr-cal-days span:first-child{color:rgba(200,80,80,.6)}
.qr-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.qr-cal-grid button{background:none;border:none;color:var(--text2);font-size:13px;padding:9px 0;cursor:pointer;transition:all .15s;font-family:var(--sans)}
.qr-cal-grid button:hover:not(:disabled):not(.qr-cal-selected){background:var(--cream);color:var(--text)}
.qr-cal-grid button:disabled{color:var(--bdr);cursor:default}
.qr-cal-grid button.qr-cal-today{background:var(--cream);color:var(--brown);font-weight:600}
.qr-cal-grid button.qr-cal-selected{background:var(--brown);color:#fff;font-weight:600;box-shadow:0 0 0 2px var(--brown),0 0 0 4px rgba(107,90,62,.25)}
.qr-cal-grid button.qr-cal-checkin,.qr-cal-grid button.qr-cal-checkout{background:var(--brown)!important;color:#fff!important;font-weight:600;box-shadow:0 0 0 2px var(--brown),0 0 0 4px rgba(107,90,62,.25)}
.qr-cal-grid button.qr-cal-range{background:rgba(107,90,62,.08);color:var(--text)}
.qr-cal-grid button.qr-cal-sun{color:rgba(200,80,80,.7)}
.qr-cal-grid button.qr-cal-sun:disabled{color:rgba(200,80,80,.25)}
/* Guest picker rows */
.qr-gp-row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--bdr-lt)}
.qr-gp-row:last-of-type{border-bottom:none}
.qr-gp-label strong{display:block;font-size:14px;font-weight:500;color:var(--text)}
.qr-gp-label small{font-size:11px;color:var(--text3);font-weight:300;margin-top:2px;display:block}
.qr-gp-ctrl{display:flex;align-items:center;gap:20px}
.qr-gp-ctrl span{font-size:16px;min-width:24px;text-align:center;color:var(--text);font-weight:500}
.qr-gp-btn{width:36px;height:36px;border:1px solid var(--bdr);background:transparent;color:var(--text2);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.qr-gp-btn:hover{border-color:var(--brown);color:var(--brown)}
.qr-gp-btn:disabled{border-color:var(--bdr-lt);color:var(--bdr);cursor:default}
.qr-submit{display:block;width:100%;padding:18px;background:rgba(129,108,91,.85);color:#fff;text-align:center;font-size:13px;letter-spacing:4px;font-weight:500;margin-top:28px;transition:all .3s}
.qr-submit:hover{background:rgba(129,108,91,1)}
.qr-phone{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding:10px;font-size:12px;color:rgba(255,255,255,.35);transition:color .3s;letter-spacing:1px}
.qr-phone svg{opacity:.5}
.qr-phone:hover{color:rgba(255,255,255,.7)}

/* ===== NOTICE BAR ===== */
.notice-bar{background:var(--brown-dk);color:#fff;overflow:hidden;position:relative;z-index:5}
.notice-bar-inner{max-width:1400px;margin:0 auto;padding:0 40px;display:flex;align-items:center;gap:20px;height:48px}
.notice-bar-icon{flex-shrink:0;color:rgba(255,255,255,.5);display:flex;align-items:center}
.notice-bar-slider{flex:1;height:48px;overflow:hidden;position:relative}
.notice-bar-track{transition:transform .4s cubic-bezier(.4,0,.2,1)}
.notice-bar-item{display:flex;align-items:center;height:48px;color:#fff;text-decoration:none;gap:20px}
.notice-bar-item:hover .notice-bar-title{color:var(--gold-lt)}
.notice-bar-title{font-size:13px;font-weight:500;letter-spacing:.3px;color:rgba(255,255,255,.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .3s}
.notice-bar-desc{font-size:12px;font-weight:300;color:rgba(255,255,255,.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notice-bar-date{font-family:var(--serif);font-size:11px;letter-spacing:.5px;color:rgba(255,255,255,.35);flex-shrink:0;margin-left:auto}
.notice-bar-pause{flex-shrink:0;background:none;border:none;color:rgba(255,255,255,.35);cursor:pointer;padding:4px;transition:color .3s;display:flex;align-items:center}
.notice-bar-pause:hover{color:#fff}

/* ===== SECTION COMMON ===== */
.offers__line,.about__line,.fac__line,.rev__line{width:40px;height:1px;background:var(--gold);margin-bottom:16px}
.offers__title,.about__title,.fac__title,.rev__title{font-family:var(--serif);font-size:1.8rem;font-weight:400;letter-spacing:6px;color:var(--text);margin-bottom:8px}
.offers__sub,.fac__sub,.rev__sub{font-size:14px;color:var(--text3);letter-spacing:1px}

/* ===== OFFERS ===== */
.offers{padding:120px 0 100px}
.offers__inner{max-width:1280px;margin:0 auto;padding:0 40px}
.offers__head{text-align:center;margin-bottom:60px}
.offers__head .offers__line{margin:0 auto 16px}
/* Featured Card */
.offers__featured{display:flex;overflow:hidden;margin-bottom:16px;border:1px solid var(--bdr-lt);transition:box-shadow .3s}
.offers__featured:hover{box-shadow:0 12px 48px rgba(0,0,0,.08)}
.offers__featured-img{flex:1.3;height:420px;overflow:hidden}
.offers__featured-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.offers__featured:hover .offers__featured-img img{transform:scale(1.04)}
.offers__featured-info{flex:1;padding:48px;display:flex;flex-direction:column;justify-content:center;background:var(--warm)}
.offers__featured-info h3{font-size:1.6rem;font-weight:600;margin-bottom:8px;color:var(--text)}
.offers__featured-info p{font-size:14px;color:var(--text2);line-height:1.9;margin-bottom:16px}
/* Grid */
.offers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.offers__card{position:relative;overflow:hidden;display:block;height:320px}
.offers__card-img{position:absolute;inset:0}
.offers__card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.offers__card:hover .offers__card-img img{transform:scale(1.06)}
.offers__card-info{position:absolute;bottom:0;left:0;right:0;padding:28px;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 100%);color:#fff;z-index:1}
.offers__card-badge{font-size:10px;letter-spacing:2px;text-transform:uppercase;opacity:.7;display:block;margin-bottom:6px}
.offers__card-info h3{font-size:1.2rem;font-weight:500;margin-bottom:4px}
.offers__card-info p{font-size:12px;opacity:.75;margin-bottom:6px}
.offers__card-price{font-family:var(--serif);font-size:1.1rem;font-weight:500}
.offers__more{display:block;text-align:center;margin-top:48px;font-size:13px;letter-spacing:2px;color:var(--brown)}
.offers__more:hover{color:var(--brown-dk)}

/* ===== ABOUT ===== */
.about{padding:120px 0;background:var(--cream)}
.about__inner{max-width:1280px;margin:0 auto;padding:0 40px;display:flex;gap:80px;align-items:center}
.about__img{flex:1.1;overflow:hidden}
.about__img img{width:100%;height:500px;object-fit:cover}
.about__text{flex:1}
.about__kr{font-size:1.5rem;font-weight:600;margin-bottom:24px;color:var(--text)}
.about__desc{font-size:14px;color:var(--text2);line-height:2.2;margin-bottom:40px}
.about__stats{display:flex;gap:40px;margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid var(--bdr)}
.about__stat strong{display:block;font-family:var(--serif);font-size:2rem;font-weight:500;color:var(--brown);letter-spacing:1px}
.about__stat span{font-size:11px;letter-spacing:1.5px;color:var(--text3)}
.about__link{font-size:13px;letter-spacing:2px;color:var(--brown);border-bottom:1px solid var(--brown);padding-bottom:2px}

/* ===== FACILITIES HOME ===== */
.fac{padding:120px 0}
.fac__inner{max-width:1280px;margin:0 auto;padding:0 40px}
.fac__head{text-align:center;margin-bottom:60px}
.fac__head .fac__line{margin:0 auto 16px}
.fac__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.fac__card{position:relative;overflow:hidden;display:block;height:300px}
.fac__card-img{position:absolute;inset:0}
.fac__card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.fac__card:hover .fac__card-img img{transform:scale(1.06)}
.fac__card-body{position:absolute;bottom:0;left:0;right:0;padding:24px;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);color:#fff;z-index:1}
.fac__card-en{font-family:var(--serif);font-size:.7rem;letter-spacing:2px;opacity:.6;display:block;margin-bottom:4px}
.fac__card-body h3{font-size:1.1rem;font-weight:500}

/* ===== REVIEWS ===== */
.rev{padding:120px 0;background:var(--warm)}
.rev__inner{max-width:1100px;margin:0 auto;padding:0 40px}
.rev__head{text-align:center;margin-bottom:60px}
.rev__head .rev__line{margin:0 auto 16px}
.rev__list{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.rev__card{background:#fff;padding:40px 32px;border:1px solid var(--bdr-lt);transition:box-shadow .3s}
.rev__card:hover{box-shadow:0 8px 40px rgba(0,0,0,.05)}
.rev__stars{color:var(--gold);font-size:13px;letter-spacing:3px;margin-bottom:20px}
.rev__text{font-size:14px;color:var(--text2);line-height:2;margin-bottom:24px;font-style:italic}
.rev__meta{display:flex;justify-content:space-between;align-items:center;font-size:13px}
.rev__meta strong{color:var(--text)}
.rev__meta span{color:var(--text3)}

/* ===== CTA ===== */
.cta{position:relative;height:450px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cta__bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed}
.cta__overlay{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.cta__content{position:relative;z-index:1;text-align:center;color:#fff}
.cta__content h2{font-family:var(--serif);font-size:2.2rem;font-weight:300;letter-spacing:8px;margin-bottom:16px}
.cta__content p{font-size:15px;opacity:.7;margin-bottom:40px}
.cta__btn{display:inline-block;padding:15px 56px;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:13px;letter-spacing:3px;transition:all .3s}
.cta__btn:hover{background:#fff;color:var(--brown);border-color:#fff}

/* ===== ROOMS LIST ===== */
.rm-hero{height:50vh;min-height:380px;padding-top:80px;background:linear-gradient(135deg,#3a2f1e,#5c4a32);display:flex;align-items:center;justify-content:center;text-align:center}
.rm-hero-label{font-family:var(--serif);font-size:.75rem;letter-spacing:5px;color:rgba(255,255,255,.4);margin-bottom:14px}
.rm-hero-title{font-size:2.2rem;font-weight:500;color:#fff;margin-bottom:12px;letter-spacing:2px}
.rm-hero-subtitle{font-size:14px;color:rgba(255,255,255,.5);font-weight:300}
.rm-list{padding:0}
.rm-full{display:flex;min-height:600px}
.rm-full--rev{flex-direction:row-reverse}
.rm-full-img{display:block;width:58%;overflow:hidden;position:relative}
.rm-full-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.25,.46,.45,.94)}
.rm-full:hover .rm-full-img img{transform:scale(1.04)}
.rm-full-badge{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,.9);color:var(--brown);font-size:10px;letter-spacing:2px;padding:6px 16px;backdrop-filter:blur(4px)}
.rm-full--rev .rm-full-badge{left:auto;right:24px}
.rm-full-body{width:42%;display:flex;flex-direction:column;justify-content:center;padding:80px 64px;background:#fff}
.rm-full:nth-child(even) .rm-full-body{background:var(--warm)}
.rm-full-en{display:block;font-family:var(--serif);font-size:.6rem;letter-spacing:5px;color:var(--text3);margin-bottom:10px}
.rm-full-body h2{font-size:1.7rem;font-weight:500;margin-bottom:0;letter-spacing:1px}
.rm-full-body h2 a{color:var(--text)}
.rm-full-line{width:32px;height:1px;background:var(--gold);margin:20px 0}
.rm-full-specs{display:flex;gap:16px;margin-bottom:24px}
.rm-full-specs span{font-size:12px;color:var(--text3);letter-spacing:.5px}
.rm-full-body>p{font-size:14px;color:var(--text2);line-height:2;margin-bottom:32px}
.rm-full-price{font-family:var(--serif);font-size:1.8rem;color:var(--brown);font-weight:400;margin-bottom:32px;letter-spacing:1px}
.rm-full-price small{font-size:.75rem;color:var(--text3)}
.rm-full-btns{display:flex;gap:10px}
.rm-btn-line{font-size:12px;letter-spacing:2px;color:var(--brown);padding-bottom:2px;border-bottom:1px solid var(--brown);transition:opacity .3s}
.rm-btn-line:hover{opacity:.6}
.rm-btn-fill{padding:11px 28px;background:var(--brown);color:#fff;font-size:11px;letter-spacing:2px;transition:background .3s}
.rm-btn-fill:hover{background:var(--brown-dk)}
.rm-cta{padding:100px 0;background:var(--cream);text-align:center}
.rm-cta-inner{max-width:600px;margin:0 auto;padding:0 24px}
.rm-cta-sub{font-family:var(--serif);font-size:.7rem;letter-spacing:5px;color:var(--brown-lt);margin-bottom:14px}
.rm-cta-inner h2{font-size:1.4rem;font-weight:500;margin-bottom:28px;letter-spacing:1px}
.rm-cta-btn{display:inline-block;padding:15px 52px;background:var(--brown);color:#fff;font-size:12px;letter-spacing:3px;transition:background .3s}
.rm-cta-btn:hover{background:var(--brown-dk)}

/* ===== ROOM DETAIL ===== */
.rd-hero{height:70vh;min-height:520px;padding-top:80px;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.rd-hero-bg{position:absolute;inset:0}
.rd-hero-bg img{width:100%;height:100%;object-fit:cover}
.rd-hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.35);z-index:1}
.rd-hero-inner{position:relative;z-index:2}
.rd-hero-badge{display:inline-block;padding:6px 20px;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:10px;letter-spacing:3px;margin-bottom:20px}
.rd-hero-title{font-size:3rem;font-weight:400;color:#fff;margin-bottom:10px;letter-spacing:3px}
.rd-hero-en{font-family:var(--serif);font-size:.8rem;letter-spacing:6px;color:rgba(255,255,255,.35)}

.rd-tag{display:block;font-family:var(--serif);font-size:.6rem;letter-spacing:5px;color:var(--brown-lt);margin-bottom:10px}

.rd-bar{border-bottom:1px solid var(--bdr-lt)}
.rd-bar-inner{max-width:1000px;margin:0 auto;display:flex}
.rd-bar-inner>div{flex:1;text-align:center;padding:32px 16px;border-right:1px solid var(--bdr-lt)}
.rd-bar-inner>div:last-child{border-right:none}
.rd-bar-inner span{display:block;font-size:10px;letter-spacing:2px;color:var(--text3);margin-bottom:6px}
.rd-bar-inner strong{font-size:1rem;font-weight:600}

.rd-intro{padding:100px 0}
.rd-intro-inner{max-width:1200px;margin:0 auto;padding:0 48px;display:flex;gap:80px;align-items:center}
.rd-intro-img{flex:1.3;overflow:hidden}
.rd-intro-img img{width:100%;height:480px;object-fit:cover}
.rd-intro-text{flex:1}
.rd-intro-text h2{font-size:1.3rem;font-weight:600;margin-bottom:24px;letter-spacing:.5px}
.rd-intro-text p{font-size:14px;color:var(--text2);line-height:2.4;margin-bottom:32px}
.rd-hl{border-top:1px solid var(--bdr-lt);padding-top:24px}
.rd-hl li{font-size:13px;color:var(--text2);padding:6px 0 6px 16px;position:relative}
.rd-hl li::before{content:'';position:absolute;left:0;top:13px;width:5px;height:5px;border-radius:50%;background:var(--gold)}

.rd-amen{padding:80px 0;background:var(--cream)}
.rd-amen-inner{max-width:1100px;margin:0 auto;padding:0 48px;text-align:center}
.rd-amen-inner h2{font-size:1.2rem;font-weight:600;margin-bottom:40px;letter-spacing:.5px}
.rd-amen-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.rd-amen-card{background:#fff;padding:28px 20px;text-align:center;border:1px solid var(--bdr-lt);transition:box-shadow .3s}
.rd-amen-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.05)}
.rd-amen-icon{width:36px;height:36px;margin:0 auto 14px;color:var(--brown)}
.rd-amen-icon svg{width:100%;height:100%}
.rd-amen-card strong{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text)}
.rd-amen-card p{font-size:11px;color:var(--text3);line-height:1.6;margin:0}

.rd-rate{padding:80px 0}
.rd-rate-inner{max-width:800px;margin:0 auto;padding:0 48px;text-align:center}
.rd-rate-inner h2{font-size:1.2rem;font-weight:600;margin-bottom:36px;letter-spacing:.5px}
.rd-rate-tbl{width:100%;border-collapse:collapse;margin-bottom:28px}
.rd-rate-tbl thead th{background:var(--brown);color:#fff;padding:14px 24px;font-size:11px;letter-spacing:2px;font-weight:400;text-align:center}
.rd-rate-tbl thead th:first-child{text-align:left}
.rd-rate-tbl tbody td{padding:20px 24px;border-bottom:1px solid var(--bdr-lt);font-size:14px;color:var(--text2);text-align:center}
.rd-rate-tbl tbody td:first-child{text-align:left;font-weight:500;color:var(--text)}
.rd-rate-price{font-family:var(--serif)!important;font-size:1.3rem!important;color:var(--brown)!important;font-weight:500!important;letter-spacing:1px}
.rd-rate-peak td{background:var(--warm)}
.rd-rate-notes{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.rd-rate-notes p{font-size:11px;color:var(--text3);position:relative;padding-left:12px}
.rd-rate-notes p::before{content:'·';position:absolute;left:0;color:var(--gold)}

.rd-book{position:relative;height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.rd-book-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.rd-book-dim{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.rd-book-inner{position:relative;z-index:1;text-align:center;color:#fff}
.rd-book-inner>span{display:block;font-family:var(--serif);font-size:.65rem;letter-spacing:5px;color:rgba(255,255,255,.4);margin-bottom:16px}
.rd-book-inner h2{font-size:1.8rem;font-weight:400;margin-bottom:8px;letter-spacing:2px}
.rd-book-inner p{font-size:1rem;opacity:.5;margin-bottom:40px;font-family:var(--serif);letter-spacing:1px}
.rd-book-inner a{display:inline-block;padding:15px 56px;border:1px solid rgba(255,255,255,.25);color:#fff;font-size:12px;letter-spacing:3px;transition:all .3s}
.rd-book-inner a:hover{background:#fff;color:var(--brown)}

.rd-other{padding:100px 0;background:var(--warm)}
.rd-other-inner{max-width:1200px;margin:0 auto;padding:0 48px;text-align:center}
.rd-other-inner h2{font-size:1.2rem;font-weight:600;margin-bottom:40px;letter-spacing:.5px}
.rd-other-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rd-other-card{overflow:hidden;background:#fff;transition:box-shadow .4s}
.rd-other-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.08)}
.rd-other-img{height:260px;overflow:hidden}
.rd-other-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.rd-other-card:hover .rd-other-img img{transform:scale(1.05)}
.rd-other-body{padding:24px;text-align:left}
.rd-other-body>span{font-family:var(--serif);font-size:.55rem;letter-spacing:3px;color:var(--text3)}
.rd-other-body h3{font-size:1.05rem;font-weight:500;margin:4px 0 10px}
.rd-other-body strong{font-family:var(--serif);font-size:1.1rem;color:var(--brown);font-weight:400}

/* ===== FACILITIES PAGE ===== */
.fc-hero{height:45vh;min-height:320px;padding-top:80px;position:relative;background:linear-gradient(135deg,#3a2f1e,#5c4a32);display:flex;align-items:center;justify-content:center;text-align:center}
.fc-hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,.2)}
.fc-hero__content{position:relative;z-index:2}
.fc-hero__label{font-family:var(--serif);font-size:.75rem;letter-spacing:5px;color:rgba(255,255,255,.4);margin-bottom:14px;display:block}
.fc-hero__title{font-size:2rem;font-weight:600;color:#fff;margin-bottom:12px}
.fc-hero__subtitle{font-size:14px;color:rgba(255,255,255,.5)}
.fc-list{padding:80px 0}
.fc-list__inner{max-width:1100px;margin:0 auto;padding:0 40px;display:flex;flex-direction:column;gap:80px}
.fc-list__card{display:flex;gap:60px;align-items:center}
.fc-list__card--reverse{flex-direction:row-reverse}
.fc-list__card-image{flex:1.2;overflow:hidden}
.fc-list__card-image img{width:100%;height:380px;object-fit:cover;transition:transform .6s}
.fc-list__card:hover .fc-list__card-image img{transform:scale(1.03)}
.fc-list__card-placeholder{width:100%;height:380px;background:var(--cream)}
.fc-list__card-body{flex:1}
.fc-list__card-label{font-family:var(--serif);font-size:.7rem;letter-spacing:2.5px;color:var(--brown);margin-bottom:8px;display:block}
.fc-list__card-name{font-size:1.6rem;font-weight:600;margin-bottom:20px}
.fc-list__card-desc{font-size:14px;color:var(--text2);line-height:2;margin-bottom:20px}
.fc-list__card-hours{font-size:13px;color:var(--text3);display:flex;align-items:center;gap:6px}
.fc-cta{padding:80px 0;background:var(--cream);text-align:center}
.fc-cta__inner{max-width:600px;margin:0 auto;padding:0 24px}
.fc-cta__heading{font-size:1.2rem;font-weight:600;margin-bottom:12px}
.fc-cta__desc{font-size:14px;color:var(--text2);margin-bottom:20px}
.fc-cta__phone{font-family:var(--serif);font-size:1.5rem;color:var(--brown);letter-spacing:2px}

/* ===== RESERVATION ===== */
/* Restore bar */
.rv-restore-bar{position:fixed;top:0;left:0;right:0;z-index:500;background:var(--brown-dk);color:#fff}
.rv-restore-inner{max-width:1100px;margin:0 auto;padding:12px 40px;display:flex;align-items:center;gap:12px;font-size:13px}
.rv-restore-inner svg{flex-shrink:0;opacity:.6}
.rv-restore-inner span{flex:1}
.rv-restore-btn{padding:6px 16px;background:#fff;color:var(--brown-dk);border:none;font-size:12px;font-weight:600;cursor:pointer;letter-spacing:.5px}
.rv-restore-dismiss{padding:6px 16px;background:none;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.2);font-size:12px;cursor:pointer}
.rv-restore-dismiss:hover{color:#fff;border-color:rgba(255,255,255,.5)}
/* Step progress */
.rv-progress{background:#fff;border-bottom:1px solid var(--bdr-lt);padding:20px 0}
.rv-progress-inner{display:flex;align-items:center;justify-content:center;gap:0;max-width:480px;margin:0 auto}
.rv-progress-step{display:flex;align-items:center;gap:8px;opacity:.35;transition:opacity .3s}
.rv-progress-step.active,.rv-progress-step.complete{opacity:1}
.rv-progress-num{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;border:1.5px solid var(--bdr);color:var(--text3);transition:all .3s}
.rv-progress-step.active .rv-progress-num{background:var(--brown-dk);color:#fff;border-color:var(--brown-dk)}
.rv-progress-step.complete .rv-progress-num{background:var(--brown);color:#fff;border-color:var(--brown)}
.rv-progress-label{font-size:12px;font-weight:500;letter-spacing:.3px;color:var(--text2)}
.rv-progress-line{width:40px;height:1px;background:var(--bdr);margin:0 12px}
/* Top bar (sticky) */
.rv-topbar{background:#fff;border-bottom:1px solid var(--bdr-lt);position:sticky;top:80px;z-index:50}
.rv-topbar-inner{max-width:1100px;margin:0 auto;padding:14px 40px;display:flex;align-items:center;gap:0}
.rv-topbar-item{flex:1;cursor:default}
.rv-topbar-label{display:block;font-size:10px;letter-spacing:2px;color:var(--text3);margin-bottom:2px}
.rv-topbar-item strong{font-size:13px;font-weight:500;color:var(--text)}
.rv-topbar-div{width:1px;height:32px;background:var(--bdr-lt);margin:0 24px;flex-shrink:0}
/* Content */
.rv-content{padding:40px 0 80px;background:var(--warm)}
.rv-layout{display:flex;gap:32px;max-width:1100px;margin:0 auto;padding:0 40px}
.rv-form-area{flex:1}
.rv-form{display:flex;flex-direction:column;gap:0}
.rv-step{background:#fff;padding:36px;border:1px solid var(--bdr-lt);border-top:none}
.rv-step:first-child{border-top:1px solid var(--bdr-lt)}
.rv-step-title{font-size:.95rem;font-weight:600;margin-bottom:24px;display:flex;align-items:center;gap:12px}
.rv-step-num{font-family:var(--serif);font-size:.8rem;color:var(--brown);letter-spacing:1px}
.rv-date-row{display:flex;gap:16px;margin-bottom:12px}
.rv-field{flex:1;margin-bottom:14px}
.rv-field label{display:block;font-size:12px;color:var(--text2);margin-bottom:6px;font-weight:500;letter-spacing:.5px}
.rv-field .required{color:#c33}
.rv-field input,.rv-field select,.rv-field textarea{width:100%;padding:10px 14px;border:1px solid var(--bdr);font-size:14px;font-family:var(--sans);color:var(--text);background:#fff;outline:none;transition:border-color .3s;resize:vertical}
.rv-field input:focus,.rv-field select:focus,.rv-field textarea:focus{border-color:var(--brown)}
.rv-field-note{font-size:11px;color:var(--text3);margin-top:4px;display:block}
/* Room filter */
.rv-room-filter{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.rv-filter-btn{padding:7px 18px;border:1px solid var(--bdr);background:#fff;font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s;letter-spacing:.3px}
.rv-filter-btn:hover{border-color:var(--brown);color:var(--brown)}
.rv-filter-btn.active{background:var(--brown-dk);color:#fff;border-color:var(--brown-dk)}
.rv-price-note{font-size:11px;color:var(--text3);margin-top:12px;letter-spacing:.3px}
/* Room cards */
.rv-room-list{display:flex;flex-direction:column;gap:0}
.rv-room-card{display:flex;align-items:center;gap:20px;padding:20px;border:1px solid var(--bdr-lt);border-top:none;cursor:pointer;transition:all .2s;position:relative}
.rv-room-card:first-child{border-top:1px solid var(--bdr-lt)}
.rv-room-card input[type=radio]{position:absolute;opacity:0;width:0;height:0}
.rv-room-card:hover{background:rgba(107,90,62,.02)}
.rv-room-card.selected{border-color:var(--brown);background:rgba(107,90,62,.03)}
.rv-room-img{width:140px;height:100px;flex-shrink:0;overflow:hidden;background:var(--cream)}
.rv-room-info{flex:1}
.rv-room-info h3{font-size:15px;font-weight:600;margin-bottom:4px}
.rv-room-meta{font-size:11px;color:var(--text3)}
.rv-room-view{font-size:11px;color:var(--brown);margin-top:3px}
.rv-room-price{font-family:var(--serif);font-size:1.05rem;color:var(--brown);font-weight:500;margin-top:6px}
.rv-room-check{width:22px;height:22px;border:1.5px solid var(--bdr);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:.3s}
.rv-room-card.selected .rv-room-check{border-color:var(--brown);background:var(--brown)}
.rv-room-card.selected .rv-room-check span::after{content:'✓';color:#fff;font-size:11px}
.rv-submit{width:100%;padding:16px;background:var(--brown);color:#fff;border:none;font-size:14px;letter-spacing:2px;cursor:pointer;transition:background .3s;margin-top:0}
.rv-submit:hover{background:var(--brown-dk)}
.rv-submit:disabled{background:var(--text3);cursor:not-allowed}
/* Summary sidebar */
.rv-summary{width:340px;flex-shrink:0}
.rv-summary-inner{position:sticky;top:140px;background:#fff;border:1px solid var(--bdr-lt);padding:32px}
.rv-summary-title{font-size:.95rem;font-weight:600;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--bdr-lt)}
.rv-summary-empty p{font-size:14px;color:var(--text3);text-align:center;padding:40px 0}
.rv-summary-room{font-size:1.05rem;font-weight:600;margin-bottom:20px}
.rv-summary-dates{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--bdr-lt)}
.rv-summary-dates>div{display:flex;justify-content:space-between;font-size:13px}
.rv-summary-dates span{color:var(--text3)}
.rv-summary-guests{display:flex;justify-content:space-between;font-size:13px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--bdr-lt)}
.rv-summary-guests span{color:var(--text3)}
.rv-summary-breakdown{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--bdr-lt);max-height:200px;overflow-y:auto}
.rv-summary-brow{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;color:var(--text2)}
.rv-summary-total{display:flex;justify-content:space-between;align-items:center}
.rv-summary-total span{font-size:14px;color:var(--text3)}
.rv-summary-total strong{font-family:var(--serif);font-size:1.4rem;color:var(--brown)}

/* ===== DATE TRIGGER ===== */
.rv-date-trigger{display:flex;align-items:center;gap:12px;padding:16px 24px;background:var(--cream);cursor:pointer;transition:all .2s;position:relative;margin-bottom:16px}
.rv-date-trigger:hover{background:var(--cream-dk)}
.rv-date-trigger-box{flex:1;text-align:center}
.rv-date-trigger-box--nights{flex:.5}
.rv-date-trigger-label{display:block;font-size:9px;letter-spacing:2px;color:var(--text3);margin-bottom:4px}
.rv-date-trigger-val{display:block;font-size:14px;font-weight:600;color:var(--text)}
.rv-date-trigger-time{display:block;font-size:10px;color:var(--text3);margin-top:1px}
.rv-date-trigger-arrow{font-size:16px;color:var(--text3);flex-shrink:0}
.rv-date-trigger-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--text3)}

/* ===== CALENDAR MODAL ===== */
.rv-cal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;opacity:0;visibility:hidden;transition:all .3s}
.rv-cal-overlay.open{opacity:1;visibility:visible}
.rv-cal-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);z-index:401;background:#fff;width:720px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:all .3s;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.rv-cal-modal.open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.rv-cal-modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid var(--bdr-lt)}
.rv-cal-modal-head h4{font-size:15px;font-weight:600;letter-spacing:.5px}
.rv-cal-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text3);padding:0;line-height:1;transition:color .2s}
.rv-cal-modal-close:hover{color:var(--text)}
.rv-cal-modal-range{display:flex;align-items:center;gap:12px;padding:16px 28px;background:var(--cream)}
.rv-cal-modal-range-box{flex:1;text-align:center}
.rv-cal-modal-range-box span{display:block;font-size:10px;letter-spacing:1.5px;color:var(--text3);margin-bottom:3px}
.rv-cal-modal-range-box strong{display:block;font-size:14px;font-weight:600;color:var(--text)}
.rv-cal-modal-range-box strong.filled{color:var(--brown)}
.rv-cal-modal-range-arrow{font-size:16px;color:var(--text3)}
.rv-cal-modal-range-nights{font-size:13px;font-weight:600;color:var(--brown);margin-left:8px;white-space:nowrap}
.rv-cal-modal-body{flex:1;overflow-y:auto;padding:20px 28px;scrollbar-width:thin;scrollbar-color:var(--bdr) transparent}
.rv-cal-modal-body::-webkit-scrollbar{width:5px}
.rv-cal-modal-body::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:3px}
.rv-cal-modal-months{display:flex;gap:16px}

/* ===== CALENDAR GRID ===== */
.rv-cal{flex:1;padding:0}
.rv-cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--bdr-lt)}
.rv-cal-month{font-size:13px;font-weight:600;letter-spacing:.5px}
.rv-cal-nav{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text2);padding:2px 6px;transition:color .2s}
.rv-cal-nav:hover{color:var(--brown)}
.rv-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.rv-cal-day-name{text-align:center;font-size:10px;color:var(--text3);padding:4px 0;letter-spacing:1px}
.rv-cal-cell{text-align:center;padding:6px 2px;cursor:pointer;position:relative;transition:background .2s;min-height:48px}
.rv-cal-cell:hover{background:var(--cream)}
.rv-cal-cell--empty{cursor:default;min-height:0}
.rv-cal-cell--past{opacity:.3;cursor:not-allowed;pointer-events:none}
.rv-cal-cell--full{opacity:.35;cursor:not-allowed;pointer-events:none}
.rv-cal-cell--checkin,.rv-cal-cell--checkout{background:var(--brown)!important;color:#fff!important;font-weight:600;box-shadow:0 0 0 2px var(--brown),0 0 0 4px rgba(107,90,62,.25)}
.rv-cal-cell--checkin .rv-cal-num,.rv-cal-cell--checkout .rv-cal-num{color:#fff}
.rv-cal-cell--range{background:rgba(107,90,62,.08)}
.rv-cal-cell--weekend .rv-cal-num{color:var(--brown-lt)}
.rv-cal-cell--sunday .rv-cal-num{color:#c44}
.rv-cal-num{display:block;font-size:13px;font-weight:500}
.rv-cal-avail{display:block;font-size:8px;margin-top:1px;line-height:1}
.rv-cal-avail--ok{color:#2e7d32}
.rv-cal-avail--few{color:#e67700}
.rv-cal-avail--full{color:#c33}
.rv-cal-cell--checkin .rv-cal-avail,.rv-cal-cell--checkout .rv-cal-avail{color:rgba(255,255,255,.7)}
.rv-cal-price{display:block;font-size:8px;color:var(--text3);margin-top:1px;line-height:1;letter-spacing:-.3px}
.rv-cal-cell--checkin .rv-cal-price,.rv-cal-cell--checkout .rv-cal-price{color:rgba(255,255,255,.6)}
.rv-cal-cell--weekend .rv-cal-price{color:var(--brown-lt)}
.rv-cal-cell--sunday .rv-cal-price{color:#c44}

/* Guest Counter */
.rv-guest-row{display:flex;gap:24px}
.rv-guest-field{flex:1}
.rv-guest-field label{display:block;font-size:12px;color:var(--text2);margin-bottom:8px;font-weight:500}
.rv-counter{display:flex;align-items:center;gap:0;border:1px solid var(--bdr)}
.rv-counter-btn{width:40px;height:40px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--text2);transition:background .2s}
.rv-counter-btn:hover{background:var(--cream)}
.rv-counter span{flex:1;text-align:center;font-size:16px;font-weight:600}

/* Room card image */
.rv-room-img{width:120px;height:85px;flex-shrink:0;overflow:hidden;background:var(--cream)}
.rv-room-img img{width:100%;height:100%;object-fit:cover}

/* ===== LOCATION ===== */
.lc-hero{height:45vh;min-height:320px;padding-top:80px;position:relative;background:linear-gradient(135deg,#3a2f1e,#5c4a32);display:flex;align-items:center;justify-content:center;text-align:center}
.lc-hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,.2)}
.lc-hero__content{position:relative;z-index:2}
.lc-hero__label{font-family:var(--serif);font-size:.75rem;letter-spacing:5px;color:rgba(255,255,255,.4);margin-bottom:14px;display:block}
.lc-hero__title{font-size:2rem;font-weight:600;color:#fff;margin-bottom:12px}
.lc-hero__subtitle{font-size:14px;color:rgba(255,255,255,.5)}
.lc-map__container{width:100%;height:450px;background:var(--cream)}
.lc-info{padding:80px 0}
.lc-info__inner{max-width:1000px;margin:0 auto;padding:0 24px}
.lc-info__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.lc-info__card{text-align:center;padding:36px 24px;background:var(--cream)}
.lc-info__card-icon{font-size:24px;margin-bottom:16px;display:block}
.lc-info__card-title{font-size:.95rem;font-weight:600;margin-bottom:12px}
.lc-info__card-text{font-size:13px;color:var(--text2);line-height:1.9}
.lc-info__card-text a{color:var(--brown)}

/* ===== PAYMENT ===== */
.pay-result{padding:160px 0 100px;min-height:70vh;display:flex;align-items:center}
.pay-card{max-width:540px;margin:0 auto;text-align:center;background:#fff;border:1px solid var(--bdr-lt);padding:56px 44px}
.pay-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 24px}
.pay-success .pay-icon{background:#d4edda;color:#155724}
.pay-fail .pay-icon{background:#f8d7da;color:#721c24}
.pay-card h1{font-size:1.3rem;margin-bottom:8px}
.pay-sub{font-size:14px;color:var(--text2);margin-bottom:32px}
.pay-code{font-size:13px;color:var(--text3);margin-bottom:24px}
.pay-details{text-align:left;margin-bottom:32px;padding:24px;background:var(--cream)}
.pay-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;border-bottom:1px solid var(--bdr-lt)}
.pay-row:last-child{border-bottom:none}
.pay-row span{color:var(--text3)}
.pay-notice{font-size:13px;color:var(--text3);margin-bottom:24px;line-height:2}
.gold-text{color:var(--brown)!important}
.btn-gold{display:inline-block;padding:14px 40px;background:var(--brown);color:#fff;font-size:13px;letter-spacing:2px;border:none;cursor:pointer;transition:background .3s}
.btn-gold:hover{background:var(--brown-dk)}

/* ===== FOOTER ===== */
.footer{background:var(--cream-dk);padding:64px 0 0}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 40px}
.footer-top{display:flex;justify-content:space-between;gap:60px;padding-bottom:40px;border-bottom:1px solid var(--bdr)}
.footer-logo{display:block;font-family:var(--serif);font-size:1.2rem;font-weight:500;letter-spacing:4px;color:var(--brown)}
.footer-logo-sub{display:block;font-family:var(--serif);font-size:.5rem;letter-spacing:5px;color:var(--text3);margin-top:2px}
.footer-links{display:flex;gap:64px}
.footer-col h4{font-size:11px;letter-spacing:2.5px;color:var(--brown);margin-bottom:16px;font-weight:500}
.footer-col a,.footer-col p{display:block;font-size:12px;color:var(--text2);line-height:2.2}
.footer-col a:hover{color:var(--brown)}
.footer-bottom{padding:20px 0;text-align:center}
.footer-bottom p{font-size:11px;color:var(--text3);letter-spacing:1px}

/* Floating - mobile */
@media(max-width:960px){
  .qr-sub{right:0;width:100%;max-height:80vh;bottom:0;transform:translateY(100%);box-shadow:0 -4px 40px rgba(0,0,0,.1)}
  .qr-sub.open{transform:translateY(0)}
  .qr-cal-months{grid-template-columns:1fr;gap:20px}
}
@media(max-width:768px){
  .qr-fab{bottom:24px;right:20px;width:66px;height:66px}
  .qr-fab svg{width:18px;height:18px}
  .qr-top{bottom:102px;right:35px;width:36px;height:36px}
  .qr-panel{width:100%;right:-100%}
  .qr-panel-body{padding:24px 20px}
  .qr-sub-body{padding:0 20px 20px}
}
@media(max-width:320px){
  .qr-fab{bottom:16px;right:14px;width:58px;height:58px}
  .qr-fab span{font-size:8px}
  .qr-top{bottom:86px;right:27px;width:32px;height:32px}
  .qr-panel-head{padding:16px 20px}
  .qr-panel-body{padding:20px 16px}
  .qr-date-text,.qr-guest-text{font-size:13px}
  .qr-cal-grid button{font-size:11px;padding:6px 0}
  .qr-gp-label strong{font-size:12px}
  .qr-submit{padding:13px;font-size:12px}
}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .offers__featured{flex-direction:column}
  .offers__featured-img{height:300px}
  .offers__featured-info{padding:32px}
  .offers__grid{grid-template-columns:1fr;grid-auto-rows:280px}
  .about__inner{flex-direction:column;gap:48px}
  .about__img img{height:360px}
  .fac__grid{grid-template-columns:1fr 1fr}
  .rev__list{grid-template-columns:1fr 1fr}
  .rv-layout{flex-direction:column}
  .rv-summary{width:100%}
  .rv-summary-inner{position:static}
  .rv-topbar-inner{padding:12px 24px}
  .rv-restore-inner{padding:12px 24px}
  .rv-progress-label{display:none}
  .rm-full,.rm-full--rev{flex-direction:column}
  .rm-full-img{width:100%;height:400px}
  .rm-full-body{width:100%;padding:48px}
  .fc-list__card,.fc-list__card--reverse{flex-direction:column;gap:32px}
  .fc-list__card-image img{height:300px}
  .rd-intro-inner{flex-direction:column;gap:40px}
  .rd-intro-img img{height:360px}
  .rd-amen-cards{grid-template-columns:repeat(3,1fr)}
  .rd-other-grid{grid-template-columns:1fr 1fr}
  .rd-bar-inner{flex-wrap:wrap}
  .rd-bar-inner>div{flex:0 0 33.33%}
  .hero__title{font-size:3rem}
}
@media(max-width:768px){
  .gnb{display:none}
  .mobile-menu-btn{display:flex}
  .header-inner{justify-content:flex-start;padding:0 20px;height:64px}
  .logo{margin:0;margin-right:auto}
  .logo-en{font-size:1.2rem;letter-spacing:3px}
  .notice-bar-inner{padding:0 16px;gap:10px;height:42px}
  .notice-bar-slider{height:42px}
  .notice-bar-item{height:42px;gap:12px}
  .notice-bar-title{font-size:12px}
  .notice-bar-desc{display:none}
  .notice-bar-date{font-size:10px}
  .hero{min-height:560px}
  .hero__content{padding:0 24px}
  .hero__title{font-size:2.4rem}
  .offers,.about,.fac,.rev{padding:80px 0}
  .offers__inner,.about__inner,.fac__inner,.rev__inner{padding:0 20px}
  .fac__grid{grid-template-columns:1fr}
  .fac__card{height:240px}
  .rev__list{grid-template-columns:1fr}
  .rm-full-img{height:280px}
  .rm-full-body{padding:32px 20px}
  .rm-full-body h2{font-size:1.3rem}
  .rm-full-price{font-size:1.4rem;margin-bottom:20px}
  .rm-full-btns{flex-direction:column;gap:10px}
  .rd-bar-inner>div{flex:0 0 50%;padding:20px 12px}
  .rd-intro-inner{padding:0 20px}
  .rd-intro-img img{height:260px}
  .rd-amen-inner,.rd-rate-inner,.rd-other-inner{padding:0 20px}
  .rd-amen-cards{grid-template-columns:1fr 1fr}
  .rd-rate-tbl thead th{padding:10px 12px;font-size:10px}
  .rd-rate-tbl tbody td{padding:14px 12px;font-size:13px}
  .rd-rate-price{font-size:1.1rem!important}
  .rd-rate-notes{flex-direction:column;gap:6px;align-items:center}
  .rd-other-grid{grid-template-columns:1fr}
  .rd-hero{min-height:360px}
  .rd-hero-title{font-size:2rem}
  .lc-info__grid{grid-template-columns:1fr}
  .rv-topbar{top:64px}
  .rv-topbar-inner{padding:10px 16px;gap:0}
  .rv-topbar-div{margin:0 12px}
  .rv-topbar-item strong{font-size:12px}
  .rv-layout{padding:0 16px}
  .rv-cal-modal{width:100%;max-width:100vw;top:auto;left:0;bottom:0;transform:translateY(100%);max-height:85vh}
  .rv-cal-modal.open{transform:translateY(0)}
  .rv-cal-modal-months{flex-direction:column;gap:20px}
  .rv-cal-modal-body{padding:16px 20px}
  .rv-cal-modal-head{padding:16px 20px}
  .rv-cal-modal-range{padding:12px 20px}
  .rv-date-trigger{flex-direction:column;gap:8px;padding:14px 16px;text-align:center}
  .rv-date-trigger-arrow{display:none}
  .rv-date-trigger-box--nights{border-top:1px solid var(--bdr-lt);padding-top:8px;margin-top:4px}
  .rv-date-trigger-icon{position:static;transform:none;margin-top:4px}
  .rv-date-trigger-box{flex:none}
  .rv-step{padding:20px}
  .rv-guest-row{flex-direction:column;gap:12px}
  .rv-room-card{flex-direction:column;align-items:stretch;gap:10px}
  .rv-room-img{width:100%;height:160px}
  .rv-room-info{text-align:left}
  .rv-room-check{position:absolute;top:12px;right:12px}
  .rv-summary-inner{padding:24px}
  .rv-room-filter{gap:6px}
  .rv-filter-btn{padding:6px 12px;font-size:11px}
  .footer-top{flex-direction:column;gap:32px}
  .footer-links{flex-direction:column;gap:24px}
  .cta__content h2{font-size:1.5rem;letter-spacing:4px}
}
@media(max-width:480px){
  .hero__title{font-size:1.9rem}
  .hero__content{padding:0 20px}
  .hero__nav{display:none}
  .offers__title,.about__title,.fac__title,.rev__title{font-size:1.4rem;letter-spacing:4px}
  .about__stats{flex-direction:column;gap:20px}
  .rm-hero,.fc-hero,.lc-hero{height:28vh;min-height:200px}
  .rm-hero-title,.fc-hero__title,.lc-hero__title{font-size:1.5rem}
  .rd-hero{min-height:300px}
  .rd-hero-title{font-size:1.6rem}
  .rd-spec-item{padding:16px 8px}
  .rd-spec-item span{font-size:9px}
  .rd-spec-item strong{font-size:.85rem}
  .rv-content{padding:32px 0 48px}
  .rv-layout{padding:0 16px}
  .rv-step{padding:16px}
  .rv-step-title{font-size:.9rem;margin-bottom:16px}
  .rv-cal-cell{padding:4px 1px;min-height:38px}
  .rv-cal-num{font-size:12px}
  .rv-cal-avail{font-size:7px}
  .rv-cal-price{font-size:7px}
  .rv-room-img{height:140px}
  .rv-room-info h3{font-size:13px}
  .rv-room-meta,.rv-room-view{font-size:10px}
  .rv-room-price{font-size:.9rem}
  .rv-field input,.rv-field textarea{padding:8px 10px;font-size:13px}
  .rv-submit{padding:14px;font-size:13px}
}
@media(max-width:320px){
  .notice-bar-inner{padding:0 10px;gap:6px;height:38px}
  .notice-bar-slider{height:38px}
  .notice-bar-item{height:38px}
  .notice-bar-title{font-size:11px}
  .notice-bar-date{font-size:9px}
  .header-inner{padding:0 10px;height:52px}
  .logo-en{font-size:.95rem;letter-spacing:2px}
  .logo-sub{font-size:.42rem;letter-spacing:2px;margin-top:-6px}
  /* Hero */
  .hero{min-height:480px}
  .hero__sub{font-size:.65rem;letter-spacing:4px;margin-bottom:12px}
  .hero__title{font-size:1.4rem}
  .hero__desc{font-size:.78rem;margin-bottom:24px}
  .hero__btn{padding:9px 20px;font-size:10px;letter-spacing:2px}
  /* Home sections */
  .offers,.about,.fac,.rev{padding:40px 0}
  .offers__inner,.about__inner,.fac__inner,.rev__inner{padding:0 10px}
  .offers__head,.fac__head,.rev__head{margin-bottom:28px}
  .offers__title,.about__title,.fac__title,.rev__title{font-size:1.1rem;letter-spacing:2px}
  .offers__sub,.fac__sub,.rev__sub{font-size:12px}
  .offers__featured-info{padding:20px 16px}
  .offers__featured-info h3{font-size:1.1rem}
  .offers__featured-info p{font-size:12px;margin-bottom:8px}
  .offers__card-info{padding:16px}
  .offers__card-info h3{font-size:1rem}
  .offers__card-price{font-size:.95rem}
  .offers__more{margin-top:28px;font-size:12px}
  .about__inner{gap:28px}
  .about__img img{height:180px}
  .about__kr{font-size:1rem;margin-bottom:16px}
  .about__desc{font-size:12px;line-height:2;margin-bottom:24px}
  .about__stats{gap:16px;margin-bottom:24px;padding-bottom:24px}
  .about__stat strong{font-size:1.3rem}
  .about__stat span{font-size:9px}
  .about__link{font-size:12px}
  .fac__card{height:160px}
  .fac__card-body{padding:16px}
  .fac__card-body h3{font-size:.95rem}
  .rev__card{padding:20px 14px}
  .rev__stars{font-size:11px;margin-bottom:12px}
  .rev__text{font-size:12px;line-height:1.8;margin-bottom:16px}
  .rev__meta{font-size:11px}
  .cta{height:260px}
  .cta__content h2{font-size:1.1rem;letter-spacing:2px}
  .cta__content p{font-size:11px;margin-bottom:24px}
  .cta__btn{padding:9px 28px;font-size:10px;letter-spacing:2px}
  /* Rooms list */
  .rm-hero{height:24vh;min-height:160px}
  .rm-hero-label{font-size:.65rem;letter-spacing:3px}
  .rm-hero-title{font-size:1.3rem}
  .rm-hero-subtitle{font-size:12px}
  .rm-full{min-height:auto}
  .rm-full-img{height:220px}
  .rm-full-body{padding:24px 16px}
  .rm-full-en{font-size:.5rem;letter-spacing:3px;margin-bottom:6px}
  .rm-full-body h2{font-size:1.15rem}
  .rm-full-line{margin:12px 0}
  .rm-full-specs{gap:10px;margin-bottom:16px}
  .rm-full-specs span{font-size:11px}
  .rm-full-body>p{font-size:12px;line-height:1.8;margin-bottom:20px}
  .rm-full-price{font-size:1.3rem;margin-bottom:20px}
  .rm-btn-line{font-size:11px}
  .rm-btn-fill{padding:9px 20px;font-size:10px}
  .rm-cta{padding:48px 0}
  .rm-cta-inner h2{font-size:1.1rem;margin-bottom:20px}
  .rm-cta-btn{padding:12px 36px;font-size:11px}
  /* Room detail */
  .rd-hero{height:50vh;min-height:260px}
  .rd-hero-badge{padding:4px 14px;font-size:9px;margin-bottom:14px}
  .rd-hero-title{font-size:1.4rem;letter-spacing:2px}
  .rd-hero-en{font-size:.65rem;letter-spacing:4px}
  .rd-bar-inner>div{padding:14px 8px}
  .rd-bar-inner span{font-size:9px;letter-spacing:1px;margin-bottom:3px}
  .rd-bar-inner strong{font-size:.85rem}
  .rd-intro{padding:48px 0}
  .rd-intro-inner{padding:0 14px;gap:28px}
  .rd-intro-img img{height:200px}
  .rd-tag{font-size:.55rem;letter-spacing:4px}
  .rd-intro-text h2{font-size:1.1rem;margin-bottom:16px}
  .rd-intro-text p{font-size:12px;line-height:2;margin-bottom:20px}
  .rd-hl{padding-top:16px}
  .rd-hl li{font-size:12px;padding:4px 0 4px 14px}
  .rd-amen{padding:40px 0}
  .rd-amen-inner{padding:0 10px}
  .rd-amen-inner h2{font-size:1.05rem;margin-bottom:24px}
  .rd-amen-cards{grid-template-columns:1fr 1fr;gap:8px}
  .rd-amen-card{padding:18px 12px}
  .rd-amen-icon{width:28px;height:28px;margin-bottom:10px}
  .rd-amen-card strong{font-size:11px}
  .rd-amen-card p{font-size:10px}
  .rd-rate{padding:40px 0}
  .rd-rate-inner{padding:0 10px}
  .rd-rate-inner h2{font-size:1.05rem;margin-bottom:24px}
  .rd-rate-tbl thead th{padding:8px 6px;font-size:9px;letter-spacing:1px}
  .rd-rate-tbl tbody td{padding:12px 6px;font-size:12px}
  .rd-rate-price{font-size:1rem!important}
  .rd-rate-notes p{font-size:10px}
  .rd-book{height:300px}
  .rd-book-inner>span{font-size:.55rem;letter-spacing:3px;margin-bottom:10px}
  .rd-book-inner h2{font-size:1.3rem;letter-spacing:1px}
  .rd-book-inner p{font-size:.85rem;margin-bottom:28px}
  .rd-book-inner a{padding:12px 36px;font-size:11px;letter-spacing:2px}
  .rd-other{padding:48px 0}
  .rd-other-inner{padding:0 10px}
  .rd-other-inner h2{font-size:1.05rem;margin-bottom:24px}
  .rd-other-img{height:180px}
  .rd-other-body{padding:16px}
  .rd-other-body h3{font-size:.95rem}
  .rd-other-body strong{font-size:1rem}
  /* Facilities */
  .fc-hero,.lc-hero{height:24vh;min-height:160px}
  .fc-hero__title,.lc-hero__title{font-size:1.3rem}
  .fc-hero__subtitle,.lc-hero__subtitle{font-size:12px}
  .fc-list{padding:40px 0}
  .fc-list__inner{padding:0 14px;gap:48px}
  .fc-list__card{gap:20px}
  .fc-list__card-image img,.fc-list__card-placeholder{height:220px}
  .fc-list__card-name{font-size:1.2rem;margin-bottom:12px}
  .fc-list__card-desc{font-size:12px;line-height:1.9}
  .fc-cta{padding:40px 0}
  .fc-cta__heading{font-size:1rem}
  .fc-cta__desc{font-size:12px}
  .fc-cta__phone{font-size:1.2rem}
  /* Location */
  .lc-map__container{height:280px}
  .lc-info{padding:40px 0}
  .lc-info__inner{padding:0 10px}
  .lc-info__card{padding:24px 16px}
  .lc-info__card-title{font-size:.85rem;margin-bottom:8px}
  .lc-info__card-text{font-size:12px}
  /* Reservation */
  .rv-restore-inner{flex-wrap:wrap;padding:10px 12px;gap:8px;font-size:11px}
  .rv-restore-btn,.rv-restore-dismiss{padding:5px 10px;font-size:10px}
  .rv-content{padding:16px 0 28px}
  .rv-layout{padding:0 8px;gap:16px}
  .rv-step{padding:10px}
  .rv-step-title{font-size:.8rem;margin-bottom:10px;gap:6px}
  .rv-step-num{font-size:.7rem}
  .rv-cal-month{font-size:11px}
  .rv-cal-day-name{font-size:8px;padding:2px 0}
  .rv-cal-cell{min-height:28px;padding:2px 0}
  .rv-cal-num{font-size:10px}
  .rv-cal-avail{font-size:6px}
  .rv-cal-price{font-size:6px}
  .rv-date-trigger{padding:8px 10px;gap:4px}
  .rv-date-trigger-label{font-size:7px;letter-spacing:1px}
  .rv-date-trigger-val{font-size:11px}
  .rv-date-trigger-time{font-size:8px}
  .rv-guest-field label{font-size:10px}
  .rv-counter-btn{width:30px;height:30px;font-size:14px}
  .rv-counter span{font-size:13px}
  .rv-room-img{height:110px}
  .rv-room-info h3{font-size:11px}
  .rv-room-meta,.rv-room-view{font-size:9px}
  .rv-room-price{font-size:.8rem}
  .rv-field label{font-size:10px}
  .rv-field input,.rv-field textarea{padding:6px 7px;font-size:12px}
  .rv-submit{padding:11px;font-size:11px;letter-spacing:1px}
  .rv-summary-inner{padding:14px}
  .rv-summary-title{font-size:.85rem;margin-bottom:14px;padding-bottom:10px}
  .rv-summary-room{font-size:.95rem}
  .rv-summary-dates>div{font-size:12px}
  .rv-summary-guests{font-size:12px}
  .rv-summary-total strong{font-size:1rem}
  /* Footer */
  .footer{padding:40px 0 0}
  .footer-inner{padding:0 10px}
  .footer-top{padding-bottom:20px;gap:24px}
  .footer-logo{font-size:.9rem;letter-spacing:2px}
  .footer-logo-sub{font-size:.4rem}
  .footer-col h4{font-size:9px;margin-bottom:10px}
  .footer-col a,.footer-col p{font-size:10px;line-height:2}
  .footer-bottom{padding:14px 0}
  .footer-bottom p{font-size:9px}
  /* Payment */
  .pay-card{padding:32px 20px}
  .pay-card h1{font-size:1.1rem}
  .pay-sub{font-size:12px}
  .pay-details{padding:16px}
  .pay-row{font-size:12px}
}
