@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Be+Vietnam+Pro:wght@300;400;500;700&display=swap');

/* ══ RESET & ROOT ══ */
* { margin:0; padding:0; box-sizing:border-box; }
html { overflow-x:hidden; }
body { overflow-x:hidden; }

:root {
    --cream:       #FAF7F2;
    --warm-white:  #FFFFFF;
    --brown-dark:  #5C3D2E;
    --brown-mid:   #8B6048;
    --brown-light: #C4956A;
    --gold:        #C9A96E;
    --gold-light:  #E8D5B0;
    --text-dark:   #2C1810;
    --text-mid:    #5A4A40;
    --text-light:  #9A8880;
    --border:      #E8DDD5;
    --footer-bg:   #1A0F0A;
}

html { scroll-behavior: smooth; }

/* Font smoothing toàn trang */
*, *::before, *::after {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* ══ CUSTOM SCROLLBAR ══
   • Webkit  → Chrome, Safari, Edge, Opera (desktop)
   • Firefox → scrollbar-width / scrollbar-color
   • Mobile  → native overlay bars shown (no custom style needed / no breakage)
*/

/* — Page scrollbar (webkit) — */
::-webkit-scrollbar               { width: 7px; height: 7px; }
::-webkit-scrollbar-track         { background: var(--cream); }
::-webkit-scrollbar-thumb         {
    background: var(--gold);
    border-radius: 99px;
    border: 2px solid var(--cream);   /* "floating" thumb gap */
    transition: background .2s ease;
}
::-webkit-scrollbar-thumb:hover   { background: var(--brown-mid); }
::-webkit-scrollbar-thumb:active  { background: var(--brown-dark); }
::-webkit-scrollbar-corner        { background: var(--cream); }

/* — Page scrollbar (Firefox) — */
html  { scrollbar-width: thin; scrollbar-color: var(--gold) var(--cream); }

/* — In-page scrollable elements (textareas, modals, etc.) — */
textarea,
.overflow-auto,
.modal-body,
.chat-messages,
[data-scroll] {
    scrollbar-width: thin;
    scrollbar-color: var(--gold) var(--cream);
}
textarea::-webkit-scrollbar              { width: 5px; }
textarea::-webkit-scrollbar-thumb,
.overflow-auto::-webkit-scrollbar-thumb,
.modal-body::-webkit-scrollbar-thumb,
.chat-messages::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 99px; border: none; }

/* — Mobile: hide custom scrollbar width (use native overlay) — */
@media (hover: none) and (pointer: coarse) {
    html { scrollbar-width: none; }
    ::-webkit-scrollbar { width: 0; height: 0; }
}

body { font-family:'Be Vietnam Pro',sans-serif; background:var(--cream); color:var(--text-dark); line-height:1.6; }
a    { text-decoration:none; color:inherit; transition:color .3s ease; }
img  { display:block; max-width:100%; }

/* ══ HEADER ══ */
.site-header {
    position:fixed; top:0; left:0; right:0; z-index:999;
    background:rgba(250,247,242,.95); backdrop-filter:blur(8px);
    border-bottom:1px solid var(--border);
    padding:0 60px; display:flex; align-items:center; justify-content:space-between;
    min-height:90px; height:auto; padding-top:12px; padding-bottom:12px; transition:min-height .3s ease, box-shadow .3s;
}
.site-header.scrolled {
    min-height:66px;
    box-shadow:0 2px 20px rgba(92,61,46,.12);
    background:rgba(250,247,242,.98);
}
.site-header.scrolled .logo-img {
    max-height:56px !important;
    transition:max-height .3s ease;
}
.logo-img { transition:height .3s ease; }
.logo { display:flex; flex-direction:column; line-height:1; }
.logo-name    { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:600; color:var(--brown-dark); letter-spacing:2px; text-transform:uppercase; }
.logo-tagline { font-size:.65rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); font-weight:300; }
.main-nav { display:flex; gap:36px; align-items:center; }
.main-nav a { font-size:.8rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-mid); position:relative; padding-bottom:4px; }
.main-nav a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1px; background:var(--gold); transition:width .3s; }
.main-nav a:hover, .main-nav a.active { color:var(--brown-dark); }
.main-nav a:hover::after, .main-nav a.active::after { width:100%; }
.btn-book-header {
    background: linear-gradient(135deg, var(--gold) 0%, var(--brown-light) 100%) !important;
    color: #fff !important; padding: 10px 22px !important; font-size: .72rem; letter-spacing: 2px;
    text-transform: uppercase; border-radius: 3px; font-weight: 700 !important;
    box-shadow: 0 2px 12px rgba(201,169,110,.4) !important; transition: all .3s !important;
    -webkit-appearance: none; touch-action: manipulation;
    display: inline-flex !important; align-items: center; justify-content: center;
    line-height: 1 !important; vertical-align: middle;
}
.btn-book-header::after { display:none!important; }
.btn-book-header:hover {
    background: linear-gradient(135deg, var(--brown-dark) 0%, var(--brown-mid) 100%) !important;
    box-shadow: 0 4px 20px rgba(92,61,46,.45) !important; transform: translateY(-1px);
}

/* ══ HERO ══ */
.hero { position:relative; height:100vh; min-height:600px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.hero-bg { position:absolute; inset:0; background:url('../images/hero-bg.png') center/cover; transform:scale(1.08); animation:hero-slow-zoom 18s ease-in-out infinite alternate; }
@keyframes hero-slow-zoom { from{transform:scale(1.08) translateY(0)} to{transform:scale(1.14) translateY(-1%)} }
.hero-bg::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 60% 40%, rgba(201,169,110,.18) 0%, transparent 65%); z-index:1; }
.hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(160deg, rgba(20,10,5,.55) 0%, rgba(44,24,16,.15) 38%, rgba(30,15,5,.25) 65%, rgba(15,8,2,.75) 100%); z-index:2; }
.hero-bg-vignette { position:absolute; inset:0; z-index:3; pointer-events:none; background:radial-gradient(ellipse at 50% 50%, transparent 40%, rgba(10,5,2,.55) 100%); }
.hero-bg-shine { position:absolute; inset:0; z-index:4; pointer-events:none; background:linear-gradient(105deg, rgba(201,169,110,.07) 0%, transparent 40%, transparent 60%, rgba(201,169,110,.04) 100%); }
.hero-content { position:relative; z-index:5; text-align:center; color:#fff; padding:0 20px; animation:fadeUp 1.2s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.hero-eyebrow  { font-size:.7rem; letter-spacing:5px; text-transform:uppercase; color:var(--gold-light); margin-bottom:20px; font-weight:300; }
.hero-title    { font-family:'Playfair Display',serif; font-size:clamp(2.6rem,5.5vw,4.6rem); font-weight:400; line-height:1.15; margin-bottom:24px; }
.hero-title em { font-style:italic; font-weight:400; }
.hero-subtitle { font-size:.9rem; font-weight:300; letter-spacing:2px; opacity:.9; margin-bottom:44px; }
.hero-cta  { display:inline-flex; gap:16px; flex-wrap:wrap; justify-content:center; }
.hero-scroll { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; color:rgba(255,255,255,.7); font-size:.65rem; letter-spacing:3px; text-transform:uppercase; animation:bounce 2s infinite; z-index:5; }
.hero-scroll span { width:1px; height:40px; background:rgba(255,255,255,.5); }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* ══ BUTTONS ══ */
.btn-primary {
    display:inline-block;
    background: linear-gradient(135deg, var(--gold) 0%, var(--brown-light) 100%);
    color:#fff; padding:15px 40px; font-size:.75rem; letter-spacing:3px;
    text-transform:uppercase; font-weight:700; transition:all .35s;
    border-radius:3px; box-shadow:0 4px 18px rgba(201,169,110,.45);
    -webkit-appearance:none; touch-action:manipulation;
}
.btn-primary:hover { background:linear-gradient(135deg, var(--brown-dark) 0%, var(--brown-mid) 100%); color:#fff; transform:translateY(-2px); box-shadow:0 6px 24px rgba(92,61,46,.4); }
.btn-outline { display:inline-block; border:1.5px solid rgba(255,255,255,.7); color:#fff; padding:15px 40px; font-size:.75rem; letter-spacing:3px; text-transform:uppercase; transition:all .3s; border-radius:3px; backdrop-filter:blur(4px); touch-action:manipulation; }
.btn-outline:hover { background:rgba(255,255,255,.18); border-color:#fff; transform:translateY(-2px); }
.btn-submit {
    background: linear-gradient(135deg, var(--brown-dark) 0%, var(--brown-mid) 100%);
    color:#fff; border:none; padding:16px 56px;
    font-size:.75rem; letter-spacing:3px; text-transform:uppercase;
    cursor:pointer; font-family:'Be Vietnam Pro',sans-serif; transition:all .3s;
    border-radius:4px; box-shadow:0 4px 16px rgba(92,61,46,.3);
    -webkit-appearance:none; touch-action:manipulation; font-weight:600;
}
.btn-submit:hover { background:linear-gradient(135deg, var(--brown-mid) 0%, var(--brown-dark) 100%); box-shadow:0 6px 24px rgba(92,61,46,.45); transform:translateY(-1px); }
.btn-back { display:inline-block; padding:16px 28px; font-size:.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-mid); border:1.5px solid var(--border); transition:all .3s; cursor:pointer; font-family:'Be Vietnam Pro',sans-serif; background:none; border-radius:4px; touch-action:manipulation; -webkit-appearance:none; }
.btn-back:hover { border-color:var(--brown-dark); color:var(--brown-dark); }
.btn-room {
    background:transparent; border:1.5px solid var(--gold); color:var(--brown-dark);
    padding:9px 22px; font-size:.7rem; letter-spacing:2px; text-transform:uppercase;
    cursor:pointer; transition:all .3s; font-family:'Be Vietnam Pro',sans-serif;
    display:inline-block; border-radius:3px; font-weight:600;
    touch-action:manipulation; -webkit-appearance:none;
}
.btn-room:hover { background:var(--gold); color:#fff; border-color:var(--gold); box-shadow:0 4px 14px rgba(201,169,110,.4); transform:translateY(-1px); }
.btn-room-solid { background:var(--gold); color:#fff; border-color:var(--gold); }
.btn-room-solid:hover { background:var(--brown-dark); border-color:var(--brown-dark); box-shadow:0 4px 14px rgba(92,61,46,.35); }

/* ══ SECTIONS ══ */
.section { padding:90px 60px; }
.section-inner { max-width:1200px; margin:0 auto; }
.section-label { font-size:.65rem; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; display:block; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3vw,2.6rem); font-weight:500; color:var(--brown-dark); line-height:1.25; margin-bottom:16px; }
.section-desc  { font-size:.95rem; color:var(--text-mid); font-weight:300; max-width:560px; line-height:1.8; }
.divider { width:50px; height:1px; background:var(--gold); margin:24px 0; }

/* ══ ABOUT ══ */
.about-section { background:var(--warm-white); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-image-wrap { position:relative; }
.about-image-wrap img { width:100%; height:520px; object-fit:cover; position:relative; z-index:1; }
.about-image-wrap::before { content:''; position:absolute; top:-20px; left:-20px; right:20px; bottom:20px; border:1px solid var(--gold-light); z-index:0; }
.about-stats { display:flex; gap:32px; margin-top:40px; padding-top:36px; border-top:1px solid var(--border); flex-wrap:wrap; }
.stat { display:flex; flex-direction:column; align-items:center; gap:12px; }
.stat-circle {
    width:90px; height:90px; border-radius:50%;
    background:linear-gradient(135deg, var(--brown-dark) 0%, var(--brown-mid,#A0654A) 100%);
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 24px rgba(92,61,46,.28), 0 0 0 6px rgba(201,169,110,.18);
    position:relative;
}
.stat-circle::before {
    content:''; position:absolute; inset:-5px; border-radius:50%;
    border:1.5px solid rgba(201,169,110,.45);
}
.stat-num {
    font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:600;
    color:#fff; line-height:1; letter-spacing:-.5px;
}
.stat-label { font-size:.68rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--brown-dark); font-weight:600; text-align:center; }

/* ── About Us button ── */
.btn-about-us {
    display:inline-flex; align-items:center; gap:10px;
    margin-top:36px;
    padding:14px 28px;
    background:transparent;
    border:1.5px solid var(--brown-dark);
    color:var(--brown-dark);
    font-size:.72rem; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
    text-decoration:none;
    position:relative; overflow:hidden;
    transition:color .3s, border-color .3s;
}
.btn-about-us::before {
    content:''; position:absolute; inset:0; left:-100%;
    background:var(--brown-dark);
    transition:left .32s cubic-bezier(.4,0,.2,1);
    z-index:0;
}
.btn-about-us:hover::before { left:0; }
.btn-about-us span, .btn-about-us svg { position:relative; z-index:1; transition:color .3s; }
.btn-about-us:hover span, .btn-about-us:hover svg { color:#fff; stroke:#fff; }
.btn-about-us svg { transition:transform .28s, color .3s; }
.btn-about-us:hover svg { transform:translateX(5px); }

/* ══ ROOMS ══ */
.rooms-section { background:var(--cream); }
.rooms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; }
.room-card { background:var(--warm-white); overflow:hidden; transition:transform .4s,box-shadow .4s; }
.room-card:hover { transform:translateY(-6px); box-shadow:0 20px 50px rgba(92,61,46,.12); }
.room-card-img { position:relative; overflow:hidden; height:240px; }
.room-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.room-card:hover .room-card-img img { transform:scale(1.06); }
.room-badge { position:absolute; top:16px; right:16px; background:var(--gold); color:var(--text-dark); font-size:.65rem; letter-spacing:2px; text-transform:uppercase; padding:5px 12px; font-weight:700; z-index:2; }
.card-img-overlay-link { position:absolute; inset:0; background:rgba(44,24,16,0); display:flex; align-items:center; justify-content:center; transition:background .4s; z-index:1; }
.card-img-overlay-link span { color:#fff; font-size:.72rem; letter-spacing:3px; text-transform:uppercase; border:1px solid rgba(255,255,255,.8); padding:10px 20px; opacity:0; transform:translateY(8px); transition:all .4s; }
.room-card:hover .card-img-overlay-link { background:rgba(44,24,16,.4); }
.room-card:hover .card-img-overlay-link span { opacity:1; transform:translateY(0); }
.room-card-body { padding:28px; }
.room-type  { font-size:.65rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.room-name  { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:500; color:var(--brown-dark); margin-bottom:12px; }
.room-desc  { font-size:.85rem; color:var(--text-mid); line-height:1.7; margin-bottom:20px; font-weight:300; }
.room-amenities { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.amenity-tag { font-size:.7rem; color:var(--text-mid); background:var(--cream); padding:4px 10px; letter-spacing:1px; }
.room-footer { display:flex; align-items:center; justify-content:space-between; padding-top:20px; border-top:1px solid var(--border); }
.room-price { display:flex; flex-direction:column; }
.price-amount { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:600; color:var(--brown-dark); }
.price-unit   { font-size:.7rem; color:var(--text-light); letter-spacing:1px; }

/* ══ AMENITIES ══ */
.amenities-section { background:var(--brown-dark); color:#fff; }
.amenities-section .section-title { color:#fff; }
.amenities-section .section-desc  { color:rgba(255,255,255,.7); }
.amenities-section .divider { background:var(--gold); }
.amenities-grid {
    display:grid; grid-template-columns:repeat(4,1fr);
    gap:1px; margin-top:56px;
    background:rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.07);
}
.amenity-item {
    background:var(--brown-dark);
    padding:36px 28px 32px;
    position:relative; overflow:hidden;
    transition:background .28s, transform .22s;
    display:flex; flex-direction:column; align-items:flex-start;
}
.amenity-item::after {
    content:''; position:absolute; bottom:0; left:0;
    width:0; height:2px;
    background:linear-gradient(90deg, var(--gold,#C9A96E), transparent);
    transition:width .35s cubic-bezier(.4,0,.2,1);
}
.amenity-item:hover { background:rgba(255,255,255,.04); }
.amenity-item:hover::after { width:100%; }
.amenity-num-circle {
    width:46px; height:46px; border-radius:50%;
    background:rgba(201,169,110,.1);
    border:1.5px solid rgba(201,169,110,.4);
    display:flex; align-items:center; justify-content:center;
    margin-bottom:20px; flex-shrink:0;
    font-family:'Playfair Display',serif;
    font-size:.85rem; font-weight:600; letter-spacing:1px;
    color:var(--gold,#C9A96E);
    transition:background .28s, border-color .28s, transform .22s;
    box-shadow:0 0 0 4px rgba(201,169,110,.07);
}
.amenity-item:hover .amenity-num-circle {
    background:rgba(201,169,110,.18);
    border-color:rgba(201,169,110,.7);
    transform:scale(1.08);
    box-shadow:0 0 0 6px rgba(201,169,110,.12);
}
.amenity-item h4 {
    font-family:'Playfair Display',serif;
    font-size:1rem; font-weight:600;
    margin-bottom:10px; color:var(--gold-light,#E8D5B0);
    letter-spacing:.3px; line-height:1.3;
}
.amenity-item p  {
    font-size:.78rem; color:rgba(255,255,255,.48);
    font-weight:300; line-height:1.78; margin:0;
}

/* ══ BOOKING BANNER ══ */
.booking-banner { background:var(--gold-light); padding:70px 60px; text-align:center; }
.booking-banner .section-title { color:var(--brown-dark); margin-bottom:12px; }
.booking-banner p { color:var(--text-mid); font-size:.9rem; font-weight:300; margin-bottom:36px; }

/* ══ TESTIMONIALS ══ */
.testimonials-section { background:var(--warm-white); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; }
.testimonial-card { background:var(--cream); padding:36px; border-left:3px solid var(--gold); }
.testimonial-quote { font-family:'Playfair Display',serif; font-size:1.1rem; font-style:italic; color:var(--text-mid); line-height:1.8; margin-bottom:24px; }
.testimonial-author { display:flex; align-items:center; gap:14px; }
.author-avatar { width:44px; height:44px; border-radius:50%; background:var(--gold-light); display:flex; align-items:center; justify-content:center; font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--brown-dark); font-weight:600; flex-shrink:0; }
.author-name { font-weight:700; font-size:.85rem; color:var(--brown-dark); }
.author-loc  { font-size:.75rem; color:var(--text-light); }
.stars { color:var(--gold); font-size:.8rem; margin-bottom:16px; }

/* ══ PAGE HERO ══ */
.page-hero { height:320px; background:var(--brown-dark); display:flex; align-items:center; justify-content:center; text-align:center; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:url('../images/phong-vip.jpg') center/cover; opacity:.25; }
.page-hero-content { position:relative; z-index:2; color:#fff; }
.page-hero-content .section-label { color:var(--gold-light); }
.page-hero-content .section-title { color:#fff; font-size:clamp(2rem,4vw,3rem); }

/* ══ ALERTS ══ */
.alert { padding:16px 24px; margin-bottom:24px; font-size:.9rem; }
.alert-success { background:#d4edda; color:#155724; border-left:4px solid #28a745; }
.alert-error   { background:#f8d7da; color:#721c24; border-left:4px solid #dc3545; }

/* ══ FORMS ══ */
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group.full-width { grid-column:1/-1; }
.form-group label { font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-mid); }
.form-group input,
.form-group select,
.form-group textarea {
    background:var(--warm-white); border:1px solid var(--border); padding:12px 16px;
    font-size:.9rem; color:var(--text-dark); font-family:'Be Vietnam Pro',sans-serif;
    outline:none; transition:border-color .3s; -webkit-appearance:none; appearance:none;
    border-radius:0;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--gold); }
.form-group select {
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239A8880' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 14px center;
    padding-right:38px;
}
.form-group textarea { resize:vertical; min-height:120px; }

/* ══ ─────────────────────────────────── ══ */
/* ══  FOOTER V2                           ══ */
/* ══ ─────────────────────────────────── ══ */
.footer-top-strip { background:var(--gold); padding:10px 0; }
.footer-strip-inner { max-width:1200px; margin:0 auto; padding:0 60px; display:flex; align-items:center; justify-content:center; gap:20px; font-size:.75rem; letter-spacing:1.5px; color:var(--text-dark); font-weight:700; flex-wrap:wrap; }
.strip-sep { opacity:.5; }

.footer-newsletter { background:var(--brown-mid); padding:40px 60px; }
.footer-newsletter-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.newsletter-text h3 { font-family:'Playfair Display',serif; font-size:1.5rem; color:#fff; margin-bottom:6px; }
.newsletter-text p  { font-size:.85rem; color:rgba(255,255,255,.7); }
.newsletter-form { display:flex; gap:0; flex:1; max-width:480px; }
.newsletter-input { flex:1; padding:13px 20px; border:none; font-family:'Be Vietnam Pro',sans-serif; font-size:.88rem; outline:none; background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.3); }
.newsletter-input::placeholder { color:rgba(255,255,255,.5); }
.newsletter-btn { background:var(--gold); color:var(--text-dark); border:none; padding:13px 28px; font-size:.72rem; letter-spacing:2px; text-transform:uppercase; cursor:pointer; font-family:'Be Vietnam Pro',sans-serif; font-weight:700; white-space:nowrap; transition:background .3s; }
.newsletter-btn:hover { background:var(--gold-light); }

.footer-main { background:var(--footer-bg); padding:70px 60px 50px; }
.footer-grid-v2 { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:60px; }

.footer-brand-v2 { display:flex; flex-direction:column; align-items:center; text-align:center; }
.footer-logo { display:flex; flex-direction:column; align-items:center; line-height:1; margin-bottom:20px; }
.footer-logo img { display:block; }
.footer-logo .logo-name    { color:var(--gold-light); font-size:1.4rem; }
.footer-logo .logo-tagline { color:rgba(255,255,255,.35); margin-top:6px; }
.footer-brand-desc { font-size:.85rem; color:rgba(255,255,255,.55); line-height:1.8; font-weight:300; max-width:280px; margin:0 auto 20px; text-align:center; }
.footer-rating { display:flex; align-items:center; justify-content:center; gap:10px; margin-bottom:20px; }
.rating-stars  { color:var(--gold); font-size:1rem; }
.footer-rating span { font-size:.78rem; color:rgba(255,255,255,.55); }
.footer-socials { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:20px; }
.social-btn { width:38px; height:38px; border:1px solid rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; color:#fff; transition:all .3s; border-radius:6px; }
.social-btn:hover { transform:translateY(-2px); opacity:.85; }
.social-btn--fb  { background:#1877F2; border-color:#1877F2; }
.social-btn--ig  { background:radial-gradient(circle at 30% 107%, #fdf497 0%, #fd5949 45%, #d6249f 60%, #285AEB 90%); border-color:#d6249f; }
.social-btn--tt  { background:#000; border-color:#69C9D0; }
.social-btn--yt  { background:#FF0000; border-color:#FF0000; }
.social-btn--za  { background:#0068FF; border-color:#0068FF; font-size:.65rem; font-weight:700; letter-spacing:0; line-height:1; }
.footer-awards { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:4px; }
.award-badge { font-size:.65rem; background:transparent; color:rgba(255,255,255,.35); border:1px solid rgba(255,255,255,.15); padding:4px 12px; letter-spacing:1.5px; text-transform:uppercase; }

.footer-col-v2 {}
.footer-col-title { font-size:.7rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:11px; }
.footer-links a { font-size:.85rem; color:rgba(255,255,255,.55); font-weight:300; transition:color .3s; }
.footer-links a:hover { color:var(--gold); }

.footer-hours { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.hours-item { display:flex; justify-content:space-between; font-size:.82rem; }
.hours-label { color:rgba(255,255,255,.5); }
.hours-val   { color:rgba(255,255,255,.85); font-weight:400; }
.footer-checkin { display:flex; gap:0; padding-top:20px; border-top:1px solid rgba(255,255,255,.08); margin-bottom:20px; }
.ci-text-item { flex:1; display:flex; flex-direction:column; gap:4px; }
.ci-text-item:first-child { padding-right:16px; border-right:1px solid rgba(255,255,255,.1); margin-right:16px; }
.ci-label { font-size:.6rem; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.4); }
.ci-text-item strong { font-size:.82rem; color:rgba(255,255,255,.85); font-weight:500; }
.ci-sep { width:1px; }
.footer-address-block { display:flex; flex-direction:column; gap:6px; padding-top:16px; border-top:1px solid rgba(255,255,255,.08); }
.footer-address-block p { font-size:.8rem; color:rgba(255,255,255,.45); font-weight:300; line-height:1.6; }

.footer-bottom-v2 { background:#3D1F10; border-top:1px solid rgba(201,169,110,.2); }
.footer-bottom-inner { max-width:1200px; margin:0 auto; padding:20px 60px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:.72rem; color:rgba(255,255,255,.45); }
.footer-bottom-links { display:flex; gap:12px; align-items:center; font-size:.72rem; color:rgba(255,255,255,.4); }
.footer-bottom-links a { color:rgba(255,255,255,.55); transition:color .3s; }
.footer-bottom-links a:hover { color:var(--gold); }
.footer-bottom-links span { opacity:.35; }
.footer-payments { display:flex; gap:8px; align-items:center; }
.pay-icon { display:flex; align-items:center; opacity:.85; transition:opacity .2s; }
.pay-icon:hover { opacity:1; }
.pay-icon svg { display:block; }

/* ══ ─────────────────────────────────── ══ */
/* ══  ROOM DETAIL PAGE                    ══ */
/* ══ ─────────────────────────────────── ══ */
.breadcrumb-bar { background:var(--warm-white); border-bottom:1px solid var(--border); padding:12px 60px; }
.breadcrumb-inner { max-width:1400px; margin:0 auto; display:flex; gap:8px; align-items:center; font-size:.75rem; color:var(--text-light); }
.breadcrumb-inner a { color:var(--text-light); transition:color .3s; }
.breadcrumb-inner a:hover { color:var(--gold); }
.bc-sep { opacity:.5; }

.detail-section { padding:50px 60px; background:var(--cream); }
.detail-inner { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 380px; gap:50px; align-items:start; }
.detail-main { display:flex; flex-direction:column; gap:48px; }

/* Gallery */
.gallery-wrap {}
.gallery-main { position:relative; overflow:hidden; height:500px; background:#111; }
.gallery-main img { width:100%; height:100%; object-fit:cover; transition:filter .5s; }
.gallery-overlay-label { position:absolute; bottom:20px; left:20px; background:rgba(44,24,16,.7); color:#fff; font-size:.68rem; letter-spacing:2px; text-transform:uppercase; padding:6px 14px; z-index:2; }
.gallery-badge { position:absolute; top:20px; left:20px; background:var(--gold); color:var(--text-dark); font-size:.65rem; letter-spacing:2px; text-transform:uppercase; padding:6px 14px; font-weight:700; z-index:2; }
.gallery-arrow { position:absolute; top:50%; transform:translateY(-50%); background:rgba(44,24,16,.5); color:#fff; border:none; width:44px; height:44px; font-size:1.8rem; cursor:pointer; z-index:3; display:flex; align-items:center; justify-content:center; transition:background .3s; line-height:1; }
.gallery-arrow:hover { background:rgba(44,24,16,.8); }
.gallery-prev { left:16px; }
.gallery-next { right:16px; }
.gallery-thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-top:6px; }
.gallery-thumb { position:relative; cursor:pointer; overflow:hidden; height:90px; border:2px solid transparent; transition:border-color .3s; }
.gallery-thumb.active { border-color:var(--gold); }
.gallery-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.gallery-thumb:hover img { transform:scale(1.05); }
.thumb-label { position:absolute; bottom:0; left:0; right:0; background:rgba(44,24,16,.65); color:#fff; font-size:.6rem; text-align:center; padding:4px; letter-spacing:1px; }

/* Video */
.detail-video-wrap { background:var(--warm-white); padding:36px; }
.detail-video-header { margin-bottom:20px; }
.video-embed-wrap { position:relative; padding-bottom:56.25%; height:0; overflow:hidden; }
.video-embed-wrap iframe { position:absolute; top:0; left:0; width:100%; height:100%; }

/* Description */
.detail-desc-block {}
.room-quick-facts { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-top:32px; }
.fact-item { background:var(--warm-white); padding:20px 16px; text-align:center; border:1px solid var(--border); }
.fact-item strong { display:block; font-family:'Playfair Display',serif; font-size:1rem; color:var(--brown-dark); margin-bottom:4px; }
.fact-item span { font-size:.68rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-light); }

/* Amenities */
.detail-amenities-block {}
.detail-amenities-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.detail-amenity-card { background:var(--warm-white); padding:20px; border:1px solid var(--border); transition:box-shadow .3s; }
.detail-amenity-card:hover { box-shadow:0 4px 20px rgba(92,61,46,.08); }
.detail-amenity-card strong { display:block; font-size:.85rem; color:var(--brown-dark); margin-bottom:4px; }
.detail-amenity-card p { font-size:.78rem; color:var(--text-light); font-weight:300; margin:0; }

/* Tags */
.detail-tags-block { background:var(--warm-white); padding:28px; }
.detail-tags { display:flex; flex-wrap:wrap; gap:10px; }
.detail-tag { font-size:.75rem; padding:6px 14px; background:var(--cream); color:var(--text-mid); border:1px solid var(--border); letter-spacing:.5px; }

/* Reviews */
.detail-reviews-block {}
.review-summary { display:flex; align-items:center; gap:16px; margin-bottom:24px; }
.review-score { font-family:'Playfair Display',serif; font-size:3.5rem; font-weight:600; color:var(--brown-dark); line-height:1; }
.review-bars { display:flex; flex-direction:column; gap:10px; }
.review-bar-row { display:flex; align-items:center; gap:12px; font-size:.8rem; color:var(--text-mid); }
.review-bar-row span:first-child { width:80px; }
.review-bar-row span:last-child  { width:24px; text-align:right; }
.review-bar-track { flex:1; height:4px; background:var(--border); }
.review-bar-fill  { height:100%; background:var(--gold); }

/* Room nav */
.room-nav { display:flex; justify-content:space-between; gap:16px; padding-top:20px; border-top:1px solid var(--border); }
.room-nav-btn { font-size:.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-mid); padding:12px 20px; border:1px solid var(--border); transition:all .3s; }
.room-nav-btn:hover { color:var(--brown-dark); border-color:var(--brown-dark); }

/* ── SIDEBAR BOOKING CARD ── */
.detail-sidebar { position:sticky; top:100px; display:flex; flex-direction:column; gap:24px; }
.sidebar-booking-card { background:var(--warm-white); border:1px solid var(--border); padding:32px; box-shadow:0 8px 40px rgba(92,61,46,.1); }
.sbc-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.sbc-price { display:flex; align-items:baseline; gap:6px; }
.sbc-amount { font-family:'Playfair Display',serif; font-size:2rem; font-weight:600; color:var(--brown-dark); }
.sbc-unit { font-size:.75rem; color:var(--text-light); }
.sbc-badge { background:var(--gold); color:var(--text-dark); font-size:.65rem; letter-spacing:2px; text-transform:uppercase; padding:4px 10px; font-weight:700; }
.sbc-form {}
.sbc-dates { display:grid; grid-template-columns:1fr auto 1fr; border:1px solid var(--border); margin-bottom:12px; }
.sbc-field { padding:12px 14px; }
.sbc-field label { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); display:block; margin-bottom:4px; }
.sbc-field input { border:none; outline:none; font-size:.85rem; color:var(--text-dark); font-family:'Be Vietnam Pro',sans-serif; width:100%; background:transparent; }
.sbc-divider-v { width:1px; background:var(--border); }
.sbc-guests { margin-bottom:16px; }
.sbc-guests label { font-size:.62rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); display:block; margin-bottom:6px; }
.sbc-guests select { width:100%; border:1px solid var(--border); padding:10px 14px; font-family:'Be Vietnam Pro',sans-serif; font-size:.88rem; outline:none; background:var(--warm-white); }
.sbc-btn { width:100%; background:var(--brown-dark); color:#fff; border:none; padding:15px; font-size:.75rem; letter-spacing:3px; text-transform:uppercase; cursor:pointer; font-family:'Be Vietnam Pro',sans-serif; transition:background .3s; }
.sbc-btn:hover { background:var(--brown-mid); }
.sbc-perks { margin-top:20px; display:flex; flex-direction:column; gap:8px; padding-top:20px; border-top:1px solid var(--border); }
.sbc-perk { font-size:.78rem; color:var(--text-mid); }
.sbc-perk::before { color:var(--gold); }
.sbc-contact { margin-top:16px; text-align:center; }
.sbc-contact p { font-size:.75rem; color:var(--text-light); margin-bottom:8px; }
.sbc-contact a { display:block; font-size:.82rem; color:var(--brown-mid); margin-bottom:6px; }
.sbc-contact a:hover { color:var(--gold); }

/* Similar rooms */
.similar-rooms h4 { font-size:.7rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.similar-card { display:flex; gap:12px; background:var(--warm-white); padding:12px; margin-bottom:10px; border:1px solid var(--border); transition:box-shadow .3s; align-items:center; }
.similar-card:hover { box-shadow:0 4px 16px rgba(92,61,46,.1); }
.similar-card img { width:70px; height:56px; object-fit:cover; flex-shrink:0; }
.similar-info strong { display:block; font-size:.82rem; color:var(--brown-dark); margin-bottom:3px; }
.similar-info span   { font-size:.75rem; color:var(--text-light); }

/* ══ ─────────────────────────────────── ══ */
/* ══  MULTI-STEP BOOKING                  ══ */
/* ══ ─────────────────────────────────── ══ */
.step-indicator { display:flex; align-items:center; justify-content:center; margin-bottom:48px; gap:0; }
.step-item { display:flex; flex-direction:column; align-items:center; gap:8px; }
.step-circle { width:40px; height:40px; border-radius:50%; border:2px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:.8rem; color:var(--text-light); background:var(--warm-white); transition:all .3s; }
.step-item span { font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); white-space:nowrap; }
.step-item.active .step-circle { border-color:var(--brown-dark); background:var(--brown-dark); color:#fff; }
.step-item.active span { color:var(--brown-dark); font-weight:700; }
.step-item.done .step-circle { border-color:var(--gold); background:var(--gold); color:var(--text-dark); }
.step-item.done span { color:var(--text-mid); }
.step-line { flex:1; height:1px; background:var(--border); min-width:60px; margin:0 12px; margin-bottom:24px; }
.step-line.done { background:var(--gold); }

.booking-card { background:var(--warm-white); padding:48px; border:1px solid var(--border); }
.booking-card-title { margin-bottom:36px; }
.booking-card-title h2 { font-family:'Playfair Display',serif; font-size:2rem; color:var(--brown-dark); margin-top:8px; }
.bk-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.bk-select {
    width:100%; padding:12px 38px 12px 16px; border:1px solid var(--border);
    font-family:'Be Vietnam Pro',sans-serif; font-size:.9rem; outline:none;
    background:var(--warm-white); transition:border-color .3s;
    -webkit-appearance:none; appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239A8880' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 14px center;
    border-radius:0;
}
.bk-select:focus { border-color:var(--gold); }
.bk-summary-bar { display:flex; gap:16px; flex-wrap:wrap; align-items:center; background:var(--cream); padding:16px 20px; margin-bottom:28px; font-size:.82rem; color:var(--text-mid); }
.bk-summary-bar .sum-total { font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--brown-dark); font-weight:600; margin-left:auto; }
.bk-actions { display:flex; justify-content:space-between; align-items:center; margin-top:36px; padding-top:28px; border-top:1px solid var(--border); }

/* Price Preview */
.price-preview { background:var(--cream); border:1px solid var(--border); padding:20px 24px; margin-top:20px; }
.pp-row { display:flex; justify-content:space-between; font-size:.85rem; color:var(--text-mid); padding:6px 0; border-bottom:1px solid var(--border); }
.pp-row:last-of-type { border-bottom:none; }
.pp-total { font-weight:700; color:var(--brown-dark); font-size:.95rem; margin-top:4px; }

/* ══ PAYMENT ══ */
.payment-layout { display:grid; grid-template-columns:1fr 320px; gap:40px; align-items:start; }
.payment-left {}
.pay-tabs { display:flex; gap:0; margin-bottom:28px; border:1px solid var(--border); overflow:hidden; }
.pay-tab { flex:1; background:none; border:none; padding:14px 10px; font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; font-family:'Be Vietnam Pro',sans-serif; color:var(--text-mid); transition:all .3s; border-right:1px solid var(--border); }
.pay-tab:last-child { border-right:none; }
.pay-tab.active { background:var(--brown-dark); color:#fff; }
.pay-panel {}

/* Credit card visual */
.credit-card-visual { background:linear-gradient(135deg,var(--brown-dark) 0%,var(--brown-mid) 100%); border-radius:12px; padding:28px 28px 22px; color:#fff; position:relative; height:180px; display:flex; flex-direction:column; justify-content:space-between; box-shadow:0 8px 30px rgba(92,61,46,.3); }
.cv-chip { width:42px; height:32px; background:linear-gradient(135deg,var(--gold),var(--gold-light)); border-radius:5px; }
.cv-number { font-size:1.2rem; letter-spacing:3px; font-family:monospace; margin-top:auto; }
.cv-bottom { display:flex; justify-content:space-between; align-items:flex-end; }
.cv-name { font-size:.75rem; letter-spacing:2px; text-transform:uppercase; opacity:.85; }
.cv-exp  { font-size:.82rem; letter-spacing:1px; opacity:.85; }
.cv-logo { position:absolute; top:22px; right:24px; font-size:.9rem; font-weight:700; letter-spacing:2px; opacity:.7; font-style:italic; }

/* Bank transfer */
.transfer-info { background:var(--cream); padding:28px; border:1px solid var(--border); }
.transfer-info h4 { font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--brown-dark); margin-bottom:20px; }
.transfer-row { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--border); font-size:.85rem; color:var(--text-mid); }
.transfer-row.highlight { font-size:1rem; color:var(--brown-dark); font-weight:700; }
.transfer-note { margin-top:16px; font-size:.78rem; color:var(--text-light); line-height:1.6; }

/* Cash */
.cash-info { text-align:center; padding:40px 20px; }
.cash-icon { font-size:3rem; margin-bottom:16px; }
.cash-info h4 { font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--brown-dark); margin-bottom:12px; }
.cash-info p  { font-size:.88rem; color:var(--text-mid); line-height:1.7; margin-bottom:20px; }
.cash-note { display:flex; flex-direction:column; gap:8px; background:var(--cream); padding:16px; }
.cash-note span { font-size:.82rem; color:var(--text-mid); }

/* Order summary */
.payment-right {}
.order-summary { background:var(--cream); border:1px solid var(--border); padding:28px; position:sticky; top:90px; }
.order-summary h4 { font-family:'Playfair Display',serif; font-size:1.3rem; color:var(--brown-dark); margin-bottom:16px; }
.os-img { width:100%; height:140px; object-fit:cover; margin-bottom:14px; }
.os-room-name { font-size:.75rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.os-rows { display:flex; flex-direction:column; gap:0; }
.os-row { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid var(--border); font-size:.82rem; color:var(--text-mid); }
.os-row strong { color:var(--text-dark); font-weight:600; }
.os-divider { height:1px; background:var(--gold); margin:16px 0 8px; }
.os-total { font-size:1rem; color:var(--brown-dark); }
.os-total strong { font-family:'Playfair Display',serif; font-size:1.3rem; }
.os-note   { font-size:.7rem; color:var(--text-light); margin-top:8px; }
.os-secure { text-align:center; margin-top:16px; font-size:.75rem; color:var(--text-mid); background:rgba(201,169,110,.1); padding:8px; border:1px solid var(--gold-light); }

.btn-pay { background:linear-gradient(135deg,var(--brown-dark),var(--brown-mid)); }

/* ── BOOKING SUCCESS ── */
.booking-success { text-align:center; padding:0 0 60px; background:transparent; max-width:760px; margin:0 auto; }
.success-top-band { background:var(--brown-dark); color:#fff; padding:28px 40px; display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:0; position:relative; overflow:hidden; }
.success-top-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 70% 50%, rgba(201,169,110,.18) 0%, transparent 70%); pointer-events:none; }
.success-top-band-hotel { font-family:'Cormorant Garamond',serif; font-size:1.1rem; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.85); position:relative; }
.success-gold-strip { height:3px; background:linear-gradient(90deg, transparent, var(--gold), transparent); }
.success-card { background:#fff; border:1px solid #ede8e0; border-top:none; box-shadow:0 8px 40px rgba(92,61,46,.10); overflow:hidden; }
.success-body { padding:48px 48px 36px; }
.success-check { width:72px; height:72px; border-radius:50%; background:rgba(201,169,110,.10); border:2px solid var(--gold); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; color:var(--gold); animation:successPop .5s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes successPop { from { transform:scale(0); opacity:0; } to { transform:scale(1); opacity:1; } }
.booking-success h2 { font-family:'Cormorant Garamond',serif; font-size:2.2rem; font-weight:600; color:var(--brown-dark); margin-bottom:10px; letter-spacing:.5px; }
.success-subtitle { font-size:.9rem; color:var(--text-mid); line-height:1.7; margin-bottom:32px; }
.success-ornament { display:flex; align-items:center; gap:12px; justify-content:center; margin-bottom:32px; }
.success-ornament::before,.success-ornament::after { content:''; flex:1; max-width:80px; height:1px; background:linear-gradient(90deg, transparent, var(--gold)); }
.success-ornament::after { background:linear-gradient(90deg, var(--gold), transparent); }
.success-ornament span { font-size:.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); }
.success-code-wrap { background:linear-gradient(135deg, #fdfaf6, #f5ede0); border:1px solid var(--gold); border-radius:4px; padding:24px 36px; display:inline-block; margin-bottom:32px; position:relative; }
.success-code-wrap::before { content:''; position:absolute; inset:3px; border:1px solid rgba(201,169,110,.3); border-radius:2px; pointer-events:none; }
.success-code-label { font-size:.58rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:10px; }
.success-code { font-family:monospace; font-size:1.85rem; font-weight:700; color:var(--brown-dark); letter-spacing:5px; }
.success-code-wrap p { font-size:.72rem; color:var(--text-light); margin-top:8px; }
.success-summary { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:#ede8e0; border:1px solid #ede8e0; margin-bottom:32px; text-align:left; }
.ss-item { background:#fff; padding:18px 22px; display:flex; align-items:flex-start; gap:12px; }
.ss-item-icon { width:32px; height:32px; border-radius:50%; background:rgba(201,169,110,.10); border:1px solid rgba(201,169,110,.3); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--gold); margin-top:2px; }
.ss-item-body { display:flex; flex-direction:column; gap:3px; }
.ss-item span { font-size:.62rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); }
.ss-item strong { font-size:.9rem; color:var(--text-dark); font-weight:600; }
.success-actions { display:flex; gap:12px; justify-content:center; margin-bottom:24px; flex-wrap:wrap; }
.success-contact { font-size:.8rem; color:var(--text-light); padding:16px 20px; background:#fdfaf6; border-top:1px solid #ede8e0; margin:0 -48px -36px; }

/* ══ ─────────────────────────────────── ══ */
/* ══  CONTACT PAGE V2                     ══ */
/* ══ ─────────────────────────────────── ══ */
.contact-quick-bar { background:var(--brown-dark); padding:0 60px; }
.contact-quick-inner { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); }
.cq-card { display:flex; gap:16px; align-items:center; padding:28px 20px; transition:background .3s; border-right:1px solid rgba(255,255,255,.08); }
.cq-card:last-child { border-right:none; }
.cq-card:hover { background:rgba(255,255,255,.05); }
.cq-icon { flex-shrink:0; color:rgba(255,255,255,.5); display:flex; align-items:center; justify-content:center; width:44px; height:44px; border:1px solid rgba(255,255,255,.12); }
.cq-content strong { display:block; font-size:.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:4px; }
.cq-content span   { display:block; font-size:.88rem; color:#fff; margin-bottom:2px; }
.cq-content em     { font-size:.72rem; color:rgba(255,255,255,.45); font-style:normal; }
.cq-book { background:rgba(201,169,110,.12); }
.cq-book:hover { background:rgba(201,169,110,.22); }

.contact-main-section {}
.contact-main-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; }
.contact-left {}
.contact-form {}

/* FAQ */
.faq-section { margin-top:48px; padding-top:40px; border-top:1px solid var(--border); }
.faq-title { font-family:'Playfair Display',serif; font-size:1.6rem; color:var(--brown-dark); margin-bottom:20px; }
.faq-item { border-bottom:1px solid var(--border); cursor:pointer; }
.faq-q { display:flex; justify-content:space-between; align-items:center; padding:18px 0; font-size:.9rem; color:var(--text-dark); font-weight:400; }
.faq-arrow { font-size:1.4rem; color:var(--gold); transition:transform .3s; flex-shrink:0; }
.faq-a { font-size:.85rem; color:var(--text-mid); line-height:1.7; padding-bottom:18px; display:none; font-weight:300; }
.faq-item.open .faq-a    { display:block; }
.faq-item.open .faq-arrow { transform:rotate(90deg); }

/* Contact right */
.contact-right {}
.contact-map-wrap { margin-bottom:28px; }
.contact-map-placeholder { background:var(--brown-dark); height:280px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.contact-map-placeholder::before { content:''; position:absolute; inset:0; background:url('../images/phong-vip.jpg') center/cover; opacity:.15; }
.map-content { position:relative; z-index:2; text-align:center; color:#fff; }
.map-content h4 { font-family:'Playfair Display',serif; font-size:1.3rem; margin-bottom:10px; }
.map-content p { font-size:.85rem; color:rgba(255,255,255,.7); line-height:1.7; margin-bottom:20px; }
.map-directions-btn { display:inline-block; border:1px solid rgba(201,169,110,.7); color:var(--gold); padding:10px 24px; font-size:.72rem; letter-spacing:2px; text-transform:uppercase; transition:all .3s; }
.map-directions-btn:hover { background:var(--gold); color:var(--text-dark); }
.map-pin-anim { position:absolute; bottom:20px; right:28px; font-size:2rem; animation:bounce 2s infinite; z-index:2; }

.contact-info-cards { display:flex; flex-direction:column; gap:16px; }
.ci-card { background:var(--warm-white); border:1px solid var(--border); border-left:3px solid var(--gold); padding:24px 28px; display:flex; gap:0; flex-direction:column; transition:box-shadow .3s; }
.ci-card:hover { box-shadow:0 4px 20px rgba(92,61,46,.08); }
.ci-card-icon-line { display:none; }
.ci-card-body h4 { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--brown-dark); margin-bottom:14px; }
.map-icon-svg { color:var(--gold); margin-bottom:14px; display:flex; justify-content:center; }
.map-pin-anim { display:none; }

.hours-table { width:100%; font-size:.83rem; border-collapse:collapse; }
.hours-table td { padding:5px 0; color:var(--text-mid); }
.hours-table td:last-child { text-align:right; }

.transport-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
.transport-list li { font-size:.83rem; color:var(--text-mid); line-height:1.5; }

.social-contact-list { display:flex; flex-direction:column; gap:10px; }
.sc-item { display:flex; align-items:center; gap:10px; font-size:.83rem; color:var(--text-mid); transition:color .3s; }
.sc-item:hover { color:var(--gold); }
.sc-item svg { color:var(--gold); flex-shrink:0; }

/* ══ RESPONSIVE ══ */
@media (max-width:1200px) {
    .detail-inner { grid-template-columns:1fr; }
    .detail-sidebar { position:static; }
    .room-quick-facts { grid-template-columns:repeat(3,1fr); }
    .footer-grid-v2 { grid-template-columns:1fr 1fr; gap:40px; }
    .contact-quick-inner { grid-template-columns:repeat(2,1fr); }
    .payment-layout { grid-template-columns:1fr; }
    .order-summary { position:static; }
    .success-summary { grid-template-columns:repeat(2,1fr); }
}
/* ── Branches dynamic grid ── */
.branches-dynamic-grid { display:grid; gap:20px; }
@media (max-width:1024px) {
    .branches-dynamic-grid { grid-template-columns:repeat(2,1fr) !important; }
    .rooms-grid, .testimonials-grid { grid-template-columns:repeat(2,1fr); }
    .amenities-grid { grid-template-columns:repeat(2,1fr); }
    .about-grid, .contact-main-grid { grid-template-columns:1fr; gap:50px; }
    .main-nav { gap:18px; }
}
@media (max-width:860px) {
    .main-nav { display:none; }
    .site-header {
        padding:0 24px;
        min-height:70px;
        padding-top:10px;
        padding-bottom:10px;
    }
    .logo-img {
        max-height:52px !important;
        height:52px !important;
        width:auto !important;
        object-fit:contain;
    }
    .site-header.scrolled .logo-img { max-height:44px !important; }

    /* ── Fix hardcoded margin-top:90px on page heroes ── */
    .page-hero { margin-top: 70px !important; }
    .invoice-page-wrap { margin-top: 70px !important; }
}
@media (max-width:768px) {
    .branches-dynamic-grid { grid-template-columns:1fr !important; }

    /* ── Compact mobile header ── */
    .site-header {
        padding:0 18px;
        min-height:62px;
        padding-top:8px;
        padding-bottom:8px;
    }
    .site-header.scrolled { min-height:56px; }
    .logo-img {
        max-height:44px !important;
        height:44px !important;
        width:auto !important;
        object-fit:contain;
    }
    .site-header.scrolled .logo-img { max-height:38px !important; }
    /* Put tagline inline next to logo on mobile */
    .logo { flex-direction:row; align-items:center; gap:9px; }
    .logo-tagline {
        font-size:.5rem;
        letter-spacing:2px;
        border-left:1px solid var(--gold-light);
        padding-left:9px;
        line-height:1.4;
        max-width:90px;
    }
    .main-nav { display:none; }
    .section { padding:60px 24px; }
    .rooms-grid, .testimonials-grid, .amenities-grid { grid-template-columns:1fr; }
    .footer-grid-v2 { grid-template-columns:1fr; gap:30px; }
    .footer-main { padding:50px 24px 40px; }
    .footer-bottom-inner { flex-direction:column; text-align:center; padding:16px 24px; }
    .footer-newsletter { padding:32px 24px; }
    .footer-newsletter-inner { flex-direction:column; }
    .newsletter-form { width:100%; }
    .booking-card { padding:28px 20px; }
    .bk-grid-2 { grid-template-columns:1fr; }
    .step-indicator { gap:4px; }
    .step-line { min-width:20px; }
    .contact-quick-inner { grid-template-columns:1fr 1fr; }
    .gallery-thumbs { grid-template-columns:repeat(4,1fr); }
    .detail-amenities-grid { grid-template-columns:1fr; }
    .room-quick-facts { grid-template-columns:repeat(2,1fr); }
    .breadcrumb-bar { padding:12px 24px; }
    .detail-section { padding:30px 20px; }
    .booking-banner { padding:50px 24px; }
    .contact-quick-bar { padding:0 24px; }
    .success-summary { grid-template-columns:1fr; }
    .success-body { padding:32px 24px 28px; }
    .success-contact { margin:0 -24px -28px; }
    .auth-box { padding:40px 28px; }
    .auth-box--wide { max-width:96vw; }
    .auth-row { grid-template-columns:1fr; }

    /* ── Fix hardcoded margin-top:90px on page heroes ── */
    .page-hero { margin-top: 62px !important; }
    .invoice-page-wrap { margin-top: 62px !important; }

    /* ── Room detail page ── */
    .gallery-main { height: 300px; }
    .gallery-thumbs { grid-template-columns: repeat(3,1fr); }
    .room-quick-facts { grid-template-columns: repeat(3,1fr); }
    .detail-sidebar { position:static; }

    /* ── Blog: override inline padding-top:110px ── */
    .section[style*="padding-top"] { padding-top: 80px !important; }

    /* ── Profile / Account nav — scrollable tabs ── */
    .account-nav { overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; }
    .acc-nav-item { padding: 12px 16px; font-size: .68rem; flex-shrink: 0; }
}

/* ── 480px: Small phones ── */
@media (max-width:480px) {
    /* Header */
    .site-header { padding:0 14px; min-height:56px; }
    .logo-img { max-height:38px !important; height:38px !important; }
    .logo-tagline { display:none; }
    .site-header.scrolled { min-height:50px; }

    /* Page hero margin */
    .page-hero { margin-top: 56px !important; }
    .invoice-page-wrap { margin-top: 56px !important; }

    /* Room detail gallery */
    .gallery-main { height: 240px; }
    .gallery-thumbs { grid-template-columns: repeat(2,1fr); }
    .gallery-thumb { height: 70px; }
    .room-quick-facts { grid-template-columns: repeat(2,1fr); }

    /* Contact quick inner — single column */
    .contact-quick-inner { grid-template-columns: 1fr; }

    /* Section inner — tighter */
    .section { padding: 48px 16px; }
    .section-inner { padding: 0; }

    /* Booking card — tighter */
    .booking-card { padding: 22px 16px; }

    /* Buttons full-width on tiny screens */
    .bk-actions { flex-direction: column; gap: 10px; }
    .bk-actions .btn-submit,
    .bk-actions .btn-back { width: 100%; text-align: center; padding: 14px 20px; }

    /* Auth boxes */
    .auth-box { padding: 28px 18px; }

    /* Profile stats: 2-col on small phones */
    .profile-stats { grid-template-columns: repeat(2,1fr); }
    .aff-stats-row { grid-template-columns: repeat(2,1fr); }
}

/* ══ ─────────────────────────────────── ══ */
/* ══  NAV — HAMBURGER & MOBILE DRAWER     ══ */
/* ══ ─────────────────────────────────── ══ */
.nav-burger { display:none; flex-direction:column; justify-content:center; gap:5px; background:none; border:none; cursor:pointer; padding:6px; width:36px; height:36px; z-index:1001; }
.nav-burger span { display:block; width:22px; height:2px; background:var(--brown-dark); border-radius:2px; transition:transform .3s, opacity .3s; }
.nav-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity:0; }
.nav-burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-nav-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:1100; }
.mobile-nav-overlay.open { display:block; }

.mobile-nav { position:fixed; top:0; right:-100%; width:min(320px,85vw); height:100%; background:#fff; z-index:1200; display:flex; flex-direction:column; box-shadow:-4px 0 24px rgba(92,61,46,.15); transition:right .3s cubic-bezier(.4,0,.2,1); }
.mobile-nav.open { right:0; }

.mobile-nav-header { display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--border); }
.mobile-nav-close { background:none; border:none; cursor:pointer; padding:6px; color:var(--text-mid); border-radius:50%; transition:background .2s; }
.mobile-nav-close:hover { background:var(--cream); }

.mobile-nav-links { flex:1; overflow-y:auto; padding:12px 0; display:flex; flex-direction:column; }
.mobile-nav-links a { display:block; padding:14px 24px; font-size:.85rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-mid); border-bottom:1px solid var(--border); transition:background .15s, color .15s; }
.mobile-nav-links a:hover, .mobile-nav-links a.active { background:var(--cream); color:var(--brown-dark); }

.mobile-nav-footer { padding:20px; border-top:1px solid var(--border); }

@media (max-width:860px) {
    .nav-burger { display:flex; }
}
@media (max-width:768px) {
    .nav-burger { display:flex; }
}

/* ══ ─────────────────────────────────── ══ */
/* ══  NAV — LOGIN LINK & USER MENU        ══ */
/* ══ ─────────────────────────────────── ══ */
.nav-login-link { font-size:.8rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-mid); position:relative; padding-bottom:4px; }
.nav-login-link::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1px; background:var(--gold); transition:width .3s; }
.nav-login-link:hover, .nav-login-link.active { color:var(--brown-dark); }
.nav-login-link:hover::after, .nav-login-link.active::after { width:100%; }

.user-menu-wrap { position:relative; }
.user-menu-btn { display:flex; align-items:center; gap:8px; background:none; border:none; cursor:pointer; padding:6px 10px; border:1px solid var(--border); transition:border-color .3s; }
.user-menu-btn:hover { border-color:var(--gold); }
.user-avatar { width:28px; height:28px; border-radius:50%; background:var(--brown-dark); color:#fff; font-size:.75rem; font-weight:600; display:flex; align-items:center; justify-content:center; font-family:'Be Vietnam Pro',sans-serif; flex-shrink:0; }
.user-name-short { font-size:.78rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-mid); }
.user-menu-btn svg { color:var(--text-light); transition:transform .3s; }
.user-dropdown { position:absolute; top:calc(100% + 10px); right:0; min-width:200px; background:#fff; border:1px solid var(--border); box-shadow:0 8px 32px rgba(92,61,46,.12); z-index:1000; display:none; flex-direction:column; }
.user-dropdown.open { display:flex; }
.user-dropdown-header { padding:16px 18px 12px; border-bottom:1px solid var(--border); }
.ud-name  { display:block; font-size:.88rem; font-weight:600; color:var(--text-dark); margin-bottom:3px; }
.ud-email { display:block; font-size:.75rem; color:var(--text-light); }
.ud-item  { padding:12px 18px; font-size:.8rem; letter-spacing:1px; text-transform:uppercase; color:var(--text-mid); transition:background .2s, color .2s; border-bottom:1px solid var(--border); }
.ud-item:last-child { border-bottom:none; }
.ud-item:hover { background:var(--cream); color:var(--brown-dark); }
.ud-logout { color:var(--text-light); }
.ud-logout:hover { color:#c0392b; background:#fff5f5; }

/* ══ ─────────────────────────────── ══ */
/* ══  WISHLIST HEART BUTTON            ══ */
/* ══ ─────────────────────────────── ══ */
.wishlist-btn {
    position:absolute; top:12px; left:12px; z-index:4;
    width:34px; height:34px; border-radius:50%;
    background:rgba(255,255,255,.85); border:none; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    color:#b45309; box-shadow:0 2px 8px rgba(0,0,0,.18);
    transition:transform .2s, background .2s, box-shadow .2s;
    opacity:0; pointer-events:none;
    padding:0;
}
.wishlist-btn svg { width:16px; height:16px; transition:transform .25s, fill .2s; }
.room-card:hover .wishlist-btn, .wishlist-btn.active { opacity:1; pointer-events:auto; }
.wishlist-btn:hover { transform:scale(1.1); background:#fff; box-shadow:0 4px 14px rgba(0,0,0,.22); }
.wishlist-btn.active { opacity:1; pointer-events:auto; background:#fff; }
.wishlist-btn.active svg { fill:#c0392b; stroke:#c0392b; transform:scale(1.1); }
.wishlist-btn.wl-pop svg { animation:wl-pop .35s cubic-bezier(.36,.07,.19,.97); }
@keyframes wl-pop { 0%{transform:scale(1)} 40%{transform:scale(1.45)} 70%{transform:scale(.88)} 100%{transform:scale(1.1)} }

/* Detail page variant — always visible, has label */
.wishlist-btn--detail {
    opacity:1; pointer-events:auto;
    width:auto; height:36px; border-radius:18px;
    padding:0 14px 0 10px; gap:6px; flex-direction:row;
    top:16px; left:auto; right:16px;
    font-size:.72rem; font-weight:600; letter-spacing:.5px; color:#7c3b1e;
}
.wishlist-btn--detail svg { width:15px; height:15px; }
.wishlist-btn--detail.active { background:#fff3ee; color:#c0392b; }
.wishlist-btn--detail.active svg { fill:#c0392b; stroke:#c0392b; }
.wl-btn-label { white-space:nowrap; }

/* ── Profile wishlist section ── */
.acc-nav-badge {
    display:inline-flex; align-items:center; justify-content:center;
    background:var(--gold); color:#fff; font-size:.6rem; font-weight:700;
    width:16px; height:16px; border-radius:50%; margin-left:5px; vertical-align:middle;
}
.wl-empty {
    text-align:center; padding:40px 20px; color:var(--text-light);
}
.wl-empty svg { display:block; margin:0 auto 14px; opacity:.3; }
.wl-empty p { font-size:.88rem; margin-bottom:16px; }
.wl-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.wl-card { border:1px solid var(--border); background:#fff; border-radius:4px; overflow:hidden; transition:box-shadow .2s; }
.wl-card:hover { box-shadow:0 6px 24px rgba(92,61,46,.1); }
.wl-card-img { display:block; position:relative; height:160px; overflow:hidden; }
.wl-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.wl-card:hover .wl-card-img img { transform:scale(1.04); }
.wl-badge { position:absolute; top:10px; left:10px; background:var(--gold); color:var(--text-dark); font-size:.6rem; letter-spacing:1.5px; text-transform:uppercase; padding:3px 9px; font-weight:700; }
.wl-card-body { padding:14px 16px; }
.wl-type { font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:4px; }
.wl-name { font-family:'Playfair Display',serif; font-size:1rem; color:var(--brown-dark); font-weight:500; text-decoration:none; display:block; margin-bottom:5px; }
.wl-name:hover { color:var(--gold); }
.wl-specs { font-size:.75rem; color:var(--text-light); margin-bottom:12px; }
.wl-footer { display:flex; align-items:center; justify-content:space-between; }
.wl-price span { font-size:1rem; font-weight:700; color:var(--brown-dark); font-family:'Playfair Display',serif; }
.wl-price small { font-size:.7rem; color:var(--text-light); margin-left:3px; }
.wl-remove-btn {
    width:28px; height:28px; border-radius:50%; border:1px solid var(--border);
    background:none; cursor:pointer; display:flex; align-items:center; justify-content:center;
    color:var(--text-light); transition:border-color .2s, color .2s;
}
.wl-remove-btn:hover { border-color:#ef4444; color:#ef4444; }
@media (max-width:640px) { .wl-grid { grid-template-columns:1fr; } }

/* ══ ─────────────────────────────────── ══ */
/* ══  AUTH PAGES (ĐĂNG NHẬP / ĐĂNG KÝ)   ══ */
/* ══ ─────────────────────────────────── ══ */
.auth-page { min-height:calc(100vh - 90px); margin-top:90px; display:flex; align-items:center; justify-content:center; padding:40px 20px; position:relative; }
.auth-bg { position:absolute; inset:0; z-index:0; }
.auth-bg::before { content:''; position:absolute; inset:0; background:url('/assets/images/phong-vip.jpg') center 35%/cover no-repeat; }
.auth-overlay { position:absolute; inset:0; background:rgba(26,15,10,.62); backdrop-filter:blur(3px); }
.auth-box { position:relative; z-index:2; background:rgba(255,255,255,.97); padding:52px 48px; width:100%; max-width:480px; box-shadow:0 32px 80px rgba(0,0,0,.32); border-radius:3px; }
.auth-box--wide { max-width:680px; }
.auth-logo { display:flex; flex-direction:column; line-height:1; margin-bottom:0; text-align:center; align-items:center; }
.auth-logo .logo-name    { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:600; color:var(--brown-dark); letter-spacing:2px; text-transform:uppercase; }
.auth-logo .logo-tagline { font-size:.6rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); font-weight:300; margin-top:6px; }
.auth-logo-img { display:block; margin:0 auto; }
.auth-divider { width:40px; height:1px; background:var(--gold); margin:20px auto; }
.auth-title { font-family:'Playfair Display',serif; font-size:1.8rem; color:var(--brown-dark); text-align:center; margin-bottom:8px; font-weight:500; }
.auth-sub   { font-size:.85rem; color:var(--text-light); text-align:center; margin-bottom:28px; font-weight:300; }
.auth-error { background:#fff5f5; border:1px solid #fca5a5; color:#b91c1c; padding:12px 16px; font-size:.83rem; margin-bottom:20px; }
.auth-form  { display:flex; flex-direction:column; gap:18px; }
.auth-row   { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.auth-field { display:flex; flex-direction:column; gap:6px; }
.auth-field label { font-size:.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-mid); font-weight:500; }
.auth-field input { border:1px solid var(--border); background:var(--cream); padding:12px 14px; font-size:.9rem; font-family:'Be Vietnam Pro',sans-serif; color:var(--text-dark); outline:none; transition:border-color .25s; }
.auth-field input:focus { border-color:var(--gold); background:#fff; }
.auth-btn   { margin-top:6px; width:100%; padding:15px; font-size:.78rem; letter-spacing:3px; }
.auth-switch { text-align:center; font-size:.82rem; color:var(--text-light); margin-top:22px; }
.auth-switch a { color:var(--gold); font-weight:500; }
.auth-switch a:hover { color:var(--brown-dark); }
/* Social login separator */
.auth-sep { display:flex; align-items:center; gap:14px; margin:22px 0 18px; }
.auth-sep::before,.auth-sep::after { content:''; flex:1; height:1px; background:var(--border); }
.auth-sep span { font-size:.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); white-space:nowrap; }
/* Social login buttons */
.auth-social { display:flex; flex-direction:column; gap:10px; }
.auth-social-btn { display:flex; align-items:center; justify-content:center; gap:10px; padding:12px 20px; border:1px solid var(--border); background:#fff; color:var(--text-dark); font-size:.82rem; font-weight:500; font-family:'Be Vietnam Pro',sans-serif; cursor:pointer; transition:all .22s; text-decoration:none; width:100%; letter-spacing:.3px; }
.auth-social-btn:hover { border-color:var(--gold); background:var(--cream); box-shadow:0 2px 10px rgba(0,0,0,.08); }
.auth-social-btn svg { flex-shrink:0; }

/* ══ ─────────────────────────────────── ══ */
/* ══  BOOKING SUCCESS — new check icon    ══ */
/* ══ ─────────────────────────────────── ══ */
.success-check { width:80px; height:80px; border-radius:50%; background:rgba(201,169,110,.12); border:2px solid var(--gold); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; color:var(--gold); }

/* ══ ─────────────────────────────────── ══ */
/* ══  ACCOUNT NAV                         ══ */
/* ══ ─────────────────────────────────── ══ */
.account-nav { display:flex; gap:0; border-bottom:2px solid var(--border); margin-bottom:40px; }
.acc-nav-item { font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); padding:14px 24px; border-bottom:2px solid transparent; margin-bottom:-2px; transition:all .2s; }
.acc-nav-item:hover { color:var(--brown-dark); }
.acc-nav-item.active { color:var(--brown-dark); border-bottom-color:var(--gold); font-weight:500; }

/* ══ ─────────────────────────────────── ══ */
/* ══  BOOKING HISTORY                     ══ */
/* ══ ─────────────────────────────────── ══ */
.empty-state { text-align:center; padding:80px 40px; background:#fff; border:1px solid var(--border); }
.empty-icon { color:var(--gold); display:flex; justify-content:center; margin-bottom:20px; }
.empty-state h3 { font-family:'Playfair Display',serif; font-size:1.5rem; color:var(--brown-dark); margin-bottom:10px; }
.empty-state p  { font-size:.88rem; color:var(--text-light); max-width:400px; margin:0 auto; line-height:1.7; }

.history-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.count-badge { display:inline-flex; align-items:center; justify-content:center; background:var(--gold); color:var(--text-dark); font-size:.68rem; font-weight:700; width:24px; height:24px; border-radius:50%; margin-left:10px; vertical-align:middle; }

.booking-history-list { display:flex; flex-direction:column; gap:16px; }
.bh-card { background:#fff; border:1px solid var(--border); display:flex; overflow:hidden; transition:box-shadow .3s; }
.bh-card:hover { box-shadow:0 6px 24px rgba(92,61,46,.1); }
.bh-left { flex-shrink:0; width:140px; }
.bh-img  { width:100%; height:100%; object-fit:cover; display:block; }
.bh-body { flex:1; padding:22px 24px; display:flex; flex-direction:column; gap:14px; }
.bh-top  { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; }
.bh-code { font-size:.65rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:4px; font-family:monospace; }
.bh-room { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--brown-dark); font-weight:500; }

.booking-status { flex-shrink:0; font-size:.65rem; letter-spacing:2px; text-transform:uppercase; padding:4px 12px; font-weight:600; }
.status-confirmed { background:rgba(201,169,110,.12); color:#8B6048; border:1px solid rgba(201,169,110,.4); }
.status-completed { background:rgba(22,163,74,.08); color:#166534; border:1px solid rgba(134,239,172,.6); }
.status-cancelled { background:rgba(239,68,68,.08); color:#b91c1c; border:1px solid rgba(252,165,165,.6); }

.bh-dates { display:flex; align-items:center; gap:16px; }
.bh-date-item { display:flex; flex-direction:column; gap:2px; }
.bh-date-label { font-size:.65rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); }
.bh-date-item strong { font-size:.92rem; color:var(--text-dark); }
.bh-date-time { font-size:.72rem; color:var(--text-light); }
.bh-date-arrow { display:flex; flex-direction:column; align-items:center; gap:2px; color:var(--gold); }
.bh-date-arrow span { font-size:.65rem; color:var(--text-light); letter-spacing:1px; }
.bh-footer { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--border); }
.bh-meta { display:flex; gap:8px; align-items:center; font-size:.78rem; color:var(--text-light); }
.bh-price { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--brown-dark); font-weight:500; }

/* ══ ─────────────────────────────────── ══ */
/* ══  PROFILE PAGE                        ══ */
/* ══ ─────────────────────────────────── ══ */
.profile-layout { display:grid; grid-template-columns:280px 1fr; gap:36px; align-items:start; }
.profile-sidebar { display:flex; flex-direction:column; gap:20px; position:sticky; top:100px; }
@media (max-width:860px) { .profile-sidebar { top:80px; } }
@media (max-width:768px) { .profile-sidebar { top:70px; position:static; } }

.member-card { background:var(--footer-bg); padding:32px 24px; text-align:center; }
.mc-avatar-wrap { position:relative; width:80px; height:80px; margin:0 auto 16px; cursor:pointer; }
.mc-avatar {
    width:80px; height:80px; border-radius:50%;
    background:var(--gold); color:var(--text-dark);
    font-family:'Playfair Display',serif; font-size:2rem; font-weight:600;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden; border:3px solid rgba(201,169,110,.35);
    transition:border-color .2s;
}
.mc-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.mc-avatar-overlay {
    position:absolute; inset:0; border-radius:50%;
    background:rgba(40,22,10,.52); display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:3px;
    opacity:0; transition:opacity .22s; pointer-events:none;
}
.mc-avatar-wrap:hover .mc-avatar-overlay { opacity:1; }
.mc-avatar-wrap:hover .mc-avatar { border-color:var(--gold); }
.mc-avatar-overlay svg { color:#fff; }
.mc-avatar-overlay span { font-size:.6rem; letter-spacing:1px; text-transform:uppercase; color:#fff; font-weight:600; }
.mc-avatar-uploading .mc-avatar-overlay { opacity:1; }
.mc-avatar-spinner { width:20px; height:20px; border:2px solid rgba(255,255,255,.3); border-top-color:#fff; border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }
.mc-name   { font-family:'Playfair Display',serif; font-size:1.2rem; color:#fff; margin-bottom:4px; }
.mc-email  { font-size:.78rem; color:rgba(255,255,255,.4); margin-bottom:12px; }
.mc-level  { font-size:.68rem; letter-spacing:3px; text-transform:uppercase; font-weight:700; margin-bottom:4px; }
.mc-since  { font-size:.72rem; color:rgba(255,255,255,.3); }

.profile-stats { background:#fff; border:1px solid var(--border); display:grid; grid-template-columns:repeat(3,1fr); }
.pstat { padding:18px 12px; text-align:center; border-right:1px solid var(--border); }
.pstat:last-child { border-right:none; }
.pstat strong { display:block; font-family:'Playfair Display',serif; font-size:1.3rem; color:var(--brown-dark); }
.pstat span   { display:block; font-size:.62rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); margin-top:3px; }

.sidebar-links { display:flex; flex-direction:column; background:#fff; border:1px solid var(--border); overflow:hidden; }
.sidebar-links a { padding:12px 18px; font-size:.78rem; color:var(--text-mid); border-bottom:1px solid var(--border); transition:all .2s; letter-spacing:.5px; }
.sidebar-links a:last-child { border-bottom:none; }
.sidebar-links a:hover { background:var(--cream); color:var(--brown-dark); }
.logout-link { color:var(--text-light)!important; }
.logout-link:hover { color:#c0392b!important; background:#fff5f5!important; }

.profile-main { display:flex; flex-direction:column; gap:24px; }
.profile-card { background:#fff; border:1px solid var(--border); padding:32px 36px; }
.profile-card-title { font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--brown-dark); margin-bottom:22px; padding-bottom:14px; border-bottom:1px solid var(--border); }

/* Affiliate */
.affiliate-header { display:flex; align-items:flex-start; justify-content:space-between; gap:20px; margin-bottom:24px; }
.aff-badge { flex-shrink:0; background:var(--gold); color:var(--text-dark); font-size:.65rem; letter-spacing:2px; font-weight:700; padding:6px 14px; align-self:flex-start; }

.aff-stats-row { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); margin-bottom:24px; }
.aff-stat { background:#fff; padding:20px; text-align:center; }
.aff-stat--gold { background:rgba(201,169,110,.06); }
.aff-stat strong { display:block; font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--brown-dark); }
.aff-stat span   { display:block; font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); margin-top:4px; }

.aff-link-box { background:var(--cream); border:1px solid var(--border); padding:20px 24px; margin-bottom:24px; }
.aff-link-label { font-size:.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:8px; }
.aff-code-row { display:flex; align-items:center; gap:12px; }
.aff-code { font-family:monospace; font-size:1.4rem; font-weight:700; color:var(--brown-dark); letter-spacing:4px; background:#fff; border:1px solid var(--border); padding:8px 16px; }
.aff-url-row { display:flex; gap:0; }
.aff-url-input { flex:1; border:1px solid var(--border); background:#fff; padding:10px 14px; font-size:.78rem; color:var(--text-mid); outline:none; font-family:'Be Vietnam Pro',sans-serif; }
.aff-copy-btn { background:var(--brown-dark); color:#fff; border:none; padding:10px 20px; font-size:.72rem; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:background .2s; font-family:'Be Vietnam Pro',sans-serif; white-space:nowrap; }
.aff-copy-btn:hover { background:var(--gold); color:var(--text-dark); }

.aff-how { display:flex; flex-direction:column; gap:12px; }
.aff-step { display:flex; gap:14px; align-items:flex-start; }
.aff-step-num { flex-shrink:0; width:28px; height:28px; border-radius:50%; background:var(--brown-dark); color:#fff; font-size:.75rem; font-weight:700; display:flex; align-items:center; justify-content:center; }
.aff-step-text { font-size:.85rem; color:var(--text-mid); line-height:1.6; padding-top:4px; }

@media (max-width: 900px) {
    .profile-layout { grid-template-columns:1fr; }
    .profile-sidebar { position:static; }
    .aff-stats-row { grid-template-columns:repeat(3,1fr); }
}

/* ══ ─────────────────────────────────── ══ */
/* ══  PROFILE – MOBILE REDESIGN           ══ */
/* ══ ─────────────────────────────────── ══ */
@media (max-width: 768px) {
    /* ── Page hero — shorter on mobile ── */
    .profile-section-wrap ~ * { }
    .page-hero { height: 160px !important; }
    .page-hero-content .section-title { font-size: 1.7rem !important; }
    .page-hero-content .section-label { font-size: .58rem !important; margin-bottom: 8px !important; }

    /* ── Section wrapper ── */
    .profile-section-wrap { padding: 20px 14px 52px !important; }

    /* ── Layout gap ── */
    .profile-layout { gap: 16px; }
    .profile-sidebar { gap: 12px; }

    /* ── Account nav — pill tabs, scrollable ── */
    .account-nav {
        gap: 0; margin-bottom: 18px;
        border-bottom: none; background: #fff;
        border: 1px solid var(--border); border-radius: 10px;
        padding: 4px; overflow-x: auto; white-space: nowrap;
        -webkit-overflow-scrolling: touch; flex-wrap: nowrap;
        box-shadow: 0 2px 10px rgba(92,61,46,.08);
    }
    .acc-nav-item {
        border-radius: 7px; padding: 10px 16px;
        font-size: .65rem; letter-spacing: 1px;
        color: var(--text-mid); transition: background .2s, color .2s;
        flex-shrink: 0; white-space: nowrap;
    }
    .acc-nav-item.active { background: var(--brown-dark); color: #fff; box-shadow: 0 2px 8px rgba(92,61,46,.25); }
    .acc-nav-item:hover:not(.active) { background: rgba(92,61,46,.07); }

    /* ── Member card — rounded, compact horizontal, gold top accent ── */
    .member-card {
        padding: 18px 18px 18px 18px;
        text-align: left;
        display: flex; align-items: center; gap: 14px;
        border-radius: 12px;
        box-shadow: 0 4px 20px rgba(40,22,10,.22);
        border-top: 3px solid var(--gold);
        position: relative; overflow: hidden;
    }
    /* subtle decorative ring on right */
    .member-card::after {
        content: '';
        position: absolute; right: -28px; top: 50%; transform: translateY(-50%);
        width: 100px; height: 100px;
        border-radius: 50%;
        border: 18px solid rgba(201,169,110,.1);
        pointer-events: none;
    }
    .mc-avatar-wrap { margin: 0; flex-shrink: 0; width: 64px; height: 64px; }
    .mc-avatar { width: 64px; height: 64px; font-size: 1.5rem; }
    .mc-info { flex: 1; min-width: 0; }
    .mc-name { font-size: 1.05rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 2px; }
    .mc-email { font-size: .7rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 6px; opacity: .55; }
    .mc-level { font-size: .58rem; margin-bottom: 2px; }
    .mc-since { font-size: .62rem; }

    /* ── Stats — 2×2 rounded card ── */
    .profile-stats {
        grid-template-columns: repeat(2, 1fr);
        border-radius: 10px; overflow: hidden;
        box-shadow: 0 2px 10px rgba(92,61,46,.07);
    }
    .pstat { padding: 16px 10px; position: relative; }
    .pstat strong { font-size: 1.15rem; }
    .pstat span { font-size: .6rem; letter-spacing: 1.2px; }
    /* gold dot accent above number */
    .pstat::before {
        content: '';
        display: block; width: 4px; height: 4px;
        border-radius: 50%; background: var(--gold);
        margin: 0 auto 6px; opacity: .7;
    }
    .pstat:nth-child(2) { border-right: none; }
    .pstat:nth-child(3) { border-top: 1px solid var(--border); }
    .pstat:nth-child(4) { border-top: 1px solid var(--border); border-right: none; }

    /* ── Sidebar links — horizontal scrollable, rounded ── */
    .sidebar-links {
        flex-direction: row; overflow-x: auto;
        -webkit-overflow-scrolling: touch; flex-wrap: nowrap;
        border-radius: 10px;
        box-shadow: 0 2px 8px rgba(92,61,46,.06);
    }
    .sidebar-links a {
        white-space: nowrap; border-bottom: none;
        border-right: 1px solid var(--border);
        flex-shrink: 0; font-size: .7rem; padding: 12px 16px;
    }
    .sidebar-links a:first-child { border-radius: 10px 0 0 10px; }
    .sidebar-links a:last-child { border-right: none; border-radius: 0 10px 10px 0; }

    /* ── Profile cards — rounded with shadow ── */
    .profile-card {
        padding: 20px 18px; margin-bottom: 0;
        border-radius: 12px;
        box-shadow: 0 2px 12px rgba(92,61,46,.07);
        border: 1px solid rgba(212,201,184,.6);
    }
    .profile-card-title {
        font-size: 1rem; margin-bottom: 16px; padding-bottom: 10px;
        padding-left: 12px; border-left: 3px solid var(--gold);
    }
    .profile-main { gap: 14px; }

    /* ── Form fields — single column, rounded inputs ── */
    .auth-row { grid-template-columns: 1fr !important; gap: 14px; }
    .auth-field input {
        font-size: .88rem; padding: 13px 14px;
        border-radius: 8px;
        border-color: rgba(212,201,184,.8);
    }
    .auth-field input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(201,169,110,.12); }
    .auth-field label { font-size: .65rem; }

    /* ── Submit button — full width, rounded ── */
    .profile-card [type=submit] {
        width: 100%; text-align: center; justify-content: center;
        padding: 14px 20px; border-radius: 8px;
        font-size: .78rem;
    }

    /* ── Affiliate header — stack ── */
    .affiliate-header { flex-direction: column; gap: 8px; margin-bottom: 16px; }
    .affiliate-header p { font-size: .8rem; margin-top: 4px; }
    .aff-badge { align-self: flex-start; font-size: .6rem; border-radius: 4px; }

    /* ── Affiliate stats — 1 column, row layout ── */
    .aff-stats-row { grid-template-columns: 1fr; gap: 1px; margin-bottom: 16px; border-radius: 8px; overflow: hidden; }
    .aff-stat { padding: 14px 16px; display: flex; align-items: center; justify-content: space-between; text-align: left; flex-direction: row-reverse; gap: 12px; }
    .aff-stat strong { font-size: 1.25rem; }
    .aff-stat span { font-size: .65rem; letter-spacing: 1px; }

    /* ── Affiliate link box — rounded ── */
    .aff-link-box { padding: 14px 16px; margin-bottom: 16px; border-radius: 8px; }
    .aff-url-row { flex-direction: column; gap: 8px; }
    .aff-url-input { width: 100%; box-sizing: border-box; font-size: .76rem; border-radius: 6px; }
    .aff-copy-btn { width: 100%; padding: 13px 20px; text-align: center; border-radius: 6px; }
    .aff-code { font-size: 1.1rem; letter-spacing: 3px; padding: 6px 14px; border-radius: 4px; }
    .aff-step-text { font-size: .8rem; }

    /* ── Wishlist cards — 1 column, rounded ── */
    .wl-grid { grid-template-columns: 1fr; gap: 12px; }
    .wl-card { border-radius: 10px; box-shadow: 0 2px 10px rgba(92,61,46,.07); }
    .wl-card-img { height: 190px; border-radius: 10px 10px 0 0; }
    .wl-footer { flex-wrap: wrap; gap: 8px; }
}

/* ── Small phones (≤420px) extra tweaks ── */
@media (max-width: 420px) {
    .page-hero { height: 140px !important; }
    .page-hero-content .section-title { font-size: 1.5rem !important; }
    .profile-section-wrap { padding: 16px 10px 44px !important; }
    .account-nav { padding: 3px; border-radius: 8px; }
    .acc-nav-item { padding: 9px 12px; font-size: .61rem; }
    .member-card { padding: 14px; gap: 12px; border-radius: 10px; }
    .mc-avatar-wrap { width: 56px; height: 56px; }
    .mc-avatar { width: 56px; height: 56px; font-size: 1.3rem; }
    .mc-name { font-size: .95rem; }
    .profile-card { padding: 16px 14px; border-radius: 10px; }
    .pstat { padding: 13px 8px; }
    .pstat strong { font-size: 1rem; }
    .profile-main { gap: 12px; }
}

/* ══ ─────────────────────────────────── ══ */
/* ══  DROPDOWN EXTRAS                     ══ */
/* ══ ─────────────────────────────────── ══ */
.ud-item { display:flex; align-items:center; gap:8px; }
.ud-item svg { flex-shrink:0; opacity:.55; }
.ud-admin { color:var(--gold)!important; }
.ud-admin svg { opacity:.8; }
.ud-admin-badge { display:inline-block; font-size:.55rem; letter-spacing:2px; text-transform:uppercase; font-weight:700; background:var(--gold); color:#1A0F0A; padding:2px 8px; margin-top:4px; }
.user-avatar--admin { background:var(--gold)!important; color:#1A0F0A!important; }

/* ══ ─────────────────────────────────── ══ */
/* ══  BOOKING HISTORY v2                  ══ */
/* ══ ─────────────────────────────────── ══ */
.bh-empty { text-align:center; padding:80px 40px; background:#fff; border:1px solid var(--border); }
.bh-empty-icon { color:var(--gold); display:flex; justify-content:center; margin-bottom:20px; }
.bh-empty h3 { font-family:'Playfair Display',serif; font-size:1.5rem; color:var(--brown-dark); margin-bottom:10px; }
.bh-empty p  { font-size:.88rem; color:var(--text-light); max-width:420px; margin:0 auto; line-height:1.7; }

.bh-list-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:24px; gap:16px; }
.bh-list-title { font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--brown-dark); margin:0 0 4px; }
.bh-list-sub { font-size:.78rem; color:var(--text-light); margin:0; letter-spacing:.5px; }
.bh-new-btn { display:inline-flex; align-items:center; gap:8px; background:var(--brown-dark); color:#fff; padding:11px 22px; font-size:.7rem; letter-spacing:2px; text-transform:uppercase; font-weight:500; transition:background .2s; white-space:nowrap; }
.bh-new-btn:hover { background:var(--gold); color:var(--text-dark); }

.bh-list { display:flex; flex-direction:column; gap:20px; }

.bh-item { background:#fff; border:1px solid var(--border); overflow:hidden; transition:box-shadow .3s; }
.bh-item:hover { box-shadow:0 8px 32px rgba(92,61,46,.1); }
.bh-item--past { opacity:.82; }

/* Ribbon */
.bh-ribbon { background:var(--footer-bg); padding:12px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.bh-ribbon-left, .bh-ribbon-right { display:flex; align-items:center; gap:12px; }
.bh-code-tag { font-family:monospace; font-size:.75rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); font-weight:600; }
.bh-now-badge { font-size:.6rem; letter-spacing:2px; text-transform:uppercase; background:var(--gold); color:#1A0F0A; padding:3px 10px; font-weight:700; }
.bh-date-booked { font-size:.68rem; color:rgba(255,255,255,.3); letter-spacing:.5px; }
.bh-status-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.bh-status-text { font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; font-weight:600; }
.status-confirmed { color:var(--gold); }
.status-completed { color:#4ade80; }
.status-cancelled { color:#f87171; }

/* Content grid */
.bh-content { display:grid; grid-template-columns:160px 1fr 1fr; }

/* Image column */
.bh-img-col { position:relative; overflow:hidden; }
.bh-img-col img { width:100%; height:100%; min-height:160px; object-fit:cover; display:block; transition:transform .4s; }
.bh-item:hover .bh-img-col img { transform:scale(1.04); }
.bh-room-label { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent, rgba(26,15,10,.85)); color:#fff; font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; padding:20px 12px 10px; font-weight:500; }

/* Dates column */
.bh-dates-col { display:flex; align-items:center; justify-content:center; gap:0; padding:28px 24px; border-right:1px solid var(--border); }
.bh-date-block { text-align:center; }
.bh-date-tag { font-size:.58rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:6px; font-weight:600; }
.bh-date-day { font-family:'Playfair Display',serif; font-size:2.6rem; color:var(--brown-dark); line-height:1; font-weight:400; }
.bh-date-mon { font-size:.7rem; color:var(--text-light); text-transform:uppercase; letter-spacing:1px; margin-top:2px; }
.bh-date-time-tag { font-size:.62rem; color:var(--gold); letter-spacing:1px; margin-top:6px; font-weight:500; }
.bh-nights-col { display:flex; flex-direction:column; align-items:center; gap:6px; padding:0 20px; }
.bh-night-line { width:1px; height:28px; background:var(--border); }
.bh-night-badge { font-size:.68rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-light); white-space:nowrap; background:var(--cream); border:1px solid var(--border); padding:4px 10px; }

/* Detail + price column */
.bh-detail-col { display:flex; flex-direction:column; justify-content:space-between; padding:28px 28px; }
.bh-detail-rows { display:flex; flex-direction:column; gap:10px; }
.bh-detail-row { display:flex; justify-content:space-between; align-items:center; font-size:.82rem; }
.bh-detail-row span { color:var(--text-light); }
.bh-detail-row strong { color:var(--text-dark); font-weight:500; }
.bh-price-block { display:flex; align-items:flex-end; justify-content:space-between; padding-top:16px; border-top:1px solid var(--border); margin-top:16px; }
.bh-price-amount { font-family:'Playfair Display',serif; font-size:1.7rem; color:var(--brown-dark); line-height:1; }
.bh-price-amount span { font-size:1rem; }
.bh-price-note { font-size:.68rem; color:var(--text-light); margin-top:4px; }
.bh-rebook-btn { display:inline-block; background:var(--cream); border:1px solid var(--border); color:var(--text-mid); font-size:.68rem; letter-spacing:2px; text-transform:uppercase; padding:9px 18px; transition:all .2s; font-weight:500; }
.bh-rebook-btn:hover { background:var(--brown-dark); color:#fff; border-color:var(--brown-dark); }

@media (max-width:900px) {
    .bh-content { grid-template-columns:1fr; }
    .bh-img-col { height:180px; }
    .bh-dates-col { border-right:none; border-bottom:1px solid var(--border); }
    .bh-list-header { flex-direction:column; align-items:flex-start; }
}

/* ── Booking history mobile ── */
@media (max-width:768px) {
    .bh-section-wrap { padding: 36px 16px 60px !important; }

    /* Account nav pill style (same as profile) */
    .bh-section-wrap .account-nav { gap:0; border-bottom:none; background:var(--cream); border:1px solid var(--border); border-radius:6px; padding:4px; overflow-x:auto; white-space:nowrap; -webkit-overflow-scrolling:touch; flex-wrap:nowrap; }
    .bh-section-wrap .acc-nav-item { border-radius:4px; padding:10px 14px; font-size:.67rem; letter-spacing:1px; color:var(--text-mid); transition:background .2s, color .2s; flex-shrink:0; white-space:nowrap; }
    .bh-section-wrap .acc-nav-item.active { background:var(--brown-dark); color:#fff; }

    /* List header */
    .bh-list-header { gap:12px; }
    .bh-new-btn { font-size:.65rem; padding:9px 16px; letter-spacing:1.5px; }

    /* Ribbon — allow wrapping on small screens */
    .bh-ribbon { padding:10px 14px; flex-wrap:wrap; gap:8px; }
    .bh-ribbon-left { gap:8px; }
    .bh-ribbon-right { gap:8px; }
    .bh-date-booked { font-size:.62rem; }

    /* Date block — tighter when stacked */
    .bh-dates-col { padding:20px 16px; flex-wrap:wrap; gap:8px; }
    .bh-date-day { font-size:2rem; }
    .bh-nights-col { padding:0 14px; }

    /* Detail col — tighter padding */
    .bh-detail-col { padding:20px 16px; }
}

@media (max-width:480px) {
    .bh-section-wrap { padding: 24px 12px 48px !important; }

    /* Ribbon — stack booking code and status */
    .bh-ribbon { padding:9px 12px; }
    .bh-code-tag { font-size:.68rem; letter-spacing:2px; }
    .bh-status-text { font-size:.62rem; letter-spacing:1px; }
    .bh-date-booked { display:none; }

    /* Dates — compact */
    .bh-dates-col { padding:16px 12px; }
    .bh-date-day { font-size:1.8rem; }
    .bh-date-tag { font-size:.54rem; }
    .bh-date-mon { font-size:.62rem; }
    .bh-nights-col { padding:0 10px; }
    .bh-night-badge { font-size:.6rem; padding:3px 8px; }

    /* Detail col */
    .bh-detail-col { padding:16px 14px; }
    .bh-detail-row { font-size:.78rem; }
    .bh-price-amount { font-size:1.4rem; }

    /* Price block — stack vertically, full-width rebook button */
    .bh-price-block { flex-direction:column; align-items:flex-start; gap:12px; padding-top:14px; margin-top:14px; }
    .bh-rebook-btn { width:100%; text-align:center; padding:11px 20px; font-size:.7rem; }

    /* Empty state */
    .bh-empty { padding:50px 20px; }
    .bh-empty h3 { font-size:1.2rem; }
}

/* ══ CMS Content Blocks ══ */
.cms-content {
    max-width: 800px;
    margin: 0 auto;
    color: var(--text-dark);
    line-height: 1.8;
    font-size: 1rem;
}
.cms-content h2 { font-family: 'Playfair Display', serif; font-size: 1.8rem; margin: 0 0 20px; color: var(--brown-dark); }
.cms-content h3 { font-family: 'Playfair Display', serif; font-size: 1.35rem; margin: 28px 0 14px; color: var(--brown-dark); }
.cms-content h4 { font-size: 1.05rem; margin: 20px 0 10px; font-weight: 600; color: var(--text-dark); }
.cms-content p  { margin: 0 0 16px; color: var(--text-mid); }
.cms-content hr { border: none; border-top: 1px solid var(--border); margin: 36px 0; }
.cms-content figure { margin: 28px 0; }
.cms-content figcaption { font-size: .78rem; color: var(--text-light); text-align: center; margin-top: 8px; }
.cms-content img { max-width: 100%; height: auto; display: block; }

/* CTA block */
.cms-cta {
    background: var(--cream);
    border: 1px solid var(--border);
    padding: 36px 40px;
    text-align: center;
    margin: 32px 0;
}
.cms-cta h3 { font-family: 'Playfair Display', serif; font-size: 1.5rem; color: var(--brown-dark); margin: 0 0 12px; }
.cms-cta p  { color: var(--text-mid); margin: 0 0 20px; }
.cms-cta .btn {
    display: inline-block;
    background: var(--brown-dark);
    color: #fff;
    padding: 12px 28px;
    text-decoration: none;
    font-size: .78rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 600;
    transition: background .2s;
}
.cms-cta .btn:hover { background: #4a3025; }

/* Two-column layout */
.cms-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin: 28px 0; }
.cms-col  { color: var(--text-mid); line-height: 1.8; }
@media (max-width: 680px) { .cms-cols { grid-template-columns: 1fr; gap: 20px; } }

/* Features grid */
.cms-features {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 20px;
    margin: 24px 0;
}
.cms-feature {
    background: var(--cream);
    border: 1px solid var(--border);
    padding: 20px 16px;
    text-align: center;
}
.cms-feature-icon { font-size: 1.6rem; margin-bottom: 8px; }
.cms-feature-name { font-weight: 600; font-size: .85rem; color: var(--brown-dark); }
.cms-feature-desc { font-size: .75rem; color: var(--text-light); margin-top: 4px; }

/* Empty state */
.cms-empty-notice {
    text-align: center;
    padding: 60px 0;
    color: var(--text-light);
}
.cms-empty-notice a { color: var(--gold); text-decoration: none; font-size: .85rem; }
.cms-empty-notice a:hover { text-decoration: underline; }

/* ══ SAFARI iOS / MOBILE FIXES ══ */
input, select, textarea, button, a {
    -webkit-tap-highlight-color: transparent;
}
/* Prevent iOS auto-zoom on input focus (font-size must be >= 16px) */
@media (max-width: 768px) {
    .form-group input,
    .form-group select,
    .form-group textarea,
    .bk-select {
        font-size: 16px !important;
    }
    /* Touch feedback on all interactive elements */
    .btn-submit, .btn-back, .btn-primary, .btn-outline,
    .btn-room, .btn-book-header, .cal-nav-btn, .cal-confirm-btn,
    .cal-clear-btn, .cal-trigger, .pay-tab {
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
    }
    /* Calendar dropdown scroll on iOS */
    .cal-drop {
        -webkit-overflow-scrolling: touch;
        overflow-y: auto;
        max-height: calc(100dvh - 180px);
    }
    /* Fix step indicator wrapping */
    .step-indicator { flex-wrap: wrap; row-gap: 8px; }
    /* Full-width submit on small screens already handled at 480px but ensure tappable size */
    .btn-submit { min-height: 50px; }
    .btn-back   { min-height: 50px; }
}
/* Fix iOS rendering of buttons (prevents native round pill style) */
.btn-submit, .btn-book-header, .btn-primary, .btn-back {
    -webkit-appearance: none;
}

/* ══════════════════════════════════════════════════════════
   BOOKING PAGE — RESPONSIVE FIXES
══════════════════════════════════════════════════════════ */
.bk-outer-section {
    padding: 60px 40px;
    background: var(--warm-white);
}
@media (max-width: 768px) {
    .bk-outer-section { padding: 40px 20px; }
}
@media (max-width: 480px) {
    .bk-outer-section { padding: 28px 14px; }
}

/* Step indicator — prevent text overflow on small phones */
@media (max-width: 480px) {
    .step-circle { width: 32px; height: 32px; font-size: .72rem; }
    .step-item span { font-size: .55rem; letter-spacing: 1px; }
    .step-line { min-width: 12px; margin: 0 4px; }
    .step-indicator { margin-bottom: 28px; }
}

/* Booking card title — scale down h2 on mobile */
@media (max-width: 768px) {
    .booking-card-title h2 { font-size: 1.5rem; }
    .booking-card-title { margin-bottom: 22px; }
}
@media (max-width: 480px) {
    .booking-card-title h2 { font-size: 1.25rem; }
}

/* Summary bar — stack on tiny screens */
@media (max-width: 480px) {
    .bk-summary-bar { flex-direction: column; align-items: flex-start; gap: 4px; padding: 12px 14px; }
    .bk-summary-bar .sum-total { margin-left: 0; font-size: 1rem; }
}

/* Credit card visual — prevent overflow on small phones */
@media (max-width: 480px) {
    .credit-card-visual { padding: 18px 16px 14px; height: auto; min-height: 140px; }
    .cv-number { font-size: .9rem; letter-spacing: 2px; }
    .cv-name { font-size: .65rem; letter-spacing: 1px; }
    .cv-chip { width: 32px; height: 24px; }
}

/* Pay tabs — compact letter-spacing on mobile */
@media (max-width: 480px) {
    .pay-tab { font-size: .65rem; letter-spacing: .5px; padding: 12px 6px; }
}

/* Order summary — tighter on mobile */
@media (max-width: 480px) {
    .order-summary { padding: 18px 14px; }
    .os-img { height: 100px; }
}

/* Transfer info — stack QR below text on mobile */
@media (max-width: 480px) {
    .transfer-info { padding: 18px 14px; }
    .transfer-info > div { flex-direction: column !important; }
}

/* ══════════════════════════════════════════════════════════
   BOOKING SUCCESS PAGE — RESPONSIVE FIXES
══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .success-top-band { padding: 20px 24px; }
    .success-top-band-hotel { font-size: .9rem; letter-spacing: 2px; }
    .booking-success h2 { font-size: 1.6rem; }
    .success-body { padding: 32px 20px 24px; }
    .success-code { font-size: 1.4rem; letter-spacing: 3px; }
    .success-code-wrap { padding: 18px 20px; }
    .success-contact { margin: 0 -20px -24px; }
}
@media (max-width: 480px) {
    .success-top-band { gap: 10px; }
    .success-top-band svg { display: none; }
    .booking-success h2 { font-size: 1.3rem; }
    .success-code { font-size: 1.15rem; letter-spacing: 2px; word-break: break-all; }
    .success-code-wrap { padding: 14px 14px; display: block; }
    .success-body { padding: 24px 16px 20px; }
    .success-contact { margin: 0 -16px -20px; }
    .success-ornament span { font-size: .52rem; letter-spacing: 2px; }
}

/* ══════════════════════════════════════════════════════════
   ROOM DETAIL SIDEBAR — RESPONSIVE FIXES
══════════════════════════════════════════════════════════ */
/* Date picker inside sidebar: stack on mobile */
@media (max-width: 640px) {
    .sbc-dates { grid-template-columns: 1fr; }
    .sbc-divider-v { display: none; }
    .sbc-field:first-child { border-bottom: 1px solid var(--border); }
    .sbc-field input { font-size: 16px; } /* prevent iOS zoom */
}

/* Prevent section-inner overflow on tiny phones */
@media (max-width: 480px) {
    .section-inner { overflow-x: hidden; }
}

/* ══ KHAI TRƯƠNG POPUP ══ */
#ktPopupOverlay {
    position: fixed; inset: 0; z-index: 19999;
    background: rgba(10, 5, 2, .72);
    display: flex; align-items: center; justify-content: center;
    padding: 20px; backdrop-filter: blur(3px);
    animation: ktFadeIn .35s ease both;
}
@keyframes ktFadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes ktSlideUp { from { opacity: 0; transform: translateY(24px) scale(.97) } to { opacity: 1; transform: none } }
#ktPopupCard {
    background: #fff; max-width: 460px; width: 100%;
    border-radius: 4px; overflow: hidden; position: relative;
    box-shadow: 0 24px 80px rgba(0,0,0,.45);
    animation: ktSlideUp .4s .1s cubic-bezier(.22,.68,0,1.2) both;
}
.kt-top-band {
    background: linear-gradient(135deg, var(--brown-dark) 0%, #3d1a08 100%);
    padding: 18px 24px 16px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
}
.kt-top-ornament {
    width: 40px; height: 1px; background: rgba(201,169,110,.5);
}
.kt-top-label {
    font-size: .6rem; letter-spacing: 4px; text-transform: uppercase;
    color: var(--gold); font-weight: 600; white-space: nowrap;
}
.kt-body { padding: 28px 32px 24px; text-align: center; }
.kt-badge {
    display: inline-block;
    background: linear-gradient(135deg, var(--gold) 0%, var(--brown-light) 100%);
    color: #fff; font-size: .62rem; letter-spacing: 3px; text-transform: uppercase;
    font-weight: 700; padding: 5px 16px; border-radius: 20px;
    margin-bottom: 14px; box-shadow: 0 2px 10px rgba(201,169,110,.4);
}
.kt-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.5rem, 4vw, 2rem); color: var(--brown-dark);
    font-weight: 500; line-height: 1.2; margin-bottom: 10px;
}
.kt-desc {
    font-size: .85rem; color: var(--text-mid); line-height: 1.7;
    margin-bottom: 22px; font-weight: 300;
}
.kt-code-wrap {
    background: var(--cream); border: 1.5px dashed var(--gold);
    border-radius: 6px; padding: 16px 20px; margin-bottom: 8px;
    position: relative; cursor: pointer;
}
.kt-code-label {
    font-size: .6rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--text-light); margin-bottom: 6px; display: block;
}
.kt-code {
    font-family: 'Courier New', monospace; font-size: 1.6rem;
    font-weight: 700; letter-spacing: 6px; color: var(--brown-dark);
    display: block;
}
.kt-copy-hint {
    font-size: .65rem; color: var(--gold); margin-top: 5px;
    display: block; transition: color .2s;
}
.kt-code-wrap:hover .kt-copy-hint { color: var(--brown-dark); }
.kt-valid {
    font-size: .7rem; color: var(--text-light); margin-bottom: 20px;
    display: block;
}
.kt-cta {
    display: block; width: 100%;
    background: linear-gradient(135deg, var(--gold) 0%, var(--brown-light) 100%);
    color: #fff; text-align: center; padding: 14px 20px;
    font-size: .78rem; letter-spacing: 2.5px; text-transform: uppercase;
    font-weight: 700; border-radius: 3px; transition: all .3s;
    box-shadow: 0 4px 16px rgba(201,169,110,.4);
    touch-action: manipulation; -webkit-appearance: none;
}
.kt-cta:hover { background: linear-gradient(135deg, var(--brown-dark) 0%, var(--brown-mid) 100%); box-shadow: 0 6px 20px rgba(92,61,46,.4); transform: translateY(-1px); }
.kt-dismiss {
    margin-top: 12px; font-size: .72rem; color: var(--text-light);
    cursor: pointer; display: block; transition: color .2s;
    touch-action: manipulation;
}
.kt-dismiss:hover { color: var(--text-mid); }
.kt-close-btn {
    position: absolute; top: 10px; right: 12px;
    background: rgba(255,255,255,.12); border: none; width: 28px; height: 28px;
    border-radius: 50%; cursor: pointer; display: flex; align-items: center;
    justify-content: center; color: rgba(255,255,255,.8); font-size: .95rem;
    transition: background .2s; touch-action: manipulation; line-height: 1;
}
.kt-close-btn:hover { background: rgba(255,255,255,.25); color: #fff; }
@media (max-width: 480px) {
    #ktPopupOverlay { padding: 12px; }
    .kt-body { padding: 22px 20px 18px; }
    .kt-code { font-size: 1.3rem; letter-spacing: 4px; }
}
