:root {
  --bg: #f8f4ec;
  --text: #2c261f;
  --muted: #6c6358;
  --gold: #b79b63;
  --gold-deep: #8f7440;
  --cream: #fffdf8;
  --line: #e7dcc8;
  --shadow: 0 14px 34px rgba(42, 33, 18, 0.08);
}
* { box-sizing: border-box; }
body { margin: 0; font-family: Georgia, 'Times New Roman', serif; color: var(--text); background: var(--bg); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }
.wrap { width: min(1140px, calc(100% - 32px)); margin: 0 auto; }
.site-header.luxe { background: linear-gradient(180deg, #fffdf8 0%, #f6efdf 100%); border-bottom: 1px solid var(--line); }
.topbar { display: flex; justify-content: space-between; gap: 16px; padding: 10px 0; font-size: 14px; color: var(--muted); }
.announcement-bar { font-family: Inter, Arial, sans-serif; color: var(--gold-deep); }
.brand-stack { text-align: center; padding: 22px 0 20px; }
.site-logo { width: min(280px, 70vw); height: auto; }
.tagline { margin: 8px 0 0; color: var(--muted); font-size: 18px; }
.main-nav { display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; margin-top: 18px; font-family: Inter, Arial, sans-serif; }
.main-nav a { padding-bottom: 4px; border-bottom: 2px solid transparent; }
.main-nav a:hover { border-color: var(--gold); color: var(--gold-deep); }
.hero-photo { position: relative; min-height: 520px; }
.hero-photo > img { width: 100%; height: 520px; object-fit: cover; display: block; filter: saturate(0.92); }
.hero-overlay { position: absolute; inset: 0; display: flex; align-items: center; }
.hero-slideshow { background: #efe5d2; }
.slide { position: relative; }
.slide > img { width: 100%; height: 520px; object-fit: cover; display: block; }
.slide-caption { position: absolute; inset: 0; display: flex; align-items: center; }
.slide-strip { margin-top: 8px; padding: 10px 0 14px; background: #e7d8bc; }
.mini-slide-window { overflow: hidden; }
.mini-slide-track { display: flex; gap: 6px; transition: transform 0.5s ease; will-change: transform; }
.mini-slide { min-width: calc((100% - 12px) / 3); }
.mini-slide img { width: 100%; height: 160px; object-fit: cover; background: #f3eadc; display: block; border: 1px solid #dcc9a5; box-shadow: none; }
.mini-slide-dots { display: flex; justify-content: center; gap: 8px; margin-top: 10px; }
.dot { width: 10px; height: 10px; border-radius: 999px; border: none; background: rgba(143,116,64,0.35); cursor: pointer; }
.dot.active { background: var(--gold-deep); }
.hero-panel { max-width: 620px; background: rgba(255,253,248,0.92); padding: 28px; border: 1px solid rgba(183,155,99,0.32); box-shadow: var(--shadow); }
.eyebrow { text-transform: uppercase; letter-spacing: 0.16em; font-size: 12px; font-family: Inter, Arial, sans-serif; }
.eyebrow.gold { color: var(--gold-deep); }
h1 { font-size: clamp(34px, 5vw, 58px); line-height: 1.02; margin: 10px 0 16px; }
h2 { font-size: clamp(28px, 4vw, 42px); margin: 0 0 12px; }
h3 { font-size: 22px; margin: 0 0 10px; }
p, li { color: var(--muted); line-height: 1.7; }
.lead { font-size: 18px; }
.actions, .center-action { display: flex; gap: 12px; margin-top: 22px; flex-wrap: wrap; justify-content: center; }
.button { display: inline-block; padding: 12px 18px; border-radius: 999px; font-family: Inter, Arial, sans-serif; border: 1px solid var(--gold-deep); }
.button.primary { background: var(--gold-deep); color: white; }
.button.gold-outline { background: transparent; color: var(--gold-deep); }
.button.large { padding: 14px 24px; }
.section { padding: 60px 0; }
.section.alt.warm { background: #f1e7d5; }
.section-head.center { text-align: center; margin-bottom: 22px; }
.merch-section p { margin-top: 0; }
.product-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.compact-grid .catalog-card img { height: 190px; }
.catalog-card, .card, .news-item { background: var(--cream); border: 1px solid var(--line); box-shadow: var(--shadow); }
.catalog-card img { width: 100%; height: 240px; object-fit: cover; display: block; }
.catalog-body { padding: 16px; }
.price { color: var(--gold-deep); font-weight: 700; font-family: Inter, Arial, sans-serif; }
.large-price { font-size: 28px; }
.availability { font-family: Inter, Arial, sans-serif; color: #2f6f3e; font-weight: 600; }
.two-col { display: grid; grid-template-columns: 1.1fr 1fr; gap: 24px; align-items: start; }
.card.soft-card { padding: 22px; border-radius: 16px; }
.detail-image { width: 100%; border: 1px solid var(--line); box-shadow: var(--shadow); }
.price-table { margin: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.price-table div { display: flex; justify-content: space-between; gap: 16px; padding: 10px 0; font-family: Inter, Arial, sans-serif; color: var(--text); }
.contact-form-demo { display: grid; gap: 14px; }
.contact-form-demo label { display: grid; gap: 6px; font-family: Inter, Arial, sans-serif; color: var(--text); }
.contact-form-demo input, .contact-form-demo textarea, .contact-form-demo select { width: 100%; padding: 12px 14px; border: 1px solid var(--line); background: #fff; font: inherit; color: var(--text); }
.admin-grid { display: grid; gap: 18px; }
.inquiry-head { display: flex; justify-content: space-between; gap: 16px; align-items: start; }
.meta { font-family: Inter, Arial, sans-serif; font-size: 14px; }
.status-pill { display: inline-block; padding: 8px 12px; border-radius: 999px; font-family: Inter, Arial, sans-serif; font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
.status-new { background: #fff2cc; color: #7b5a00; }
.status-replied { background: #dff3e6; color: #1d6a39; }
.status-closed { background: #ececec; color: #555; }
.admin-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.category-grid { display: grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap: 14px; }
.category-tile { display: flex; align-items: center; justify-content: center; min-height: 96px; background: var(--cream); border: 1px solid var(--line); box-shadow: var(--shadow); font-family: Inter, Arial, sans-serif; font-weight: 700; }
.arrival-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; }
.arrival-card { background: var(--cream); border: 1px solid var(--line); box-shadow: var(--shadow); padding: 20px; }
.seasonal-band { background: #e9dcc2; }
.seasonal-banner { display: flex; justify-content: space-between; gap: 20px; align-items: center; }
.news-list { display: grid; gap: 16px; }
.news-item { padding: 18px; }
.admin-grid.two-up { grid-template-columns: repeat(2, minmax(0,1fr)); }
@media (max-width: 1100px) {
  body {
    background: var(--bg); 
    color: var(--text); 
  }

  .product-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .category-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .arrival-grid, .admin-grid.two-up { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .two-col { grid-template-columns: 1fr; }
  .hero-panel { max-width: 560px; }
}
@media (max-width: 920px) {
  body {
    background: var(--bg); 
    color: var(--text); 
  }

  .topbar { text-align: center; justify-content: center; }
  .main-nav { gap: 12px; }
  h1 { font-size: clamp(28px, 7vw, 42px); }
  h2 { font-size: clamp(24px, 6vw, 34px); }
  .hero-photo > img, .slide > img { height: 320px; }
  .hero-panel { margin: 16px; padding: 20px; max-width: none; }
  .mini-slide { min-width: calc((100% - 6px) / 2); }
  .mini-slide img { height: 180px; }
  .seasonal-banner { flex-direction: column; align-items: start; }
}
@media (max-width: 640px) and (orientation: portrait) {
  .topbar, .two-col, .product-grid, .admin-grid.two-up, .category-grid, .arrival-grid { grid-template-columns: 1fr; display: grid; }
  .mini-slide { min-width: 100%; }
}

/* Admin/UI button cursor behavior */
button,
.button,
button.button,
input[type="button"],
input[type="submit"] {
  cursor: pointer;
}

button:disabled,
.button[disabled],
button[disabled],
input[type="button"]:disabled,
input[type="submit"]:disabled {
  cursor: not-allowed;
}

/* Compact public blog/update media layout */
.update-card.has-update-image {
  display: grid;
  grid-template-columns: minmax(160px, 240px) 1fr;
  gap: 1.25rem;
  align-items: start;
}

.update-card-media img {
  display: block;
  width: 100%;
  max-width: 240px;
  height: auto;
  border-radius: 18px;
  object-fit: cover;
}

.update-card-body h3 {
  margin-top: 0.35rem;
}

@media (max-width: 720px) {
  .update-card.has-update-image {
    grid-template-columns: 1fr;
  }

  .update-card-media img {
    max-width: 320px;
  }
}

/* Public blog/update readability tuning */
.update-card {
  font-size: 1.08rem;
  line-height: 1.65;
}

.update-card h3 {
  font-size: 1.45rem;
  line-height: 1.25;
  margin-bottom: 0.55rem;
}

.update-card .small-note {
  font-size: 1rem;
  line-height: 1.45;
}

.update-card .update-text {
  font-size: 1.18rem;
  line-height: 1.7;
}


/* Extra spacing before More details button on product cards */
.catalog-card .catalog-body p:last-of-type {
  margin-bottom: 1rem;
}

.catalog-card .card-price-tiers {
  margin: 0.7rem 0 1rem;
}

.catalog-card .card-actions {
  margin-top: 1rem;
}

/* Bold size labels on product price tiers */
.card-price-row .tier-label,
.price-table .tier-label {
  font-weight: 800;
}

.card-price-row .tier-price,
.price-table .tier-price {
  font-weight: 600;
}

/* Store Spotlight alignment option */
.product-grid.spotlight-align-left {
  justify-content: start;
  justify-items: stretch;
}

.product-grid.spotlight-align-center {
  justify-content: center;
  justify-items: center;
  grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
}

.product-grid.spotlight-align-center .catalog-card {
  width: 100%;
  max-width: 320px;
}

/* Final Store Spotlight alignment override */
.product-grid.spotlight-align-center {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center !important;
  justify-items: center !important;
  align-items: stretch;
  gap: 1.25rem;
}

.product-grid.spotlight-align-center .catalog-card {
  flex: 0 1 320px;
  width: 100%;
  max-width: 320px;
}

.product-grid.spotlight-align-left {
  display: grid;
  justify-content: start;
  justify-items: stretch;
}

/* Final public Store Spotlight centering override */
#homepage-store-spotlight-items.spotlight-align-center,
#homepage-store-update-section .spotlight-align-center,
#store-spotlight-page-items.spotlight-align-center,
#new-arrivals-page-section .spotlight-align-center {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  justify-items: center !important;
  align-items: stretch !important;
  gap: 1.25rem !important;
}

#homepage-store-spotlight-items.spotlight-align-center .catalog-card,
#homepage-store-update-section .spotlight-align-center .catalog-card,
#store-spotlight-page-items.spotlight-align-center .catalog-card,
#new-arrivals-page-section .spotlight-align-center .catalog-card {
  flex: 0 1 320px !important;
  width: 100% !important;
  max-width: 320px !important;
}

#homepage-store-spotlight-items.spotlight-align-left,
#store-spotlight-page-items.spotlight-align-left {
  justify-content: start !important;
}

/* Store Spotlight grid placement after heading */
#homepage-store-spotlight-items,
#store-spotlight-page-items {
  margin-top: 1.35rem;
  width: 100%;
}

#homepage-store-spotlight-items.spotlight-align-center,
#store-spotlight-page-items.spotlight-align-center {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 1.25rem !important;
}

#homepage-store-spotlight-items.spotlight-align-center .catalog-card,
#store-spotlight-page-items.spotlight-align-center .catalog-card {
  flex: 0 1 320px !important;
  max-width: 320px !important;
  width: 100% !important;
}

#homepage-store-spotlight-items.spotlight-align-left,
#store-spotlight-page-items.spotlight-align-left {
  justify-content: start !important;
}

/* Hard Store Spotlight centering by direct container ID */
#homepage-store-spotlight-items,
#store-spotlight-page-items {
  margin-top: 1.35rem;
  width: 100%;
}

#homepage-store-spotlight-items.spotlight-align-center,
#store-spotlight-page-items.spotlight-align-center {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 1.25rem !important;
}

#homepage-store-spotlight-items.spotlight-align-center .catalog-card,
#store-spotlight-page-items.spotlight-align-center .catalog-card {
  flex: 0 1 320px !important;
  max-width: 320px !important;
  width: 100% !important;
}

#homepage-store-spotlight-items.spotlight-align-left,
#store-spotlight-page-items.spotlight-align-left {
  display: grid;
  justify-content: start !important;
}

/* Hard Store Spotlight centering by direct container ID */
#homepage-store-spotlight-items,
#store-spotlight-page-items {
  margin-top: 1.35rem;
  width: 100%;
}

#homepage-store-spotlight-items.spotlight-align-center,
#store-spotlight-page-items.spotlight-align-center {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 1.25rem !important;
}

#homepage-store-spotlight-items.spotlight-align-center .catalog-card,
#store-spotlight-page-items.spotlight-align-center .catalog-card {
  flex: 0 1 320px !important;
  max-width: 320px !important;
  width: 100% !important;
}

#homepage-store-spotlight-items.spotlight-align-left,
#store-spotlight-page-items.spotlight-align-left {
  display: grid;
  justify-content: start !important;
}

/* Consistent public topbar announcement colors */
.site-header.luxe .topbar,
.site-header.luxe .topbar span,
.site-header.luxe .topbar a,
.site-announcement-primary,
.site-announcement-secondary,
[data-site-announcement],
[data-site-announcement-right] {
  color: #8a6a28 !important;
}

/* Consistent public topbar announcement colors */
.site-header.luxe .topbar,
.site-header.luxe .topbar span,
.site-header.luxe .topbar a,
.site-announcement-primary,
.site-announcement-secondary,
[data-site-announcement],
[data-site-announcement-right] {
  color: #8a6a28 !important;
}

/* Final compact admin card layout */
body.compact-admin-dashboard main {
  max-width: 1320px;
  margin-left: auto;
  margin-right: auto;
}

body.compact-admin-dashboard main > section:last-of-type {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
  align-items: stretch !important;
}

body.compact-admin-dashboard main > section:last-of-type > * {
  min-width: 0 !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 14px 16px 13px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
}

body.compact-admin-dashboard main > section:last-of-type .eyebrow,
body.compact-admin-dashboard main > section:last-of-type > * > p:first-child {
  font-size: 0.68rem !important;
  line-height: 1 !important;
  margin: 0 0 7px !important;
  letter-spacing: 0.18em !important;
}

body.compact-admin-dashboard main > section:last-of-type h2,
body.compact-admin-dashboard main > section:last-of-type h3 {
  font-size: clamp(1.18rem, 1.4vw, 1.55rem) !important;
  line-height: 0.94 !important;
  margin: 3px 0 6px !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}

body.compact-admin-dashboard main > section:last-of-type p {
  font-size: 0.86rem !important;
  line-height: 1.18 !important;
  margin: 0 0 10px !important;
}

body.compact-admin-dashboard main > section:last-of-type a,
body.compact-admin-dashboard main > section:last-of-type button {
  min-height: 0 !important;
  width: fit-content !important;
  margin-top: 2px !important;
  padding: 5px 11px !important;
  font-size: 0.78rem !important;
  line-height: 1.02 !important;
  border-radius: 999px !important;
}

@media (max-width: 1180px) {
  body.compact-admin-dashboard main > section:last-of-type {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 860px) {
  body.compact-admin-dashboard main > section:last-of-type {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 580px) {
  body.compact-admin-dashboard main > section:last-of-type {
    grid-template-columns: 1fr !important;
  }
}

/* Home page client cleanup: remove hero overlay card and narrow lower image section */
.home-hero .hero-card,
.home-hero .hero-copy,
.home-hero .hero-panel,
.home-hero .hero-content,
.home-hero .hero-text,
.home-hero .hero-overlay {
  display: none !important;
}

.home-hero,
.hero.home-hero,
.index-hero,
.hero-banner {
  min-height: 430px;
}

.home-hero img,
.index-hero img,
.hero-banner img {
  width: 100%;
  object-fit: cover;
}

.home-gallery,
.feature-gallery,
.merch-gallery,
.store-gallery,
.image-gallery,
.home-feature-grid,
.spotlight-grid,
.merch-grid {
  width: min(80%, 1180px);
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 800px) {
  .home-gallery,
  .feature-gallery,
  .merch-gallery,
  .store-gallery,
  .image-gallery,
  .home-feature-grid,
  .spotlight-grid,
  .merch-grid {
    width: calc(100% - 28px);
  }

  .home-hero,
  .hero.home-hero,
  .index-hero,
  .hero-banner {
    min-height: 300px;
  }
}

/* Exact homepage lower-image shrink after hero */
.home-narrow-after-hero {
  width: min(80%, 1180px) !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.home-narrow-after-hero img {
  max-width: 100%;
  height: auto;
}

@media (max-width: 800px) {
  .home-narrow-after-hero {
    width: calc(100% - 28px) !important;
  }
}

/* CampusGear home: shrink mini image strip under hero */
.hero-slideshow .slide-strip {
  width: min(80%, 1180px) !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.hero-slideshow .mini-slide-window {
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden;
}

.hero-slideshow .mini-slide-track {
  width: 100%;
}

.hero-slideshow .mini-slide img {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 800px) {
  .hero-slideshow .slide-strip {
    width: calc(100% - 28px) !important;
  }
}

/* Corrected client request: shrink the large hero image, not the mini image strip */
.hero-slideshow {
  background: #efe4cf;
}

.hero-slideshow .slide-one {
  width: min(80%, 1320px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden;
}

.hero-slideshow .slide-one img {
  width: 100% !important;
  height: auto !important;
  display: block;
  object-fit: cover;
}

/* Restore the image strip below the hero back to normal page width */
.hero-slideshow .slide-strip {
  width: min(1080px, calc(100% - 32px)) !important;
  max-width: 1080px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.hero-slideshow .mini-slide-window {
  width: 100% !important;
}

@media (max-width: 800px) {
  .hero-slideshow .slide-one {
    width: 100% !important;
  }

  .hero-slideshow .slide-strip {
    width: calc(100% - 28px) !important;
  }
}

/* Correct homepage slider size after hero image shrink */
.hero-slideshow .slide-strip {
  width: min(80%, 1320px) !important;
  max-width: 1320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-top: 16px;
  padding-bottom: 16px;
}

.hero-slideshow .mini-slide-window {
  width: 100% !important;
  max-height: 320px !important;
  overflow: hidden !important;
}

.hero-slideshow .mini-slide {
  height: clamp(180px, 21vw, 320px) !important;
  overflow: hidden !important;
}

.hero-slideshow .mini-slide img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

@media (max-width: 800px) {
  .hero-slideshow .slide-strip {
    width: calc(100% - 28px) !important;
  }

  .hero-slideshow .mini-slide {
    height: 190px !important;
  }
}

/* Final homepage image sizing: keep 80% width, reduce vertical height */
.hero-slideshow .slide-one {
  width: min(80%, 1320px) !important;
  height: clamp(260px, 27vw, 360px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden !important;
}

.hero-slideshow .slide-one img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

.hero-slideshow .slide-strip {
  width: min(80%, 1320px) !important;
  max-width: 1320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

.hero-slideshow .mini-slide-window {
  width: 100% !important;
  max-height: 170px !important;
  overflow: hidden !important;
}

.hero-slideshow .mini-slide {
  height: clamp(110px, 11vw, 170px) !important;
  overflow: hidden !important;
}

.hero-slideshow .mini-slide img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

@media (max-width: 800px) {
  .hero-slideshow .slide-one {
    width: 100% !important;
    height: 260px !important;
  }

  .hero-slideshow .slide-strip {
    width: calc(100% - 28px) !important;
  }

  .hero-slideshow .mini-slide {
    height: 125px !important;
  }
}

/* Final compact homepage layout: reduce header/logo and image vertical real estate */
.site-header.luxe {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.site-header .topbar,
.topbar.announcement-bar {
  min-height: 24px !important;
  padding-top: 2px !important;
  padding-bottom: 2px !important;
  font-size: 0.82rem !important;
}

.brand-stack {
  gap: 4px !important;
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

.site-logo {
  max-width: 230px !important;
  max-height: 95px !important;
  width: auto !important;
  height: auto !important;
}

.tagline {
  margin-top: 2px !important;
  margin-bottom: 4px !important;
  font-size: 1rem !important;
}

.main-nav.centered {
  margin-top: 4px !important;
  gap: 20px !important;
}

.main-nav.centered a {
  padding-top: 4px !important;
  padding-bottom: 4px !important;
}

/* Keep hero centered but much shorter */
.hero-slideshow .slide-one {
  width: min(80%, 1320px) !important;
  height: clamp(190px, 20vw, 260px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden !important;
}

.hero-slideshow .slide-one img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

/* Keep slider useful but not dominant */
.hero-slideshow .slide-strip {
  width: min(80%, 1320px) !important;
  max-width: 1320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

.hero-slideshow .mini-slide-window {
  width: 100% !important;
  max-height: 105px !important;
  overflow: hidden !important;
}

.hero-slideshow .mini-slide {
  height: clamp(80px, 8vw, 105px) !important;
  overflow: hidden !important;
}

.hero-slideshow .mini-slide img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.hero-slideshow .mini-slide-dots {
  margin-top: 4px !important;
}

/* Pull next content closer */
#homepage-store-spotlight-section {
  padding-top: 34px !important;
}

@media (max-width: 800px) {
  .site-logo {
    max-width: 190px !important;
    max-height: 78px !important;
  }

  .tagline {
    font-size: 0.92rem !important;
  }

  .hero-slideshow .slide-one {
    width: 100% !important;
    height: 210px !important;
  }

  .hero-slideshow .slide-strip {
    width: calc(100% - 28px) !important;
  }

  .hero-slideshow .mini-slide {
    height: 85px !important;
  }
}

/* Compact homepage Store Spotlight section */
#homepage-store-spotlight-section {
  width: min(80%, 1120px) !important;
  max-width: 1120px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-top: 26px !important;
  padding-bottom: 26px !important;
}

#homepage-store-spotlight-section .section-head {
  margin-bottom: 14px !important;
}

#homepage-store-spotlight-section .eyebrow {
  margin-bottom: 4px !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.16em !important;
}

#homepage-store-spotlight-section h2 {
  margin-top: 0 !important;
  margin-bottom: 8px !important;
  font-size: clamp(1.7rem, 2.5vw, 2.35rem) !important;
  line-height: 1.05 !important;
}

#homepage-store-spotlight-section #homepage-store-spotlight-body {
  max-width: 620px !important;
  font-size: 0.95rem !important;
  line-height: 1.4 !important;
  margin-bottom: 0 !important;
}

#homepage-store-spotlight-items.product-grid {
  width: 100% !important;
  max-width: 760px !important;
  margin: 16px auto 0 !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(190px, 240px)) !important;
  justify-content: center !important;
  gap: 14px !important;
}

#homepage-store-spotlight-items .catalog-card {
  max-width: 240px !important;
  border-radius: 12px !important;
  overflow: hidden !important;
}

#homepage-store-spotlight-items .catalog-card img {
  width: 100% !important;
  height: 135px !important;
  object-fit: cover !important;
  display: block !important;
}

#homepage-store-spotlight-items .catalog-body {
  padding: 10px 12px !important;
}

#homepage-store-spotlight-items .catalog-body h3 {
  margin: 0 0 6px !important;
  font-size: 1.05rem !important;
  line-height: 1.15 !important;
}

#homepage-store-spotlight-items .catalog-body p {
  margin: 4px 0 !important;
  font-size: 0.88rem !important;
  line-height: 1.35 !important;
}

#homepage-store-spotlight-items .availability {
  font-size: 0.82rem !important;
}

@media (max-width: 800px) {
  #homepage-store-spotlight-section {
    width: calc(100% - 28px) !important;
    padding-top: 24px !important;
    padding-bottom: 24px !important;
  }

  #homepage-store-spotlight-items.product-grid {
    max-width: 100% !important;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
  }

  #homepage-store-spotlight-items .catalog-card {
    max-width: none !important;
  }

  #homepage-store-spotlight-items .catalog-card img {
    height: 125px !important;
  }
}

/* Tighten homepage gap between Store Spotlight and Featured Merchandise */
#homepage-store-spotlight-section {
  padding-bottom: 8px !important;
  margin-bottom: 0 !important;
}

#homepage-store-spotlight-items.product-grid {
  margin-bottom: 0 !important;
}

#homepage-store-spotlight-section + .section {
  padding-top: 18px !important;
  margin-top: 0 !important;
}

#homepage-store-spotlight-section + .section .section-head {
  margin-top: 0 !important;
  margin-bottom: 18px !important;
}

@media (max-width: 800px) {
  #homepage-store-spotlight-section {
    padding-bottom: 10px !important;
  }

  #homepage-store-spotlight-section + .section {
    padding-top: 16px !important;
  }
}

/* Homepage compact footer replacing removed Why Shop Here section */
.campus-home-footer {
  background: #d9c9aa;
  border-top: 1px solid rgba(120, 92, 42, 0.22);
  padding: 20px 0;
  color: #3a3027;
}

.campus-footer-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: 18px;
  align-items: start;
}

.campus-footer-inner div {
  display: grid;
  gap: 3px;
}

.campus-footer-inner strong {
  color: #2b241d;
  font-size: 0.95rem;
}

.campus-footer-inner span,
.campus-footer-inner a {
  color: #5f5144;
  font-size: 0.92rem;
}

.campus-footer-inner a {
  text-decoration: none;
}

.campus-footer-inner a:hover {
  text-decoration: underline;
}

@media (max-width: 800px) {
  .campus-footer-inner {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .campus-home-footer {
    padding: 18px 0;
  }
}

/* Homepage: use slider as large banner, replacing old static hero image */
.home-slider-banner {
  width: min(80%, 1320px) !important;
  margin: 0 auto 0 !important;
  background: #efe4cf;
}

.home-slider-window {
  width: 100%;
  height: clamp(300px, 30vw, 460px);
  overflow: hidden;
  background: #efe4cf;
}

.home-slider-track {
  height: 100%;
  display: flex;
  transition: transform 450ms ease;
  will-change: transform;
}

.home-slider-slide {
  min-width: 100%;
  height: 100%;
}

.home-slider-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.home-slider-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: 8px 0 10px;
  background: #efe4cf;
}

.home-slider-dots .dot {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 999px;
  background: rgba(125, 99, 50, 0.32);
  cursor: pointer;
}

.home-slider-dots .dot.active {
  background: rgba(125, 99, 50, 0.82);
}

@media (max-width: 800px) {
  .home-slider-banner {
    width: 100% !important;
  }

  .home-slider-window {
    height: 280px;
  }
}

/* Homepage slider: compact 4-up banner */
.home-slider-banner {
  width: min(80%, 1320px) !important;
  margin: 0 auto !important;
  background: #efe4cf !important;
}

.home-slider-window {
  width: 100% !important;
  height: clamp(175px, 17vw, 270px) !important;
  overflow: hidden !important;
  background: #efe4cf !important;
}

.home-slider-track {
  height: 100% !important;
  display: flex !important;
  transition: transform 450ms ease !important;
  will-change: transform !important;
}

.home-slider-page {
  min-width: 100% !important;
  height: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(var(--slide-count), minmax(0, 1fr)) !important;
  gap: 6px !important;
}

.home-slider-tile {
  height: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  background: #efe4cf !important;
}

.home-slider-tile img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

.home-slider-dots {
  display: flex !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 7px 0 8px !important;
  background: #efe4cf !important;
}

.home-slider-dots .dot {
  width: 10px !important;
  height: 10px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(125, 99, 50, 0.32) !important;
  cursor: pointer !important;
}

.home-slider-dots .dot.active {
  background: rgba(125, 99, 50, 0.82) !important;
}

@media (max-width: 900px) {
  .home-slider-banner {
    width: 100% !important;
  }

  .home-slider-window {
    height: 220px !important;
  }

  .home-slider-page {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-auto-rows: 1fr !important;
  }
}

@media (max-width: 560px) {
  .home-slider-window {
    height: 190px !important;
  }

  .home-slider-page {
    grid-template-columns: 1fr !important;
  }
}

/* Homepage slider: preserve image proportions and add even spacing */
.home-slider-window {
  height: clamp(175px, 17vw, 270px) !important;
  padding: 8px !important;
  box-sizing: border-box !important;
  background: #efe4cf !important;
}

.home-slider-page {
  gap: 10px !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}

.home-slider-tile {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  background: #f8f2e6 !important;
}

.home-slider-tile img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block !important;
}

.home-slider-dots {
  padding: 7px 0 8px !important;
}

@media (max-width: 900px) {
  .home-slider-window {
    height: 220px !important;
    padding: 7px !important;
  }

  .home-slider-page {
    gap: 8px !important;
  }
}

@media (max-width: 560px) {
  .home-slider-window {
    height: 190px !important;
    padding: 6px !important;
  }
}

/* Homepage slider: 5-up balanced row with subtle horizontal fill */
.home-slider-banner {
  width: min(88%, 1500px) !important;
}

.home-slider-window {
  height: clamp(165px, 15vw, 245px) !important;
  padding: 8px !important;
}

.home-slider-page {
  gap: 8px !important;
}

.home-slider-tile {
  background: #f8f2e6 !important;
}

/* Mild horizontal fill so images feel less narrow, without obvious distortion */
.home-slider-tile img {
  object-fit: contain !important;
  transform: scaleX(1.035) !important;
  transform-origin: center center !important;
}

/* Keep smaller screens practical */
@media (max-width: 1100px) {
  .home-slider-banner {
    width: 94% !important;
  }

  .home-slider-window {
    height: 220px !important;
  }
}

@media (max-width: 900px) {
  .home-slider-page {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .home-slider-tile img {
    transform: none !important;
  }
}

@media (max-width: 560px) {
  .home-slider-page {
    grid-template-columns: 1fr !important;
  }
}

/* FINAL homepage slider strip polish:
   full-width shaded banner area, narrower centered image row */
.home-slider-banner {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  background: #eadfc9 !important;
  padding: 8px 0 0 !important;
}

.home-slider-window {
  width: min(82%, 1400px) !important;
  margin: 0 auto !important;
  height: clamp(160px, 14vw, 230px) !important;
  padding: 7px !important;
  box-sizing: border-box !important;
  background: #eadfc9 !important;
  overflow: hidden !important;
}

.home-slider-page {
  gap: 7px !important;
}

.home-slider-tile {
  background: #f8f2e6 !important;
}

.home-slider-tile img {
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
}

.home-slider-dots {
  width: 100% !important;
  background: #eadfc9 !important;
  padding: 7px 0 8px !important;
}

@media (max-width: 1100px) {
  .home-slider-window {
    width: 92% !important;
    height: 210px !important;
  }
}

@media (max-width: 700px) {
  .home-slider-window {
    width: 100% !important;
    height: 190px !important;
    padding: 6px !important;
  }
}

/* Homepage slider: tighten centered image row */
.home-slider-window {
  width: min(74%, 1180px) !important;
}

.home-slider-page {
  gap: 5px !important;
}

@media (max-width: 1100px) {
  .home-slider-window {
    width: 88% !important;
  }
}

@media (max-width: 700px) {
  .home-slider-window {
    width: 100% !important;
  }
}

/* Homepage slider: tighten centered image row */
.home-slider-window {
  width: min(74%, 1180px) !important;
}

.home-slider-page {
  gap: 5px !important;
}

@media (max-width: 1100px) {
  .home-slider-window {
    width: 88% !important;
  }
}

@media (max-width: 700px) {
  .home-slider-window {
    width: 100% !important;
  }
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.12);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.10);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.09);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.08);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.06);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.00);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.00);
  transform-origin: center center;
}

/* Slight extra horizontal stretch for homepage slider images */
.home-slider-page > * {
  overflow: hidden;
}

.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scaleX(1.08);
  transform-origin: center center;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(1.08) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(1.04) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(1.02) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(1.00) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(0.90) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 26% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 24% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 20% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 26% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 28% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 30% !important;
  transform: scaleX(0.96) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 30% !important;
  transform: scaleX(0.98) !important;
  transform-origin: center center !important;
}

/* FINAL homepage slider image focal correction */
.home-slider-tile img,
.home-slider-page img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center 32% !important;
  transform: scaleX(0.98) !important;
  transform-origin: center center !important;
}

/* Dynamic homepage featured merchandise */
#homepage-featured-merchandise .catalog-card img {
  object-fit: cover;
  object-position: center center;
}

#homepage-featured-merchandise .catalog-body h3 a {
  color: inherit;
  text-decoration: none;
}

#homepage-featured-merchandise .catalog-body h3 a:hover {
  text-decoration: underline;
}

/* Homepage featured merchandise: center cards like Store Spotlight */
#homepage-featured-merchandise {
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-content: center !important;
  align-items: stretch !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 320px)) !important;
}

#homepage-featured-merchandise .catalog-card {
  width: 100% !important;
  max-width: 320px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 760px) {
  #homepage-featured-merchandise {
    max-width: 360px !important;
    grid-template-columns: 1fr !important;
  }

  #homepage-featured-merchandise .catalog-card {
    max-width: 360px !important;
  }
}

/* FIX: Featured merchandise centered row, not forced 2x2 grid */
#homepage-featured-merchandise {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: stretch !important;
  gap: 18px !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  grid-template-columns: none !important;
}

#homepage-featured-merchandise .catalog-card {
  flex: 0 1 255px !important;
  width: 255px !important;
  max-width: 255px !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

@media (max-width: 760px) {
  #homepage-featured-merchandise {
    max-width: 100% !important;
    gap: 14px !important;
  }

  #homepage-featured-merchandise .catalog-card {
    flex: 1 1 280px !important;
    width: auto !important;
    max-width: 360px !important;
  }
}


/* Homepage slider: keep incomplete final pages from stretching one image full-width */
.home-slider-spacer {
  height: 100% !important;
  min-width: 0 !important;
  pointer-events: none !important;
}

/* FIX: prevent previous homepage slider page from bleeding into partial final pages */
.home-slider-track {
  width: 100% !important;
}

.home-slider-page {
  flex: 0 0 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.home-slider-spacer {
  background: transparent !important;
  overflow: hidden !important;
}

/* Homepage slider bleed mask:
   keep the working 5-up carousel, but cover tiny adjacent-page slivers
   with the same shaded banner background. */
.home-slider-window {
  position: relative !important;
  overflow: hidden !important;
}

.home-slider-window::before,
.home-slider-window::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 14px !important;
  background: #eadfc9 !important;
  z-index: 8 !important;
  pointer-events: none !important;
}

.home-slider-window::before {
  left: 0 !important;
}

.home-slider-window::after {
  right: 0 !important;
}

/* Preserve normal centered final-page tile behavior */
.home-slider-spacer {
  background: transparent !important;
  pointer-events: none !important;
}










