/*
Theme Name: OktoberfestEvents
Theme URI: https://oktoberfestevents.de/
Author: OktoberfestEvents
Description: A professional bilingual (DE/EN) theme for an Oktoberfest events information and travel site. Custom homepage, blog, and pages with built-in SEO structure.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: oktoberfestevents
*/
:root{
  --blue:#0a4a8f; --blue-dark:#06335f; --sky:#1c74d4;
  --white:#ffffff; --cream:#f8f5ef; --gold:#e3a008; --gold-dark:#b8860b;
  --ink:#15181f; --muted:#5b6472; --line:#e6e2d9;
  --shadow:0 14px 40px rgba(8,30,60,.13);
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--serif);line-height:1.1;font-weight:800;letter-spacing:-.01em}
section{padding:84px 0}
.eyebrow{color:var(--gold-dark);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem}
.lozenge{height:12px;background-size:40px 40px;
  background-image:linear-gradient(135deg,var(--blue) 25%,transparent 25%),
    linear-gradient(225deg,var(--blue) 25%,transparent 25%),
    linear-gradient(45deg,var(--blue) 25%,transparent 25%),
    linear-gradient(315deg,var(--blue) 25%,var(--white) 25%);
  background-position:20px 0,20px 0,0 0,0 0}
header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-weight:800;font-size:1.25rem;color:var(--blue)}
.brand .mark{width:32px;height:32px;border-radius:50%;background:conic-gradient(var(--blue) 0 25%,#fff 0 50%,var(--blue) 0 75%,#fff 0);border:2px solid var(--blue)}
.menu{display:flex;gap:28px;align-items:center}
.menu a{font-weight:500;font-size:.97rem}
.menu a:hover{color:var(--sky)}
.lang{display:flex;border:1px solid var(--line);border-radius:30px;overflow:hidden}
.lang button{border:0;background:transparent;padding:7px 13px;font-weight:700;cursor:pointer;color:var(--muted);font-size:.82rem;font-family:var(--sans)}
.lang button.on{background:var(--blue);color:#fff}
.burger{display:none;border:0;background:transparent;font-size:1.6rem;cursor:pointer;color:var(--blue)}
.btn{display:inline-block;padding:14px 28px;border-radius:32px;font-weight:600;cursor:pointer;border:2px solid transparent;transition:.18s;font-family:var(--sans)}
.btn-gold{background:var(--gold);color:#231a00}
.btn-gold:hover{background:var(--gold-dark);color:#fff;transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--blue)}
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#0a4a8f 0%,#06335f 100%);color:#fff}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding-top:74px;padding-bottom:74px;position:relative;z-index:2}
.hero h1{font-size:clamp(2.3rem,4.6vw,3.7rem);margin-bottom:20px;color:#fff}
.hero h1 em{color:var(--gold);font-style:normal}
.hero p.sub{font-size:1.16rem;opacity:.94;max-width:520px;margin-bottom:28px}
.cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .deco{position:absolute;inset:0;opacity:.13;z-index:1;background-image:radial-gradient(circle at 80% 20%,#fff 0 2px,transparent 2px);background-size:34px 34px}
.count{display:flex;gap:14px;margin-top:34px}
.count .u{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:12px 16px;text-align:center;min-width:74px}
.count .u b{display:block;font-family:var(--serif);font-size:1.9rem;line-height:1;color:var(--gold)}
.count .u span{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.8}
.count-label{font-size:.82rem;opacity:.8;margin-top:18px;display:block}
.statbar{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.statbar .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:20px;padding:30px 24px}
.stat{text-align:center}
.stat b{font-family:var(--serif);font-size:1.8rem;color:var(--blue);display:block}
.stat span{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.head{text-align:center;margin-bottom:50px}
.head h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin:12px 0}
.head p{color:var(--muted);max-width:620px;margin:0 auto}
.grid{display:grid;gap:24px}
.g3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow);transition:.2s}
.card:hover{transform:translateY(-5px)}
.card .ic{width:52px;height:52px;border-radius:14px;background:var(--cream);display:grid;place-items:center;font-size:1.6rem;margin-bottom:16px}
.card h3{font-size:1.22rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.97rem}
.events{background:var(--cream)}
.ev{display:flex;align-items:center;gap:22px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 24px;margin-bottom:15px;transition:.18s}
.ev:hover{border-color:var(--sky);box-shadow:var(--shadow);transform:translateX(4px)}
.ev .date{flex:0 0 88px;text-align:center;background:linear-gradient(160deg,var(--blue),var(--blue-dark));color:#fff;border-radius:12px;padding:12px 6px}
.ev .date b{font-family:var(--serif);display:block;font-size:1.6rem;line-height:1}
.ev .date span{font-size:.72rem;text-transform:uppercase}
.ev .info{flex:1}
.ev .info h3{font-size:1.15rem}
.ev .info p{color:var(--muted);font-size:.92rem}
.ev .tag{font-size:.74rem;font-weight:600;padding:6px 13px;border-radius:20px;background:var(--cream);color:var(--blue-dark);white-space:nowrap}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.checklist{list-style:none;display:grid;gap:15px}
.checklist li{display:flex;gap:13px;align-items:flex-start;font-size:1.02rem}
.checklist li::before{content:"\2713";color:#fff;background:var(--gold);width:25px;height:25px;border-radius:50%;display:grid;place-items:center;flex:0 0 25px;font-size:.8rem;font-weight:800}
.panel{background:linear-gradient(160deg,var(--blue),var(--blue-dark));color:#fff;border-radius:20px;padding:40px}
.panel h3{font-size:1.45rem;margin-bottom:16px;color:#fff}
.panel ul{list-style:none;display:grid;gap:13px}
.panel li{padding-bottom:13px;border-bottom:1px solid rgba(255,255,255,.18);display:flex;justify-content:space-between;gap:12px}
.panel li b{color:var(--gold)}
.news{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;text-align:center}
.news form{display:flex;gap:10px;max-width:480px;margin:26px auto 0;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:230px;padding:15px 20px;border-radius:32px;border:0;font-size:1rem;font-family:var(--sans)}
footer.site{background:var(--ink);color:#c4ccd7;padding:60px 0 30px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:38px}
footer.site h4{color:#fff;margin-bottom:15px;font-size:1rem;font-family:var(--sans)}
footer.site a{display:block;color:#97a2b1;padding:5px 0;font-size:.93rem}
footer.site a:hover{color:var(--gold)}
.copy{border-top:1px solid #292f3a;padding-top:22px;font-size:.85rem;color:#727d8c;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.page-head{background:linear-gradient(160deg,var(--blue),var(--blue-dark));color:#fff;padding:64px 0;text-align:center}
.page-head h1{color:#fff;font-size:clamp(2rem,4vw,2.8rem)}
.page-head p{opacity:.9;margin-top:10px}
.bloggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-5px)}
.post .thumb{aspect-ratio:16/9;background:var(--cream);display:grid;place-items:center;font-size:2.4rem;overflow:hidden}
.post .thumb img{width:100%;height:100%;object-fit:cover}
.post .body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.post .meta{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.post h2,.post h3{font-size:1.2rem}
.post p{color:var(--muted);font-size:.95rem}
.post .more{margin-top:auto;color:var(--sky);font-weight:600;font-size:.92rem}
.article{max-width:760px;margin:0 auto;padding:64px 24px}
.article h1{font-size:clamp(1.9rem,4vw,2.6rem);margin-bottom:14px}
.article .meta{color:var(--muted);font-size:.9rem;margin-bottom:30px}
.article p,.article ul,.article ol{margin-bottom:18px;font-size:1.05rem}
.article ul,.article ol{padding-left:22px}
.article h2{font-size:1.6rem;margin:28px 0 12px}
.article h3{font-size:1.3rem;margin:22px 0 10px}
.article img{border-radius:14px;margin:20px 0}
.article a{color:var(--sky);text-decoration:underline}
.pager{display:flex;justify-content:center;gap:14px;margin-top:40px;flex-wrap:wrap}
.pager a,.pager span{padding:10px 18px;border-radius:30px;border:1px solid var(--line);font-weight:600}
.pager .current{background:var(--blue);color:#fff;border-color:var(--blue)}
[data-en]{display:none}
html[lang="en"] [data-de]{display:none}
html[lang="en"] [data-en]{display:revert}
@media(max-width:880px){
  .hero .wrap,.g3,.split,.fgrid,.bloggrid{grid-template-columns:1fr}
  .hero .art{order:-1;max-width:380px;margin:0 auto}
  .menu{display:none}
  .burger{display:block}
  .menu.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:#fff;padding:20px 24px;border-bottom:1px solid var(--line);gap:14px}
}

/* Long-page additions */
.toc{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 28px;box-shadow:var(--shadow);max-width:980px;margin:0 auto}
.toc h2{font-size:1.2rem;margin-bottom:14px}
.toc-links{display:flex;flex-wrap:wrap;gap:10px}
.toc-links a{background:var(--cream);border:1px solid var(--line);border-radius:30px;padding:8px 16px;font-size:.9rem;font-weight:600;color:var(--blue);transition:.15s}
.toc-links a:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.tbl-wrap{overflow-x:auto;border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow)}
table.ofe{width:100%;border-collapse:collapse;background:#fff;min-width:640px}
table.ofe th,table.ofe td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.96rem}
table.ofe thead th{background:var(--blue);color:#fff;font-family:var(--sans);font-weight:600;position:sticky;top:0}
table.ofe tbody tr:nth-child(even){background:var(--cream)}
table.ofe tbody tr:hover{background:#eef4fb}
table.ofe td:first-child{font-weight:700;color:var(--blue-dark)}
.timeline{max-width:820px;margin:0 auto;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:3px;background:linear-gradient(var(--gold),var(--blue))}
.tl-item{position:relative;margin-bottom:26px}
.tl-item::before{content:"";position:absolute;left:-34px;top:4px;width:20px;height:20px;border-radius:50%;background:#fff;border:4px solid var(--gold)}
.tl-item h3{font-size:1.15rem;margin-bottom:4px}
.tl-item .when{color:var(--gold-dark);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.tl-item p{color:var(--muted);font-size:.97rem;margin-top:4px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.mini{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;text-align:center;box-shadow:var(--shadow)}
.mini .ic{font-size:1.8rem;margin-bottom:8px}
.mini h3{font-size:1.02rem;margin-bottom:4px}
.mini p{color:var(--muted);font-size:.86rem}
@media(max-width:880px){.g4{grid-template-columns:repeat(2,1fr)}}

/* Festive / attractive additions */
.eyebrow{display:inline-block}
.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.gallery .tile{aspect-ratio:1;border-radius:18px;display:grid;place-items:center;box-shadow:var(--shadow);transition:.25s;cursor:default;position:relative;overflow:hidden}
.gallery .tile svg{width:64%;height:64%}
.gallery .tile span{position:absolute;bottom:8px;font-size:.72rem;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.35);letter-spacing:.03em}
.gallery .tile:hover{transform:translateY(-6px) rotate(-1.5deg)}
.t-blue{background:linear-gradient(150deg,#0a4a8f,#06335f)}
.t-gold{background:linear-gradient(150deg,#f0b429,#b8860b)}
.t-red{background:linear-gradient(150deg,#d9483f,#a3281f)}
.t-green{background:linear-gradient(150deg,#3f9d6b,#256b46)}
@media(max-width:880px){.gallery{grid-template-columns:repeat(3,1fr)}}

.ctaband{position:relative;overflow:hidden;background:linear-gradient(120deg,#0a4a8f,#1c74d4);color:#fff;text-align:center;border-radius:0}
.ctaband .wrap{position:relative;z-index:2;padding:64px 24px}
.ctaband .confetti{position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:radial-gradient(circle,#e3a008 0 4px,transparent 4px),radial-gradient(circle,#fff 0 3px,transparent 3px),radial-gradient(circle,#d9483f 0 3px,transparent 3px);
  background-size:90px 90px,70px 70px,110px 110px;background-position:0 0,30px 40px,60px 10px;animation:floaty 9s ease-in-out infinite alternate}
@keyframes floaty{to{background-position:10px 30px,40px 10px,80px 40px}}
.ctaband h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:12px}
.ctaband p{opacity:.95;max-width:560px;margin:0 auto 24px;font-size:1.1rem}
.ctaband .btn-gold{font-size:1.05rem;padding:16px 34px}

.count .u{transition:.3s}
#cd-s{animation:pulse 1s ease-in-out infinite}
@keyframes pulse{50%{opacity:.55}}
.ev:hover .date{transform:scale(1.06)}
.ev .date{transition:.18s}
.divider{height:14px;margin:0;background-size:44px 44px;
  background-image:linear-gradient(135deg,var(--gold) 25%,transparent 25%),linear-gradient(225deg,var(--gold) 25%,transparent 25%),linear-gradient(45deg,var(--gold) 25%,transparent 25%),linear-gradient(315deg,var(--gold) 25%,var(--cream) 25%);
  background-position:22px 0,22px 0,0 0,0 0}

/* International / premium refinements v1.5 */
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);color:#fff;border-radius:30px;padding:8px 16px;font-size:.82rem;font-weight:600;letter-spacing:.02em;margin-bottom:20px}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(227,160,8,.25)}
.hero h1{font-size:clamp(2.4rem,4.8vw,4rem)}
.hero .sub{font-size:1.2rem}
.trust{background:#fff;border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;padding:22px 24px}
.trust .ti{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.92rem;font-weight:600}
.trust .ti b{color:var(--blue);font-size:1.05rem}
.sec-num{display:inline-block;font-family:var(--sans);font-weight:800;color:var(--gold);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase}
.card{position:relative;overflow:hidden}
.card.accent::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--gold))}
.intro-lead{font-size:1.3rem;line-height:1.6;color:var(--ink);max-width:780px;margin:0 auto;text-align:center;font-family:var(--serif);font-weight:600}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px)}
.flags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:14px}
.flags span{font-size:.8rem;color:var(--muted);background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:5px 12px}
.hero .wrap{padding-top:90px;padding-bottom:90px}
section{padding:90px 0}
.head h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}

/* Image-led professional design v1.6 */
.phero{position:relative;color:#fff;min-height:86vh;display:flex;align-items:center;background-size:cover;background-position:center}
.phero::before{content:"";position:absolute;inset:0;background:linear-gradient(175deg,rgba(6,28,58,.55) 0%,rgba(6,28,58,.82) 100%);z-index:1}
.phero .wrap{position:relative;z-index:2;width:100%}
.phero .inner{max-width:700px}
.phero h1{color:#fff;font-size:clamp(2.5rem,5.2vw,4.3rem);text-shadow:0 2px 24px rgba(0,0,0,.3)}
.phero h1 em{color:var(--gold);font-style:normal}
.phero .sub{font-size:1.25rem;opacity:.96;max-width:560px;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.phero .count .u{background:rgba(255,255,255,.13);backdrop-filter:blur(4px)}

.feat{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.feat .ph{border-radius:22px;overflow:hidden;box-shadow:0 24px 60px rgba(8,30,60,.2);aspect-ratio:4/3}
.feat .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:.5s}
.feat .ph:hover img{transform:scale(1.05)}
.feat.rev .txt{order:2}

.pgallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:16px}
.pgallery figure{margin:0;border-radius:18px;overflow:hidden;position:relative;box-shadow:var(--shadow)}
.pgallery img{width:100%;height:100%;object-fit:cover;transition:.5s}
.pgallery figure:hover img{transform:scale(1.07)}
.pgallery .tall{grid-row:span 2}
.pgallery .wide{grid-column:span 2}
.pgallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;color:#fff;font-weight:700;font-size:.92rem;background:linear-gradient(transparent,rgba(8,20,40,.78))}

.imgcard{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:.25s;display:flex;flex-direction:column}
.imgcard:hover{transform:translateY(-6px)}
.imgcard .thumb{aspect-ratio:3/2;overflow:hidden}
.imgcard .thumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.imgcard:hover .thumb img{transform:scale(1.06)}
.imgcard .pad{padding:22px}
.imgcard h3{font-size:1.18rem;margin-bottom:6px}
.imgcard p{color:var(--muted);font-size:.95rem}

.keydates{list-style:none;display:grid;gap:12px;margin-top:8px}
.keydates li{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 18px}
.keydates .d{flex:0 0 92px;font-weight:800;color:var(--blue);font-family:var(--serif)}
.keydates .t{color:var(--ink);font-weight:600}
.keydates .t small{display:block;color:var(--muted);font-weight:400;font-size:.86rem}

.ctaphoto{position:relative;color:#fff;background-size:cover;background-position:center;text-align:center}
.ctaphoto::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(8,28,58,.72),rgba(8,28,58,.82))}
.ctaphoto .wrap{position:relative;z-index:2;padding:84px 24px}
.ctaphoto h2{color:#fff}
.attrib{text-align:center;color:var(--muted);font-size:.78rem;margin-top:30px}
.attrib a{color:var(--muted);text-decoration:underline}

@media(max-width:880px){
  .feat{grid-template-columns:1fr}
  .feat.rev .txt{order:0}
  .pgallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .pgallery .wide{grid-column:span 2}
}

/* Professional events list v1.7 */
.evintro{max-width:760px;margin:0 auto 36px;text-align:center;color:var(--muted);font-size:1.05rem}
.evlist{display:grid;gap:16px;max-width:960px;margin:0 auto}
.evrow{display:flex;gap:22px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px 24px;box-shadow:var(--shadow);transition:.2s;flex-wrap:wrap}
.evrow:hover{border-color:var(--sky);transform:translateY(-3px)}
.evrow .when{flex:0 0 92px;text-align:center;background:linear-gradient(160deg,var(--blue),var(--blue-dark));color:#fff;border-radius:14px;padding:14px 8px}
.evrow .when b{display:block;font-family:var(--serif);font-size:1.7rem;line-height:1}
.evrow .when span{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em}
.evrow .det{flex:1;min-width:220px}
.evrow .det h3{font-size:1.2rem;margin-bottom:4px}
.evrow .det .loc{color:var(--blue);font-weight:600;font-size:.9rem;margin-bottom:5px}
.evrow .det p{color:var(--muted);font-size:.92rem;margin:0}
.evrow .det .range{color:var(--ink);font-weight:600;font-size:.9rem}
.evpill{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:3px 9px;margin-left:8px;vertical-align:middle}
.evpill.ok{color:#256b46;background:#e6f4ec}
.evpill.exp{color:#8a5a1a;background:#fbf0db}
.evrow .go{flex:0 0 auto}
.evrow .go a{display:inline-flex;align-items:center;gap:6px;background:var(--gold);color:#231a00;font-weight:700;padding:11px 20px;border-radius:30px;font-size:.9rem;white-space:nowrap;transition:.18s}
.evrow .go a:hover{background:var(--gold-dark);color:#fff;transform:translateX(2px)}
.evnote{max-width:960px;margin:26px auto 0;text-align:center;color:var(--muted);font-size:.84rem}
@media(max-width:720px){.evrow .go{flex-basis:100%}.evrow .go a{width:100%;justify-content:center}}

/* Event detail page components v1.8 */
.infobox{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:22px 26px;margin:26px 0}
.infobox h3{font-size:1.1rem;margin-bottom:12px}
.infobox ul{list-style:none;display:grid;gap:9px;padding:0;margin:0}
.infobox li{font-size:.97rem;color:var(--ink)}
.infobox li strong{color:var(--blue-dark)}
.bookbox{display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border-radius:18px;padding:26px 30px;margin:30px 0}
.bookbox strong{font-family:var(--serif);font-size:1.2rem}
.bookbox span{display:block;opacity:.9;font-size:.92rem;margin-top:4px}
.bookbox .btn{white-space:nowrap}
.article .infobox a,.article .bookbox a{color:#fff}
.article .infobox a{color:var(--sky)}
.evrow{cursor:pointer}
.evrow .det h3 a{color:inherit}
.evrow .det h3 a:hover{color:var(--sky)}

/* Booking buttons + decision guide v1.9 */
.tripbox{border:1px solid var(--line);border-radius:18px;padding:22px 24px;margin:18px 0 30px;background:#fff;box-shadow:var(--shadow)}
.tripbtns{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.tripbtns a{display:flex;flex-direction:column;gap:3px;align-items:flex-start;border:1px solid var(--line);border-radius:14px;padding:14px 16px;transition:.18s;background:var(--cream);text-decoration:none}
.tripbtns a:hover{border-color:var(--sky);transform:translateY(-3px);background:#fff}
.tripbtns .ic{font-size:1.5rem}
.tripbtns b{font-size:.97rem;color:var(--ink)}
.tripbtns small{color:var(--muted);font-size:.8rem}
.tripnote{color:var(--muted);font-size:.82rem;margin-top:-8px}
@media(max-width:720px){.tripbtns{grid-template-columns:1fr}}
.choosegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:960px;margin:0 auto}
.choose{background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow)}
.choose b{display:block;color:var(--blue-dark);margin-bottom:5px;font-size:1rem}
.choose p{color:var(--muted);font-size:.92rem;margin:0}
@media(max-width:880px){.choosegrid{grid-template-columns:1fr}}

/* Site search v2.0 */
.hsearch input,.navsearch input{border:1px solid var(--line);border-radius:30px;padding:8px 14px;font-size:.9rem;font-family:var(--sans);width:150px;outline:none;background:#fff}
.hsearch input:focus,.navsearch input:focus{border-color:var(--sky)}
.navsearch{display:none}
.imgcard{text-decoration:none;color:inherit}
@media(max-width:880px){
  .hsearch{display:none}
  .navsearch{display:block;margin-top:6px;width:100%}
  .navsearch input{width:100%}
}

/* Events hub homepage v2.1 */
.ehero{background:linear-gradient(160deg,#0a4a8f,#06335f);color:#fff;padding:66px 0 0;position:relative;overflow:hidden}
.ehero .deco{position:absolute;inset:0;opacity:.12;background-image:radial-gradient(circle at 80% 20%,#fff 0 2px,transparent 2px);background-size:34px 34px}
.ehero .wrap{position:relative;z-index:2}
.ehero h1{color:#fff;font-size:clamp(2.1rem,4.4vw,3.3rem);text-align:center;max-width:920px;margin:0 auto 14px}
.ehero h1 em{color:var(--gold);font-style:normal}
.ehero p.sub{text-align:center;opacity:.92;max-width:640px;margin:0 auto 28px;font-size:1.14rem}
.efind{max-width:640px;margin:0 auto;background:#fff;border-radius:16px;padding:8px;display:flex;gap:8px;box-shadow:0 18px 50px rgba(0,0,0,.28)}
.efind input{flex:1;border:0;outline:0;padding:13px 16px;font-size:1rem;font-family:var(--sans);border-radius:12px;color:var(--ink)}
.efind button{border:0;background:var(--gold);color:#231a00;font-weight:700;padding:0 24px;border-radius:12px;cursor:pointer;font-family:var(--sans)}
.efind button:hover{background:var(--gold-dark);color:#fff}
.echips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:24px auto -34px;position:relative;z-index:4;max-width:760px}
.echip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:30px;padding:9px 18px;font-weight:600;font-size:.9rem;cursor:pointer;transition:.15s}
.echip:hover{background:rgba(255,255,255,.26)}
.echip.on{background:var(--gold);color:#231a00;border-color:var(--gold)}
.events-wrap{background:var(--cream);padding:74px 0 84px}
.egrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ecard{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.ecard:hover{transform:translateY(-6px);border-color:var(--sky)}
.ethumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.ethumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.ecard:hover .ethumb img{transform:scale(1.07)}
.edate{position:absolute;top:12px;left:12px;background:#fff;border-radius:12px;padding:7px 12px;text-align:center;box-shadow:0 6px 18px rgba(0,0,0,.22)}
.edate b{display:block;font-family:var(--serif);font-size:1.35rem;line-height:1;color:var(--blue)}
.edate span{font-size:.68rem;text-transform:uppercase;color:var(--muted);font-weight:700}
.epill{position:absolute;top:14px;right:12px;background:var(--gold);color:#231a00;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:4px 10px}
.ebody{padding:20px;display:flex;flex-direction:column;gap:7px;flex:1}
.ebody h3{font-size:1.18rem;line-height:1.2}
.emeta{color:var(--blue);font-weight:600;font-size:.86rem}
.ebody p{color:var(--muted);font-size:.92rem;flex:1;margin:0}
.ecta{color:var(--sky);font-weight:700;font-size:.9rem;margin-top:4px}
.eno{text-align:center;color:var(--muted);padding:30px;display:none;grid-column:1/-1}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:980px;margin:0 auto}
.step{text-align:center;padding:10px}
.step .n{width:54px;height:54px;border-radius:50%;background:var(--blue);color:#fff;font-family:var(--serif);font-weight:800;font-size:1.4rem;display:grid;place-items:center;margin:0 auto 14px}
.step h3{font-size:1.12rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:.95rem}
@media(max-width:880px){.egrid,.steps{grid-template-columns:1fr}.echips{margin-bottom:-26px}}

/* Long homepage banners & sections v2.3 */
.featband{position:relative;overflow:hidden;color:#fff;background-size:cover;background-position:center;min-height:400px;display:flex;align-items:center}
.featband::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,28,58,.9),rgba(6,28,58,.5) 70%,rgba(6,28,58,.3))}
.featband .wrap{position:relative;z-index:2}
.featband .inner{max-width:580px}
.featbadge{display:inline-block;background:var(--gold);color:#231a00;font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;border-radius:20px;padding:6px 14px;margin-bottom:16px}
.featband h2{color:#fff;font-size:clamp(2rem,3.8vw,2.9rem);margin-bottom:14px;line-height:1.12}
.featband p{opacity:.95;font-size:1.1rem;margin-bottom:24px;max-width:500px}
.featmeta{display:flex;gap:26px;flex-wrap:wrap;margin-bottom:26px}
.featmeta div b{display:block;font-family:var(--serif);font-size:1.5rem;color:var(--gold)}
.featmeta div span{font-size:.82rem;opacity:.85;text-transform:uppercase;letter-spacing:.04em}

.valuegrid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.value{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 24px;box-shadow:var(--shadow);text-align:center;transition:.2s}
.value:hover{transform:translateY(-5px)}
.value .ic{width:58px;height:58px;border-radius:16px;background:var(--cream);display:grid;place-items:center;font-size:1.7rem;margin:0 auto 14px}
.value h3{font-size:1.08rem;margin-bottom:6px}
.value p{color:var(--muted);font-size:.92rem}

.regionband{background:linear-gradient(160deg,var(--blue),var(--blue-dark));color:#fff;text-align:center}
.regionband .wrap{padding:60px 24px}
.regionband h2{color:#fff;margin-bottom:10px;font-size:clamp(1.7rem,3.2vw,2.3rem)}
.regionband p{opacity:.9;max-width:600px;margin:0 auto}
.citychips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.citychips span{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.28);border-radius:30px;padding:9px 18px;font-weight:600;font-size:.92rem}

.postgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:.2s}
.pcard:hover{transform:translateY(-6px);border-color:var(--sky)}
.pcard .pthumb{aspect-ratio:16/9;overflow:hidden;background:var(--cream)}
.pcard .pthumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.pcard:hover .pthumb img{transform:scale(1.06)}
.pcard .ppad{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.pcard .pmeta{font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.pcard h3{font-size:1.12rem;line-height:1.25}
.pcard p{color:var(--muted);font-size:.92rem;flex:1}
.pcard .pmore{color:var(--sky);font-weight:700;font-size:.88rem}
@media(max-width:880px){.valuegrid{grid-template-columns:repeat(2,1fr)}.postgrid{grid-template-columns:1fr}.featband::before{background:linear-gradient(rgba(6,28,58,.82),rgba(6,28,58,.82))}}

/* Homepage hero banner + events page filter v2.4 */
.hbanner{position:relative;overflow:hidden;color:#fff;background-size:cover;background-position:center;min-height:560px;display:flex;align-items:center}
.hbanner-ov{position:absolute;inset:0;background:linear-gradient(160deg,rgba(6,28,58,.86),rgba(6,28,58,.6) 60%,rgba(6,28,58,.4));z-index:1}
.hbanner .wrap{position:relative;z-index:2}
.hbanner-in{max-width:720px}
.hbanner h1{color:#fff;font-size:clamp(2.3rem,5vw,3.8rem);line-height:1.1;margin:14px 0 16px;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hbanner h1 em{color:var(--gold);font-style:normal}
.hbanner p{font-size:1.18rem;opacity:.95;max-width:560px;margin-bottom:28px;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.evfilter-wrap{background:linear-gradient(160deg,var(--blue),var(--blue-dark));padding:0 0 50px}
.evfilter-wrap .efind{max-width:640px;margin:0 auto;background:#fff;border-radius:16px;padding:8px;display:flex;gap:8px;box-shadow:0 18px 50px rgba(0,0,0,.28);transform:translateY(-26px)}
.evfilter-wrap .efind input{flex:1;border:0;outline:0;padding:13px 16px;font-size:1rem;font-family:var(--sans);border-radius:12px;color:var(--ink)}
.evfilter-wrap .efind button{border:0;background:var(--gold);color:#231a00;font-weight:700;padding:0 24px;border-radius:12px;cursor:pointer;font-family:var(--sans)}
.echips.dark{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:-10px}
.echips.dark .echip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:30px;padding:9px 18px;font-weight:600;font-size:.9rem;text-decoration:none;transition:.15s}
.echips.dark .echip:hover{background:rgba(255,255,255,.26)}
.echips.dark .echip.on{background:var(--gold);color:#231a00;border-color:var(--gold)}
@media(max-width:880px){.hbanner{min-height:460px}}


/* What people enjoy (experiences) v2.5 */
.expgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.exp{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow);transition:.2s}
.exp:hover{transform:translateY(-5px);border-color:var(--sky)}
.exp .ic{width:60px;height:60px;border-radius:16px;background:var(--cream);display:grid;place-items:center;font-size:1.8rem;margin-bottom:16px}
.exp h3{font-size:1.18rem;margin-bottom:8px}
.exp p{color:var(--muted);font-size:.95rem}
@media(max-width:880px){.expgrid{grid-template-columns:1fr}}

/* Single post banner v2.6 */
.postbanner{position:relative;overflow:hidden;color:#fff;background-size:cover;background-position:center;min-height:340px;display:flex;align-items:flex-end}
.postbanner-ov{position:absolute;inset:0;background:linear-gradient(rgba(6,28,58,.35),rgba(6,28,58,.85));z-index:1}
.postbanner .wrap{position:relative;z-index:2;padding-bottom:30px}
.postbanner-in{max-width:820px}
.pb-cat{display:inline-block;background:var(--gold);color:#231a00;font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;border-radius:20px;padding:5px 13px;margin-bottom:14px}
.postbanner h1{color:#fff;font-size:clamp(1.8rem,3.6vw,2.7rem);line-height:1.12;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.pb-meta{margin-top:12px;opacity:.92;font-size:.92rem}

/* FAQ accordion (homepage) v2.6 */
.faqwrap{max-width:820px;margin:0 auto;display:grid;gap:14px}
details.card{padding:0;overflow:hidden}
details.card>summary{list-style:none;cursor:pointer;padding:22px 26px;font-weight:700;font-family:var(--serif);font-size:1.1rem;display:flex;justify-content:space-between;align-items:center;gap:14px}
details.card>summary::-webkit-details-marker{display:none}
details.card>summary::after{content:"+";color:var(--gold);font-size:1.6rem;font-weight:800;flex:0 0 auto;line-height:1}
details.card[open]>summary::after{content:"\2013"}
details.card .faqbody{padding:0 26px 24px;color:var(--muted)}
