/* ══════════════════════════════
   BEANS & CONES — style.css
   ══════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:wght@700&family=Great+Vibes&family=Poppins:wght@400;500;600;700;800&display=swap');

/* ══════════════════════════════
   ROOT COLOR VARIABLES
   ══════════════════════════════ */
:root {


   --gold:       #C9A84C;
    --gold-light: #F0D58C;
    --gold-dark:  #9A7230;
    --cream:      #FDF8EF;
    --dark:       #1A1208;
    --brown:      #3D2B1F;
    --soft:       #F5EDD8;
    --border:     rgba(201,168,76,0.25);
    --shadow:     0 8px 32px rgba(61,43,31,0.10);
    --radius:     16px;



   --accent: #C8782A;
      --accent-light: #f5e8d8;
      --dark: #1a1a1a;
      --muted: #6b6b6b;
      --border: #e5e0d8;


 --espresso:    #0f0a06;
    --roast:       #1c1108;
    --dark-card:   #1e1409;
    --mid-card:    #2a1d0d;
    --gold:        #c8902a;
    --gold-light:  #e6b84a;
    --gold-glow:   rgba(200,144,42,.18);
    --cream:       #f5ede0;
    --cream-muted: #c4a882;
    --text-main:   #f0e6d8;
    --text-muted:  #8a7260;
    --border:      rgba(200,144,42,.18);
    --border-light:rgba(200,144,42,.32);
    --shadow:      0 8px 40px rgba(0,0,0,.55);

    --bg:        #1a0f07;
  --bg2:       #2a1a0d;
  --card-bg:   #241408;
  --gold:      #c8902a;
  --gold-lt:   #e8b84b;
  --cream:     #f5ead8;
  --muted:     #9a7a5a;
  --border:    rgba(200,144,42,0.25);
  --btn-bg:    #3a2010;
  --shadow:    rgba(0,0,0,0.5);


  /*happy custerms*/
    --gold:       #c8860a;
  --gold-lt:    #e5a420;
  --red:        #ae3737;
  --red-dk:     #8a2020;
  --espresso:   #2B1B17;
  --espresso2:  #1f0e02;
  --espresso3:  #2a1504;

   --cream:    #FAF6F0;
      --warm:     #F5EDE0;
      --espresso: #2C1A0E;
      --latte:    #8B5E3C;
      --gold:     #C69B5A;
      --muted:    #7A6555;

   --rv-bg:        #0E0A06;
  --rv-card:      #1A1108;
  --rv-card-h:    #211608;
  --rv-gold:      #C8860A;
  --rv-gold-lt:   #E5A830;
  --rv-border:    rgba(200,134,10,0.15);
  --rv-border-h:  rgba(200,134,10,0.45);
  --rv-text:      #F4EFE4;
  --rv-muted:     rgba(244,239,228,0.5);
  --rv-star:      #F5A623;


  /*menu*/
        --gold: #C8922A;
      --gold-light: #E8A83E;
      --dark-bg: #1a1208;
      --dark-card: #231a0e;
      --cream: #FDF6EC;
      --text-dark: #1a1208;
      --text-muted: #888;
      
   --cream:      #F4EFE4;
      --cream-dark: #EDE5D0;
      --dark:       #1C1208;
      --brown:      #2E1A0E;
      --gold:       #C8860A;
      --gold-light: #E8A020;
      --muted:      #7A6050;
      --white:      #FFFFFF;

  --color-bg:            #f5f0e8;
  --color-navbar-bg:     #fdf8f0;
  --color-navbar-border: #e8dfc8;
  --color-navbar-shadow: rgba(0, 0, 0, 0.07);

  --color-brand-dark:    #3B2206;
  --color-brand-mid:     #8B5E1A;
  --color-brand-gold:    #C8860A;
  --color-brand-light:   #fdf3e0;
  --color-brand-pale:    #f5e9c8;

  --color-text-primary:  #3B2206;
  --color-text-muted:    #5A3A0A;
  --color-text-light:    #888;

  --color-border-light:  #e0c98a;
  --color-border-pale:   #eedfc4;

  --color-cart-bg:       #1C1208;
  --color-cart-hover:    #3B2206;
  --color-cart-text:     #ffffff;

  --color-active-hover:  #fdf0d8;
  --color-white:         #ffffff;

  /*herosection colors*/
      --cream:       #F4EFE4;
      --dark:        #1C1208;
      --brown:       #2E1A0E;
      --gold:        #C8860A;
      --gold-light:  #E8A020;
      --text-muted:  #6B5040;
      --card-bg:     #63332a;
      --badge-bg:    #F0E8D8;

  /*location section*/
   --dark-bg:    #1A1008;
      --dark-mid:   #231508;
      --dark-card:  #2A1A0A;
      --gold:       #C8860A;
      --gold-light: #E8A020;
      --cream:      #F4EFE4;
      --text-dim:   rgba(244,239,228,0.5);
      --border:     rgba(200,134,10,0.2);

   /*categires*/
      --bgground: #fff;
        --dark:        #1C1208;
        --dark2:        #C8860A;
       --border:     #EDE8DF;
      --star:       #F5A623;

    /*hot deals*/
          --bc-bg:          #1E1208;
      --bc-card-bg:     #2A1A0A;
      --bc-card-hover:  #321F0C;
      --bc-card-border: rgba(200,134,10,0.18);
      --bc-gold:        #C8860A;
      --bc-gold-light:  #E8A020;
      --bc-cream:       #F4EFE4;
      --bc-text-dim:    rgba(244,239,228,0.55);
      --bc-badge-bg:    rgba(200,134,10,0.15);

    /*footer*/
          --bc-ft-bg:        #160D06;
      --bc-ft-bottom-bg: #100A04;
      --bc-ft-gold:      #C8860A;
      --bc-ft-gold-lt:   #E8A020;
      --bc-ft-cream:     #F4EFE4;
      --bc-ft-dim:       rgba(244,239,228,0.42);
      --bc-ft-mid:       rgba(244,239,228,0.62);
      --bc-ft-border:    rgba(200,134,10,0.15);
      --bc-ft-border-t:  rgba(255,255,255,0.07);

    /*playstors*/
          --bc-app-bg:       #F2E8C8;
      --bc-app-dark:     #1C1208;
      --bc-app-brown:    #2E1A0E;
      --bc-app-gold:     #C8860A;
      --bc-app-gold-lt:  #E8A020;
      --bc-app-text:     #3B2206;
      --bc-app-muted:    #7A6050;
      --bc-phone-bg:     #2A1608;
      --bc-phone-screen: #3D1E08;


        --bc-rv-bg:        #fff;
      --bc-rv-card:      #EEEADE;
      --bc-rv-dark:      #1C1208;
      --bc-rv-gold:      #C8860A;
      --bc-rv-gold-lt:   #E8A020;
      --bc-rv-muted:     #7A6A58;
      --bc-rv-star:      #F5A623;
      --bc-rv-quote:     #C8860A;
      --bc-rv-border:    rgba(200,134,10,0.12);

            --bc-pr-bg:        #1A0E06;
      --bc-pr-card:      #221408;
      --bc-pr-card-hvr:  #2C1B0C;
      --bc-pr-border:    rgba(200,134,10,0.15);
      --bc-pr-gold:      #C8860A;
      --bc-pr-gold-lt:   #E8A020;
      --bc-pr-cream:     #F4EFE4;
      --bc-pr-dim:       rgba(244,239,228,0.50);
      --bc-pr-icon-bg:   rgba(200,134,10,0.12);
      --bc-pr-icon-bdr:  rgba(200,134,10,0.20);

            --bc-sl-bg:        #F2E8C8;
      --bc-sl-card:      #FFFFFF;
      --bc-sl-dark:      #1C1208;
      --bc-sl-gold:      #C8860A;
      --bc-sl-gold-lt:   #E8A020;
      --bc-sl-muted:     #8A7A68;
      --bc-sl-border:    #EDE8DF;
      --bc-sl-open-bg:   #EAF5EC;
      --bc-sl-open-dot:  #2E9B4A;
      --bc-sl-open-txt:  #1E7A38;
      --bc-sl-icon-bg:   #F0E8D8;
      --bc-sl-dist-bg:   #FDF3E0;
      --bc-sl-dist-bdr:  #E8D4A0;
}

/* ── RESET & BASE ── */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  /*background: var(--color-bg);*/
  font-family: 'Poppins', sans-serif;
}

 /* ── NAV BASE ── */
  .bc-nav {
    background: var(--espresso) !important;
    border-bottom: 1px solid rgba(200,134,10,0.2);
    font-family: var(--font-ui);
    position: sticky;
    top: 0;
    z-index: 1000;
    transition: background .35s ease, box-shadow .35s ease;
    padding: 16px 5px;
  }
  .bc-nav.scrolled {
    background: rgba(22,8,0,.95) !important;
    box-shadow: 0 4px 32px rgba(0,0,0,.5);
    backdrop-filter: blur(14px);
    border-bottom-color: rgba(200,134,10,.3);
  }

  /* ── CONTAINER ── */
  .bc-nav .container {
    position: relative;
    display: flex;
    align-items: center;
    height: var(--nav-h);
    max-width: 1320px;
    padding: 0 28px;
  }

  /* ── LEFT — Nav Links ── */
  .nav-left {
    display: flex;
    align-items: center;
    gap: 2px;
    z-index: 2;
    flex: 1;
  }
  .nav-left .nav-link {
    font-size: 14.5px;
    font-weight: 500;
    color: rgba(255,255,255,.65) !important;
    padding: 6px 13px !important;
    border-radius: 8px;
    transition: color .2s, background .2s;
    white-space: nowrap;
  }
  .nav-left .nav-link:hover,
  .nav-left .nav-link.active {
    color: var(--gold-lt) !important;
    /* background: rgba(200,134,10,.1); */
  }

  /* ── CENTER — Logo (absolute so it never shifts sides) ── */
  .nav-logo-wrap {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    pointer-events: none;
  }
  .nav-logo-wrap a {
    pointer-events: all;
    display: block;
  }
  .nav-logo-wrap img {
    height: 148px;
    width: auto;
    display: block;
    filter: drop-shadow(0 2px 6px rgba(200,134,10,.25));
    transition: transform .35s cubic-bezier(.34,1.56,.64,1);
    margin-top: 14px;
  }
  .nav-logo-wrap img:hover { transform: scale(1.07) rotate(-4deg); }

  /* ── RIGHT — Location · Sign In · Cart ── */
  .nav-right {
    display: flex;
    align-items: center;
    gap: 6px;
    z-index: 2;
    margin-left: auto;
  }

  /* ── LOCATION PILL ── */
  .loc-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    background: rgba(200,134,10,.1) !important;
    border: 1.5px solid rgba(200,134,10,.3) !important;
    border-radius: 999px !important;
    padding: 5px 13px 5px 9px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--gold-lt) !important;
    transition: all .22s ease !important;
    cursor: pointer;
    text-decoration: none;
  }
  .loc-btn:hover, .loc-btn.show {
    background: rgba(200,134,10,.2) !important;
    border-color: var(--gold) !important;
    color: #fff !important;
  }
  .loc-pulse {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--gold);
    position: relative;
    flex-shrink: 0;
  }
  .loc-pulse::before {
    content:'';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    border: 1.5px solid var(--gold);
    animation: pulse 1.8s ease-out infinite;
  }
  @keyframes pulse {
    0%   { transform: scale(1);   opacity: .8; }
    100% { transform: scale(2.4); opacity: 0;  }
  }
  .chevron-icon {
    width: 12px; height: 12px;
    transition: transform .28s cubic-bezier(.34,1.56,.64,1);
    flex-shrink: 0;
  }
  .loc-btn[aria-expanded="true"] .chevron-icon { transform: rotate(180deg); }

  /* ── LOC DROPDOWN ── */
  .bc-dropdown {
    min-width: 190px !important;
    background: var(--espresso2) !important;
    border: 1px solid rgba(200,134,10,.22) !important;
    border-radius: 14px !important;
    padding: 8px !important;
    margin-top: 10px !important;
    box-shadow: 0 16px 48px rgba(0,0,0,.55) !important;
  }
  .loc-option {
    display: flex; align-items: center; gap: 8px;
    width: 100%; padding: 9px 12px;
    border-radius: 9px;
    font-size: 13.5px;
    color: rgba(255,255,255,.7);
    background: none; border: none;
    cursor: pointer;
    font-family: var(--font-ui);
    transition: background .18s, color .18s, transform .18s;
    text-align: left;
  }
  .loc-option:hover { background: rgba(200,134,10,.15); color: var(--gold-lt); transform: translateX(3px); }
  .loc-option.active-loc { color: var(--gold-lt); background: rgba(200,134,10,.1); font-weight: 600; }
  .drop-label { font-size: 11px; color: var(--muted); letter-spacing: .5px; padding: 2px 12px 8px; }

  /* ── SIGN IN BTN ── */
  .signin-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,.7) !important;
    padding: 6px 13px !important;
    border-radius: 8px !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    background: transparent !important;
    transition: all .2s !important;
    text-decoration: none;
    white-space: nowrap;
  }
  .signin-btn:hover {
    color: #fff !important;
    border-color: rgba(255,255,255,.3) !important;
    background: rgba(255,255,255,.06) !important;
  }

  /* ── CART BTN ── */
  .cart-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 7px;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #fff !important;
    padding: 7px 16px !important;
    border-radius: 9px !important;
    background: linear-gradient(135deg, var(--red), var(--red-dk)) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(174,55,55,.35);
    transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s !important;
    text-decoration: none;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
  }
  .cart-btn::before {
    content:'';
    position: absolute;
    top: 0; left: -80%;
    width: 60%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.15), transparent);
    transform: skewX(-15deg);
    transition: left .45s ease;
  }
  .cart-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(174,55,55,.5) !important; color: #fff !important; }
  .cart-btn:hover::before { left: 140%; }
  .cart-badge {
    background: var(--gold);
    color: #111;
    font-size: 10px; font-weight: 700;
    width: 17px; height: 17px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
  }

  /* ── MOBILE TOGGLER ── */
  .bc-toggler {
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 40px; height: 40px;
    border-radius: 9px;
    border: 1.5px solid rgba(200,134,10,.3) !important;
    background: rgba(200,134,10,.08) !important;
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
    box-shadow: none !important;
    margin-left: 10px;
  }
  .bc-toggler:hover { background: rgba(200,134,10,.18) !important; border-color: var(--gold) !important; }
  .tog-bar {
    display: block;
    width: 19px; height: 2px;
    border-radius: 2px;
    background: var(--gold-lt);
    transition: transform .28s ease, opacity .28s ease, width .28s ease;
  }

  /* ════════════════════════════
     OFFCANVAS — MOBILE MENU
  ════════════════════════════ */
  .bc-offcanvas {
    width: 300px !important;
    background: var(--espresso2) !important;
    border-right: 1px solid rgba(200,134,10,.18) !important;
  }
  .oc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0px 10px 0px;
    border-bottom: 1px solid rgba(200,134,10,.15);
  }
  .oc-header img { height: 76px; width: auto; }
  .oc-close {
    width: 34px; height: 34px;
    border-radius: 8px;
    border: 1.5px solid rgba(255,255,255,.1);
    background: transparent;
    color: rgba(255,255,255,.6);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: all .2s;
    padding: 0;
  }
  .oc-close:hover { background: rgba(255,255,255,.07); color: #fff; border-color: rgba(255,255,255,.25); }
  .oc-body { padding: 20px 16px 28px; overflow-y: auto; }

  /* OC nav links */
  .oc-nav { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 3px; }
  .oc-nav a {
    display: flex; align-items: center; gap: 11px;
    padding: 11px 14px;
    border-radius: 10px;
    font-size: 15px; font-weight: 500;
    color: rgba(255,255,255,.7);
    text-decoration: none;
    transition: background .18s, color .18s, transform .18s;
  }
  .oc-nav a:hover, .oc-nav a.active {
    background: rgba(200,134,10,.12);
    color: var(--gold-lt);
    transform: translateX(3px);
  }
  .oc-nav svg { width: 18px; height: 18px; flex-shrink: 0; }

  .oc-divider { height: 1px; background: rgba(255,255,255,.07); margin: 16px 0; }
  .oc-section-label { font-size: 11px; color: var(--muted); letter-spacing: .6px; margin-bottom: 10px; padding: 0 4px; }
  .oc-loc-list { display: flex; flex-direction: column; gap: 3px; }

  /* OC auth */
  .oc-auth-title { font-size: 14px; font-weight: 600; color: #fff; margin: 0 0 14px; }
  .oc-input {
    width: 100%; padding: 9px 13px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 9px;
    color: #fff; font-size: 13.5px;
    font-family: var(--font-ui);
    outline: none;
    transition: border-color .2s, background .2s;
    margin-bottom: 10px;
    display: block;
  }
  .oc-input::placeholder { color: rgba(255,255,255,.35); }
  .oc-input:focus { border-color: rgba(200,134,10,.5); background: rgba(200,134,10,.05); }
  .oc-forgot { font-size: 12px; color: var(--gold-lt); text-decoration: none; display: block; margin-bottom: 12px; }
  .oc-signin-btn {
    width: 100%; padding: 10px;
    background: linear-gradient(135deg, var(--gold), #e09820);
    border: none; border-radius: 9px;
    font-size: 14px; font-weight: 600;
    color: #1a0800; cursor: pointer;
    transition: transform .2s, box-shadow .2s;
  }
  .oc-signin-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(200,134,10,.35); }

  /* OC cart */
  .oc-cart {
    display: flex; align-items: center; gap: 10px;
    width: 100%; padding: 12px 16px;
    background: linear-gradient(135deg, var(--red), var(--red-dk));
    border: none; border-radius: 10px;
    font-size: 14px; font-weight: 600;
    color: #fff; cursor: pointer;
    text-decoration: none;
    margin-top: 16px;
    transition: transform .2s, box-shadow .2s;
  }
  .oc-cart:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(174,55,55,.45); color: #fff; }

  /* ── MOBILE LAYOUT ── */
  @media (max-width: 991px) {
    .bc-nav .container { height: 62px; padding: 0 16px; }
    .nav-left  { display: none !important; }
    .nav-right { display: none !important; }
    .nav-logo-wrap {
      position: static;
      transform: none;
      pointer-events: all;
      /* flex: 1; */
      display: flex;
      justify-content: center;
    }
    .bc-nav {
    background: var(--espresso) !important;
    border-bottom: 1px solid rgba(200, 134, 10, 0.2);
    font-family: var(--font-ui);
    position: sticky;
    top: 0;
    z-index: 1000;
    transition: background .35s ease, box-shadow .35s ease;
    padding: 0px 0px !important;
}
    .nav-logo-wrap img { height: 81px;
        margin-top: -9px;  }
    .bc-toggler { display: flex !important; }
  }
  @media (min-width: 992px) {
    .bc-toggler { display: none !important; }
  }
/*hero section*/

  
      /* ══════════════════════════════
       HERO SECTION
    ══════════════════════════════ */
    .bc-hero {
      min-height: 100vh;
      /*background: linear-gradient(160deg, #F4EFE4 0%, #EDE5D0 60%, #E5D9BF 100%);*/
      background-color: #F5EBDD;
      display: flex;
      align-items: center;
      padding: 2rem 0 4rem;
      position: relative;
      overflow: hidden;
    }
 
    /* Decorative background blobs */
    .bc-hero::before {
      content: '';
      position: absolute;
      top: -100px; right: -100px;
      width: 500px; height: 500px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(200,134,10,0.08) 0%, transparent 65%);
      pointer-events: none;
    }
    .bc-hero::after {
      content: '';
      position: absolute;
      bottom: -80px; left: -80px;
      width: 400px; height: 400px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(200,134,10,0.06) 0%, transparent 65%);
      pointer-events: none;
    }
 
    /* ══ LEFT CONTENT ══ */
 
    /* EST Badge */
    .bc-est-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      border: 1.5px solid rgba(200,134,10,0.4);
      border-radius: 50px;
      padding: 0.45rem 1.2rem;
      font-size: 0.68rem;
      font-weight: 600;
      color: var(--brown);
      letter-spacing: 2.5px;
      text-transform: uppercase;
      margin-bottom: 1.8rem;
      background: rgba(200,134,10,0.06);
      opacity: 0;
      animation: bc-fadeUp 0.7s ease 0.1s forwards;
    }
    .bc-est-badge .bc-dot {
      width: 7px; height: 7px;
      border-radius: 50%;
      background: var(--gold);
      flex-shrink: 0;
      box-shadow: 0 0 0 3px rgba(200,134,10,0.2);
    }
 
    /* Heading */
    .bc-hero-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(2.8rem, 5.5vw, 3.5rem);
      line-height: 1.06;
      color: var(--dark);
      margin-bottom: 1.5rem;
      opacity: 0;
      animation: bc-fadeUp 0.8s ease 0.25s forwards;
    }
    .bc-hero-heading .bc-italic {
      font-style: italic;
      font-family: 'Instrument Serif', serif;
    }
    .bc-hero-heading .bc-gold {
      color: var(--gold);
      font-style: italic;
      font-family: 'Instrument Serif', serif;
      position: relative;
      display: inline-block;
    }
    /* underline accent on gold text */
    .bc-hero-heading .bc-gold::after {
      content: '';
      position: absolute;
      bottom: 2px; left: 0; right: 0;
      height: 3px;
      background: linear-gradient(90deg, var(--gold), transparent);
      border-radius: 2px;
    }
 
    /* Sub paragraph */
    .bc-hero-sub {
      font-size: 0.92rem;
      color: var(--muted);
      line-height: 1.85;
      max-width: 430px;
      margin-bottom: 2.2rem;
      font-weight: 300;
      opacity: 0;
      animation: bc-fadeUp 0.8s ease 0.4s forwards;
    }
 
    /* CTA Buttons */
    .bc-hero-btns {
      display: flex;
      gap: 1rem;
      flex-wrap: wrap;
      margin-bottom: 2.8rem;
      opacity: 0;
      animation: bc-fadeUp 0.8s ease 0.55s forwards;
    }
    .bc-btn-order {
      background: var(--dark);
      color: #fff;
      border: none;
      border-radius: 50px;
      padding: 0.85rem 2rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.9rem;
      font-weight: 600;
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      cursor: pointer;
      text-decoration: none;
      transition: all 0.3s ease;
      box-shadow: 0 4px 20px rgba(28,18,8,0.2);
    }
    .bc-btn-order:hover {
      background: var(--brown);
      transform: translateY(-3px);
      box-shadow: 0 12px 32px rgba(28,18,8,0.3);
      color: #fff;
    }
    .bc-btn-bolt {
      background: var(--gold);
      color: var(--dark);
      width: 24px; height: 24px;
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 0.65rem;
      flex-shrink: 0;
      transition: transform 0.3s;
    }
    .bc-btn-order:hover .bc-btn-bolt { transform: rotate(15deg) scale(1.1); }
 
    .bc-btn-store {
      background: transparent;
      color: var(--dark);
      border: 1.5px solid rgba(28,18,8,0.22);
      border-radius: 50px;
      padding: 0.85rem 2rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.9rem;
      font-weight: 500;
      display: inline-flex;
      align-items: center;
      gap: 0.55rem;
      cursor: pointer;
      text-decoration: none;
      transition: all 0.3s ease;
    }
    .bc-btn-store:hover {
      border-color: var(--gold);
      color: var(--gold);
      transform: translateY(-3px);
      background: rgba(200,134,10,0.05);
    }
    .bc-btn-store i { color: var(--gold); font-size: 0.8rem; }
 
    /* Stats */
    .bc-stats-row {
      display: flex;
      gap: 0;
      border-top: 1px solid rgba(28,18,8,0.1);
      padding-top: 1.6rem;
      opacity: 0;
      animation: bc-fadeUp 0.8s ease 0.7s forwards;
    }
    .bc-stat-item {
      padding-right: 2.2rem;
      margin-right: 2.2rem;
      border-right: 1px solid rgba(28,18,8,0.1);
    }
    .bc-stat-item:last-child { border-right: none; margin-right: 0; padding-right: 0; }
    .bc-stat-num {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.8rem;
      font-weight: 700;
      color: var(--dark);
      display: block;
      line-height: 1;
    }
    .bc-stat-num sup { font-size: 1rem; color: var(--gold); }
    .bc-stat-label {
      font-size: 0.6rem;
      font-weight: 600;
      color: var(--muted);
      letter-spacing: 1.8px;
      text-transform: uppercase;
      margin-top: 0.3rem;
      display: block;
      line-height: 1.5;
    }
 
    /* ══ RIGHT CARD AREA ══ */
    .bc-hero-right {
      position: relative;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 2rem 1.5rem 2rem 1rem;
      opacity: 0;
      animation: bc-fadeRight 0.9s ease 0.3s forwards;
    }
 
    /* Feature card */
    .bc-feature-card {
      width: min(340px, 88vw);
      border-radius: 28px;
      overflow: hidden;
      position: relative;
      box-shadow:
        0 40px 80px rgba(28,18,8,0.2),
        0 0 0 1px rgba(255,255,255,0.5);
      flex-shrink: 0;
    }
    .bc-feature-card img {
      width: 100%;
      height: 460px;
      object-fit: cover;
      display: block;
      transition: transform 0.6s ease;
    }
    .bc-feature-card:hover img { transform: scale(1.04); }
 
    /* Dark gradient overlay */
    .bc-card-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to bottom, rgba(0,0,0,0.05) 40%, rgba(20,10,3,0.88) 100%);
    }
 
    /* Bestseller pill */
    .bc-badge-bestseller {
      position: absolute;
      top: 16px; right: 16px;
      background: var(--gold);
      color: #fff;
      border-radius: 50px;
      padding: 0.32rem 0.85rem;
      font-size: 0.6rem;
      font-weight: 700;
      letter-spacing: 1px;
      text-transform: uppercase;
      display: flex; align-items: center; gap: 0.3rem;
      z-index: 5;
      box-shadow: 0 4px 12px rgba(200,134,10,0.4);
    }
 
    /* Card bottom content */
    .bc-card-bottom {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: 1.6rem 1.4rem;
      z-index: 4;
    }
    .bc-card-label {
      font-size: 0.58rem;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--gold-light);
      font-weight: 600;
      margin-bottom: 0.5rem;
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
    .bc-card-label::before {
      content: '';
      width: 18px; height: 1.5px;
      background: var(--gold-light);
    }
    .bc-card-title {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.45rem;
      font-weight: 700;
      color: #fff;
      margin-bottom: 0.3rem;
      line-height: 1.2;
    }
    .bc-card-price {
      font-size: 0.88rem;
      color: var(--gold-light);
      font-weight: 500;
    }
 
    /* ── Floating badge: Rating ── */
    .bc-badge-rating {
      position: absolute;
      top: 24px;
      left: -16px;
      background: var(--white);
      border-radius: 16px;
      padding: 0.6rem 1rem;
      box-shadow: 0 10px 40px rgba(28,18,8,0.15);
      display: flex;
      flex-direction: column;
      gap: 0.15rem;
      z-index: 10;
      min-width: 96px;
      animation: bc-floatY 4s ease-in-out 1s infinite;
    }
    .bc-badge-rating .bc-r-label {
      font-size: 0.52rem;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: var(--muted);
      font-weight: 600;
    }
    .bc-badge-rating .bc-r-val {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.05rem;
      font-weight: 700;
      color: var(--dark);
      display: flex;
      align-items: center;
      gap: 0.35rem;
    }
    .bc-badge-rating .bc-r-val i { color: #F5A623; font-size: 0.82rem; }
 
    /* ── Floating badge: Scoop ── */
    .bc-badge-scoop {
      position: absolute;
      bottom: 90px;
      right: -16px;
      background: var(--white);
      border-radius: 16px;
      padding: 0.7rem 1rem;
      box-shadow: 0 10px 40px rgba(28,18,8,0.15);
      z-index: 10;
      min-width: 138px;
      animation: bc-floatY 4s ease-in-out 1.8s infinite;
    }
    .bc-badge-scoop .bc-s-label {
      font-size: 0.5rem;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: var(--muted);
      font-weight: 600;
      margin-bottom: 0.2rem;
      display: flex;
      align-items: center;
      gap: 0.3rem;
    }
    .bc-badge-scoop .bc-s-name {
      font-family: 'Libre Baskerville', serif;
      font-size: 0.9rem;
      font-weight: 700;
      color: var(--dark);
    }
 
    /* ══ ANIMATIONS ══ */
    @keyframes bc-fadeUp {
      from { opacity: 0; transform: translateY(32px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    @keyframes bc-fadeRight {
      from { opacity: 0; transform: translateX(40px); }
      to   { opacity: 1; transform: translateX(0); }
    }
    @keyframes bc-floatY {
      0%, 100% { transform: translateY(0); }
      50%       { transform: translateY(-10px); }
    }
 
    /* ══════════════════════════════
       RESPONSIVE
    ══════════════════════════════ */
 
    /* Tablet (768–991px) */
    @media (max-width: 991.98px) {
      .bc-hero {
        padding: 5.5rem 0 4rem;
        min-height: auto;
        text-align: center;
      }
      .bc-est-badge { margin: 0 auto 1.8rem; }
      .bc-hero-sub   { max-width: 100%; margin: 0 auto 2.2rem; }
      .bc-hero-btns  { justify-content: center; }
      .bc-stats-row  { justify-content: center; }
 
      .bc-hero-right {
        margin-top: 4rem;
        padding: 1.5rem 2rem;
        opacity: 1; animation: none;
      }
      .bc-badge-rating { left: 12px; }
      .bc-badge-scoop  { right: 12px; }
      .bc-feature-card { width: min(340px, 78vw); }
      .bc-feature-card img { height: 400px; }
    }
 
    /* Mobile (576–767px) */
    @media (max-width: 767.98px) {
      .bc-hero { padding: 5rem 0 3.5rem; }
 
      .bc-hero-heading { font-size: clamp(2rem, 8vw, 2.8rem); }
      .bc-hero-sub     { font-size: 0.86rem; }
 
      .bc-btn-order, .bc-btn-store {
        font-size: 0.86rem;
        padding: 0.75rem 1.6rem;
      }
 
      .bc-stat-num   { font-size: 1.5rem; }
      .bc-stat-item  { padding-right: 1.5rem; margin-right: 1.5rem; }
 
      .bc-hero-right { margin-top: 3rem; padding: 1rem 1.5rem; }
      .bc-feature-card { width: min(300px, 82vw); }
      .bc-feature-card img { height: 360px; }
 
      .bc-badge-rating { left: 6px; top: 14px; }
      .bc-badge-scoop  { right: 6px; bottom: 70px; }
    }
 
    /* Small Mobile (< 576px) */
    @media (max-width: 575.98px) {
      .bc-hero { padding: 1.5rem 0 3rem !important; }
 
      .bc-est-badge { font-size: 0.6rem; letter-spacing: 1.8px; }
 
      .bc-hero-heading {
        font-size: clamp(1.9rem, 9vw, 2.4rem);
        line-height: 1.1;
      }
 
      .bc-hero-sub {
        font-size: 0.82rem;
        line-height: 1.8;
      }
      .bc-hero-sub br { display: none; }
 
      .bc-hero-btns {
        flex-direction: column;
        align-items: center;
        gap: 0.8rem;
      }
      .bc-btn-order, .bc-btn-store {
        width: 100%;
        max-width: 280px;
        justify-content: center;
      }
 
      .bc-stat-num   { font-size: 1.3rem; }
      .bc-stat-item  { padding-right: 1.1rem; margin-right: 1.1rem; }
      .bc-stat-label { font-size: 0.55rem; letter-spacing: 1px; }
 
      .bc-hero-right { margin-top: 2.5rem; padding: 1rem; }
      .bc-feature-card {
        width: min(270px, 86vw);
        border-radius: 22px;
      }
      .bc-feature-card img { height: 320px; }
 
      .bc-badge-rating {
        left: 4px; top: 10px;
        min-width: 82px;
        padding: 0.5rem 0.75rem;
      }
      .bc-badge-rating .bc-r-val { font-size: 0.9rem; }
 
      .bc-badge-scoop {
        right: 4px; bottom: 58px;
        min-width: 118px;
        padding: 0.55rem 0.75rem;
      }
 
      .bc-badge-bestseller {
        font-size: 0.55rem;
        padding: 0.25rem 0.65rem;
      }
 
      .bc-card-title { font-size: 1.2rem; }
      .bc-card-bottom { padding: 1.2rem; }
    }
 @keyframes bc-bounceUp {
  0%   { opacity: 0; transform: translateY(40px); }
  55%  { opacity: 1; transform: translateY(-12px); }
  75%  { transform: translateY(6px); }
  90%  { transform: translateY(-4px); }
  100% { opacity: 1; transform: translateY(0); }
}

.bc-est-badge {
  /* ... same ... */
  animation: bc-bounceUp 0.8s cubic-bezier(0.36, 0.07, 0.19, 0.97) 0.1s forwards;
}

.bc-hero-heading {
  /* ... same ... */
  animation: bc-bounceUp 0.85s cubic-bezier(0.36, 0.07, 0.19, 0.97) 0.25s forwards;
}

.bc-hero-sub {
  /* ... same ... */
  animation: bc-bounceUp 0.85s cubic-bezier(0.36, 0.07, 0.19, 0.97) 0.4s forwards;
}

.bc-hero-btns {
  /* ... same ... */
  animation: bc-bounceUp 0.85s cubic-bezier(0.36, 0.07, 0.19, 0.97) 0.55s forwards;
}

.bc-stats-row {
  /* ... same ... */
  animation: bc-bounceUp 0.85s cubic-bezier(0.36, 0.07, 0.19, 0.97) 0.7s forwards;
}
    /* Very Small (< 360px) */
    @media (max-width: 359px) {
      .bc-hero-heading { font-size: 1.65rem; }
      .bc-feature-card { width: 90vw; }
      .bc-feature-card img { height: 280px; }
      .bc-stat-item { padding-right: 0.8rem; margin-right: 0.8rem; }
    }



     
    
    /*location section*/
        /* ══════════════════════════ 
       TICKER / MARQUEE STRIP
    ══════════════════════════ */
    .ticker-wrap {
      background: var(--dark-bg);
      border-bottom: 1px solid var(--border);
      overflow: hidden;
      padding: 0.65rem 0;
      position: relative;
    }

    /* fade edges */
    .ticker-wrap::before,
    .ticker-wrap::after {
      content: '';
      position: absolute;
      top: 0; bottom: 0;
      width: 80px;
      z-index: 2;
      pointer-events: none;
    }
    .ticker-wrap::before {
      left: 0;
      background: linear-gradient(to right, var(--dark-bg), transparent);
    }
    .ticker-wrap::after {
      right: 0;
      background: linear-gradient(to left, var(--dark-bg), transparent);
    }

    .ticker-track {
      display: flex;
      gap: 0;
      width: max-content;
      animation: ticker-scroll 28s linear infinite;
    }
    .ticker-track:hover { animation-play-state: paused; }

    .ticker-item {
      display: inline-flex;
      align-items: center;
      gap: 0.6rem;
      white-space: nowrap;
      font-size: 0.72rem;
      font-weight: 600;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: rgba(244,239,228,0.75);
      padding: 0 2rem;
    }
    .ticker-dot {
      width: 6px; height: 6px;
      border-radius: 50%;
      background: var(--gold);
      flex-shrink: 0;
    }
    .ticker-item:hover { color: var(--gold-light); }

    @keyframes ticker-scroll {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    /* ══════════════════════════
       STORE FINDER SECTION
    ══════════════════════════ */
    .store-finder {
      background: var(--dark-mid);
      padding: 2rem 0;
      border-bottom: 1px solid var(--border);
    }

    /* Left — title */
    .finder-title {
      display: flex;
      align-items: flex-start;
      flex-direction: column;
      gap: 0.25rem;
    }
    .finder-title h5 {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.05rem;
      font-weight: 700;
      color: var(--cream);
      display: flex;
      align-items: center;
      gap: 0.5rem;
      margin: 0;
    }
    .finder-title h5 i { color: var(--gold); font-size: 0.95rem; }
    .finder-title p {
      font-size: 0.75rem;
      color: var(--text-dim);
      font-weight: 300;
      margin: 0;
      padding-left: 1.4rem;
    }

    /* Center — search bar */
    .finder-search {
      display: flex;
      align-items: center;
      background: rgba(255,255,255,0.06);
      border: 1.5px solid rgba(255,255,255,0.1);
      border-radius: 50px;
      overflow: hidden;
      transition: border-color 0.25s;
    }
    .finder-search:focus-within {
      border-color: var(--gold);
    }
    .finder-search .search-icon {
      padding: 0 0.9rem 0 1.2rem;
      color: rgba(244,239,228,0.35);
      font-size: 0.82rem;
      flex-shrink: 0;
    }
    .finder-search input {
      flex: 1;
      background: transparent;
      border: none;
      outline: none;
      color: var(--cream);
      font-family: 'Poppins', sans-serif;
      font-size: 0.85rem;
      font-weight: 400;
      padding: 0.75rem 0.5rem;
      min-width: 0;
    }
    .finder-search input::placeholder {
      color: rgba(244,239,228,0.3);
    }
    .btn-search {
      background: var(--cream);
      color: var(--dark-bg);
      border: none;
      border-radius: 50px;
      padding: 0.65rem 1.4rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.82rem;
      font-weight: 700;
      margin: 4px;
      cursor: pointer;
      transition: all 0.25s;
      white-space: nowrap;
      flex-shrink: 0;
    }
    .btn-search:hover {
      background: var(--gold-light);
      color: #fff;
      transform: scale(1.03);
    }

    /* Right — Use My Location */
    .btn-location {
      background: transparent;
      border: 1.5px solid var(--gold);
      color: var(--gold);
      border-radius: 50px;
      padding: 0.68rem 1.3rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.82rem;
      font-weight: 600;
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      cursor: pointer;
      transition: all 0.25s;
      white-space: nowrap;
    }
    .btn-location:hover {
      background: var(--gold);
      color: #fff;
      transform: translateY(-1px);
      box-shadow: 0 4px 20px rgba(200,134,10,0.3);
    }
    .btn-location i { font-size: 0.78rem; }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */

    /* Tablet */
    @media (max-width: 991.98px) {
      .store-finder .row {
        gap: 1.2rem;
      }
      .finder-title {
        text-align: center;
        align-items: center;
      }
      .finder-title p { padding-left: 0; }
    }

    /* Mobile */
    @media (max-width: 767.98px) {
      .store-finder { padding: 1.8rem 0; }

      .finder-title h5 { font-size: 0.95rem; }
      .finder-title p  { font-size: 0.7rem; }

      .finder-search { width: 100%; }

      .btn-location {
        width: 100%;
        justify-content: center;
      }

      /* Stack all 3 sections vertically */
      .finder-cols {
        flex-direction: column;
        align-items: center;
        gap: 1rem;
      }
      .finder-col-title,
      .finder-col-search,
      .finder-col-btn {
        width: 100%;
        display: flex;
        justify-content: center;
      }
      .finder-col-search { max-width: 480px; }
      .finder-col-btn    { max-width: 240px; }
    }

    /* Small mobile */
    @media (max-width: 575.98px) {
      .ticker-item {
        font-size: 0.65rem;
        letter-spacing: 1.5px;
        padding: 0 1.4rem;
      }

      .finder-search input { font-size: 0.8rem; }
      .btn-search { padding: 0.55rem 1.1rem; font-size: 0.78rem; }
      .btn-location { font-size: 0.78rem; padding: 0.6rem 1.1rem; }
    }

    /*what are you section*/
        /* ══════════════════════════
       SECTION
    ══════════════════════════ */
    .menu-section {
      padding: 4rem 0 5rem;
      background: #fff !important;
    }

    /* ── Tag ── */
    .section-tag {
      font-size: 0.68rem;
      font-weight: 600;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.6rem;
      display: block;
    }

    /* ── Heading ── */
    .section-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(1.7rem, 3.5vw, 2.3rem);
      font-weight: 700;
      color: var(--dark);
      line-height: 1.15;
      margin-bottom: 0;
    }
    .section-heading .highlight {
      color: var(--gold);
      font-style: italic;
    }

    /* Gold underline below heading */
    .heading-line {
      width: 36px;
      height: 3px;
      background: var(--gold);
      border-radius: 2px;
      margin-top: 0.7rem;
    }

    /* ── Filter Tabs ── */
    .filter-tabs {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex-wrap: wrap;
    }
    .filter-btn {
      background: transparent;
      border: 1.5px solid var(--border);
      color: var(--dark);
      border-radius: 50px;
      padding: 0.45rem 1.15rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.82rem;
      font-weight: 500;
      cursor: pointer;
      transition: all 0.22s ease;
      white-space: nowrap;
    }
    .filter-btn:hover {
      border-color: var(--gold);
      color: var(--gold);
    }
    .filter-btn.active {
      background: var(--dark);
      border-color: var(--dark);
      color: #fff;
    }

    /* ══════════════════════════
       CATEGORY CARDS
    ══════════════════════════ */
    .category-card {
      background: var(--card-bg);
      border-radius: 18px;
      padding: 2rem 1rem 1.5rem;
      text-align: center;
      cursor: pointer;
      transition: all 0.28s ease;
      border: 1.5px solid transparent;
      height: 100%;
    }
      .category-card-1 {
      background: var(--card-bg);
      border-radius: 18px;
      padding: 2rem 1rem 1.5rem;
      text-align: center;
      cursor: pointer;
      transition: all 0.28s ease;
      border: 1.5px solid transparent;
      height: 100%;
      box-shadow: 10px;
    }

    .category-card:hover {
      transform: translateY(-6px);
      border-color: var(--border);
      box-shadow: 0 16px 48px rgba(28,18,8,0.1);
    }
    .category-card.active-card {
      border-color: #fff !important;
      box-shadow: 0 8px 30px rgba(200,134,10,0.12);
    }

    /* Circle image */
    .cat-img-wrap {
      width: 90px;
      height: 90px;
      border-radius: 50%;
      overflow: hidden;
      margin: 0 auto 1.1rem;
      background: var(--cream);
      flex-shrink: 0;
    }
    .cat-img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform 0.35s ease;
    }
    .category-card:hover .cat-img-wrap img {
      transform: scale(1.08);
    }

    /* Card text */
    .cat-name {
      font-family: 'Libre Baskerville', serif;
      font-size: 0.95rem;
      font-weight: 700;
      color: #fff;
      margin-bottom: 0.2rem;
    }
    .cat-count {
      font-size: 0.72rem;
      color: var(--text-muted);
      font-weight: 400;
    }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */

    /* Tablet */
    @media (max-width: 991.98px) {
      .menu-section { padding: 3rem 0 4rem; }

      .filter-tabs {
        justify-content: flex-start;
        margin-top: 1.2rem;
      }
    }

    /* Mobile */
    @media (max-width: 767.98px) {
      .section-heading { font-size: 1.6rem; }

      .filter-tabs {
        gap: 0.4rem;
        margin-top: 1rem;
      }
      .filter-btn {
        font-size: 0.76rem;
        padding: 0.38rem 0.9rem;
      }

      .cat-img-wrap { width: 75px; height: 75px; }
      .cat-name { font-size: 0.88rem; }
    }

    /* Small mobile */
    @media (max-width: 575.98px) {
      .menu-section { padding: 2.5rem 0 3rem; }
      .section-heading { font-size: 1.45rem; }

      .cat-img-wrap { width: 68px; height: 68px; }
      .category-card { padding: 1.4rem 0.6rem 1.2rem; border-radius: 14px; }
    }


    /*dfsd*/
        /* ══════════════════════════
       SECTION
    ══════════════════════════ */
    .toppicks-section {
      padding: 4.5rem 0 5rem;
      background: #F5EBDD;
    }

    /* ── Tag ── */
    .section-tag {
      font-size: 0.68rem;
      font-weight: 600;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--gold);
      display: block;
      margin-bottom: 0.5rem;
    }

    /* ── Heading ── */
    .section-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(1.7rem, 3.5vw, 2.3rem);
      font-weight: 700;
      color: var(--dark);
      line-height: 1.15;
      margin-bottom: 0;
    }
    .section-heading .highlight {
      color: var(--gold);
      font-style: italic;
    }
    .heading-line {
      width: 36px;
      height: 3px;
      background: var(--gold);
      border-radius: 2px;
      margin-top: 0.7rem;
    }

    /* ── Explore Button ── */
    .btn-explore {
      background: transparent;
      border: 1.5px solid var(--dark);
      color: var(--dark);
      border-radius: 50px;
      padding: 0.6rem 1.5rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.85rem;
      font-weight: 500;
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      cursor: pointer;
      text-decoration: none;
      transition: all 0.25s;
      white-space: nowrap;
    }
    .btn-explore:hover {
      background: var(--dark);
      color: #fff;
      transform: translateX(3px);
    }
    .btn-explore i { font-size: 0.8rem; transition: transform 0.25s; }
    .btn-explore:hover i { transform: translateX(4px); }

    /* ══════════════════════════
       PRODUCT CARD
    ══════════════════════════ */
    .product-card {
      background: #fff;
      border-radius: 20px;
      overflow: hidden;
      border: 1.5px solid transparent;
      transition: all 0.3s ease;
      height: 100%;
      display: flex;
      flex-direction: column;
      box-shadow: 0 20px 60px rgba(28,18,8,0.1);
    }
    .product-card:hover {
      transform: translateY(-6px);
      border-color: var(--border);
      box-shadow: 0 20px 60px rgba(28,18,8,0.1);
    }

    /* ── Card Image ── */
    .card-img-wrap {
      position: relative;
      overflow: hidden;
      height: 220px;
      flex-shrink: 0;
    }
    .card-img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform 0.4s ease;
    }
    .product-card:hover .card-img-wrap img {
      transform: scale(1.06);
    }

    /* ── Badge on image ── */
    .img-badge {
      position: absolute;
      top: 12px;
      left: 12px;
      border-radius: 50px;
      padding: 0.28rem 0.75rem;
      font-size: 0.65rem;
      font-weight: 700;
      letter-spacing: 0.5px;
      display: flex;
      align-items: center;
      gap: 0.3rem;
      z-index: 2;
    }
    .img-badge.bestseller { background: #1C1208; color: #fff; }
    .img-badge.new        { background: #2D5A1B; color: #fff; }
    .img-badge.loved      { background: #8B1A2E; color: #fff; }
    .img-badge.value      { background: #C8860A; color: #fff; }

    /* ── Card Body ── */
    .card-body-custom {
      padding: 1.1rem 1.2rem 1.3rem;
      display: flex;
      flex-direction: column;
      flex: 1;
    }

    /* Stars row */
    .stars-row {
      display: flex;
      align-items: center;
      gap: 0.3rem;
      margin-bottom: 0.5rem;
    }
    .stars {
      display: flex;
      gap: 1px;
    }
    .stars i {
      color: var(--star);
      font-size: 0.68rem;
    }
    .review-count {
      font-size: 0.7rem;
      color: #fff;
      font-weight: 400;
    }

    /* Product name */
    .product-name {
      font-family: 'Libre Baskerville', serif;
      font-size: 1rem;
      font-weight: 700;
      color: #2B1B17  !important;
      margin-bottom: 0.45rem;
      line-height: 1.3;
    }

    /* Description */
    .product-desc {
      font-size: 0.77rem;
      color: #6F5E57;
      font-weight: 300;
      line-height: 1.65;
      flex: 1;
      margin-bottom: 1.1rem;
    }

    /* Price + Add row */
    .card-footer-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-top: auto;
    }
    .product-price {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.2rem;
      font-weight: 700;
      color: var(--dark2);

    }
    .btn-add {
      background: var(--dark);
      color: #fff;
      border: none;
      border-radius: 50px;
      padding: 0.5rem 1.2rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.8rem;
      font-weight: 600;
      cursor: pointer;
      transition: all 0.25s;
      display: flex;
      align-items: center;
      gap: 0.35rem;
    }
    .btn-add:hover {
      background: var(--gold);
      transform: scale(1.05);
    }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media (max-width: 991.98px) {
      .toppicks-section { padding: 3rem 0 4rem; }
      .btn-explore { margin-top: 1rem; }
      .card-img-wrap { height: 200px; }
    }

    @media (max-width: 767.98px) {
      .section-heading { font-size: 1.65rem; }
      .card-img-wrap { height: 190px; }
      .product-name { font-size: 0.95rem; }
      .product-desc { font-size: 0.74rem; }
    }

    @media (max-width: 575.98px) {
      .toppicks-section { padding: 2.5rem 0 3rem; }
      .section-heading  { font-size: 1.45rem; }
      .card-img-wrap    { height: 180px; }
      .card-body-custom { padding: 0.9rem 1rem 1.1rem; }
      .product-price    { font-size: 1.05rem; }
      .btn-add          { padding: 0.42rem 1rem; font-size: 0.75rem; }
    }

    /*hot deals*/
        /* ══════════════════════════
       SECTION
    ══════════════════════════ */
    .bc-deals-section {
      background: var(--bc-bg);
      padding: 5rem 0 5.5rem;
    }

    /* ── Tag ── */
    .bc-section-tag {
      font-size: 0.68rem;
      font-weight: 600;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--bc-gold);
      display: block;
      text-align: center;
      margin-bottom: 0.7rem;
    }

    /* ── Heading ── */
    .bc-section-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(1.8rem, 4vw, 2.6rem);
      font-weight: 700;
      color: var(--bc-cream);
      text-align: center;
      line-height: 1.15;
      margin-bottom: 0;
    }
    .bc-section-heading .bc-highlight {
      color: var(--bc-gold);
      font-style: italic;
    }
    .bc-heading-line {
      width: 36px;
      height: 3px;
      background: var(--bc-gold);
      border-radius: 2px;
      margin: 0.9rem auto 0;
    }

    /* ══════════════════════════
       DEAL CARD
    ══════════════════════════ */
    .bc-deal-card {
      background: #3b2a25;
      border: 1.5px solid var(--bc-card-border);
      border-radius: 18px;
      padding: 1.8rem;
      position: relative;
      overflow: hidden;
      height: 100%;
      display: flex;
      flex-direction: column;
      transition: all 0.3s ease;
    }
    .bc-deal-card:hover {
      background: var(--bc-card-hover);
      border-color: rgba(200,134,10,0.4);
      transform: translateY(-5px);
      box-shadow: 0 20px 50px rgba(0,0,0,0.35);
    }

    /* ── Watermark ── */
    .bc-watermark {
      position: absolute;
      top: 50%;
      right: -10px;
      transform: translateY(-55%);
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(4.5rem, 8vw, 6.5rem);
      font-weight: 700;
      color: rgba(200,134,10,0.08);
      line-height: 1;
      pointer-events: none;
      user-select: none;
      white-space: nowrap;
    }

    /* ── Category pill ── */
    .bc-deal-pill {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      background: var(--bc-badge-bg);
      border: 1px solid rgba(200,134,10,0.25);
      border-radius: 50px;
      padding: 0.3rem 0.85rem;
      font-size: 0.68rem;
      font-weight: 600;
      color: var(--bc-gold-light);
      margin-bottom: 1.2rem;
      width: fit-content;
    }
    .bc-deal-pill i { font-size: 0.6rem; }

    /* ── Deal title ── */
    .bc-deal-title {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.1rem;
      font-weight: 700;
      color: #fff;
      margin-bottom: 0.65rem;
      line-height: 1.3;
      position: relative;
      z-index: 1;
    }

    /* ── Description ── */
    .bc-deal-desc {
      font-size: 0.77rem;
      color: var(--bc-text-dim);
      font-weight: 300;
      line-height: 1.7;
      flex: 1;
      margin-bottom: 1.5rem;
      position: relative;
      z-index: 1;
    }

    /* ── Coupon row ── */
    .bc-coupon-row {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      position: relative;
      z-index: 1;
    }
    .bc-coupon-code {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      background: rgba(200,134,10,0.12);
      border: 1.5px dashed rgba(200,134,10,0.45);
      border-radius: 8px;
      padding: 0.55rem 1rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.82rem;
      font-weight: 700;
      color: var(--bc-gold-light);
      letter-spacing: 1.5px;
      text-transform: uppercase;
      cursor: pointer;
      transition: all 0.2s;
      user-select: none;
    }
    .bc-coupon-code:hover {
      background: rgba(200,134,10,0.22);
      border-color: var(--bc-gold);
    }
    .bc-coupon-code i { font-size: 0.72rem; color: var(--bc-gold); }

    /* ── Copy tip ── */
    .bc-copy-tip {
      font-size: 0.68rem;
      color: var(--bc-gold);
      font-weight: 500;
      opacity: 0;
      transition: opacity 0.2s;
    }
    .bc-copy-tip.bc-show { opacity: 1; }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media (max-width: 991.98px) {
      .bc-deals-section { padding: 4rem 0 4.5rem; }
      .bc-watermark { font-size: 5rem; }
    }

    @media (max-width: 767.98px) {
      .bc-deals-section    { padding: 3rem 0 3.5rem; }
      .bc-section-heading  { font-size: 1.7rem; }
      .bc-deal-card        { padding: 1.5rem; }
      .bc-deal-title       { font-size: 1rem; }
    }

    @media (max-width: 575.98px) {
      .bc-deals-section   { padding: 2.5rem 0 3rem; }
      .bc-section-heading { font-size: 1.5rem; }
      .bc-deal-card       { padding: 1.3rem; border-radius: 14px; }
      .bc-watermark       { font-size: 4rem; right: -5px; }
      .bc-coupon-code     { font-size: 0.76rem; padding: 0.48rem 0.85rem; }
    }

    /*footer*/

    /* ══════════════════════════
       FOOTER MAIN
    ══════════════════════════ */
    .bc-footer {
      background: var(--bc-ft-bg);
      padding: 4rem 0 0;
    }

    /* ── Logo + Brand ── */
    .bc-ft-logo-row {
      display: flex;
      align-items: center;
      gap: 0.7rem;
      margin-bottom: 1.1rem;
    }
    .bc-ft-logo-img {
      width: 62px;
      height: 62px;
      border-radius: 50%;
      border: 2px solid var(--bc-ft-gold);
      background: #2A1A0A;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.7rem;
      flex-shrink: 0;
      overflow: hidden;
    }
    .bc-ft-logo-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: 50%;
    }
    .bc-ft-brand-main {
      font-family: 'Libre Baskerville', serif;
      font-size: 1.05rem;
      font-weight: 700;
      color: var(--bc-ft-cream);
      letter-spacing: 1px;
      display: block;
      line-height: 1.2;
    }
    .bc-ft-brand-sub {
      font-family: 'Great Vibes', cursive;
      font-size: 1.2rem;
      color: var(--bc-ft-gold);
      display: block;
      line-height: 1.4;
    }

    /* Tagline */
    .bc-ft-tagline {
      font-size: 0.78rem;
      color: var(--bc-ft-mid);
      font-weight: 300;
      line-height: 1.85;
      margin-bottom: 1.5rem;
    }

    /* Social icons */
    .bc-ft-socials {
      display: flex;
      gap: 0.45rem;
      flex-wrap: wrap;
    }
    .bc-ft-social {
      width: 34px;
      height: 34px;
      border-radius: 8px;
      border: 1px solid var(--bc-ft-border-t);
      background: rgba(255,255,255,0.05);
      color: var(--bc-ft-mid);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.76rem;
      text-decoration: none;
      transition: all 0.22s;
    }
    .bc-ft-social:hover {
      border-color: var(--bc-ft-gold);
      background: rgba(200,134,10,0.15);
      color: var(--bc-ft-gold);
      transform: translateY(-2px);
    }

    /* ── Column title ── */
    .bc-ft-col-ttl {
      font-size: 0.62rem;
      font-weight: 700;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--bc-ft-gold);
      margin-bottom: 1.3rem;
      display: block;
    }

    /* ── Links ── */
    .bc-ft-links {
      list-style: none;
      padding: 0; margin: 0;
      display: flex;
      flex-direction: column;
      gap: 0.65rem;
    }
    .bc-ft-links li a {
      font-size: 0.8rem;
      color: var(--bc-ft-mid);
      text-decoration: none;
      font-weight: 300;
      transition: all 0.2s;
    }
    .bc-ft-links li a:hover {
      color: var(--bc-ft-gold-lt);
      padding-left: 5px;
    }

    /* ── Newsletter ── */
    .bc-ft-news-sub {
      font-size: 0.76rem;
      color: var(--bc-ft-dim);
      font-weight: 300;
      line-height: 1.7;
      margin-bottom: 1rem;
    }
    .bc-ft-input-row {
      display: flex;
      margin-bottom: 1.8rem;
    }
    .bc-ft-email-inp {
      flex: 1;
      background: rgba(255,255,255,0.05);
      border: 1px solid rgba(255,255,255,0.1);
      border-right: none;
      border-radius: 8px 0 0 8px;
      padding: 0.6rem 0.9rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.76rem;
      color: var(--bc-ft-cream);
      outline: none;
      min-width: 0;
      transition: border-color 0.2s;
    }
    .bc-ft-email-inp::placeholder { color: var(--bc-ft-dim); }
    .bc-ft-email-inp:focus {
      border-color: var(--bc-ft-gold);
    }
    .bc-ft-go-btn {
      background: var(--bc-ft-gold);
      color: #fff;
      border: none;
      border-radius: 0 8px 8px 0;
      padding: 0.6rem 1.1rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.8rem;
      font-weight: 700;
      cursor: pointer;
      transition: background 0.2s;
      flex-shrink: 0;
    }
    .bc-ft-go-btn:hover { background: var(--bc-ft-gold-lt); }

    /* ── Get In Touch ── */
    .bc-ft-contact {
      list-style: none; padding: 0; margin: 0;
      display: flex; flex-direction: column; gap: 0.5rem;
    }
    .bc-ft-contact li {
      display: flex; align-items: center; gap: 0.55rem;
      font-size: 0.78rem;
      color: var(--bc-ft-mid);
    }
    .bc-ft-contact li i {
      color: var(--bc-ft-gold);
      font-size: 0.72rem;
      width: 14px;
      flex-shrink: 0;
    }
    .bc-ft-contact li a {
      color: var(--bc-ft-mid);
      text-decoration: none;
      font-weight: 300;
      transition: color 0.2s;
    }
    .bc-ft-contact li a:hover { color: var(--bc-ft-gold-lt); }

    /* ── Bottom Bar ── */
    .bc-ft-bottom {
      background: var(--bc-ft-bottom-bg);
      border-top: 1px solid var(--bc-ft-border);
      margin-top: 3.5rem;
      padding: 1.1rem 0;
    }
    .bc-ft-bottom-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 0.5rem;
    }
    .bc-ft-copy {
      font-size: 0.7rem;
      color: var(--bc-ft-dim);
      font-weight: 300;
    }
    .bc-ft-btm-links {
      display: flex; gap: 1.4rem;
    }
    .bc-ft-btm-links a {
      font-size: 0.7rem;
      color: var(--bc-ft-dim);
      text-decoration: none;
      transition: color 0.2s;
    }
    .bc-ft-btm-links a:hover { color: var(--bc-ft-gold-lt); }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media (max-width: 991.98px) {
      .bc-footer { padding: 3rem 0 0; }
    }

    @media (max-width: 767.98px) {
      .bc-footer { padding: 2.5rem 0 0; }
      .bc-ft-bottom-inner {
        flex-direction: column;
        align-items: center;
        text-align: center;
      }
      .bc-ft-btm-links { justify-content: center; }
    }

    @media (max-width: 575.98px) {
      .bc-footer { padding: 2rem 0 0; }
      .bc-ft-brand-main { font-size: 0.95rem; }
      .bc-ft-brand-sub  { font-size: 1.05rem; }
      .bc-ft-logo-img   { width: 52px; height: 52px; font-size: 1.4rem; }

      /* Stack email row on tiny screens */
      .bc-ft-input-row  { flex-direction: column; }
      .bc-ft-email-inp  {
        border-right: 1px solid rgba(255,255,255,0.1);
        border-bottom: none;
        border-radius: 8px 8px 0 0;
      }
      .bc-ft-go-btn { border-radius: 0 0 8px 8px; padding: 0.6rem; }
    }

    /*plystries*/

    /* ══════════════════════════
       SECTION
    ══════════════════════════ */
    .bc-app-section {
      background: var(--bc-app-bg);
      padding: 0rem 0;
      overflow: hidden;
      position: relative;
      /*height: 90vh;*/
    }

    /* subtle radial glow behind phones */
    .bc-app-section::after {
      content: '';
      position: absolute;
      top: 50%; right: 10%;
      transform: translateY(-50%);
      width: 520px; height: 520px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(200,134,10,0.12) 0%, transparent 70%);
      pointer-events: none;
    }

    /* ── Left content ── */
    .bc-app-tag {
      font-size: 0.65rem;
      font-weight: 600;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--bc-app-gold);
      display: block;
      margin-bottom: 0.8rem;
    }

    .bc-app-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(1.8rem, 4vw, 2.8rem);
      font-weight: 700;
      color: var(--bc-app-dark);
      line-height: 1.1;
      margin-bottom: 0;
    }
    .bc-app-heading .bc-app-gold-line {
      color: var(--bc-app-gold);
      font-style: italic;
      display: block;
    }

    .bc-app-desc {
      font-size: 0.85rem;
      color: var(--bc-app-muted);
      font-weight: 300;
      line-height: 1.8;
      max-width: 380px;
      margin: 1.4rem 0 2rem;
    }

    /* ── Store Buttons ── */
    .bc-app-btns {
      display: flex;
      gap: 0.8rem;
      flex-wrap: wrap;
    }

    .bc-app-store-btn {
      background: var(--bc-app-dark);
      color: #fff;
      border: none;
      border-radius: 10px;
      padding: 0.7rem 1.4rem;
      display: flex;
      align-items: center;
      gap: 0.65rem;
      text-decoration: none;
      transition: all 0.25s;
      cursor: pointer;
    }
    .bc-app-store-btn:hover {
      background: var(--bc-app-brown);
      transform: translateY(-2px);
      box-shadow: 0 10px 28px rgba(28,18,8,0.25);
      color: #fff;
    }
    .bc-app-store-btn i {
      font-size: 1.4rem;
      flex-shrink: 0;
    }
    .bc-app-store-btn .bc-app-btn-text {
      display: flex;
      flex-direction: column;
      line-height: 1.2;
    }
    .bc-app-store-btn .bc-app-btn-sub {
      font-size: 0.58rem;
      font-weight: 400;
      letter-spacing: 0.5px;
      text-transform: uppercase;
      opacity: 0.7;
    }
    .bc-app-store-btn .bc-app-btn-main {
      font-size: 0.92rem;
      font-weight: 700;
      letter-spacing: 0.3px;
    }

    /* ══════════════════════════
       PHONE IMAGE
    ══════════════════════════ */
    .bc-app-phones {
      display: flex;
      justify-content: center;
      align-items: center;
    }
    .bc-app-phones img {
      width: 100%;
      max-width: 300px;
      height: auto;
      object-fit: contain;
      display: block;
      filter: drop-shadow(0 30px 60px rgba(28,18,8,0.25));
      animation: bc-float 5s ease-in-out infinite;
    }
    @keyframes bc-float {
      0%, 100% { transform: translateY(0); }
      50%       { transform: translateY(-10px); }
    }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media (max-width: 991.98px) {
      .bc-app-section { padding: 4rem 0; }
      .bc-app-phones img { max-width: 420px; }
      .bc-app-phones { margin-top: 3rem; }
    }

    @media (max-width: 767.98px) {
      .bc-app-section { padding: 3rem 0; }
      .bc-app-heading { font-size: 2rem; }
      .bc-app-desc    { max-width: 100%; font-size: 0.82rem; }
      .bc-app-phones  { margin-top: 2.5rem; }
      .bc-app-phones img { max-width: 360px; }
    }

    @media (max-width: 575.98px) {
      .bc-app-section { padding: 2.5rem 0; }
      .bc-app-heading { font-size: 1.7rem; text-align: center; }
      .bc-app-tag     { text-align: center; }
      .bc-app-desc    { text-align: center; margin-left: auto; margin-right: auto; }
      .bc-app-btns    { justify-content: center; }
      .bc-app-phones  { margin-top: 2rem; }
      .bc-app-phones img { max-width: 300px; }
    }


        /* ══════════════════════════
       happy custerms
    ══════════════════════════ */
    
.bc-rv-section {
  background: var(--rv-bg);
  padding: 6rem 0 5rem;
  position: relative;
  overflow: hidden;
}

/* Background texture blobs */
.bc-rv-section::before {
  content: '';
  position: absolute;
  top: -150px; right: -150px;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,134,10,0.07) 0%, transparent 65%);
  pointer-events: none;
}
.bc-rv-section::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -100px;
  width: 450px; height: 450px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,134,10,0.05) 0%, transparent 65%);
  pointer-events: none;
}

/* ── Header ── */
.bc-rv-tag {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--rv-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
}
.bc-rv-tag::before,
.bc-rv-tag::after {
  content: '';
  width: 30px; height: 1px;
  background: var(--rv-gold);
  opacity: 0.5;
}

.bc-rv-heading {
  font-family: 'Libre Baskerville', serif;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  font-weight: 700;
  color: var(--rv-text);
  text-align: center;
  line-height: 1.15;
  margin-bottom: 0;
}
.bc-rv-heading .bc-rv-highlight {
  color: var(--rv-gold-lt);
  font-style: italic;
}

.bc-rv-line {
  width: 40px; height: 3px;
  background: linear-gradient(90deg, var(--rv-gold), transparent);
  border-radius: 2px;
  margin: 1rem auto 0;
}

/* ══ SLIDER WRAPPER ══ */
.bc-rv-slider-outer {
  position: relative;
  margin-top: 3.5rem;
}

/* Track that holds all cards */
.bc-rv-track-wrap {
  overflow: hidden;
  border-radius: 20px;
}
.bc-rv-track {
  display: flex;
  gap: 1.5rem;
  transition: transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
  cursor: grab;
  user-select: none;
}
.bc-rv-track.is-dragging { cursor: grabbing; transition: none; }

/* ══ REVIEW CARD ══ */
.bc-rv-card {
  background: var(--rv-card);
  border: 1px solid var(--rv-border);
  border-radius: 20px;
  padding: 2.2rem 2rem 1.8rem;
  flex: 0 0 calc(33.333% - 1rem);
  min-width: calc(33.333% - 1rem);
  display: flex;
  flex-direction: column;
  transition: border-color 0.3s ease, background 0.3s ease, transform 0.3s ease;
  position: relative;
  overflow: hidden;
}
.bc-btn-outline {
  background: transparent;
  border: 1.5px solid var(--gold);
  color: var(--gold);
  border-radius: 50px;
  padding: 0.85rem 2rem;
  font-size: 0.9rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  transition: all 0.3s ease;
}

.bc-btn-outline:hover {
  background: var(--gold);
  color: #fff;
  transform: translateY(-3px);
}
/* Subtle inner shimmer top-left */
.bc-rv-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 60%; height: 1px;
  background: linear-gradient(90deg, var(--rv-gold), transparent);
  opacity: 0;
  transition: opacity 0.3s;
}
.bc-rv-card:hover {
  border-color: var(--rv-border-h);
  background: var(--rv-card-h);
  transform: translateY(-6px);
}
.bc-rv-card:hover::before { opacity: 1; }

/* Quote mark */
.bc-rv-quote-mark {
  font-family: Georgia, serif;
  font-size: 4rem;
  color: var(--rv-gold);
  line-height: 0.6;
  margin-bottom: 1.4rem;
  display: block;
  opacity: 0.35;
}

/* Review text */
.bc-rv-text {
  font-size: 0.84rem;
  color: var(--rv-muted);
  font-weight: 300;
  line-height: 1.9;
  flex: 1;
  margin-bottom: 1.4rem;
}

/* Stars */
.bc-rv-stars {
  display: flex;
  gap: 3px;
  margin-bottom: 1.4rem;
}
.bc-rv-stars i { color: var(--rv-star); font-size: 0.76rem; }
.bc-rv-stars i.half { opacity: 0.4; }

/* Author */
.bc-rv-author {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 1.2rem;
  margin-top: auto;
}

.bc-rv-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Poppins', sans-serif;
  font-size: 1rem; font-weight: 700;
  color: #fff; flex-shrink: 0;
  border: 1.5px solid rgba(200,134,10,0.3);
}
.bc-rv-avatar.av-purple { background: #3B2B7A; }
.bc-rv-avatar.av-blue   { background: #1A3D7A; }
.bc-rv-avatar.av-teal   { background: #0D5C4A; }
.bc-rv-avatar.av-rose   { background: #7A1F3D; }
.bc-rv-avatar.av-amber  { background: #7A4A0D; }

.bc-rv-author-name {
  font-size: 0.88rem; font-weight: 600;
  color: var(--rv-text);
  display: block; line-height: 1.3;
}
.bc-rv-author-role {
  font-size: 0.7rem; color: var(--rv-muted);
  font-weight: 300; display: block;
}

/* ══ NAVIGATION ══ */
.bc-rv-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 2.8rem;
}

.bc-rv-btn {
  width: 46px; height: 46px;
  border-radius: 50%;
  border: 1.5px solid var(--rv-border);
  background: transparent;
  color: var(--rv-gold);
  font-size: 1rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}
.bc-rv-btn:hover {
  background: var(--rv-gold);
  border-color: var(--rv-gold);
  color: #0E0A06;
  transform: scale(1.08);
}
.bc-rv-btn:disabled {
  opacity: 0.25;
  cursor: not-allowed;
  transform: none;
}

/* Dots */
.bc-rv-dots {
  display: flex;
  gap: 6px;
  align-items: center;
}
.bc-rv-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(200,134,10,0.25);
  cursor: pointer;
  transition: all 0.3s ease;
  border: none;
  padding: 0;
}
.bc-rv-dot.active {
  background: var(--rv-gold);
  width: 22px;
  border-radius: 4px;
}

/* ══ RESPONSIVE ══ */
@media (max-width: 991.98px) {
  .bc-rv-section { padding: 4.5rem 0 4rem; }
  .bc-rv-card {
    flex: 0 0 calc(50% - 0.75rem);
    min-width: calc(50% - 0.75rem);
  }
}

@media (max-width: 767.98px) {
  .bc-rv-section { padding: 3.5rem 0 3rem; }
  .bc-rv-card {
    flex: 0 0 calc(85vw);
    min-width: calc(85vw);
    padding: 1.8rem 1.6rem 1.5rem;
  }
  .bc-rv-track { gap: 1rem; }
  .bc-rv-btn { width: 40px; height: 40px; font-size: 0.9rem; }
}

@media (max-width: 575.98px) {
  .bc-rv-section { padding: 2.5rem 0 2.5rem; }
  .bc-rv-card {
    flex: 0 0 90vw;
    min-width: 90vw;
    padding: 1.5rem 1.3rem 1.3rem;
  }
  .bc-rv-heading { font-size: 1.55rem; }
  .bc-rv-text { font-size: 0.8rem; }
}

    /*sdfs*/
        /* ══════════════════════════
       SECTION
    ══════════════════════════ */
    .bc-pr-section {
      background: var(--bc-pr-bg);
      padding: 5rem 0 5.5rem;
      position: relative;
      overflow: hidden;
    }

    /* Soft radial glow center */
    .bc-pr-section::before {
      content: '';
      position: absolute;
      top: 0; left: 50%;
      transform: translateX(-50%);
      width: 700px; height: 300px;
      background: radial-gradient(ellipse, rgba(200,134,10,0.07) 0%, transparent 70%);
      pointer-events: none;
    }

    /* ── Tag ── */
    .bc-pr-tag {
      font-size: 0.63rem;
      font-weight: 600;
      letter-spacing: 3px;
      text-transform: uppercase;
      color: var(--bc-pr-gold);
      display: block;
      text-align: center;
      margin-bottom: 0.65rem;
    }

    /* ── Heading ── */
    .bc-pr-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(1.8rem, 4.5vw, 2.8rem);
      font-weight: 700;
      color: var(--bc-pr-cream);
      text-align: center;
      line-height: 1.15;
      margin-bottom: 0;
    }
    .bc-pr-heading .bc-pr-hl {
      color: var(--bc-pr-gold);
      font-style: italic;
    }

    /* Gold underline */
    .bc-pr-line {
      width: 36px;
      height: 3px;
      background: var(--bc-pr-gold);
      border-radius: 2px;
      margin: 0.9rem auto 0;
    }

    /* ══════════════════════════
       FEATURE CARD
    ══════════════════════════ */
    .bc-pr-card {
      background: var(--bc-pr-card);
      border: 1px solid var(--bc-pr-border);
      border-radius: 18px;
      padding: 2.2rem 1.6rem 2rem;
      text-align: center;
      height: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      transition: all 0.3s ease;
    }
    .bc-pr-card:hover {
      background: var(--bc-pr-card-hvr);
      border-color: rgba(200,134,10,0.32);
      transform: translateY(-5px);
      box-shadow: 0 20px 50px rgba(0,0,0,0.3);
    }

    /* ── Icon box ── */
    .bc-pr-icon-box {
      width: 58px;
      height: 58px;
      border-radius: 14px;
      background: var(--bc-pr-icon-bg);
      border: 1px solid var(--bc-pr-icon-bdr);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.6rem;
      margin-bottom: 1.4rem;
      transition: transform 0.3s;
    }
    .bc-pr-card:hover .bc-pr-icon-box {
      transform: scale(1.1) rotate(-4deg);
    }

    /* ── Card title ── */
    .bc-pr-card-title {
      font-family: 'Libre Baskerville', serif;
      font-size: 1rem;
      font-weight: 700;
      color: var(--bc-pr-cream);
      margin-bottom: 0.75rem;
      line-height: 1.3;
    }

    /* ── Card desc ── */
    .bc-pr-card-desc {
      font-size: 0.78rem;
      color: var(--bc-pr-dim);
      font-weight: 300;
      line-height: 1.8;
    }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media (max-width: 991.98px) {
      .bc-pr-section { padding: 4rem 0 4.5rem; }
    }

    @media (max-width: 767.98px) {
      .bc-pr-section  { padding: 3rem 0 3.5rem; }
      .bc-pr-heading  { font-size: 1.75rem; }
      .bc-pr-card     { padding: 1.8rem 1.4rem 1.6rem; }
    }

    @media (max-width: 575.98px) {
      .bc-pr-section      { padding: 2.5rem 0 3rem; }
      .bc-pr-heading      { font-size: 1.5rem; }
      .bc-pr-card         { padding: 1.5rem 1.2rem; border-radius: 14px; }
      .bc-pr-card-desc    { font-size: 0.76rem; }
      .bc-pr-icon-box     { width: 52px; height: 52px; font-size: 1.4rem; }
    }

    /* ── 2 col on xs ── */
    @media (max-width: 399px) {
      .bc-pr-heading { font-size: 1.3rem; }
    }


        /* ══════════════════════════
       SECTION
    ══════════════════════════ */
    .bc-sl-section {
      background: var(--bc-sl-bg);
      padding: 4.5rem 0 5rem;
    }

    /* ── Tag ── */
    .bc-sl-tag {
      font-size: 0.63rem;
      font-weight: 600;
      letter-spacing: 2.5px;
      text-transform: uppercase;
      color: var(--bc-sl-gold);
      display: block;
      margin-bottom: 0.5rem;
    }

    /* ── Heading ── */
    .bc-sl-heading {
      font-family: 'Libre Baskerville', serif;
      font-size: clamp(1.8rem, 4vw, 2.5rem);
      font-weight: 700;
      color: var(--bc-sl-dark);
      line-height: 1.15;
      margin-bottom: 0;
    }
    .bc-sl-heading .bc-sl-hl {
      color: var(--bc-sl-gold);
      font-style: italic;
    }
    .bc-sl-line {
      width: 34px;
      height: 3px;
      background: var(--bc-sl-gold);
      border-radius: 2px;
      margin-top: 0.7rem;
    }

    /* ── View All button ── */
    .bc-sl-view-btn {
      background: transparent;
      border: 1.5px solid rgba(28,18,8,0.2);
      border-radius: 50px;
      padding: 0.55rem 1.3rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.82rem;
      font-weight: 500;
      color: var(--bc-sl-dark);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 0.45rem;
      transition: all 0.25s;
      white-space: nowrap;
    }
    .bc-sl-view-btn:hover {
      background: var(--bc-sl-dark);
      color: #fff;
      border-color: var(--bc-sl-dark);
      transform: translateX(2px);
    }
    .bc-sl-view-btn i { font-size: 0.75rem; transition: transform 0.25s; }
    .bc-sl-view-btn:hover i { transform: translateX(3px); }

    /* ══════════════════════════
       STORE CARD
    ══════════════════════════ */
    .bc-sl-card {
      background: var(--bc-sl-card);
      border: 1.5px solid var(--bc-sl-border);
      border-radius: 18px;
      padding: 1.5rem 1.5rem 1.3rem;
      height: 100%;
      display: flex;
      flex-direction: column;
      transition: all 0.28s ease;
    }
    .bc-sl-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 16px 50px rgba(28,18,8,0.1);
      border-color: rgba(200,134,10,0.25);
    }

    /* ── Card top row ── */
    .bc-sl-card-top {
      display: flex;
      align-items: flex-start;
      gap: 0.9rem;
      margin-bottom: 1.3rem;
      flex: 1;
    }

    /* Store icon */
    .bc-sl-store-icon {
      width: 44px;
      height: 44px;
      border-radius: 10px;
      background: var(--bc-sl-icon-bg);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.2rem;
      flex-shrink: 0;
    }

    /* Store info */
    .bc-sl-info { flex: 1; min-width: 0; }

    .bc-sl-name-row {
      display: flex;
      align-items: center;
      gap: 0.5rem;
      flex-wrap: wrap;
      margin-bottom: 0.3rem;
    }
    .bc-sl-name {
      font-family: 'Libre Baskerville', serif;
      font-size: 0.95rem;
      font-weight: 700;
      color: var(--bc-sl-dark);
      line-height: 1.2;
    }

    /* Open Now badge */
    .bc-sl-open-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.3rem;
      background: var(--bc-sl-open-bg);
      border-radius: 50px;
      padding: 0.18rem 0.6rem;
      font-size: 0.63rem;
      font-weight: 600;
      color: var(--bc-sl-open-txt);
      white-space: nowrap;
    }
    .bc-sl-open-badge::before {
      content: '';
      width: 6px; height: 6px;
      border-radius: 50%;
      background: var(--bc-sl-open-dot);
      display: inline-block;
      flex-shrink: 0;
    }

    .bc-sl-address {
      font-size: 0.76rem;
      color: var(--bc-sl-muted);
      font-weight: 300;
      line-height: 1.55;
    }

    /* ── Card bottom row ── */
    .bc-sl-card-bottom {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 0.5rem;
      padding-top: 1rem;
      border-top: 1px solid var(--bc-sl-border);
      margin-top: auto;
      flex-wrap: wrap;
    }

    /* Distance pill */
    .bc-sl-dist {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
      background: var(--bc-sl-dist-bg);
      border: 1px solid var(--bc-sl-dist-bdr);
      border-radius: 50px;
      padding: 0.3rem 0.8rem;
      font-size: 0.72rem;
      font-weight: 500;
      color: var(--bc-sl-gold);
      white-space: nowrap;
    }
    .bc-sl-dist i { font-size: 0.65rem; color: var(--bc-sl-gold); }

    /* Select Store button */
    .bc-sl-select-btn {
      background: transparent;
      border: none;
      font-family: 'Poppins', sans-serif;
      font-size: 0.78rem;
      font-weight: 500;
      color: var(--bc-sl-dark);
      cursor: pointer;
      padding: 0.2rem 0;
      transition: color 0.2s;
      white-space: nowrap;
    }
    .bc-sl-select-btn:hover { color: var(--bc-sl-gold); }

    /* ══════════════════════════
       RESPONSIVE
    ══════════════════════════ */
    @media (max-width: 991.98px) {
      .bc-sl-section { padding: 3.5rem 0 4rem; }
    }

    @media (max-width: 767.98px) {
      .bc-sl-section  { padding: 3rem 0 3.5rem; }
      .bc-sl-heading  { font-size: 1.7rem; }

      /* Move View All btn below heading on mobile */
      .bc-sl-header-row {
        flex-direction: column;
        align-items: flex-start !important;
        gap: 1rem;
      }
    }

    @media (max-width: 575.98px) {
      .bc-sl-section  { padding: 2.5rem 0 3rem; }
      .bc-sl-heading  { font-size: 1.5rem; }
      .bc-sl-card     { padding: 1.3rem; border-radius: 14px; }
      .bc-sl-name     { font-size: 0.88rem; }
      .bc-sl-address  { font-size: 0.72rem; }
    }


    /*Menu page css code*/
  /* ── HEADER ── */
  .section-label {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 3px;
    color: var(--gold);
    text-transform: uppercase;
  }
  .browse-heading {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.8rem, 5vw, 2.8rem);
    font-weight: 700;
    color: var(--text-dark);
  }
  .browse-heading .craving { color: var(--gold); }
  .underline-gold {
    width: 48px; height: 3px;
    background: var(--gold);
    border-radius: 2px;
    margin-top: 6px;
  }

  /* ── FILTER TABS ── */
  .filter-tabs .btn-tab {
    border-radius: 50px;
    padding: 6px 18px;
    font-size: 0.8rem;
    font-weight: 500;
    border: none;
    background: #f0ece6;
    color: #555;
    transition: all 0.25s;
  }
  .filter-tabs .btn-tab.active,
  .filter-tabs .btn-tab:hover {
    background: var(--text-dark);
    color: #fff;
  }

  /* ── CATEGORY CARDS ── */
  .cat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: transform 0.2s;
  }
  .cat-card:hover { transform: translateY(-4px); }
  .cat-img-wrap {
    width: 72px; height: 72px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid #f0ece6;
    background: #f7f0e6;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .cat-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
  .cat-img-wrap.active-cat {
    border-color: var(--gold);
    box-shadow: 0 0 0 4px rgba(200,146,42,0.15);
  }
  .cat-label { font-size: 0.75rem; font-weight: 500; color: #333; text-align: center; }
  .cat-count { font-size: 0.65rem; color: #888; text-align: center; margin-top: -4px; }

  /* ══════════════════════════════════
     DIAMOND MENU SECTIONS
  ══════════════════════════════════ */

  /* ── LIGHT SECTION ── */
  .menu-section-light {
    background: var(--cream);
    padding: 72px 0;
  }

  /* Hero image */
  .hero-coffee-img, .hero-icecream-img {
    width: 100%; height: 340px;
    object-fit: cover;
    border-radius: 12px;
  }

  .menu-badge {
    position: absolute;
    bottom: -22px; right: -22px;
    width: 88px; height: 88px;
    background: var(--gold);
    transform: rotate(45deg);
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    box-shadow: 0 6px 24px rgba(200,146,42,0.45);
  }
  .menu-badge::before {
    content: '';
    position: absolute;
    inset: 6px;
    border: 1.5px solid rgba(255,255,255,0.35);
    border-radius: 3px;
  }
  .menu-badge-inner {
    transform: rotate(-45deg);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.3;
    text-align: center;
    gap: 2px;
  }
  .menu-badge-inner .badge-sub {
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    opacity: 0.88;
  }
  .menu-badge-inner .badge-title {
    font-family: 'Playfair Display', serif;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.5px;
  }

  /* ── DIAMOND MENU ITEM ── */
  .menu-item-diamond {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 14px 0;
    border-bottom: 1px dashed #ddd;
    position: relative;
  }
  .menu-item-diamond:last-of-type { border-bottom: none; }

  /* Diamond image wrapper */
  .diamond-img-wrap {
    position: relative;
    width: 58px;
    height: 58px;
    flex-shrink: 0;
  }
  .diamond-img-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--gold);
    transform: rotate(45deg) scale(0.95);
    border-radius: 4px;
    z-index: 0;
    opacity: 0.15;
  }
  .diamond-img-wrap .d-img {
    position: absolute;
    inset: 6px;
    overflow: hidden;
    transform: rotate(45deg);
    border-radius: 4px;
    z-index: 1;
    border: 2px solid var(--gold);
  }
  .diamond-img-wrap .d-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    transform: rotate(-45deg) scale(1.45);
  }

  /* Item text */
  .menu-item-info { flex: 1; }
  .menu-item-name {
    font-weight: 600;
    font-size: 0.92rem;
    color: #222;
    margin-bottom: 2px;
  }
  .menu-item-desc { font-size: 0.72rem; color: var(--text-muted); }

  .menu-item-dots {
    flex: 1;
    border-bottom: 2px dotted #ccc;
    margin: 0 10px;
    height: 1px;
    align-self: center;
  }

  /* Price badge — diamond shape */
  .menu-item-price {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 64px;
    height: 36px;
    font-weight: 700;
    font-size: 0.95rem;
    color: #fff;
    background: var(--gold);
    clip-path: polygon(10px 0%, calc(100% - 10px) 0%, 100% 50%, calc(100% - 10px) 100%, 10px 100%, 0% 50%);
    padding: 0 18px;
    white-space: nowrap;
    letter-spacing: 0.5px;
  }

  .btn-view-all {
    background: var(--gold);
    color: #fff;
    border: none;
    padding: 10px 32px;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: background 0.2s;
  }
  .btn-view-all:hover { background: #b07a1f; color: #fff; }

  /* ── DARK SECTION ── */
  .menu-section-dark {
    background: var(--dark-bg);
    padding: 72px 0;
  }

  .menu-section-dark .menu-item-diamond {
    border-bottom-color: #3a2c18;
  }
  .menu-section-dark .menu-item-name { color: #e8d8b8; }
  .menu-section-dark .menu-item-desc { color: #8a7a62; }
  .menu-section-dark .menu-item-dots { border-bottom-color: #3a2c18; }
  .menu-section-dark .menu-item-price {
    background: var(--gold-light);
    color: #1c1208;
  }
  .menu-section-dark .diamond-img-wrap::before { opacity: 0.25; }
  .menu-section-dark .diamond-img-wrap .d-img { border-color: var(--gold-light); }
  .menu-section-dark .menu-item-dots { border-bottom-color: #3a2c18; }

  /* Section divider diamond ornament */
  .diamond-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 28px;
  }
  .diamond-divider .dd-line {
    flex: 1;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--gold));
  }
  .diamond-divider .dd-line.rev {
    background: linear-gradient(to left, transparent, var(--gold));
  }
  .diamond-divider .dd-gem {
    width: 12px; height: 12px;
    background: var(--gold);
    transform: rotate(45deg);
    border-radius: 2px;
  }
  .menu-section-dark .diamond-divider .dd-line {
    background: linear-gradient(to right, transparent, var(--gold-light));
  }
  .menu-section-dark .diamond-divider .dd-line.rev {
    background: linear-gradient(to left, transparent, var(--gold-light));
  }
  .menu-section-dark .diamond-divider .dd-gem {
    background: var(--gold-light);
  }

  /* ── RESPONSIVE ── */
  @media (max-width: 767px) {
    .cat-img-wrap { width: 56px; height: 56px; }
    .cat-label { font-size: 0.68rem; }
    .hero-coffee-img, .hero-icecream-img { height: 220px; }
    .menu-badge { width: 68px; height: 68px; right: -10px; bottom: -10px; }
    .menu-badge-inner .badge-title { font-size: 0.76rem; }
    .menu-badge-inner .badge-sub { font-size: 0.5rem; }
    .filter-tabs .btn-tab { padding: 5px 12px; font-size: 0.72rem; }
    .diamond-img-wrap { width: 48px; height: 48px; }
  }
  @media (max-width: 400px) {
    .cat-img-wrap { width: 46px; height: 46px; }
  }


  /* ══════════════════════════════════
   DELIVERY SECTION
══════════════════════════════════ */
.delivery-section {
  background: #fff;
  padding: 15px 0 0;
  overflow: hidden;
  position: relative;
}
.delivery-heading {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.2rem, 6vw, 3.8rem);
  font-weight: 800;
  color: #2b1e0e;
  line-height: 1.1;
  margin-bottom: 20px;
  letter-spacing: -0.5px;
}
.delivery-desc {
  font-size: 0.85rem;
  color: #a08060;
  line-height: 1.7;
  max-width: 420px;
  margin-bottom: 28px;
}
.btn-order-now {
  display: inline-block;
  background: var(--gold);
  color: #fff;
  text-decoration: none;
  padding: 12px 34px;
  border-radius: 4px;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: background 0.2s;
}
.btn-order-now:hover { background: #b07a1f; color: #fff; }

.delivery-img {
  width: 100%;
  /*max-width: 420px;*/
  object-fit: contain;
  display: block;
  margin: 0 auto;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.5));
}
/* Responsive */
@media (max-width: 767px) {
  .delivery-section { padding: 48px 0 0; }
  .phones-wrap { height: 280px; }
  .phone-frame-front { width: 140px; height: 264px; }
  .phone-frame-back  { width: 120px; height: 228px; }
  .splash-circle { width: 90px; height: 90px; }
  .phone-back { transform: rotate(6deg) translateX(48px); }
}
@media (max-width: 480px) {
  .delivery-img { max-width: 300px; }
  .btn-store { min-width: 130px; padding: 9px 14px; }
}

/* ══════════════════════════════════
   APP SECTION
══════════════════════════════════ */
.app-section {
  background: #f5edd8;
  padding: 72px 0;
  overflow: hidden;
}
.app-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 3px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.app-heading {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.7rem, 4vw, 2.5rem);
  font-weight: 800;
  color: var(--text-dark);
  line-height: 1.2;
  margin-bottom: 16px;
}
.app-heading-gold { color: var(--gold); }

.app-desc {
  font-size: 0.85rem;
  color: var(--text-muted);
  line-height: 1.7;
  max-width: 400px;
}

/* Store buttons */
.btn-store {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #1a1208;
  color: #fff;
  text-decoration: none;
  padding: 10px 20px;
  border-radius: 10px;
  transition: background 0.2s, transform 0.15s;
  min-width: 148px;
}
.btn-store:hover { background: #3a2c18; transform: translateY(-2px); color: #fff; }
.store-icon { width: 22px; height: 22px; flex-shrink: 0; }
.store-text { display: flex; flex-direction: column; }
.store-sub { font-size: 0.58rem; opacity: 0.7; letter-spacing: 0.5px; line-height: 1; }
.store-name { font-size: 0.82rem; font-weight: 700; line-height: 1.4; }

/* ── Phone mockup ── */
.phones-wrap {
  position: relative;
  display: inline-flex;
  align-items: flex-end;
  justify-content: center;
  height: 380px;
}

.phone-back {
  position: absolute;
  right: 10px;
  bottom: 0;
  z-index: 1;
  transform: rotate(6deg) translateX(60px);
}
.phone-front {
  position: relative;
  z-index: 2;
}

.phone-frame {
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.28);
  border: 6px solid #111;
  background: #111;
  position: relative;
}
.phone-frame::before {
  content: '';
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 6px;
  background: #222;
  border-radius: 4px;
  z-index: 10;
}

.phone-frame-front { width: 180px; height: 340px; }
.phone-frame-back  { width: 150px; height: 290px; }

.phone-screen {
  width: 100%; height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: 20px;
}

/* Front — splash */
.phone-screen-splash { background: #3d1f08; }
.splash-circle {
  width: 120px; height: 120px;
  border-radius: 50%;
  background: #fff;
  border: 4px solid var(--gold);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}

/* Back — menu list */
.phone-screen-menu { background: #1c1208; padding: 20px 8px 8px; justify-content: flex-start; }
.mock-menu-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 10px;
  gap: 3px;
}
.mock-logo-sm { font-size: 1rem; }
.mock-menu-items { display: flex; flex-direction: column; gap: 6px; width: 100%; }
.mock-item {
  height: 32px;
  border-radius: 6px;
  background: #2e1e0a;
  width: 100%;
}
/* ══════════════════════════════════
   COMBOS SECTION
══════════════════════════════════ */
.combos-section {
  background: #fff;
  padding: 72px 0;
}
.combos-img-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
}
.combos-hero-img {
  width: 100%;
  max-width: 320px;
  height: 320px;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}
.hex-badge {
  position: absolute;
  bottom: 28px;
  right: -10px;
  width: 108px;
  height: 108px;
  background: var(--gold);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 28px rgba(200,146,42,0.45);
}
.hex-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.3;
  text-align: center;
}
.hex-menu {
  font-size: 0.72rem;
  font-weight: 500;
  color: rgba(255,255,255,0.88);
  letter-spacing: 1px;
}
.hex-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
}
.combo-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid #f0ece6;
}
.combo-item:last-of-type { border-bottom: none; }
.combo-img {
  width: 58px; height: 58px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid #f0e8d8;
}
.combo-info { flex: 0 0 auto; min-width: 130px; }
.combo-name {
  font-weight: 700;
  font-size: 0.92rem;
  color: #1a1208;
  margin-bottom: 3px;
}
.combo-desc { font-size: 0.72rem; color: #9a8870; }
.combo-dots {
  flex: 1;
  border-bottom: 2px dotted #d0c8b8;
  height: 1px;
  align-self: center;
  margin: 0 8px;
}
.combo-price {
  font-weight: 800;
  font-size: 1rem;
  color: var(--gold);
  white-space: nowrap;
  flex-shrink: 0;
}
.btn-view-all-combo {
  background: transparent;
  color: var(--gold);
  border: 1.5px solid var(--gold);
  padding: 9px 28px;
  border-radius: 4px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  transition: all 0.2s;
  cursor: pointer;
}
.btn-view-all-combo:hover { background: var(--gold); color: #fff; }

  /* ══ SECTION ══ */
  .combos-section {
    background: #fff;
    padding: 72px 0;
    min-height: 100vh;
    display: flex;
    align-items: center;
  }

  /* ══ LEFT IMAGE ══ */
  .img-wrap {
    position: relative;
    display: inline-block;
    width: 100%;
  }

  .food-img {
    width: 100%;
    max-width: 340px;
    height: 340px;
    object-fit: cover;
    border-radius: 8px;
    display: block;
  }

  /* ── Hexagon badge ── */
  .hex-badge {
    position: absolute;
    bottom: 30px;
    right: -10px;
    width: 112px;
    height: 112px;
    background: var(--gold);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 28px rgba(200,146,42,0.4);
    cursor: default;
  }

  .hex-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.25;
  }

  .hex-menu {
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
  }

  .hex-sub {
    font-size: 0.72rem;
    font-weight: 500;
    color: rgba(255,255,255,0.85);
    letter-spacing: 0.5px;
  }

  /* ══ RIGHT LIST ══ */
  .menu-list { width: 100%; }

  .menu-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--border);
  }
  .menu-row:last-of-type { border-bottom: none; }

  /* circular thumb */
  .item-thumb {
    width: 62px;
    height: 62px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 2px solid var(--border);
  }

  .item-info { flex: 0 0 auto; min-width: 140px; }
  .item-name {
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--dark);
    margin-bottom: 3px;
  }
  .item-desc {
    font-size: 0.72rem;
    color: var(--muted);
  }

  /* dotted spacer */
  .item-dots {
    flex: 1;
    border-bottom: 2px dotted #ccc;
    height: 1px;
    align-self: center;
    margin: 0 12px;
    min-width: 30px;
  }

  /* price */
  .item-price {
    font-weight: 800;
    font-size: 1.05rem;
    color: var(--gold);
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* VIEW ALL button */
  .btn-view-all {
    background: transparent;
    color: var(--gold);
    border: 1.5px solid var(--gold);
    padding: 8px 28px;
    border-radius: 3px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s;
  }
  .btn-view-all:hover { background: var(--gold); color: #fff; }

  /* ══ RESPONSIVE ══ */
  @media (max-width: 767px) {
    .combos-section { padding: 48px 0; min-height: unset; }
    .food-img { max-width: 100%; height: 240px; }
    .hex-badge { width: 88px; height: 88px; right: 8px; bottom: 16px; }
    .hex-menu { font-size: 0.88rem; }
    .hex-sub  { font-size: 0.62rem; }
    .item-info { min-width: 110px; }
    .item-thumb { width: 50px; height: 50px; }
  }

  @media (max-width: 480px) {
    .item-name { font-size: 0.85rem; }
    .item-price { font-size: 0.95rem; }
    .item-dots { margin: 0 6px; }
  }



/* ══ HERO ══ */
.pg-hero {
  background: var(--ink);
  padding: 52px 0 0;
  position: relative;
  overflow: hidden;
}
.pg-hero::after {
  content: 'MENU';
  position: absolute;
  bottom: 40px; right: -10px;
  font-family: 'Syne', sans-serif;
  font-size: min(22vw, 200px);
  font-weight: 800;
  color: rgba(255,255,255,0.03);
  line-height: 1;
  pointer-events: none;
  letter-spacing: -8px;
}

.hero-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 24px;
  padding-bottom: 36px;
}

.hero-left {}

.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(212,146,42,0.15);
  border: 1px solid rgba(212,146,42,0.3);
  color: var(--glt);
  border-radius: 50px;
  padding: 6px 18px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 18px;
}

.hero-h1 {
  font-family: 'Syne', sans-serif;
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  font-weight: 800;
  color: #fff;
  line-height: 0.92;
  letter-spacing: -3px;
  margin-bottom: 18px;
}
.hero-h1 .hl { color: var(--glt); display: block; }

.hero-desc {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.4);
  max-width: 380px;
  line-height: 1.7;
}

.hero-stats {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  align-items: stretch;
}
.hstat {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 14px;
  padding: 16px 22px;
  text-align: center;
  min-width: 90px;
}
.hstat-n {
  font-family: 'Syne', sans-serif;
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--glt);
  line-height: 1;
}
.hstat-l {
  font-size: 0.6rem;
  color: rgba(255,255,255,0.3);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-top: 4px;
}

/* mosaic */
.hero-mosaic {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  height: 130px;
  gap: 3px;
}
.hero-mosaic img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.45;
  transition: opacity 0.3s, transform 0.3s;
}
.hero-mosaic img:hover { opacity: 0.9; transform: scale(1.03); }

/* ══ STICKY NAV ══ */
.cat-nav {
  background: var(--white);
  border-bottom: 2px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 4px 20px rgba(15,10,5,0.07);
}
.cat-nav-scroll {
  display: flex;
  align-items: stretch;
  overflow-x: auto;
  scrollbar-width: none;
  gap: 2px;
}
.cat-nav-scroll::-webkit-scrollbar { display: none; }

.cnav-link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 20px;
  font-size: 0.73rem;
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: all 0.2s;
  flex-shrink: 0;
}
.cnav-link .cni { font-size: 1.25rem; line-height: 1; }
.cnav-link:hover { color: var(--ink); }
.cnav-link.on { color: var(--gold); border-bottom-color: var(--gold); font-weight: 700; }
.cnav-badge {
  font-size: 0.58rem;
  background: var(--ash);
  color: var(--muted);
  border-radius: 50px;
  padding: 1px 8px;
  font-weight: 700;
  line-height: 1.6;
}
.cnav-link.on .cnav-badge { background: rgba(212,146,42,0.12); color: var(--gold); }

/* ══ BODY ══ */
.pg-body { padding: 52px 0 80px; }

/* ── Category block ── */
.cat-block { margin-bottom: 68px; }

.cat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.cat-title-wrap { display: flex; align-items: center; gap: 14px; }

.cat-icon-box {
  width: 50px; height: 50px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  flex-shrink: 0;
}

.cat-title {
  font-family: 'Syne', sans-serif;
  font-size: clamp(1.5rem, 3.5vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.8px;
  line-height: 1;
}
.cat-qty { font-size: 0.7rem; color: var(--muted); font-weight: 600; margin-top: 3px; letter-spacing: 1px; }

.btn-viewall {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.74rem; font-weight: 700;
  text-decoration: none;
  padding: 9px 20px;
  border-radius: 50px;
  border: 1.5px solid var(--border);
  color: var(--ink);
  transition: all 0.2s;
  letter-spacing: 0.2px;
  white-space: nowrap;
}
.btn-viewall svg { width: 13px; height: 13px; transition: transform 0.2s; }
.btn-viewall:hover { background: var(--ink); border-color: var(--ink); color: #fff; }
.btn-viewall:hover svg { transform: translateX(3px); }

.cat-divider {
  height: 2px; border-radius: 2px; margin-bottom: 26px; margin-top: 6px;
}

/* ── Item Card ── */
.item-card {
  background: var(--white);
  border-radius: var(--rad);
  overflow: hidden;
  border: 1.5px solid var(--border);
  transition: transform 0.25s cubic-bezier(.25,.8,.25,1), box-shadow 0.25s, border-color 0.25s;
  height: 100%;
  display: flex;
  flex-direction: column;
  animation: fadeUp 0.4s ease both;
}
.item-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 48px rgba(15,10,5,0.12);
  border-color: rgba(0,0,0,0);
}

.icard-img-wrap { position: relative; overflow: hidden; }
.icard-img {
  width: 100%; height: 172px;
  object-fit: cover; display: block;
  transition: transform 0.45s ease;
}
.item-card:hover .icard-img { transform: scale(1.07); }

.icard-badge {
  position: absolute; top: 10px; left: 10px;
  font-size: 0.58rem; font-weight: 800;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 50px;
}
.b-hot { background: #ff5252; color: #fff; }
.b-new { background: #2ecc71; color: #fff; }

.icard-price-float {
  position: absolute; bottom: 10px; right: 10px;
  background: rgba(15,10,5,0.82);
  backdrop-filter: blur(6px);
  color: #fff;
  font-family: 'Syne', sans-serif;
  font-size: 0.85rem; font-weight: 800;
  padding: 5px 13px; border-radius: 50px;
}

.icard-body {
  padding: 14px 15px 15px;
  flex: 1; display: flex; flex-direction: column;
}
.icard-name {
  font-family: 'Syne', sans-serif;
  font-weight: 700; font-size: 0.88rem;
  color: var(--ink); margin-bottom: 5px; letter-spacing: -0.2px;
}
.icard-desc {
  font-size: 0.69rem; color: var(--muted);
  flex: 1; margin-bottom: 14px; line-height: 1.5;
}
.icard-foot {
  display: flex; align-items: center; justify-content: space-between;
}
.icard-price {
  font-family: 'Syne', sans-serif;
  font-size: 1.05rem; font-weight: 800;
}
.btn-plus {
  width: 34px; height: 34px; border-radius: 10px;
  background: var(--ash); border: 1.5px solid var(--border);
  color: var(--ink); font-size: 1.2rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s; flex-shrink: 0;
}
.btn-plus:hover { background: var(--gold); border-color: var(--gold); color: #fff; transform: scale(1.1); }

/* empty */
.empty-wrap { text-align: center; padding: 80px 20px; }
.empty-wrap .ei { font-size: 3.5rem; margin-bottom: 16px; display: block; }
.empty-wrap h4 { font-family: 'Syne', sans-serif; font-size: 1.4rem; font-weight: 700; margin-bottom: 8px; }
.empty-wrap p { font-size: 0.85rem; color: var(--muted); }

/* ══ FOOTER ══ */
.pg-footer {
  background: var(--ink);
  padding: 30px 0;
}
.pf-row {
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 12px;
}
.pf-brand { font-family: 'Syne', sans-serif; font-size: 1.1rem; font-weight: 800; color: #fff; }
.pf-brand em { color: var(--glt); font-style: normal; }
.pf-copy { font-size: 0.7rem; color: rgba(255,255,255,0.25); }
.pf-back {
  font-size: 0.74rem; font-weight: 700;
  color: var(--glt); text-decoration: none;
  display: flex; align-items: center; gap: 5px;
  transition: opacity 0.2s;
}
.pf-back:hover { opacity: 0.7; color: var(--glt); }

/* ══ ANIMATIONS ══ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══ RESPONSIVE ══ */
@media (max-width: 991px) {
  .hero-mosaic { grid-template-columns: repeat(3, 1fr); height: 100px; }
  .hero-mosaic img:nth-child(n+4) { display: none; }
}
@media (max-width: 767px) {
  .pg-hero { padding: 36px 0 0; }
  .hero-h1 { letter-spacing: -1.5px; }
  .hero-stats { gap: 6px; }
  .hstat { padding: 12px 14px; min-width: 70px; }
  .hstat-n { font-size: 1.3rem; }
  .hero-mosaic { grid-template-columns: repeat(2, 1fr); height: 80px; }
  .hero-mosaic img:nth-child(n+3) { display: none; }
  .icard-img { height: 145px; }
  .cat-title { font-size: 1.4rem; }
}
@media (max-width: 480px) {
  .icard-img { height: 130px; }
  .cnav-link { padding: 10px 14px; }
  .hstat { min-width: 62px; padding: 10px 12px; }
}





    /* ── Outer wrapper ── */
    .bc-hero-right {
      position: relative;
      width: 480px;
      height: 420px;
    }

    /* ── Teal panel — right side background block ── */
    .bc-teal-panel {
      position: absolute;
      top: 40px;
      right: 0;
      width: 58%;
      height: 88%;
      background: #e6ca96;
      border-radius: 6px;
      z-index: 1;
    }

    /* ── Square nav dots on teal panel right edge ── */
    .bc-square-dots {
      position: absolute;
      right: 14px;
      top: 50%;
      transform: translateY(-50%);
      display: flex;
      flex-direction: column;
      gap: 10px;
      z-index: 5;
    }
    .bc-sq-dot {
      width: 12px;
      height: 12px;
      border: 2px solid rgba(255,255,255,0.7);
      border-radius: 2px;
      background: transparent;
      cursor: pointer;
      transition: all 0.3s;
      padding: 0;
    }
    .bc-sq-dot.active {
      background: #fff;
      border-color: #fff;
      height: 22px;
    }

    /* ── Main photo — overlaps teal panel ── */
    .bc-photo-wrap {
      position: absolute;
      top: 54px;
      left: 0;
      width: 83%;
      height: 80%;
      border-radius: 4px;
      overflow: hidden;
      z-index: 3;
      box-shadow: 0 18px 55px rgba(0,0,0,0.22);
    }

    /* Slides */
    .bc-slides {
      display: flex;
      width: 100%;
      height: 100%;
      transition: transform 0.75s cubic-bezier(0.77,0,0.18,1);
      will-change: transform;
    }
    .bc-slide {
      min-width: 100%;
      height: 100%;
      position: relative;
    }
    .bc-slide img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .bc-slide::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(to bottom, transparent 45%, rgba(0,0,0,0.55) 100%);
      pointer-events: none;
    }

    /* Bestseller badge */
    .bc-badge-bestseller {
      position: absolute;
      top: 14px;
      right: 14px;
      z-index: 10;
      background: #ffd700;
      color: #1a1a1a;
      font-size: 10px;
      font-weight: 700;
      border-radius: 20px;
      padding: 5px 12px;
      display: flex;
      align-items: center;
      gap: 5px;
      box-shadow: 0 2px 10px rgba(0,0,0,0.18);
    }

    /* Card bottom info */
    .bc-card-bottom {
      position: absolute;
      bottom: 18px;
      left: 18px;
      z-index: 10;
      color: #fff;
    }
    .bc-card-label {
      font-size: 10px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 1px;
      opacity: 0.8;
      margin-bottom: 4px;
    }
    .bc-card-title {
      font-size: 20px;
      font-weight: 800;
      line-height: 1.2;
      text-shadow: 0 2px 8px rgba(0,0,0,0.4);
    }
    .bc-card-price {
      font-size: 13px;
      font-weight: 600;
      margin-top: 4px;
      color: #ffd700;
    }

    /* ── Rating badge ── */
    .bc-badge-rating {
      position: absolute;
      top: -10px;
      left: 10px;
      z-index: 20;
      background: #fff;
      border-radius: 30px;
      padding: 7px 16px;
      display: flex;
      align-items: center;
      gap: 10px;
      box-shadow: 0 4px 18px rgba(0,0,0,0.13);
    }
    .bc-r-label {
      font-size: 10px;
      color: #888;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.5px;
    }
    .bc-r-val {
      font-weight: 700;
      color: #1a1a1a;
      font-size: 13px;
    }
    .bc-r-val i { color: #f5a623; margin-right: 3px; }

    /* ── Scoop badge ── */
    .bc-badge-scoop {
      position: absolute;
      bottom: -14px;
      left: 18px;
      z-index: 20;
      background: #0e7c6b;
      color: #fff;
      border-radius: 12px;
      padding: 9px 16px;
      box-shadow: 0 6px 22px rgba(14,124,107,0.35);
    }
    .bc-s-label {
      font-size: 10px;
      font-weight: 600;
      opacity: 0.85;
      margin-bottom: 2px;
    }
    .bc-s-name {
      font-size: 15px;
      font-weight: 800;
    }


/*About section*/
 .about-hero {
      background: linear-gradient(135deg, #2C1A0E 0%, #4A2C17 60%, #7A4520 100%);
      min-height: 420px;
      display: flex;
      align-items: center;
      position: relative;
      overflow: hidden;
    }
    .about-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: radial-gradient(circle at 80% 50%, rgba(198,155,90,.18) 0%, transparent 60%);
    }
    .about-hero .badge-pill {
      background: var(--gold);
      color: var(--espresso);
      font-size: .72rem;
      letter-spacing: .12em;
      text-transform: uppercase;
      padding: .45rem 1.1rem;
      border-radius: 50px;
      font-weight: 500;
    }
    .about-hero h1 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2.2rem, 5vw, 3.8rem);
      color: #fff;
      line-height: 1.15;
    }
    .about-hero h1 em {
      color: var(--gold);
      font-style: italic;
    }
    .about-hero p {
      color: rgba(255,255,255,.72);
      font-size: 1.05rem;
      line-height: 1.75;
      max-width: 560px;
    }
    .hero-bean {
      font-size: 9rem;
      opacity: .06;
      position: absolute;
      right: -1rem;
      bottom: -2rem;
      line-height: 1;
      user-select: none;
    }

    /* ── STORY ── */
    .story-section {
      padding: 90px 0;
      background: var(--cream);
    }
    .section-label {
      font-size: .72rem;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: var(--gold);
      font-weight: 500;
    }
    .story-section h2 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(1.9rem, 3.5vw, 2.8rem);
      color: var(--espresso);
      line-height: 1.2;
    }
    .story-section p {
      color: var(--muted);
      font-size: 1.01rem;
      line-height: 1.85;
    }
    .story-card {
      background: var(--warm);
      border-radius: 20px;
      padding: 2.2rem;
      border: 1px solid rgba(198,155,90,.2);
    }
    .stat-box {
      text-align: center;
      padding: 1.5rem;
    }
    .stat-box .num {
      font-family: 'Playfair Display', serif;
      font-size: 2.6rem;
      color: var(--latte);
      font-weight: 700;
      line-height: 1;
    }
    .stat-box .label {
      font-size: .8rem;
      color: var(--muted);
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-top: .4rem;
    }
    .divider-line {
      width: 1px;
      background: rgba(198,155,90,.3);
    }

    /* ── TEAM ── */
    .team-section {
      padding: 90px 0;
      background: var(--warm);
    }
    .team-section h2 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(1.9rem, 3.5vw, 2.8rem);
      color: var(--espresso);
    }
    .team-card {
      background: var(--cream);
      border-radius: 20px;
      overflow: hidden;
      border: 1px solid rgba(198,155,90,.18);
      transition: transform .3s ease, box-shadow .3s ease;
    }
    .team-card:hover {
      transform: translateY(-6px);
      box-shadow: 0 20px 50px rgba(44,26,14,.12);
    }
    .team-card .img-wrap {
      height: 240px;
      overflow: hidden;
      background: #e8ddd3;
      position: relative;
    }
    .team-card .img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform .5s ease;
    }
    .team-card:hover .img-wrap img {
      transform: scale(1.05);
    }
    .team-card .role-badge {
      position: absolute;
      bottom: 12px;
      left: 12px;
      background: var(--espresso);
      color: var(--gold);
      font-size: .7rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      padding: .32rem .85rem;
      border-radius: 50px;
      font-weight: 500;
    }
    .team-card .card-body {
      padding: 1.2rem 1.4rem 1.5rem;
    }
    .team-card .name {
      font-family: 'Playfair Display', serif;
      font-size: 1.15rem;
      color: var(--espresso);
      margin-bottom: .2rem;
    }
    .team-card .socials a {
      color: var(--muted);
      font-size: 1rem;
      margin-right: .6rem;
      text-decoration: none;
      transition: color .2s;
    }
    .team-card .socials a:hover { color: var(--gold); }

    /* ── VALUES ── */
    .values-section {
      padding: 90px 0;
      background: var(--cream);
    }
    .values-section h2 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(1.9rem, 3.5vw, 2.8rem);
      color: var(--espresso);
    }
    .value-item {
      display: flex;
      gap: 1.1rem;
      align-items: flex-start;
      padding: 1.6rem;
      border-radius: 16px;
      border: 1px solid rgba(198,155,90,.15);
      background: var(--warm);
      height: 100%;
      transition: border-color .3s;
    }
    .value-item:hover { border-color: var(--gold); }
    .value-icon {
      width: 48px;
      height: 48px;
      border-radius: 12px;
      background: var(--espresso);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      font-size: 1.3rem;
      color: var(--gold);
    }
    .value-item h5 {
      font-family: 'Playfair Display', serif;
      font-size: 1.05rem;
      color: var(--espresso);
      margin-bottom: .3rem;
    }
    .value-item p {
      font-size: .9rem;
      color: var(--muted);
      margin: 0;
      line-height: 1.65;
    }

    /* ── CTA ── */
    .cta-section {
      background: linear-gradient(135deg, var(--espresso), #4A2C17);
      padding: 80px 0;
      text-align: center;
    }
    .cta-section h2 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2rem, 4vw, 3rem);
      color: #fff;
    }
    .cta-section p { color: rgba(255,255,255,.68); }
    .btn-gold {
      background: var(--gold);
      color: var(--espresso);
      font-weight: 500;
      padding: .8rem 2.2rem;
      border-radius: 50px;
      border: none;
      font-size: .95rem;
      text-decoration: none;
      display: inline-block;
      transition: opacity .2s, transform .2s;
    }
    .btn-gold:hover { opacity: .9; transform: translateY(-2px); color: var(--espresso); }
    .btn-outline-light-custom {
      color: rgba(255,255,255,.8);
      border: 1px solid rgba(255,255,255,.35);
      padding: .8rem 2.2rem;
      border-radius: 50px;
      font-size: .95rem;
      text-decoration: none;
      display: inline-block;
      transition: background .2s;
    }
    .btn-outline-light-custom:hover { background: rgba(255,255,255,.08); color: #fff; }
    /* =============================================
   PAGE HEADER — New Design
   Beans & Cones
   ============================================= */

/* ---- Variables (match your main style.css) ---- */
:root {
  --gold:         #E8A020;
  --gold-light:   #F5B84A;
  --dark:         #111111;
  --white:        #FFFFFF;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'DM Sans', sans-serif;
}

/* =============================================
   WRAPPER
   ============================================= */
.page-header-wrap {
  position: relative;
  overflow: hidden;
  padding: 100px 0 80px;

  /* Background image with dark gradient overlay */
  background:
    linear-gradient(
      135deg,
      rgba(10, 10, 10, 0.88) 0%,
      rgba(10, 10, 10, 0.70) 60%,
      rgba(232, 160, 32, 0.25) 100%
    ),
    url('../images/menu.png') center center / cover no-repeat;

  /* Bottom wave clip */
  /*clip-path: polygon(0 0, 100% 0, 100% 88%, 0 100%);*/
  /*margin-bottom: 70px;*/
}

/* =============================================
   DECORATIVE ELEMENTS
   ============================================= */

/* Circles */
.deco-circle {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0.12;
}

.deco-circle-1 {
  width: 340px;
  height: 340px;
  border: 2px solid var(--gold);
  top: -100px;
  right: -80px;
}

.deco-circle-2 {
  width: 180px;
  height: 180px;
  border: 2px solid var(--gold);
  top: 20px;
  right: 80px;
  opacity: 0.08;
}

.deco-circle-3 {
  width: 90px;
  height: 90px;
  background: var(--gold);
  bottom: 60px;
  left: 5%;
  opacity: 0.07;
}

/* Diagonal stripe */
.deco-stripe {
  position: absolute;
  width: 6px;
  height: 100%;
  background: var(--gold);
  top: 0;
  left: 38px;
  opacity: 0.55;
  transform: skewX(-8deg);
}

/* =============================================
   LEFT SIDE — TITLE
   ============================================= */
.header-left {
  padding-right: 30px;
}

.header-eyebrow {
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}

.header-title {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: 20px;
}

.gold-text {
  color: var(--gold);
  font-style: italic;
}

/* Animated underline divider */
.header-divider {
  width: 64px;
  height: 3px;
  background: var(--gold);
  border-radius: 2px;
  position: relative;
}

.header-divider::after {
  content: '';
  position: absolute;
  left: 72px;
  top: 0;
  width: 12px;
  height: 3px;
  background: var(--gold);
  border-radius: 2px;
  opacity: 0.5;
}

/* =============================================
   RIGHT SIDE — BREADCRUMB CARD
   ============================================= */
.header-right {
  display: flex;
  justify-content: flex-end;
}

.breadcrumb-card {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(232, 160, 32, 0.3);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 12px;
  padding: 18px 28px;
  display: inline-block;
}

/* Breadcrumb items */
.breadcrumb-card .breadcrumb {
  flex-wrap: wrap;
  gap: 4px;
}

.breadcrumb-card .breadcrumb-item a {
  color: rgba(255, 255, 255, 0.65);
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 500;
  font-family: var(--font-body);
  transition: color 0.2s;
}

.breadcrumb-card .breadcrumb-item a:hover {
  color: var(--gold);
}

.breadcrumb-card .breadcrumb-item.active {
  color: var(--gold);
  /*font-size: 0.82rem;*/
  font-weight: 700;
  font-family: var(--font-body);
}

/* Separator */
.breadcrumb-card .breadcrumb-item + .breadcrumb-item::before {
  content: '/';
  color: rgba(255, 255, 255, 0.3);
  font-weight: 300;
}

/* =============================================
   RESPONSIVE — TABLET (768px)
   ============================================= */
@media (max-width: 991.98px) {
  .page-header-wrap {
    padding: 80px 0 70px;
    clip-path: polygon(0 0, 100% 0, 100% 92%, 0 100%);
    margin-bottom: 50px;
  }

  .header-left {
    padding-right: 0;
    margin-bottom: 24px;
  }

  .header-right {
    justify-content: flex-start;
  }

  .deco-circle-1 {
    width: 240px;
    height: 240px;
    top: -60px;
    right: -60px;
  }

  .deco-circle-2 {
    display: none;
  }
}

/* =============================================
   RESPONSIVE — MOBILE (576px)
   ============================================= */
@media (max-width: 575.98px) {
  .page-header-wrap {
    padding: 60px 0 55px;
    clip-path: polygon(0 0, 100% 0, 100% 94%, 0 100%);
    margin-bottom: 40px;
  }

  .header-title {
    font-size: 2rem;
  }

  .deco-stripe {
    left: 12px;
  }

  .deco-circle-1 {
    width: 160px;
    height: 160px;
    top: -30px;
    right: -30px;
  }

  .deco-circle-3 {
    display: none;
  }

  .breadcrumb-card {
    padding: 12px 18px;
    width: 100%;
  }

  .header-right {
    justify-content: flex-start;
  }
}






/*offers sections*/
/* ── Section ── */
.deals-section {
  padding: 60px 0 80px;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(200,144,42,0.08) 0%, transparent 60%),
    radial-gradient(ellipse at 10% 80%, rgba(200,144,42,0.05) 0%, transparent 50%),
    var(--bg);
  position: relative;
  overflow: hidden;
}

.deals-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(200,144,42,0.07) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

/* ── Header ── */
.deals-header h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 700;
  color: var(--cream);
  line-height: 1.2;
}

.deals-header h2 em {
  font-style: italic;
  color: var(--gold);
}

/* ── Filter Tabs ── */
.filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.filter-tab {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  color: var(--muted);
  border-radius: 30px;
  padding: 6px 18px;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.25s ease;
  letter-spacing: 0.3px;
}

.filter-tab:hover,
.filter-tab.active {
  background: var(--gold);
  border-color: var(--gold);
  color: #1a0f07;
}

.filter-tab.new-badge {
  position: relative;
}

.filter-tab.new-badge::after {
  content: '●';
  font-size: 0.4rem;
  color: #e74c3c;
  position: absolute;
  top: 4px;
  right: 6px;
}

/* ── Deal Cards ── */
.deal-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 18px;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  height: 100%;

  /* Fade-in animation */
  opacity: 0;
  transform: translateY(28px);
  animation: cardReveal 0.55s ease forwards;
}

.deal-card:nth-child(1) { animation-delay: 0.05s; }
.deal-card:nth-child(2) { animation-delay: 0.15s; }
.deal-card:nth-child(3) { animation-delay: 0.25s; }
.deal-card:nth-child(4) { animation-delay: 0.35s; }

@keyframes cardReveal {
  to { opacity: 1; transform: translateY(0); }
}

.deal-card::before {
  content: '';
  position: absolute;
  top: -40px; left: -40px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,144,42,0.12), transparent 70%);
  pointer-events: none;
}

.deal-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.55), 0 0 0 1px rgba(200,144,42,0.4);
  border-color: rgba(200,144,42,0.5);
}

/* Card image */
.deal-img-wrap {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--bg2);
  box-shadow: 0 4px 14px var(--shadow);
}

.deal-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.deal-card:hover .deal-img-wrap img {
  transform: scale(1.1);
}

/* Card content */
.deal-body { flex: 1; min-width: 0; }

.deal-badge {
  font-family: 'Playfair Display', serif;
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--gold-lt);
  line-height: 1;
  margin-bottom: 4px;
}

.deal-title {
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--cream);
  margin-bottom: 6px;
  line-height: 1.3;
}

.deal-desc {
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.55;
  margin-bottom: 14px;
}

/* Code + btn row */
.deal-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.deal-code {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(200,144,42,0.12);
  border: 1px dashed rgba(200,144,42,0.5);
  border-radius: 8px;
  padding: 5px 12px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--gold-lt);
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
}

.deal-code:hover { background: rgba(200,144,42,0.22); }

.deal-code .code-icon {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  color: #1a0f07;
  font-weight: 900;
}

.btn-redeem {
  background: var(--btn-bg);
  border: 1px solid rgba(200,144,42,0.4);
  color: var(--cream);
  border-radius: 10px;
  padding: 8px 20px;
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.25s ease;
  white-space: nowrap;
  letter-spacing: 0.3px;
}

.btn-redeem:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #1a0f07;
  transform: scale(1.04);
}

/* Meta row */
.deal-meta {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.06);
  font-size: 0.68rem;
  color: rgba(154,122,90,0.7);
}

/* ── View More Button ── */
.btn-view-more {
  background: transparent;
  border: 1.5px solid var(--border);
  color: var(--cream);
  border-radius: 30px;
  padding: 12px 36px;
  font-family: 'Lato', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.btn-view-more:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #1a0f07;
  transform: scale(1.04);
}

.btn-view-more .arrow {
  transition: transform 0.3s ease;
}

.btn-view-more:hover .arrow {
  transform: translateX(5px);
}

/* ── Toast (copied!) ── */
.copy-toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--gold);
  color: #1a0f07;
  padding: 10px 24px;
  border-radius: 30px;
  font-weight: 700;
  font-size: 0.85rem;
  opacity: 0;
  transition: all 0.3s ease;
  z-index: 9999;
  pointer-events: none;
}

.copy-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ── Responsive ── */
@media (max-width: 575px) {
  .deal-card { flex-direction: column; align-items: flex-start; }
  .deal-img-wrap { width: 100%; height: 160px; border-radius: 10px; }
  .deal-badge { font-size: 1.4rem; }
  .deal-footer { flex-direction: column; align-items: flex-start; }
  .btn-redeem { width: 100%; text-align: center; }
}

/*login design css*/

 #topBtn {
      position: fixed;
      bottom: 40px;
      right: 40px;
      display: none;
      z-index: 99;
      /*border-radius: 50%;*/
      width: 50px;
      height: 50px;
      font-size: 18px;
    }

  .btn-top-button{
    background-color: #e7cfa9;
    color: #000;

  }
  .btn-top-button:hover{
    background-color: #e7cfa9;
    color: #000;
  }
 .signin-item {
  position: relative;
}

/* Dropdown Design */
.login-dropdown {
  position: absolute;
  top: 49px;
  right: -23px;
  width: 280px;
  padding: 20px;
  border-radius: 15px;

  /*background: rgba(255, 255, 255, 0.15);*/
  /*backdrop-filter: blur(15px);*/

  /*box-shadow: 0 10px 25px rgba(0,0,0,0.3);*/
background-color: #b8860b;
  opacity: 0;
  transform: translateY(-20px);
  pointer-events: none;

  transition: all 0.3s ease;
}

/* Show animation */
.login-dropdown.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}


.login-dropdown::after {
    content: '';
    position: absolute;
    top: -6px;
    right: 25px;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 7px solid #b8860b;
}

/* Inputs */
.login-dropdown .form-control {
  background: rgba(255,255,255,0.2);
  border: none;
  color: white;
}

.login-dropdown .form-control::placeholder {
  color: #ddd;
}

.login-dropdown .form-control:focus {
  background: rgba(255,255,255,0.3);
  box-shadow: none;
  color: white;
}

/* Button */
.btn-login {
  background: #2c1a0e;
  border: none;
  color: white;
  transition: 0.3s;
}

.btn-login:hover {
  background: #ff4f91;
  transform: scale(1.05);
}

/* Links */
.small-link {
  color: #fff;
  text-decoration: none;
  font-size: 13px;
}

.small-link:hover {
  text-decoration: underline;
}

/*login desin css End*/


/* menu deatils */

 /* ── Page wrapper ── */
  .detail-page {
    min-height: 100vh;
    padding: 40px 0 80px;
    background:
      radial-gradient(ellipse 80% 50% at 10% 0%, rgba(200,144,42,.07) 0%, transparent 60%),
      radial-gradient(ellipse 60% 40% at 90% 100%, rgba(200,144,42,.05) 0%, transparent 60%),
      var(--espresso);
  }

  /* ── Back button ── */
  .back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--cream-muted);
    font-size: .82rem;
    font-weight: 500;
    letter-spacing: .5px;
    text-transform: uppercase;
    text-decoration: none;
    padding: 8px 16px;
    border: 1px solid var(--border);
    border-radius: 999px;
    transition: all .25s;
    margin-bottom: 36px;
  }
  .back-link:hover {
    color: var(--gold-light);
    border-color: var(--border-light);
    background: var(--gold-glow);
  }
  .back-link svg { transition: transform .25s; }
  .back-link:hover svg { transform: translateX(-3px); }

  /* ── SLIDESHOW ── */
  .slideshow-wrap {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    aspect-ratio: 1/1;
    background: var(--dark-card);
    box-shadow: var(--shadow);
    border: 1px solid var(--border);
  }

  .slide-img {
    position: absolute;
    inset: 0; width: 100%; height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity .7s ease;
  }
  .slide-img.active { opacity: 1; }

  /* Gradient overlay bottom */
  .slideshow-wrap::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 40%;
    background: linear-gradient(transparent, rgba(15,10,6,.7));
    pointer-events: none;
    z-index: 5;
  }

  /* Badge */
  .slide-badge {
    position: absolute;
    top: 16px; left: 16px;
    background: var(--gold);
    color: #fff;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 5px 12px;
    border-radius: 999px;
    z-index: 10;
  }

  .slide-arrow {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    z-index: 10;
    background: rgba(15,10,6,.72);
    border: 1px solid var(--border-light);
    border-radius: 50%;
    width: 38px; height: 38px;
    color: var(--gold-light);
    font-size: 1.3rem;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all .2s;
    padding: 0;
  }
  .slide-arrow:hover { background: var(--gold); border-color: var(--gold); color: #fff; }
  .slide-arrow.left  { left: 12px; }
  .slide-arrow.right { right: 12px; }

  .slide-dots {
    position: absolute;
    bottom: 14px; left: 50%;
    transform: translateX(-50%);
    display: flex; gap: 6px; z-index: 10;
  }
  .dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: rgba(245,237,224,.35);
    cursor: pointer;
    transition: all .3s;
  }
  .dot.active { background: var(--gold-light); transform: scale(1.4); }

  /* ── Thumbnails ── */
  .thumb-row { display: flex; gap: 10px; margin-top: 12px;}
  .thumb-img {
    flex: 1; aspect-ratio: 1/1;
    object-fit: cover;
    border-radius: 10px;
    border: 2px solid transparent;
    cursor: pointer; opacity: .55;
    transition: all .2s;
    width: 100px !important;
  }
  .thumb-img.active, .thumb-img:hover {
    border-color: var(--gold);
    opacity: 1;
    box-shadow: 0 0 10px var(--gold-glow);
  }

  /* ── PRODUCT INFO ── */
  .product-category {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 8px;
  }
  .product-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.6rem;
    font-weight: 700;
    color: var(--cream);
    line-height: 1.15;
    margin-bottom: 10px;
  }

  .stars-row { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
  .stars { color: var(--gold); letter-spacing: 2px; font-size: 1rem; }
  .stars-count { font-size: .78rem; color: var(--text-muted); }

  .price-tag {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 20px;
  }
  .price-currency { font-size: 1.1rem; color: var(--gold); font-weight: 600; margin-top: 4px; }
  .price-value {
    font-family: 'Cormorant Garamond', serif;
    font-size: 3rem;
    font-weight: 700;
    color: var(--gold-light);
    line-height: 1;
  }

  .product-desc {
    color: var(--cream-muted);
    font-size: .9rem;
    line-height: 1.8;
    border-left: 2px solid var(--border-light);
    padding-left: 16px;
    margin-bottom: 28px;
  }

  /* ── Options Grid ── */
  .options-section { margin-bottom: 28px; }
  .options-title {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border);
  }

  .option-label {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .8px;
    color: var(--cream-muted);
    margin-bottom: 6px;
  }

  .form-select {
    background-color: var(--mid-card);
    border: 1.5px solid var(--border);
    border-radius: 10px;
    color: var(--text-main);
    font-family: 'DM Sans', sans-serif;
    font-size: .88rem;
    padding: 10px 14px;
    transition: border-color .2s, box-shadow .2s;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23c8902a' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  }
  .form-select:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px var(--gold-glow);
    background-color: var(--mid-card);
    color: var(--text-main);
  }
  .form-select option { background: var(--roast); }

  /* ── Qty + Cart ── */
  .action-bar {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
  }

  .qty-wrapper {
    display: inline-flex;
    align-items: center;
    background: var(--mid-card);
    border: 1.5px solid var(--border);
    border-radius: 12px;
    padding: 4px 6px;
    gap: 4px;
  }
  .qty-btn {
    background: none; border: none;
    width: 36px; height: 36px;
    border-radius: 8px;
    font-size: 1.2rem;
    color: var(--cream-muted);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s, color .2s;
  }
  .qty-btn:hover { background: var(--gold-glow); color: var(--gold-light); }
  .qty-num {
    min-width: 36px;
    text-align: center;
    font-size: 1rem;
    font-weight: 600;
    color: var(--cream);
  }

  .btn-add-cart {
    flex: 1;
    background: linear-gradient(135deg, var(--gold) 0%, #a87020 100%);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: .95rem;
    font-weight: 600;
    padding: 14px 28px;
    letter-spacing: .5px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: all .25s;
    min-width: 160px;
  }
  .btn-add-cart::before {
    content: '';
    position: absolute;
    top: 0; left: -100%; width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
    transition: left .4s;
  }
  .btn-add-cart:hover::before { left: 100%; }
  .btn-add-cart:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(200,144,42,.4); }
  .btn-add-cart:active { transform: scale(.98); }

  .btn-wishlist {
    width: 50px; height: 50px;
    background: var(--mid-card);
    border: 1.5px solid var(--border);
    border-radius: 12px;
    color: var(--text-muted);
    font-size: 1.2rem;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all .25s;
    flex-shrink: 0;
  }
  .btn-wishlist:hover, .btn-wishlist.liked {
    background: rgba(231,76,60,.12);
    border-color: rgba(231,76,60,.4);
    color: #e74c3c;
  }

  /* ── Divider ── */
  .gold-divider {
    border: none;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--border-light), transparent);
    margin: 48px 0;
  }

  /* ── Related Section ── */
  .section-heading {
    /* text-align: center; */
    margin-bottom: 32px;
  }
  .section-heading .label {
    font-size: .72rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--gold);
    display: block;
    margin-bottom: 6px;
  }
  .section-heading h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--cream);
  }

  .related-card {
    display: block;
    background: var(--dark-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    position: relative;
    transition: all .3s;
  }
  .related-card:hover {
    border-color: var(--border-light);
    box-shadow: 0 8px 32px rgba(0,0,0,.5);
    transform: translateY(-4px);
    color: inherit;
  }

  .related-img-wrap {
    position: relative;
    overflow: hidden;
  }
  .related-img-wrap img {
    width: 100%;
    height: 130px;
    object-fit: cover;
    transition: transform .4s ease;
  }
  .related-card:hover .related-img-wrap img { transform: scale(1.06); }

  .related-card-body { padding: 12px 12px 14px; }
  .related-name {
    font-size: .84rem;
    font-weight: 600;
    color: var(--cream);
    line-height: 1.3;
    margin-bottom: 2px;
  }
  .related-sub { font-size: .72rem; color: var(--text-muted); margin-bottom: 10px; }
  .related-price {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--gold-light);
  }

  .btn-related-add {
    background: var(--gold);
    color: #fff; border: none;
    border-radius: 8px;
    width: 28px; height: 28px;
    font-size: 1rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background .2s, transform .15s;
    padding: 0;
  }
  .btn-related-add:hover { background: var(--gold-light); transform: scale(1.1); }

  .heart-btn {
    position: absolute;
    top: 8px; right: 8px;
    background: rgba(15,10,6,.7);
    border: 1px solid var(--border);
    border-radius: 50%;
    width: 30px; height: 30px;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem;
    color: var(--text-muted);
    cursor: pointer;
    transition: all .2s;
    padding: 0;
    z-index: 5;
  }
  .heart-btn.liked { color: #e74c3c; border-color: rgba(231,76,60,.4); background: rgba(231,76,60,.1); }

  /* ── Info Pills ── */
  .info-pills {
    display: flex; gap: 10px; flex-wrap: wrap;
    margin-bottom: 24px;
  }
  .pill {
    display: flex; align-items: center; gap: 6px;
    background: var(--mid-card);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: .76rem;
    color: var(--cream-muted);
  }
  .pill-icon { font-size: .9rem; }

  /* ── Fade-in animation ── */
  @keyframes fadeUp {
    from { opacity:0; transform:translateY(18px); }
    to   { opacity:1; transform:translateY(0); }
  }
  .fade-up {
    opacity: 0;
    animation: fadeUp .55s ease forwards;
  }
  .fade-up:nth-child(1) { animation-delay: .05s; }
  .fade-up:nth-child(2) { animation-delay: .12s; }
  .fade-up:nth-child(3) { animation-delay: .2s; }
  .fade-up:nth-child(4) { animation-delay: .28s; }

  @media (max-width:575px) {
    .product-title { font-size: 2rem; }
    .price-value   { font-size: 2.4rem; }
    .btn-add-cart  { min-width: 120px; }
    .related-img-wrap img { height: 100px; }
  }



  /* loader */
#page-loader {
  position: fixed;
  inset: 0;
  background: #0f0a06;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  transition: opacity .8s ease, visibility .8s ease;
}
#page-loader.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.cup {
  position: relative;
  width: 220px;
  height: 180px;
  border: 8px solid #ffefdb;
  box-shadow: 0 0 0 12px #352a22;
  border-radius: 10px 10px 60px 75px;
  background: url('../images/coffee.png');
  background-repeat: repeat-x;
  background-position: 0 130px;
  animation: filling 4s infinite;
    z-index: 1;   /* ✅ ఇది add చేయండి */
  overflow: visible;
}
@keyframes filling {
  0%, 100% { background-position: 0 130px; }
  50%       { background-position: 600px -70px; }
}
.cup .cup-handle {
  position: absolute;
  top: 10px;
  right: -74px;
  width: 65px;
  height: 120px;
  border: 12px solid #352a22;
  border-radius: 20px 10px 50px 20px;
}
.cup .steam {
  position: absolute;
  border-radius: 10px 2px;
  width: 8px;
  animation: steaming 2s infinite;
}
@keyframes steaming {
  0%, 100% { opacity: 0; }
  50%       { opacity: 1; filter: blur(.8px); transform: translateY(-10px); }
}
.cup .steam:nth-child(1) { top:-70px;  left:65px;  height:30px; background:#8e5a3423; animation-delay:.2s; }
.cup .steam:nth-child(2) { top:-120px; left:95px;  height:50px; background:#8e5a3454; animation-delay:.6s; }
.cup .steam:nth-child(3) { top:-90px;  left:125px; height:40px; background:#8e5a3433; animation-delay:1s;  }
.loader-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #c8902a;
  margin: 0;
}
.loader-dots span {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #c8902a;
  margin: 0 3px;
  animation: dot-pulse 1.2s ease-in-out infinite;
}
.loader-dots span:nth-child(2) { animation-delay: .2s; }
.loader-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes dot-pulse {
  0%,100% { opacity:.2; transform:scale(.8); }
  50%      { opacity:1;  transform:scale(1.2); }
}
/* ఈ ఒక్క block మాత్రమే add చేయండి — existing code తర్వాత */
.cup .cup-handle {
  position: absolute;
  top: 20px;
  right: -85px;
  width: 65px;
  height: 100px;
  border: 12px solid #ffefdb;
  border-left: none;
  border-radius: 0 50px 50px 0;
  background: transparent;
  z-index: 2;   /* ✅ ఇది important */
}

/* All menus */
/* ══ WRAPPER ══ */
#app {
  position: relative;
  width: 100%;
  padding: 60px 0 80px;
  overflow: hidden;
}

/* ══ SWIPER ══ */
.swiper {
  width: 100%;
  padding: 40px 0 60px !important;
  overflow: visible !important;
}

/* ── Slide ── */
.swiper-slide {
  width: 280px;
  border-radius: 20px;
  overflow: hidden;
  background: #1a1a1a;
  position: relative;
  cursor: pointer;
  transition: transform 0.5s ease, box-shadow 0.5s ease;
  will-change: transform;
}

/* Active slide bigger */
.swiper-slide-active {
  box-shadow: 0 28px 70px rgba(0,0,0,0.7), 0 0 0 1px rgba(200,144,42,0.35) !important;
}

/* ── Animated opacity wrapper ── */
.swiper-carousel-animate-opacity {
  position: relative;
  width: 100%;
  height: 100%;
  transition: opacity 0.5s ease;
}

/* Image */
.swiper-slide img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.swiper-slide-active img {
  transform: scale(1.04);
}

/* Dark gradient overlay */
.swiper-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 30%,
    rgba(0,0,0,0.3) 60%,
    rgba(0,0,0,0.85) 100%
  );
  border-radius: 20px;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.swiper-slide:not(.swiper-slide-active)::after {
  background: linear-gradient(to bottom, rgba(0,0,0,0.2), rgba(0,0,0,0.75));
}

/* ── Slide Content ── */
.slide-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 20px 20px 22px;
  z-index: 2;
  transform: translateY(4px);
  transition: transform 0.4s ease;
}
.swiper-slide-active .slide-content {
  transform: translateY(0);
}

/* Category tag */
.slide-tag {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  border: 1px solid rgba(255,255,255,0.2);
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 7px;
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(4px);
}

.slide-content h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
  margin-bottom: 7px;
  transition: font-size 0.3s ease;
}
.swiper-slide-active .slide-content h2 {
  font-size: 1.25rem;
}

.slide-content p {
  font-size: 0.76rem;
  color: rgba(255,255,255,0.6);
  line-height: 1.6;
  margin-bottom: 12px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.4s ease, opacity 0.4s ease;
}
.swiper-slide-active .slide-content p {
  max-height: 60px;
  opacity: 1;
}

/* Price + button row */
.slide-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.swiper-slide-active .slide-footer {
  opacity: 1;
  transform: translateY(0);
}

.slide-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #e8b84b;
}

.slide-order-btn {
  background: #c8902a;
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 7px 16px;
  font-size: 0.74rem;
  font-weight: 700;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  letter-spacing: 0.3px;
  transition: background 0.2s, transform 0.15s;
}
.slide-order-btn:hover {
  background: #e8b84b;
  color: #1a0a00;
  transform: scale(1.05);
}

/* ── Best Seller badge ── */
.slide-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  background: #e8b84b;
  color: #1a0a00;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 6px;
  letter-spacing: 0.3px;
  opacity: 0;
  transform: scale(0.7);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.swiper-slide-active .slide-badge {
  opacity: 1;
  transform: scale(1);
}

/* ══ NAVIGATION BUTTONS ══ */
.swiper-button-prev,
.swiper-button-next {
  width: 46px !important;
  height: 46px !important;
  background: rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.15) !important;
  border-radius: 50% !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  top: 44% !important;
  transition: all 0.2s !important;
}
.swiper-button-prev { left: 20px !important; }
.swiper-button-next { right: 20px !important; }

.swiper-button-prev:hover,
.swiper-button-next:hover {
  background: #c8902a !important;
  border-color: #c8902a !important;
}
.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 0.9rem !important;
  font-weight: 900;
  color: #fff !important;
}

/* ══ PAGINATION ══ */
.swiper-pagination {
  bottom: 18px !important;
}
.swiper-pagination-bullet {
  width: 7px !important;
  height: 7px !important;
  background: rgba(255,255,255,0.25) !important;
  opacity: 1 !important;
  transition: all 0.3s !important;
}
.swiper-pagination-bullet-active {
  background: #e8b84b !important;
  width: 22px !important;
  border-radius: 4px !important;
}

/* ══ RESPONSIVE ══ */
@media (max-width: 767px) {
  .swiper-slide { width: 240px; }
  .swiper-slide img { height: 270px; }
  .swiper-button-prev { left: 8px !important; }
  .swiper-button-next { right: 8px !important; }
}
@media (max-width: 480px) {
  .swiper-slide { width: 200px; }
  .swiper-slide img { height: 230px; }
}


/* stores */
.stores-section {
  padding: 56px 0 80px;
}

/* ── Section Header ── */
.section-header h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  color: var(--brown);
}
.section-header h2 em { font-style: italic; color: var(--gold); }
.gold-line {
  width: 48px; height: 3px;
  background: var(--gold);
  border-radius: 2px;
  margin: 10px 0 12px;
}
.section-header p { color: var(--muted); font-size: 0.93rem; }

/* ── Store Card ── */
.store-card {
  background: var(--white);
  border: 2px dashed var(--border);
  border-radius: 18px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  opacity: 0;
  transform: translateY(24px);
  animation: fadeUp 0.5s ease forwards;
}
.store-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 36px var(--shadow);
  border-color: var(--gold);
}

.col-md-6:nth-child(1) .store-card { animation-delay: 0.05s; }
.col-md-6:nth-child(2) .store-card { animation-delay: 0.18s; }
.col-12.bottom-card    .store-card { animation-delay: 0.30s; }

@keyframes fadeUp {
  to { opacity: 1; transform: translateY(0); }
}

/* Map */
.store-map {
  width: 100%;
  height: 200px;
  border: none;
  display: block;
  filter: sepia(10%);
  transition: filter 0.3s;
}
.store-card:hover .store-map { filter: sepia(0%); }

/* Bottom card map taller */
.bottom-card .store-map { height: 220px; }

/* Card body */
.store-body { padding: 18px 20px 20px; }

/* Store name row */
.store-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.store-logo {
  width: 32px; height: 32px;
  background: var(--gold);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}
.store-name {
  font-weight: 700;
  font-size: 1rem;
  color: #fff;
  line-height: 1.2;
}

/* Rating row */
.rating-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 14px;
  font-size: 0.8rem;
  color: var(--muted);
}
.stars { color: var(--gold-lt); font-size: 0.85rem; letter-spacing: 1px; }
.rating-num { font-weight: 700; color: var(--brown); }
.review-count { color: var(--muted); }

/* Info rows */
.info-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.5;
}
.info-row svg {
  flex-shrink: 0;
  margin-top: 2px;
}

/* Share + Pin icons top right of map */
.map-wrap { position: relative; }
.map-actions {
  position: absolute;
  top: 10px; right: 10px;
  display: flex;
  gap: 6px;
  z-index: 5;
}
.map-action-btn {
  background: rgba(255,255,255,0.92);
  border: 1px solid #ddd;
  border-radius: 8px;
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  font-size: 0.85rem;
  transition: background 0.2s;
  text-decoration: none;
}
.map-action-btn:hover { background: var(--gold); color: #fff; }

/* Bottom card — wider layout on md+ */
.bottom-card-inner {
  display: flex;
  flex-direction: column;
}

/* Divider */
.card-divider {
  border: none;
  border-top: 1px solid #eee;
  margin: 12px 0;
}

/* Open/Closed */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  margin-left: 8px;
}
.status-badge.open   { background: rgba(39,174,96,0.1); border: 1px solid rgba(39,174,96,0.3); color: #1e8449; }
.status-badge.closed { background: rgba(231,76,60,0.08); border: 1px solid rgba(231,76,60,0.3); color: #c0392b; }
.sdot {
  width: 6px; height: 6px;
  border-radius: 50%;
}
.open   .sdot { background: #27ae60; animation: sdotPulse 1.8s infinite; }
.closed .sdot { background: #e74c3c; }

@keyframes sdotPulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:0.5; transform:scale(1.5); }
}

/* Directions button */
.btn-dir {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--gold);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 8px 18px;
  font-size: 0.8rem;



  /* contect us */

  font-weight: 700;
  text-decoration: none;
  transition: background 0.2s, transform 0.15s;
  margin-top: 4px;
}
.btn-dir:hover { background: var(--brown-mid); color: #fff; transform: scale(1.03); }

/* ── Responsive ── */
@media (max-width: 767px) {
  .store-map { height: 175px; }
  .bottom-card .store-map { height: 175px; }
}



/* contect us */
    /* ── HERO STRIP ── */
    .contact-hero {
      background: var(--dark);
      color: #fff;
      padding: 90px 0 70px;
      position: relative;
      overflow: hidden;
    }
    .contact-hero::before {
      content: 'CONTACT';
      position: absolute;
      right: -20px;
      top: 50%;
      transform: translateY(-50%);
      font-family: 'Playfair Display', serif;
      font-size: 160px;
      font-weight: 600;
      color: rgba(255,255,255,0.04);
      line-height: 1;
      pointer-events: none;
      user-select: none;
    }
    .contact-hero h1 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2.4rem, 5vw, 3.8rem);
      font-weight: 600;
      letter-spacing: -0.5px;
    }
    .contact-hero p {
      font-size: 1.05rem;
      color: rgba(255,255,255,0.6);
      max-width: 420px;
      line-height: 1.7;
    }
    .hero-accent-line {
      width: 48px;
      height: 3px;
      background: var(--accent);
      border-radius: 2px;
      margin-bottom: 24px;
    }

    /* ── MAIN CARD ── */
    .contact-card {
      background: #fff;
      border-radius: 20px;
      box-shadow: 0 8px 48px rgba(0,0,0,0.07);
      overflow: hidden;
      margin-top: 68px;
      margin-bottom: 80px;
    }

    /* ── LEFT INFO PANEL ── */
    .info-panel {
      background: var(--accent);
      padding: 52px 44px;
      color: #fff;
      position: relative;
      overflow: hidden;
    }
    .info-panel::after {
      content: '';
      position: absolute;
      bottom: -60px;
      right: -60px;
      width: 200px;
      height: 200px;
      border-radius: 50%;
      background: rgba(255,255,255,0.07);
    }
    .info-panel h2 {
      font-family: 'Playfair Display', serif;
      font-size: 1.7rem;
      font-weight: 600;
      margin-bottom: 12px;
    }
    .info-panel p {
      font-size: 0.95rem;
      color: rgba(255,255,255,0.8);
      line-height: 1.7;
      margin-bottom: 36px;
    }
    .info-item {
      display: flex;
      align-items: flex-start;
      gap: 16px;
      margin-bottom: 28px;
    }
    .info-icon {
      width: 42px;
      height: 42px;
      border-radius: 10px;
      background: rgba(255,255,255,0.15);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      flex-shrink: 0;
    }
    .info-item-text strong {
      display: block;
      font-weight: 500;
      font-size: 0.85rem;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: rgba(255,255,255,0.65);
      margin-bottom: 3px;
    }
    .info-item-text span {
      font-size: 0.97rem;
      color: #fff;
    }
    .social-links {
      display: flex;
      gap: 10px;
      margin-top: 40px;
      position: relative;
      z-index: 1;
    }
    .social-links a {
      width: 38px;
      height: 38px;
      border-radius: 8px;
      border: 1px solid rgba(255,255,255,0.25);
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      text-decoration: none;
      font-size: 1rem;
      transition: background 0.2s;
    }
    .social-links a:hover {
      background: rgba(255,255,255,0.2);
    }

    /* ── FORM PANEL ── */
    .form-panel {
      padding: 52px 44px;
    }
    .form-panel h2 {
      font-family: 'Playfair Display', serif;
      font-size: 1.7rem;
      font-weight: 600;
      margin-bottom: 6px;
    }
    .form-panel .sub {
      color: var(--muted);
      font-size: 0.95rem;
      margin-bottom: 36px;
    }

    /* custom form controls */
    .form-floating > .form-control,
    .form-floating > .form-select {
      border: 1.5px solid var(--border);
      border-radius: 10px;
      background: #faf9f7;
      font-family: 'DM Sans', sans-serif;
      font-size: 0.97rem;
      color: var(--dark);
      transition: border-color 0.2s, box-shadow 0.2s;
    }
    .form-floating > .form-control:focus,
    .form-floating > .form-select:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 4px rgba(200,120,42,0.12);
      background: #fff;
    }
    .form-floating > label {
      color: var(--muted);
      font-size: 0.92rem;
    }
    .form-floating > textarea.form-control {
      min-height: 130px;
      resize: none;
    }
    .form-check-input:checked {
      background-color: var(--accent);
      border-color: var(--accent);
    }
    .form-check-input:focus {
      box-shadow: 0 0 0 4px rgba(200,120,42,0.12);
    }
    .form-check-label {
      font-size: 0.9rem;
      color: var(--muted);
    }

    /* subject chips */
    .subject-chips {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 24px;
    }
    .subject-chips input[type="radio"] { display: none; }
    .subject-chips label {
      padding: 7px 16px;
      border-radius: 50px;
      border: 1.5px solid var(--border);
      font-size: 0.88rem;
      cursor: pointer;
      color: var(--muted);
      background: #faf9f7;
      transition: all 0.18s;
    }
    .subject-chips input[type="radio"]:checked + label {
      background: var(--accent-light);
      border-color: var(--accent);
      color: var(--accent);
      font-weight: 500;
    }

    /* submit button */
    .btn-send {
      background: var(--dark);
      color: #fff;
      border: none;
      border-radius: 10px;
      padding: 13px 32px;
      font-family: 'DM Sans', sans-serif;
      font-size: 0.97rem;
      font-weight: 500;
      letter-spacing: 0.02em;
      transition: background 0.2s, transform 0.15s;
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }
    .btn-send:hover {
      background: var(--accent);
      transform: translateY(-1px);
    }
    .btn-send i { font-size: 1rem; }

    /* ── BOTTOM STRIP ── */
    .map-strip {
      background: #ede9e3;
      height: 220px;
      border-radius: 16px;
      overflow: hidden;
      margin-bottom: 80px;
    }
    .map-strip iframe {
      width: 100%;
      height: 100%;
      border: none;
      filter: grayscale(30%);
    }

    /* responsive */
    @media (max-width: 767px) {
      .info-panel, .form-panel { padding: 36px 28px; }
      .contact-card { margin-top: -30px; }
    }

    /* loader */
    #preloader {
  position: fixed;
  inset: 0;
  background: #1a110a;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  z-index: 9999;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}

#preloader.hide {
  opacity: 0;
  visibility: hidden;
}

.steam {
  display: flex;
  gap: 10px;
  padding-bottom: 6px;
}
.steam span {
  display: block;
  width: 5px;
  border-radius: 10px;
  background: linear-gradient(to top, #c97c3a88, transparent);
  animation: steamRise 1.8s ease-in-out infinite;
}
.steam span:nth-child(1) { height: 30px; }
.steam span:nth-child(2) { height: 24px; animation-delay: 0.3s; }
.steam span:nth-child(3) { height: 28px; animation-delay: 0.6s; }

@keyframes steamRise {
  0%   { transform: scaleX(1) translateY(0); opacity: 0.8; }
  100% { transform: scaleX(1.6) translateY(-20px); opacity: 0; }
}

.cup {
  position: relative;
  width: 80px;
  height: 70px;
  background: #f5efe0;
  border-radius: 0 0 20px 20px;
  border: 2.5px solid #c4a46b;
  overflow: hidden;
}
.cup::after {
  content: '';
  position: absolute;
  right: -22px;
  top: 12px;
  width: 22px;
  height: 36px;
  border: 2.5px solid #c4a46b;
  border-left: none;
  border-radius: 0 14px 14px 0;
}

.coffee-fill {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: #5c3317;
  animation: fillUp 1.8s ease-in-out infinite alternate;
}
.coffee-fill::after {
  content: '';
  position: absolute;
  top: -4px; left: -10%;
  width: 120%; height: 10px;
  background: #7B4E28;
  border-radius: 50%;
  animation: wave 1.2s ease-in-out infinite alternate;
}

@keyframes fillUp {
  0%   { height: 20%; }
  100% { height: 75%; }
}
@keyframes wave {
  0%   { transform: translateX(-5px); }
  100% { transform: translateX(5px); }
}

.saucer {
  width: 100px;
  height: 14px;
  background: #e8d5b0;
  border-radius: 50%;
  border: 2px solid #c4a46b;
  margin-top: -3px;
}

.dots { display: flex; gap: 8px; }
.dots span {
  width: 7px; height: 7px;
  background: #c97c3a;
  border-radius: 50%;
  animation: dotBounce 1.2s ease-in-out infinite;
}
.dots span:nth-child(2) { animation-delay: 0.2s; }
.dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dotBounce {
  0%, 100% { transform: translateY(0);    opacity: 0.4; }
  50%       { transform: translateY(-8px); opacity: 1;   }
}

.loader-text {
  font-family: Georgia, serif;
  font-size: 14px;
  color: #c97c3a;
  letter-spacing: 4px;
  text-transform: uppercase;
  animation: blink 2s ease-in-out infinite;
}
@keyframes blink {
  0%, 100% { opacity: 0.5; }
  50%       { opacity: 1; }
}

/* ==============================
   END OF PRELOADER CSS
   ============================== */


/* ── SECTION HEADING ── */
.menu-section-tag {
  font-size: 12px;
  font-weight: 600;
  color: #c8921a;
  text-transform: uppercase;
  letter-spacing: 2px;
}
.menu-section-heading {
  font-size: 2rem;
  font-weight: 700;
  color: #2d1a0e;
  font-family: 'Playfair Display', serif;
}
.accent-gold {
  color: #c8921a;
}
.menu-heading-line {
  width: 60px;
  height: 3px;
  background: #c8921a;
  border-radius: 2px;
  margin: 10px auto 0;
}

.menu-card {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: pointer;
}
.menu-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 28px rgba(200,146,26,0.2) !important;
}
.menu-card .card-img-top {
  transition: transform 0.35s ease;
}
.menu-card:hover .card-img-top {
  transform: scale(1.07);
}

/* ===== ICE CREAM SECTION CSS ===== */
.menu-section-dark {
  background-color: #111111;
  padding: 60px 0;
}

.ic-card {
  background: #1a1a1a;
  border-radius: 18px;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.25s ease;
}

.ic-card:hover {
  transform: translateY(-6px);
}

.ic-card .card-img-top {
  height: 200px;        /* ← పెద్ద image height */
  object-fit: cover;
  width: 100%;
}

.ic-card .card-body {
  padding: 14px 16px;
}

.ic-card .card-title {
  color: #ffffff;
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 6px;
}

.ic-card .card-text {
  color: #c8921a;
  font-weight: 700;
  font-size: 16px;
}

/* ── MENU CARD ── */
.menu-card-link {
  display: block;
  height: 120%;
}
.menu-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #f0e6d0;
  box-shadow: 0 3px 14px rgba(0,0,0,0.07);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.menu-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(200,146,26,0.2);
}

/* Image */
.menu-card-img {
  width: 100%;
  height: 160px;
  overflow: hidden;
}
.menu-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}
.menu-card:hover .menu-card-img img {
  transform: scale(1.08);
}

/* Body */
.menu-card-body {
  padding: 12px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.menu-card-name {
  font-size: 14px;
  font-weight: 700;
  color: #2d1a0e;
  line-height: 1.3;
}
.menu-card-sub {
  font-size: 11px;
  color: #999;
  font-style: italic;
}
.menu-card-price {
  font-size: 15px;
  font-weight: 700;
  color: #c8921a;
  margin-top: auto;
  padding-top: 6px;
  border-top: 1px dashed #f0e6d0;
}

/* View All Button */
.btn-view-all-gold {
  display: inline-flex;
  align-items: center;
  background: #c8921a;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding: 11px 30px;
  border-radius: 8px;
  text-decoration: none;
  letter-spacing: 0.5px;
  transition: all 0.22s;
}
.btn-view-all-gold:hover {
  background: #a07015;
  color: #fff;
  transform: translateY(-2px);
}

/* Mobile fix */
@media (max-width: 575.98px) {
  .menu-card-img {
    height: 130px;
  }
  .menu-card-name {
    font-size: 12px;
  }
  .menu-card-price {
    font-size: 13px;
  }
  .menu-section-heading {
    font-size: 1.6rem;
  }
}





/* check out page */
  /* ── PAGE HEADER (matches existing) ── */
  .page-header-wrap {
    /* background: linear-gradient(135deg, var(--brown) 0%, #2a1a10 100%); */
    /* padding: 60px 0 50px; */
    position: relative;
    overflow: hidden;
  }
  .page-header-wrap .deco-circle {
    position: absolute; border-radius: 50%;
    border: 1px solid rgba(201,168,76,0.18);
  }
  .deco-circle-1 { width:260px;height:260px;top:-80px;right:-60px; }
  .deco-circle-2 { width:160px;height:160px;bottom:-40px;left:80px; border-color:rgba(201,168,76,0.12);}
  .deco-circle-3 { width:80px;height:80px;top:30px;left:40%; border-color:rgba(201,168,76,0.20);}
  .deco-stripe {
    position:absolute;top:0;right:120px;width:4px;height:100%;
    background:linear-gradient(to bottom,transparent,var(--gold),transparent);opacity:.3;
  }
  .header-eyebrow {
    font-size:12px;letter-spacing:3px;text-transform:uppercase;
    color:var(--gold-light);margin-bottom:10px;font-weight:500;
  }
  .header-title {
    font-family:'Playfair Display',serif;font-size:clamp(2rem,5vw,3.2rem);
    font-weight:700;color:#fff;line-height:1.1;
  }
  .gold-text { color:var(--gold); }
  .header-divider {
    width:60px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));
    border-radius:2px;margin-top:18px;
  }
  .breadcrumb-card {
    background:rgba(255,255,255,0.07);backdrop-filter:blur(8px);
    border:1px solid rgba(201,168,76,0.25);border-radius:12px;
    padding:14px 22px;display:inline-block;
  }
  .breadcrumb-card .breadcrumb { margin:0; }
  .breadcrumb-item a { color:var(--gold-light);text-decoration:none;font-size:14px; }
  .breadcrumb-item.active { color:rgba(255,255,255,0.6);font-size:14px; }
  .breadcrumb-item+.breadcrumb-item::before { color:rgba(201,168,76,0.5); }

  /* ── CHECKOUT WRAPPER ── */
  .checkout-section {
    padding: 60px 0 80px;
    background: var(--cream);
  }

  /* ── STEPS BAR ── */
  .steps-bar {
    display:flex;align-items:center;justify-content:center;
    gap:0;margin-bottom:48px;
  }
  .step-item {
    display:flex;align-items:center;gap:10px;
  }
  .step-circle {
    width:36px;height:36px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:14px;font-weight:600;border:2px solid var(--border);
    background:var(--soft);color:var(--brown);transition:.3s;
  }
  .step-item.active .step-circle {
    background:var(--gold);border-color:var(--gold);color:#fff;
    box-shadow:0 0 0 4px rgba(201,168,76,0.2);
  }
  .step-item.done .step-circle {
    background:var(--brown);border-color:var(--brown);color:#fff;
  }
  .step-label { font-size:13px;font-weight:500;color:var(--brown);opacity:.6; }
  .step-item.active .step-label { opacity:1;color:var(--gold-dark); }
  .step-item.done .step-label  { opacity:1;color:var(--brown); }
  .step-line { width:60px;height:2px;background:var(--border);margin:0 4px; }
  .step-line.done { background:var(--brown); }
  @media(max-width:480px){
    .step-label{display:none;}
    .step-line{width:30px;}
  }

  /* ── CARDS ── */
  .card-bc {
    background:#fff;border-radius:var(--radius);
    border:1px solid var(--border);box-shadow:var(--shadow);
    padding:32px;
  }
  .card-bc + .card-bc { margin-top:24px; }

  .section-title {
    font-family:'Playfair Display',serif;
    font-size:1.25rem;font-weight:600;color:var(--brown);
    margin-bottom:24px;display:flex;align-items:center;gap:10px;
  }
  .section-title::after {
    content:'';flex:1;height:1px;background:var(--border);
  }
  .title-icon {
    width:36px;height:36px;border-radius:10px;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-size:16px;flex-shrink:0;
  }

  /* ── FORM CONTROLS ── */
  .form-label {
    font-size:13px;font-weight:500;color:var(--brown);
    margin-bottom:7px;letter-spacing:.3px;
  }
  .form-control, .form-select {
    border:1.5px solid rgba(201,168,76,0.3);
    border-radius:10px;padding:11px 16px;
    font-family:'DM Sans',sans-serif;font-size:14px;
    background:var(--cream);color:var(--dark);
    transition:border-color .25s,box-shadow .25s;
  }
  .form-control:focus, .form-select:focus {
    border-color:var(--gold);
    box-shadow:0 0 0 3px rgba(201,168,76,0.15);
    background:#fff;outline:none;
  }
  .form-control::placeholder { color:rgba(61,43,31,0.35); }

  /* Input with icon */
  .input-icon-wrap { position:relative; }
  .input-icon-wrap .form-control { padding-left:44px; }
  .input-icon-wrap .fi {
    position:absolute;left:14px;top:50%;transform:translateY(-50%);
    color:var(--gold);font-size:16px;pointer-events:none;
  }

  /* Payment method tabs */
  .pay-tabs { display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap; }
  .pay-tab {
    flex:1;min-width:100px;padding:14px 10px;border-radius:12px;
    border:2px solid var(--border);background:var(--soft);
    cursor:pointer;text-align:center;transition:.25s;
  }
  .pay-tab:hover { border-color:var(--gold); }
  .pay-tab.selected {
    border-color:var(--gold);background:#fff;
    box-shadow:0 4px 14px rgba(201,168,76,0.18);
  }
  .pay-tab .pt-icon { font-size:22px;margin-bottom:4px; }
  .pay-tab .pt-label { font-size:12px;font-weight:500;color:var(--brown); }

  /* Card number visual */
  .card-preview {
    background:linear-gradient(135deg,var(--brown) 0%,#5c3a25 100%);
    border-radius:16px;padding:24px;color:#fff;
    position:relative;overflow:hidden;margin-bottom:20px;
  }
  .card-preview::before {
    content:'';position:absolute;top:-30px;right:-30px;
    width:160px;height:160px;border-radius:50%;
    background:rgba(201,168,76,0.15);
  }
  .card-preview::after {
    content:'';position:absolute;bottom:-40px;right:40px;
    width:100px;height:100px;border-radius:50%;
    background:rgba(201,168,76,0.10);
  }
  .card-chip {
    width:38px;height:28px;border-radius:6px;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    margin-bottom:20px;
  }
  .card-number-preview {
    font-size:18px;letter-spacing:4px;font-weight:300;
    margin-bottom:20px;font-family:monospace;
  }
  .card-meta { display:flex;justify-content:space-between;align-items:flex-end; }
  .card-meta-label { font-size:10px;opacity:.6;text-transform:uppercase;letter-spacing:1px; }
  .card-meta-val  { font-size:14px;font-weight:500; }
  .card-brand { font-family:'Playfair Display',serif;font-size:20px;color:var(--gold-light); }

  /* ── ORDER SUMMARY ── */
  .order-item {
    display:flex;align-items:center;gap:14px;
    padding:14px 0;border-bottom:1px solid var(--border);
  }
  .order-item:last-of-type{border-bottom:none;}
  .oi-img {
    width:52px;height:52px;border-radius:10px;object-fit:cover;
    background:var(--soft);flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    font-size:24px;border:1px solid var(--border);
  }
  .oi-info { flex:1; }
  .oi-name { font-size:14px;font-weight:500;color:var(--dark); }
  .oi-variant { font-size:12px;color:rgba(61,43,31,0.55);margin-top:2px; }
  .oi-qty {
    background:var(--soft);border:1px solid var(--border);
    border-radius:6px;padding:2px 8px;font-size:12px;
    font-weight:500;color:var(--brown);
  }
  .oi-price { font-size:15px;font-weight:600;color:var(--brown); }

  /* Coupon */
  .coupon-row {
    display:flex;gap:10px;margin:20px 0;
  }
  .coupon-row .form-control { flex:1; }
  .btn-coupon {
    padding:11px 20px;border-radius:10px;
    background:var(--soft);border:1.5px dashed var(--gold);
    color:var(--gold-dark);font-weight:500;font-size:13px;
    cursor:pointer;white-space:nowrap;transition:.25s;
    font-family:'DM Sans',sans-serif;
  }
  .btn-coupon:hover{background:var(--gold);color:#fff;border-style:solid;}

  /* Price breakdown */
  .price-row {
    display:flex;justify-content:space-between;
    font-size:14px;color:var(--brown);padding:8px 0;
  }
  .price-row.total {
    border-top:2px solid var(--border);margin-top:8px;
    padding-top:16px;font-size:18px;font-weight:700;
    color:var(--dark);
  }
  .price-row .badge-discount {
    background:rgba(201,168,76,0.15);color:var(--gold-dark);
    font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500;
  }
  .price-row .savings { color:#2e7d4f;font-weight:500; }

  /* Trust badges */
  .trust-strip {
    display:flex;justify-content:center;gap:24px;
    flex-wrap:wrap;margin-top:20px;padding-top:20px;
    border-top:1px solid var(--border);
  }
  .trust-badge {
    display:flex;align-items:center;gap:7px;
    font-size:12px;color:rgba(61,43,31,0.55);
  }
  .trust-badge i { color:var(--gold);font-size:15px; }

  /* ── SUBMIT BUTTON ── */
  .btn-pay {
    width:100%;padding:16px;border:none;border-radius:12px;
    background:linear-gradient(135deg,var(--brown) 0%,var(--gold-dark) 100%);
    color:#fff;font-family:'DM Sans',sans-serif;
    font-size:16px;font-weight:600;letter-spacing:.5px;
    cursor:pointer;position:relative;overflow:hidden;
    transition:.3s;display:flex;align-items:center;justify-content:center;gap:10px;
  }
  .btn-pay::after {
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,0.08) 100%);
  }
  .btn-pay:hover { transform:translateY(-2px);box-shadow:0 12px 28px rgba(61,43,31,0.35); }
  .btn-pay:active{ transform:translateY(0); }
  .btn-pay .lock-icon { font-size:18px; }
  .btn-pay .amount-badge {
    background:rgba(255,255,255,0.18);border-radius:6px;
    padding:2px 10px;font-size:14px;margin-left:6px;
  }

  /* Sticky summary on mobile */
  @media(max-width:767px){
    .checkout-section{padding:36px 0 60px;}
    .card-bc{padding:20px;}
    .pay-tabs{gap:8px;}
    .pay-tab{min-width:80px;padding:12px 8px;}
    .card-number-preview{font-size:15px;letter-spacing:2px;}
  }

  /* ── ANIMATIONS ── */
  @keyframes slideUp {
    from{opacity:0;transform:translateY(20px);}
    to  {opacity:1;transform:translateY(0);}
  }
  .animate-up { animation:slideUp .5s ease both; }
  .d1{animation-delay:.05s} .d2{animation-delay:.12s} .d3{animation-delay:.2s}


  .cart-badge[data-count="0"] { display: none; }



  /* User Button */
.user-btn {
  text-decoration: none;
  color: #333;
  font-weight: 500;
}

/* Avatar Circle */
.user-avatar {
  width: 35px;
  height: 35px;
  background: linear-gradient(135deg, #c8a45c, #e5c07b);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
}

/* Email text */
.user-email {
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Custom Dropdown */
.custom-dropdown {
  border-radius: 15px;
  padding: 10px;
  border: none;
  min-width: 220px;
}

/* Dropdown items */
.custom-dropdown .dropdown-item {
  border-radius: 10px;
  padding: 8px 12px;
  transition: 0.3s;
}

.custom-dropdown .dropdown-item:hover {
  background: #f8f5ef;
  transform: translateX(5px);
}

/* Header */
.dropdown-header {
  font-size: 14px;
}



/* login ayyaka */
/* ---------- SIGN IN BUTTON ---------- */
.signin-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 20px;
  background: transparent;
  border: 1.5px solid rgba(200, 132, 58, 0.45);
  border-radius: 50px;
  color: #f5ede0;
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.25s ease;
  white-space: nowrap;
}
.signin-btn svg {
  color: #c8843a;
  transition: color 0.25s;
}
.signin-btn:hover {
  background: rgba(200, 132, 58, 0.12);
  border-color: #d4a847;
  color: #d4a847;
  text-decoration: none;
}
.signin-btn:hover svg {
  color: #d4a847;
}

/* ---------- CART BUTTON ---------- */
.cart-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 20px;
  background: linear-gradient(135deg, #c8843a 0%, #d4a847 100%);
  border: none;
  border-radius: 50px;
  color: #1a0f0a;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  position: relative;
  transition: all 0.25s ease;
  white-space: nowrap;
}
.cart-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(200, 132, 58, 0.4);
  color: #1a0f0a;
  text-decoration: none;
}
.cart-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #1a0f0a;
  color: #d4a847;
  font-size: 10px;
  font-weight: 700;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid #d4a847;
  margin-left: 2px;
  line-height: 1;
}

/* ---------- NAV SEPARATOR ---------- */
.nav-sep {
  width: 1px;
  height: 26px;
  background: rgba(200, 132, 58, 0.2);
  display: inline-block;
  margin: 0 2px;
}

/* ---------- USER BUTTON (logged in) ---------- */
.user-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 14px 5px 5px;
  background: rgba(200, 132, 58, 0.1);
  border: 1.5px solid rgba(200, 132, 58, 0.3);
  border-radius: 50px;
  color: #f5ede0 !important;
  font-size: 13px;
  font-weight: 500;
  text-decoration: none !important;
  transition: all 0.2s;
}
.user-btn:hover {
  background: rgba(200, 132, 58, 0.18);
  border-color: #d4a847;
}
.user-btn::after {
  /* remove default bootstrap caret */
  display: none !important;
}
.user-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, #c8843a, #d4a847);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: #1a0f0a;
  flex-shrink: 0;
}
.user-email {
  max-width: 130px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ---------- CUSTOM DROPDOWN ---------- */
.custom-dropdown {
  background: #2a160c !important;
  border: 1px solid rgba(200, 132, 58, 0.2) !important;
  border-radius: 14px !important;
  overflow: hidden;
  padding: 0 !important;
  min-width: 220px;
  margin-top: 8px !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5) !important;
}
.custom-dropdown .dropdown-header {
  background: rgba(200, 132, 58, 0.08);
  border-bottom: 1px solid rgba(200, 132, 58, 0.12);
  padding: 16px;
  text-align: center;
}
.custom-dropdown .dh-avatar {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: linear-gradient(135deg, #c8843a, #d4a847);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  color: #1a0f0a;
  margin: 0 auto 10px;
}
.custom-dropdown .dh-name {
  font-size: 13px;
  font-weight: 600;
  color: #f5ede0;
}
.custom-dropdown .dh-sub {
  font-size: 11px;
  color: rgba(245, 237, 224, 0.4);
  margin-top: 3px;
}
.custom-dropdown .dropdown-divider {
  border-color: rgba(200, 132, 58, 0.12) !important;
  margin: 0;
}
.custom-dropdown .dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  color: rgba(245, 237, 224, 0.7) !important;
  font-size: 13px;
  transition: all 0.18s;
  border-bottom: 1px solid rgba(200, 132, 58, 0.06);
}
.custom-dropdown .dropdown-item:hover {
  background: rgba(200, 132, 58, 0.1) !important;
  color: #f5ede0 !important;
}
.custom-dropdown .dropdown-item.text-danger {
  color: rgba(220, 80, 80, 0.8) !important;
}
.custom-dropdown .dropdown-item.text-danger:hover {
  background: rgba(220, 80, 80, 0.08) !important;
  color: #ff6b6b !important;
}
.custom-dropdown .item-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(200, 132, 58, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
.custom-dropdown .text-danger .item-icon {
  background: rgba(220, 80, 80, 0.1);
}