:root{
    --bg:#fff;
    --fg:#111;
    --muted:#6b6b6b;
    --line:#e9e9e9;
    --radius:18px;
    --max:1220px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.header{
    position:sticky;top:0;z-index:10;
    background:rgba(255,255,255,.92);
    backdrop-filter: blur(8px);
    border-bottom:1px solid var(--line);
}
.header__inner{
    max-width:var(--max);
    margin:0 auto;
    padding:18px 22px;
    display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.logo{display:flex;flex-direction:column;line-height:1}
.logo__top{font-weight:700;font-size:18px;letter-spacing:-.02em}
.logo__bottom{font-weight:500;color:var(--muted);font-size:13px;margin-top:3px}

.nav{display:flex;gap:18px;align-items:center}
.nav a{font-size:14px;color:var(--muted)}
.nav a.is-active{color:var(--fg)}

.header__right{display:flex;gap:10px;align-items:center}
.header__icon{
    width:38px;height:38px;border-radius:999px;
    display:flex;align-items:center;justify-content:center;
    border:1px solid var(--line); color:var(--fg);
}
.burger{
    width:42px;height:42px;border-radius:999px;border:1px solid var(--line);
    background:#fff; display:none; align-items:center; justify-content:center; flex-direction:column; gap:4px;
}
.burger span{display:block;width:16px;height:2px;background:var(--fg);opacity:.9}

.hero{padding:24px 22px 10px}
.hero__inner{max-width:var(--max);margin:0 auto}
.hero__media{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.hero__placeholder{
    height:340px;
    background:linear-gradient(135deg,#f2f2f2,#fff);
    display:flex;align-items:center;justify-content:center;
    color:var(--muted);font-size:14px;
}
.hero__content{padding:18px 4px 0}
.hero__content h1{margin:0;font-size:44px;letter-spacing:-.03em}
.hero__content p{margin:10px 0 0;color:var(--muted);max-width:62ch}

.section{max-width:var(--max);margin:0 auto;padding:34px 22px}
.section--alt{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fafafa}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}
.section__head h2{margin:0;font-size:26px;letter-spacing:-.02em}
.section__link{font-size:14px;color:var(--muted)}
.section__meta{font-size:13px;color:var(--muted)}
.error{color:#b00020}

.grid{
    display:grid;
    gap:18px;
}
.grid--3{grid-template-columns:repeat(3,minmax(0,1fr));}

.card, .event{
    border:1px solid var(--line);
    border-radius:var(--radius);
    overflow:hidden;
    background:#fff;
    transition:transform .18s ease,border-color .18s ease;
}
.card:hover, .event:hover{transform:translateY(-2px);border-color:#dcdcdc}

.card__media, .event__media{aspect-ratio:16/10;background:#f4f4f4}
.card__media img, .event__media img{width:100%;height:100%;object-fit:cover}
.ph{width:100%;height:100%;background:linear-gradient(135deg,#efefef,#fff)}

.card__body{padding:16px}
.meta{font-size:13px;color:var(--muted)}
.time{font-size:14px;margin-top:4px}

.card__body h3{margin:10px 0 6px;font-size:16px}
.card__body p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}

.event__body{padding:16px 16px 14px}
.event__top{display:flex;justify-content:space-between;gap:12px}
.event__actions{display:flex;align-items:center;gap:10px}
.badge{
    display:inline-flex;align-items:center;justify-content:center;
    padding:7px 10px;border-radius:999px;
    color:#fff;font-size:12px;line-height:1;font-weight:600;
}
.arrow{
    width:34px;height:34px;border-radius:999px;border:1px solid var(--line);
    display:inline-flex;align-items:center;justify-content:center;
    font-size:18px;
}
.event__title{margin:12px 0 8px;font-size:16px;letter-spacing:-.01em}
.event__desc{margin:0;color:var(--muted);font-size:13px;line-height:1.45}
.event__footer{margin-top:12px;display:flex;justify-content:flex-end}
.tag{font-size:12px;color:var(--muted);border:1px solid var(--line);padding:6px 10px;border-radius:999px}

.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.split__box{border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:#fff}

.footer{border-top:1px solid var(--line)}
.footer__inner{
    max-width:var(--max);margin:0 auto;padding:24px 22px;
    display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:13px;
}
.footer__links a{margin-left:12px;color:var(--muted)}

@media (max-width: 980px){
    .grid--3{grid-template-columns:repeat(2,minmax(0,1fr));}
    .split{grid-template-columns:1fr}
}
@media (max-width: 680px){
    .nav{display:none}
    .burger{display:flex}
    .grid--3{grid-template-columns:1fr}
    .hero__content h1{font-size:32px}
}
.section__head--carousel{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:16px;
}

.carouselControls{
    display:flex;
    gap:10px;
    align-items:center;
}

.carouselBtn{
    width:46px;
    height:46px;
    border-radius:999px;
    border:1px solid var(--line);
    background:#fff;
    font-size:18px;
    line-height:1;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
}

.carousel{
    position:relative;
}

.carousel__track{
    display:flex;
    gap:18px;
    overflow:auto;
    padding-bottom:6px;
    scroll-snap-type:x mandatory;
    scroll-behavior:smooth;
    -webkit-overflow-scrolling: touch;
}

.carousel__track::-webkit-scrollbar{
    height:8px;
}
.carousel__track::-webkit-scrollbar-thumb{
    background:#ddd;
    border-radius:999px;
}

.eventSlide{
    flex:0 0 calc((100% - 36px) / 3); /* 3 slides with 2 gaps (18px * 2) */
    scroll-snap-align:start;
    border:1px solid var(--line);
    border-radius:var(--radius);
    overflow:hidden;
    background:#fff;
    transition:transform .18s ease,border-color .18s ease;
}

.eventSlide:hover{
    transform:translateY(-2px);
    border-color:#dcdcdc;
}

@media (max-width: 980px){
    .eventSlide{ flex-basis: calc((100% - 18px) / 2); } /* 2 per row */
}

@media (max-width: 680px){
    .eventSlide{ flex-basis: 100%; } /* 1 per row */
}

/* HTML description clamp (works with HTML content too) */
.event__desc--clamp{
    margin-top:8px;
    color:var(--muted);
    font-size:13px;
    line-height:1.45;

    display:-webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4; /* adjust number of lines */
    overflow:hidden;
}

.event__desc--clamp h3,
.event__desc--clamp h4{
    margin:0 0 6px;
    font-size:13px;
    font-weight:600;
    color:var(--fg);
}

.event__desc--clamp p{
    margin:0 0 6px;
}
.eventPage{max-width:var(--max);margin:0 auto;padding:26px 22px 44px}
.eventHero__kicker{color:var(--muted);font-size:14px;margin-top:8px}
.eventHero__title{margin:10px 0 10px;font-size:44px;letter-spacing:-.03em}
.eventHero__datetime{display:flex;gap:14px;color:var(--muted);font-size:14px;margin-bottom:10px}
.eventHero__tags{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 18px}
.pill{border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-size:13px;color:var(--fg);background:#fff}
.eventHero__image{margin:18px 0 14px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.eventHero__image img{width:100%;height:auto;display:block}
.eventBody{font-size:15px;line-height:1.7;max-width:78ch}
.eventBody h2,.eventBody h3,.eventBody h4{margin:16px 0 8px;letter-spacing:-.01em}
.eventBody p{margin:0 0 10px}
.eventCTA{display:flex;align-items:center;gap:12px;margin-top:18px}
.buyBtn{
    display:inline-flex;align-items:center;justify-content:center;
    padding:12px 18px;border-radius:999px;
    background:#111;color:#fff;font-size:14px;
    border:1px solid #111;
}
@media (max-width: 680px){
    .eventHero__title{font-size:32px}
}

