:root{--jgl-ink:#211713;--jgl-paper:#fffaf2;--jgl-panel:#fff;--jgl-line:#e8d9ca;--jgl-red:#b7252b;--jgl-green:#315f4c;--jgl-gold:#c79132;--jgl-shadow:0 18px 45px rgba(45,27,18,.10)}
*{box-sizing:border-box}
body{margin:0;background:var(--jgl-paper);color:var(--jgl-ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.55}
a{color:inherit;text-decoration:none}
a:hover{color:var(--jgl-red)}
img,svg,video,iframe,embed,object{max-width:100%;height:auto}
img{display:block}
body{overflow-x:clip}
.jgl-main{width:min(1180px,calc(100% - 32px));margin:0 auto}
.jgl-primary-menu{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap;padding:.55rem 1rem}
.jgl-masthead{background:#fffdf8;padding:.8rem 1rem}
.jgl-brand-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1180px;margin:0 auto}
.jgl-logo-link{flex:0 0 auto}
.jgl-logo-img{display:block;max-height:78px;width:auto;max-width:min(360px,42vw)}
.jgl-logo-text{font-family:Georgia,serif;font-weight:900;font-size:1.6rem}
.jgl-brand-copy{flex:1;text-align:left}
.jgl-brand-copy p{margin:.2rem 0}
.jgl-site-title{font-family:Georgia,serif;font-size:clamp(2.6rem,7vw,5.6rem);font-weight:900;letter-spacing:-.05em;text-transform:uppercase}
.jgl-sticky-nav{position:sticky;top:0;z-index:9999;background:#fffdf8;border-top:1px solid var(--jgl-line);border-bottom:1px solid var(--jgl-line);box-shadow:0 8px 24px rgba(33,23,19,.08)}
.jgl-primary-menu{list-style:none;margin:0;font-weight:900}
.jgl-primary-menu a{display:block;padding:.35rem}
.jgl-eyebrow,.jgl-tag{text-transform:uppercase;letter-spacing:.11em;font-size:.72rem;font-weight:800;color:var(--jgl-red)}
section{margin:2rem 0}
.jgl-layout-grid,.jgl-events-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,.8fr);gap:1.2rem}
.jgl-lead-card,.jgl-today-panel,.jgl-featured-event,.jgl-event-finder,.jgl-whats-on-page,.jgl-card-section,.jgl-tools,.jgl-community,.jgl-newsletter,.jgl-card,.jgl-event-card,.jgl-social-feed,.jgl-social-card,.jgl-single{background:var(--jgl-panel);border:1px solid var(--jgl-line);border-radius:24px;box-shadow:var(--jgl-shadow);padding:1rem}
.jgl-lead-card,.jgl-today-panel,.jgl-featured-event,.jgl-event-finder,.jgl-card,.jgl-event-card,.jgl-social-card{min-width:0}
.jgl-lead-card h1,.jgl-section-heading h2,section>h2,.jgl-newsletter h2{font-family:Georgia,serif;font-size:clamp(2rem,4vw,3.8rem);line-height:.98}
.jgl-image-placeholder{min-height:260px;display:grid;place-items:center;border-radius:18px;color:white;font-weight:900;background:linear-gradient(135deg,rgba(49,95,76,.9),rgba(183,37,43,.8))}
.jgl-hero-image{min-height:360px}
.jgl-button,.jgl-chip,.jgl-newsletter-button,button{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;background:var(--jgl-red);color:white;padding:.72rem 1rem;font-weight:900;cursor:pointer}
.jgl-newsletter-button-secondary{background:var(--jgl-green)}
.jgl-chip-submit,.jgl-chip{background:var(--jgl-gold);color:var(--jgl-ink)}
.jgl-newsletter-button-block,.jgl-button-full{display:flex;width:100%;margin-top:1rem}
.jgl-newsletter-actions,.jgl-chip-row{display:flex;justify-content:center;gap:.8rem;flex-wrap:wrap;margin-top:1rem}
.jgl-planning-strip{background:var(--jgl-green);color:white;border-radius:28px;padding:1.2rem}
.jgl-section-heading{text-align:center;max-width:760px;margin:0 auto 1.2rem}
.jgl-event-card-row,.jgl-social-grid,.jgl-cards.jgl-three,.jgl-tool-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.jgl-date-pill{display:inline-flex;background:#f6ead9;color:var(--jgl-red);border-radius:999px;padding:.25rem .6rem;font-weight:900}
.jgl-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.3rem}
.jgl-calendar-grid span{background:#fffaf4;border-radius:9px;text-align:center;padding:.35rem}
.jgl-social-card{box-shadow:none;border-top:6px solid var(--jgl-gold)}
.jgl-tool-grid a{background:#fffaf4;border:1px solid var(--jgl-line);border-radius:18px;padding:1rem;font-weight:900}
.jgl-newsletter,.jgl-site-footer{background:var(--jgl-ink);color:white;text-align:center}
.jgl-site-footer{padding:2rem;margin-top:2rem}
.jgl-single{max-width:820px;margin:2rem auto}
.jgl-single img,.jgl-content img{max-width:100%;height:auto}
.jgl-card-image{display:block;overflow:hidden;border-radius:14px;aspect-ratio:16/9;margin-bottom:.75rem}
.jgl-card-image img{width:100%;height:100%;object-fit:cover}
.jgl-feature-hero{margin-bottom:1rem;border-radius:18px;overflow:hidden}
.jgl-feature-hero img{width:100%;height:auto}
.jgl-lead-card img{width:100%;height:auto;border-radius:18px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.jgl-modal-open{overflow:hidden}
.jgl-newsletter-cta[hidden]{display:none}
.jgl-newsletter-cta{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem}
.jgl-newsletter-cta-backdrop{position:absolute;inset:0;background:rgba(33,23,19,.65);backdrop-filter:blur(2px)}
.jgl-newsletter-cta-panel{position:relative;background:var(--jgl-panel);color:var(--jgl-ink);border-radius:24px;box-shadow:var(--jgl-shadow);padding:1.6rem 1.4rem;max-width:460px;width:100%;text-align:center;animation:jgl-cta-in .2s ease-out}
@keyframes jgl-cta-in{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.jgl-newsletter-cta-panel h2{font-family:Georgia,serif;font-size:clamp(1.6rem,3.2vw,2.2rem);line-height:1.05;margin:.4rem 0 .6rem}
.jgl-newsletter-cta-panel p{margin:.4rem 0}
.jgl-newsletter-cta-close{position:absolute;top:.4rem;right:.6rem;background:transparent;color:var(--jgl-ink);font-size:1.6rem;line-height:1;padding:.2rem .55rem;border-radius:999px}
.jgl-newsletter-cta-close:hover{background:var(--jgl-line)}
.jgl-newsletter-cta-form{display:flex;gap:.5rem;margin:.9rem 0 .4rem;flex-wrap:wrap}
.jgl-newsletter-cta-form input[type=email]{flex:1 1 200px;min-width:0;padding:.7rem .9rem;border:1px solid var(--jgl-line);border-radius:999px;font:inherit;background:#fffdf8;color:var(--jgl-ink)}
.jgl-newsletter-cta-form input[type=email]:focus{outline:2px solid var(--jgl-red);outline-offset:1px}
.jgl-newsletter-cta-form .jgl-newsletter-button{flex:0 0 auto}
.jgl-newsletter-cta-small{font-size:.78rem;color:#6c5a4d;margin-top:.4rem}
.jgl-turnstile{flex:1 1 100%;display:flex;justify-content:center;min-height:65px}
.jgl-turnstile-missing{outline:2px solid var(--jgl-red);outline-offset:4px;border-radius:8px}
@media (max-width:760px){
.jgl-brand-row{align-items:center;flex-direction:row;justify-content:space-between;gap:.5rem}
.jgl-logo-img{max-width:200px;max-height:50px}
.jgl-brand-copy{display:none}
.jgl-newsletter-actions{display:none}
.jgl-nav-toggle{display:inline-flex}
.jgl-masthead{padding:.45rem .7rem}
.jgl-layout-grid,.jgl-events-grid,.jgl-event-card-row,.jgl-social-grid,.jgl-cards.jgl-three,.jgl-tool-grid{grid-template-columns:1fr}
.jgl-main{width:min(100% - 20px,1180px)}
.jgl-hero-image,.jgl-hero-image-link img,.jgl-hero-image-real{min-height:220px;height:220px}
.jgl-event-image-link img,.jgl-event-image-real{height:200px}
.jgl-site-title{font-size:2.8rem}
.jgl-chip-row{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start}
.jgl-chip{white-space:nowrap}
.jgl-newsletter-button{width:100%}
.jgl-sticky-nav .jgl-primary-menu{display:none;flex-direction:column;padding:0;width:100%;background:#fffdf8}
.jgl-sticky-nav .jgl-primary-menu li{width:100%;border-bottom:1px solid var(--jgl-line)}
.jgl-sticky-nav .jgl-primary-menu li:last-child{border-bottom:0}
.jgl-sticky-nav .jgl-primary-menu a{padding:.75rem 1rem;display:block}
.jgl-nav-open .jgl-sticky-nav .jgl-primary-menu{display:flex}
.jgl-primary-menu .sub-menu{position:static;display:none;box-shadow:none;border:0;border-radius:0;background:var(--jgl-paper);padding:0 0 0 1.25rem;width:100%;transform:none;min-width:0}
.jgl-primary-menu .menu-item-has-children.is-open > .sub-menu,
.jgl-primary-menu .megamenu.is-open > .sub-menu{display:block}
.jgl-cta-strip{flex-direction:column}
.jgl-cta-strip .jgl-button{width:100%}
.jgl-cta-row{flex-direction:column;align-items:stretch}
.jgl-cta-row .jgl-button{width:100%}
}

/* ===== Button hover (preserves text colour, darkens bg) ===== */
.jgl-button,.jgl-button:hover,.jgl-button:focus,.jgl-newsletter-button,.jgl-newsletter-button:hover,.jgl-newsletter-button:focus{color:#fff}
.jgl-button,.jgl-newsletter-button,.jgl-chip,button{transition:filter .15s ease,background-color .15s ease,color .15s ease,border-color .15s ease}
.jgl-button:hover,.jgl-newsletter-button:hover,button:not(.jgl-nav-toggle):not([data-jgl-newsletter-close]):hover{filter:brightness(.88)}
.jgl-chip,.jgl-chip:hover,.jgl-chip:focus{color:var(--jgl-ink)}
.jgl-chip:hover{filter:brightness(.93)}
.jgl-tool-grid a:hover{background:#fff;color:var(--jgl-red);border-color:var(--jgl-red)}

/* ===== Outline button variant ===== */
.jgl-button-outline,.jgl-button-outline:hover,.jgl-button-outline:focus{background:transparent;color:var(--jgl-ink);border:2px solid var(--jgl-ink)}
.jgl-button-outline:hover{background:var(--jgl-ink);color:#fff;filter:none}

/* ===== Large button ===== */
.jgl-button-large{padding:.9rem 1.4rem;font-size:1.02rem}

/* ===== CTA strip + row ===== */
.jgl-cta-strip{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;background:var(--jgl-panel);border:1px solid var(--jgl-line);border-radius:24px;box-shadow:var(--jgl-shadow);padding:1rem;margin:2rem 0}
.jgl-cta-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:.6rem}

/* ===== Real featured-image hero / event ===== */
.jgl-hero-image-link,.jgl-event-image-link{display:block;overflow:hidden;border-radius:18px;margin-bottom:1rem}
.jgl-hero-image-link img,.jgl-hero-image-real{width:100%;height:360px;object-fit:cover;display:block}
.jgl-event-image-link img,.jgl-event-image-real{width:100%;height:260px;object-fit:cover;display:block}

/* ===== Hamburger toggle ===== */
.jgl-nav-toggle{display:none;background:transparent;color:var(--jgl-ink);width:44px;height:44px;padding:0;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer;border:0;flex:0 0 auto}
.jgl-nav-toggle:hover{background:var(--jgl-line);filter:none}
.jgl-nav-toggle-bar{display:block;width:22px;height:2px;background:var(--jgl-ink);border-radius:2px;transition:transform .2s,opacity .2s}
.jgl-nav-open .jgl-nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.jgl-nav-open .jgl-nav-toggle-bar:nth-child(2){opacity:0}
.jgl-nav-open .jgl-nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Desktop dropdowns + megamenu ===== */
.jgl-primary-menu li{position:relative}
.jgl-primary-menu .menu-item-has-children > a::after{content:" \25BE";font-size:.7em;opacity:.6;margin-left:.15rem}
.jgl-primary-menu .sub-menu{list-style:none;margin:0;padding:.5rem;position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--jgl-line);border-top:3px solid var(--jgl-red);border-radius:0 0 16px 16px;box-shadow:var(--jgl-shadow);min-width:220px;display:none;z-index:9998}
.jgl-primary-menu .sub-menu a{display:block;padding:.5rem .75rem;border-radius:8px;font-weight:700}
.jgl-primary-menu .sub-menu a:hover{background:var(--jgl-paper);color:var(--jgl-red)}
.jgl-primary-menu li:hover > .sub-menu,
.jgl-primary-menu li:focus-within > .sub-menu{display:block}
/* Add CSS class "megamenu" to a top-level menu item in Appearance → Menus to convert its sub-menu into a 3-column wide panel. */
.jgl-primary-menu .megamenu > .sub-menu{left:50%;transform:translateX(-50%);width:760px;max-width:90vw;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem 1.2rem;padding:1.25rem 1.5rem;border-radius:18px}
.jgl-primary-menu .megamenu:hover > .sub-menu,
.jgl-primary-menu .megamenu:focus-within > .sub-menu{display:grid}
.jgl-primary-menu .megamenu .sub-menu li > a{font-family:Georgia,serif;font-size:1.05rem;font-weight:700}
