/* ============================================================
   CHILI'S Nascar GIVEAWAY — style.css
   ============================================================ */

   @font-face {
    font-family: "TT Norms Pro Variable";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/TT+Norms+Pro+Variable.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
    font-feature-settings: "liga" off,"clig" off
}

@font-face {
    font-family: "TT Norms Pro Variable - Exp Black";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/TT+Norms+Pro+Variable.ttf") format("truetype");
    font-weight: 845;
    font-style: normal;
    font-display: swap;
    font-feature-settings: "liga" off,"clig" off
}

@font-face {
    font-family: "TT Norms Pro Variable - Compact Black";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/TT+Norms+Pro+Variable.ttf") format("truetype");
    font-weight: 845;
    font-style: normal;
    font-display: swap;
    font-feature-settings: "liga" off,"clig" off;
    leading-trim:both;text-edge:cap}

@font-face {
    font-family: "TT Norms Pro Variable - Extra Bold";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/TT+Norms+Pro+Variable.ttf") format("truetype");
    font-weight: 740;
    font-style: normal;
    font-display: swap;
    font-feature-settings: "liga" off,"clig" off;
    leading-trim:both;text-edge:cap}

@font-face {
    font-family: "TT Norms Pro Variable - Compact Extra Bold";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/TT+Norms+Pro+Variable.ttf") format("truetype");
    font-weight: 740;
    font-style: normal;
    font-display: swap;
    font-feature-settings: "liga" off,"clig" off
}

@font-face {
    font-family: "TT Norms Pro Variable - Demi Bold";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/TT+Norms+Pro+Variable.ttf") format("truetype");
    font-weight: 545;
    font-style: normal;
    font-display: swap;
    font-feature-settings: "liga" off,"clig" off;
    leading-trim:both;text-edge:cap}

@font-face {
    font-family: "Dirk-Black";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/Dirk-Black.otf") format("opentype");
    font-weight: 800;
    font-style: normal;
    font-display: swap;
    leading-trim:both;text-edge:cap;font-feature-settings: "liga" off,"clig" off
}

@font-face {
    font-family: "Alfa Slab One";
    src: url("https://galeinternal-emailcreatives.s3.us-west-2.amazonaws.com/chilis-marg-day/AlfaSlabOne-Regular.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap
}

/* ── CSS Reset / Base ─────────────────────────────────────── */

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

* {
  margin: 0;
outline: none;
}

a { outline: 0; }    /* this too */

body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
  margin: 0;
  padding: 0;
}

p {
  text-wrap: pretty;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  text-wrap: balance;
}

#root,
#__next {
  isolation: isolate;
}

.row {
  --bs-gutter-x: 0;
}


/* ── CSS Custom Properties ────────────────────────────────── */

:root {
  color-scheme: light;
  --background-color: #ffffff;
  --text-color: #000000;
  --nav-h: 80px;
}

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: light;
    --background-color: #ffffff;
    --text-color: #000000;
    
  }
}


/* ── Global Layout ────────────────────────────────────────── */

body {
  min-width: 320px;
  width: 100vw;
  height: fit-content;
  overflow-x: hidden;
  background-color: #eeece7;
  font-family: "Montserrat", sans-serif;
  font-variation-settings: "slnt" 0;
}

main {
  position: relative;
  width: 100%;
  height: fit-content;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

a,
button {
  cursor: pointer;
  background: rgba(0, 0, 0, 0);
  border: none;
  text-decoration: none;
}

a {
  color: inherit;
  text-decoration: none;
}

sup {
  top: -0.25em;
  line-height: 10px;
  vertical-align: 2px;
}

.max-1440 {
  max-width: 1440px;
  margin: 0 auto;
}

.max-1170 {
  max-width: 1170px;
  margin: 0 auto;
}

.full-width {
  width: 100%;
}

.inner-box {
  position: relative;
  content: "";
  width: 100%;
  height: 100%;
}


/* ── Focus / Accessibility ────────────────────────────────── */

a {
  outline: none;
}

a:hover {
  border-radius: 8px;
  outline: 2px solid #FFC60B;
  outline-offset: 2px;
}

/* Only show focus for keyboard users */
a:focus:not(:focus-visible) {
  outline: none;
}

a:focus-visible {
  border-radius: 8px;
  outline: 2px solid #ED1C24;
  outline-offset: 2px;
}
.btn:focus-visible {
  outline: 2px solid #ED1C24;
  border-radius: 8px;
}


/* ── Typography Scale ─────────────────────────────────────── */

/* Headings */
h1 {
  transition: all .3s;
  font-family: Montserrat, sans-serif;
  font-weight: 600;
  font-size: 25px;
  line-height: normal;
  text-transform: uppercase;
}

h2 {
  transition: all .3s;
  font-family: Montserrat, sans-serif;
  font-weight: 900;
  font-size: 20px;
  line-height: normal;
  text-transform: uppercase;
}

h3 {
  transition: all .3s;
  font-family: Montserrat, sans-serif;
  font-weight: 900;
  font-size: 18px;
  font-style: normal;
  line-height: 140%;
  text-transform: uppercase;
}

/* Accent Headings */
.headline {
  transition: all .3s;
  font-size: 42px;
  line-height: 100%;
  text-transform: uppercase;
  font-weight: 400;
  font-family: Alfa Slab One;
  color: #ED1C24;
  letter-spacing: 0px;
}

.h1-accent {
  transition: all .3s;
  font-family: "Dirk-Black", sans-serif;
  font-size: 60px;
  line-height: 100%;
  text-transform: uppercase;
}

.h2-accent {
  transition: all .3s;
  font-family: 'Alfa Slab One', sans-serif;
  font-size: 40px;
  font-weight: 400;
  font-style: normal;
  line-height: 100%;
  text-transform: uppercase;
  color: #ED1C24;
}

.h3-accent {
  transition: all .3s;
  font-family: "Dirk-Black", sans-serif;
  font-size: 40px;
  line-height: 100%;
  text-transform: uppercase;
}

.h4-accent {
  transition: all .3s;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 20px;
  font-style: normal;
  line-height: 100%;
  text-transform: uppercase;
  color: #EEECE7;
}

.h5-accent {
  transition: all .3s;
  font-family: "Dirk-Black", sans-serif;
  font-size: 31px;
  font-style: normal;
  line-height: 100%;
  text-transform: uppercase;
}

/* Body / Utility Text */
.body-large {
  font-family: Montserrat, sans-serif;
  font-weight: 900;
  font-size: 18px;
  line-height: 140%;
}

.body-medium {
  font-family: Montserrat, sans-serif;
  font-weight: 800;
  font-size: 16px;
  line-height: 140%;
}

.body-small {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 140%;
}

.legal {
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 120%;
  color: #ffffff;
}

p.small-text {
  font-size: 14px;
  text-align: left;
  line-height: 120%;
  font-weight: 400;
  font-family: Montserrat, sans-serif;
  color: #ffffff;
}

/* Superscript Variants */
.right-symbol {
  font-size: 11px;
  top: -0.65em;
  font-weight: 900;
  font-family: Montserrat, sans-serif;
}

.dollar-sup {
  font-size: 10px;
  font-weight: 900;
  top: -0.6em;
}

.sup-alfa {
  font-family: "Alfa Slab One", serif;
  font-size: 18px;
  top: -1em;
}

.trade-symbol {
  font-size: 12px;
  top: -2.2em;
}

/* Data Display */
.data-title {
  transition: all .3s;
  font-family: "Dirk-Black", sans-serif;
  font-size: 60px;
  font-style: normal;
  line-height: 95%;
}

.data-title-small {
  transition: all .3s;
  font-family: "Dirk-Black", sans-serif;
  font-size: 60px;
  line-height: 95%;
}

.data-large {
  transition: all .3s;
  font-family: Montserrat, sans-serif;
  font-size: 26px;
  font-weight: 400;
  line-height: 80%;
  text-transform: uppercase;
}

.data-small {
  transition: all .3s;
  font-family: Montserrat, sans-serif;
  font-weight: 900;
  font-size: 10px;
  line-height: 80%;
  text-transform: uppercase;
}

.data-price {
  transition: all .3s;
  font-family: "Alfa Slab One", serif;
  font-size: 40px;
  line-height: normal;
  text-transform: uppercase;
}

.data-price-legal {
  transition: all .3s;
  font-family: "Alfa Slab One", serif;
  font-size: 14px;
  line-height: normal;
  text-transform: uppercase;
}

/* Color Utilities */
.txt-thursday-night { color: #22235b; }
.txt-cilantro        { color: #749e33; }
.txt-ranch           { color: #eeece7; }
.txt-white           { color: #fff; }
.txt-Sunrise         { color: #ffc60b; }

.link {
  color: #eeece7;
}

.link:hover {
  color: #ffc60b;
  text-decoration: underline;
}

.breakhypen {
  white-space: nowrap;
}

.horizontal-thick-border {
  border-color: #22235b;
  border-width: 20px;
  opacity: 1;
  margin: 0 16px 10px;
}


/* ── Buttons ──────────────────────────────────────────────── */

.order-btn {
    font-family: "TT Norms Pro Variable - Extra Bold" !important;
}

.btn {
  width: fit-content;
  padding: 10px 50px;
  border: none;
  outline: none;
  border-radius: 8px;
  transition: all .3s;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  color: #fff;
  font-size: 14px;
  line-height: normal;
  letter-spacing: .28px;
  text-transform: uppercase;
}

.primary-btn {
  background: #ed1c24;
}

.primary-btn:focus,
.primary-btn:hover {
  background-color: #fff;
  border-radius: 8px;
  color: #ed1c24;
  padding: 10px 50px !important;
}

.secondary-btn {
  background: #22235b;
}

.secondary-btn:focus,
.secondary-btn:hover {
  background-color: #fff;
  border-radius: 8px;
  color: #22235b;
}


/* ── Navigation ───────────────────────────────────────────── */

nav {
  position: absolute;
  width: 100%;
  top: 0;
  padding: 0;
  z-index: 10;
  transition: all .2s;
}

/* Mobile toggle button */
nav #mobile-nav-toggle-button {
  position: relative;
  z-index: 9;
  padding: 16px;
  background-color: rgba(0, 0, 0, 0);
  border: none;
}

nav #mobile-nav-toggle-button #menu-icon {
  stroke: #ffffff;
}

nav #mobile-nav-toggle-button #close-icon {
  stroke: #ffffff;
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 16px;
  left: 16px;
}

/* Desktop nav — hidden on mobile */
nav #nav-list {
  display: none;
}

/* Mobile drawer */
nav #mobile-nav-list {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

nav #mobile-nav-list #mobile-nav-list-wrapper {
  transition: all .6s;
  background-color: #000000;
  position: relative;
  z-index: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  padding-top: 72px;
  padding-bottom: 50px;
  transform: translateY(-600px);
}

nav #mobile-nav-list #mobile-nav-list-wrapper::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: #000000;
  border-radius: 440px;
  opacity: 0.4;
  filter: blur(103.6949234008789px);
  z-index: -1;
}

nav #mobile-nav-list #mobile-nav-list-wrapper .nav-item {
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-weight: 900;
  line-height: 120%;
  text-transform: uppercase;
  transition: all .3s;
}

nav #mobile-nav-list #mobile-nav-list-wrapper .nav-item:hover {
  color: #FFC60B;
}

/* Expanded state (JS adds .expand) */
nav.expand #mobile-nav-toggle-button #menu-icon {
  visibility: hidden;
  opacity: 0;
}

nav.expand #mobile-nav-toggle-button #close-icon {
  visibility: visible;
  opacity: 1;
}

nav.expand #mobile-nav-list {
  display: block;
}

nav.expand #mobile-nav-list #mobile-nav-list-wrapper {
  transform: translateY(0);
}


/* ── Hero Section ─────────────────────────────────────────── */

#hero {
  color: #FFC60B;
  background-color: #000;
}

#hero #hero-wrapper {
    position: relative;
    padding: 11% 0 20% 0%;
    overflow: hidden;
}

#hero #hero-wrapper::before,
#hero #hero-wrapper::after {
  position: absolute;
  display: block;
  content: "";
  width: 0;
  height: 100%;
  opacity: 0;
  transition: all .3s;
  z-index: 2;
}

#hero #hero-content {
  max-width: 928px;
  position: relative;
  z-index: 1;
  gap: 32px;
  transition: all .3s;
  width: 100%;
  padding: 0px;
}

.hero-badge {
    width: 220px;
    position: absolute;
    z-index: 9;
    left: 50%;
    transform: translateX(-50%);
    top: -16%;
}
.hero-card  {
    background: #22235B;
    padding: 110px 120px 85px;
    border-radius: 20px;
}
.card-headline {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 0px;
    line-height: 1;
    margin-top: 40px;
}
.card-headline img {
    width: 100%;
    max-width: 360px;
}

div#card-form {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 32px;
    align-items: normal;
}


.card-subtext {
    font-family: Montserrat;
    font-size: 28px;
    font-style: normal;
    font-weight: 500;
    line-height: 120%;
    color: #fff;
    text-align: left;
        display: contents;
}
p.card-legal {
    font-family: Montserrat;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 120%;
    color: white;
}
p.card-legal a{
  text-decoration: underline;
}
#hero #hero-img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
    object-fit: cover;
    object-position: center center;
}

#hero #marg-bold-txt-group {
  color: rgba(0, 0, 0, 0);
}

#hero #marg-bold-txt-group span {
  display: block;
  height: 0;
  overflow: hidden;
}

/* Hero state groups */
.welcome {
  gap: 32px;
}

.expired {
  gap: 32px;
}


/* ── Secondary Module (if used) ───────────────────────────── */


/* ════════════════════════════════════════════════════════════
   SECONDARY SECTION
   ════════════════════════════════════════════════════════════ */
#secondary {
  background: #22235B;
  padding: 134px;
}
.secondary-inner {
  max-width: 1100px; margin: 0 auto;
  display: flex; flex-direction: column;
  gap: 40px; align-items: center;
}
.secondary-text { max-width: 480px; }

/* Red italic headline — matches design */
.secondary-headline {
 font-family: "Alfa Slab One";
  font-size: 40px; font-style: normal;  font-weight: 400;
  line-height: 1.05; text-transform: uppercase;
  color: #ED1C24; 
  margin-bottom: 20px; letter-spacing: 0.01em;
}
.secondary-text p {
  font-family: var(--font-body); font-weight: 400;
  font-size: 15px; line-height: 1.7;
  color: rgba(255,255,255,0.82);
}
.secondary-text p + p { margin-top: 14px; }

/* Driver photo — white border frame */
.secondary-image {
  width: 100%; background: #EEECE7;
    box-shadow: 8.939px 8.939px 44.693px 0 rgba(0, 0, 0, 0.20);
    border: 16px solid #EEECE7;
}
.secondary-image img { width: 100%; height: auto; display: block; }


/* ── Form ─────────────────────────────────────────────────── */

form#surveyForm {
  width: 100%;
}

.custom-email {
  max-width: 688px;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 0 40px 0 rgba(0, 0, 0, 0.04);
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.form-control:focus {
  box-shadow: none;
  border: none;
  border-radius: 8px;
  background: #ffffff;
  color: #000000;
  opacity: 1;
}

input[type="email"] {
  border: 0;
  border-radius: 8px;
  height: 50px;
  background: #ffffff;
  color: #000000;
  line-height: 26px;
  margin: 7px 7px 7px 16px;
  outline: none;
  font-size: 18px;
}

button.next.action-button.submit {
  background: #ED1C24;
  border: 0;
  border-radius: 8px;
  color: white;
  height: 50px;
  font-size: 40px;
  line-height: 50px;
  width: 64px;
  margin: 7px 7px 7px 0;
display: flex;
    justify-content: center;
    align-items: center;
}

button.next.action-button.submit:focus {
  outline: none;
  border-radius: 8px;
  border: 2px solid #FFC60B;
}

button.next.action-button.submit:hover {
  background: #ED1C24;
  color: #ED1C24;
  border: 1px solid #ED1C24;
}

/* Placeholder text */
.form-control::placeholder,
::placeholder {
  color: #000000;
  opacity: 1;
}

::-ms-input-placeholder {
  color: #000000;
}

/* Validation error */
.errorMsg {
  display: flex;
  padding-top: 12px;
  color: #ffffff;
  font-weight: 500;
font-family: TT Norms Pro Variable;
}

.borderRed {
  border: 1px solid #ED1C24;
}


/* ── Recipe / How It Works Section ───────────────────────── */

#recipe-section {
  position: relative;
  z-index: 2;
}

.inner-box.d-flex.flex-column.align-items-center.flex-lg-row.justify-content-between{
  gap: 40px;
}

#recipe-section .inner-box p {
  margin-bottom: 0px;
        text-align: left;
        color: white;
        font-size: 24px;
        font-family: "Montserrat", sans-serif;
        font-weight: 500;
        line-height: 120%;
        padding-right: 0px;
}

#recipe-section .inner-box h2:first-of-type {
  margin-bottom: 20px;
}

#recipe-section .inner-box h2:last-of-type {
  margin-bottom: 24px;
}

#recipe-section .recipe-content {
  position: relative;
  z-index: 0;
  padding: 0px;
  color: white;
}

#recipe-section .recipe-group {
  position: relative;
  max-width: 100%;
  transition: all .3s;
}

/* Pin decorative elements */
#recipe-section .pin-group {
  display: block;
  width: fit-content;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 43%;
  width: 15%;
  min-width: 20px;
  min-height: 20px;
  max-width: 40px;
  max-height: 40px;
}

#recipe-section .pin-group .pin-shadow {
  position: absolute;
  width: 140%;
  max-width: none;
  top: 0;
  left: 0px;
}

#recipe-section .pin-group .pin {
  position: absolute;
  width: 100%;
  top: -10px;
  left: 16px;
}

/* Polaroid photos */
#recipe-section .polaroid-photo {
  z-index: 0;
  max-width: 100%;
  box-shadow: 8.102px 8.102px 40.509px 0px rgba(0, 0, 0, .2);
  margin-left: 0%;
  transform-origin: 48% 2%;
  margin-top: 3%;
}

#recipe-section .polaroid-photo.left-photo {
  transform: rotate(-8deg);
  cursor: pointer;
  transition: 500ms cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

#recipe-section .polaroid-photo.left-photo:hover {
  transform: rotate(-3deg);
}

/* Numbered list */
#recipe-section ol.number-list {
  list-style: none;
  counter-reset: list-counter;
  text-align: left;
}

#recipe-section ol.number-list li {
  counter-increment: list-counter;
  position: relative;
  margin-bottom: 30px;
  padding-left: 60px;
}

#recipe-section ol.number-list li:last-child {
  margin-bottom: 0;
}

#recipe-section ol.number-list li::before {
  content: counter(list-counter);
  width: 35px;
  height: 35px;
  border: 2px solid #22235b;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: bold;
  color: #22235b;
  font-family: "Dirk-Black", sans-serif;
  position: absolute;
  left: 0;
  top: 30px;
  transform: translateY(-50%);
}


/* ── Welcome / Hero Copy ──────────────────────────────────── */

.welcome_content {
  margin-bottom: 0px;
  text-align: left;
  color: white;
  font-size: 28px;
  padding-right: 0px;
  font-family: "Montserrat", sans-serif;
  font-weight: 400;
  line-height: 120%;
  padding-right: 45px;
}

.herocopy {
  font-family: "Montserrat", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 120%;
  color: #ffffff;
  padding-bottom: 32px;
}

/* State wrapper display helpers */
.thankYouContent,.newMember,.secondTimeEntry ,.expired{
  padding: 85px 120px;
  flex-direction: column;
  gap: 32px;
}



/* ── Image Sections ───────────────────────────────────────── */

.image-section {
  max-width: 1800px;
  margin: 0 auto;
  background-color: #000000;
}

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

.cheese_img {
  display: block;
  max-width: 100%;
  position: relative;
  margin-top: 30px;
}
.newMember .btn , .expired .btn {
    font-family: 'TT Norms Pro Variable - Extra Bold' !important;
}

/* ── Footer ───────────────────────────────────────────────── */

footer {
  background-color: #000000;
  color: #eeece7;
  padding: 0px 0px;
}

footer #footer-heading {
  margin-bottom: 24px;
}

#footer-deco {
  display: block;
  width: 100%;
  height: 46px;
  background-image: url("https://image.email.chilis.com/lib/fe8e12727762017e7c/m/1/ca87cea0-eed4-4834-a3d7-c8b7dae29f77.jpg");
  background-size: contain;
}

#fun-fact-section {
  padding: 50px 32px 25px;
  background-color: #000000;
}


/* ── Accordion ────────────────────────────────────────────── */

#accordionContainer {
  --bs-accordion-bg: black;
  padding-top: 50px;
  color: white;
}

.accordion {
  --bs-accordion-btn-icon: url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cmask id='m' style='mask-type:alpha' maskUnits='userSpaceOnUse' x='0' y='0' width='18' height='18'%3E%3Crect width='18' height='18' transform='matrix(0 -1 -1 0 18 18)' fill='%23D9D9D9'/%3E%3C/mask%3E%3Cg mask='url(%23m)'%3E%3Cpath d='M1.75961 5.99992L8.99992 13.2402L16.2402 5.99992L15.1758 4.93548L8.99992 11.1115L2.82405 4.93548L1.75961 5.99992Z' fill='white'/%3E%3C/g%3E%3C/svg%3E);
}

.accordion-flush > .accordion-item:first-child {
  border-top: 1px solid #dee2e6;
}

.accordion-button {
  font-family: "Montserrat", sans-serif;
  color: #EEECE7;
  font-weight: 700;
  padding: 32px 0 0;
  font-size: 18px;
  text-transform: uppercase;
line-height: 25px;
}

button.accordion-button.collapsed {
  padding-bottom: 32px;
}

button.accordion-button {
  padding-bottom: 24px;
}

.accordion-button:not(.collapsed) {
  background: black;
  color: #EEECE7;
  box-shadow: none;
}

.accordion-button:focus {
  outline: 1px solid #FFC60B;
  outline-offset: 2px;
  border-radius: 8px;
  box-shadow: none;
}

#accordionContainer .accordion-button::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cmask id='m' style='mask-type:alpha' maskUnits='userSpaceOnUse' x='0' y='0' width='18' height='18'%3E%3Crect width='18' height='18' transform='matrix(0 -1 -1 0 18 18)' fill='%23D9D9D9'/%3E%3C/mask%3E%3Cg mask='url(%23m)'%3E%3Cpath d='M1.75961 5.99992L8.99992 13.2402L16.2402 5.99992L15.1758 4.93548L8.99992 11.1115L2.82405 4.93548L1.75961 5.99992Z' fill='white'/%3E%3C/g%3E%3C/svg%3E") !important;
}

.accordion-body {
  color: #EEECE7;
  font-family: "Montserrat", sans-serif;
  padding: 0 0 32px;
  font-weight: 400;
  font-size: 14px;
  line-height: 120%;
}


/* ── Back to Top Button ───────────────────────────────────── */

#back-to-top-btn {
  position: fixed;
  display: flex;
  font-family: "Dirk-Black", sans-serif;
  gap: 10px;
  text-transform: uppercase;
  line-height: 100%;
  color: #fff;
  text-align: left;
  bottom: 20px;
  right: 0;
  z-index: 100;
  background-color: #ed1c24;
  cursor: pointer;
  font-size: 20px;
  border-radius: 6px 0px 0px 6px;
  border-top: 2px solid #eeece7;
  border-bottom: 2px solid #eeece7;
  border-left: 2px solid #eeece7;
  padding: 16px;
  justify-content: center;
  align-items: center;
  transition: all .2s;
  min-width: 66px;
}

#back-to-top-btn p {
  display: none;
}

#back-to-top-btn:hover {
  border-color: #ed1c24;
  color: #ed1c24;
  background-color: #fff;
}


/* ════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ════════════════════════════════════════════════════════════ */

/* ── ≥2000px: Ultra-wide edge gradients ──────────────────── */

@media screen and (min-width: 2000px) {
  #hero #hero-wrapper::before {
    top: 0;
    left: 0;
    z-index: 1;
    opacity: 1;
    width: 100px;
    height: auto;
    background-image: linear-gradient(to right, black, transparent);
  }

  #hero #hero-wrapper::after {
    top: 0;
    right: 0;
    z-index: 1;
    opacity: 1;
    width: 100px;
    background-image: linear-gradient(to left, black, transparent);
  }
}


/* ── ≤480px: Mobile ───────────────────────────────────────── */

@media only screen and (max-width: 756px) {
div#state-welcome {
    padding: 120px 30px 30px;
}
h4.card-subtext {
    font-size: 22px;
}
.hero-badge {
    width: 180px;
    
    top: -12%;
}
 



  .welcome_content {
    font-size: 22px !important;
  }

  .herocopy {
    font-family: "Montserrat", sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 120%;
    color: #ffffff;
    padding-bottom: 0px;
  }

  .headline {
    font-size: 32px;
    padding-bottom: 0px;
  }

  .h2-accent {
    font-family: 'Alfa Slab One', sans-serif;
    font-size: 30px;
  }

  .legal {
    padding-bottom: 100px;
  }

  .expired {
    display: flex;
  }

  .thankYouContent {
            padding: 85px 32px;
  }

  #hero #hero-content {
    max-width: 100%;
    padding: 0 32px;
  }

  #hero #hero-wrapper {
    padding-bottom: 40%;
    padding-top: calc(var(--nav-h) + 40px);
  }

  #accordionContainer {
    --bs-accordion-bg: black;
    padding-top: 30px;
    color: white;
  }
  #secondary{
    padding: 85px 32px;
  }
#recipe-section .inner-box p{
    padding-right: 0;
font-size: 18px;
}
  .h4-accent {
font-size: 30px;
}
#hero #hero-img {
    object-position: bottom;
}
}

@media only screen and (min-width: 481px) and (max-width: 756px) {

div#state-welcome {
    padding: 120px 30px 30px;
}
h4.card-subtext {
    font-size: 22px;
}

}

/* ── 481px–1024px: Tablet ─────────────────────────────────── */

@media only screen and (min-width: 757px) and (max-width: 1024px) {
 
#recipe-section .inner-box p {
        padding-right: 0;
    }
  .thankYouContent {
            padding: 85px 32px;
  }



  .herocopy {
    font-family: "Montserrat", sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 120%;
    text-align: left !important;
    color: #ffffff;
    padding-bottom: 0px;
  }

  .headline {
    text-align: left !important;
    font-size: 32px;
    padding-bottom: 0px;
  }

  .h2-accent {
    font-family: 'Alfa Slab One', sans-serif;
    font-size: 30px;
  }

  .legal {
    padding-bottom: 100px;
  }

  #hero #hero-wrapper {
    padding: 28% 0px 50px;
  }

  #hero #hero-content {
    max-width: 100%;
    padding: 0 32px;
  }
  .h4-accent {
font-size: 30px;
}
#secondary {
    padding: 84px 48px;
}
#hero #hero-img {
    object-position: bottom;
}
  #hero #hero-wrapper {
    padding-bottom: 30%;
  }
}


/* ── ≥1025px: Desktop ─────────────────────────────────────── */

@media only screen and (min-width: 1025px) {
  .legal {
    padding-bottom: 50px;
    padding-top: 50px;
  }


  
  .welcome_content {
    margin-bottom: 0px;
    text-align: left;
    color: white;
    font-size: 24px;
    font-family: "Montserrat", sans-serif;
    font-weight: 500;
    line-height: 120%;
    padding-right: 45px;
  }

  .herocopy {
    font-family: "Montserrat", sans-serif;
    font-size: 28px;
    font-style: normal;
    font-weight: 500;
    line-height: 120%;
    color: #ffffff;
    padding-bottom: 0px;
  }

  #fun-fact-section {
    padding: 85px 48px 42px;
  }



  .welcome .headline {
    padding-top: 66px !important;
  }

  
#hero #hero-wrapper {

    padding: 14% 0 20% 0%;

}
}


/* ── ≥360px ───────────────────────────────────────────────── */

@media screen and (min-width: 360px) {
  #recipe-section ol.number-list li::before {
    top: 20px;
  }
}


/* ── ≥768px: Tablet/Desktop ───────────────────────────────── */

@media screen and (min-width: 768px) {
  input[type="email"] {
    width: 590px;
    float: left;
    font-size: 18px;
  }

  footer {
    padding: 0px;
  }

  footer #footer-heading {
    margin-bottom: 40px;
  }

  #recipe-section ol.number-list li {
    margin-bottom: 40px;
    padding-left: 86px;
  }

  #recipe-section ol.number-list li::before {
    border-width: 3px;
    width: 54px;
    height: 54px;
    top: 30px;
  }

  #fun-fact-section {
    /* padding: 32px 0px 0; */
  }

  /* Nav */
  nav {
    padding: 27px 48px;
  }

  nav #mobile-nav-toggle-button {
    display: none;
  }

  nav #mobile-nav-list {
    display: none;
  }

  nav #nav-list {
    background: rgba(0, 0, 0, 0);
    display: flex;
    justify-content: space-between;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
  }

  nav #nav-list .left-nav-container {
    display: flex;
    align-items: center;
    gap: 24px;
  }

  nav #nav-list .left-nav-container #nav-logo {
    width: 85px;
    margin-right: 24px;
  }

  nav #nav-list .left-nav-container #nav-logo img {
    object-fit: contain;
  }

  nav #nav-list .left-nav-container .nav-item {
    color: #fff;
    padding:5px;
  }

  nav #nav-list .left-nav-container .nav-item:hover {
    color: #FFC60B;
  }

  nav #nav-list .order-btn {
    border: 2px solid #fff;
    transition: all .3s;
  }

  nav #nav-list .order-btn:focus-visible,
  nav #nav-list .order-btn:focus,
  nav #nav-list .order-btn:hover {
    color: #FFC60B;
    outline: none;
    border-radius: 8px;
    padding: 10px 50px;
    border-color: #FFC60B;
  }

  nav #mobile-nav-toggle-button #menu-icon {
    stroke: #ffffff;
  }

  /* Typography scale-ups */
  .btn {
    font-size: 20px;
    letter-spacing: .4px;
    padding: 10px 50px;
  }

  .right-symbol   { top: -1.2em; }
  .dollar-sup     { font-size: 18px; top: -0.5em; }
  .sup-alfa       { font-size: 20px; top: -0.6em; }
  .trade-symbol   { font-size: 16px; top: -2.2em; }

  .h1-accent      { font-size: 70px; }
  h1              { font-size: 50px; }
  h2              { font-size: 40px; }
  .h2-accent      { font-size: 40px; }
  .h3-accent      { font-size: 50px; }
  .h4-accent      { font-size: 40px; }

  .body-large     { font-size: 30px; line-height: 120%; }
  .body-medium    { font-size: 24px; line-height: 120%; }
  .body-small     { font-size: 18px; }

  .legal          { font-size: 14px; line-height: 120%; }

  .data-title     { font-size: 90px; font-style: normal; line-height: 95%; }
  .data-large     { font-size: 31px; }
  .data-small     { font-size: 16px; }
  .data-price     { font-size: 65px; }
  .data-price-legal { font-size: 24px; }

  .double-border  { padding: 15px; }

  #back-to-top-btn {
    bottom: 60px;
    padding: 22px 14px;
  }

  #back-to-top-btn p {
    display: inline;
  }
  
}


/* ── ≥992px ───────────────────────────────────────────────── */

@media screen and (min-width: 992px) {
  #recipe-section .inner-box h2:first-of-type { margin-bottom: 28px; }
  #recipe-section .inner-box h2:last-of-type  { margin-bottom: 24px; }

  .horizontal-thick-border {
    margin: 0 48px 10px;
  }

  #recipe-section .recipe-group {
    margin-left: -2%;
  }

  #recipe-section .recipe-group .polaroid {
    max-width: 360px;
    transition: max-width .3s;
  }

  #recipe-section .recipe-content {
    margin-top: 0px;
  }
}


/* ── ≥1200px ──────────────────────────────────────────────── */

@media screen and (min-width: 1200px) {
  #recipe-section .recipe-group {
    margin-left: 0%;
  }

  #recipe-section .recipe-group .polaroid {
    max-width: 420px;
  }

  .sup-alfa {
    top: -1.2em;
  }
}


/* ── ≥1488px ──────────────────────────────────────────────── */

@media screen and (min-width: 1488px) {
  .horizontal-thick-border {
    margin: 0 0 10px;
  }

  #fun-fact-section {
    padding: 85px 42px 42px;
  }

  #recipe-section .recipe-group .polaroid {
    max-width: 470px;
  }
}
