:root { --eb-primary: #0f75bc; --eb-dark: #0b1020; --eb-muted: #64748b; --eb-bg: #f6f8fb; --radius: 20px; }

html, body { margin: 0; padding: 0; font-family: "Space Grotesk", system-ui, -apple-system, sans-serif; color: #0b1020; background: #fff; }

#loader { position: fixed; inset: 0; display: grid; place-items: center; background: #ffffff; opacity: 0; pointer-events: none; transition: opacity .2s; }

#loader.is-visible { opacity: 1; pointer-events: auto; }

.spinner { width: 40px; height: 40px; border-radius: 50%; border: 4px solid #e5e7eb; border-top-color: var(--eb-primary); animation: spin 1s linear infinite; }

@keyframes spin { to { transform: rotate(360deg); } }

.card a, .card o { cursor: pointer !important; border: none !important; border-radius: var(--border-radius) !important; transition: var(--transition) !important; padding: 0.8rem 2rem !important; background: var(--primary-color) !important; color: #fff !important; font-size: 1rem !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 0.5rem; font-weight: 500; text-decoration: none; }

.card a:hover, .card o:hover { background: #fff !important; color: var(--primary-color) !important; border: 2px var(--primary-color) solid !important; }

.card i { font-size: 2.5rem; color: #666; }

#site-search-bar { position: relative; display: flex; flex-direction: column; align-items: center; overflow: visible; --search-w: clamp(280px, 92vw, 880px); }

.subbar #site-search-bar { width: 100%; }

#site-search-bar .eb-search { width: var(--search-w); box-sizing: border-box; margin-inline: 0; }

#site-search-bar .eb-search-results { position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%); width: var(--search-w); max-height: 70vh; overflow: auto; box-sizing: border-box; z-index: 50; margin: 0; }

.eb-search { width: min(1100px, 100%); display: flex; align-items: center; gap: 10px; border: 1px solid #e5e7eb; border-radius: var(--radius, 14px); padding: 10px 12px; box-shadow: 0 10px 24px rgba(2,6,23,.06); }

.eb-search i { opacity: .7; }

.eb-search input { flex: 1; border: none; outline: none; font: inherit; padding: 6px 2px; min-width: 120px; }

.eb-search .clear { border: none; background: #0b102008; padding: 4px 10px; border-radius: 10px; font-size: 18px; line-height: 1; cursor: pointer; }

.eb-search .clear:hover { background: #0b102012; }

.eb-search-results { width: min(1100px, 100%); margin-top: 10px; background: #fff; border: 1px solid #eef2f7; border-radius: var(--radius, 14px); box-shadow: 0 18px 36px rgba(2,6,23,.10); overflow: hidden; }

.eb-sg { border-top: 1px solid #f1f5f9; }

.eb-sg:first-child { border-top: none; }

.eb-sg-h { position: sticky; top: 0; z-index: 1; display: flex; align-items: center; gap: 8px; padding: 10px 12px; font-weight: 700; color: #0b1020; background: #f8fafc; }

.eb-sg-h .tag { font-weight: 700; font-size: .82rem; color: #64748b; }

.eb-r { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; padding: 10px 12px; cursor: pointer; border-top: 1px solid #f8fafc; }

.eb-r:hover { background: #f8fafc; }

.eb-r .thumb { width: 44px; height: 44px; flex: 0 0 auto; border-radius: 10px; background: #f1f5f9; overflow: hidden; display: grid; place-items: center; border: 1px solid #eef2f7; }

.eb-r .thumb img { width: 100%; height: 100%; object-fit: cover; }

.eb-r .meta { display: flex; flex-direction: column; gap: 2px; }

.eb-r .meta .t, .eb-r .meta .s { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.eb-r .t { font-weight: 700; }

.eb-r .s { font-size: .9rem; color: #64748b; }

.eb-r .chip { white-space: nowrap; max-width: 30ch; overflow: hidden; text-overflow: ellipsis; font-size: .78rem; padding: 4px 8px; border-radius: 999px; border: 1px solid #e5e7eb; color: #0b1020; }

.eb-empty { padding: 14px 12px; color: #64748b; }

.eb-hl mark { background: #0f75bc1a; color: inherit; padding: 0 2px; border-radius: 4px; }

.hero-wrap { position: relative; overflow: hidden; margin-top: 0; }

.hero-wrap .subbar { overflow-x: clip; }

.hero { position: relative; height: 68vh; max-height: 760px; min-height: 520px; display: grid; place-items: center; color: #fff !important; margin-top: 0px !important; padding-top: calc(var(--header-h) * .4) !important; }

.hero-slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity 1s ease; filter: brightness(.65); }

.hero-slide.is-active { opacity: 1; }

.hero-content { position: relative; z-index: 1; text-align: center; padding: 0 16px; max-width: 1100px; }

.hero-content p { color: white !important; }

.hero h1 { font-size: clamp(32px, 6vw, 64px); line-height: 1.08; margin: 0 0 14px; }

.hero p { font-size: clamp(16px, 2.6vw, 22px); opacity: .95; margin: 0 auto 24px; max-width: 900px; }

.hero-ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.subbar { display: flex; gap: 20px; justify-content: center; padding: 12px 16px; background: transparent !important; }

.btn { display: inline-flex; align-items: center; gap: 10px; padding: 12px 18px; border-radius: 12px; border: 1px solid transparent; font-weight: 700; text-decoration: none; }

.btn.primary { background: var(--eb-primary); color: #fff; }

.btn.secondary, .btn-secondary { background: #ffffff !important; color: #0b1020; border-color: #e5e7eb !important; }

.marquee { overflow: hidden; border-top: 1px solid #eef2f7; background: #fff; }

.marquee-track { display: flex; gap: 60px; align-items: center; animation: marquee 28s linear infinite; padding: 16px 0; }

.marquee img { height: 28px; opacity: .7; filter: grayscale(100%); }

@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

.section { padding: 56px 16px; background: #fff; }

.section.alt { background: var(--eb-bg); }

.container { max-width: 1200px; margin: 0 auto; }

.grid { display: grid; gap: 18px; }

.grid.cols-3 { grid-template-columns: repeat(1, minmax(0,1fr)); }

.card { background: #fff; border: 1px solid #eef2f7; border-radius: var(--radius); padding: 18px; box-shadow: 0 10px 30px rgba(2,6,23,0.05); }

.card h3 { margin: 6px 0 8px; }

.muted { color: var(--eb-muted); }

.carousel { position: relative; overflow: hidden; border-radius: var(--radius); border: 1px solid #eef2f7; background: #fff; }

.carousel-track { display: flex; transition: transform .6s ease; }

.carousel-slide { min-width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 16px; align-items: center; }

.phone { width: 100%; aspect-ratio: 9/19.5; border-radius: 20px; border: 1px solid #e5e7eb; background: #f9fafb; overflow: hidden; display: grid; place-items: center; }

.phone img { width: 100%; height: 100%; object-fit: cover; }

.carousel-nav { position: absolute; inset: auto 12px 12px auto; display: flex; gap: 8px; }

.dot { width: 10px; height: 10px; border-radius: 50%; background: #e5e7eb; }

.dot.is-active { background: var(--eb-primary); }

.events-grid { display: grid; grid-template-columns: repeat(1, minmax(0,1fr)); gap: 14px; }

.event-card { border: 1px solid #eef2f7; border-radius: var(--radius); overflow: hidden; background: #fff; display: flex; flex-direction: column; }

.event-card .poster { position: relative; width: 100%; aspect-ratio: 1/1; overflow: hidden; }

.event-card .poster > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }

.event-content { padding: 12px; display: flex; flex-direction: column; gap: 8px; }

.event-content h4 { margin: 0; font-size: 18px; }

.event-content .description { display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; }

.event-content .description.clamp-3 { -webkit-line-clamp: 3; line-clamp: 3; }

.price-tag { cursor: pointer !important; border: none !important; border-radius: var(--border-radius) !important; transition: var(--transition) !important; padding: 0.8rem 2rem !important; background: var(--primary-color); color: #fff !important; font-size: 1rem !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 0.5rem; font-weight: 500; }

.testi { display: grid; gap: 14px; }

.avatar { width: 40px; height: 40px; border-radius: 50%; background: #e5e7eb; }

.newsletter { display: flex; gap: 10px; flex-wrap: wrap; }

.newsletter input { flex: 1; min-width: 240px; padding: 12px 14px; border-radius: 12px; border: 1px solid #e5e7eb; }

.newsletter button { padding: 12px 16px; border-radius: 12px; background: var(--eb-primary); color: #fff; border: none; font-weight: 700; }

.coming-soon { padding: 56px 16px; background: var(--eb-bg, #f6f8fb); }

.coming-soon .wrap { max-width: 1100px; margin: 0 auto; display: grid; gap: 16px; }

.coming-soon h2 { margin: 0; }

.coming-soon .lead { color: var(--eb-muted, #64748b); margin: 0 0 6px; }

.countdown { display: grid; grid-auto-flow: column; gap: 10px; align-items: stretch; width: fit-content; }

.time-box { min-width: 86px; padding: 10px 12px; border-radius: var(--radius, 14px); background: #fff; border: 1px solid #eef2f7; text-align: center; box-shadow: 0 10px 24px rgba(2,6,23,.06); }

.time-box .val { font-size: 28px; font-weight: 800; line-height: 1; color: #0b1020; }

.time-box .lbl { margin-top: 6px; font-size: .82rem; color: var(--eb-muted, #64748b); }

.waitlist { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 10px; }

.waitlist input[type="email"] { flex: 1 1 260px; min-width: 220px; padding: 12px 14px; border: 1px solid #e5e7eb; border-radius: 12px; outline: none; }

.waitlist input[type="email"]:focus { border-color: var(--eb-primary, #0f75bc); box-shadow: 0 0 0 4px color-mix(in oklab, var(--eb-primary, #0f75bc) 20%, transparent); }

.waitlist button { padding: 12px 16px; border-radius: 12px; border: none; font-weight: 700; background: var(--eb-primary, #0f75bc); color: #fff; }

.waitlist .hint { color: var(--eb-muted, #64748b); font-size: .9rem; }

footer { background: #0b1020; color: #cbd5e1; margin-top: 40px; }

footer a { color: #cbd5e1; text-decoration: none; }

.footer-links h4 { color: #fff; margin-bottom: 10px; }

.footer-grid { display: grid; gap: 20px; grid-template-columns: repeat(1, minmax(0,1fr)); }

nav a.is-current, footer a.is-current { display: none; }

.hamburger span { background-color: white; }

@media (max-width: 640px) { .eb-r { grid-template-columns: 1fr auto; } .eb-r .thumb { display: none; } .countdown { grid-auto-flow: row; width: 100%; } .time-box { width: 100%; } }

@media (min-width: 740px) { .events-grid { grid-template-columns: repeat(3, minmax(0,1fr)); } }

@media (min-width: 768px) { .event-content .description.clamp-3 { -webkit-line-clamp: 4; line-clamp: 4; } }

@media (min-width: 820px) { .grid.cols-3 { grid-template-columns: repeat(3, minmax(0,1fr)); } .testi { grid-template-columns: 1fr 1fr; } }

@media (min-width: 900px) { .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }

@media (min-width: 1024px) { #coming-soon, #coming-soon.section { display: flex; justify-content: center; align-items: center; } #coming-soon .wrap { max-width: 800px; width: 100%; text-align: center; margin: 0 auto; } #coming-soon h2 { font-size: 3rem; } #coming-soon .countdown { display: flex !important; justify-content: center !important; margin: 2rem auto !important; flex-wrap: wrap !important; align-items: center !important; align-self: center !important; align-content: center !important; } #coming-soon .time-box { display: flex; flex-direction: column; align-items: center; min-width: 120px; } #coming-soon .lead { font-size: 1.25rem; max-width: 600px; margin-left: auto; margin-right: auto; } #coming-soon .waitlist { display: flex; justify-content: center; align-items: center; gap: 1rem; max-width: 500px; margin: 2rem auto 0; flex-wrap: wrap; } #coming-soon .waitlist input { flex: 1; min-width: 250px; padding: 1rem; font-size: 1rem; } #coming-soon .waitlist button { padding: 1rem 2rem; font-size: 1rem; white-space: nowrap; } }

@media (min-width: 1200px) { .hero, .section, .mobile-app-cta, .newsletter-signup, .hero-wrap .subbar { width: 100vw !important; max-width: 100vw !important; margin-inline: calc(50% - 50vw) !important; padding-inline: clamp(24px, 4vw, 64px) !important; } .hero { min-height: 100vh !important; display: grid; place-items: center; position: relative; overflow: hidden; height: 100vh !important; } .hero-slide { position: absolute; inset: 0; background-size: cover; background-position: center; } .hero-content { position: relative; z-index: 2; max-width: 1200px; } .hero-wrap .subbar { min-height: 56px; display: grid; place-items: center; } }