/* =========================================================
   DABA CATERING — PREMIUM DESIGN SYSTEM (v2)
   Color system, motion system and footer rebuilt from scratch.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Raleway:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ---------- DESIGN TOKENS ---------- */
:root{
    /* Hospitality palette — warm espresso structure, champagne surfaces,
       gold/copper/olive/wine accents drawn from a working kitchen's own
       materials: coffee, brass, olive oil, aged wine, seared copper. */
    --espresso:#2b1c12;
    --espresso-deep:#1a1109;
    --espresso-soft:#3c2a19;
    --cream:#f9f2e3;
    --champagne:#f0e2c4;
    --champagne-deep:#e7d3aa;
    --paper:#fffaf0;

    --gold:#bb8c46;
    --gold-light:#e3bd7e;
    --gold-dark:#8f6a34;
    --copper:#a35d33;
    --copper-light:#c98457;
    --olive:#6d6b3d;
    --olive-light:#95915c;
    --wine:#6b2e2e;
    --wine-light:#9a5252;

    --text:#2a1f16;
    --text-muted:#8d7a63;
    --text-on-dark:#f1e7d6;
    --text-on-dark-muted:#c5ae8c;

    --border:rgba(43,28,18,0.12);
    --border-dark:rgba(241,231,214,0.14);

    --radius-sm:10px;
    --radius-md:20px;
    --radius-lg:32px;

    --shadow-sm:0 8px 22px -10px rgba(43,28,18,0.18);
    --shadow-md:0 26px 55px -22px rgba(43,28,18,0.30);
    --shadow-lg:0 55px 100px -35px rgba(26,17,9,0.45);

    --container:1260px;
    --font-display:"Fraunces", Georgia, serif;
    --font-body:"Raleway", sans-serif;

    /* Motion system */
    --ease-premium:cubic-bezier(.16,1,.3,1);   /* cinematic expo-out — entrances */
    --ease-soft:cubic-bezier(.22,.61,.36,1);   /* gentle — hover states */
    --dur-fast:.45s;
    --dur-med:1s;
    --dur-slow:1.5s;

    --nav-h:88px;
    --topbar-h:44px;
}

/* ---------- RESET / BASE ---------- */
*,*::before,*::after{ box-sizing:border-box; }
/* overflow-x:clip on html is the reliable mobile guard — body-level
   overflow-x:hidden alone is ignored by phone browsers when transformed
   elements (reveal animations) poke past the viewport, which let the
   whole page pan sideways on small screens. */
html{ scroll-behavior:smooth; scroll-padding-top:96px; overflow-x:clip; }
body{
    margin:0;
    font-family:var(--font-body);
    color:var(--text);
    background:var(--cream);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
    max-width:100%;
    line-height:1.6;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{
    font-family:var(--font-display);
    color:var(--espresso);
    margin:0;
    font-weight:500;
    line-height:1.15;
    letter-spacing:-0.01em;
}
p{ margin:0; }
::selection{ background:var(--gold); color:#fff; }

body.menu-open{ overflow:hidden; }

.container,.containerr,.containerf,.containerrr{
    max-width:var(--container);
    margin-inline:auto;
    padding-inline:clamp(20px,5vw,40px);
    position:relative;
}

.tag{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-family:var(--font-body);
    font-size:12.5px;
    font-weight:700;
    letter-spacing:2.6px;
    text-transform:uppercase;
    color:var(--gold-dark);
}
.tag::before{
    content:"";
    width:26px;
    height:1px;
    background:var(--gold);
    display:inline-block;
}
.highlight{ font-style:italic; color:var(--gold-dark); font-weight:500; }

.services > .containerr > .tag,
.signature-menu > .containerr > .tag,
.gallery > .containerf > .tag,
.process > .containerr > .tag,
.testimonials > .containerr > .tag,
.blog > .containerr > .tag{ justify-content:center; width:100%; }
.services h2,.signature-menu h2,.gallery h2,.process h2,.testimonials h2,.blog h2{
    text-align:center;
    font-size:clamp(2rem,4vw,2.85rem);
    max-width:820px;
    margin:16px auto 0;
}
.services .subtitle,.signature-menu .subtitle,.process .subtitle{
    text-align:center;
    max-width:620px;
    margin:18px auto 0;
    color:var(--text-muted);
    font-size:16px;
    line-height:1.75;
}
.services > .containerr,.signature-menu > .containerr,.gallery > .containerf,.process > .containerr,.testimonials > .containerr,.blog > .containerr{
    text-align:center;
}

.btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    background:var(--espresso);
    color:var(--cream);
    padding:16px 30px;
    border-radius:100px;
    font-size:13.5px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    transition:transform .5s var(--ease-premium), background .4s var(--ease-soft), box-shadow .4s var(--ease-soft);
    box-shadow:var(--shadow-sm);
}
.btn i{ transition:transform .4s var(--ease-soft); font-size:12px; }
.btn:hover{ background:var(--gold-dark); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.btn:hover i{ transform:translateX(4px); }

/* =========================================================
   MOTION SYSTEM — choreographed reveals (replaces AOS)
   Controlled by IntersectionObserver in script.js via [data-reveal].
   Each variant is a distinct move, not a single reused fade.
   ========================================================= */
[data-reveal]{
    transition:
        opacity var(--dur-med) var(--ease-premium),
        transform var(--dur-med) var(--ease-premium),
        clip-path var(--dur-slow) var(--ease-premium);
    transition-delay:calc(var(--d,0) * 1s);
    will-change:opacity, transform;
}
[data-reveal="rise"]{ opacity:0; transform:translateY(42px); }
[data-reveal="rise-sm"]{ opacity:0; transform:translateY(20px); }
[data-reveal="scale"]{ opacity:0; transform:scale(.92); }
[data-reveal="left"]{ opacity:0; transform:translateX(-56px); }
[data-reveal="right"]{ opacity:0; transform:translateX(56px); }
[data-reveal="mask"]{ opacity:1; clip-path:inset(0 0 100% 0); }
/* Reveal-in uses the standalone `scale` property (not transform:scale()),
   so it never fights the hover-zoom rules below — both animate the same
   element but on genuinely independent CSS properties and simply compose. */
[data-reveal="mask"] > img{
    scale:1.18;
    transition:scale 1.6s var(--ease-premium);
    transition-delay:calc(var(--d,0) * 1s);
}
[data-reveal="mask"].is-visible > img{ scale:1; }

[data-reveal].is-visible{
    opacity:1;
    transform:none;
    clip-path:inset(0 0 0% 0);
}

@media (prefers-reduced-motion:reduce){
    [data-reveal]{ transition-duration:.01ms !important; }
    [data-reveal="mask"] > img{ transition-duration:.01ms !important; }
}

/* =========================================================
   TOP UTILITY BAR
   ========================================================= */
.top-bar-wrapper{
    position:fixed;
    top:0; left:0; right:0;
    z-index:1001;
    background:var(--espresso-deep);
    transition:transform .5s var(--ease-premium), background .3s ease;
    transform:translateY(0);
}
.top-bar-wrapper.hide-top-bar{ transform:translateY(-100%); }
.top-bar-wrapper.scrolled{ background:var(--espresso-deep); }
.top-bar{ height:var(--topbar-h); display:flex; align-items:center; }
.header-flex{
    max-width:var(--container);
    margin-inline:auto;
    width:100%;
    padding-inline:clamp(20px,5vw,40px);
    display:flex;
    align-items:center;
    justify-content:space-between;
}
.call-to-action{ display:flex; align-items:center; gap:26px; }
.call-to-action p{
    display:flex; align-items:center; gap:8px;
    font-size:12.5px; color:var(--text-on-dark-muted); letter-spacing:.3px;
}
.call-to-action i{ color:var(--gold); font-size:11px; }
.right-area{ display:flex; align-items:center; gap:28px; }
.top-social-bookmark ul{ display:flex; gap:16px; }
.top-social-bookmark a{
    color:var(--text-on-dark-muted); font-size:12px;
    width:26px;height:26px;display:flex;align-items:center;justify-content:center;
    border:1px solid var(--border-dark); border-radius:50%;
    transition:all .4s var(--ease-soft);
}
.top-social-bookmark a:hover{ color:var(--espresso-deep); background:var(--gold); border-color:var(--gold); }
.book-table-popup a{
    font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
    color:var(--gold-light);
    display:flex; align-items:center;
    transition:color .3s ease;
}
.book-table-popup a:hover{ color:#fff; }

/* =========================================================
   MAIN NAVIGATION
   ========================================================= */
.mainmenu-area{
    position:fixed;
    left:0; right:0;
    top:var(--topbar-h);
    z-index:1000;
    background:transparent;
    transition:top .5s var(--ease-premium), background .4s ease, box-shadow .4s ease, padding .35s ease;
}
.mainmenu-area.top-bar-hidden{ top:0; }
.mainmenu-area.scrolled{
    background:rgba(249,242,227,0.94);
    -webkit-backdrop-filter:blur(14px);
    backdrop-filter:blur(14px);
    box-shadow:0 14px 36px -22px rgba(26,17,9,0.4);
}
.navbar{
    max-width:var(--container);
    margin-inline:auto;
    padding:22px clamp(20px,5vw,40px);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    transition:padding .35s ease;
}
.mainmenu-area.scrolled .navbar{ padding-block:14px; }

.navbar-brand .logo{
    font-family:var(--font-display);
    font-size:26px;
    font-weight:600;
    letter-spacing:1px;
    color:var(--espresso);
    display:flex;
    flex-direction:column;
    line-height:1;
}
.mainmenu-area:not(.scrolled) .navbar-brand .logo{ color:#fff; }
.navbar-brand .logo span{
    font-family:var(--font-body);
    font-size:9.5px;
    font-weight:700;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--gold-light);
    margin-top:4px;
}

.navbar-nav{ display:flex; align-items:center; gap:2px; }
.navbar-nav > li{ position:relative; }
.navbar-nav > li > a{
    display:block;
    padding:10px 16px;
    font-size:13.5px;
    font-weight:600;
    letter-spacing:.4px;
    color:#fff;
    transition:color .3s ease;
    position:relative;
}
.mainmenu-area.scrolled .navbar-nav > li > a{ color:var(--espresso); }
.navbar-nav > li > a::after{
    content:"";
    position:absolute;
    left:16px; right:16px; bottom:5px;
    height:1.5px;
    background:var(--gold);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .4s var(--ease-premium);
}
.navbar-nav > li:hover > a::after,
.navbar-nav > li.active > a::after{ transform:scaleX(1); }
.navbar-nav > li > a:hover{ color:var(--gold-light); }
.mainmenu-area.scrolled .navbar-nav > li > a:hover{ color:var(--gold-dark); }

.has-dropdown{ display:flex; align-items:center; }
.has-dropdown > a::before{
    font-family:"Font Awesome 6 Free"; font-weight:900; content:"\f107";
    font-size:10px; margin-left:6px; opacity:.7;
}
.dropdown-menu{
    position:absolute;
    top:calc(100% + 14px);
    left:0;
    min-width:230px;
    background:var(--paper);
    border-radius:14px;
    box-shadow:var(--shadow-lg);
    padding:10px;
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    transition:all .35s var(--ease-premium);
    z-index:20;
}
.has-dropdown:hover .dropdown-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown-menu li a{
    display:block;
    padding:11px 16px;
    font-size:13px;
    font-weight:600;
    color:var(--text);
    border-radius:9px;
    transition:all .25s ease;
}
.dropdown-menu li a:hover{ background:var(--champagne); color:var(--gold-dark); padding-left:20px; }

.nav-cta{
    background:var(--gold);
    color:var(--espresso-deep);
    padding:13px 24px;
    border-radius:100px;
    font-size:13px;
    font-weight:700;
    letter-spacing:.6px;
    white-space:nowrap;
    transition:all .4s var(--ease-soft);
    box-shadow:0 10px 25px -12px rgba(187,140,70,0.7);
}
.nav-cta:hover{ background:var(--espresso); color:#fff; transform:translateY(-2px); }

.hamburger{
    display:none;
    width:46px; height:46px;
    border-radius:50%;
    border:1px solid var(--border-dark);
    background:rgba(255,255,255,0.08);
    color:#fff;
    align-items:center;
    justify-content:center;
    font-size:16px;
    transition:all .3s ease;
}
.mainmenu-area.scrolled .hamburger{ color:var(--espresso); border-color:var(--border); background:rgba(43,28,18,0.05); }

/* =========================================================
   MOBILE MENU
   ========================================================= */
.mobile-menu{
    position:fixed;
    top:0; right:0;
    width:min(400px,88vw);
    height:100%;
    background:var(--espresso-deep);
    z-index:1100;
    padding:36px 34px;
    transform:translateX(100%);
    transition:transform .55s var(--ease-premium);
    overflow-y:auto;
    display:flex;
    flex-direction:column;
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu-brand{
    font-family:var(--font-display);
    font-size:24px;
    color:#fff;
    display:flex;
    flex-direction:column;
    margin-bottom:36px;
}
.mobile-menu-brand span{
    font-family:var(--font-body);
    font-size:9px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--gold-light);
    margin-top:4px;
}
.close-menu{
    position:absolute;
    top:30px; right:30px;
    width:42px; height:42px;
    border-radius:50%;
    border:1px solid var(--border-dark);
    background:transparent;
    color:#fff;
    font-size:15px;
}
.mobile-menu > ul > li{ border-bottom:1px solid var(--border-dark); }
.mobile-menu > ul > li > a{
    display:flex; align-items:center; justify-content:space-between;
    padding:18px 2px;
    font-family:var(--font-display);
    font-size:20px;
    color:var(--text-on-dark);
    transition:color .3s ease;
}
.mobile-menu > ul > li:hover > a,
.mobile-menu > ul > li.active-mobile > a{ color:var(--gold-light); }
.mobile-dropdown-icon i{ font-size:12px; color:var(--gold-light); transition:transform .3s ease; }
.mobile-submenu{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease-premium); }
.mobile-submenu.open{ max-height:260px; }
.mobile-submenu li a{
    display:block;
    padding:10px 4px 10px 16px;
    font-size:13.5px;
    color:var(--text-on-dark-muted);
    border-left:2px solid var(--gold);
}
.mobile-menu-footer{
    margin-top:auto;
    padding-top:26px;
    border-top:1px solid var(--border-dark);
    display:flex;
    flex-direction:column;
    gap:12px;
}
.mobile-menu-footer a{ font-size:13px; color:var(--text-on-dark-muted); display:flex; align-items:center; gap:8px; }
.mobile-menu-footer a i{ color:var(--gold); }
.mobile-menu-social{ display:flex; gap:14px; margin-top:6px; }
.mobile-menu-social a{
    width:36px; height:36px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    border:1px solid var(--border-dark); color:var(--text-on-dark);
}
.mobile-menu-social a:hover{ background:var(--gold); border-color:var(--gold); color:var(--espresso-deep); }

.menu-overlay{
    position:fixed; inset:0;
    background:rgba(26,17,9,0.6);
    -webkit-backdrop-filter:blur(3px);
    backdrop-filter:blur(3px);
    z-index:1090;
    opacity:0; visibility:hidden;
    transition:opacity .4s ease, visibility .4s ease;
}
.menu-overlay.active{ opacity:1; visibility:visible; }

/* =========================================================
   HERO — cinematic staggered entrance (not scroll-triggered;
   plays on load / on each slide change via .active toggling)
   ========================================================= */
.hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    overflow:hidden;
    background:var(--espresso-deep);
}
.hero-slide{
    position:absolute; inset:0;
    background-size:cover;
    background-position:center;
    opacity:0;
    transform:scale(1.14);
    transition:opacity 1.6s ease;
}
.hero-slide.active{ opacity:1; animation:kenburns 10s ease-in-out forwards; }
@keyframes kenburns{ from{ transform:scale(1.14); } to{ transform:scale(1); } }

.hero-scrim{
    position:absolute; inset:0;
    background:
        linear-gradient(180deg, rgba(26,17,9,0.6) 0%, rgba(26,17,9,0.32) 38%, rgba(26,17,9,0.82) 100%),
        linear-gradient(100deg, rgba(26,17,9,0.92) 8%, rgba(26,17,9,0.38) 55%, rgba(26,17,9,0.16) 100%);
}
.hero-inner{
    position:relative; z-index:2;
    padding-top:calc(var(--topbar-h) + var(--nav-h) + 20px);
    padding-bottom:70px;
    width:100%;
    transition:transform .1s linear, opacity .1s linear;
}
.hero-content{
    max-width:700px;
    opacity:0;
    visibility:hidden;
    position:absolute;
    transition:opacity .7s ease, visibility .7s ease;
}
.hero-content.active{ position:relative; opacity:1; visibility:visible; }

/* Staggered child choreography — each element enters on its own beat */
.hero-content > *{ opacity:0; }
.hero-content.active .tag{ animation:heroRise .9s var(--ease-premium) .15s forwards; }
.hero-content.active h1{ animation:heroRise 1.05s var(--ease-premium) .32s forwards; }
.hero-content.active .hero-sub{ animation:heroRise 1s var(--ease-premium) .52s forwards; }
.hero-content.active .hero-cta-row{ animation:heroRise .95s var(--ease-premium) .7s forwards; }
.hero-content.active .rating-box{ animation:heroRise .95s var(--ease-premium) .88s forwards; }
@keyframes heroRise{
    from{ opacity:0; transform:translateY(30px); }
    to{ opacity:1; transform:translateY(0); }
}

.hero-content .tag{ color:var(--gold-light); margin-bottom:22px; }
.hero-content .tag::before{ background:var(--gold-light); }
.hero-content h1{ color:#fff; font-size:clamp(2.5rem,5.6vw,4.5rem); font-weight:500; margin-bottom:22px; }
.hero-content h1 span{ color:var(--gold-light); font-style:italic; }
.hero-sub{ color:rgba(241,231,214,0.86); font-size:clamp(15px,1.6vw,17.5px); max-width:560px; line-height:1.75; margin-bottom:34px; }
.hero-cta-row{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-bottom:44px; }

.cta-btn{
    display:inline-flex; align-items:center; gap:12px;
    background:var(--gold);
    color:var(--espresso-deep);
    padding:18px 32px;
    border-radius:100px;
    font-size:13.5px;
    font-weight:700;
    letter-spacing:.8px;
    text-transform:uppercase;
    box-shadow:0 18px 40px -18px rgba(187,140,70,0.85);
    transition:all .5s var(--ease-premium);
}
.cta-btn i{ transition:transform .4s var(--ease-soft); }
.cta-btn:hover{ background:#fff; transform:translateY(-3px); }
.cta-btn:hover i{ transform:translateX(5px); }
.cta-btn-ghost{
    display:inline-flex; align-items:center;
    padding:18px 30px;
    border-radius:100px;
    border:1px solid rgba(241,231,214,0.4);
    color:#fff;
    font-size:13.5px;
    font-weight:600;
    letter-spacing:.5px;
    transition:all .4s var(--ease-soft);
    backdrop-filter:blur(6px);
}
.cta-btn-ghost:hover{ background:rgba(241,231,214,0.14); border-color:#fff; }

.rating-box{ display:flex; align-items:center; gap:18px; }
.rating-box .avatars{ display:flex; }
.rating-box .avatars img{
    width:46px; height:46px; border-radius:50%;
    border:2.5px solid var(--espresso-deep);
    object-fit:cover;
    margin-left:-14px;
}
.rating-box .avatars img:first-child{ margin-left:0; }
.rating-info{ display:flex; flex-direction:column; gap:4px; }
.rating-box .stars{ color:var(--gold-light); font-size:14px; letter-spacing:2px; }
.rating-box .stars span{ color:#fff; font-family:var(--font-body); font-weight:700; margin-left:6px; letter-spacing:0; }
.clients-label{ color:rgba(241,231,214,0.78); font-size:13px; }

.hero-dots{ position:absolute; left:clamp(20px,5vw,40px); bottom:0; display:flex; gap:10px; z-index:3; }
.hero-dot{ width:34px; height:3px; border-radius:3px; background:rgba(241,231,214,0.28); cursor:pointer; transition:background .4s ease; }
.hero-dot.active{ background:var(--gold-light); }

.scroll-cue{
    position:absolute;
    right:clamp(20px,5vw,40px);
    bottom:38px;
    z-index:3;
    display:flex; align-items:center; gap:12px;
    color:rgba(241,231,214,0.78);
    font-size:11.5px; letter-spacing:2px; text-transform:uppercase;
    writing-mode:vertical-rl;
}
.scroll-cue span{ width:1px; height:52px; background:rgba(241,231,214,0.35); position:relative; overflow:hidden; }
.scroll-cue span::after{
    content:""; position:absolute; top:-100%; left:0; width:100%; height:100%;
    background:var(--gold-light); animation:scrollcue 2.4s ease-in-out infinite;
}
@keyframes scrollcue{ 0%{ top:-100%; } 60%{ top:100%; } 100%{ top:100%; } }

/* =========================================================
   TRUST MARQUEE (ambient, non-scroll motion — kept as-is)
   ========================================================= */
.marquee-strip{ background:var(--espresso-deep); padding:20px 0; overflow:hidden; border-bottom:1px solid var(--border-dark); }
.marquee-track{ display:flex; align-items:center; gap:26px; width:max-content; animation:marquee 34s linear infinite; }
.marquee-track span{ font-family:var(--font-display); font-style:italic; font-size:clamp(16px,2vw,22px); color:var(--text-on-dark); white-space:nowrap; }
.marquee-track i{ color:var(--gold); font-size:10px; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* =========================================================
   WHY US / ABOUT
   ========================================================= */
.why-us{ padding:clamp(80px,10vw,140px) 0 clamp(40px,6vw,70px); }
.why-us .row{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(40px,6vw,90px); align-items:start; }
.why-us h1{ font-size:clamp(2rem,3.6vw,2.9rem); margin:18px 0 32px; max-width:520px; }
.features{ display:flex; flex-direction:column; gap:2px; }
.features li{
    padding:20px 4px; font-size:16.5px; font-weight:600; color:var(--text-muted);
    border-bottom:1px solid var(--border); cursor:pointer; position:relative; padding-left:26px;
    transition:all .4s var(--ease-soft);
}
.features li::before{ content:""; position:absolute; left:0; top:26px; width:12px; height:1.5px; background:var(--border); transition:all .4s var(--ease-soft); }
.features li.active,.features li:hover{ color:var(--espresso); padding-left:34px; }
.features li.active::before,.features li:hover::before{ width:20px; background:var(--gold); }

.why-us .right > p{ font-size:16.5px; line-height:1.85; color:var(--text-muted); max-width:520px; margin-bottom:28px; }
.image-box{ position:relative; margin-top:34px; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); aspect-ratio:8/3.2; }
.image-box img{ width:100%; height:100%; object-fit:cover; }
.image-box-badge{
    position:absolute; left:24px; bottom:24px;
    background:rgba(249,242,227,0.94);
    backdrop-filter:blur(8px);
    border-radius:16px;
    padding:16px 22px;
    display:flex; align-items:baseline; gap:10px;
    box-shadow:var(--shadow-sm);
}
.image-box-badge strong{ font-family:var(--font-display); font-size:26px; color:var(--gold-dark); }
.image-box-badge span{ font-size:12px; color:var(--text-muted); max-width:110px; line-height:1.3; }

.promise-row{
    display:grid; grid-template-columns:repeat(3,1fr); gap:26px;
    margin-top:clamp(60px,8vw,100px); padding-top:clamp(50px,7vw,70px);
    border-top:1px solid var(--border);
}
.promise-card{ background:var(--paper); border:1px solid var(--border); border-radius:var(--radius-md); padding:34px 30px; transition:all .5s var(--ease-premium); }
.promise-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.promise-card i{ width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; margin-bottom:20px; }
.promise-card:nth-child(1) i{ background:rgba(187,140,70,0.14); color:var(--gold-dark); }
.promise-card:nth-child(2) i{ background:rgba(163,93,51,0.14); color:var(--copper); }
.promise-card:nth-child(3) i{ background:rgba(109,107,61,0.14); color:var(--olive); }
.promise-card h4{ font-size:19px; margin-bottom:10px; }
.promise-card p{ color:var(--text-muted); font-size:14.5px; line-height:1.7; }

/* =========================================================
   SERVICES
   ========================================================= */
.services{ 
    padding:clamp(80px,10vw,140px) 0;
     background:var(--champagne); 
 /*             background:
        linear-gradient(120deg, rgba(26,17,9,0.94) 20%, rgba(43,28,18,0.74) 100%),
        url("img/slidehiro/photo-1498654896293-37aacf113fd9.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat; */
}
.cards{ margin-top:clamp(50px,7vw,70px); display:grid; grid-template-columns:repeat(3,1fr); gap:30px; text-align:left; }
.card{ background:var(--paper); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .6s var(--ease-premium), box-shadow .6s var(--ease-premium); min-width:0; }
.card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.card-media{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease-premium); }
.card:hover .card-media img{ transform:scale(1.08); }
.card-tag{
    position:absolute; top:18px; left:18px;
    background:rgba(249,242,227,0.94);
    font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
    padding:8px 14px; border-radius:100px;
}
.card:nth-child(1) .card-tag{ color:var(--gold-dark); }
.card:nth-child(2) .card-tag{ color:var(--copper); }
.card:nth-child(3) .card-tag{ color:var(--olive); }
.card-body{ padding:30px 28px 32px; }
.card-body h3{ font-size:21px; margin-bottom:12px; }
.card-body p{ color:var(--text-muted); font-size:14.5px; line-height:1.7; margin-bottom:20px; }
.card-body a{ font-size:13px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--espresso); display:inline-flex; align-items:center; gap:8px; }
.card-body a i{ font-size:11px; transition:transform .3s var(--ease-soft); }
.card-body a:hover i{ transform:translateX(5px); }
.card-body a:hover{ color:var(--gold-dark); }

.occasion-pills{ margin-top:44px; display:flex; flex-wrap:wrap; justify-content:center; gap:14px; }
.occasion-pills span{
    display:inline-flex; align-items:center; gap:9px;
    background:var(--paper); border:1px solid var(--border);
    padding:12px 20px; border-radius:100px;
    font-size:13.5px; font-weight:600; color:var(--text-muted);
    transition:all .35s var(--ease-soft);
}
.occasion-pills span:hover{ border-color:var(--gold); color:var(--gold-dark); background:#fff; }
.occasion-pills span:nth-child(1) i{ color:var(--gold); }
.occasion-pills span:nth-child(2) i{ color:var(--copper); }
.occasion-pills span:nth-child(3) i{ color:var(--wine); }
.occasion-pills span:nth-child(4) i{ color:var(--olive); }
.occasion-pills span:nth-child(5) i{ color:var(--gold-dark); }

/* =========================================================
   SIGNATURE MENU
   ========================================================= */
.signature-menu{ padding:clamp(80px,10vw,140px) 0; }
.menu-grid{ margin-top:clamp(50px,7vw,70px); display:grid; grid-template-columns:repeat(4,1fr); gap:26px; text-align:left; }
.menu-card{ background:var(--paper); border:1px solid var(--border); border-radius:var(--radius-md); padding:26px 26px 30px; transition:all .5s var(--ease-premium); min-width:0; }
.menu-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.menu-card-img{ border-radius:16px; overflow:hidden; aspect-ratio:5/4; margin-bottom:20px; }
.menu-card-img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-premium); }
.menu-card:hover .menu-card-img img{ transform:scale(1.06); }
.menu-card i{ font-size:18px; margin-bottom:12px; }
.menu-card:nth-child(1) i{ color:var(--gold); }
.menu-card:nth-child(2) i{ color:var(--copper); }
.menu-card:nth-child(3) i{ color:var(--olive); }
.menu-card:nth-child(4) i{ color:var(--wine); }
.menu-card h3{ font-size:18px; margin-bottom:10px; line-height:1.3; }
.menu-card p{ font-size:13.8px; color:var(--text-muted); line-height:1.65; }

.menu-cta{ margin-top:56px; display:flex; flex-direction:column; align-items:center; gap:22px; }
.menu-cta p{ color:var(--text-muted); font-size:15px; max-width:480px; text-align:center; }

/* =========================================================
   IMPACT / STATS — real transform-based parallax layer
   (replaces background-attachment:fixed, which iOS Safari
   ignores and which scrolled janky on lower-end devices)
   ========================================================= */
.impact{
    position:relative;
    padding:clamp(80px,10vw,130px) 0;
    color:#fff;
    overflow:hidden;
    isolation:isolate;
    background:var(--espresso-deep);
}
.impact-bg{
    position:absolute;
    left:0; right:0;
    top:-18%; height:136%;
    background-size:cover;
    background-position:center;
    will-change:transform;
    z-index:-2;
}
.impact .overlay{
    position:absolute; inset:0;
    background:linear-gradient(120deg, rgba(26,17,9,0.94) 20%, rgba(43,28,18,0.74) 100%);
    z-index:-1;
}
.impact .tag{ color:var(--gold-light); }
.impact .tag::before{ background:var(--gold-light); }
.impact h1{ color:#fff; font-size:clamp(2rem,3.6vw,3rem); margin-top:16px; }
.impact .bottom-row{ margin-top:clamp(50px,7vw,80px); display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:center; }
.impact .bottom-left p{ font-size:16px; line-height:1.8; color:rgba(241,231,214,0.82); max-width:420px; margin-bottom:26px; }
.impact .clients .avatars{ display:flex; align-items:center; }
.impact .avatars img{ width:44px; height:44px; border-radius:50%; border:2.5px solid var(--espresso-deep); object-fit:cover; margin-left:-14px; }
.impact .avatars img:first-child{ margin-left:0; }
.impact .avatars .plus{
    width:44px; height:44px; border-radius:50%;
    background:var(--gold); color:var(--espresso-deep);
    display:flex; align-items:center; justify-content:center;
    font-weight:800; font-size:15px; margin-left:-14px;
    border:2.5px solid var(--espresso-deep);
}
.impact small{ display:block; margin-top:14px; color:rgba(241,231,214,0.6); font-size:13px; letter-spacing:.3px; }

.impact .right{ display:flex; align-items:center; gap:0; }
.impact .stat{ text-align:center; flex:1; }
.impact .counter{ font-family:var(--font-display); font-size:clamp(2.4rem,4.2vw,3.6rem); color:var(--gold-light); font-weight:500; }
.impact .stat p{ font-size:13px; letter-spacing:.5px; color:rgba(241,231,214,0.7); margin-top:6px; text-transform:uppercase; }
.impact .divider{ width:1px; height:60px; background:rgba(241,231,214,0.18); margin:0 20px; }

/* =========================================================
   GALLERY — figcaption color tied to event category
   ========================================================= */
.gallery{ padding:clamp(80px,10vw,140px) 0; background:var(--champagne); }
.filters{ margin-top:clamp(40px,6vw,54px); display:flex; justify-content:center; flex-wrap:wrap; gap:12px; }
.filters button{
    background:transparent; border:1px solid var(--border);
    padding:12px 24px; border-radius:100px;
    font-size:13px; font-weight:700; letter-spacing:.5px; color:var(--text-muted);
    transition:all .35s var(--ease-soft);
}
.filters button:hover{ border-color:var(--gold); color:var(--gold-dark); }
.filters button.active{ background:var(--espresso); border-color:var(--espresso); color:#fff; }

.grid{ margin-top:36px; display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:230px; gap:18px; }
.grid figure{ position:relative; margin:0; overflow:hidden; border-radius:18px; box-shadow:var(--shadow-sm); min-width:0; }
.grid figure:nth-child(1){ grid-column:span 2; grid-row:span 2; }
.grid figure:nth-child(4){ grid-column:span 2; }
.grid figure:nth-child(6){ grid-column:span 2; }
.grid figure.hide{ display:none; }
.grid img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease-premium); }
.grid figure:hover img{ transform:scale(1.1); }
.grid figcaption{
    position:absolute; left:0; right:0; bottom:0; padding:22px;
    background:linear-gradient(0deg, rgba(26,17,9,0.88) 0%, rgba(26,17,9,0) 75%);
    color:#fff; font-family:var(--font-display); font-size:16px;
    opacity:0; transform:translateY(12px);
    transition:all .45s var(--ease-premium);
}
.grid figure:hover figcaption{ opacity:1; transform:translateY(0); }
.grid figcaption span{ display:block; font-family:var(--font-body); font-size:10.5px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:4px; }
.grid figure[data-category="wedding"] figcaption span{ color:var(--wine-light); }
.grid figure[data-category="corporate"] figcaption span{ color:var(--olive-light); }
.grid figure[data-category="cocktail"] figcaption span{ color:var(--copper-light); }
.grid figure[data-category="buffet"] figcaption span{ color:var(--gold-light); }
.gallery-cta{ margin-top:50px; display:flex; justify-content:center; }

/* =========================================================
   PROCESS
   ========================================================= */
.process{ 
    padding:clamp(80px,10vw,140px) 0; 
    
}
.process-grid{ margin-top:clamp(50px,7vw,70px); display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:left; position:relative; }
.process-card{ background:var(--paper); border:1px solid var(--border); border-radius:var(--radius-md); padding:34px 28px; position:relative; transition:all .5s var(--ease-premium); min-width:0; }
.process-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.process-num{ font-family:var(--font-display); font-size:15px; font-weight:600; letter-spacing:1px; }
.process-card:nth-child(1) .process-num{ color:var(--gold); }
.process-card:nth-child(2) .process-num{ color:var(--copper); }
.process-card:nth-child(3) .process-num{ color:var(--olive); }
.process-card:nth-child(4) .process-num{ color:var(--wine); }
.process-card i{ display:block; font-size:22px; color:var(--gold-dark); margin:18px 0 16px; }
.process-card h3{ font-size:19px; margin-bottom:10px; }
.process-card p{ font-size:14px; color:var(--text-muted); line-height:1.7; }
.process-cta{ margin-top:50px; display:flex; justify-content:center; }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testimonials{
     padding:clamp(80px,10vw,140px) 0;
      background:var(--champagne); --tpv:3;
       --testi-gap:30px;
       
 }

/* Multi-card auto-sliding carousel — --tpv (testimonials-per-view)
   controls how many cards are visible at once; JS (script.js) drives
   the transform and the infinite loop. See RESPONSIVE for --tpv at
   each breakpoint: 3 desktop / 2 tablet / 1 mobile. */
.testi-wrapper{ margin-top:clamp(50px,7vw,70px); }
.testi-viewport{ overflow:hidden; }
.testi-track{
    display:flex;
    gap:var(--testi-gap);
    align-items:stretch;
    will-change:transform;
    transition:transform .6s var(--ease-premium);
}
.testi-track.no-transition{ transition:none; }
.testi-card{
    flex:0 0 calc((100% - (var(--tpv) - 1) * var(--testi-gap)) / var(--tpv));
    min-width:0;
    display:flex;
    flex-direction:column;
    background:var(--paper); border-radius:var(--radius-md); padding:38px 34px;
    text-align:left; box-shadow:var(--shadow-sm);
    transition:transform .5s var(--ease-premium), box-shadow .5s var(--ease-premium);
}
.testi-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.quote-mark{ color:var(--gold); font-size:22px; opacity:.6; }
.testi-card .stars{ color:var(--gold); font-size:13px; letter-spacing:2px; margin:14px 0 16px; }
.testi-card p{ flex:1; font-size:15px; line-height:1.8; color:var(--text); }
.testi-card .user{ display:flex; align-items:center; gap:14px; margin-top:26px; padding-top:22px; border-top:1px solid var(--border); }

.testi-controls{ display:flex; align-items:center; justify-content:center; gap:22px; margin-top:40px; }
.testi-arrow{
    width:46px; height:46px; border-radius:50%; flex-shrink:0;
    border:1px solid var(--border); background:var(--paper); color:var(--espresso);
    display:flex; align-items:center; justify-content:center; font-size:14px;
    transition:all .35s var(--ease-soft);
}
.testi-arrow:hover{ background:var(--espresso); color:#fff; border-color:var(--espresso); transform:translateY(-2px); }
.testi-dots{ display:flex; align-items:center; gap:10px; }
.testi-dot{
    width:9px; height:9px; border-radius:50%; border:none; padding:0;
    background:var(--border); cursor:pointer; transition:all .35s var(--ease-soft);
}
.testi-dot:hover{ background:var(--gold-light); }
.testi-dot.active{ width:28px; border-radius:5px; background:var(--gold); }
.testi-card .user img{ width:50px; height:50px; border-radius:50%; object-fit:cover; border:2px solid var(--gold); }
.testi-card .user h4{ font-size:15.5px; margin-bottom:2px; }
.testi-card .user span{ font-size:12px; color:var(--text-muted); letter-spacing:.4px; text-transform:uppercase; }

/* =========================================================
   JOURNAL / BLOG
   ========================================================= */
.blog{ padding:clamp(80px,10vw,140px) 0; }
.blog-grid{ margin-top:clamp(50px,7vw,70px); display:grid; grid-template-columns:repeat(3,1fr); gap:30px; text-align:left; }
.blog-card{ background:var(--paper); border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); transition:all .6s var(--ease-premium); min-width:0; }
.blog-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.blog-card .img-box{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.blog-card .img-box img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease-premium); }
.blog-card:hover .img-box img{ transform:scale(1.08); }
.blog-card .badge{
    position:absolute; top:18px; left:18px;
    color:#fff; font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
    padding:8px 14px; border-radius:100px;
}
.blog-card:nth-child(1) .badge{ background:var(--wine); }
.blog-card:nth-child(2) .badge{ background:var(--olive); }
.blog-card:nth-child(3) .badge{ background:var(--copper); }
.blog-content{ padding:28px 26px 30px; }
.blog-content h3{ font-size:19px; line-height:1.35; margin-bottom:12px; }
.blog-content p{ font-size:14px; color:var(--text-muted); line-height:1.7; margin-bottom:18px; }
.blog-content > a{ font-size:13px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--espresso); display:inline-flex; align-items:center; gap:8px; }
.blog-content > a i{ font-size:11px; transition:transform .3s ease; }
.blog-content > a:hover{ color:var(--gold-dark); }
.blog-content > a:hover i{ transform:translateX(5px); }
.blog-content .meta{ margin-top:18px; padding-top:16px; border-top:1px solid var(--border); font-size:12px; color:var(--text-muted); }

/* =========================================================
   PROMO / AVAILABILITY BANNER
   ========================================================= */
.promo{
     background:linear-gradient(120deg, 
     var(--espresso-deep) 0%,
      var(--espresso-soft) 100%); 
      padding:clamp(70px,8vw,110px) 0;
       text-align:center; 
       position:relative; 
       overflow:hidden;
        background:
        linear-gradient(120deg, rgba(26,17,9,0.94) 20%, rgba(43,28,18,0.74) 100%),
        url("img/slidehiro/photo-1498654896293-37aacf113fd9.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    }
       
.promo::before{
    content:""; position:absolute; inset:0;
    background:radial-gradient(circle at 15% 20%, rgba(187,140,70,0.2), transparent 45%),
               radial-gradient(circle at 85% 80%, rgba(163,93,51,0.16), transparent 45%);
}
.promo-content{ position:relative; max-width:680px; margin-inline:auto; padding-inline:20px; display:flex; flex-direction:column; align-items:center; }
.promo-content .tag{ color:var(--gold-light); }
.promo-content .tag::before{ background:var(--gold-light); }
.promo-content h2{ color:#fff; font-size:clamp(1.9rem,3.6vw,2.6rem); margin:18px 0 18px; }
.promo-content p{ color:rgba(241,231,214,0.75); font-size:15.5px; line-height:1.7; margin-bottom:34px; }
.promo-btn{
    display:inline-flex; align-items:center; gap:10px;
    background:var(--gold); color:var(--espresso-deep);
    padding:17px 34px; border-radius:100px;
    font-weight:700; font-size:13.5px; letter-spacing:.8px; text-transform:uppercase;
    transition:all .45s var(--ease-premium);
}
.promo-btn:hover{ background:#fff; transform:translateY(-3px); }

/* =========================================================
   RESERVATION
   ========================================================= */
.reservation{ padding:clamp(80px,10vw,140px) 0; background:var(--champagne); }
.reservation-header{ text-align:center; max-width:640px; margin-inline:auto; }
.subhead{
    display:inline-flex; align-items:center; gap:8px;
    background:var(--paper); border:1px solid var(--border);
    padding:9px 18px; border-radius:100px;
    font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
    color:var(--gold-dark); margin-bottom:22px;
}
.reservation-header h2{ font-size:clamp(2rem,3.6vw,2.7rem); }
.reservation-header .desc{ margin-top:18px; color:var(--text-muted); font-size:15.5px; line-height:1.75; }

.reservation-grid{
    margin-top:clamp(50px,7vw,80px);
    display:grid; grid-template-columns:0.85fr 1.15fr;
    background:var(--espresso-deep);
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-lg);
}
.reservation-left{ padding:clamp(40px,5vw,58px); color:var(--text-on-dark); min-width:0; }
.reservation-left h4{ color:var(--gold-light); font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase; display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.reservation-left h3{ color:#fff; font-size:clamp(1.4rem,2.4vw,1.85rem); margin-bottom:18px; }
.left-description{ color:var(--text-on-dark-muted); font-size:14.5px; line-height:1.8; margin-bottom:34px; }
.contact-item{ padding:20px 0; border-top:1px solid var(--border-dark); }
.contact-item:last-child{ padding-bottom:0; }
.contact-label{ font-size:13px; color:var(--text-on-dark-muted); display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.contact-label i{ color:var(--gold); }
.phone-number{ font-family:var(--font-display); font-size:19px; color:#fff; display:flex; align-items:center; gap:10px; transition:color .3s ease; }
.phone-number:hover{ color:var(--gold-light); }
.phone-number.static{ font-family:var(--font-body); font-size:14px; font-weight:600; color:var(--text-on-dark); }
.phone-number i{ color:var(--gold); font-size:14px; }

.reservation-right{ background:var(--paper); padding:clamp(40px,5vw,58px); min-width:0; }
.reservation-right h4{ font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gold-dark); display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.reservation-right h3{ font-size:clamp(1.4rem,2.4vw,1.85rem); margin-bottom:30px; }

.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.input-group{
    position:relative; display:flex; align-items:center; gap:12px;
    background:var(--cream); border:1px solid var(--border); border-radius:14px;
    padding:16px 18px; transition:all .3s ease;
}
.input-group:focus-within{ border-color:var(--gold); box-shadow:0 0 0 4px rgba(187,140,70,0.14); }
.input-group i{ color:var(--gold-dark); font-size:15px; width:16px; text-align:center; }
.input-group input,.input-group select{
    border:none; outline:none; background:transparent;
    font-family:var(--font-body); font-size:14.5px; color:var(--text); width:100%;
}
.input-group input::placeholder{ color:var(--text-muted); }
.input-group select{ cursor:pointer; }

.btn-reserve{
    grid-column:1/-1; display:flex; align-items:center; justify-content:center; gap:12px;
    background:var(--espresso); color:#fff; padding:19px; border:none; border-radius:14px;
    font-size:14px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; margin-top:6px;
    transition:all .4s var(--ease-premium);
}
.btn-reserve:hover{ background:var(--gold-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.form-note{ grid-column:1/-1; text-align:center; font-size:12.5px; color:var(--text-muted); margin-top:2px; }

/* =========================================================
   CTA
   ========================================================= */
.cta-footer{ background:var(--espresso-deep); padding-top:clamp(80px,10vw,130px); }
.cta-content{ text-align:center; max-width:760px; margin:0 auto clamp(60px,8vw,90px); }
.cta-content .tag{ justify-content:center; color:var(--gold-light); }
.cta-content .tag::before{ background:var(--gold-light); }
.cta-content h1{ color:#fff; font-size:clamp(2.2rem,4.6vw,3.6rem); margin:18px 0 36px; }
.cta-content .buttons{ display:flex; justify-content:center; gap:18px; flex-wrap:wrap; }
.cta-content .btn.primary{ background:var(--gold); color:var(--espresso-deep); box-shadow:0 18px 40px -18px rgba(187,140,70,0.75); }
.cta-content .btn.primary:hover{ background:#fff; }
.cta-content .btn.secondary{ background:transparent; border:1px solid var(--border-dark); color:#fff; }
.cta-content .btn.secondary:hover{ background:rgba(241,231,214,0.08); }

/* =========================================================
   FOOTER — rebuilt with explicit grid-template-areas so the
   layout is deterministic (not just fr-fallback) at every
   breakpoint, plus overflow safeguards for long text/links.
   ========================================================= */
.footer-box{ 
    background:var(--espresso-deep); 
    border-top:1px solid var(--border-dark);
     padding-top:clamp(56px,7vw,88px);

     }


     .cta-footer{
    background:
        linear-gradient(120deg, rgba(26,17,9,0.94) 20%, rgba(43,28,18,0.74) 100%),
        url("img/about/12.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
/* .cta-footer.overlay{
    position:absolute; inset:0;
    background:linear-gradient(120deg, rgba(26,17,9,0.94) 20%, rgba(43,28,18,0.74) 100%);
    z-index:-1;
} */
.footer-container{
    display:grid;
    grid-template-columns:1.3fr .85fr .95fr .85fr;
    grid-template-areas:"brand areas contact explore";
    gap:clamp(28px,4vw,48px);
    padding-bottom:clamp(40px,6vw,60px);
    text-align:left;
    align-items:start;
}
.footer-col{ min-width:0; }
.footer-col p, .footer-col p a, .footer-bottom-bar, .phone-number, .contact-label{
    overflow-wrap:break-word;
    word-break:break-word;
}

.footer-brand{ grid-area:brand;margin-left: 2rem; }
.footer-col--areas{ grid-area:areas;margin-left: 2rem; }
.footer-col--contact{ grid-area:contact;margin-left: 2rem; }
.footer-col--explore{ grid-area:explore; margin-left: 2rem;}

.footer-col h2{
    font-family:var(--font-display); font-size:clamp(22px,2.4vw,26px); color:#fff;
    display:flex; flex-direction:column; margin-bottom:16px;
}
.footer-col h2 span{ font-family:var(--font-body); font-size:9.5px; letter-spacing:3px; text-transform:uppercase; color:var(--gold-light); margin-top:6px; font-weight:700; }
.footer-brand p{ color:var(--text-on-dark-muted); font-size:14px; line-height:1.75; max-width:300px; margin-bottom:24px; }
.footer-social{ display:flex; flex-wrap:wrap; gap:12px; }
.footer-social a{
    width:38px; height:38px; border-radius:50%; border:1px solid var(--border-dark); color:var(--text-on-dark);
    display:flex; align-items:center; justify-content:center; transition:all .35s var(--ease-soft); flex-shrink:0;
}
.footer-social a:hover{ background:var(--gold); color:var(--espresso-deep); border-color:var(--gold); }
.footer-col h4{ color:#fff; font-size:13.5px; letter-spacing:1px; text-transform:uppercase; margin-bottom:20px; }
.footer-col p{ color:var(--text-on-dark-muted); font-size:14px; line-height:1.75; margin-bottom:10px; }
.footer-col p a{ color:var(--text-on-dark-muted); transition:color .3s ease; }
.footer-col p a:hover{ color:var(--gold-light); }
.footer-col small{ color:var(--text-on-dark-muted); opacity:.75; font-size:12px; }
.footer-col ul li{ margin-bottom:12px; }
.footer-col ul li a{ color:var(--text-on-dark-muted); font-size:14px; transition:all .3s ease; display:inline-block; }
.footer-col ul li a:hover{ color:var(--gold-light); padding-left:4px; }

.footer-bottom-bar{
    border-top:1px solid var(--border-dark);
    padding:22px clamp(0px,2vw,16px) 30px;
    text-align:center;
    font-size:12.5px;
    line-height:1.8;
    color:var(--text-on-dark-muted);
}
.footer-bottom-bar a{ color:var(--gold-light); }

/* =========================================================
   FLOATING UI
   ========================================================= */
#topBtn{
    position:fixed; right:26px; bottom:96px; width:55px; height:55px; border-radius:50%; border:none;
    background:var(--espresso); display:flex; align-items:center; justify-content:center; cursor:pointer;
    z-index:900; opacity:0; visibility:hidden; transform:translateY(14px);
    transition:all .45s var(--ease-premium); box-shadow:var(--shadow-md);
}
#topBtn.show{ opacity:1; visibility:visible; transform:translateY(0); }
#topBtn svg{ position:absolute; transform:rotate(-90deg); }
#topBtn span{ position:relative; color:#fff; font-size:15px; z-index:2; }
#topBtn:hover{ background:var(--gold-dark); }



/* =========================================================
   RESPONSIVE
   ========================================================= */

/* Ultra-wide guard — keep hero/section rhythm from feeling
   sparse on very large monitors */
@media (min-width:1600px){
    :root{ --container:1320px; }
    .hero-content h1{ font-size:clamp(3.4rem,4.6vw,5rem); }
}

@media (max-width:1080px){
    .why-us .row{ grid-template-columns:1fr; }
    .why-us .right{ margin-top:10px; }
    .cards{ grid-template-columns:repeat(2,1fr); }
    .menu-grid{ grid-template-columns:repeat(2,1fr); }
    .blog-grid{ grid-template-columns:repeat(2,1fr); }
    .process-grid{ grid-template-columns:repeat(2,1fr); }
    .testimonials{ --tpv:2; }
    .impact .bottom-row{ grid-template-columns:1fr; gap:40px; }
    .reservation-grid{ grid-template-columns:1fr; }
    .grid{ grid-template-columns:repeat(2,1fr); }
    .grid figure:nth-child(1){ grid-column:span 2; }
}

/* ---- FOOTER: 1024px — brand keeps its own row, 3 link
   columns share the next row so nothing gets squeezed ---- */
@media (max-width:1024px){
    .footer-container{
        grid-template-columns:repeat(3,1fr);
        grid-template-areas:
            "brand brand brand"
            "areas contact explore";
        row-gap:clamp(32px,5vw,44px);
    }
    .footer-brand p{ max-width:460px; }
}

@media (max-width:950px){
    :root{ --nav-h:76px; }
    .navbar-nav,.nav-cta{ display:none; }
    .hamburger{ display:flex; }
    .call-to-action{ gap:16px; }
    .call-to-action p:last-child{ display:none; }
    .top-social-bookmark{ display:none; }
    .hero-cta-row{ gap:14px; }
    .rating-box{ flex-wrap:wrap; }
}

/* ---- FOOTER: 768px — single column stack, generous rhythm ---- */
@media (max-width:768px){
    .footer-container{
        grid-template-columns:1fr;
        grid-template-areas:
            "brand"
            "areas"
            "contact"
            "explore";
        row-gap:38px;
        text-align:left;
    }
    .footer-brand p{ max-width:100%; }
}

@media (max-width:760px){
    html{ scroll-padding-top:70px; }
    .header-flex{ justify-content:center; }
    .right-area{ display:none; }
    .navbar{ padding-block:16px; }
    .hero-inner{ padding-top:calc(var(--nav-h) + 30px); }
    .hero-content h1{ font-size:clamp(2.1rem,8vw,2.8rem); }
    .hero-sub{ font-size:14.5px; }
    .hero-cta-row{ flex-direction:column; align-items:stretch; }
    .cta-btn,.cta-btn-ghost{ justify-content:center; }
    .scroll-cue{ display:none; }
    .rating-box{ gap:14px; }

    section{ scroll-margin-top:70px; }
    .why-us,.services,.signature-menu,.gallery,.process,.testimonials,.blog,.reservation,.impact,.promo,.cta-footer{
        padding-top:64px; padding-bottom:64px;
    }
    .cards,.menu-grid,.blog-grid,.process-grid{ grid-template-columns:1fr; }
    .testimonials{ --tpv:1; --testi-gap:20px; }
    .testi-card{ padding:30px 26px; }
    .testi-card p{ font-size:14.5px; line-height:1.75; }
    .testi-controls{ margin-top:30px; gap:16px; }

    /* Reveal animations must not push content past the viewport edge
       on narrow screens — smaller offsets, same feel */
    [data-reveal="left"]{ transform:translateX(-28px); }
    [data-reveal="right"]{ transform:translateX(28px); }
    .grid{ grid-template-columns:1fr 1fr; grid-auto-rows:170px; }
    .grid figure:nth-child(1),.grid figure:nth-child(4),.grid figure:nth-child(6){ grid-column:span 1; }
    .promise-row{ grid-template-columns:1fr; }
    .impact .right{ flex-direction:column; gap:26px; }
    .impact .divider{ display:none; }
    .form-grid{ grid-template-columns:1fr; }
    .cta-content .buttons{ flex-direction:column; }
    .cta-content .btn{ justify-content:center; }
}

/* ---- FOOTER: 480px and below — tighter type + spacing ---- */
@media (max-width:480px){
    .footer-box{ padding-top:48px; }
    .footer-container{ row-gap:30px; padding-bottom:34px; }
    .footer-col h2{ font-size:22px; }
    .footer-col h4{ margin-bottom:16px; }
    .footer-col p{ font-size:13.5px; }
    .footer-social a{ width:36px; height:36px; }
    .footer-bottom-bar{ padding:18px 0 26px; font-size:11.5px; }
    .cta-content h1{ font-size:clamp(1.8rem,8vw,2.4rem); }

    /* Testimonials — comfortable phone spacing */
    .testi-card{ padding:26px 20px; }
    .quote-mark{ font-size:18px; }
    .testi-card .stars{ margin:12px 0 14px; }
    .testi-card .user{ margin-top:20px; padding-top:18px; gap:12px; }
    .testi-card .user img{ width:44px; height:44px; }
    .testi-card .user h4{ font-size:14.5px; }
    .testi-arrow{ width:40px; height:40px; font-size:13px; }
    .testi-controls{ gap:12px; }
    .testi-dots{ gap:8px; }
    .testi-dot.active{ width:22px; }
}

@media (max-width:400px){
    :root{ --topbar-h:0px; }
    .top-bar-wrapper{ display:none; }
    .mainmenu-area{ top:0; }
    .hero-inner{ padding-top:calc(var(--nav-h) + 24px); }

    /* Testimonials — 320–400px: keep line lengths readable */
    .testi-card{ padding:24px 18px; }
    .testi-card p{ font-size:14px; }
/* 
    .wa-text{ display:none; }
    .wa-btn{ padding:0; left:18px; bottom:18px; } */
    #topBtn{ width:48px; height:48px; right:18px; bottom:88px; }
}

@media (prefers-reduced-motion:reduce){
    *{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; }
}



/* WHATSAPP BUTTON - PROFESSIONAL VERSION */
.wa-btn {
    position: fixed;
    left: 25px;
    bottom: 25px;
    display: flex;
    align-items: center;
    text-decoration: none;
    z-index: 9999;
    cursor: pointer;
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* TEXT CONTAINER */
.wa-text {
    background: linear-gradient(135deg, #fff 0%, #f8f9fa 100%);
    color: #1a1a1a;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 16px;
    border-radius: 30px;
    margin-right: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12);
    opacity: 0;
    transform: translateX(-15px);
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    white-space: nowrap;
}

.wa-text-main {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: #075e54;
    letter-spacing: 0.3px;
}

.wa-text-small {
    display: block;
    font-size: 11px;
    font-weight: 400;
    color: #666;
    margin-top: 2px;
}

/* ICON CONTAINER */
.wa-icon {
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    box-shadow: 0 8px 25px rgba(37, 211, 102, 0.3);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

/* ICON STYLES */
.wa-icon i {
    font-size: 28px;
    color: white;
    transition: transform 0.3s ease;
}

/* HOVER EFFECTS */
.wa-btn:hover .wa-text {
    opacity: 1;
    transform: translateX(0);
}

.wa-btn:hover .wa-icon {
    transform: scale(1.08);
    box-shadow: 0 12px 30px rgba(37, 211, 102, 0.4);
}

.wa-btn:hover .wa-icon i {
    transform: scale(1.05);
}

/* PULSE ANIMATION - RING EFFECT */
.wa-icon::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: rgba(37, 211, 102, 0.6);
    top: 0;
    left: 0;
    animation: pulse-ring 2s infinite;
    z-index: -1;
}

/* PULSE ANIMATION - DOT EFFECT */
.wa-icon::after {
    content: "";
    position: absolute;
    width: 12px;
    height: 12px;
    background: #25D366;
    border-radius: 50%;
    top: -2px;
    right: -2px;
    border: 2px solid white;
    animation: pulse-dot 1.5s infinite;
    opacity: 0;
}

@keyframes pulse-ring {
    0% {
        transform: scale(1);
        opacity: 0.8;
    }
    70% {
        transform: scale(1.4);
        opacity: 0;
    }
    100% {
        transform: scale(1);
        opacity: 0;
    }
}

@keyframes pulse-dot {
    0% {
        transform: scale(0.8);
        opacity: 1;
    }
    50% {
        transform: scale(1.2);
        opacity: 0.7;
    }
    100% {
        transform: scale(0.8);
        opacity: 1;
    }
}

/* SHOW DOT ON ACTIVE */
.wa-btn.active .wa-icon::after {
    opacity: 1;
}

/* TOOLTIP ON HOVER (Desktop only) */
@media (min-width: 769px) {
    .wa-btn::before {
        content: "Need help? Chat with us!";
        position: absolute;
        left: 70px;
        bottom: 15px;
        background: #1a1a1a;
        color: white;
        padding: 6px 12px;
        border-radius: 8px;
        font-size: 12px;
        white-space: nowrap;
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
        pointer-events: none;
        font-family: inherit;
        z-index: 9998;
    }
    
    .wa-btn:hover::before {
        opacity: 1;
        visibility: visible;
        left: 80px;
    }
}

/* RESPONSIVE DESIGN */
@media (max-width: 768px) {
    .wa-btn {
        left: 15px;
        bottom: 15px;
    }
    
    .wa-icon {
        width: 48px;
        height: 48px;
    }
    
    .wa-icon i {
        font-size: 24px;
    }
    
    /* Hide text completely on mobile */
    .wa-text {
        display: none;
    }
    
    /* Adjust tooltip for mobile if needed */
    .wa-btn::before {
        display: none;
    }
}

/* For tablets - show text on hover only */
@media (min-width: 769px) and (max-width: 1024px) {
    .wa-text {
        max-width: 0;
        padding: 10px 0;
        overflow: hidden;
        transition: all 0.3s ease;
    }
    
    .wa-btn:hover .wa-text {
        max-width: 150px;
        padding: 10px 16px;
    }
}

/* DARK MODE SUPPORT */
@media (prefers-color-scheme: dark) {
    .wa-text {
        background: linear-gradient(135deg, #2d2d2d 0%, #1a1a1a 100%);
        border-color: rgba(255, 255, 255, 0.1);
    }
    
    .wa-text-main {
        color: #25D366;
    }
    
    .wa-text-small {
        color: #aaa;
    }
}

/* SCROLL REVEAL (optional) */
.wa-btn {
    animation: slideInLeft 0.5s ease-out;
}

@keyframes slideInLeft {
    from {
        opacity: 0;
        transform: translateX(-50px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* ACCESSIBILITY */
.wa-btn:focus-visible {
    outline: 2px solid #25D366;
    outline-offset: 2px;
    border-radius: 30px;
}

/* PREVENT TEXT SELECTION */
.wa-text {
    user-select: none;
}

/* LOADING STATE (optional) */
.wa-btn.loading .wa-icon {
    animation: shake 0.5s ease;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

/* =========================================================
   PRELOADER — luxury wordmark reveal
   Espresso curtain, staggered serif letters rising out of a
   baseline mask, a gold hairline drawing outward, then the
   whole curtain lifts to hand off into the hero entrance.
   script.js removes it on window load (min 1.4s, max 4s).
   ========================================================= */
.preloader{
    position:fixed;
    inset:0;
    z-index:99999;
    background:var(--espresso-deep);
    display:flex;
    align-items:center;
    justify-content:center;
    transition:transform 1s var(--ease-premium), visibility 1s;
}
/* soft warm vignette so the curtain doesn't read as flat black */
.preloader::before{
    content:"";
    position:absolute; inset:0;
    background:radial-gradient(ellipse 90% 60% at 50% 42%, rgba(187,140,70,0.10) 0%, transparent 65%);
    pointer-events:none;
}
.preloader-inner{
    display:flex;
    flex-direction:column;
    align-items:center;
    padding:0 24px;
    text-align:center;
}
.preloader-word{
    display:flex;
    overflow:hidden;                 /* baseline mask the letters rise out of */
    font-family:var(--font-display);
    font-weight:500;
    font-size:clamp(3rem,10vw,4.6rem);
    letter-spacing:.14em;
    color:var(--text-on-dark);
    line-height:1.1;
    padding-bottom:.06em;            /* keep serif descenders inside the mask */
}
.preloader-word span{
    display:inline-block;
    transform:translateY(115%);
    animation:preloader-letter 1s var(--ease-premium) forwards;
}
.preloader-word span:nth-child(1){ animation-delay:.18s; }
.preloader-word span:nth-child(2){ animation-delay:.28s; }
.preloader-word span:nth-child(3){ animation-delay:.38s; }
.preloader-word span:nth-child(4){ animation-delay:.48s; }
@keyframes preloader-letter{
    to{ transform:translateY(0); }
}
.preloader-rule{
    width:min(180px,42vw);
    height:1px;
    margin:22px 0 16px;
    background:linear-gradient(90deg, transparent, var(--gold), transparent);
    transform:scaleX(0);
    animation:preloader-rule .9s var(--ease-premium) .75s forwards;
}
@keyframes preloader-rule{
    to{ transform:scaleX(1); }
}
.preloader-sub{
    font-family:var(--font-body);
    font-size:11.5px;
    font-weight:700;
    letter-spacing:.42em;
    text-indent:.42em;               /* optically re-center tracked caps */
    text-transform:uppercase;
    color:var(--gold-light);
    opacity:0;
    animation:preloader-fade .9s ease .95s forwards;
}
@keyframes preloader-fade{
    to{ opacity:1; }
}
.preloader-progress{
    width:min(180px,42vw);
    height:2px;
    margin-top:38px;
    border-radius:2px;
    background:rgba(241,231,214,0.12);
    overflow:hidden;
}
.preloader-progress-fill{
    display:block;
    width:0%;
    height:100%;
    border-radius:2px;
    background:linear-gradient(90deg, var(--gold-dark), var(--gold-light));
    transition:width .35s ease-out;
}

/* Exit — curtain lifts; hero entrance plays underneath */
.preloader.preloader-exit{
    transform:translateY(-100%);
    visibility:hidden;
}
.preloader.preloader-exit .preloader-inner{
    opacity:0;
    transform:translateY(-26px);
    transition:opacity .5s ease, transform .7s var(--ease-premium);
}

/* Page state while the preloader is up: lock scroll and hold the
   hero entrance so it plays fresh the moment the curtain lifts */
body.is-loading{ overflow:hidden; }
body.is-loading .hero-content.active > *{ animation:none !important; }
body.is-loading .hero-slide.active{ animation-play-state:paused; }

@media (prefers-reduced-motion:reduce){
    .preloader{ transition:opacity .2s ease, visibility .2s; }
    .preloader.preloader-exit{ transform:none; opacity:0; }
    .preloader-word span{ transform:none; animation:none; }
    .preloader-rule{ transform:none; animation:none; }
    .preloader-sub{ opacity:1; animation:none; }
}
