/* ============================================================
   TYCO v02 — extra sections: The Spot carousel, Find Us map, Feed grid
   ============================================================ */

/* ============================================================
   BRAND PALETTE — white base · navy sections · yellow accents
   ============================================================ */
:root { --tyco-white: #FCFCFA; --tyco-navy: #15243C; --tyco-navy-2: #1d3354; --tyco-yellow: #D4B838; --tyco-yellow-hi: #E4C84A; }

.u-bg-bone-white   { background-color: var(--tyco-white) !important; --bg-color: #FCFCFA; }
.u-fg-bone-white   { color: var(--tyco-white) !important; --fg-color: #FCFCFA; }
.u-bg-sunset-orange{ background-color: var(--tyco-navy) !important; --bg-color: #15243C; --link-color: #F2B924; }
.u-fg-sunset-orange{ color: var(--tyco-navy) !important; --fg-color: #15243C; }
.u-bg-dusk-blue    { background-color: var(--tyco-navy) !important; --bg-color: #15243C; --link-color: #F2B924; }
.u-fg-dusk-blue    { color: var(--tyco-navy) !important; --fg-color: #15243C; }
.u-bg-brick-red    { background-color: var(--tyco-navy) !important; --bg-color: #15243C; --link-color: #F2B924; }
.u-fg-brick-red    { color: var(--tyco-navy) !important; --fg-color: #15243C; }

/* Buttons -> yellow with navy label */
.c-cta, .c-cta--outlined-button, .c-cta--solid-button {
  background-color: var(--tyco-yellow) !important; color: var(--tyco-navy) !important;
  border: 1px solid var(--tyco-yellow) !important;
}
.c-cta:hover { background-color: var(--tyco-yellow-hi) !important; border-color: var(--tyco-yellow-hi) !important; }
.c-cta__label { color: var(--tyco-navy) !important; }

/* ---- Fonts: Chivo (display) + Krub (body) ---- */
body, input, textarea, button, .c-rich-text, .c-rich-text p, .c-cta__label, [class*="t-body"] { font-family: 'Krub', system-ui, sans-serif !important; }
h1, h2, h3, h4, h5, [class^="t-heading"], [class*=" t-heading"], .c-feature-tile__title, .brandline, .tyco-sig__name, .tyco-step__title, .franchise-benefit h4, .tyco-form h3 { font-family: 'Chivo', system-ui, sans-serif !important; font-weight: 300 !important; }

/* ---- Scroll reveal (pop in) ---- */
.tyco-pop { opacity: 0; transform: translateY(28px); transition: opacity 0.7s cubic-bezier(0.2,0.7,0.2,1), transform 0.7s cubic-bezier(0.2,0.7,0.2,1); }
.tyco-pop.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .tyco-pop { opacity: 1; transform: none; transition: none; } }

/* ---- The Spot: photo carousel with arrows ---- */
.tyco-carousel { position: relative; margin-top: 2.5rem; }
.tyco-carousel__track {
  display: flex; gap: 1rem; overflow-x: auto;
  scroll-snap-type: x mandatory; scroll-behavior: smooth;
  padding: 0 clamp(1rem, 6vw, 5rem);
  scrollbar-width: none; -ms-overflow-style: none;
}
.tyco-carousel__track::-webkit-scrollbar { display: none; }
.tyco-carousel__track figure {
  flex: 0 0 auto; width: min(82vw, 620px); margin: 0; scroll-snap-align: center;
}
.tyco-carousel__track img {
  width: 100%; height: clamp(20rem, 46vw, 34rem); object-fit: cover; display: block;
}
.tyco-carousel__arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 3.25rem; height: 3.25rem; border-radius: 50%; border: none; cursor: pointer;
  background: var(--tyco-yellow); color: var(--tyco-navy);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.25s ease, transform 0.25s ease;
}
.tyco-carousel__arrow:hover { background: var(--tyco-yellow-hi); }
.tyco-carousel__arrow:active { transform: translateY(-50%) scale(0.94); }
.tyco-carousel__arrow svg { width: 1.1rem; height: 1.1rem; }
.tyco-carousel__arrow--prev { left: clamp(0.6rem, 2.5vw, 2rem); }
.tyco-carousel__arrow--next { right: clamp(0.6rem, 2.5vw, 2rem); }

/* ---- Franchising page ---- */
.franchise-hero { padding-top: clamp(9rem, 16vw, 13rem) !important; }
.franchise-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.franchise-benefits { list-style: none; margin: 1.6rem 0 0; padding: 0; display: grid; gap: 1.4rem; }
.franchise-benefit { border-top: 1px solid currentColor; padding-top: 1.1rem; }
.franchise-benefit h4 { font-family: 'Chivo', system-ui, sans-serif; font-weight: 400; font-size: 1.3rem; margin-bottom: 0.4rem; }
.franchise-benefit p { font-family: 'Krub', sans-serif; font-size: 0.9rem; line-height: 1.55; opacity: 0.85; }
.tyco-form { background: var(--tyco-navy); color: #FCFCFA; padding: clamp(1.6rem, 3vw, 2.4rem); }
.tyco-form h3 { font-family: 'Chivo', system-ui, sans-serif; font-weight: 400; color: #FCFCFA; font-size: 1.6rem; margin-bottom: 1.4rem; }
.tyco-field { margin-bottom: 1.1rem; }
.tyco-field label { display: block; font-family: 'Krub', sans-serif; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.4rem; opacity: 0.8; }
.tyco-field input, .tyco-field textarea { width: 100%; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.18); color: #FCFCFA; font-family: 'Krub', sans-serif; font-size: 0.95rem; padding: 0.8rem 0.9rem; border-radius: 2px; outline: none; transition: border-color 0.3s ease; }
.tyco-field input:focus, .tyco-field textarea:focus { border-color: var(--tyco-yellow); }
.tyco-field textarea { min-height: 6rem; resize: vertical; }
.tyco-form__btn { width: 100%; background: var(--tyco-yellow); color: var(--tyco-navy); border: none; cursor: pointer; font-family: 'Krub', sans-serif; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.8rem; padding: 1rem; border-radius: 2px; transition: background 0.3s ease; }
.tyco-form__btn:hover { background: var(--tyco-yellow-hi); }
.tyco-form__note { font-size: 0.7rem; opacity: 0.6; margin-top: 0.8rem; }
.tyco-form__thanks { display: none; }
.tyco-form.is-sent form { display: none; }
.tyco-form.is-sent .tyco-form__thanks { display: block; font-family: 'Chivo', system-ui, sans-serif; font-size: 1.4rem; line-height: 1.3; }
@media (max-width: 760px) { .franchise-grid { grid-template-columns: 1fr; } }

/* ---- About eyebrow (Est. 2018) ---- */
.tyco-eyebrow { font-family: 'Krub', sans-serif; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.24em; text-transform: uppercase; color: var(--tyco-yellow); margin-bottom: 0.9rem; }

/* ---- Language toggle ---- */
.lang-toggle { background: none; border: none; cursor: pointer; font-family: 'Krub', sans-serif; font-size: 0.74rem; font-weight: 600; letter-spacing: 0.06em; color: inherit; display: inline-flex; align-items: center; gap: 0.3rem; padding: 0; }
.lang-toggle [data-lang] { opacity: 0.45; transition: opacity 0.3s ease; }
.lang-toggle [data-lang].is-active { opacity: 1; }
.lang-toggle .lang-sep { opacity: 0.35; }
.lang-toggle--ov { color: var(--nav-cream); font-size: 1.05rem; margin-top: 1.2rem; }

/* ---- Signature carousel: fixed background, sliding cutout cups ---- */
.tyco-sig { position: relative; max-width: 680px; margin: 0 auto; }
.tyco-sig-section { background: url('../assets/photos/signatures/sig-bg.jpg') center / cover no-repeat; }
.tyco-sig__stage { position: relative; aspect-ratio: 16 / 9; overflow: hidden; }
.tyco-sig__cup { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; will-change: transform; filter: drop-shadow(0 14px 12px rgba(40, 20, 30, 0.18)); }
.tyco-sig__cup.is-anim { transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1); }
.tyco-sig__arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 4; width: 3rem; height: 3rem; border-radius: 50%; border: none; cursor: pointer; background: var(--tyco-yellow); color: var(--tyco-navy); display: flex; align-items: center; justify-content: center; transition: background 0.25s ease, transform 0.25s ease; }
.tyco-sig__arrow:hover { background: var(--tyco-yellow-hi); }
.tyco-sig__arrow:active { transform: translateY(-50%) scale(0.92); }
.tyco-sig__arrow svg { width: 1.05rem; height: 1.05rem; }
.tyco-sig__arrow--prev { left: 0.6rem; }
.tyco-sig__arrow--next { right: 0.6rem; }
.tyco-sig__info { margin-top: 1.6rem; }
.tyco-sig__name { font-family: 'Chivo', system-ui, sans-serif; font-weight: 300; font-size: clamp(1.8rem, 3vw, 2.4rem); line-height: 1.05; }
.tyco-sig__desc { font-family: 'Krub', sans-serif; font-size: 0.95rem; line-height: 1.6; margin: 0.7rem auto 0; opacity: 0.85; max-width: 42ch; min-height: 3rem; }
.tyco-sig__dots { display: flex; justify-content: center; gap: 0.5rem; margin-top: 1.4rem; }
.tyco-sig__dot { width: 0.5rem; height: 0.5rem; border-radius: 50%; border: none; cursor: pointer; padding: 0; background: currentColor; opacity: 0.25; transition: opacity 0.25s ease, transform 0.25s ease; }
.tyco-sig__dot.is-active { opacity: 1; transform: scale(1.3); background: var(--tyco-yellow); }
@media (max-width: 600px) { .tyco-sig__arrow { width: 2.6rem; height: 2.6rem; } }

/* ---- Find Us: embedded map ---- */
.tyco-map { width: 100%; height: 100%; min-height: 24rem; }
.tyco-map iframe {
  width: 100%; height: 100%; min-height: 24rem; border: 0; display: block;
  filter: grayscale(0.3) sepia(0.1) contrast(1.02);
}
.tyco-find-list { list-style: none; margin: 1.5rem 0 0; padding: 0; }
.tyco-find-list li { margin-bottom: 0.4rem; }

/* ---- Mobile spacing + touch optimization ---- */
@media (max-width: 600px) {
  /* Tighten the oversized desktop section padding on phones */
  .u-pt-10 { padding-top: 3.25rem !important; }
  .u-pb-10 { padding-bottom: 3.25rem !important; }
  .tyco-cards-head { margin-bottom: 1.5rem; gap: 1rem; }
  .tyco-cards-head .c-cta { width: 100%; justify-content: center; }
  /* Carousel: comfortable image height + slightly smaller arrows */
  .tyco-carousel__track figure { width: 86vw; }
  .tyco-carousel__track img { height: 24rem; }
  .tyco-carousel__arrow { width: 2.6rem; height: 2.6rem; }
  .tyco-carousel__arrow--prev { left: 0.5rem; }
  .tyco-carousel__arrow--next { right: 0.5rem; }
  /* Bigger tap targets for footer links */
  .footer ul a { display: inline-block; padding: 0.15rem 0; }
}

/* ---- The TYCO Way (3 steps) ---- */
.tyco-steps {
  list-style: none; margin: clamp(2rem, 4vw, 3rem) auto 0; padding: 0;
  max-width: 1080px; display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 3rem); text-align: left;
}
.tyco-step { border-top: 1px solid currentColor; padding-top: 1.2rem; }
.tyco-step__num { font-family: 'Krub', sans-serif; font-size: 0.8rem; font-weight: 600; letter-spacing: 0.1em; opacity: 0.7; }
.tyco-step__title { font-family: 'Chivo', system-ui, sans-serif; font-weight: 400; font-size: clamp(1.4rem, 2vw, 1.7rem); line-height: 1.05; margin: 0.6rem 0; }
.tyco-step__text { font-family: 'Krub', sans-serif; font-size: 0.9rem; line-height: 1.6; opacity: 0.85; }
@media (max-width: 760px) { .tyco-steps { grid-template-columns: 1fr; gap: 1.5rem; } }

/* ---- Footer (matches the menu page) ---- */
.footer { background: var(--tyco-navy); color: #FCFCFA; padding-block: clamp(3.5rem, 7vw, 6rem) 2.5rem; }
.footer .wrap { max-width: 1280px; margin-inline: auto; padding-inline: clamp(1.25rem, 5vw, 6rem); }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(246,240,225,0.18); }
.footer .logo-img { width: 3.4rem; height: 3.4rem; border-radius: 999px; margin-bottom: 1.4rem; }
.footer .brandline { font-family: 'Chivo', system-ui, sans-serif; font-weight: 400; font-size: clamp(1.6rem, 2.4vw, 2.2rem); line-height: 1.15; max-width: 16ch; }
.footer .brandline em { font-style: italic; color: #E7D9C0; }
.footer h4 { font-family: 'Krub', sans-serif; font-size: 0.68rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: #C6A079; margin-bottom: 1.3rem; }
.footer ul { list-style: none; display: grid; gap: 0.8rem; margin: 0; padding: 0; }
.footer ul a, .footer ul li { font-family: 'Krub', sans-serif; font-size: 0.92rem; color: rgba(246,240,225,0.8); transition: color 0.4s ease; }
.footer ul a:hover { color: #F6F0E1; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 1.5rem; flex-wrap: wrap; padding-top: 2rem; }
.footer-bottom span { font-family: 'Krub', sans-serif; font-size: 0.74rem; letter-spacing: 0.04em; color: #C6A079; }
@media (max-width: 760px) { .footer-top { grid-template-columns: 1fr; gap: 2.2rem; } }

/* ---- Signature cocktail cards ---- */
.tyco-cards-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 1.5rem; flex-wrap: wrap; margin-bottom: clamp(2rem, 4vw, 3rem);
}
.tyco-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2vw, 1.6rem); }
.tyco-card { position: relative; }
.tyco-card__media { aspect-ratio: 3 / 4; overflow: hidden; background: #e7d9c0; }
.tyco-card__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 1s cubic-bezier(0.32,0.72,0,1);
}
.tyco-card:hover .tyco-card__media img { transform: scale(1.05); }
.tyco-card__body { padding-top: 1rem; margin-top: 0.9rem; border-top: 1px solid currentColor; }
.tyco-card__row { display: flex; justify-content: space-between; align-items: baseline; gap: 0.6rem; }
.tyco-card__name { font-family: 'Chivo', system-ui, sans-serif; font-size: 1.35rem; line-height: 1.05; letter-spacing: -0.01em; }
.tyco-card__price { font-family: 'Krub', sans-serif; font-weight: 600; font-size: 0.9rem; white-space: nowrap; }
.tyco-card__note { font-family: 'Krub', sans-serif; font-size: 0.78rem; line-height: 1.5; margin-top: 0.45rem; opacity: 0.82; }
@media (max-width: 900px) { .tyco-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .tyco-cards { grid-template-columns: 1fr; } }

/* ---- See you on the feed ---- */
.tyco-feed {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.6rem;
  margin: 2.5rem 0; max-width: 1080px; margin-inline: auto;
}
.tyco-feed a { display: block; overflow: hidden; }
.tyco-feed img {
  width: 100%; aspect-ratio: 1; object-fit: cover; display: block;
  transition: transform 0.6s cubic-bezier(0.32,0.72,0,1);
}
.tyco-feed a:hover img { transform: scale(1.06); }
@media (max-width: 760px) {
  .tyco-feed { grid-template-columns: repeat(3, 1fr); }
  .tyco-feed a:nth-child(4), .tyco-feed a:nth-child(5) { display: none; }
}
