:root {
  --primary: #ff3d3d;
  --primary-dark: #c91d28;
  --ink: #141414;
  --ink-soft: #3d3d3d;
  --muted: #74777c;
  --line: rgba(20, 20, 20, 0.11);
  --surface: #ffffff;
  --surface-soft: #f7f1e8;
  --cream: #fff8ef;
  --black: #080808;
  --white: #ffffff;
  --blue-soft: #e6f2ff;
  --green-soft: #e9f8ef;
  --radius: 26px;
  --radius-sm: 16px;
  --shadow: 0 22px 70px rgba(0, 0, 0, 0.12);
  --shadow-soft: 0 10px 35px rgba(0, 0, 0, 0.08);
  --max: 1180px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top left, rgba(255, 61, 61, 0.14), transparent 32rem),
    linear-gradient(180deg, var(--cream) 0%, #f8f8f8 38%, #ffffff 100%);
  line-height: 1.55;
  min-height: 100vh;
}
a { color: inherit; text-decoration: none; transition: 180ms ease; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }
.skip-link { position:absolute; left:-999px; top:0; background:var(--black); color:var(--white); padding:12px 18px; border-radius:0 0 12px 0; z-index:9999; }
.skip-link:focus { left:0; }

/* Navigation */
nav.site-nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.nav-inner {
  width: min(var(--max), calc(100% - 40px));
  margin: 0 auto;
  min-height: 88px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.logo-img { height: 88px; width: auto; object-fit: contain; }
.nav-menu { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.nav-link { font-weight: 850; color: var(--ink); padding: 10px 13px; border-radius: 999px; }
.nav-link:hover, .nav-link.active { color: var(--primary-dark); background: rgba(255,61,61,0.08); }
.btn-nav, .btn-primary, .btn-secondary, .btn-dark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 999px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  border: 0;
  white-space: nowrap;
}
.btn-nav { background: var(--black); color: var(--white); padding: 12px 18px; box-shadow: 0 12px 25px rgba(0,0,0,0.14); }
.btn-nav:hover { background: var(--primary); transform: translateY(-1px); }
.btn-primary { background: var(--primary); color: var(--white); padding: 16px 24px; box-shadow: 0 20px 35px rgba(255,61,61,0.22); }
.btn-primary:hover { background: var(--primary-dark); transform: translateY(-2px); }
.btn-secondary { background: rgba(255,255,255,0.14); border: 1px solid rgba(255,255,255,0.35); color: var(--white); padding: 16px 24px; backdrop-filter: blur(12px); }
.btn-secondary:hover { background: var(--white); color: var(--ink); transform: translateY(-2px); }
.btn-dark { background: var(--black); color: var(--white); padding: 14px 20px; }
.btn-dark:hover { background: var(--primary-dark); transform: translateY(-2px); }

/* Layout */
.container { width: min(var(--max), calc(100% - 40px)); margin: 0 auto; padding: 70px 0; }
.container.tight { padding: 46px 0; }
.section-head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 28px; }
.section-kicker, .eyebrow { color: var(--primary-dark); font-weight: 950; letter-spacing: .08em; text-transform: uppercase; font-size: .8rem; }
.section-title { font-size: clamp(2rem, 4vw, 3.7rem); line-height: .98; letter-spacing: -.045em; font-weight: 950; text-wrap: balance; }
.section-copy { max-width: 650px; color: var(--muted); font-size: 1.04rem; margin-top: 12px; }
.muted { color: var(--muted); }

/* Hero */
.hero {
  position: relative;
  isolation: isolate;
  min-height: 710px;
  display: grid;
  place-items: center;
  color: var(--white);
  overflow: hidden;
  background:
    linear-gradient(100deg, rgba(0,0,0,0.88) 0%, rgba(0,0,0,0.58) 50%, rgba(0,0,0,0.20) 100%),
    url('../../parliament.jpg') center / cover no-repeat,
    #222;
}
.hero::after { content:""; position:absolute; inset:auto 0 0; height:180px; background:linear-gradient(180deg, transparent, var(--cream)); z-index:-1; pointer-events:none; }
.hero-inner { width:min(var(--max), calc(100% - 40px)); display:grid; grid-template-columns:minmax(0,1.1fr) minmax(320px,.66fr); align-items:end; gap:36px; padding:88px 0 120px; }
.hero .eyebrow { display:inline-flex; align-items:center; gap:8px; width:fit-content; color:var(--white); margin-bottom:18px; padding:8px 12px; border-radius:999px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.28); backdrop-filter:blur(12px); }
.live-dot { width:8px; height:8px; border-radius:50%; background:var(--primary); box-shadow:0 0 0 7px rgba(255,61,61,.18); }
.hero h1 { max-width:860px; font-size:clamp(3rem,8vw,7rem); line-height:.9; letter-spacing:-.075em; font-weight:950; text-wrap:balance; text-shadow:0 12px 40px rgba(0,0,0,.35); }
.hero p { max-width:700px; margin:24px 0 34px; font-size:clamp(1.08rem,2vw,1.36rem); color:rgba(255,255,255,.88); }
.hero-buttons { display:flex; gap:12px; flex-wrap:wrap; }
.hero-panel { border:1px solid rgba(255,255,255,.20); background:rgba(255,255,255,.12); backdrop-filter:blur(22px); border-radius:var(--radius); padding:22px; box-shadow:0 24px 80px rgba(0,0,0,.22); }
.hero-panel small { display:block; color:rgba(255,255,255,.72); text-transform:uppercase; letter-spacing:.10em; font-weight:900; margin-bottom:12px; }
.mini-pick { display:grid; gap:8px; padding:16px; border-radius:18px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.16); }
.mini-pick + .mini-pick { margin-top:10px; }
.mini-pick strong { font-size:1rem; }
.mini-pick span { color:rgba(255,255,255,.72); font-size:.92rem; }
.stat-row { display:flex; gap:12px; flex-wrap:wrap; margin-top:22px; }
.stat-chip { border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.10); border-radius:999px; padding:10px 13px; font-weight:850; color:rgba(255,255,255,.86); }

/* Page Header */
.page-header { background: var(--blue-soft); color: var(--ink); padding: 82px 20px 106px; text-align:center; }
.page-header.dark { color:var(--white); background:linear-gradient(135deg, rgba(0,0,0,.85), rgba(0,0,0,.55)), url('../../parliament.jpg') center / cover no-repeat, #111; }
.page-header .super-header { color:var(--primary); font-weight:900; text-transform:uppercase; letter-spacing:2px; font-size:.86rem; margin-bottom:10px; display:block; }
.page-header h1 { font-size:clamp(2.6rem, 7vw, 5.5rem); line-height:.95; letter-spacing:-.06em; font-weight:950; margin-bottom:15px; }
.page-header p { font-size:1.18rem; color:#555; max-width:720px; margin:0 auto; }
.page-header.dark p { color:rgba(255,255,255,.78); }

/* Quick Picks */
.quick-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:16px; }
.quick-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); padding:18px; box-shadow:var(--shadow-soft); min-height:100%; }
.quick-card .label { color:var(--primary-dark); font-weight:950; text-transform:uppercase; letter-spacing:.08em; font-size:.74rem; margin-bottom:8px; }
.quick-card h3 { font-size:1.12rem; line-height:1.15; margin-bottom:8px; letter-spacing:-.02em; }
.quick-card p { color:var(--muted); font-size:.95rem; }

/* Featured */
.featured-card { display:grid; grid-template-columns:minmax(0,.9fr) minmax(0,1fr); gap:0; overflow:hidden; border-radius:calc(var(--radius) + 8px); background:var(--black); color:var(--white); box-shadow:var(--shadow); }
.featured-media { min-height:420px; background:linear-gradient(135deg, rgba(255,61,61,.35), rgba(0,0,0,.25)), url('../images/events/canadian-tulip-festival.webp') center/cover; }
.featured-content { padding:clamp(28px,5vw,54px); display:flex; flex-direction:column; justify-content:center; }
.featured-content h2 { font-size:clamp(2rem,5vw,4.5rem); line-height:.93; letter-spacing:-.06em; margin:12px 0 16px; }
.featured-content p { color:rgba(255,255,255,.78); font-size:1.05rem; max-width:620px; }
.badge-row { display:flex; flex-wrap:wrap; gap:8px; margin:18px 0 24px; }
.badge { width:fit-content; display:inline-flex; align-items:center; border-radius:999px; padding:8px 10px; font-size:.75rem; font-weight:950; text-transform:uppercase; letter-spacing:.05em; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); color:rgba(255,255,255,.88); }

/* Tools and Event Cards */
.tools { display:grid; grid-template-columns:minmax(220px,1fr) auto; gap:14px; align-items:center; margin:28px 0; padding:14px; border:1px solid var(--line); background:rgba(255,255,255,.74); border-radius:22px; box-shadow:var(--shadow-soft); }
.search-wrap { position:relative; }
.search-wrap span { position:absolute; left:16px; top:50%; transform:translateY(-50%); color:var(--muted); pointer-events:none; }
.event-search { width:100%; border:1px solid var(--line); background:var(--white); padding:15px 18px 15px 44px; border-radius:999px; outline:none; color:var(--ink); }
.event-search:focus { border-color:rgba(255,61,61,.55); box-shadow:0 0 0 4px rgba(255,61,61,.10); }
.filter-row { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.filter-btn { border:1px solid var(--line); background:var(--white); color:var(--ink-soft); border-radius:999px; padding:11px 14px; cursor:pointer; font-weight:850; transition:180ms ease; }
.filter-btn:hover, .filter-btn.active { color:var(--white); background:var(--black); border-color:var(--black); }
.status-line { display:flex; justify-content:space-between; align-items:center; gap:16px; margin-bottom:18px; color:var(--muted); font-size:.95rem; }
.event-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px; }
.event-card { position:relative; overflow:hidden; background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow-soft); border:1px solid rgba(0,0,0,.07); min-height:100%; display:flex; flex-direction:column; transform:translateY(0); }
.event-card:hover { transform:translateY(-6px); box-shadow:var(--shadow); }
.card-image { min-height:210px; background:linear-gradient(135deg, rgba(255,61,61,.88), rgba(10,10,10,.72)), url('../../parliament.jpg') center/cover no-repeat; position:relative; display:flex; align-items:end; padding:16px; color:var(--white); }
.card-image::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 28%, rgba(0,0,0,.65)); pointer-events:none; }
.tag, .price { position:relative; z-index:1; display:inline-flex; width:fit-content; align-items:center; border-radius:999px; font-size:.75rem; line-height:1; font-weight:950; letter-spacing:.04em; text-transform:uppercase; padding:8px 10px; }
.tag { background:rgba(255,255,255,.92); color:var(--ink); box-shadow:0 10px 24px rgba(0,0,0,.18); }
.price { position:absolute; top:16px; right:16px; background:rgba(0,0,0,.64); color:var(--white); border:1px solid rgba(255,255,255,.22); backdrop-filter:blur(10px); }
.card-content { padding:21px; display:flex; flex-direction:column; flex:1; gap:12px; }
.event-card-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.date { color:var(--primary-dark); font-weight:950; font-size:.86rem; letter-spacing:.04em; text-transform:uppercase; }
.price-pill { display:inline-flex; width:fit-content; max-width:48%; align-items:center; justify-content:center; border-radius:999px; padding:8px 10px; background:rgba(255,61,61,.10); color:var(--primary-dark); border:1px solid rgba(255,61,61,.18); font-size:.76rem; line-height:1.15; font-weight:950; text-align:center; }
.card-title { font-size:1.34rem; line-height:1.14; letter-spacing:-.02em; font-weight:950; }
.description { color:var(--muted); font-size:.96rem; }
.event-detail-list { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; margin-top:2px; }
.event-detail-list div { border:1px solid var(--line); background:#fbfbfb; border-radius:14px; padding:10px; min-width:0; }
.event-detail-list span { display:block; color:var(--muted); font-size:.72rem; font-weight:900; text-transform:uppercase; letter-spacing:.06em; margin-bottom:3px; }
.event-detail-list strong { display:block; color:var(--ink); font-size:.9rem; line-height:1.25; overflow-wrap:anywhere; }
.event-notes { border-left:3px solid var(--primary); padding-left:12px; color:var(--ink-soft); font-size:.92rem; }
.meta { display:grid; gap:6px; margin-top:auto; color:var(--ink-soft); font-size:.94rem; padding-top:8px; }
.meta span { display:flex; align-items:flex-start; gap:8px; }
.card-footer { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:8px; padding-top:14px; border-top:1px solid var(--line); }
.source { color:var(--muted); font-size:.82rem; font-weight:750; }
.view-link { font-weight:950; color:var(--primary-dark); }
.empty-state { grid-column:1/-1; text-align:center; padding:58px 24px; border:1px dashed rgba(0,0,0,.18); background:rgba(255,255,255,.68); border-radius:var(--radius); color:var(--muted); }
.featured-note { margin:14px 0 0; color:rgba(255,255,255,.82); font-weight:750; }

/* Event Detail Pages */
.event-detail-page { background:linear-gradient(180deg, var(--cream), #fff 42%); }
.event-detail-hero {
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto;
  padding:64px 0 20px;
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1fr);
  gap:34px;
  align-items:center;
}
.event-detail-media img {
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:var(--radius);
  background:var(--black);
  box-shadow:var(--shadow);
}
.event-detail-media img.is-fallback { object-position:center; }
.event-detail-copy { min-width:0; }
.event-detail-copy h1 {
  margin:14px 0 16px;
  font-size:clamp(2.4rem,6vw,5.2rem);
  line-height:.94;
  letter-spacing:-.06em;
  font-weight:950;
  text-wrap:balance;
}
.event-detail-copy p { max-width:700px; color:var(--ink-soft); font-size:1.12rem; margin-bottom:20px; }
.event-detail-copy .badge, .event-detail-notes .badge { background:var(--black); color:var(--white); border-color:var(--black); }
.event-detail-copy .badge-row { margin:0 0 22px; }
.back-link {
  display:inline-flex;
  width:fit-content;
  margin-bottom:18px;
  color:var(--primary-dark);
  font-weight:950;
}
.back-link:hover { color:var(--black); }
.event-detail-layout {
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1fr);
  gap:24px;
  align-items:start;
}
.event-detail-panel {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow-soft);
}
.event-detail-panel div { min-width:0; border:1px solid var(--line); border-radius:14px; padding:14px; background:#fbfbfb; }
.event-detail-panel span {
  display:block;
  margin-bottom:4px;
  color:var(--muted);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.event-detail-panel strong { display:block; color:var(--ink); font-size:.98rem; line-height:1.25; overflow-wrap:anywhere; }
.event-detail-notes {
  padding:28px;
  border-radius:var(--radius);
  background:var(--black);
  color:var(--white);
  box-shadow:var(--shadow);
}
.event-detail-notes h2 { font-size:clamp(1.5rem,3vw,2.3rem); line-height:1; letter-spacing:-.035em; margin-bottom:12px; }
.event-detail-notes p { color:rgba(255,255,255,.78); margin-top:12px; }
.event-detail-notes a { color:var(--white); font-weight:900; text-decoration:underline; text-underline-offset:3px; }
.source-line { font-size:.94rem; }

/* Blog Placeholder */
.construction-page {
  min-height:calc(100vh - 88px);
  display:grid;
  place-items:center;
  padding:64px 20px 78px;
  background:
    radial-gradient(circle at top left, rgba(255, 61, 61, 0.12), transparent 34rem),
    linear-gradient(180deg, var(--cream), #fff 70%);
}
.construction-inner {
  width:min(1040px, 100%);
  text-align:center;
}
.construction-inner h1 {
  margin:8px 0 10px;
  font-size:clamp(2.4rem, 7vw, 5.4rem);
  line-height:.92;
  letter-spacing:-.06em;
  font-weight:950;
}
.construction-inner p {
  max-width:680px;
  margin:0 auto 28px;
  color:var(--muted);
  font-size:1.1rem;
}
.construction-inner img {
  width:100%;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.08);
  background:var(--surface);
}
.construction-inner .hero-buttons {
  justify-content:center;
  margin-top:28px;
}

/* Shop */
.shop-page {
  background:linear-gradient(180deg, var(--cream), #fff 54%);
}
.shop-hero {
  width:min(var(--max), calc(100% - 40px));
  margin:0 auto;
  padding:58px 0 28px;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.05fr);
  gap:34px;
  align-items:center;
}
.shop-hero-copy h1 {
  margin:10px 0 16px;
  font-size:clamp(2.6rem, 6vw, 5.8rem);
  line-height:.92;
  letter-spacing:-.065em;
  font-weight:950;
  text-wrap:balance;
}
.shop-hero-copy p {
  max-width:640px;
  margin-bottom:26px;
  color:var(--muted);
  font-size:1.12rem;
}
.shop-hero-media img {
  width:100%;
  aspect-ratio:16/11;
  object-fit:cover;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.08);
  background:var(--surface);
}
.shop-feature {
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,.62fr);
  gap:24px;
  align-items:center;
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow-soft);
}
.shop-feature img {
  width:100%;
  aspect-ratio:16/7;
  object-fit:cover;
  object-position:top center;
  border-radius:18px;
  background:#f3f3f3;
}
.shop-feature h2 {
  margin:6px 0 8px;
  font-size:clamp(1.8rem, 4vw, 3.2rem);
  line-height:.98;
  letter-spacing:-.045em;
  font-weight:950;
}
.shop-feature p { color:var(--muted); }
.shop-product-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.shop-product-card {
  overflow:hidden;
  border:1px solid rgba(0,0,0,.07);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow-soft);
  transition:transform 180ms ease, box-shadow 180ms ease;
}
.shop-product-card:hover {
  transform:translateY(-5px);
  box-shadow:var(--shadow);
}
.shop-product-media {
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
  background:#f2f2f2;
}
.shop-product-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:opacity 200ms ease;
}
.shop-product-img-front { z-index:2; opacity:1; }
.shop-product-img-back { z-index:1; opacity:1; }
.shop-product-card:hover .shop-product-img-front { opacity:0; }
.shop-product-content {
  padding:20px;
  display:grid;
  gap:7px;
}
.shop-product-content > span {
  color:var(--primary-dark);
  font-size:.74rem;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.shop-product-content h3 {
  font-size:1.25rem;
  line-height:1.12;
  letter-spacing:-.02em;
  font-weight:950;
}
.shop-product-content p {
  color:var(--muted);
  font-size:.95rem;
}
.shop-product-footer {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:10px;
}
.shop-product-footer strong {
  font-size:1.12rem;
  font-weight:950;
}
.shop-product-footer .btn-dark {
  padding:11px 17px;
}

/* Cart */
.cart-page { padding-top:46px; }
.cart-topline {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:22px;
}
.clear-cart-btn,
.remove-cart-item {
  border:0;
  background:transparent;
  color:var(--muted);
  font-weight:900;
  cursor:pointer;
}
.clear-cart-btn:hover,
.remove-cart-item:hover { color:var(--primary-dark); }
.cart-wrapper {
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(300px,.6fr);
  gap:24px;
  align-items:start;
}
.cart-items,
.cart-summary,
.empty-cart {
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow-soft);
}
.cart-items { padding:24px; }
.cart-header-row {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding-bottom:18px;
  margin-bottom:4px;
  border-bottom:1px solid var(--line);
}
.cart-header-row h2,
.cart-summary h2,
.empty-cart h2 {
  font-size:clamp(1.6rem,3vw,2.45rem);
  line-height:1;
  letter-spacing:-.04em;
  font-weight:950;
}
.cart-count-pill {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:fit-content;
  border-radius:999px;
  padding:8px 10px;
  background:rgba(255,61,61,.10);
  color:var(--primary-dark);
  border:1px solid rgba(255,61,61,.18);
  font-size:.78rem;
  font-weight:950;
  white-space:nowrap;
}
.cart-item {
  display:grid;
  grid-template-columns:92px minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
  padding:18px 0;
  border-bottom:1px solid var(--line);
}
.cart-item:last-child { border-bottom:0; padding-bottom:0; }
.cart-item-img {
  width:92px;
  height:92px;
  object-fit:cover;
  border-radius:16px;
  background:#f2f2f2;
  border:1px solid var(--line);
}
.cart-item-copy h3 {
  font-size:1.08rem;
  line-height:1.16;
  letter-spacing:-.01em;
  font-weight:950;
}
.cart-item-copy p {
  margin-top:5px;
  color:var(--muted);
  font-weight:850;
}
.cart-summary {
  position:sticky;
  top:116px;
  padding:26px;
}
.cart-summary h2 { margin-bottom:18px; }
.summary-row,
.summary-total {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.summary-row {
  padding:11px 0;
  color:var(--muted);
  border-bottom:1px solid var(--line);
}
.summary-row strong { color:var(--ink); }
.summary-total {
  padding-top:18px;
  margin-top:8px;
  font-size:1.24rem;
  font-weight:950;
}
.checkout-btn { width:100%; margin-top:22px; }
.empty-cart {
  text-align:center;
  padding:54px 24px;
}
.empty-cart p {
  max-width:520px;
  margin:10px auto 24px;
  color:var(--muted);
}

/* Newsletter / CTA */
.newsletter { display:grid; grid-template-columns:1fr auto; gap:18px; align-items:center; border:1px solid var(--line); background:var(--black); color:var(--white); border-radius:calc(var(--radius) + 8px); padding:clamp(26px,5vw,46px); box-shadow:var(--shadow); }
.newsletter h2 { font-size:clamp(1.9rem,4vw,3.4rem); line-height:.98; letter-spacing:-.05em; margin-bottom:8px; }
.newsletter p { color:rgba(255,255,255,.72); max-width:620px; }
.newsletter-form { display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.newsletter-form input { min-width:260px; border:1px solid rgba(255,255,255,.20); background:rgba(255,255,255,.10); color:var(--white); border-radius:999px; padding:15px 16px; outline:none; }
.newsletter-form input::placeholder { color:rgba(255,255,255,.58); }
.submit-card { margin-top:26px; display:grid; grid-template-columns:1fr auto; gap:18px; align-items:center; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); color:var(--ink); padding:26px; box-shadow:var(--shadow-soft); }
.submit-card p { color:var(--muted); margin-top:4px; }

/* Forms */
.form-card { margin-top:-62px; background:var(--white); padding:clamp(28px,5vw,50px); border-radius:var(--radius); box-shadow:var(--shadow); position:relative; z-index:10; }
.form-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.form-group { margin-bottom:22px; }
.form-group.full { grid-column:1/-1; }
.form-group label { display:block; margin-bottom:8px; font-weight:850; font-size:.95rem; color:#333; }
.form-group input, .form-group textarea, .form-group select { width:100%; padding:15px; border:2px solid #eee; border-radius:12px; font-size:1rem; background:#fbfbfb; font-family:inherit; transition:.2s; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline:none; border-color:var(--primary); background:#fff; }
.form-group textarea { min-height:160px; resize:vertical; }
.submit-btn { width:100%; background:var(--primary); color:white; padding:18px; border:none; border-radius:12px; font-size:1.1rem; font-weight:900; cursor:pointer; transition:background .2s, transform .1s; }
.submit-btn:hover { background:var(--primary-dark); transform:translateY(-1px); }
.help-card { background:var(--green-soft); border:1px solid rgba(0,0,0,.08); border-radius:var(--radius); padding:24px; margin-top:24px; }
.help-card ul { margin:12px 0 0 20px; color:var(--muted); }

/* Footer */
footer { margin-top:30px; background:#0e0e0e; color:rgba(255,255,255,.78); padding:48px 20px; text-align:center; }
.footer-links { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.footer-links a { padding:8px 12px; border-radius:999px; font-weight:750; }
.footer-links a:hover { color:var(--white); background:rgba(255,255,255,.10); }
.agency-link { color:var(--white); font-weight:900; }
.footer-note { margin-top:10px; font-size:.9rem; }

@media (max-width: 980px) {
  .hero-inner, .featured-card, .newsletter, .submit-card, .event-detail-hero, .event-detail-layout, .shop-hero, .shop-feature, .cart-wrapper { grid-template-columns: 1fr; }
  .hero { min-height:auto; }
  .hero-inner { padding:70px 0 100px; }
  .event-grid, .shop-product-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .quick-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .section-head, .status-line { align-items:flex-start; flex-direction:column; }
  .tools { grid-template-columns:1fr; }
  .filter-row { justify-content:flex-start; }
  .newsletter-form { justify-content:flex-start; }
  .event-detail-hero { align-items:start; }
  .cart-summary { position:static; }
}
@media (max-width: 700px) {
  .nav-inner { width:min(100% - 24px, var(--max)); gap:10px; min-height:76px; }
  .logo-img { height:72px; }
  .nav-menu { gap:2px; justify-content:flex-end; }
  .nav-link { padding:8px 9px; font-size:.82rem; }
  .btn-nav { padding:10px 11px; font-size:.82rem; }
  .nav-menu .optional { display:none; }
  .hero-inner, .container { width:min(100% - 28px, var(--max)); }
  .hero h1 { letter-spacing:-.055em; }
  .hero-buttons, .btn-primary, .btn-secondary, .btn-dark { width:100%; }
  .event-grid, .quick-grid, .form-grid, .shop-product-grid { grid-template-columns:1fr; }
  .featured-media { min-height:260px; }
  .tools { padding:10px; position:sticky; top:76px; z-index:90; border-radius:18px; }
  .filter-row { flex-wrap:nowrap; overflow-x:auto; justify-content:flex-start; padding-bottom:2px; scrollbar-width:none; }
  .filter-row::-webkit-scrollbar { display:none; }
  .filter-btn { flex:0 0 auto; padding:10px 12px; font-size:.88rem; }
  .newsletter-form input, .newsletter-form button { width:100%; min-width:0; }
  .event-card-head { flex-direction:column; }
  .price-pill { max-width:100%; }
  .event-detail-list { grid-template-columns:1fr; }
  .event-detail-hero { width:min(100% - 28px, var(--max)); padding:34px 0 8px; gap:22px; }
  .event-detail-panel { grid-template-columns:1fr; padding:12px; }
  .event-detail-notes { padding:22px; }
  .shop-hero { width:min(100% - 28px, var(--max)); padding:34px 0 12px; gap:22px; }
  .shop-feature { padding:12px; }
  .shop-feature img { aspect-ratio:16/10; }
  .cart-topline,
  .cart-header-row { align-items:flex-start; flex-direction:column; }
  .cart-item { grid-template-columns:74px minmax(0,1fr); }
  .cart-item-img { width:74px; height:74px; }
  .remove-cart-item { grid-column:2; justify-self:start; }
}

/* Ottawalist Chatbot */
.sr-only {
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.site-chatbot {
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:1200;
  font-family:inherit;
}
.chatbot-toggle {
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:0;
  border-radius:999px;
  background:var(--black);
  color:var(--white);
  padding:13px 17px 13px 13px;
  font-weight:950;
  box-shadow:0 18px 45px rgba(0,0,0,.22);
  cursor:pointer;
}
.chatbot-toggle:hover,
.chatbot-toggle[aria-expanded="true"] {
  background:var(--primary-dark);
  transform:translateY(-1px);
}
.chatbot-toggle span:first-child {
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
}
.chatbot-panel {
  position:absolute;
  right:0;
  bottom:64px;
  width:min(390px, calc(100vw - 32px));
  max-height:min(680px, calc(100vh - 112px));
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto auto;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.10);
  border-radius:22px;
  background:var(--surface);
  color:var(--ink);
  box-shadow:0 28px 90px rgba(0,0,0,.24);
}
.chatbot-panel[hidden] { display:none; }
.chatbot-header {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:18px;
  background:var(--black);
  color:var(--white);
}
.chatbot-header strong { display:block; font-size:1.05rem; line-height:1.1; }
.chatbot-header span { display:block; margin-top:4px; color:rgba(255,255,255,.70); font-size:.86rem; line-height:1.35; }
.chatbot-close {
  width:32px;
  height:32px;
  border:1px solid rgba(255,255,255,.20);
  border-radius:50%;
  background:rgba(255,255,255,.10);
  color:var(--white);
  font-weight:950;
  cursor:pointer;
}
.chatbot-messages {
  display:grid;
  align-content:start;
  gap:13px;
  min-height:280px;
  overflow:auto;
  padding:16px;
  background:#fbfaf8;
}
.chatbot-message { display:grid; gap:8px; }
.chatbot-message.is-user { justify-items:end; }
.chatbot-bubble {
  max-width:92%;
  border-radius:18px;
  padding:12px 14px;
  background:var(--white);
  border:1px solid var(--line);
  color:var(--ink-soft);
  font-size:.94rem;
  line-height:1.42;
  box-shadow:0 8px 22px rgba(0,0,0,.05);
}
.chatbot-message.is-user .chatbot-bubble {
  background:var(--primary);
  color:var(--white);
  border-color:var(--primary);
}
.chatbot-results { display:grid; gap:8px; }
.chatbot-result {
  display:grid;
  gap:3px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:var(--white);
  box-shadow:0 8px 22px rgba(0,0,0,.05);
}
.chatbot-result:hover { border-color:rgba(255,61,61,.32); transform:translateY(-1px); }
.chatbot-result strong { font-size:.96rem; line-height:1.18; }
.chatbot-result span { color:var(--primary-dark); font-size:.78rem; font-weight:900; }
.chatbot-result p { color:var(--muted); font-size:.86rem; line-height:1.35; }
.chatbot-prompts {
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:12px 14px;
  border-top:1px solid var(--line);
  background:var(--surface);
  scrollbar-width:none;
}
.chatbot-prompts::-webkit-scrollbar { display:none; }
.chatbot-prompts button {
  flex:0 0 auto;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
  color:var(--ink-soft);
  padding:8px 10px;
  font-size:.82rem;
  font-weight:850;
  cursor:pointer;
}
.chatbot-prompts button:hover { background:var(--black); border-color:var(--black); color:var(--white); }
.chatbot-form {
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  padding:14px;
  border-top:1px solid var(--line);
  background:var(--surface);
}
.chatbot-form input {
  min-width:0;
  border:1px solid var(--line);
  border-radius:999px;
  padding:12px 14px;
  outline:none;
  background:#fff;
  color:var(--ink);
}
.chatbot-form input:focus {
  border-color:rgba(255,61,61,.55);
  box-shadow:0 0 0 4px rgba(255,61,61,.10);
}
.chatbot-form button {
  border:0;
  border-radius:999px;
  background:var(--primary);
  color:var(--white);
  padding:12px 15px;
  font-weight:950;
  cursor:pointer;
}
.chatbot-form button:hover { background:var(--primary-dark); }
@media (max-width:700px) {
  .site-chatbot { right:14px; bottom:14px; }
  .chatbot-toggle { padding:12px 14px 12px 12px; }
  .chatbot-panel {
    right:-2px;
    bottom:62px;
    width:calc(100vw - 24px);
    max-height:calc(100vh - 96px);
    border-radius:18px;
  }
}
