/* ================================================================
   MAGNUM BAKES & CAKES — style.css  (Mobile-First)
================================================================ */
:root {
  --bg-top:    #FAF0DC;
  --bg-mid:    #F0D9AB;
  --bg-warm:   #E8C07A;
  --choc:      #2C1507;
  --choc-mid:  #3D1F0A;
  --brand-org: #E87010;
  --brand-org2:#C85C00;
  --gold:      #C8920A;
  --gold-lt:   #E0B84A;
  --text-dark: #1A0C02;
  --text-mid:  #4A2E10;
  --text-lt:   #8A6040;
  --cream:     #FAF0DC;
  --cream2:    #F5E8C8;
  --radius-sm: 4px;
  --radius-md: 10px;
  --shadow-sm: 0 2px 14px rgba(44,21,7,.07);
  --shadow-md: 0 8px 30px rgba(44,21,7,.12);
  --shadow-lg: 0 20px 48px rgba(44,21,7,.18);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--bg-top);color:var(--text-dark);overflow-x:hidden;-webkit-text-size-adjust:100%}
img{display:block;max-width:100%}
a{text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 4%;display:flex;align-items:center;justify-content:space-between;height:64px;background:rgba(44,21,7,.97);backdrop-filter:blur(14px);border-bottom:1px solid rgba(200,146,10,.25);transition:all .3s}
nav.scrolled{height:54px;box-shadow:0 4px 20px rgba(0,0,0,.35)}
.nav-logo{display:flex;align-items:center;gap:9px}
.nav-logo-icon{width:40px;height:40px;border-radius:50%;background:var(--brand-org);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.nav-logo-img{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--cream);border:2px solid var(--gold);box-shadow:0 4px 14px rgba(0,0,0,.28);flex-shrink:0}
.nav-logo-text .brand{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:800;color:var(--cream)}
.nav-logo-text .sub{font-size:.55rem;letter-spacing:2.5px;color:var(--gold-lt);text-transform:uppercase}
.nav-links{display:none;align-items:center;gap:24px}
.nav-links a{color:rgba(250,240,220,.75);font-size:.75rem;letter-spacing:1.5px;text-transform:uppercase;transition:color .3s}
.nav-links a:hover{color:var(--gold-lt)}
.nav-cta{background:var(--brand-org)!important;color:#fff!important;padding:8px 18px;border-radius:var(--radius-sm);font-weight:600!important}
.hamburger{display:flex;flex-direction:column;gap:5px;padding:4px;background:none;border:none;cursor:pointer}
.hamburger span{width:22px;height:2px;background:var(--cream);display:block;transition:all .3s;border-radius:2px}

/* ── BUTTONS ── */
.btn-primary{padding:13px 28px;background:var(--brand-org);color:#fff;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:700;border-radius:var(--radius-sm);display:inline-block;transition:all .3s}
.btn-primary:hover{background:var(--gold);color:var(--choc);transform:translateY(-2px);box-shadow:0 8px 24px rgba(200,146,10,.35)}
.btn-outline{padding:12px 28px;background:transparent;color:var(--cream);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;border:1px solid rgba(250,240,220,.3);border-radius:var(--radius-sm);display:inline-block;transition:all .3s}
.btn-outline:hover{border-color:var(--gold-lt);color:var(--gold-lt)}
.btn-outline-dark{padding:12px 24px;background:transparent;color:var(--choc);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:700;border:2px solid var(--choc);border-radius:var(--radius-sm);display:inline-block;transition:all .3s}
.btn-outline-dark:hover{background:var(--choc);color:var(--cream)}
.btn-white{padding:12px 24px;background:#fff;color:var(--brand-org);font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;border-radius:var(--radius-sm);display:inline-block;transition:all .3s}
.btn-white:hover{background:var(--choc);color:#fff}
.btn-outline-w{padding:11px 24px;background:transparent;color:#fff;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:700;border:2px solid rgba(255,255,255,.55);border-radius:var(--radius-sm);display:inline-block;transition:all .3s}
.btn-outline-w:hover{background:#fff;color:var(--brand-org)}

/* ── HERO ── */
.hero{display:flex;flex-direction:column;background:linear-gradient(160deg,var(--choc) 0%,#3D1F0A 55%,#1A0C02 100%);position:relative;overflow:hidden;padding-top:64px}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 30% 70%,rgba(232,112,16,.15) 0%,transparent 60%);pointer-events:none}
.hero-content{padding:40px 6% 36px;position:relative;z-index:2}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:18px;opacity:0;animation:fadeUp .8s .2s forwards}
.hero-eyebrow span{font-size:.65rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold-lt);font-weight:600}
.eyebrow-line{width:36px;height:1px;background:var(--gold);opacity:.5}
.hero-h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,8vw,4.8rem);font-weight:800;color:var(--cream);line-height:1.08;margin-bottom:10px;opacity:0;animation:fadeUp .9s .35s forwards}
.hero-h1 em{font-style:italic;color:var(--brand-org);display:block}
.hero-sub{font-family:'Cormorant Garamond',serif;font-size:clamp(1rem,3vw,1.15rem);font-style:italic;color:rgba(250,240,220,.6);line-height:1.65;margin-bottom:24px;opacity:0;animation:fadeUp .9s .5s forwards;max-width:480px}
.hero-badges{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:18px;opacity:0;animation:fadeUp .9s .65s forwards}
.badge{display:flex;align-items:center;gap:7px;font-size:.73rem;color:rgba(250,240,220,.65)}
.badge-dot{width:5px;height:5px;border-radius:50%;background:var(--brand-org);flex-shrink:0}
.hero-proof{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:24px;max-width:520px;opacity:0;animation:fadeUp .9s .72s forwards}
.hero-proof div{padding:10px 12px;background:rgba(250,240,220,.06);border:1px solid rgba(200,146,10,.22);border-radius:var(--radius-sm)}
.hero-proof strong{display:block;color:var(--gold-lt);font-family:'Playfair Display',serif;font-size:1rem;line-height:1.1}
.hero-proof span{display:block;margin-top:3px;color:rgba(250,240,220,.58);font-size:.62rem;letter-spacing:1px;text-transform:uppercase;line-height:1.3}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .8s forwards}
.hero-visual{position:relative;width:100%;height:260px;overflow:hidden;flex-shrink:0}
.hero-img-wrap{position:absolute;inset:0;opacity:0;animation:fadeIn 1.2s .3s forwards}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;animation:slowZoom 14s ease-out forwards;transform:scale(1.06)}
.hero-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,var(--choc) 0%,rgba(44,21,7,.2) 20%,transparent 50%,rgba(44,21,7,.4) 100%)}
.hero-float{position:absolute;bottom:16px;right:16px;background:rgba(44,21,7,.9);border:1px solid rgba(200,146,10,.45);padding:12px 18px;border-radius:var(--radius-sm);backdrop-filter:blur(8px);opacity:0;animation:fadeUp .8s 1.2s forwards}
.hero-float .f-num{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:800;color:var(--gold-lt);line-height:1}
.hero-float .f-txt{font-size:.6rem;letter-spacing:2px;color:rgba(250,240,220,.55);text-transform:uppercase;margin-top:2px}
.hero-float .f-note{font-size:.66rem;color:rgba(250,240,220,.7);margin-top:6px;max-width:150px;line-height:1.35}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slowZoom{from{transform:scale(1.07)}to{transform:scale(1)}}

/* ── TRUST BAR ── */
.trust-bar{background:var(--choc-mid);border-top:1px solid rgba(200,146,10,.15);border-bottom:1px solid rgba(200,146,10,.15);padding:12px 4%;display:flex;justify-content:flex-start;gap:20px;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.trust-bar::-webkit-scrollbar{display:none}
.t-item{color:rgba(250,240,220,.7);font-size:.75rem;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}

/* ── SECTION BASE ── */
section{padding:60px 6%}
.sec-label{font-size:.66rem;letter-spacing:5px;text-transform:uppercase;color:var(--brand-org);font-weight:700;margin-bottom:8px}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,5vw,2.9rem);font-weight:700;color:var(--choc);line-height:1.18;margin-bottom:12px}
.sec-title em{font-style:italic;color:var(--brand-org2)}
.sec-desc{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:var(--text-lt);line-height:1.7;max-width:500px}

/* ── CATEGORIES ── */
.categories{background:linear-gradient(180deg,var(--bg-top) 0%,var(--cream2) 100%)}
.cats-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;flex-wrap:wrap;gap:16px}
.cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.cat-card{background:#fff;border:1px solid rgba(200,146,10,.12);border-radius:var(--radius-sm);padding:18px 10px;text-align:center;cursor:pointer;transition:all .35s;display:block;position:relative;overflow:hidden}
.cat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--brand-org);transform:scaleX(0);transition:transform .35s}
.cat-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(44,21,7,.1)}
.cat-card:hover::after{transform:scaleX(1)}
.cat-icon{font-size:1.6rem;margin-bottom:7px;display:block}
.cat-name{font-family:'Playfair Display',serif;font-size:.82rem;font-weight:700;color:var(--choc)}
.cat-count{font-size:.62rem;color:var(--text-lt);margin-top:2px}

/* ── SHOWCASE ── */
.showcase{background:linear-gradient(160deg,var(--cream2) 0%,var(--bg-mid) 100%)}
.showcase-inner{display:flex;flex-direction:column;gap:32px}
.showcase-img{position:relative;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg)}
.showcase-img img{width:100%;height:260px;object-fit:cover;object-position:center;transition:transform .6s}
.showcase-img:hover img{transform:scale(1.03)}
.showcase-badge{position:absolute;bottom:16px;left:16px;background:var(--brand-org);color:#fff;padding:10px 16px;border-radius:var(--radius-sm)}
.sb-num{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:800;display:block;line-height:1}
.sb-txt{font-size:.6rem;letter-spacing:2px;text-transform:uppercase;opacity:.85}
.price-header-row{display:flex;justify-content:space-between;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-lt);padding:0 0 8px;border-bottom:2px solid rgba(200,146,10,.2);margin-bottom:4px}
.cake-list{display:grid;gap:0}
.cake-row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(200,146,10,.12);gap:12px}
.cake-row:last-child{border-bottom:none}
.ck-name{font-family:'Playfair Display',serif;font-size:.88rem;font-weight:700;color:var(--choc)}
.ck-price{font-weight:700;color:var(--brand-org2);white-space:nowrap;font-size:.85rem}

/* ── BISCUITS (dark) ── */
.biscuits-section{background:linear-gradient(135deg,var(--choc) 0%,#1A0C02 100%);padding:60px 6%;position:relative;overflow:hidden}
.biscuits-section::before{content:'';position:absolute;top:-80px;left:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(200,146,10,.07) 0%,transparent 70%);pointer-events:none}
.biscuits-inner{display:flex;flex-direction:column;gap:32px}
.biscuit-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:18px}
/* Biscuit grid item: name+price left, order button right */
.bis-item{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(200,146,10,.15);
  border-radius:var(--radius-sm);
  padding:10px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  transition:all .3s;
}
.bis-item:hover{background:rgba(200,146,10,.1);border-color:rgba(200,146,10,.35)}
.bis-item.featured{border-color:rgba(200,146,10,.35);background:rgba(200,146,10,.07)}
.bis-left{display:flex;flex-direction:column;gap:2px;min-width:0}
.bi-name{font-family:'Playfair Display',serif;font-size:.8rem;font-weight:700;color:var(--cream);display:block}
.bi-price{font-size:.68rem;color:var(--gold-lt);font-weight:600;white-space:nowrap;display:block}
.biscuits-img{position:relative;border-radius:var(--radius-md);overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.biscuits-img img{width:100%;height:260px;object-fit:cover;object-position:center}
.biscuits-label{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(to top,rgba(44,21,7,.85),transparent);font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--cream);font-size:.9rem;text-align:center}

/* ── MENU SECTION ── */
.menu-section{background:linear-gradient(160deg,var(--bg-top) 0%,var(--cream2) 100%)}
.menu-header{text-align:center;margin-bottom:36px}
.menu-header .sec-desc{margin:0 auto}
.menu-tabs{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;margin-bottom:28px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.menu-tabs::-webkit-scrollbar{display:none}
.menu-tab{padding:9px 16px;border:1px solid rgba(200,146,10,.25);background:transparent;color:var(--text-mid);font-size:.72rem;letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius-sm);transition:all .25s;white-space:nowrap;flex-shrink:0}
.menu-tab:hover,.menu-tab.active{background:var(--choc);color:var(--cream);border-color:var(--choc)}
.menu-panel{display:none}
.menu-panel.active{display:block}
.menu-panel-header{display:flex;gap:16px;align-items:center;margin-bottom:20px;padding:16px;background:#fff;border-radius:var(--radius-md);border:1px solid rgba(200,146,10,.12);box-shadow:var(--shadow-sm)}
.menu-panel-img{width:80px;height:70px;object-fit:cover;border-radius:6px;flex-shrink:0}
.menu-panel-info h3{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--choc);margin-bottom:4px}
.menu-panel-info p{font-size:.75rem;color:var(--text-lt);line-height:1.4}
.menu-items{display:grid;gap:14px;grid-column:1/-1}
.menu-item{background:#fff;border:1px solid rgba(200,146,10,.14);border-radius:var(--radius-sm);overflow:hidden;box-shadow:0 8px 26px rgba(44,21,7,.08);transition:all .3s}
.menu-item:hover{border-color:rgba(200,146,10,.32);box-shadow:0 14px 34px rgba(44,21,7,.13);transform:translateY(-2px)}
.product-card{display:flex;flex-direction:column;min-width:0}
.product-card-img{width:100%;aspect-ratio:4/3;background:var(--cream2);overflow:hidden;position:relative}
.product-card-img img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s}
.menu-item:hover .product-card-img img{transform:scale(1.04)}
.product-card-tag{position:absolute;top:10px;left:10px;background:rgba(44,21,7,.9);color:var(--gold-lt);border:1px solid rgba(224,184,74,.5);border-radius:var(--radius-sm);padding:5px 8px;font-size:.56rem;font-weight:800;letter-spacing:1px;text-transform:uppercase}
.product-card-body{display:flex;flex-direction:column;gap:7px;padding:13px;min-height:164px}
.mi-name{font-family:'Playfair Display',serif;font-size:.96rem;font-weight:700;color:var(--choc);line-height:1.2}
.mi-price{font-weight:700;color:var(--brand-org2);white-space:nowrap;font-size:.88rem}
.mi-details{font-size:.72rem;color:var(--text-lt);line-height:1.45}

/* ── GALLERY ── */
.gallery{background:linear-gradient(180deg,var(--bg-warm) 0%,#D4965A 100%);padding-bottom:0}
.gallery-header{margin-bottom:28px}
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.g-item{overflow:hidden;position:relative;cursor:pointer;background:var(--choc-mid);height:200px}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.g-item:hover img{transform:scale(1.06)}
.g-item::after{content:'';position:absolute;inset:0;background:rgba(44,21,7,0);transition:background .3s}
.g-item:hover::after{background:rgba(44,21,7,.18)}
.g-caption{position:absolute;bottom:0;left:0;right:0;padding:10px 14px;background:linear-gradient(to top,rgba(44,21,7,.8),transparent);color:var(--cream);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:.85rem;opacity:0;transition:opacity .3s;z-index:2}
.g-item:hover .g-caption{opacity:1}

/* ── ABOUT ── */
.about{background:linear-gradient(135deg,var(--choc) 0%,#1A0C02 100%);display:flex;flex-direction:column;gap:36px;padding:60px 6%}
.about-imgs{position:relative;height:300px}
.a-img1{position:absolute;left:0;top:0;width:68%;height:85%;border-radius:var(--radius-sm);overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.a-img1 img{width:100%;height:100%;object-fit:cover}
.a-img2{position:absolute;right:0;bottom:0;width:50%;height:52%;border-radius:var(--radius-sm);overflow:hidden;border:3px solid var(--choc);box-shadow:0 14px 36px rgba(0,0,0,.45);z-index:2}
.a-img2 img{width:100%;height:100%;object-fit:cover;object-position:top}
.a-badge{position:absolute;left:-10px;top:50%;transform:translateY(-50%);background:var(--brand-org);padding:8px 14px;border-radius:var(--radius-sm);z-index:3;box-shadow:0 8px 20px rgba(232,112,16,.5);text-align:center}
.a-badge strong{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:800;color:#fff;display:block;line-height:1}
.a-badge span{font-size:.55rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.85)}
.about-points{display:grid;gap:16px;margin-top:6px}
.about-point{display:flex;gap:13px;align-items:flex-start}
.ap-icon{width:36px;height:36px;border-radius:50%;background:rgba(200,146,10,.12);border:1px solid rgba(200,146,10,.25);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.ap-text strong{display:block;font-family:'Playfair Display',serif;font-size:.85rem;color:var(--cream);margin-bottom:2px}
.ap-text span{font-size:.74rem;color:rgba(250,240,220,.48);line-height:1.5}

/* ── REVIEWS ── */
.reviews{background:linear-gradient(160deg,var(--bg-top) 0%,var(--cream2) 100%)}
.google-rating-bar{display:flex;align-items:center;gap:16px;margin-bottom:28px;padding:14px 20px;background:#fff;border-radius:var(--radius-md);border:1px solid rgba(200,146,10,.15);box-shadow:var(--shadow-sm);width:fit-content}
.gr-num{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:800;color:var(--choc);line-height:1}
.gr-stars{color:#FFC107;font-size:1rem;letter-spacing:2px}
.gr-based{font-size:.7rem;color:var(--text-lt);margin-top:3px}
.reviews-grid{display:grid;gap:16px}
.review-card{background:#fff;border-radius:var(--radius-md);padding:20px;border:1px solid rgba(200,146,10,.1);box-shadow:var(--shadow-sm);transition:all .35s}
.review-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.review-hd{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.r-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:.9rem;flex-shrink:0}
.r-name{font-weight:600;font-size:.85rem;color:var(--choc)}
.r-date{font-size:.66rem;color:var(--text-lt);margin-top:2px}
.r-stars{color:#FFC107;font-size:.8rem;letter-spacing:1px;margin-bottom:9px}
.r-text{font-family:'Cormorant Garamond',serif;font-size:.98rem;font-style:italic;color:var(--text-mid);line-height:1.65}

/* ── CTA STRIP ── */
.cta-strip{background:linear-gradient(135deg,var(--brand-org) 0%,var(--brand-org2) 100%);padding:44px 6%;display:flex;flex-direction:column;gap:20px;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.08);pointer-events:none}
.cta-strip h2{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:800;color:#fff}
.cta-strip p{font-size:.85rem;color:rgba(255,255,255,.82);margin-top:4px}
.cta-btns{display:flex;gap:10px;flex-wrap:wrap}

/* ── CONTACT ── */
.contact{background:linear-gradient(160deg,var(--cream2) 0%,var(--bg-mid) 100%)}
.contact-layout{display:flex;flex-direction:column;gap:24px;margin-top:32px}
.contact-cards{display:grid;gap:12px}
.c-card{display:flex;gap:13px;align-items:flex-start;padding:16px;background:#fff;border-radius:var(--radius-sm);border:1px solid rgba(200,146,10,.12);transition:all .3s}
.c-card:hover{border-color:rgba(200,146,10,.3);box-shadow:var(--shadow-sm)}
.c-card-icon{font-size:1.1rem;flex-shrink:0;margin-top:2px}
.c-card h4{font-family:'Playfair Display',serif;font-size:.85rem;font-weight:700;color:var(--choc);margin-bottom:3px}
.c-card p{font-size:.78rem;color:var(--text-mid);line-height:1.5}
.c-card a{color:var(--brand-org2);font-weight:600}

/* ── MAP ── */
.map-wrap{border-radius:var(--radius-md);overflow:hidden;height:320px;box-shadow:var(--shadow-md);flex-shrink:0}
.map-wrap iframe{width:100%;height:100%;min-height:320px;border:0;display:block}

/* ── FOOTER ── */
footer{background:var(--choc);padding:48px 6% 24px}
.footer-grid{display:grid;gap:28px;margin-bottom:36px}
.f-brand-name{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:800;color:var(--cream)}
.f-brand-sub{font-size:.58rem;letter-spacing:2.5px;color:var(--gold-lt);text-transform:uppercase;margin-bottom:12px}
.f-brand p{font-size:.78rem;color:rgba(250,240,220,.48);line-height:1.7;margin-bottom:18px}
.footer-logo-img{width:48px;height:48px;border-radius:50%;object-fit:cover;background:var(--cream);border:2px solid var(--gold);flex-shrink:0}
.social-row{display:flex;gap:8px}
.soc{width:34px;height:34px;border:1px solid rgba(200,146,10,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .3s}
.soc:hover{border-color:var(--gold-lt);background:rgba(200,146,10,.1)}
.f-col h5{font-family:'Playfair Display',serif;font-size:.8rem;font-weight:700;color:var(--cream);margin-bottom:14px;letter-spacing:1px}
.f-col ul{list-style:none;display:grid;gap:8px}
.f-col ul li a{color:rgba(250,240,220,.48);font-size:.76rem;transition:color .3s}
.f-col ul li a:hover{color:var(--gold-lt)}
.footer-bottom{border-top:1px solid rgba(250,240,220,.08);padding-top:20px;display:flex;flex-direction:column;gap:6px}
.footer-bottom p{font-size:.7rem;color:rgba(250,240,220,.32)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── WHATSAPP FLOAT ── */
.wa-btn{
  position:fixed;bottom:20px;right:20px;z-index:900;
  width:56px;height:56px;
  background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.45);
  animation:wa-pulse 2.2s ease-in-out infinite;
  transition:transform .3s;
}
.wa-btn:hover{transform:scale(1.1)}
.wa-btn svg{width:30px;height:30px;fill:#fff;display:block}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 6px 20px rgba(37,211,102,.45)}
  50%{box-shadow:0 6px 28px rgba(37,211,102,.65),0 0 0 7px rgba(37,211,102,.12)}
}
.mobile-order-bar{display:none}

/* ================================================================
   ORDERING SYSTEM — Order Now buttons
================================================================ */

/* Right side wrapper in showcase cake rows */
.cake-row-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

/* Right side wrapper in menu panel rows */
.menu-item-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

/* ── Base Order Now button ── */
.cake-order-btn {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  background: var(--brand-org);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: background .25s, transform .2s, box-shadow .25s;
  text-decoration: none;
  flex-shrink: 0;
  line-height: 1;
}
.cake-order-btn:hover {
  background: var(--gold);
  color: var(--choc);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(200,146,10,.3);
}
.cake-order-btn:active {
  transform: translateY(0);
}

/* Smaller variant for menu panels */
.cake-order-btn--sm {
  min-height: 42px;
  justify-content: center;
  width: 100%;
  margin-top: auto;
  padding: 8px 11px;
  font-size: .66rem;
}

/* Ghost variant for dark biscuit section */
.cake-order-btn--ghost {
  background: transparent;
  color: var(--gold-lt);
  border: 1px solid rgba(200,146,10,.45);
  padding: 5px 10px;
  font-size: .62rem;
  flex-shrink: 0;
}
.cake-order-btn--ghost:hover {
  background: var(--brand-org);
  color: #fff;
  border-color: var(--brand-org);
  box-shadow: 0 4px 14px rgba(232,112,16,.4);
}

/* Very narrow phones: stack price + button vertically */
@media (max-width: 360px) {
  .cake-row-right,
  .menu-item-right {
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
  }
}

@media (max-width: 639px) {
  body{padding-bottom:72px}
  .hero-proof{grid-template-columns:1fr 1fr}
  .hero-proof div:first-child{grid-column:1/-1}
  .hero-btns a{flex:1 1 100%;text-align:center}
  .mobile-order-bar{
    position:fixed;left:10px;right:10px;bottom:10px;z-index:950;
    display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:6px;
    padding:7px;background:rgba(44,21,7,.96);border:1px solid rgba(200,146,10,.35);
    border-radius:var(--radius-sm);box-shadow:0 12px 32px rgba(0,0,0,.35);backdrop-filter:blur(10px)
  }
  .mobile-order-bar a{
    min-height:42px;display:flex;align-items:center;justify-content:center;
    color:var(--cream);font-size:.7rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;
    border-radius:var(--radius-sm);border:1px solid rgba(250,240,220,.12)
  }
  .mobile-order-bar a:nth-child(2){background:var(--brand-org);color:#fff;border-color:var(--brand-org)}
  .wa-btn{display:none}
}

/* ═══════════════════════ TABLET ≥ 640px ═══════════════════════ */
@media(min-width:640px){
  .hero{flex-direction:row;min-height:100vh}
  .hero-content{flex:1;padding:80px 5% 60px 8%}
  .hero-visual{width:45%;height:auto;flex:none}
  .hero-img-overlay{background:linear-gradient(to right,var(--choc) 0%,rgba(44,21,7,.25) 40%,transparent 65%),linear-gradient(to top,rgba(44,21,7,.5) 0%,transparent 35%)}
  .cats-grid{grid-template-columns:repeat(4,1fr)}
  .showcase-inner{flex-direction:row;gap:48px;align-items:center}
  .showcase-img img{height:420px}
  .biscuits-inner{flex-direction:row;gap:48px;align-items:center}
  .biscuits-img img{height:420px}
  .about{flex-direction:row;gap:56px;align-items:center}
  .about-imgs{height:380px;flex:1;min-width:0}
  .gallery-grid{grid-template-columns:repeat(4,1fr);grid-template-rows:240px 240px}
  .g-item{height:auto}
  .g-item.g-wide{grid-column:span 2}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .cta-strip{flex-direction:row;align-items:center;justify-content:space-between;padding:52px 8%}
  .contact-layout{flex-direction:row;align-items:stretch}
  .contact-cards{flex:1}
  .map-wrap{height:420px;min-height:420px;flex:1}
  .map-wrap iframe{min-height:420px}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr}
  .footer-bottom{flex-direction:row;justify-content:space-between}
  .menu-panel.active{display:grid;grid-template-columns:1fr 1fr;column-gap:32px}
  .menu-panel-header{grid-column:1/-1}
  .menu-items{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* ═══════════════════════ DESKTOP ≥ 900px ═══════════════════════ */
@media(min-width:900px){
  nav{height:70px;padding:0 5%}
  nav.scrolled{height:58px}
  .hamburger{display:none}
  .nav-links{display:flex}
  section{padding:88px 8%}
  .biscuits-section{padding:88px 8%}
  .about{padding:88px 8%}
  .showcase-img img{height:520px}
  .biscuits-img img{height:520px}
  .about-imgs{height:460px}
  .gallery-grid{grid-template-rows:280px 280px}
  .cats-grid{grid-template-columns:repeat(8,1fr)}
  .biscuit-grid{grid-template-columns:1fr 1fr 1fr}
  .menu-items{grid-template-columns:repeat(3,minmax(0,1fr))}
  .map-wrap{height:500px;min-height:500px}
  .map-wrap iframe{min-height:500px}
}
