@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@700;800&family=Source+Sans+3:wght@400;600;700&display=swap");

:root {
  --green: #4EA414;
  --green-dark: #2E7D00;
  --red: #D42B00;
  --red-dark: #B02200;
  --blue: #4A9FD9;
  --ink: #383632;
  --muted: #655f57;
  --paper: #fbf6eb;
  --paper-deep: #f2ead9;
  --paper-line: #e2d7c2;
  --card: rgba(255, 251, 242, 0.92);
  --white: #ffffff;
  --shadow-lg: 0 24px 70px rgba(77, 63, 31, 0.12);
  --shadow-md: 0 16px 34px rgba(77, 63, 31, 0.08);
  --radius-xl: 30px;
  --radius-lg: 22px;
  --radius-md: 16px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Source Sans 3', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top right, rgba(74,159,217,0.10), transparent 22%),
    radial-gradient(circle at top left, rgba(78,164,20,0.10), transparent 24%),
    linear-gradient(180deg, #fffdf8 0%, var(--paper) 46%, #f7f1e4 100%);
  overflow-x: clip;
}
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.2;
  background-image:
    linear-gradient(rgba(98, 88, 73, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(98, 88, 73, 0.06) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.55), transparent 88%);
}
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 20% 18%, rgba(78,164,20,0.10), transparent 14%),
    radial-gradient(circle at 80% 24%, rgba(212,43,0,0.08), transparent 14%),
    radial-gradient(circle at 72% 72%, rgba(74,159,217,0.10), transparent 16%);
}
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
p { margin: 0; color: var(--muted); line-height: 1.68; }
h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  color: var(--ink);
}
code {
  display: inline-block;
  margin-top: 1rem;
  padding: 0.8rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--paper-line);
  background: rgba(255,255,255,0.8);
  color: var(--ink);
  overflow-wrap: anywhere;
}

.site-wrap { position: relative; }
.container {
  width: min(1180px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 0 1rem;
}
.hero-section,
.page-section,
.footer-zone { position: relative; }
.hero-section {
  padding: 4.5rem 0 4.5rem;
}
.page-section {
  padding: clamp(1.5rem, 3.5vw, 3rem) 0;
}
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 0.73rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green-dark);
}
.eyebrow::before {
  content: '';
  width: 14px;
  height: 14px;
  border-radius: 4px;
  background: linear-gradient(135deg, var(--green), var(--blue));
  transform: rotate(12deg);
  box-shadow: 0 0 0 6px rgba(78,164,20,0.10);
}
.display-title,
.page-title {
  font-size: clamp(2.7rem, 5.9vw, 5.4rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
  text-transform: uppercase;
}
.section-title {
  font-size: clamp(2rem, 4vw, 3.35rem);
  line-height: 1;
  letter-spacing: -0.04em;
  text-transform: uppercase;
}
.lede { font-size: clamp(1.05rem, 1.8vw, 1.28rem); max-width: 42rem; }
.accent-green { color: var(--green-dark); }
.accent-red { color: var(--red); }

.top-strip {
  position: relative;
  z-index: 35;
  background: linear-gradient(90deg, var(--green-dark), var(--green));
  color: var(--white);
}

.top-strip .container {
  max-width:1536px !important;
}

@media (max-width: 720px) {
  .top-strip { display: none; }
}

.shell-row {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  font-size: 0.94rem;
}
.top-note,
.top-links {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: nowrap;
}
.top-links a { font-weight: 700; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
}
.nav-shell {
  width: min(1180px, calc(100% - 2rem));
  margin: 0.75rem auto 0;
  border: 2px solid rgba(56,54,50,0.10);
  border-radius: 999px;
  background: rgba(255,251,242,0.86);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(18px);
  transition: margin-top 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}
.nav-shell .container {
  width: 100%;
}
.site-header.is-scrolled .nav-shell {
  margin-top: 0.35rem;
  background: rgba(255,251,242,0.94);
  box-shadow: var(--shadow-lg);
}

@media (min-width: 1025px) {
  .container { padding: 0; }
}

@media (max-width: 1024px) {
  .nav-shell { border-radius: 43px; }
}

.nav-row {
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 1rem 0 1.25rem;
  transition: min-height 300ms ease;
}
.brand-lockup img {
  height: 50px;
  width: auto;
  transition: height 300ms ease;
}
.nav-desktop {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.nav-link,
.nav-phone {
  padding: 0.85rem 0.95rem;
  border-radius: 999px;
  font-size: 1rem;
  font-weight: 700;
  transition: color 180ms ease, background-color 180ms ease, font-size 300ms ease;
}

@media (min-width: 1025px) {
  .nav-row { min-height: 103px; }
  .brand-lockup img { height: 63px; }
  .nav-link, .nav-phone { font-size: 1.25rem; }
  .site-header.is-scrolled .nav-row { min-height: 82px; }
  .site-header.is-scrolled .brand-lockup img { height: 50px; }
  .site-header.is-scrolled .nav-link,
  .site-header.is-scrolled .nav-phone { font-size: 1rem; }
}
.nav-link:hover,
.nav-link.is-active {
  background: rgba(78,164,20,0.10);
  color: var(--green-dark);
}
.nav-phone { color: var(--red); }
.nav-toggle {
  display: none;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 0;
  background: transparent;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  margin: 4px auto;
  background: var(--ink);
  transition: transform 180ms ease, opacity 180ms ease;
}
.nav-toggle.is-open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.mobile-menu { display: none; padding: 0 1rem 1rem; }
.mobile-menu.is-open { display: block; }
.mobile-panel {
  display: grid;
  gap: 0.7rem;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(56,54,50,0.10);
}
.mobile-panel a:not(.btn) {
  padding: 0.86rem 0.25rem;
  font-weight: 700;
}
.mobile-panel .btn { width: 100%; }

.btn-row { display: flex; flex-wrap: wrap; gap: 0.85rem; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0.95rem 1.35rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, border-color 180ms ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  background: var(--red);
  color: var(--white);
  box-shadow: 0 16px 32px rgba(212,43,0,0.18);
}
.btn-primary:hover { background: var(--red-dark); }
.btn-secondary {
  background: rgba(78,164,20,0.10);
  color: var(--green-dark);
  border-color: rgba(78,164,20,0.24);
}
.btn-secondary:hover {
  background: rgba(78,164,20,0.16);
  border-color: rgba(78,164,20,0.34);
}
.btn-ghost {
  background: rgba(255,255,255,0.64);
  color: var(--ink);
  border-color: rgba(56,54,50,0.10);
}
.btn-compact { min-height: 46px; padding-inline: 1.1rem; }

.hero-grid,
.page-grid,
.story-grid,
.contact-grid,
.quote-grid,
.side-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, 0.96fr);
  gap: 1.2rem;
}
.hero-card,
.page-card,
.service-card,
.note-card,
.route-card,
.story-card,
.contact-card,
.sidebar-card,
.jobber-card,
.price-card,
.review-card,
.footer-card,
.footer-banner,
.ticket-card,
.audience-card,
.fact-card {
  position: relative;
  background: var(--card);
  border: 1px solid rgba(98,88,73,0.14);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
}
.hero-card,
.page-card,
.story-card,
.contact-card,
.sidebar-card,
.jobber-card,
.price-card,
.review-card,
.ticket-card,
.audience-card,
.fact-card,
.service-card,
.note-card,
.route-card { padding: clamp(1.4rem, 3vw, 2rem); }
.hero-card::before,
.page-card::before,
.story-card::before,
.contact-card::before,
.sidebar-card::before,
.jobber-card::before,
.price-card::before,
.review-card::before,
.ticket-card::before,
.audience-card::before,
.fact-card::before,
.service-card::before,
.note-card::before,
.route-card::before,
.footer-card::before,
.footer-banner::before {
  content: none;
}
.hero-card::after,
.page-card::after,
.story-card::after,
.contact-card::after,
.sidebar-card::after,
.jobber-card::after,
.ticket-card::after,
.audience-card::after,
.fact-card::after {
  content: none;
}
.hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}
.hero-badges { display: flex; flex-wrap: wrap; gap: 0.7rem; margin: 1.2rem 0 1.5rem; }
.mini-pill,
.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.58rem 0.8rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.74);
  border: 1px solid rgba(98,88,73,0.12);
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--ink);
}
.hero-stats,
.fact-grid,
.ticket-grid,
.price-grid,
.review-grid,
.instagram-grid,
.service-grid,
.note-grid {
  display: grid;
  gap: 1rem;
}
.hero-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 1.5rem; }
.fact-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.ticket-grid,
.review-grid,
.instagram-grid,
.service-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.service-grid-two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.price-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.price-grid--three-col { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.note-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.stat-value,
.price-value {
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: clamp(2rem, 3vw, 2.7rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
  color: var(--ink);
}
.stat-label,
.kicker {
  margin-top: 0.4rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.74rem;
  color: var(--green-dark);
}
.fpo-scene,
.story-visual,
.jobber-placeholder {
  position: relative;
  overflow: hidden;
  min-height: 320px;
  display: grid;
  place-items: center;
  text-align: center;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(98,88,73,0.20);
  background:
    linear-gradient(135deg, rgba(78,164,20,0.10), transparent 35%),
    linear-gradient(315deg, rgba(74,159,217,0.10), transparent 30%),
    rgba(255,255,255,0.55);
}
.hero-card > .fpo-scene {
  min-height: 0;
  height: 100%;
}

.jobber-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(135deg, transparent 0 18px, rgba(98,88,73,0.03) 18px 36px);
  pointer-events: none;
}
.fpo-stack,
.jobber-placeholder > div,
.story-visual > div { position: relative; z-index: 1; }
.fpo-mark {
  display: inline-grid;
  place-items: center;
  width: 78px;
  height: 78px;
  margin: 0 auto 1rem;
  border-radius: 24px;
  background: rgba(78,164,20,0.12);
  border: 1px solid rgba(78,164,20,0.18);
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--green-dark);
}
.fpo-title {
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.fpo-note { margin-top: 0.6rem; max-width: 24rem; }
.route-board { display: grid; gap: 0.8rem; }
.route-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.68);
  border: 1px solid rgba(98,88,73,0.12);
}
.route-state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.route-state.green { background: rgba(78,164,20,0.12); color: var(--green-dark); }
.route-state.blue { background: rgba(74,159,217,0.12); color: #2b6e9c; }
.route-state.red { background: rgba(212,43,0,0.10); color: var(--red); }
.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.4rem;
}
.section-head .lede { max-width: 34rem; }
.card-head,
.contact-row,
.label-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.8rem;
}
.contact-row {
  justify-content: flex-start;
}
.contact-row > div:last-child {
  flex: 1;
  text-align: left;
}
.service-icon,
.note-icon,
.contact-icon,
.ticket-no {
  display: inline-grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: rgba(78,164,20,0.12);
  border: 1px solid rgba(78,164,20,0.18);
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--green-dark);
}
.list-checks,
.footer-list,
.bullet-list {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.7rem;
}
.list-checks li,
.bullet-list li {
  position: relative;
  padding-left: 1.3rem;
}
.list-checks li::before,
.bullet-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--green);
}
.audience-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.88), rgba(247,240,226,0.94));
}
.audience-switch {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1.2rem;
}
.switch-btn {
  appearance: none;
  border: 1px solid rgba(98,88,73,0.12);
  background: rgba(255,255,255,0.74);
  color: var(--ink);
  border-radius: 999px;
  padding: 0.75rem 1rem;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}
.switch-btn.is-active,
.switch-btn:hover {
  background: rgba(78,164,20,0.12);
  border-color: rgba(78,164,20,0.24);
  color: var(--green-dark);
}
.review-stars {
  font-size: 0.88rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--red);
}
.footer-zone {
  padding: clamp(1.5rem, 3.5vw, 3rem) 0 7rem;
}
.footer-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: clamp(3rem, 7vw, 6rem);
  background: linear-gradient(135deg, rgba(255,255,255,0.92), rgba(240,247,236,0.92));
  padding: clamp(1.5rem, 3vw, 2rem);
}
.footer-banner > :first-child {
  flex: 1;
}
.footer-title { max-width: 14ch; margin-top: 0.8rem; }
.footer-copy { margin-top: 0.8rem; }
.footer-cta-stack {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 0.85rem;
  min-width: min(100%, 260px);
  margin-inline: auto;
}
.footer-cta-stack .btn {
  width: 100%;
}
.footer-cta-divider {
  align-self: center;
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-green-dark);
}
.footer-card {
  padding: 1.7rem;
  background: linear-gradient(180deg, rgba(44,67,32,0.96), rgba(31,49,23,0.98));
  color: rgba(255,255,255,0.84);
}
.footer-card p,
.footer-card a { color: rgba(255,255,255,0.84); }
.footer-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 1rem;
}
.footer-logo {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  margin-bottom: 1rem;
}
.footer-label {
  font-size: 0.76rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #d9efce;
  margin-bottom: 0.9rem;
}
.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 1.2rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.mobile-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 45;
  transform: translateY(calc(100% + 20px));
  transition: transform 220ms ease;
}
.mobile-cta.is-visible { transform: translateY(0); }
.mobile-cta-inner {
  display: none;
  gap: 0.75rem;
  margin: 0 auto 1rem;
  padding: 0.8rem;
  border-radius: 24px;
  background: rgba(255,251,242,0.95);
  border: 1px solid rgba(98,88,73,0.12);
  box-shadow: var(--shadow-lg);
}
.mobile-cta-inner .btn { flex: 1; }
.mobile-cta-spacer { height: 0; }

[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms cubic-bezier(.16,1,.3,1), transform 700ms cubic-bezier(.16,1,.3,1);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}
[data-delay="1"] { transition-delay: 0.12s; }
[data-delay="2"] { transition-delay: 0.24s; }
[data-delay="3"] { transition-delay: 0.36s; }
[data-delay="4"] { transition-delay: 0.48s; }

@media (max-width: 1120px) {
  .ticket-grid,
  .review-grid,
  .instagram-grid,
  .service-grid,
  .fact-grid,
  .price-grid,
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1120px) and (min-width: 721px) {
  .hide-at-two-col { display: none; }
  .instagram-grid > *:last-child:nth-child(odd),
  .review-grid > *:last-child:nth-child(odd) { display: none; }
}

@media (max-width: 920px) {
  .nav-desktop { display: none; }
  .nav-toggle { display: inline-block; }
  .hero-section { padding-top: 2.25rem; }
  .hero-grid,
  .page-grid,
  .story-grid,
  .contact-grid,
  .quote-grid,
  .side-grid,
  .footer-banner,
  .section-head { grid-template-columns: minmax(0, 1fr); display: grid; }
  .quote-grid > article,
  .quote-grid > aside { min-width: 0; }
  .quote-grid > aside > article { min-width: 0; }
  .hero-stats,
  .note-grid { grid-template-columns: 1fr; }
  .top-links { display: none; }
}

@media (max-width: 720px) {
  .ticket-grid,
  .review-grid,
  .instagram-grid,
  .service-grid,
  .fact-grid,
  .footer-grid,
  .note-grid { grid-template-columns: 1fr; }
  .price-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .brand-lockup img { height: 55px; }
  .mobile-cta-inner { display: flex; }
  .mobile-cta-spacer { height: 7rem; }
  .footer-zone { padding-bottom: 8rem; }
}

@media (max-width: 768px) {
  .service-grid-two-up { grid-template-columns: 1fr; }
}

@media (max-width: 400px) {
  .price-grid { grid-template-columns: minmax(0, 1fr); }
}

.top-note-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--white);
  box-shadow: 0 0 0 6px rgba(255,255,255,0.16);
  flex: 0 0 auto;
}

.page-grid--single {
  grid-template-columns: minmax(0, 1fr);
}

.page-grid--single .page-card {
  max-width: 56rem;
}

.policy-shell {
  display: grid;
  gap: 1.5rem;
}

.policy-card {
  padding: clamp(1.5rem, 3vw, 2.5rem);
  border: 1px solid rgba(56, 54, 50, 0.1);
  border-radius: var(--radius-xl);
  background: var(--card);
  box-shadow: var(--shadow-md);
}

.policy-title {
  margin-top: 1rem;
  max-width: 10ch;
}

.policy-intro {
  margin-top: 1rem;
}

.policy-body {
  display: grid;
  gap: 1.5rem;
}

.policy-section {
  display: grid;
  gap: 0.9rem;
}

.policy-section h2,
.policy-section h3 {
  line-height: 1.15;
}

.policy-section h2 {
  font-size: clamp(1.4rem, 2.8vw, 2rem);
}

.policy-section h3 {
  font-size: 1.08rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.policy-list {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--muted);
  list-style-type: disc;
}

.policy-list li + li {
  margin-top: 0.45rem;
}

.policy-card a {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.no-footer-banner .footer-banner {
  display: none;
}


@media (min-width: 768px) {
  .container {
    max-width:calc(1535px + 2rem) !important;
    padding: 0 1rem;
  }
}

/* ── Instagram feed ─────────────────────────────────── */

.instagram-item {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: var(--radius-md);
  display: block;
  background: var(--paper-deep);
}

.instagram-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ── Service area checker ───────────────────────────────────────────────── */
.sac-input-row {
  display: flex;
  gap: 0.6rem;
  margin-top: 1.4rem;
}
.sac-input {
  flex: 1;
  min-width: 0;
  height: 54px;
  padding: 0 1.1rem;
  border-radius: 999px;
  border: 1px solid var(--paper-line);
  background: rgba(255,255,255,0.8);
  font: inherit;
  font-size: 1rem;
  color: var(--ink);
  outline: none;
  transition: border-color 180ms ease, box-shadow 180ms ease;
}
.sac-input:focus {
  border-color: rgba(78,164,20,0.4);
  box-shadow: 0 0 0 3px rgba(78,164,20,0.10);
}
.sac-loading {
  display: none;
  margin-top: 0.75rem;
  font-size: 0.88rem;
  color: var(--muted);
}
.sac-loading.show { display: block; }
.sac-result {
  display: none;
  align-items: flex-start;
  gap: 1rem;
  margin-top: 1.4rem;
  padding: 1rem 1.2rem;
  border-radius: var(--radius-md);
  border: 1px solid rgba(98,88,73,0.14);
  background: rgba(255,255,255,0.68);
}
.sac-result.show { display: flex; }
.sac-result.inside  { border-color: rgba(78,164,20,0.30);  background: rgba(78,164,20,0.06); }
.sac-result.outside { border-color: rgba(212,43,0,0.28);   background: rgba(212,43,0,0.05); }
.sac-result-icon {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 1.25rem;
  font-weight: 800;
}
.sac-result.inside  .sac-result-icon { background: rgba(78,164,20,0.15); color: var(--green-dark); }
.sac-result.outside .sac-result-icon { background: rgba(212,43,0,0.12);  color: var(--red); }
.sac-result-title {
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-weight: 800;
  font-size: 0.95rem;
  color: var(--ink);
}
.sac-result.inside  .sac-result-title { color: var(--green-dark); }
.sac-result.outside .sac-result-title { color: var(--red); }
.sac-result-postal {
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 0.25rem;
}
.sac-result-detail {
  font-size: 0.9rem;
  color: var(--muted);
  margin-top: 0.4rem;
  line-height: 1.55;
}
.jobber-form-note {
  display: grid;
  gap: 0.75rem;
  margin-top: 1.2rem;
}
.jobber-form-note p {
  font-size: 0.98rem;
}
.jobber-embed-shell {
  margin-top: 1.2rem;
  /*padding: clamp(0.45rem, 1vw, 0.7rem);*/
  border-radius: var(--radius-lg);
  border: 1px solid rgba(98,88,73,0.16);
  padding:0;
  overflow: hidden;
  /*background:*/
  /*  linear-gradient(135deg, rgba(78,164,20,0.10), transparent 35%),*/
  /*  linear-gradient(315deg, rgba(74,159,217,0.10), transparent 30%),*/
  /*  rgba(255,255,255,0.6);*/
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.55);
}
.jobber-card .jobber-inline-work-request {
  position: relative;
  width: 100%;
  max-width: none;
  min-height: 720px;
  margin: 0;
  padding:0;
  /*padding: 0.35rem;*/
  /*border-radius: calc(var(--radius-lg) - 4px);*/
  /*border: 1px solid rgba(98,88,73,0.12);*/
  /*background: rgba(255,255,255,0.74);*/
  /*box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);*/
  height:auto !important;
}
.jobber-card iframe.jobber-work-request {
  display: block;
  max-width: none;
  min-height: 720px;
  padding: 0;
  border-radius: calc(var(--radius-lg) - 8px);
  background: var(--white);
  box-shadow: 0 18px 40px rgba(77,63,31,0.10);
}
.jobber-card .jobber-flash {
  max-width: none;
  margin: 0;
  border: 1px solid rgba(212,43,0,0.18);
  border-radius: var(--radius-md);
  background: rgba(212,43,0,0.06);
  font-family: 'Source Sans 3', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  text-align: left;
}
.sac-map-card {
  padding: 0;
  overflow: hidden;
  min-height: 460px;
}
#map {
  width: 100%;
  height: 100%;
  min-height: 460px;
}

.instagram-placeholder {
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-md);
  border: 1px solid rgba(98,88,73,0.14);
  background:
    linear-gradient(135deg, rgba(78,164,20,0.08) 0%, transparent 55%),
    linear-gradient(315deg, rgba(74,159,217,0.07) 0%, transparent 45%),
    var(--card);
  box-shadow: var(--shadow-md);
}

.review-placeholder {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(98,88,73,0.14);
  box-shadow: var(--shadow-md);
  padding: clamp(1.4rem, 3vw, 2rem);
  background: var(--card);
}
.review-placeholder::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.55) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: review-shimmer 1.6s ease-in-out infinite;
}
@keyframes review-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
.review-placeholder-stars,
.review-placeholder-line,
.review-placeholder-kicker {
  border-radius: 4px;
  background: rgba(98,88,73,0.1);
}
.review-placeholder-stars  { height: 1.1rem; width: 6.5rem; margin-bottom: 1rem; }
.review-placeholder-line   { height: 0.8rem; margin-bottom: 0.55rem; }
.review-placeholder-line:nth-child(2) { width: 100%; }
.review-placeholder-line:nth-child(3) { width: 88%; }
.review-placeholder-line:nth-child(4) { width: 72%; }
.review-placeholder-kicker { height: 0.7rem; width: 52%; margin-top: 1rem; }
