/* Lambton Family Hub · Coastal Daylight design system (V55) */

:root{--teal:#0E97A8;--teal-dk:#0B7C8C;--rose:#FB6E97;--amber:#F4A623;
  --ink:#13233B;          /* deep lake navy · text + dark surfaces */
  --ink-2:#0E1B2E;        /* darker navy */
  --slate:#43536B;        /* secondary text */
  --paper:#FBF6EC;        /* warm sand */
  --surface:#FFFFFF;
  --mist:#EEF3F4;         /* cool pale */
  --line:#E7E0D4;         /* hairlines on light */
  --sunset:#FF6A45;       /* primary accent · sunset coral */
  --sunset-deep:#E9542F;
  --marigold:#FFB23E;     /* golden hour */
  --lake:#1FA3BE;         /* lake-sky cyan */
  --violet:#7C6CF0;       /* category pop */
  --green:#2BAE76;        /* category pop */
  --pink:#FF82A9;         /* category pop */
  --r-lg:26px; --r-md:18px; --r-sm:12px;
  --shadow:0 18px 50px -18px rgba(16,27,46,.30);
  --shadow-soft:0 10px 30px -12px rgba(16,27,46,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  color:var(--ink);
  background:var(--surface);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.display{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.04}
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase}

/* ---------------- HEADER ---------------- */
header{position:absolute;top:0;left:0;right:0;z-index:50}
.nav{display:flex;align-items:center;gap:2rem;height:84px}
.brand{display:flex;align-items:center;gap:.65rem;color:#fff}
.brand .mark{width:38px;height:38px;flex:none}
.brand .name{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.nav-links{display:flex;gap:2rem;margin-left:1rem}
.nav-links a{color:rgba(255,255,255,.82);font-weight:600;font-size:.97rem;transition:color .15s}
.nav-links a:hover{color:#fff}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:1.1rem}
.nav-ghost{color:#fff;font-weight:600;font-size:.97rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:'Hanken Grotesk';font-weight:700;border:none;cursor:pointer;border-radius:999px;transition:transform .14s ease, box-shadow .14s ease, background .14s ease}
.btn:focus-visible{outline:3px solid var(--marigold);outline-offset:2px}
.btn-sun{background:var(--sunset);color:#fff;padding:.72rem 1.3rem;box-shadow:0 10px 24px -8px rgba(255,106,69,.7)}
.btn-sun:hover{background:var(--sunset-deep);transform:translateY(-1px)}

/* ---------------- HERO ---------------- */
.hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:140px 0 90px}
.hero::before{ /* sunset glow on the horizon */
  content:"";position:absolute;left:50%;bottom:-300px;transform:translateX(-50%);
  width:1500px;height:720px;border-radius:50%;
  background:radial-gradient(ellipse 60% 100% at 50% 100%,rgba(255,176,70,.52) 0%,rgba(255,106,69,.36) 38%,rgba(255,106,69,.10) 60%,transparent 74%);
  filter:blur(4px);pointer-events:none;
}
.hero::after{ /* faint horizon line */
  content:"";position:absolute;left:0;right:0;bottom:150px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),transparent);
}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero-eyebrow{color:var(--marigold);margin-bottom:1.1rem;display:flex;align-items:center;gap:.6rem}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--marigold)}
.hero h1{font-size:clamp(2.7rem,5vw,4.05rem);margin-bottom:1.25rem}
.hero h1 .glow{color:var(--marigold)}
.hero p.lede{font-size:1.18rem;color:rgba(255,255,255,.8);max-width:30em;margin-bottom:2rem}

/* search */
.searchbar{background:#fff;border-radius:18px;padding:7px;display:flex;align-items:stretch;box-shadow:var(--shadow);max-width:560px}
.search-field{flex:1;display:flex;flex-direction:column;justify-content:center;padding:.55rem .95rem;min-width:0}
.search-field + .search-field{border-left:1px solid var(--line)}
.search-field label{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#9AA0A6}
.search-field .val{font-weight:600;color:var(--ink);font-size:.96rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-field .val.placeholder{color:#9AA0A6;font-weight:500}
.search-go{flex:none;width:50px;border-radius:13px;background:var(--ink);color:#fff;display:grid;place-items:center;margin-left:4px}
.search-go svg{width:20px;height:20px}
.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.4rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.42rem .9rem;border-radius:999px;font-size:.86rem;font-weight:600;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);transition:background .15s}
.chip:hover{background:rgba(255,255,255,.2)}
.chip .d{width:7px;height:7px;border-radius:50%}

/* hero floating cards */
.hero-cards{position:relative;height:470px}
.fc{position:absolute;width:284px;background:#fff;color:var(--ink);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow)}
.fc .thumb{height:140px;position:relative}
.fc .tag{position:absolute;top:12px;left:12px;background:rgba(19,35,59,.9);color:#fff;font-size:.72rem;font-weight:700;padding:.28rem .65rem;border-radius:999px;letter-spacing:.02em}
.fc .body{padding:.95rem 1.05rem 1.1rem}
.fc .when{font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--sunset-deep)}
.fc .title{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.1rem;line-height:1.18;margin:.2rem 0 .35rem}
.fc .where{font-size:.85rem;color:var(--slate);display:flex;align-items:center;gap:.35rem}
.fc-1{top:0;right:6px;transform:rotate(2deg);z-index:2}
.fc-2{bottom:0;left:0;transform:rotate(-2deg);z-index:3}
.fc-mini{position:absolute;right:18px;bottom:26px;background:#fff;color:var(--ink);border-radius:14px;padding:.7rem .95rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.7rem;z-index:4}
.fc-mini .ic{width:38px;height:38px;border-radius:11px;background:var(--marigold);display:grid;place-items:center;flex:none;font-size:1.15rem}
.fc-mini b{font-family:'Bricolage Grotesque';font-size:1.35rem;display:block;line-height:1}
.fc-mini span{font-size:.74rem;color:var(--slate);font-weight:600}

/* thumb gradients (stand in for photography) */
.g-markets{background:linear-gradient(135deg,#FFC65C,#FF8A3D)}
.g-music{background:linear-gradient(135deg,#8E7BFF,#5B49C9)}
.g-outdoors{background:linear-gradient(135deg,#34C281,#16906F)}
.g-arts{background:linear-gradient(135deg,#FF7E63,#E94C5B)}
.g-sports{background:linear-gradient(135deg,#2FB6D1,#1577A6)}
.g-community{background:linear-gradient(135deg,#FFB199,#FF6A88)}
.g-little{background:linear-gradient(135deg,#FF9CC2,#FF6FA3)}

/* ---------------- CATEGORY BROWSE ---------------- */
.section{padding:84px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2.2rem}
.sec-head .eyebrow{color:var(--sunset);margin-bottom:.5rem}
.sec-head h2{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.8rem,3vw,2.5rem);letter-spacing:-.02em;line-height:1.05}
.sec-head .link{font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}
.sec-head .link:hover{color:var(--sunset)}

.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.cat{position:relative;border-radius:var(--r-md);padding:1.1rem 1rem 1.15rem;color:#fff;overflow:hidden;min-height:118px;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .16s ease, box-shadow .16s ease}
.cat:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.cat .ico{position:absolute;top:.9rem;left:1rem;font-size:1.3rem}
.cat .n{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.02rem}
.cat .c{font-size:.78rem;opacity:.85;font-weight:600}

/* ---------------- THIS WEEKEND ---------------- */
.weekend{background:var(--paper)}
.rail{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ecard{background:#fff;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .16s ease, box-shadow .16s ease;cursor:pointer}
.ecard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ecard .thumb{height:172px;position:relative}
.ecard .cat-tag{position:absolute;top:13px;left:13px;background:#fff;color:var(--ink);font-size:.72rem;font-weight:700;padding:.3rem .7rem;border-radius:999px;display:flex;align-items:center;gap:.35rem}
.ecard .cat-tag .d{width:7px;height:7px;border-radius:50%}
.ecard .free{position:absolute;top:13px;right:13px;background:var(--green);color:#fff;font-size:.72rem;font-weight:800;padding:.3rem .65rem;border-radius:999px}
.ecard .body{padding:1.15rem 1.25rem 1.35rem}
.ecard .when{color:var(--sunset-deep);font-weight:700;font-size:.82rem;letter-spacing:.03em;text-transform:uppercase;margin-bottom:.3rem}
.ecard h3{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.28rem;line-height:1.16;letter-spacing:-.01em;margin-bottom:.5rem}
.ecard .where{color:var(--slate);font-size:.92rem;display:flex;align-items:center;gap:.4rem}
.ecard .where svg{width:15px;height:15px;flex:none;color:var(--sunset)}

/* ---------------- UPCOMING (list) ---------------- */
.day-label{display:flex;align-items:center;gap:.9rem;margin:0 0 1.1rem;font-weight:700}
.day-label .d{font-family:'Bricolage Grotesque';font-size:1.05rem;color:var(--ink)}
.day-label .c{font-size:.8rem;font-weight:700;color:var(--slate);letter-spacing:.03em;text-transform:uppercase}
.day-label .rule{flex:1;height:1px;background:var(--line)}
.up-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:2.4rem}
.row{display:flex;gap:1.1rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:.9rem 1.1rem;transition:border-color .15s, box-shadow .15s;cursor:pointer}
.row:hover{border-color:transparent;box-shadow:var(--shadow-soft)}
.date-chip{flex:none;width:60px;height:60px;border-radius:14px;background:var(--mist);display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}
.date-chip .dd{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.5rem;color:var(--ink)}
.date-chip .mm{font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);margin-top:2px}
.row .info{min-width:0}
.row .k{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:.35rem;margin-bottom:.15rem}
.row .k .d{width:7px;height:7px;border-radius:50%}
.row .t{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.06rem;line-height:1.2;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .w{font-size:.86rem;color:var(--slate);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .cost{margin-left:auto;flex:none;font-weight:800;font-size:.84rem;color:var(--green)}
.row .cost.paid{color:var(--ink)}
.more-btn{display:block;margin:2.6rem auto 0;background:var(--ink);color:#fff;padding:.9rem 2rem;border-radius:999px;font-weight:700}
.more-btn:hover{background:var(--ink-2)}

/* ---------------- TRUST ---------------- */
.trust{padding:46px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;justify-content:center}
.trust .lbl{font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate)}
.trust .logos{display:flex;gap:2.4rem;align-items:center;flex-wrap:wrap;justify-content:center}
.trust .logos span{font-weight:800;font-size:1.05rem;color:#9AA4B0;letter-spacing:.01em}

/* ---------------- NEWSLETTER ---------------- */
.news{position:relative;overflow:hidden;background:var(--ink);color:#fff;margin:0 28px;border-radius:34px}
.news::before{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,106,69,.5),transparent 65%)}
.news::after{content:"";position:absolute;left:-100px;bottom:-160px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,178,62,.4),transparent 65%)}
.news-inner{position:relative;z-index:2;padding:64px 8%;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.news .eyebrow{color:var(--marigold);margin-bottom:.9rem}
.news h2{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.9rem,3.2vw,2.7rem);letter-spacing:-.02em;line-height:1.05;margin-bottom:.7rem}
.news p{color:rgba(255,255,255,.78);font-size:1.05rem}
.news-form{display:flex;gap:.6rem;background:#fff;padding:7px;border-radius:16px;box-shadow:var(--shadow)}
.news-form input{flex:1;border:none;outline:none;padding:.7rem 1rem;font-family:inherit;font-size:1rem;color:var(--ink);background:transparent;min-width:0}
.news-note{margin-top:.85rem;font-size:.82rem;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:.45rem}

/* ---------------- FOOTER ---------------- */
footer{background:var(--ink-2);color:#fff;padding:72px 0 34px;margin-top:84px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .name{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.4rem;display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem}
.foot-brand p{color:rgba(255,255,255,.6);max-width:24em;font-size:.95rem}
.fcol h4{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--marigold);margin-bottom:1rem;font-weight:700}
.fcol a{display:block;color:rgba(255,255,255,.74);padding:.3rem 0;font-size:.95rem;transition:color .15s}
.fcol a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;gap:1rem;flex-wrap:wrap}
.foot-bottom p{color:rgba(255,255,255,.5);font-size:.85rem}
.foot-social{display:flex;gap:.7rem}
.foot-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:background .15s}
.foot-social a:hover{background:var(--sunset)}
.foot-social svg{width:18px;height:18px}

/* ---------------- PREMIER SPONSORS ---------------- */
.premier{background:var(--paper);padding:40px 0;text-align:center;border-bottom:1px solid var(--line)}
.premier .eyebrow{color:var(--sunset);margin-bottom:1.2rem;display:inline-flex;align-items:center;gap:.6rem}
.premier .eyebrow::before,.premier .eyebrow::after{content:"";width:26px;height:1px;background:#D8C7A8}
.premier-logos{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.psp{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1rem 2.2rem;min-width:212px;min-height:88px;display:grid;place-items:center;box-shadow:var(--shadow-soft)}
.psp .wm{font-weight:800;font-size:1.08rem;color:var(--ink);letter-spacing:.01em;line-height:1.1;text-align:center}
.psp .wm small{display:block;font-size:.7rem;font-weight:600;color:var(--slate);letter-spacing:.02em;margin-top:3px}
.psp.open{border-style:dashed;border-color:#D8C7A8;background:transparent;box-shadow:none;color:var(--sunset-deep);font-weight:700;cursor:pointer}

/* ---------------- COMMUNITY PARTNERS ---------------- */
.partners{padding:84px 0;background:#fff}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pcard{display:flex;align-items:center;gap:1rem;background:var(--paper);border-radius:var(--r-md);padding:1.1rem 1.25rem}
.pcard .av{width:50px;height:50px;border-radius:14px;flex:none;display:grid;place-items:center;color:#fff;font-weight:800;font-family:'Bricolage Grotesque';font-size:1.05rem}
.pcard .pn{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.02rem;color:var(--ink);line-height:1.15}
.pcard .pb{font-size:.85rem;color:var(--slate);margin-top:1px}
.partners-cta{margin-top:1.7rem;display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap;text-align:center}
.partners-cta span{color:var(--slate);font-weight:600}
.partners-cta a{font-weight:700;color:var(--sunset-deep);display:inline-flex;align-items:center;gap:.35rem}
.partners-cta a:hover{color:var(--sunset)}

/* featured event card */
.ecard.featured{outline:2px solid var(--sunset)}
.ecard .feat{position:absolute;top:13px;right:13px;background:var(--sunset);color:#fff;font-size:.72rem;font-weight:800;padding:.3rem .7rem;border-radius:999px;display:inline-flex;align-items:center;gap:.3rem;box-shadow:0 6px 14px -4px rgba(255,106,69,.7)}

/* ---------------- RESPONSIVE ---------------- */
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
  .hero-cards{height:380px;max-width:380px}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .rail{grid-template-columns:1fr 1fr}
  .pgrid{grid-template-columns:1fr}
  .news-inner{grid-template-columns:1fr;gap:28px;padding:48px 7%}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:680px){
  .wrap{padding:0 18px}
  .nav-links,.nav-ghost{display:none}
  .hero{padding:118px 0 70px}
  .hero h1{font-size:2.5rem}
  .searchbar{flex-wrap:wrap;max-width:none}
  .search-field{flex:1 1 40%}
  .search-field + .search-field{border-left:none}
  .hero-cards{display:none}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .rail{grid-template-columns:1fr}
  .up-grid{grid-template-columns:1fr}
  .news{margin:0 14px;border-radius:26px}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* rose woven through page as secondary accent */
.ecard.featured{outline-color:#FB6E97 !important}
.ecard .feat{background:#FB6E97 !important;box-shadow:0 6px 14px -4px rgba(251,110,151,.6)!important}
.partners-cta a{color:#EE4E7E !important}
.news .eyebrow{color:#FF9FBE !important}
.day-label .d{color:var(--ink)!important}

/* ===== layer ===== */
:root{
  --ink:#142A44; --ink-2:#102338; --paper:#FFFFFF;
  --sunset:#FF6A4A; --sunset-deep:#E8542F; --marigold:#F4A623; --lake:#00A3B4; --violet:#6C5CE0;
}
.hero{background:linear-gradient(180deg,#FFF6E9 0%,#EAF3F1 100%)!important;color:var(--ink)}
.hero::before{background:radial-gradient(ellipse 60% 100% at 50% 100%,rgba(255,176,70,.40) 0%,rgba(255,106,69,.18) 44%,transparent 72%)!important;filter:blur(2px)}
.hero::after{background:linear-gradient(90deg,transparent,rgba(20,42,68,.12),transparent)!important}
.hero h1{color:var(--ink)!important}
.hero h1 .glow{color:var(--sunset-deep)!important}
.hero p.lede{color:var(--slate)!important}
.hero-eyebrow{color:var(--sunset-deep)!important}
.hero-eyebrow .dot{background:var(--sunset-deep)!important}
.nav-links a{color:rgba(20,42,68,.78)!important}
.nav-links a:hover{color:var(--ink)!important}
.brand{color:var(--ink)!important}
.nav-ghost{color:var(--ink)!important}
.chip{color:var(--ink)!important;background:#fff!important;border-color:var(--line)!important;box-shadow:0 2px 8px -4px rgba(20,42,68,.25)}
.chip:hover{background:var(--mist)!important}
.search-go{background:var(--ink)!important}
.fc-1 .thumb{background:linear-gradient(135deg,#FFB347,#FF7A3D)!important}
.fc-2 .thumb{background:linear-gradient(135deg,#2BC4D4,#0E92A4)!important}

/* ===== layer ===== */
:root{ --sunset:#0E9AAE; --sunset-deep:#0B8294; --lake:#0E9AAE; }
.hero-eyebrow{color:#E8497A !important}
.hero-eyebrow .dot{background:#FB5A86 !important}
.search-go{background:#0B8294 !important}
.fc-mini .ic{background:#FB5A86 !important}
.fc-1 .thumb{background:linear-gradient(135deg,#34C9D6,#0E92A4)!important}
.fc-2 .thumb{background:linear-gradient(135deg,#FF7FA6,#F1497B)!important}

/* ===== layer ===== */
/* Newsletter -> teal brand band (pop without going dark) */
.news{background:var(--teal,#0E97A8)!important}
.news::before{background:radial-gradient(circle,rgba(251,110,151,.55),transparent 65%)!important}
.news::after{background:radial-gradient(circle,rgba(244,166,35,.45),transparent 65%)!important}
/* Footer -> light cream */
footer{background:#F5F0E5!important;color:#142A44!important}
.foot-brand .name{color:#142A44!important}
.foot-brand p{color:#5b6b7e!important}
.fcol h4{color:#0B7C8C!important}
.fcol a{color:#43536B!important}
.fcol a:hover{color:#142A44!important}
.foot-top{border-bottom-color:rgba(20,42,68,.14)!important}
.foot-bottom{border-top-color:rgba(20,42,68,.12)!important}
.foot-bottom p{color:#8a93a0!important}
.foot-social a{background:#0E97A8!important}

/* ===== layer ===== */
.brand .mark{height:50px !important;width:auto !important;flex:none}
.foot-brand .name .mark{height:42px !important;width:auto !important}

/* ===== live build additions (forms, image cards, states) ===== */
.search-field input,
.search-field select{
  border:none;background:transparent;font-family:inherit;font-weight:600;
  color:var(--ink);font-size:.96rem;width:100%;outline:none;padding:0;
}
.search-field select{cursor:pointer;-webkit-appearance:none;appearance:none}
.search-field input::placeholder{color:#9AA0A6;font-weight:500}
.ecard .thumb{background-size:cover;background-position:center;background-repeat:no-repeat}
.fc .thumb{background-size:cover;background-position:center;background-repeat:no-repeat}
.ph-icon{font-size:3rem;opacity:.48;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);filter:grayscale(.15)}
.feed-loading,.feed-empty{color:var(--slate);padding:1.6rem 0;font-weight:600}
.ecard{cursor:pointer;text-decoration:none;color:inherit;display:block}
.cat .c:empty{display:none}
.news-note.ok{color:#9FE6C7}
.news-note.err{color:#FFC2D2}


/* ===== white-space rhythm: trust strip, tinted band, wave seam ===== */
.trust-strip{background:#EAF3F2;border-top:1px solid #E7E0D4;border-bottom:1px solid #E7E0D4}
.trust-strip .wrap{display:flex;justify-content:center;align-items:center;gap:2.6rem;flex-wrap:wrap;padding:17px 0}
.trust-item{display:flex;align-items:center;gap:.55rem;font-weight:700;color:#3F5168;font-size:.96rem}
.trust-item svg{width:18px;height:18px;color:#0E97A8;flex:none}
@media(max-width:640px){.trust-strip .wrap{gap:1.1rem}.trust-item{font-size:.82rem}}

.partners.tinted{background:#F6F0E4}
.wave-sep{display:block;width:100%;height:54px;line-height:0;margin-bottom:-1px}
.wave-sep svg{display:block;width:100%;height:100%}


/* ===== lift + category colour edge on feed rows ===== */
.row{
  border:1px solid #ECE6DA;
  border-left:5px solid var(--cat,#0E97A8);
  box-shadow:0 10px 26px -16px rgba(16,27,46,.26);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.row:hover{
  border-color:#ECE6DA;
  border-left-color:var(--cat,#0E97A8);
  transform:translateY(-2px);
  box-shadow:0 18px 36px -16px rgba(16,27,46,.36);
}
.up-grid{gap:16px}


/* ===== listing + filter bar (All events / Camps) ===== */
.page-head{padding:118px 0 30px;background:linear-gradient(120deg,#FFE7CE 0%,#FDF3E4 44%,#E3F1EE 100%)}
.page-head .accent-bar{height:5px;width:104px;border-radius:999px;margin-top:1.15rem;background:linear-gradient(90deg,#0E97A8,#F4A623,#FB6E97)}
.page-head .eyebrow{color:#EE4E7E;margin-bottom:.5rem}
.page-head h1{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.2rem,4vw,3rem);letter-spacing:-.02em;color:var(--ink);line-height:1.04}
.page-head .page-sub{color:var(--slate);font-size:1.12rem;margin-top:.55rem;max-width:60ch}
.filterbar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:13px 0}
.fb-inner{display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.fb-search{flex:1;min-width:220px;display:flex;align-items:center;gap:.55rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.62rem .9rem}
.fb-search svg{width:17px;height:17px;color:var(--slate);flex:none}
.fb-search input{border:none;outline:none;font-family:inherit;font-size:.95rem;width:100%;color:var(--ink);background:transparent}
.fb-sel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:.6rem .9rem;font-family:inherit;font-weight:600;font-size:.92rem;color:var(--ink);cursor:pointer}
.fb-free{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.6rem 1rem;font-weight:600;font-size:.92rem;color:var(--ink);cursor:pointer;user-select:none}
.fb-free .dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--slate);background:transparent}
.fb-free.on{border-color:var(--teal);color:#0B7C8C;background:#E9F6F7}
.fb-free.on .dot{background:var(--teal);border-color:var(--teal)}
.fb-count{margin-left:auto;color:var(--slate);font-weight:700;font-size:.9rem;white-space:nowrap}
.results{padding:42px 0 20px}
@media(max-width:680px){.fb-count{display:none}.fb-search{min-width:100%}}

.page-head h1 .glow{color:#0E97A8}


/* ===== forms (Submit) ===== */
.formwrap{max-width:760px;margin:0 auto;padding:38px 0 20px}
.frow{margin-bottom:1.35rem}
.flabel{display:block;font-weight:700;color:var(--ink);margin-bottom:.4rem;font-size:.96rem}
.fhint{color:var(--slate);font-size:.84rem;font-weight:500;margin-top:.25rem}
.finput,.ftext,.fselect{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:12px;padding:.78rem .95rem;outline:none;transition:border-color .15s, box-shadow .15s}
.finput:focus,.ftext:focus,.fselect:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,151,168,.15)}
.ftext{min-height:120px;resize:vertical}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:560px){.f2{grid-template-columns:1fr}}
.catgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
@media(max-width:560px){.catgrid{grid-template-columns:1fr 1fr}}
.catchk{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:10px;padding:.55rem .7rem;cursor:pointer;font-weight:600;font-size:.9rem}
.catchk input{accent-color:var(--teal);width:16px;height:16px;flex:none}
.ftoggle{display:flex;align-items:center;gap:.6rem;font-weight:700;cursor:pointer;color:var(--ink)}
.ftoggle input{width:18px;height:18px;accent-color:var(--teal)}
.filebtn{display:inline-flex;align-items:center;gap:.5rem;background:#EAF3F2;border:1px solid var(--line);border-radius:10px;padding:.6rem 1rem;font-weight:700;cursor:pointer;color:#0B7C8C}
.filebtn input{display:none}
#posterName{color:var(--slate);font-size:.88rem;margin-left:.6rem}
.submit-note{margin:0 0 1rem;font-weight:700}
.submit-note.err{color:#C2334D}
.formactions{margin-top:1.7rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.fsection-title{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.12rem;color:var(--ink);margin:2rem 0 1rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.success-box{max-width:620px;margin:46px auto;text-align:center;background:#fff;border:1px solid var(--line);border-radius:20px;padding:3rem 2rem;box-shadow:0 16px 40px -20px rgba(16,27,46,.3)}
.success-box .em{font-size:2.6rem}
.success-box .big{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.9rem;color:var(--ink);margin:.6rem 0}
.success-box p{color:var(--slate);font-size:1.05rem;line-height:1.6;margin-bottom:1.4rem}

/* ===== content pages (advertise / newsletter / canada day / 404) ===== */
.prose{max-width:760px;margin:0 auto;padding:40px 0}
.prose p{color:#3f5168;font-size:1.08rem;line-height:1.7;margin-bottom:1.1rem}
.prose h2{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.6rem;color:var(--ink);margin:2rem 0 .9rem}
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:1.6rem 0}
@media(max-width:760px){.tier-grid{grid-template-columns:1fr}}
.tier{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.6rem;box-shadow:0 12px 30px -18px rgba(16,27,46,.26);border-top:5px solid var(--cat,#0E97A8)}
.tier h3{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.2rem;color:var(--ink);margin-bottom:.3rem}
.tier .price{font-weight:800;color:#0B7C8C;font-size:1.3rem;margin-bottom:.8rem}
.tier ul{list-style:none;color:#51617A;font-size:.94rem;line-height:1.7}
.tier li{padding-left:1.3rem;position:relative}
.tier li::before{content:"\2713";position:absolute;left:0;color:var(--teal);font-weight:800}
.bigcta{display:inline-flex;align-items:center;gap:.5rem;background:var(--sunset);color:#fff;font-weight:800;padding:.95rem 1.7rem;border-radius:999px;text-decoration:none;box-shadow:0 12px 28px -10px rgba(14,151,168,.6);font-size:1.05rem}
.bigcta:hover{background:var(--sunset-deep)}
.center{text-align:center}
.notfound{max-width:620px;margin:40px auto;text-align:center;padding:30px 0}
.notfound .code{font-family:'Bricolage Grotesque';font-weight:800;font-size:5rem;color:var(--teal);line-height:1}

/* ===== mobile polish fixes (V55) ===== */
html,body{max-width:100%;overflow-x:hidden}
.brand,.btn,.chip,.cat,.ecard,.row,.pcard,.tier,.news-form{min-width:0}
.brand .name,.foot-brand .name,.fcol a,.partners-cta,.page-head h1,.hero h1,.ecard h3,.row .t{overflow-wrap:anywhere}

@media(max-width:680px){
  header{position:absolute}
  .wrap{padding-left:18px;padding-right:18px}
  .nav{
    height:auto;
    min-height:92px;
    align-items:center;
    flex-wrap:wrap;
    gap:.55rem .75rem;
    padding-top:12px;
    padding-bottom:10px;
  }
  .brand{flex:0 0 auto;gap:.48rem}
  .brand .mark{height:42px!important;width:auto!important}
  .brand .name{display:none}
  .nav-right{margin-left:0;flex:none}
  .nav-right .btn{padding:.62rem .86rem;font-size:0;white-space:nowrap}
  .nav-right .btn::after{content:"Submit";font-size:.9rem}
  .nav-links{
    order:3;
    display:flex!important;
    width:100%;
    margin:0;
    gap:.45rem;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:.1rem 0 .2rem;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{
    flex:0 0 auto;
    color:var(--ink)!important;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(20,42,68,.12);
    border-radius:999px;
    padding:.42rem .72rem;
    font-size:.84rem;
    box-shadow:0 6px 16px -14px rgba(16,27,46,.5);
  }

  .hero{padding:148px 0 58px}
  .hero h1{font-size:clamp(1.88rem,7.8vw,2.08rem);line-height:1.1}
  .hero p.lede{font-size:1.05rem;margin-bottom:1.4rem}
  .searchbar{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:7px;
    border-radius:16px;
    padding:7px;
  }
  .search-field{
    flex:none;
    min-width:0;
    background:#F8FAFA;
    border:1px solid #EAF0EE;
    border-radius:12px;
    padding:.62rem .75rem;
  }
  .search-field:first-child{grid-column:1/-1}
  .search-field + .search-field{border-left:1px solid #EAF0EE}
  .search-go{
    grid-column:1/-1;
    width:100%;
    height:46px;
    margin-left:0;
    border-radius:12px;
  }

  .page-head{padding:148px 0 28px}
  .page-head h1{font-size:clamp(2rem,9vw,2.45rem)}
  .page-head .page-sub{font-size:1.02rem;max-width:32ch}
  .sec-head{align-items:flex-start;gap:1rem;margin-bottom:1.45rem}
  .sec-head .link{font-size:.95rem}
  .section,.partners{padding:58px 0}
  footer{margin-top:58px;padding:54px 0 30px}

  .fb-inner{gap:8px}
  .fb-search{min-width:100%;padding:.68rem .8rem}
  .fb-sel,.fb-free{
    flex:1 1 calc(50% - 4px);
    min-width:0;
    max-width:100%;
    padding:.62rem .72rem;
    font-size:.88rem;
  }

  .row{
    display:grid;
    grid-template-columns:54px minmax(0,1fr) auto;
    align-items:start;
    gap:.75rem;
    padding:.82rem .9rem;
  }
  .date-chip{width:54px;height:54px;border-radius:13px}
  .date-chip .dd{font-size:1.35rem}
  .row .cost{margin-left:0;font-size:.78rem;line-height:1.2;white-space:nowrap}
  .row .k{font-size:.68rem;white-space:normal}
  .row .t{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .row .w{white-space:normal;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}

  .ecard .thumb{height:156px}
  .ecard .cat-tag{max-width:calc(100% - 30px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ecard .feat,.ecard .free{font-size:.68rem;padding:.28rem .58rem}
  .pcard{align-items:flex-start;padding:1rem}

  .news{margin:0 12px;border-radius:22px}
  .news-inner{padding:38px 22px}
  .news-form{flex-direction:column;gap:7px}
  .news-form .btn{width:100%;min-height:44px}
  .news-note{align-items:flex-start;line-height:1.35}

  .formwrap,.prose{width:min(100% - 36px,760px)}
  .catgrid{grid-template-columns:1fr 1fr}
  .catchk{padding:.58rem .62rem;font-size:.86rem}
  .filebtn{width:100%;justify-content:center}
  #posterName{display:block;margin:.55rem 0 0}

  .foot-top{grid-template-columns:1fr 1fr;gap:26px 22px}
  .foot-bottom{align-items:flex-start}
}

@media(max-width:480px){
  .brand .mark{height:36px!important}
  .brand .name{display:none}
  .nav{gap:.5rem .55rem}
  .nav-right .btn{padding:.56rem .64rem;font-size:0}
  .nav-right .btn::after{font-size:.82rem}
  .hero{padding-top:142px}
  .hero h1{font-size:1.9rem;line-height:1.1}
  .foot-top{grid-template-columns:1fr}
  .foot-brand{grid-column:auto}
  .foot-brand p{max-width:none}
  .bigcta{display:flex;width:100%;justify-content:center;text-align:center;padding:.86rem 1rem}
  .tier{padding:1.25rem}
  .success-box{padding:2rem 1.2rem}
  .success-box .big{font-size:1.55rem}
}

@media(max-width:360px){
  .wrap{padding-left:14px;padding-right:14px}
  .brand .name{font-size:.94rem}
  .nav-right .btn{padding:.58rem .68rem;font-size:.84rem}
  .fb-sel,.fb-free{flex-basis:100%}
  .row{grid-template-columns:50px minmax(0,1fr);position:relative;padding-right:.9rem}
  .row .cost{grid-column:2;justify-self:start;margin-top:.15rem}
  .date-chip{width:50px;height:50px}
  .catgrid{grid-template-columns:1fr}
}

/* ===== requested desktop + mobile improvements ===== */
.menu-toggle{display:none}
.mobile-submit-link{display:none!important}
.nav-links a.active{
  color:var(--ink)!important;
  position:relative;
}
.nav-links a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-10px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,#0E97A8,#FB6E97);
}

.premier-logos{
  display:grid;
  grid-template-columns:repeat(3,minmax(220px,260px));
  justify-content:center;
  align-items:stretch;
  gap:18px;
}
.psp{
  min-width:0;
  min-height:104px;
  padding:1rem 1.35rem;
  border-radius:14px;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.psp img{
  width:100%;
  max-width:190px!important;
  max-height:58px!important;
  object-fit:contain;
}
.psp:hover,.psp:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(14,151,168,.35);
  box-shadow:0 18px 42px -22px rgba(16,27,46,.34);
}
.psp.open{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:#FFF8EC;
}

.fb-sel:hover,.fb-free:hover,.fb-search:focus-within,
.finput:hover,.ftext:hover,.fselect:hover{
  border-color:rgba(14,151,168,.45);
}
.fb-sel:focus-visible,.fb-free:focus-visible,.pcard:focus-visible,.psp:focus-visible{
  outline:3px solid rgba(244,166,35,.55);
  outline-offset:2px;
}
.pcard{
  border:1px solid transparent;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.pcard:hover,.pcard:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(14,151,168,.22);
  background:#fff;
  box-shadow:0 16px 34px -22px rgba(16,27,46,.38);
}

.feed-loading{
  position:relative;
  min-height:206px;
  font-size:0;
  padding:0;
}
.feed-loading::before{
  content:"";
  display:block;
  height:206px;
  border-radius:18px;
  background:
    linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent) -220px 0/220px 100% no-repeat,
    linear-gradient(#fff,#fff) 0 0/100% 62px no-repeat,
    linear-gradient(#fff,#fff) 0 72px/100% 62px no-repeat,
    linear-gradient(#fff,#fff) 0 144px/100% 62px no-repeat,
    #F3F6F5;
  border:1px solid #ECE6DA;
  animation:skeleton-sweep 1.35s ease-in-out infinite;
  box-shadow:0 12px 30px -24px rgba(16,27,46,.3);
}
@keyframes skeleton-sweep{to{background-position:calc(100% + 220px) 0,0 0,0 72px,0 144px,0 0}}

.filter-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  border-radius:12px;
  padding:.64rem .9rem;
  font:700 .9rem 'Hanken Grotesk',system-ui,sans-serif;
  cursor:pointer;
}
.filter-toggle::after{
  content:"+";
  margin-left:.45rem;
  color:#0B7C8C;
  font-weight:800;
}
.filter-toggle[aria-expanded="true"]::after{content:"-"}

.ad-lead{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:28px;
  align-items:start;
  margin-bottom:2.2rem;
}
.ad-lead p{margin-bottom:0}
.ad-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.ad-stat{
  background:#F6F0E4;
  border:1px solid var(--line);
  border-radius:14px;
  padding:1rem;
}
.ad-stat b{
  display:block;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:1.55rem;
  line-height:1;
  color:#0B7C8C;
}
.ad-stat span{display:block;color:var(--slate);font-weight:700;font-size:.82rem;margin-top:.35rem}
.tier.featured-tier{
  position:relative;
  transform:translateY(-8px);
  box-shadow:0 22px 48px -28px rgba(16,27,46,.45);
}
.tier .badge{
  display:inline-flex;
  margin-bottom:.7rem;
  color:#fff;
  background:#FB6E97;
  border-radius:999px;
  padding:.22rem .62rem;
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.ad-cta-panel{
  margin-top:2.2rem;
  padding:1.35rem;
  border:1px solid rgba(14,151,168,.22);
  border-radius:18px;
  background:linear-gradient(120deg,#E9F6F7,#FFF8EC);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.ad-cta-panel p{margin:0;color:var(--slate);font-size:1rem}

@media(max-width:980px){
  .premier-logos{grid-template-columns:repeat(2,minmax(220px,260px))}
  .ad-lead{grid-template-columns:1fr}
}

@media(max-width:680px){
  .nav{min-height:78px;position:relative}
  .nav{justify-content:space-between}
  .brand{order:1}
  .nav-right{display:none}
  .menu-toggle{
    order:2;
    margin-left:0;
    position:absolute;
    top:18px;
    right:18px;
    display:grid;
    width:44px;
    height:44px;
    place-items:center;
    border:1px solid rgba(20,42,68,.13);
    border-radius:999px;
    background:#fff;
    box-shadow:0 10px 22px -16px rgba(16,27,46,.45);
  }
  .menu-toggle span{
    display:block;
    width:18px;
    height:2px;
    margin:2px 0;
    border-radius:999px;
    background:var(--ink);
  }
  .nav-links{
    order:4;
    display:none!important;
    overflow:visible;
    padding:.55rem 0 0;
  }
  .nav-links a.active::after{display:none}
  body.nav-open .nav-links{
    display:grid!important;
    grid-template-columns:1fr 1fr;
    gap:.5rem;
  }
  body.nav-open .mobile-submit-link{display:flex!important}
  body.nav-open .nav-links a{
    justify-content:center;
    text-align:center;
    white-space:normal;
  }
  body.nav-open .menu-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  body.nav-open .menu-toggle span:nth-child(2){opacity:0}
  body.nav-open .menu-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .hero,.page-head{padding-top:128px}

  .filter-toggle{display:inline-flex;flex:0 0 auto}
  .fb-search{flex:1 1 calc(100% - 106px);min-width:0!important}
  .filterbar:not(.filters-open) .fb-sel,
  .filterbar:not(.filters-open) .fb-free,
  .filterbar:not(.filters-open) .fb-count{display:none}
  .filterbar.filters-open .fb-sel,
  .filterbar.filters-open .fb-free{display:inline-flex}

  .formactions{
    position:sticky;
    bottom:0;
    z-index:30;
    margin-left:-18px;
    margin-right:-18px;
    padding:12px 18px calc(12px + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.94);
    border-top:1px solid var(--line);
    backdrop-filter:blur(12px);
    box-shadow:0 -14px 32px -28px rgba(16,27,46,.5);
  }
  .formactions .btn{width:100%;min-height:46px}
  .formactions .fhint{display:none}

  .premier-logos{grid-template-columns:minmax(0,224px)}
  .psp{min-height:88px}
  .ad-lead,.ad-stats{grid-template-columns:1fr}
  .tier.featured-tier{transform:none}
  .ad-cta-panel{display:block;text-align:center}
  .ad-cta-panel .bigcta{margin-top:1rem}
}

@media(max-width:680px){
  header .wrap.nav > .menu-toggle{
    display:grid!important;
    position:fixed!important;
    top:18px!important;
    right:18px!important;
    z-index:100;
    background:#fff!important;
    border:1px solid rgba(20,42,68,.18)!important;
    box-shadow:0 12px 26px -16px rgba(16,27,46,.55)!important;
  }
}
