/*
Theme Name: Sabby Grand Hotel
Theme URI: https://sabbygrandhotel.com
Author: Sabby Grand Hotel
Description: Premium luxury hotel WordPress theme for Sabby Grand Hotel with Room, Banquet, Restaurant & Bar bookings, dynamic admin approval, employee roles, notifications, invoices, coupons, reviews, dark mode and full responsive UI.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: sabby
*/
:root{
 --gold:#c9a24c; --gold-2:#e8c878; --ink:#0e1726; --ink-2:#1b2436;
 --bg:#ffffff; --soft:#f7f5ef; --muted:#6b7280; --line:#e5e0d2;
 --rose:#8b1e3f; --shadow:0 20px 60px rgba(14,23,38,.12);
 --radius:14px; --max:1240px;
}
[data-theme="dark"]{--bg:#0b1220;--soft:#111a2e;--ink:#f4eedf;--ink-2:#e8dcb8;--muted:#9aa3b2;--line:#1f2a44;}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:'Poppins',system-ui,sans-serif;line-height:1.6}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;color:var(--ink);margin:0 0 .6rem;line-height:1.2}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.4rem;border-radius:999px;font-weight:600;border:0;cursor:pointer;transition:.25s;font-size:.95rem}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff;box-shadow:0 12px 30px rgba(201,162,76,.35)}
.btn-gold:hover{transform:translateY(-2px)}
.btn-outline{background:transparent;border:2px solid var(--gold);color:var(--gold)}
.btn-dark{background:var(--ink);color:#fff}
.section{padding:80px 0}
.section-head{text-align:center;margin-bottom:50px}
.section-head .eyebrow{color:var(--gold);letter-spacing:4px;text-transform:uppercase;font-size:.8rem;font-weight:600}
.section-head h2{font-size:2.6rem;margin-top:.5rem}
.section-head p{color:var(--muted);max-width:680px;margin:.6rem auto 0}
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .thumb{aspect-ratio:4/3;background:#ddd center/cover no-repeat;position:relative}
.card .body{padding:18px}
.card .body h3{font-size:1.25rem}
.price{color:var(--gold);font-weight:700;font-size:1.1rem}

/* Top bar */
.topbar{background:var(--ink);color:#e8dcb8;font-size:.82rem;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.topbar a{margin-left:12px}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--line);backdrop-filter:saturate(180%) blur(10px)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-2));display:grid;place-items:center;color:#fff;font-family:'Playfair Display',serif;font-weight:700;font-size:1.2rem}
.brand .name{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--ink)}
.brand .tag{font-size:.7rem;letter-spacing:3px;color:var(--gold);text-transform:uppercase}
.main-nav ul{display:flex;gap:6px;list-style:none;margin:0;padding:0}
.main-nav a{padding:10px 14px;border-radius:8px;font-weight:500;font-size:.95rem;transition:.2s}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--gold)}
.head-cta{display:flex;align-items:center;gap:10px}
.toggle-theme,.menu-toggle{background:transparent;border:1px solid var(--line);width:42px;height:42px;border-radius:50%;cursor:pointer;display:grid;place-items:center;color:var(--ink)}
.menu-toggle{display:none}

/* Hero */
.hero{position:relative;height:90vh;min-height:560px;color:#fff;overflow:hidden}
.hero .swiper,.hero .swiper-wrapper,.hero .swiper-slide{height:100%}
.hero .swiper-slide{background:#222 center/cover no-repeat;position:relative;display:flex;align-items:center}
.hero .swiper-slide::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,23,38,.55),rgba(14,23,38,.75))}
.hero-content{position:relative;z-index:2;text-align:center;width:100%;padding:0 20px}
.hero-content .eyebrow{color:var(--gold-2);letter-spacing:6px;text-transform:uppercase;font-weight:600}
.hero-content h1{font-size:4rem;color:#fff;margin:.6rem 0;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.hero-content p{font-size:1.15rem;max-width:680px;margin:0 auto 1.6rem;opacity:.95}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Booking Categories */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:-60px;position:relative;z-index:5}
.cat{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;text-align:center;border-top:4px solid var(--gold);transition:.3s}
.cat:hover{transform:translateY(-8px)}
.cat .ico{width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff;display:grid;place-items:center;font-size:1.6rem;margin:0 auto 14px}
.cat h3{font-size:1.2rem}
.cat p{color:var(--muted);font-size:.9rem;margin:.4rem 0 1rem}

/* Stats */
.stats{background:var(--ink);color:#fff;padding:60px 0}
.stats .grid{grid-template-columns:repeat(4,1fr);text-align:center}
.stat .num{font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--gold-2)}

/* About */
.about-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:center}
.about-wrap .imgs{position:relative;aspect-ratio:4/4;background:#ddd center/cover no-repeat;border-radius:var(--radius)}

/* Booking form */
.booking-form{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-grid .full{grid-column:1/-1}
label{display:block;font-weight:600;margin-bottom:6px;font-size:.9rem}
input,select,textarea{width:100%;padding:.8rem 1rem;border:1px solid var(--line);border-radius:10px;background:var(--bg);color:var(--ink);font-family:inherit;font-size:.95rem}
input:focus,select:focus,textarea:focus{outline:2px solid var(--gold);outline-offset:1px}
textarea{min-height:110px;resize:vertical}

/* Offers */
.offer{position:relative;border-radius:var(--radius);overflow:hidden;color:#fff;min-height:280px;background:#333 center/cover no-repeat;display:flex;align-items:flex-end;padding:24px}
.offer::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85))}
.offer .info{position:relative;z-index:2}
.offer .badge{display:inline-block;background:var(--gold);padding:4px 12px;border-radius:999px;font-size:.78rem;font-weight:700;margin-bottom:8px}

/* Reviews */
.review{background:var(--soft);padding:26px;border-radius:var(--radius);border:1px solid var(--line)}
.review .stars{color:var(--gold);letter-spacing:2px;margin-bottom:8px}
.review .who{display:flex;align-items:center;gap:12px;margin-top:14px}
.review .avatar{width:44px;height:44px;border-radius:50%;background:var(--gold);color:#fff;display:grid;place-items:center;font-weight:700}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery-grid a{aspect-ratio:1/1;background:#ddd center/cover no-repeat;border-radius:10px;transition:.3s;display:block}
.gallery-grid a:hover{transform:scale(1.04)}

/* Contact */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.info-card{background:var(--soft);padding:20px;border-radius:12px;border:1px solid var(--line);margin-bottom:14px;display:flex;gap:14px;align-items:flex-start}
.info-card i{color:var(--gold);font-size:1.4rem;margin-top:4px}

/* Footer */
.site-footer{background:var(--ink);color:#cdd5e0;padding:70px 0 0}
.site-footer h4{color:#fff;font-family:'Poppins',sans-serif;font-size:1.05rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px}
.site-footer a{color:#cdd5e0;display:block;padding:5px 0;font-size:.92rem}
.site-footer a:hover{color:var(--gold-2)}
.social{display:flex;gap:10px;margin-top:14px}
.social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;padding:0}
.social a:hover{background:var(--gold);color:#fff}
.copyright{border-top:1px solid rgba(255,255,255,.08);margin-top:50px;padding:20px 0;text-align:center;font-size:.85rem}

/* Floating */
.wa-float,.up-float{position:fixed;right:20px;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:1.4rem;z-index:99;box-shadow:0 10px 30px rgba(0,0,0,.25);cursor:pointer;border:0}
.wa-float{bottom:22px;background:#25d366;animation:pulse 2s infinite}
.up-float{bottom:88px;background:var(--ink);opacity:0;transform:translateY(20px);transition:.3s}
.up-float.show{opacity:1;transform:none}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}50%{box-shadow:0 0 0 14px rgba(37,211,102,0)}}

/* Page hero */
.page-hero{height:380px;background:var(--ink) center/cover no-repeat;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center;position:relative}
.page-hero::before{content:"";position:absolute;inset:0;background:rgba(14,23,38,.65)}
.page-hero .inner{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:3rem}
.crumb{color:var(--gold-2);font-size:.95rem;margin-top:8px}

/* Badges */
.badge-status{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:700}
.b-pending{background:#fff3cd;color:#856404}
.b-approved{background:#d4edda;color:#155724}
.b-rejected{background:#f8d7da;color:#721c24}
.b-completed{background:#d1ecf1;color:#0c5460}

/* Marquee */
.marquee{background:var(--gold);color:#fff;padding:8px 0;overflow:hidden;font-size:.9rem;font-weight:500}
.marquee span{display:inline-block;padding-left:100%;animation:scroll 28s linear infinite;white-space:nowrap}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

/* AOS-style */
[data-aos]{opacity:0;transform:translateY(30px);transition:.7s ease}
[data-aos].aos-in{opacity:1;transform:none}

@media(max-width:980px){
 .g-3,.g-4,.cat-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}
 .about-wrap,.contact-wrap{grid-template-columns:1fr}
 .hero-content h1{font-size:2.4rem}
 .stats .grid{grid-template-columns:repeat(2,1fr)}
 .main-nav{position:fixed;inset:64px 0 auto;background:var(--bg);border-bottom:1px solid var(--line);padding:14px 20px;display:none}
 .main-nav.open{display:block}
 .main-nav ul{flex-direction:column}
 .menu-toggle{display:grid}
 .section-head h2{font-size:1.9rem}
 .section{padding:60px 0}
 .form-grid{grid-template-columns:1fr}
}
@media(max-width:560px){
 .g-2,.g-3,.g-4,.cat-grid,.gallery-grid{grid-template-columns:1fr}
 .hero{height:78vh;min-height:480px}
 .hero-content h1{font-size:1.9rem}
 .page-hero{height:280px}
 .page-hero h1{font-size:2rem}
}
