/* ============================================================
   GrillMania — Colors & Type Tokens
   Brand: GrillMania (Chełm, PL) — street-food grill bar
   ============================================================ */

/* ---------- Web Fonts (Google Fonts) ----------
   - Anton:        display, condensed, all-caps. Mirrors the
                   chunky sans on the logo lockup.
   - Bebas Neue:   secondary display, slightly tighter for
                   menus & price tags.
   - Inter:        body / UI text. Strong Polish glyph support.
   - Permanent Marker: chalkboard / "street food sign" accent.
   NOTE: Substitutions. Originals not provided by brand.
*/
/* vietnamese */
@font-face {
  font-family: 'Anton';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/80afdb60.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Anton';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/2d4b5376.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Anton';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/8f3b8fc5.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/bb9c8e13.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Bebas Neue';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/959f7b6b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/3805ebcb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/e1ea5509.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/381860a9.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/62229e6a.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/5ff53ccd.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/3a0b7b3c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/b6542c3c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/3805ebcb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/e1ea5509.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/381860a9.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/62229e6a.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/5ff53ccd.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/3a0b7b3c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/b6542c3c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/3805ebcb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/e1ea5509.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/381860a9.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/62229e6a.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/5ff53ccd.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/3a0b7b3c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/b6542c3c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/3805ebcb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/e1ea5509.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/381860a9.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/62229e6a.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/5ff53ccd.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/3a0b7b3c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/b6542c3c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/3805ebcb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/e1ea5509.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/381860a9.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/62229e6a.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/5ff53ccd.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/3a0b7b3c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/b6542c3c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/3805ebcb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/e1ea5509.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/381860a9.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/62229e6a.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/5ff53ccd.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/3a0b7b3c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/b6542c3c.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin */
@font-face {
  font-family: 'Permanent Marker';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/7e8150f9.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


:root {
  /* ---------- Brand Colors ---------- */
  /* Core fire palette — pulled from the logo flames */
  --fire-red:        #E63629;   /* primary brand red */
  --fire-red-deep:   #B81E14;   /* press / shadow */
  --fire-orange:     #FF6B1A;   /* flame mid */
  --fire-amber:      #FFA51E;   /* flame warm */
  --fire-yellow:     #FFC724;   /* flame tip / highlight */

  /* Charcoal / grill — backgrounds */
  --charcoal-900:    #0A0A0A;   /* pure grill black */
  --charcoal-800:    #141414;
  --charcoal-700:    #1F1F1F;
  --charcoal-600:    #2A2A2A;
  --charcoal-500:    #3A3A3A;
  --ash-400:         #5C5C5C;
  --ash-300:         #8A8A8A;
  --ash-200:         #BFBFBF;
  --ash-100:         #E6E3DE;
  --cream:           #F5EFE6;   /* warm off-white, "napkin" */
  --paper:           #FBF8F2;
  --white:           #FFFFFF;

  /* Accent / supportive */
  --mustard:         #E8A11A;   /* secondary warm */
  --char-smoke:      rgba(10,10,10,0.72);

  /* ---------- Semantic Color Roles ---------- */
  --bg:              var(--charcoal-900);
  --bg-elev:         var(--charcoal-800);
  --bg-card:         var(--charcoal-700);
  --bg-inverse:      var(--cream);

  --fg:              var(--white);
  --fg-muted:        var(--ash-200);
  --fg-subtle:       var(--ash-300);
  --fg-inverse:      var(--charcoal-900);

  --accent:          var(--fire-red);
  --accent-hot:      var(--fire-orange);
  --accent-spark:    var(--fire-yellow);
  --on-accent:       var(--white);

  --border:          rgba(255,255,255,0.10);
  --border-strong:   rgba(255,255,255,0.20);
  --border-inverse:  rgba(10,10,10,0.12);

  --success:         #4CB95A;
  --info:            #2F8FE6;
  --warning:         var(--fire-amber);
  --danger:          var(--fire-red);

  /* ---------- Type Stacks ---------- */
  --font-display:    'Anton', 'Impact', 'Oswald', sans-serif;
  --font-display-2:  'Bebas Neue', 'Anton', 'Impact', sans-serif;
  --font-body:       'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-marker:     'Permanent Marker', 'Caveat', cursive;

  /* ---------- Type Scale (fluid-ish, landing oriented) ---------- */
  --fs-hero:         clamp(64px, 9vw, 144px);  /* big "GRILLMANIA" hero */
  --fs-display:      clamp(48px, 6vw, 88px);
  --fs-h1:           clamp(36px, 4vw, 56px);
  --fs-h2:           clamp(28px, 3vw, 40px);
  --fs-h3:           22px;
  --fs-h4:           18px;
  --fs-body:         16px;
  --fs-body-lg:      18px;
  --fs-small:        14px;
  --fs-micro:        12px;

  --lh-tight:        0.9;
  --lh-snug:         1.05;
  --lh-normal:       1.5;
  --lh-loose:        1.7;

  --tracking-display: -0.01em;
  --tracking-caps:   0.04em;
  --tracking-eyebrow:0.18em;

  /* ---------- Spacing ---------- */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  24px;
  --space-6:  32px;
  --space-7:  48px;
  --space-8:  64px;
  --space-9:  96px;
  --space-10: 128px;

  /* ---------- Radii ---------- */
  --radius-xs:  4px;
  --radius-sm:  8px;
  --radius-md:  12px;
  --radius-lg:  20px;
  --radius-xl:  28px;
  --radius-pill: 999px;

  /* ---------- Shadows / Glow ---------- */
  --shadow-card:    0 8px 24px rgba(0,0,0,0.35);
  --shadow-lift:    0 18px 48px rgba(0,0,0,0.55);
  --glow-fire:      0 0 0 4px rgba(230,54,41,0.20),
                    0 12px 40px rgba(255,107,26,0.45);
  --glow-soft:      0 8px 32px rgba(255,107,26,0.30);

  /* ---------- Motion ---------- */
  --ease-out-soft:  cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-snap:      cubic-bezier(0.34, 1.56, 0.64, 1);
  --dur-fast:       120ms;
  --dur-base:       200ms;
  --dur-slow:       360ms;
}

/* ============================================================
   Semantic element styles — drop these classes onto plain HTML
   ============================================================ */
.gm-bg-dark   { background: var(--bg); color: var(--fg); }
.gm-bg-paper  { background: var(--bg-inverse); color: var(--fg-inverse); }

/* Typography utility classes. Prefixed `.gm-t-` to avoid collisions with
   BEM block names like `.gm-hero` used by full sections. Apply directly to
   elements, not to containers, so descendants don't inherit caps. */
.gm-t-hero {
  font-family: var(--font-display);
  font-size: var(--fs-hero);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-display);
  text-transform: uppercase;
}
.gm-t-display {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  line-height: var(--lh-tight);
  text-transform: uppercase;
}
.gm-t-h1 { font-family: var(--font-display); font-size: var(--fs-h1); line-height: var(--lh-snug); text-transform: uppercase; letter-spacing: var(--tracking-display); }
.gm-t-h2 { font-family: var(--font-display); font-size: var(--fs-h2); line-height: var(--lh-snug); text-transform: uppercase; }
.gm-t-h3 { font-family: var(--font-display-2); font-size: var(--fs-h3); line-height: 1.1;  letter-spacing: var(--tracking-caps); text-transform: uppercase; }
.gm-t-h4 { font-family: var(--font-body); font-size: var(--fs-h4); font-weight: 800; line-height: 1.2; }

.gm-t-eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: 700;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--accent);
}

.gm-t-body    { font-family: var(--font-body); font-size: var(--fs-body);    line-height: var(--lh-normal); font-weight: 400; }
.gm-t-body-lg { font-family: var(--font-body); font-size: var(--fs-body-lg); line-height: var(--lh-normal); font-weight: 500; }
.gm-t-small   { font-family: var(--font-body); font-size: var(--fs-small);   line-height: 1.4;             font-weight: 500; }
.gm-t-micro   { font-family: var(--font-body); font-size: var(--fs-micro);   line-height: 1.3;             font-weight: 600; letter-spacing: var(--tracking-caps); text-transform: uppercase; }

.gm-t-marker  { font-family: var(--font-marker); font-weight: 400; }

/* utility: red flame text */
.gm-fire-text {
  background: linear-gradient(180deg, var(--fire-yellow) 0%, var(--fire-orange) 45%, var(--fire-red) 100%);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
}

/* ============================================================
   Landing-page-only styles (extends colors_and_type.css)
   ============================================================ */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--charcoal-900);
  color: var(--fg);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* layout helpers */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* ------------- HEADER ------------- */
.gm-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10,10,10,0.72);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
}
.gm-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
}
.gm-header__logo {
  display: flex; align-items: center; gap: 12px;
}
.gm-header__logo img {
  width: 44px; height: 44px; border-radius: 50%; object-fit: cover;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.06);
}
.gm-header__name {
  font-family: var(--font-display);
  font-size: 22px; letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 1;
}
.gm-header__name span { color: var(--fire-orange); }
.gm-header__nav { display: flex; align-items: center; gap: 28px; }
.gm-header__nav a {
  font-size: 13px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--fg-muted); transition: color var(--dur-fast) var(--ease-out-soft);
}
.gm-header__nav a:hover { color: var(--fg); }
.gm-header__right { display: flex; align-items: center; gap: 14px; }
.gm-header__phone {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 14px; letter-spacing: 0.02em;
  color: var(--fg);
}
.gm-header__phone svg { width: 16px; height: 16px; color: var(--fire-orange); }
@media (max-width: 800px) {
  .gm-header__nav { display: none; }
  .gm-header__phone { display: none; }
  .gm-header__inner { height: 60px; }
}

/* ------------- BUTTON ------------- */
.gm-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body); font-weight: 800;
  font-size: 15px; letter-spacing: 0.04em;
  padding: 14px 22px;
  border-radius: var(--radius-pill);
  border: 0; cursor: pointer; line-height: 1;
  transition: transform var(--dur-fast) var(--ease-snap),
              background var(--dur-base) var(--ease-out-soft),
              box-shadow var(--dur-base) var(--ease-out-soft);
}
.gm-btn:active { transform: scale(0.97); }
.gm-btn--primary {
  background: var(--fire-red); color: #fff;
  box-shadow: var(--glow-fire);
}
.gm-btn--primary:hover { background: var(--fire-orange); }
.gm-btn--ghost {
  background: transparent; color: #fff;
  border: 1.5px solid rgba(255,255,255,0.35);
  box-shadow: none;
}
.gm-btn--ghost:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.6); }
.gm-btn--dark { background: var(--charcoal-900); color: #fff; box-shadow: none; }
.gm-btn--sm { font-size: 12px; padding: 10px 16px; }
.gm-btn--lg { font-size: 17px; padding: 18px 30px; }
.gm-btn svg { width: 18px; height: 18px; }

/* ------------- HERO ------------- */
.gm-hero {
  position: relative; overflow: hidden;
  padding: 110px 0 130px;
  background:
    radial-gradient(1100px 600px at 80% -10%, rgba(255,107,26,0.35), transparent 60%),
    radial-gradient(900px 500px at 10% 110%, rgba(230,54,41,0.28), transparent 60%),
    var(--charcoal-900);
}
.gm-hero::before {
  /* subtle noise */
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.07 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: 0.5; pointer-events: none;
}

/* ------------- FIRE BACKGROUND ------------- */
.gm-firebg {
  position: absolute; inset: 0; overflow: hidden; pointer-events: none;
  z-index: 0;
}
.gm-firebg__flames { position: absolute; inset: -10% -5% -5% -5%; filter: blur(28px); }
.gm-firebg__flame {
  position: absolute; bottom: -10%; width: 36%; height: 110%;
  border-radius: 50% 50% 30% 30% / 60% 60% 40% 40%;
  mix-blend-mode: screen; opacity: 0.85;
  animation: gm-firepulse 3.2s ease-in-out infinite alternate;
  transform-origin: 50% 100%;
}
.gm-firebg__flame--1 { left: -8%;  background: radial-gradient(ellipse at 50% 100%, rgba(255,199,36,0.95) 0%, rgba(255,107,26,0.85) 32%, rgba(230,54,41,0.6) 55%, transparent 80%); animation-duration: 2.6s; }
.gm-firebg__flame--2 { left: 18%;  background: radial-gradient(ellipse at 50% 100%, rgba(255,199,36,0.95) 0%, rgba(255,107,26,0.9)  30%, rgba(184,30,20,0.55) 60%, transparent 82%); animation-duration: 3.4s; animation-delay: -0.6s; }
.gm-firebg__flame--3 { left: 40%;  background: radial-gradient(ellipse at 50% 100%, rgba(255,231,140,1)    0%, rgba(255,107,26,0.95) 28%, rgba(230,54,41,0.5)  62%, transparent 84%); animation-duration: 2.1s; animation-delay: -1.2s; height: 95%; }
.gm-firebg__flame--4 { left: 60%;  background: radial-gradient(ellipse at 50% 100%, rgba(255,199,36,0.9)  0%, rgba(255,107,26,0.8)  35%, rgba(184,30,20,0.5)  58%, transparent 80%); animation-duration: 3.8s; animation-delay: -0.3s; }
.gm-firebg__flame--5 { left: 78%;  background: radial-gradient(ellipse at 50% 100%, rgba(255,199,36,0.95) 0%, rgba(255,107,26,0.9)  30%, rgba(230,54,41,0.55) 60%, transparent 82%); animation-duration: 2.9s; animation-delay: -1.6s; }
@keyframes gm-firepulse {
  0%   { transform: scaleY(0.92) scaleX(1.02); opacity: 0.75; }
  35%  { transform: scaleY(1.08) scaleX(0.95); opacity: 0.95; }
  60%  { transform: scaleY(1.00) scaleX(1.05); opacity: 0.85; }
  100% { transform: scaleY(1.14) scaleX(0.92); opacity: 1; }
}
.gm-firebg__embers { position: absolute; inset: 0; }
.gm-firebg__ember {
  position: absolute; bottom: 0;
  width: 4px; height: 4px; border-radius: 50%;
  background: radial-gradient(circle, #FFE780 0%, #FF6B1A 60%, transparent 100%);
  box-shadow: 0 0 8px rgba(255,180,40,0.9);
  animation: gm-ember 4s linear infinite;
  opacity: 0;
}
@keyframes gm-ember {
  0%   { transform: translateY(0)     translateX(0)   scale(1);   opacity: 0; }
  10%  { opacity: 1; }
  100% { transform: translateY(-110vh) translateX(20px) scale(0.3); opacity: 0; }
}
.gm-firebg__veil {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,0.45) 0%, rgba(10,10,10,0.15) 40%, rgba(10,10,10,0.65) 100%);
}
.gm-hero__grid { z-index: 1; } /* keep content above the fire layer */
.gm-hero__grid {
  position: relative;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: center;
}
.gm-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--fire-amber);
  padding: 6px 14px; border-radius: var(--radius-pill);
  background: rgba(255,165,30,0.10); border: 1px solid rgba(255,165,30,0.25);
  margin-bottom: 22px;
}
.gm-hero__eyebrow .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--fire-amber); box-shadow: 0 0 12px var(--fire-amber);
}
.gm-hero__title {
  font-family: var(--font-display);
  font-size: clamp(56px, 8vw, 132px);
  line-height: 0.88;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  margin: 0;
}
.gm-hero__title .fire {
  background: linear-gradient(180deg, var(--fire-yellow) 0%, var(--fire-orange) 50%, var(--fire-red) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.gm-hero__sub {
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.5; color: var(--fg-muted);
  margin: 24px 0 32px; max-width: 520px;
}
.gm-hero__sub strong { color: var(--fg); font-weight: 700; }
.gm-hero__ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.gm-hero__meta {
  margin-top: 36px; display: flex; gap: 28px; flex-wrap: wrap;
  font-size: 13px; color: var(--fg-muted); font-weight: 600;
  letter-spacing: 0.04em;
}
.gm-hero__meta-item { display: inline-flex; align-items: center; gap: 8px; }
.gm-hero__meta-item svg { width: 16px; height: 16px; color: var(--fire-orange); }

/* hero visual */
.gm-hero__visual {
  position: relative; aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 40%, rgba(255,165,30,0.4), transparent 55%),
    linear-gradient(160deg, var(--charcoal-700) 0%, var(--charcoal-900) 100%);
  border: 1px solid var(--border);
}
.gm-hero__visual img.gm-hero__photo {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.85) contrast(1.08) saturate(1.05);
}
.gm-hero__visual::after {
  /* warm protection gradient over photo */
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(10,10,10,0.15) 0%, rgba(10,10,10,0) 35%, rgba(10,10,10,0.55) 100%),
    radial-gradient(circle at 30% 20%, rgba(255,107,26,0.2), transparent 60%);
}
.gm-hero__placeholder {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; color: var(--ash-300); font-size: 12px;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.gm-hero__placeholder svg {
  width: 80px; height: 80px; color: var(--fire-orange);
  filter: drop-shadow(0 0 24px rgba(255,107,26,0.5));
}
.gm-hero__badge {
  position: absolute; top: 22px; left: 22px;
  background: rgba(10,10,10,0.82); backdrop-filter: blur(6px);
  border: 1px solid var(--border);
  padding: 10px 14px; border-radius: var(--radius-pill);
  font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 8px;
}
.gm-hero__badge .dot { width: 8px; height: 8px; border-radius: 50%; background: #4CB95A; box-shadow: 0 0 12px #4CB95A; }
.gm-hero__price {
  position: absolute; bottom: 22px; right: 22px;
  background: var(--fire-red); padding: 14px 18px;
  border-radius: var(--radius-md);
  font-family: var(--font-display); text-transform: uppercase;
  font-size: 28px; line-height: 1;
  box-shadow: var(--glow-fire);
  transform: rotate(-4deg);
}
.gm-hero__price small { display: block; font-family: var(--font-body); font-size: 10px; font-weight: 800; letter-spacing: 0.18em; opacity: 0.85; }

/* full-bleed video hero */
.gm-hero--bleed { padding: 140px 0 160px; }
.gm-hero--bleed::before { opacity: 0.3; } /* dial down noise so video reads */
.gm-hero--bleed .gm-hero__grid { grid-template-columns: 1fr; max-width: 760px; }
.gm-hero__bleed {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.7) contrast(1.05) saturate(1.08);
}
.gm-hero__bleed-veil {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(900px 600px at 20% 50%, rgba(10,10,10,0.85) 0%, rgba(10,10,10,0.35) 60%, transparent 100%),
    linear-gradient(180deg, rgba(10,10,10,0.5) 0%, rgba(10,10,10,0.15) 40%, rgba(10,10,10,0.75) 100%);
}

@media (max-width: 900px) {
  .gm-hero { padding: 60px 0 80px; }
  .gm-hero__grid { grid-template-columns: 1fr; gap: 36px; }
  .gm-hero__visual { aspect-ratio: 5/4; }
  .gm-hero--bleed { padding: 80px 0 100px; }
  .gm-hero__bleed-veil {
    background:
      radial-gradient(900px 600px at 50% 30%, rgba(10,10,10,0.6) 0%, rgba(10,10,10,0.3) 60%, transparent 100%),
      linear-gradient(180deg, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.25) 40%, rgba(10,10,10,0.8) 100%);
  }
}

/* ------------- PROMOS ------------- */
.gm-promos {
  padding: 80px 0 40px;
  background: var(--charcoal-900);
  border-bottom: 1px solid var(--border);
}
.gm-promos__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 36px; flex-wrap: wrap;
}
.gm-promos__title {
  font-family: var(--font-display);
  font-size: clamp(36px, 4vw, 56px); line-height: 0.9;
  text-transform: uppercase; margin: 8px 0 0;
  letter-spacing: -0.01em;
}
.gm-promos__sub { font-size: 15px; color: var(--fg-muted); max-width: 420px; text-align: right; }
.gm-promos__sub a { color: var(--fire-orange); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }

.gm-promos__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

.gm-promo {
  appearance: none; border: 1px solid var(--border); cursor: pointer;
  background: var(--charcoal-700); color: inherit;
  border-radius: var(--radius-lg); overflow: hidden;
  display: grid; grid-template-columns: 180px 1fr;
  text-align: left; padding: 0;
  transition: transform var(--dur-base) var(--ease-out-soft),
              box-shadow var(--dur-base) var(--ease-out-soft),
              border-color var(--dur-base) var(--ease-out-soft);
  font-family: inherit;
}
.gm-promo:hover { transform: translateY(-4px); box-shadow: var(--shadow-lift); border-color: rgba(255,165,30,0.5); }
.gm-promo:active { transform: translateY(-2px); }

.gm-promo__media { position: relative; aspect-ratio: 9/16; overflow: hidden; }
.gm-promo__media img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transition: transform 500ms var(--ease-out-soft);
}
.gm-promo:hover .gm-promo__media img { transform: scale(1.05); }

.gm-promo__tag {
  position: absolute; top: 10px; left: 10px;
  font-size: 10px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 5px 9px; border-radius: var(--radius-pill);
  background: rgba(10,10,10,0.75); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.15);
}
.gm-promo__tag--event { color: #ff6b6b; }
.gm-promo__tag--stała { color: var(--fire-amber); }

.gm-promo__body {
  padding: 22px 24px; display: flex; flex-direction: column; gap: 8px;
  justify-content: center;
}
.gm-promo__eyebrow {
  font-size: 11px; font-weight: 800; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--fire-orange);
}
.gm-promo__title {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 0.95; text-transform: uppercase;
  margin: 0; letter-spacing: -0.005em;
}
.gm-promo__sub { font-size: 14px; color: var(--fg-muted); line-height: 1.45; margin: 4px 0 8px; }
.gm-promo__cta {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--fg);
}
.gm-promo__cta svg { width: 14px; height: 14px; transition: transform var(--dur-base) var(--ease-out-soft); }
.gm-promo:hover .gm-promo__cta svg { transform: translateX(4px); }

@media (max-width: 900px) {
  .gm-promos__grid { grid-template-columns: 1fr; }
  .gm-promo { grid-template-columns: 130px 1fr; }
  .gm-promos__sub { text-align: left; }
}
@media (max-width: 480px) {
  .gm-promo { grid-template-columns: 110px 1fr; }
  .gm-promo__body { padding: 16px 18px; }
}

/* lightbox */
.gm-promo__lightbox {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(10,10,10,0.92); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  padding: 40px 24px;
  animation: gm-fade 180ms var(--ease-out-soft);
}
.gm-promo__lightbox img {
  max-width: 100%; max-height: 100%; height: auto;
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lift);
  cursor: zoom-out;
}
.gm-promo__close {
  position: absolute; top: 22px; right: 22px;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,0.08); border: 1px solid var(--border-strong);
  color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-fast) var(--ease-out-soft);
}
.gm-promo__close:hover { background: rgba(255,255,255,0.16); }
@keyframes gm-fade { from { opacity: 0; } to { opacity: 1; } }

/* ------------- WHY US ------------- */
.gm-why { padding: 60px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.gm-why__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.gm-why__card {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 24px 26px;
  background: var(--charcoal-700);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.gm-why__icon {
  width: 48px; height: 48px; flex-shrink: 0;
  border-radius: 14px;
  background: rgba(255,107,26,0.12);
  display: flex; align-items: center; justify-content: center;
  color: var(--fire-orange);
}
.gm-why__icon svg { width: 26px; height: 26px; }
.gm-why__title { font-family: var(--font-display); font-size: 22px; text-transform: uppercase; line-height: 1; margin: 0 0 6px; letter-spacing: 0.01em; }
.gm-why__desc { font-size: 14px; color: var(--fg-muted); line-height: 1.5; margin: 0; }
@media (max-width: 800px) {
  .gm-why__grid { grid-template-columns: 1fr; }
}

/* ------------- MENU BOARD (cream inverse) ------------- */
.gm-menu {
  background: var(--cream); color: var(--charcoal-900);
  padding: 100px 0 110px;
  position: relative;
}
.gm-menu::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 40px;
  background: linear-gradient(180deg, var(--charcoal-900), transparent);
}
.gm-menu__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 48px; flex-wrap: wrap; }
.gm-menu__eyebrow {
  font-size: 12px; font-weight: 800; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--fire-red);
}
.gm-menu__title {
  font-family: var(--font-display);
  font-size: clamp(44px, 5vw, 72px); line-height: 0.9;
  text-transform: uppercase; margin: 8px 0 0;
  letter-spacing: -0.01em;
}
.gm-menu__sub { font-size: 16px; color: #5C5C5C; max-width: 360px; text-align: right; }

.gm-menu__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.gm-menu__item {
  background: #fff; border: 1px solid rgba(0,0,0,0.07);
  border-radius: var(--radius-lg);
  padding: 22px; display: flex; flex-direction: column; gap: 14px;
  transition: transform var(--dur-base) var(--ease-out-soft), box-shadow var(--dur-base) var(--ease-out-soft);
}
.gm-menu__item:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); }
.gm-menu__photo {
  aspect-ratio: 4/3; border-radius: var(--radius-md);
  background: linear-gradient(140deg, #2a1810, #0a0a0a);
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.45);
}
.gm-menu__photo img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.95) saturate(1.05);
  transition: transform 400ms var(--ease-out-soft);
}
.gm-menu__item:hover .gm-menu__photo img { transform: scale(1.05); }

body.gm-no-photos .gm-menu__photo img { display: none; }
/* video element rendered through the same class as <img> */
.gm-hero__visual video.gm-hero__photo { object-fit: cover; }
body.gm-no-photos .gm-hero__photo { display: none; }
body.gm-no-photos .gm-menu__photo::after {
  content: "Miejsce na zdjęcie";
  position: absolute; inset: auto 0 8px 0; text-align: center;
  font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
body.gm-no-photos .gm-menu__photo .lucide,
body.gm-no-photos .gm-menu__photo > i { display: block; }
.gm-menu__photo svg { width: 48px; height: 48px; color: var(--fire-orange); }
.gm-menu__photo small { position: absolute; bottom: 8px; left: 10px; font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; }
.gm-menu__row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.gm-menu__name { font-family: var(--font-display); font-size: 24px; text-transform: uppercase; line-height: 1.05; margin: 0; letter-spacing: -0.01em; flex: 1 1 auto; min-width: 0; }
.gm-menu__price { font-family: var(--font-display-2); font-size: 24px; letter-spacing: 0.02em; color: var(--fire-red); white-space: nowrap; flex-shrink: 0; }
.gm-menu__desc { font-size: 13px; color: #5C5C5C; line-height: 1.45; margin: 0; }
.gm-menu__tag {
  display: inline-block; padding: 4px 10px; border-radius: var(--radius-pill);
  font-size: 10px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase;
  background: var(--fire-red); color: #fff; align-self: flex-start;
}
@media (max-width: 900px) { .gm-menu__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .gm-menu__grid { grid-template-columns: 1fr; } .gm-menu__sub{text-align:left;} }

/* category chips */
.gm-menu__chips { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 36px; }
.gm-menu__chip {
  font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 10px 16px; border-radius: var(--radius-pill);
  background: #fff; border: 1px solid rgba(0,0,0,0.08); color: var(--charcoal-900);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out-soft);
}
.gm-menu__chip:hover { border-color: var(--fire-red); color: var(--fire-red); }
.gm-menu__chip--active { background: var(--charcoal-900); color: #fff; border-color: var(--charcoal-900); }

/* ------------- LOCATION ------------- */
.gm-loc { padding: 100px 0; }
.gm-loc__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.gm-loc__title { font-family: var(--font-display); font-size: clamp(40px, 5vw, 64px); text-transform: uppercase; line-height: 0.92; letter-spacing: -0.01em; margin: 14px 0 24px; }
.gm-loc__rows { display: flex; flex-direction: column; gap: 18px; margin-top: 28px; }
.gm-loc__row { display: flex; gap: 14px; align-items: flex-start; }
.gm-loc__row svg { width: 22px; height: 22px; color: var(--fire-orange); flex-shrink: 0; margin-top: 2px; }
.gm-loc__row-label { font-size: 11px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-muted); }
.gm-loc__row-value { font-size: 17px; font-weight: 600; margin-top: 2px; }
.gm-loc__map {
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl); overflow: hidden;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,107,26,0.18), transparent 60%),
    linear-gradient(140deg, var(--charcoal-700), var(--charcoal-900));
  border: 1px solid var(--border);
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.gm-loc__map svg { width: 60px; height: 60px; color: var(--fire-red); filter: drop-shadow(0 0 16px rgba(230,54,41,0.7)); }
.gm-loc__map-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 32px 32px;
}
.gm-loc__map-label {
  position: absolute; bottom: 18px; left: 18px;
  background: rgba(10,10,10,0.82); backdrop-filter: blur(6px);
  padding: 10px 14px; border-radius: var(--radius-md); font-size: 12px; font-weight: 700;
  border: 1px solid var(--border); letter-spacing: 0.06em;
}
@media (max-width: 900px) { .gm-loc__grid { grid-template-columns: 1fr; } }

/* ------------- SOCIAL ------------- */
.gm-social {
  padding: 80px 0; background: var(--charcoal-800);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.gm-social__inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.gm-social__title { font-family: var(--font-display); font-size: clamp(32px, 3.5vw, 48px); text-transform: uppercase; line-height: 0.95; margin: 0; max-width: 580px; }
.gm-social__links { display: flex; gap: 12px; }

/* ------------- FOOTER ------------- */
.gm-foot { padding: 48px 0 120px; }
.gm-foot__inner { display: flex; justify-content: space-between; gap: 32px; flex-wrap: wrap; align-items: flex-end; }
.gm-foot__brand { display: flex; align-items: center; gap: 14px; }
.gm-foot__brand img { width: 56px; height: 56px; border-radius: 50%; }
.gm-foot__tag { font-family: var(--font-display); font-size: 24px; text-transform: uppercase; letter-spacing: 0.02em; }
.gm-foot__meta { font-size: 13px; color: var(--fg-subtle); }
.gm-foot__meta a:hover { color: var(--fire-orange); }
.gm-foot__legal { font-size: 11px; color: var(--ash-400); letter-spacing: 0.06em; text-transform: uppercase; }

/* ------------- STICKY MOBILE BOTTOM BAR ------------- */
.gm-orderbar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  background: rgba(10,10,10,0.92); backdrop-filter: blur(12px);
  border-top: 1px solid var(--border);
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  display: none; gap: 10px;
}
.gm-orderbar .gm-btn { flex: 1; justify-content: center; padding: 14px; font-size: 14px; }
@media (max-width: 800px) {
  .gm-orderbar { display: flex; }
  body { padding-bottom: 84px; }
}

/* ------------- TOAST ------------- */
.gm-toast {
  position: fixed; left: 50%; bottom: 30px; transform: translateX(-50%);
  background: var(--charcoal-900); color: #fff;
  padding: 14px 22px; border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lift);
  font-size: 14px; font-weight: 600;
  z-index: 100;
  display: flex; align-items: center; gap: 10px;
  animation: gm-toast 200ms var(--ease-snap);
}
.gm-toast svg { width: 18px; height: 18px; color: var(--fire-orange); }
@keyframes gm-toast {
  from { opacity: 0; transform: translate(-50%, 14px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}
@media (max-width: 800px) { .gm-toast { bottom: 100px; } }