/* ==========================================================================
   Simple Slice — Global CSS
   Design tokens and shared component styles.
   All colours/fonts come from theme.json CSS custom properties.
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS CUSTOM PROPERTIES (mirrors theme.json for use in plain CSS)
   -------------------------------------------------------------------------- */
:root {
  --ss-cream:        #F3E7CE;
  --ss-charcoal:     #2A2018;
  --ss-tomato:       #C2331C;
  --ss-teal:         #1F6E5C;
  --ss-gold:         #F2A93B;
  --ss-muted:        #5F5043;
  --ss-cream-red:    #FFE2D2;
  --ss-cream-dark:   #D8C9B6;
  --ss-cream-teal:   #D8EFE8;
  --ss-footer-muted: #B09A86;
  --ss-white:        #FFFFFF;

  --ss-font-display: 'Bebas Neue', sans-serif;
  --ss-font-body:    'Archivo', sans-serif;
  --ss-font-script:  'Yellowtail', cursive;

  --ss-max-width:  1240px;
  --ss-side-pad:   40px;
  --ss-section-v:  74px;

  --ss-card-shadow: 6px 6px 0 var(--ss-charcoal);
  --ss-btn-shadow:  4px 4px 0 var(--ss-charcoal);
  --ss-border:      3px solid var(--ss-charcoal);
  --ss-hatch: repeating-linear-gradient(
    45deg,
    rgba(255,255,255,.05) 0 22px,
    transparent 22px 44px
  );
}

/* --------------------------------------------------------------------------
   BASE RESET
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--ss-cream);
  font-family: var(--ss-font-body);
  color: var(--ss-charcoal);
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; }

/* --------------------------------------------------------------------------
   TOP ANNOUNCEMENT STRIP
   -------------------------------------------------------------------------- */
.ss-top-strip {
  background: var(--ss-teal);
  color: var(--ss-cream);
  text-align: center;
  font-family: var(--ss-font-display);
  font-size: 16px;
  letter-spacing: .22em;
  padding: 8px 16px;
}

/* --------------------------------------------------------------------------
   SITE HEADER / NAV
   -------------------------------------------------------------------------- */
.ss-header {
  max-width: var(--ss-max-width);
  margin: 0 auto;
  padding: 14px var(--ss-side-pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.ss-logo img { height: 64px; width: auto; }

.ss-nav {
  display: flex;
  align-items: center;
  gap: 26px;
  font-family: var(--ss-font-display);
  font-size: 22px;
  letter-spacing: .06em;
}

.ss-nav a {
  text-decoration: none;
  color: var(--ss-charcoal);
  transition: color .15s;
}

.ss-nav a:hover,
.ss-nav a.current-menu-item {
  color: var(--ss-tomato);
}

.ss-nav .ss-nav-cta {
  color: var(--ss-cream) !important;
  background: var(--ss-tomato);
  padding: 7px 20px;
  border-radius: 4px;
}

.ss-nav .ss-nav-cta:hover {
  background: var(--ss-charcoal);
  color: var(--ss-cream) !important;
}

/* Mobile nav handled by WordPress overlayMenu="mobile" */

/* --------------------------------------------------------------------------
   PAGE HEADER BANDS (hatch + scallop)
   -------------------------------------------------------------------------- */
.ss-page-header {
  position: relative;
  overflow: hidden;
}

.ss-page-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: var(--ss-hatch);
  pointer-events: none;
}

.ss-page-header__inner {
  position: relative;
  max-width: var(--ss-max-width);
  margin: 0 auto;
  padding: 64px var(--ss-side-pad) 70px;
  text-align: center;
}

.ss-scallop {
  height: 26px;
  background: radial-gradient(circle at 13px -2px, var(--ss-cream) 13px, transparent 14px);
  background-size: 26px 26px;
  background-repeat: repeat-x;
}

/* --------------------------------------------------------------------------
   SECTION WRAPPER
   -------------------------------------------------------------------------- */
.ss-section {
  max-width: var(--ss-max-width);
  margin: 0 auto;
  padding: var(--ss-section-v) var(--ss-side-pad);
}

/* --------------------------------------------------------------------------
   TYPOGRAPHY UTILITIES
   -------------------------------------------------------------------------- */
.ss-display {
  font-family: var(--ss-font-display);
  font-weight: 400;
  line-height: .92;
  letter-spacing: .02em;
}

.ss-script {
  font-family: var(--ss-font-script);
  font-weight: 400;
}

.ss-kicker {
  font-family: var(--ss-font-script);
  font-size: clamp(28px, 3.5vw, 38px);
  color: var(--ss-gold);
  display: block;
  margin-bottom: 4px;
}

.ss-badge {
  display: inline-block;
  background: var(--ss-gold);
  color: var(--ss-charcoal);
  font-family: var(--ss-font-display);
  font-size: 20px;
  letter-spacing: .14em;
  padding: 5px 16px;
  border-radius: 3px;
  transform: rotate(-2deg);
}

/* --------------------------------------------------------------------------
   BUTTONS
   -------------------------------------------------------------------------- */
.ss-btn {
  display: inline-block;
  text-decoration: none;
  font-family: var(--ss-font-display);
  font-size: 24px;
  letter-spacing: .06em;
  padding: 11px 26px;
  border-radius: 5px;
  border: var(--ss-border);
  box-shadow: var(--ss-btn-shadow);
  cursor: pointer;
  transition: transform .1s, box-shadow .1s;
  line-height: 1;
}

.ss-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--ss-charcoal);
}

.ss-btn--primary {
  color: var(--ss-tomato);
  background: var(--ss-cream);
}

.ss-btn--teal {
  color: var(--ss-cream);
  background: var(--ss-teal);
}

.ss-btn--gold {
  color: var(--ss-teal);
  background: var(--ss-gold);
}

.ss-btn--red {
  color: var(--ss-cream);
  background: var(--ss-tomato);
}

/* --------------------------------------------------------------------------
   STICKER CARDS
   -------------------------------------------------------------------------- */
.ss-card {
  background: var(--ss-cream);
  border: var(--ss-border);
  border-radius: 8px;
  box-shadow: var(--ss-card-shadow);
  overflow: hidden;
}

.ss-card__body {
  padding: 18px 22px 24px;
  border-top: var(--ss-border);
}

.ss-card__title {
  font-family: var(--ss-font-display);
  font-size: 32px;
  letter-spacing: .03em;
  color: var(--ss-tomato);
  margin: 0 0 4px;
}

.ss-card__price {
  font-family: var(--ss-font-display);
  font-size: 26px;
  color: var(--ss-tomato);
}

.ss-card__blurb {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ss-muted);
  margin: 4px 0 0;
}

/* --------------------------------------------------------------------------
   MARQUEE
   -------------------------------------------------------------------------- */
@keyframes ss-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.ss-marquee-wrap {
  background: var(--ss-charcoal);
  overflow: hidden;
  padding: 13px 0;
  border-bottom: 3px solid var(--ss-tomato);
}

.ss-marquee-track {
  display: flex;
  width: max-content;
  animation: ss-marquee 38s linear infinite;
  will-change: transform;
}

.ss-marquee-track:hover { animation-play-state: paused; }

.ss-marquee-list {
  display: flex;
  gap: 28px;
  align-items: center;
  padding: 0 28px 0 0;
  font-family: var(--ss-font-display);
  font-size: 26px;
  color: var(--ss-cream);
  letter-spacing: .06em;
  white-space: nowrap;
  list-style: none;
  margin: 0;
  padding-left: 0;
  flex-shrink: 0;
}

.ss-marquee-list .star { color: var(--ss-gold); }

/* --------------------------------------------------------------------------
   TODO IMAGE PLACEHOLDERS
   (Remove once real images are added via Media Library)
   -------------------------------------------------------------------------- */
.ss-img-todo {
  background: var(--ss-charcoal);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ss-gold);
  font-family: var(--ss-font-display);
  font-size: 18px;
  letter-spacing: .1em;
  text-align: center;
  padding: 20px;
}

/* --------------------------------------------------------------------------
   FORMS (shared between Events, Trade, Contact)
   -------------------------------------------------------------------------- */
.ss-form-field {
  width: 100%;
  font-family: var(--ss-font-body);
  font-size: 15px;
  color: var(--ss-charcoal);
  background: var(--ss-white);
  border: 2px solid var(--ss-charcoal);
  border-radius: 6px;
  padding: 12px 14px;
  outline: none;
  transition: border-color .15s;
}

.ss-form-field:focus { border-color: var(--ss-tomato); }

.ss-form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.ss-form-row { margin-bottom: 14px; }

.ss-form-btn {
  width: 100%;
  cursor: pointer;
  color: var(--ss-cream);
  background: var(--ss-tomato);
  font-family: var(--ss-font-display);
  font-size: 26px;
  letter-spacing: .06em;
  padding: 13px;
  border: var(--ss-border);
  border-radius: 6px;
  box-shadow: var(--ss-btn-shadow);
  transition: transform .1s, box-shadow .1s;
}

.ss-form-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--ss-charcoal);
}

/* --------------------------------------------------------------------------
   FOOTER
   -------------------------------------------------------------------------- */
.ss-footer {
  background: var(--ss-charcoal);
  color: var(--ss-cream);
  padding: 40px var(--ss-side-pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
}

.ss-footer__brand {
  display: flex;
  align-items: center;
  gap: 14px;
}

.ss-footer__logo { height: 56px; width: auto; }

.ss-footer__copy {
  font-size: 13px;
  color: var(--ss-footer-muted);
  margin: 0;
}

.ss-footer__links {
  display: flex;
  gap: 22px;
  font-family: var(--ss-font-display);
  font-size: 22px;
  letter-spacing: .06em;
  list-style: none;
  margin: 0;
  padding: 0;
}

.ss-footer__links a {
  text-decoration: none;
  color: var(--ss-cream);
  transition: color .15s;
}

.ss-footer__links a:hover { color: var(--ss-gold); }

.ss-footer__links .ss-footer-accent a { color: var(--ss-gold); }

/* --------------------------------------------------------------------------
   HERO — CIRCLE IMAGE WITH GOLD RING
   -------------------------------------------------------------------------- */
.ss-hero-img-wrap {
  position: relative;
}

.ss-hero-img-wrap::before {
  content: '';
  position: absolute;
  inset: -14px;
  background: var(--ss-gold);
  border-radius: 50%;
}

.ss-hero-img-wrap img,
.ss-hero-img-wrap .ss-img-todo {
  position: relative;
  width: 100%;
  height: 420px;
  border-radius: 50%;
  object-fit: cover;
}

/* --------------------------------------------------------------------------
   ABOUT — STORY IMAGE WITH TEAL BORDER HALO
   -------------------------------------------------------------------------- */
.ss-story-img-wrap {
  position: relative;
}

.ss-story-img-wrap::before {
  content: '';
  position: absolute;
  inset: -12px;
  background: var(--ss-teal);
  border-radius: 10px;
}

.ss-story-img-wrap img,
.ss-story-img-wrap .ss-img-todo {
  position: relative;
  width: 100%;
  height: 440px;
  object-fit: cover;
  border-radius: 8px;
}

/* --------------------------------------------------------------------------
   GALLERY GRID
   -------------------------------------------------------------------------- */
.ss-gallery {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 200px 200px;
  gap: 16px;
}

.ss-gallery__main {
  grid-row: span 2;
}

.ss-gallery img,
.ss-gallery .ss-img-todo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

/* --------------------------------------------------------------------------
   CONTACT FORM — DARK CARD WITH RED SHADOW
   -------------------------------------------------------------------------- */
.ss-contact-form-card {
  background: var(--ss-charcoal);
  border-radius: 12px;
  padding: 36px;
  box-shadow: 8px 8px 0 var(--ss-tomato);
}

.ss-contact-form-card .ss-form-field {
  border-color: var(--ss-charcoal);
}

/* --------------------------------------------------------------------------
   RESPONSIVE BREAKPOINTS
   -------------------------------------------------------------------------- */
@media (max-width: 960px) {
  :root { --ss-side-pad: 24px; --ss-section-v: 50px; }

  .ss-gallery {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }
  .ss-gallery__main { grid-row: span 1; }
}

@media (max-width: 640px) {
  :root { --ss-side-pad: 16px; }

  .ss-form-grid-2 { grid-template-columns: 1fr; }

  .ss-hero-img-wrap { display: none; } /* hide circle image below hero text on mobile */

  .ss-gallery {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
}


/* ==========================================================================
   HEADER NAV FIX — pull everything to the right, group icons with nav
   ========================================================================== */

/* The outer header row */
.ss-site-header .ss-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
}

/* Force the WordPress navigation block to sit right */
.ss-site-header .ss-header .wp-block-navigation {
  margin-left: auto !important;
  justify-content: flex-end !important;
}

/* Nav items row */
.ss-site-header .wp-block-navigation__container {
  display: flex !important;
  align-items: center !important;
  gap: 26px !important;
  flex-wrap: nowrap !important;
}

/* Account icon — pull it in tight next to the nav */
.ss-site-header .wc-block-customer-account {
  margin-left: 18px !important;
  padding-left: 18px !important;
  border-left: 2px solid rgba(42,32,24,.15) !important;
}

/* Basket icon — sit right next to account with no gap */
.ss-site-header .wc-block-mini-cart {
  margin-left: 14px !important;
}

/* Make sure account + basket icons are vertically centred */
.ss-site-header .wc-block-customer-account,
.ss-site-header .wc-block-mini-cart {
  display: flex !important;
  align-items: center !important;
}

/* Icon colour */
.ss-site-header .wc-block-customer-account a,
.ss-site-header .wc-block-mini-cart__button {
  color: var(--ss-charcoal) !important;
}

.ss-site-header .wc-block-customer-account a:hover,
.ss-site-header .wc-block-mini-cart__button:hover {
  color: var(--ss-tomato) !important;
}


/* ==========================================================================
   BUTTON OVERRIDES — force our styles over WordPress block defaults
   ========================================================================== */

.wp-block-button.ss-btn .wp-block-button__link,
.wp-block-button.ss-btn a {
  font-family: var(--ss-font-display) !important;
  font-size: 24px !important;
  letter-spacing: .06em !important;
  padding: 11px 26px !important;
  border-radius: 5px !important;
  border: 3px solid var(--ss-charcoal) !important;
  box-shadow: 4px 4px 0 var(--ss-charcoal) !important;
  text-decoration: none !important;
  display: inline-block !important;
  line-height: 1 !important;
  transition: transform .1s, box-shadow .1s !important;
}

.wp-block-button.ss-btn .wp-block-button__link:active,
.wp-block-button.ss-btn a:active {
  transform: translate(2px, 2px) !important;
  box-shadow: 2px 2px 0 var(--ss-charcoal) !important;
}

/* Primary — cream bg, tomato text */
.wp-block-button.ss-btn--primary .wp-block-button__link {
  background: var(--ss-cream) !important;
  color: var(--ss-tomato) !important;
}

/* Teal — teal bg, cream text */
.wp-block-button.ss-btn--teal .wp-block-button__link {
  background: var(--ss-teal) !important;
  color: var(--ss-cream) !important;
}

/* Gold — gold bg, teal text */
.wp-block-button.ss-btn--gold .wp-block-button__link {
  background: var(--ss-gold) !important;
  color: var(--ss-teal) !important;
}

/* Red — tomato bg, cream text */
.wp-block-button.ss-btn--red .wp-block-button__link {
  background: var(--ss-tomato) !important;
  color: var(--ss-cream) !important;
}

/* Also cover plain <a> buttons used outside wp-block-button */
a.ss-btn--primary { background: var(--ss-cream) !important; color: var(--ss-tomato) !important; }
a.ss-btn--teal    { background: var(--ss-teal) !important;  color: var(--ss-cream) !important; }
a.ss-btn--gold    { background: var(--ss-gold) !important;  color: var(--ss-teal) !important; }
a.ss-btn--red     { background: var(--ss-tomato) !important; color: var(--ss-cream) !important; }


/* ==========================================================================
   CONTACT FORM 7 — field styles
   ========================================================================== */

.wpcf7-form input:not([type="submit"]),
.wpcf7-form textarea,
.wpcf7-form select {
  width: 100%;
  font-family: var(--ss-font-body);
  font-size: 15px;
  color: var(--ss-charcoal);
  background: var(--ss-white);
  border: 2px solid var(--ss-charcoal);
  border-radius: 6px;
  padding: 12px 14px;
  outline: none;
  box-sizing: border-box;
  transition: border-color .15s;
  margin-top: 4px;
}

.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
  border-color: var(--ss-tomato);
}

.wpcf7-form label {
  display: flex;
  flex-direction: column;
  font-family: var(--ss-font-display);
  font-size: 18px;
  letter-spacing: .04em;
  color: var(--ss-charcoal);
  width: 100%;
  margin-bottom: 14px;
}

.wpcf7-form .ss-form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.wpcf7-form input[type="submit"],
.wpcf7-form .ss-form-btn {
  width: 100%;
  cursor: pointer;
  color: var(--ss-cream);
  background: var(--ss-tomato);
  font-family: var(--ss-font-display);
  font-size: 26px;
  letter-spacing: .06em;
  padding: 13px;
  border: 3px solid var(--ss-charcoal);
  border-radius: 6px;
  box-shadow: var(--ss-btn-shadow);
  transition: transform .1s, box-shadow .1s;
  margin-top: 6px;
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-form .ss-form-btn:hover {
  background: var(--ss-charcoal);
}

.wpcf7-form input[type="submit"]:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--ss-charcoal);
}

/* Validation messages */
.wpcf7-not-valid-tip {
  color: var(--ss-tomato);
  font-size: 13px;
  margin-top: 4px;
}

.wpcf7-response-output {
  font-family: var(--ss-font-body);
  font-size: 15px;
  padding: 12px 16px !important;
  border-radius: 6px !important;
  border: 2px solid var(--ss-teal) !important;
  color: var(--ss-teal);
  margin-top: 14px !important;
}

.wpcf7-response-output.wpcf7-validation-errors {
  border-color: var(--ss-tomato) !important;
  color: var(--ss-tomato);
}

@media (max-width: 640px) {
  .wpcf7-form .ss-form-grid-2 {
    grid-template-columns: 1fr;
  }
}


/* ==========================================================================
   LOGO — double size without expanding header height
   ========================================================================== */

.ss-logo {
  overflow: visible !important;
}

.ss-logo .wp-block-site-logo,
.ss-logo .wp-block-site-logo img {
  width: 128px !important;
  height: 128px !important;
  max-width: none !important;
  position: relative;
  z-index: 10;
}


/* ==========================================================================
   MOBILE RESPONSIVE FIXES
   ========================================================================== */

/* Force full width on everything */
body, .wp-site-blocks, .wp-block-group {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

/* --- NAVIGATION — hamburger on mobile --- */

/* Style WordPress's native hamburger button */
.ss-site-header .wp-block-navigation__responsive-container-open {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--ss-charcoal) !important;
  padding: 8px !important;
}

.ss-site-header .wp-block-navigation__responsive-container-open svg {
  fill: var(--ss-charcoal) !important;
  stroke: var(--ss-charcoal) !important;
}

/* Mobile overlay panel — WordPress handles open/close, we just style it */
.ss-site-header .wp-block-navigation__responsive-container.is-menu-open {
  background: var(--ss-charcoal) !important;
}

.ss-site-header .wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-content {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 32px !important;
  height: 100% !important;
}

.ss-site-header .wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation-item__content {
  font-family: var(--ss-font-display) !important;
  font-size: 42px !important;
  letter-spacing: .06em !important;
  color: var(--ss-cream) !important;
  text-decoration: none !important;
}

.ss-site-header .wp-block-navigation__responsive-container.is-menu-open
.ss-nav-cta .wp-block-navigation-item__content {
  color: var(--ss-gold) !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

/* Close button */
.ss-site-header .wp-block-navigation__responsive-container-close {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: var(--ss-cream) !important;
}

.ss-site-header .wp-block-navigation__responsive-container-close svg {
  fill: var(--ss-cream) !important;
  stroke: var(--ss-cream) !important;
}

/* --- HERO — stack on mobile --- */
@media (max-width: 768px) {

  /* Hero inner grid — single column */
  .ss-page-header__inner > div[style*="grid-template-columns"] {
    display: flex !important;
    flex-direction: column !important;
    padding: 36px 20px 48px !important;
    gap: 28px !important;
  }

  /* Hide the pizza circle image on mobile — text is enough */
  .ss-hero-img-wrap {
    display: none !important;
  }

  /* Full width padding on page header */
  .ss-page-header__inner {
    padding: 40px 20px 50px !important;
    text-align: left !important;
  }

  /* Three pizza cards — stack vertically */
  .wp-block-columns[style*="grid-template-columns: repeat(3"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }

  /* Four catering cards — two columns on mobile */
  div[style*="grid-template-columns: repeat(4"] {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }

  /* Catering split band — stack */
  div[style*="grid-template-columns:1fr 1fr"] {
    display: flex !important;
    flex-direction: column !important;
  }

  /* Events + trade enquiry split — stack */
  div[style*="grid-template-columns:1fr 1.1fr"],
  div[style*="grid-template-columns:1fr 1.05fr"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 32px !important;
  }

  /* Contact split grid */
  div[style*="grid-template-columns:1fr 1fr;gap:54px"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 32px !important;
  }

  /* About story split */
  div[style*="grid-template-columns:1fr 1fr;gap:50px"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 28px !important;
  }

  /* Three styles rows on about page */
  div[style*="grid-template-columns:200px 1fr"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }

  /* Hours three columns — stack */
  .wp-block-columns[style*="grid-template-columns: repeat(3"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }

  /* Values cards three columns — stack */
  div[style*="grid-template-columns: repeat(3,1fr)"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }

  /* Section padding */
  .ss-section {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Form grid — single column */
  .ss-form-grid-2 {
    grid-template-columns: 1fr !important;
  }

  /* Gallery — single column on mobile */
  .ss-gallery {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    height: auto !important;
  }

  .ss-gallery img {
    height: 240px !important;
  }

  .ss-gallery__main {
    grid-row: auto !important;
  }

  /* Footer — stack */
  .ss-footer {
    flex-direction: column !important;
    text-align: center !important;
    gap: 16px !important;
  }

  .ss-footer__links {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 16px !important;
  }

  /* Buttons full width on mobile */
  .ss-btn {
    display: block !important;
    text-align: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  div[style*="display:flex;gap:14px"] {
    flex-direction: column !important;
  }
}
