:root {
    --efc-bg: #020711;
    --efc-bg-2: #071029;
    --efc-ink: #ffffff;
    --efc-muted: rgba(255,255,255,.72);
    --efc-soft: rgba(255,255,255,.12);
    --efc-line: rgba(255,255,255,.16);
    --efc-accent-1: #17d7ff;
    --efc-accent-2: #9b5cff;
    --efc-accent-3: #31f6c6;
    --efc-radius: 28px;
    --efc-glow: 0 0 44px rgba(23,215,255,.32), 0 0 90px rgba(155,92,255,.20);
    --efc-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.efora-channel-theme {
    margin: 0;
    font-family: var(--efc-font);
    background: var(--efc-bg);
    color: var(--efc-ink);
    overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
.efc-site-shell {
    min-height: 100vh;
    background:
        radial-gradient(circle at 78% 18%, rgba(23,215,255,.18), transparent 32%),
        radial-gradient(circle at 85% 65%, rgba(155,92,255,.22), transparent 34%),
        linear-gradient(180deg, #030712 0%, #071026 54%, #020711 100%);
    position: relative;
}
.efc-site-shell::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: radial-gradient(circle at center, black, transparent 72%);
    opacity: .22;
    z-index: 0;
}
.efc-header {
    position: fixed;
    top: 18px;
    left: 50%;
    transform: translateX(-50%);
    width: min(1480px, calc(100% - 44px));
    min-height: 74px;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    padding: 14px 22px;
    border: 1px solid rgba(255,255,255,.11);
    border-radius: 999px;
    background: rgba(3, 7, 18, .56);
    backdrop-filter: blur(18px);
    box-shadow: 0 20px 70px rgba(0,0,0,.35), inset 0 1px rgba(255,255,255,.06);
}
.efc-brand { display: flex; align-items: center; gap: 16px; min-width: 220px; }
.efc-brand-mark { position: relative; width: 38px; height: 32px; display: inline-grid; align-items: center; }
.efc-brand-mark span {
    display: block; height: 6px; width: 34px; border-radius: 999px;
    background: linear-gradient(90deg, var(--efc-accent-3), var(--efc-accent-1), var(--efc-accent-2));
    box-shadow: 0 0 20px rgba(23,215,255,.45);
    margin: 2px 0;
}
.efc-brand-mark span:nth-child(2) { width: 27px; margin-left: 7px; opacity: .86; }
.efc-brand-mark span:nth-child(3) { width: 20px; margin-left: 14px; opacity: .74; }
.efc-brand-text strong { display: block; letter-spacing: .32em; text-transform: uppercase; font-size: 23px; line-height: 1; font-weight: 700; }
.efc-brand-text em { display: block; margin-top: 7px; letter-spacing: .42em; text-transform: uppercase; color: var(--efc-accent-3); font-style: normal; font-size: 10px; }
.efc-nav { display: flex; justify-content: flex-end; flex: 1; }
.efc-menu, .efc-footer-menu { display: flex; align-items: center; gap: clamp(18px, 3vw, 48px); list-style: none; padding: 0; margin: 0; }
.efc-menu a { color: rgba(255,255,255,.78); text-transform: uppercase; letter-spacing: .18em; font-size: 12px; font-weight: 700; transition: color .25s ease, text-shadow .25s ease; }
.efc-menu a:hover { color: #fff; text-shadow: 0 0 18px rgba(23,215,255,.65); }
.efc-menu-toggle { display: none; width: 46px; height: 46px; border: 1px solid var(--efc-line); background: rgba(255,255,255,.04); border-radius: 16px; padding: 11px; }
.efc-menu-toggle span { display: block; height: 2px; background: #fff; border-radius: 999px; margin: 5px 0; }

.efc-hero { min-height: 100vh; position: relative; overflow: hidden; display: grid; align-items: center; padding: 144px 0 80px; z-index: 1; }
.efc-particles { position: absolute; inset: 0; width: 100%; height: 100%; opacity: .88; z-index: 1; }
.efc-hero::before,
.efc-hero::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    filter: blur(16px);
    opacity: .75;
    pointer-events: none;
    z-index: 0;
}
.efc-hero::before { width: 680px; height: 680px; right: 4%; top: 16%; background: radial-gradient(circle, rgba(23,215,255,.17), rgba(155,92,255,.10) 43%, transparent 70%); animation: efcPulse 8s ease-in-out infinite; }
.efc-hero::after { width: 1080px; height: 280px; right: -8%; bottom: 6%; background: linear-gradient(90deg, transparent, rgba(23,215,255,.20), rgba(155,92,255,.18), transparent); transform: rotate(-12deg); animation: efcDrift 12s ease-in-out infinite; }
.efc-hero-grid { position: relative; z-index: 3; width: min(1480px, calc(100% - 72px)); margin: 0 auto; display: grid; grid-template-columns: minmax(420px, .88fr) minmax(520px, 1.12fr); align-items: center; gap: clamp(30px, 5vw, 80px); }
.efc-eyebrow { display: flex; align-items: center; gap: 16px; color: rgba(255,255,255,.84); font-size: 14px; letter-spacing: .42em; text-transform: uppercase; font-weight: 800; margin-bottom: 34px; }
.efc-eyebrow span { width: 62px; height: 3px; border-radius: 999px; background: linear-gradient(90deg, var(--efc-accent-3), var(--efc-accent-2)); box-shadow: 0 0 18px rgba(23,215,255,.75); }
.efc-hero h1 { font-size: clamp(54px, 7.2vw, 112px); line-height: .96; letter-spacing: -.065em; margin: 0 0 32px; font-weight: 600; max-width: 820px; }
.efc-hero h1 span { background: linear-gradient(100deg, var(--efc-accent-1), var(--efc-accent-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.efc-subheadline { max-width: 560px; color: var(--efc-muted); font-size: clamp(21px, 2.4vw, 30px); line-height: 1.45; margin: 0 0 38px; }
.efc-cta-row { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; }
.efc-cta-row.center { justify-content: center; }
.efc-btn { min-height: 62px; display: inline-flex; align-items: center; justify-content: center; gap: 14px; padding: 0 28px; border-radius: 22px; border: 1px solid rgba(255,255,255,.18); font-weight: 800; font-size: 15px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.efc-btn:hover { transform: translateY(-2px); }
.efc-btn-primary { background: linear-gradient(135deg, rgba(23,215,255,.92), rgba(155,92,255,.95)); box-shadow: 0 0 34px rgba(23,215,255,.28), 0 0 60px rgba(155,92,255,.18); color: #fff; }
.efc-btn-ghost { background: rgba(255,255,255,.04); border-color: rgba(23,215,255,.45); color: #fff; backdrop-filter: blur(14px); }
.efc-play { width: 30px; height: 30px; border: 2px solid rgba(255,255,255,.8); border-radius: 999px; position: relative; flex: 0 0 auto; }
.efc-play::after { content: ""; position: absolute; top: 8px; left: 11px; border-left: 9px solid #fff; border-top: 6px solid transparent; border-bottom: 6px solid transparent; }
.efc-people { width: 28px; height: 28px; position: relative; border: 1px solid rgba(255,255,255,.55); border-radius: 999px; flex: 0 0 auto; }
.efc-people::before, .efc-people::after { content: ""; position: absolute; border-radius: 999px; border: 1px solid rgba(255,255,255,.75); }
.efc-people::before { width: 7px; height: 7px; top: 6px; left: 9px; }
.efc-people::after { width: 16px; height: 8px; bottom: 5px; left: 5px; border-top-left-radius: 10px; border-top-right-radius: 10px; }
.efc-hero-visual { min-height: 620px; position: relative; }
.efc-stage { position: absolute; inset: 0; display: grid; place-items: center; perspective: 1200px; }
.efc-ring { width: clamp(360px, 42vw, 640px); height: clamp(360px, 42vw, 640px); border-radius: 999px; position: relative; background: radial-gradient(circle, rgba(3,7,18,.82) 0 42%, transparent 43%), conic-gradient(from 40deg, rgba(23,215,255,.95), rgba(155,92,255,.88), rgba(49,246,198,.7), rgba(23,215,255,.95)); box-shadow: inset 0 0 60px rgba(255,255,255,.13), 0 0 80px rgba(23,215,255,.3), 0 0 130px rgba(155,92,255,.22); animation: efcRingRotate 22s linear infinite; }
.efc-ring::before, .efc-ring::after { content: ""; position: absolute; inset: 10%; border-radius: inherit; border: 1px solid rgba(255,255,255,.16); box-shadow: 0 0 40px rgba(23,215,255,.18); }
.efc-ring::after { inset: -12%; border-color: rgba(155,92,255,.20); transform: rotateX(62deg) rotateZ(-18deg); }
.efc-ring-core { position: absolute; inset: 24%; display: grid; place-items: center; align-content: center; border-radius: inherit; background: radial-gradient(circle, rgba(0,0,0,.45), rgba(3,7,18,.7)); animation: efcCounterRotate 22s linear infinite; }
.efc-ring-core strong { display: block; font-size: clamp(38px, 5vw, 78px); line-height: 1; font-weight: 500; letter-spacing: -.03em; }
.efc-ring-core span { display: block; margin-top: 18px; color: var(--efc-accent-3); letter-spacing: .42em; text-transform: uppercase; font-weight: 800; font-size: clamp(12px, 1.3vw, 18px); }
.efc-float-card { position: absolute; width: 190px; min-height: 118px; padding: 20px; border-radius: 22px; border: 1px solid rgba(23,215,255,.38); background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.04)); backdrop-filter: blur(14px); box-shadow: 0 18px 70px rgba(0,0,0,.32), 0 0 36px rgba(23,215,255,.14); transform-style: preserve-3d; animation: efcFloat 7s ease-in-out infinite; }
.efc-float-card b { display: block; text-transform: uppercase; letter-spacing: .07em; font-size: 13px; line-height: 1.25; }
.efc-float-card small { display: block; color: rgba(255,255,255,.68); margin-top: 9px; font-size: 12px; line-height: 1.35; }
.card-a { left: 6%; top: 23%; transform: rotateY(18deg) rotateZ(-6deg); }
.card-b { left: 12%; bottom: 18%; animation-delay: -1.2s; }
.card-c { right: 4%; top: 18%; animation-delay: -2s; }
.card-d { right: 1%; bottom: 20%; animation-delay: -3.2s; }
.efc-hero-orbits { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.orbit { position: absolute; border-radius: 999px; border: 1px solid rgba(23,215,255,.15); box-shadow: 0 0 50px rgba(23,215,255,.12); }
.orbit-1 { width: 900px; height: 180px; right: 2%; bottom: 13%; transform: rotate(-12deg); animation: efcOrbit 12s ease-in-out infinite; }
.orbit-2 { width: 720px; height: 140px; right: 8%; bottom: 22%; transform: rotate(18deg); animation: efcOrbit 15s ease-in-out infinite reverse; }
.orbit-3 { width: 640px; height: 640px; right: 8%; top: 18%; opacity: .22; animation: efcPulse 9s ease-in-out infinite; }
.efc-scroll { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 5; display: grid; justify-items: center; gap: 8px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .28em; font-size: 10px; }
.efc-scroll span { width: 2px; height: 48px; border-radius: 999px; background: linear-gradient(var(--efc-accent-1), transparent); }
.efc-section { position: relative; z-index: 2; padding: clamp(74px, 9vw, 140px) 36px; }
.efc-section-inner, .efc-section-head, .efc-card-grid, .efc-split { width: min(1180px, 100%); margin: 0 auto; }
.efc-section-inner { text-align: center; }
.efc-section h2 { margin: 0; font-size: clamp(34px, 5vw, 72px); line-height: 1.02; letter-spacing: -.055em; }
.efc-section p { color: var(--efc-muted); font-size: 19px; line-height: 1.72; }
.efc-kicker { color: var(--efc-accent-3); text-transform: uppercase; letter-spacing: .26em; font-size: 12px; font-weight: 900; margin-bottom: 18px; }
.efc-what { background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.04)); }
.efc-mini-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 44px; }
.efc-mini-grid div, .efc-card, .efc-proof-card { border: 1px solid rgba(255,255,255,.12); border-radius: var(--efc-radius); background: linear-gradient(145deg, rgba(255,255,255,.10), rgba(255,255,255,.035)); box-shadow: 0 24px 90px rgba(0,0,0,.22), inset 0 1px rgba(255,255,255,.08); backdrop-filter: blur(18px); }
.efc-mini-grid div { padding: 26px; text-align: left; }
.efc-mini-grid strong, .efc-mini-grid span { display: block; }
.efc-mini-grid strong { margin-bottom: 10px; }
.efc-mini-grid span { color: rgba(255,255,255,.64); line-height: 1.5; }
.efc-section-head { text-align: center; margin-bottom: 40px; }
.efc-card-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 18px; }
.efc-card { padding: 28px 24px; min-height: 260px; position: relative; overflow: hidden; }
.efc-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 0, rgba(23,215,255,.16), transparent 38%); opacity: .9; pointer-events: none; }
.efc-card span { display: block; width: 36px; height: 4px; border-radius: 999px; background: linear-gradient(90deg, var(--efc-accent-1), var(--efc-accent-2)); margin-bottom: 28px; box-shadow: 0 0 22px rgba(23,215,255,.35); }
.efc-card h3 { position: relative; margin: 0 0 14px; font-size: 21px; line-height: 1.15; }
.efc-card p { position: relative; font-size: 15px; line-height: 1.55; margin: 0; }
.efc-split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items: center; }
.efc-proof-card { padding: 36px; }
.efc-proof-card ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 18px; }
.efc-proof-card li { position: relative; padding-left: 32px; color: rgba(255,255,255,.82); line-height: 1.55; }
.efc-proof-card li::before { content: ""; position: absolute; top: 9px; left: 0; width: 14px; height: 14px; border-radius: 999px; background: linear-gradient(135deg, var(--efc-accent-1), var(--efc-accent-2)); box-shadow: 0 0 22px rgba(23,215,255,.35); }
.efc-partners { background: radial-gradient(circle at 50% 0, rgba(155,92,255,.16), transparent 44%); }
.efc-footer { position: relative; z-index: 2; width: min(1480px, calc(100% - 72px)); margin: 0 auto; padding: 34px 0 54px; display: flex; justify-content: space-between; gap: 20px; color: rgba(255,255,255,.6); border-top: 1px solid rgba(255,255,255,.12); }
.efc-footer-links, .efc-footer-menu { display: flex; gap: 22px; flex-wrap: wrap; }
.efc-footer a { color: rgba(255,255,255,.72); }
.efc-simple-page { min-height: 100vh; padding: 140px 24px; background: #030712; }
.efc-content-shell { width: min(980px, 100%); margin: 0 auto; color: #fff; }
.efc-entry { border: 1px solid var(--efc-line); border-radius: 28px; padding: 32px; background: rgba(255,255,255,.04); }
.efc-reveal { opacity: 0; transform: translateY(22px); transition: opacity .8s ease, transform .8s ease; }
.efc-reveal.is-visible { opacity: 1; transform: none; }
@keyframes efcPulse { 0%,100% { transform: scale(1); opacity: .66; } 50% { transform: scale(1.07); opacity: .92; } }
@keyframes efcDrift { 0%,100% { transform: translate3d(0,0,0) rotate(-12deg); } 50% { transform: translate3d(-5%, -4%,0) rotate(-9deg); } }
@keyframes efcRingRotate { to { transform: rotate(360deg); } }
@keyframes efcCounterRotate { to { transform: rotate(-360deg); } }
@keyframes efcFloat { 0%,100% { translate: 0 0; } 50% { translate: 0 -18px; } }
@keyframes efcOrbit { 0%,100% { opacity: .32; translate: 0 0; } 50% { opacity: .62; translate: -18px -10px; } }
@media (max-width: 1180px) {
    .efc-hero-grid { grid-template-columns: 1fr; padding-top: 50px; }
    .efc-hero-visual { min-height: 560px; order: -1; opacity: .85; }
    .efc-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .efc-card-grid .efc-card:last-child { grid-column: span 2; }
}
@media (max-width: 900px) {
    .efc-header { top: 12px; width: calc(100% - 24px); border-radius: 24px; padding: 12px 14px; min-height: 64px; }
    .efc-menu-toggle { display: block; }
    .efc-nav { position: absolute; top: calc(100% + 10px); right: 0; width: min(340px, 100%); padding: 18px; border: 1px solid var(--efc-line); border-radius: 24px; background: rgba(3,7,18,.92); backdrop-filter: blur(18px); transform: translateY(-8px); opacity: 0; pointer-events: none; transition: opacity .25s ease, transform .25s ease; }
    .efc-nav.is-open { opacity: 1; transform: none; pointer-events: auto; }
    .efc-menu { align-items: stretch; flex-direction: column; gap: 0; }
    .efc-menu a { display: block; padding: 14px 10px; }
    .efc-brand { min-width: 0; }
    .efc-brand-text strong { font-size: 18px; }
    .efc-brand-text em { letter-spacing: .24em; }
    .efc-hero { padding-top: 110px; }
    .efc-hero-grid { width: min(100% - 36px, 720px); }
    .efc-hero-visual { min-height: 430px; }
    .efc-float-card { width: 154px; min-height: 96px; padding: 14px; }
    .efc-mini-grid, .efc-split { grid-template-columns: 1fr; }
    .efc-card-grid { grid-template-columns: 1fr; }
    .efc-card-grid .efc-card:last-child { grid-column: auto; }
    .efc-footer { width: min(100% - 36px, 720px); flex-direction: column; }
}
@media (max-width: 560px) {
    .efc-hero h1 { font-size: clamp(44px, 14vw, 70px); }
    .efc-subheadline { font-size: 19px; }
    .efc-btn { width: 100%; }
    .efc-stage { transform: scale(.82); }
    .card-a { left: -8%; } .card-b { left: -2%; } .card-c { right: -8%; } .card-d { right: -10%; }
    .efc-section { padding-left: 20px; padding-right: 20px; }
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; }
    .efc-particles { display: none; }
}

/* v3.1.3 futuristic hero + sharper Singularity palette */
:root {
    --efc-bg: #01030d;
    --efc-bg-2: #0b1133;
    --efc-muted: rgba(236, 243, 255, .8);
    --efc-soft: rgba(120, 118, 255, .16);
    --efc-line: rgba(156, 172, 255, .18);
    --efc-accent-1: #52e8ff;
    --efc-accent-2: #9f69ff;
    --efc-accent-3: #577cff;
    --efc-glow: 0 0 58px rgba(82,232,255,.40), 0 0 120px rgba(159,105,255,.32), 0 0 160px rgba(87,124,255,.18);
}

body.efora-channel-theme {
    background:
        radial-gradient(circle at 78% 14%, rgba(88,224,255,.20), transparent 18%),
        radial-gradient(circle at 92% 64%, rgba(165,98,255,.22), transparent 24%),
        radial-gradient(circle at 72% 36%, rgba(84,92,255,.14), transparent 20%),
        linear-gradient(180deg, #01030c 0%, #040717 44%, #030512 100%);
}

.efc-site-shell {
    background:
        radial-gradient(circle at 72% 14%, rgba(75, 214, 255, .14), transparent 20%),
        radial-gradient(circle at 86% 54%, rgba(156, 104, 255, .24), transparent 28%),
        radial-gradient(circle at 64% 78%, rgba(72, 102, 255, .16), transparent 24%),
        linear-gradient(180deg, #01030c 0%, #050a1f 40%, #060b21 68%, #02040f 100%);
}

.efc-site-shell::before {
    background-image:
        linear-gradient(rgba(255,255,255,.024) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
    background-size: 92px 92px;
    mask-image: radial-gradient(circle at 52% 22%, black, transparent 78%);
    opacity: .18;
}

.efc-site-shell::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 70% 26%, rgba(69,229,255,.12), transparent 20%),
        radial-gradient(circle at 84% 66%, rgba(154,104,255,.18), transparent 18%),
        radial-gradient(circle at 62% 42%, rgba(87,124,255,.14), transparent 18%),
        radial-gradient(circle at 28% 72%, rgba(53,90,220,.08), transparent 24%);
    filter: blur(32px);
    animation: efcSlowDrift 18s ease-in-out infinite;
    z-index: 0;
}

.efc-header {
    border-color: rgba(157, 187, 255, .13);
    background: rgba(3, 8, 24, .58);
    box-shadow: 0 20px 70px rgba(0,0,0,.42), inset 0 1px rgba(255,255,255,.06), 0 0 0 1px rgba(75,125,255,.05);
}

.efc-brand-mark span {
    background: linear-gradient(90deg, #67ecff, #5e9fff, #a96eff);
    box-shadow: 0 0 18px rgba(69,229,255,.44);
}

.efc-menu a,
.efc-footer a { color: rgba(246, 249, 255, .78); }
.efc-menu a:hover,
.efc-footer a:hover { color: #fff; text-shadow: 0 0 22px rgba(69,229,255,.58); }

.efc-hero {
    padding: 146px 0 88px;
    overflow: visible;
}

.efc-hero .efc-container,
.efc-hero-grid,
.efc-hero-visual {
    overflow: visible;
}

.efc-particles {
    opacity: 1;
    mix-blend-mode: screen;
    filter: saturate(1.18) brightness(1.08);
}

.efc-particles::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.efc-hero::before,
.efc-hero::after {
    filter: blur(22px);
    opacity: .92;
}

.efc-hero::before {
    width: min(1080px, 68vw);
    height: min(1080px, 68vw);
    right: -4%;
    top: -1%;
    background: radial-gradient(circle, rgba(82,232,255,.30) 0%, rgba(82,232,255,.12) 24%, rgba(159,105,255,.16) 44%, rgba(87,124,255,.10) 56%, transparent 72%);
    animation: efcHeroGlow 10s ease-in-out infinite;
}

.efc-hero::after {
    width: min(1260px, 92vw);
    height: 380px;
    right: -6%;
    bottom: 2%;
    background: linear-gradient(90deg, transparent 2%, rgba(74,92,255,.12) 18%, rgba(64,234,255,.18) 42%, rgba(153,107,255,.26) 70%, transparent 98%);
    transform: rotate(-10deg);
    animation: efcLightSweep 14s ease-in-out infinite;
}

.efc-hero-grid {
    width: min(1500px, calc(100% - 72px));
    grid-template-columns: minmax(420px, .78fr) minmax(620px, 1.22fr);
    gap: clamp(26px, 4.4vw, 74px);
}

.efc-eyebrow {
    margin-bottom: 28px;
    color: rgba(243,247,255,.88);
    text-shadow: 0 0 16px rgba(69,229,255,.28);
}

.efc-eyebrow span {
    width: 60px;
    background: linear-gradient(90deg, var(--efc-accent-1), var(--efc-accent-2));
    box-shadow: 0 0 20px rgba(69,229,255,.55);
}

.efc-hero h1 {
    font-size: clamp(64px, 7.5vw, 124px);
    line-height: .94;
    font-weight: 500;
    letter-spacing: -.072em;
    margin-bottom: 28px;
    text-shadow: 0 4px 28px rgba(0,0,0,.2);
}

.efc-hero h1 span {
    background: linear-gradient(98deg, #57efff 6%, #5ab3ff 42%, #b076ff 92%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 0 18px rgba(82,229,255,.18));
}

.efc-subheadline {
    max-width: 540px;
    color: rgba(226, 235, 252, .76);
    font-size: clamp(19px, 2.1vw, 28px);
    line-height: 1.5;
    margin-bottom: 36px;
}

.efc-btn {
    border-radius: 24px;
    min-height: 64px;
    padding: 0 30px;
}

.efc-btn-primary {
    background: linear-gradient(135deg, rgba(57,214,255,.96), rgba(79,157,255,.94) 40%, rgba(156,103,255,.95));
    border-color: rgba(150, 209, 255, .42);
    box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 0 34px rgba(57,214,255,.35), 0 0 68px rgba(156,103,255,.18), 0 10px 36px rgba(5,10,30,.35);
}

.efc-btn-primary:hover {
    box-shadow: 0 0 0 1px rgba(255,255,255,.12) inset, 0 0 42px rgba(57,214,255,.42), 0 0 78px rgba(156,103,255,.26), 0 16px 46px rgba(5,10,30,.42);
}

.efc-btn-ghost {
    background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
    border-color: rgba(94,180,255,.32);
    box-shadow: inset 0 1px rgba(255,255,255,.05), 0 0 0 1px rgba(103,159,255,.04), 0 12px 28px rgba(2,7,22,.3);
}

.efc-hero-visual {
    min-height: 860px;
    position: relative;
    z-index: 1;
}

.efc-stage {
    position: absolute;
    inset: -176px calc((max(36px, (100vw - 1500px) / 2) * -1) - 160px) -6% 0;
    display: block;
    overflow: hidden;
    border-radius: 42px;
    transition: transform .35s ease-out;
    will-change: transform;
}

.efc-stage::before,
.efc-stage::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
}

.efc-stage::before {
    width: 78%;
    height: 78%;
    right: 2%;
    top: 6%;
    background: radial-gradient(circle, rgba(82,236,255,.42) 0%, rgba(82,236,255,.18) 32%, rgba(140,97,255,.22) 54%, rgba(87,124,255,.12) 64%, transparent 78%);
    filter: blur(24px);
    animation: efcHeroGlow 11s ease-in-out infinite;
}

.efc-stage::after {
    width: 92%;
    height: 34%;
    left: 0%;
    bottom: 1%;
    background: linear-gradient(90deg, transparent 0%, rgba(66,110,255,.20) 16%, rgba(60,231,255,.22) 38%, rgba(145,99,255,.32) 72%, transparent 100%);
    filter: blur(24px);
    transform: rotate(-11deg);
    opacity: .92;
    animation: efcLightSweep 18s ease-in-out infinite;
}

.efc-stage-ambience {
    position: absolute;
    border-radius: 999px;
    filter: blur(86px);
    opacity: .68;
    pointer-events: none;
    mix-blend-mode: screen;
    animation: efcAmbientFloat 14s ease-in-out infinite;
}

.ambience-one {
    width: 56%;
    height: 54%;
    top: 2%;
    right: 8%;
    background: radial-gradient(circle, rgba(69,229,255,1), rgba(69,229,255,.38) 34%, rgba(87,124,255,.16) 52%, transparent 76%);
}

.ambience-two {
    width: 52%;
    height: 46%;
    right: -2%;
    bottom: 1%;
    background: radial-gradient(circle, rgba(157,103,255,.98), rgba(157,103,255,.36) 34%, rgba(87,124,255,.14) 52%, transparent 74%);
    animation-delay: -4.2s;
}

.ambience-three {
    width: 40%;
    height: 34%;
    left: 18%;
    bottom: 18%;
    background: radial-gradient(circle, rgba(61,129,255,.94), rgba(61,129,255,.28) 40%, rgba(132,95,255,.10) 60%, transparent 78%);
    animation-delay: -8s;
}

.efc-stage-rings {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.ring-line {
    position: absolute;
    border-radius: 50%;
    border: 1px solid rgba(132, 149, 255, .20);
    box-shadow: 0 0 26px rgba(68,173,255,.10);
    opacity: .9;
    animation: efcArcFloat 14s ease-in-out infinite;
}

.ring-line-one {
    width: 70%;
    height: 86%;
    right: 2%;
    top: 8%;
    border-left-color: transparent;
    border-top-color: rgba(69,229,255,.16);
    border-bottom-color: rgba(167,102,255,.44);
    transform: rotate(-10deg);
}

.ring-line-two {
    width: 44%;
    height: 54%;
    right: 14%;
    top: 32%;
    border-right-color: transparent;
    border-left-color: rgba(69,229,255,.34);
    border-bottom-color: rgba(69,229,255,.12);
    transform: rotate(6deg);
    animation-delay: -5s;
}

.ring-line-three {
    width: 58%;
    height: 20%;
    left: 4%;
    bottom: 10%;
    border-top-color: rgba(63,184,255,.18);
    border-right-color: rgba(154,104,255,.12);
    border-left-color: transparent;
    border-bottom-color: rgba(63,184,255,.10);
    transform: rotate(12deg);
    animation-delay: -8s;
}

.efc-hero-art {
    position: absolute;
    inset: 0;
    background-repeat: no-repeat;
    background-size: auto 118%;
    background-position: right 48%;
    opacity: var(--efc-hero-image-opacity, .92);
    filter: saturate(1.16) brightness(.94) contrast(1.04) drop-shadow(0 0 40px rgba(83,236,255,.18)) drop-shadow(0 0 110px rgba(154,104,255,.22));
    transform-origin: 60% 50%;
    animation: efcHeroArtFloat 16s ease-in-out infinite;
    -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.18) 10%, rgba(0,0,0,.82) 20%, #000 32%, #000 100%);
    mask-image: linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.18) 10%, rgba(0,0,0,.82) 20%, #000 32%, #000 100%);
}

.efc-hero-art::before,
.efc-hero-art::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    mix-blend-mode: screen;
}

.efc-hero-art::before {
    background:
        radial-gradient(circle at 73% 18%, rgba(220, 246, 255, .78) 0 1px, rgba(82,232,255,.26) 2px, transparent 7px),
        radial-gradient(circle at 77% 23%, rgba(255, 247, 226, .92) 0 1.2px, rgba(159,105,255,.22) 2.8px, transparent 9px),
        radial-gradient(circle at 72% 31%, rgba(230, 249, 255, .70) 0 1px, rgba(82,232,255,.18) 2px, transparent 8px),
        radial-gradient(circle at 76% 36%, rgba(230, 249, 255, .76) 0 1.4px, rgba(82,232,255,.22) 2.4px, transparent 10px),
        radial-gradient(circle at 70% 42%, rgba(255, 241, 211, .74) 0 1px, rgba(159,105,255,.16) 2.2px, transparent 8px),
        radial-gradient(circle at 80% 47%, rgba(231, 248, 255, .72) 0 1px, rgba(82,232,255,.16) 2px, transparent 7px),
        radial-gradient(circle at 74% 54%, rgba(224, 246, 255, .54) 0 1px, rgba(87,124,255,.12) 2px, transparent 9px),
        radial-gradient(circle at 68% 26%, rgba(82,232,255,.14), transparent 10%),
        radial-gradient(circle at 73% 36%, rgba(82,232,255,.16), transparent 12%),
        radial-gradient(circle at 78% 44%, rgba(159,105,255,.16), transparent 12%);
    filter: blur(.15px) drop-shadow(0 0 10px rgba(82,232,255,.36)) drop-shadow(0 0 20px rgba(159,105,255,.18));
    animation: efcFaceSparkle 8s ease-in-out infinite;
}

.efc-hero-art::after {
    background:
        radial-gradient(circle at 74% 29%, rgba(82,232,255,.16), transparent 12%),
        radial-gradient(circle at 76% 39%, rgba(159,105,255,.12), transparent 12%),
        radial-gradient(circle at 71% 48%, rgba(87,124,255,.10), transparent 12%),
        linear-gradient(120deg, transparent 62%, rgba(82,232,255,.08) 72%, transparent 82%);
    filter: blur(12px);
    opacity: .95;
    animation: efcFaceGlow 10s ease-in-out infinite;
}

.efc-stage-star {
    position: absolute;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: #dff7ff;
    box-shadow: 0 0 18px rgba(73,232,255,.92), 0 0 34px rgba(154,104,255,.52), 0 0 62px rgba(87,124,255,.24);
    animation: efcTwinkle 4.6s ease-in-out infinite;
}

.star-a { top: 14%; right: 38%; animation-delay: -.4s; }
.star-b { top: 24%; right: 12%; width: 5px; height: 5px; animation-delay: -1.2s; }
.star-c { top: 53%; right: 24%; width: 6px; height: 6px; animation-delay: -2.1s; }
.star-d { top: 72%; right: 14%; width: 8px; height: 8px; animation-delay: -3.3s; }
.star-e { bottom: 18%; left: 26%; width: 5px; height: 5px; animation-delay: -2.8s; }
.star-f { bottom: 8%; right: 42%; width: 6px; height: 6px; animation-delay: -1.8s; }

.efc-scroll {
    bottom: 14px;
    gap: 10px;
    color: rgba(238,243,255,.56);
    letter-spacing: .34em;
    font-size: 11px;
}

.efc-scroll span {
    width: 3px;
    height: 54px;
    background: linear-gradient(180deg, rgba(71,232,255,.92), rgba(152,105,255,.16));
    box-shadow: 0 0 16px rgba(71,232,255,.34);
}

.efc-mini-grid div,
.efc-card,
.efc-proof-card,
.efc-entry {
    border-color: rgba(133, 161, 255, .14);
    background: linear-gradient(145deg, rgba(10, 17, 44, .82), rgba(7, 12, 31, .56));
    box-shadow: 0 26px 90px rgba(0,0,0,.28), inset 0 1px rgba(255,255,255,.07), 0 0 0 1px rgba(70,100,210,.06);
}

.efc-card::before,
.efc-what {
    background-image: radial-gradient(circle at 20% 0, rgba(69,229,255,.12), transparent 38%);
}

.efc-kicker,
.efc-brand-text em {
    color: #53e9ff;
}

.efc-footer {
    border-top-color: rgba(147,176,255,.12);
}

@keyframes efcHeroGlow {
    0%, 100% { transform: scale(1) translate3d(0,0,0); opacity: .88; }
    50% { transform: scale(1.08) translate3d(-1.5%, 2%, 0); opacity: 1; }
}

@keyframes efcLightSweep {
    0%, 100% { transform: translate3d(0,0,0) rotate(-10deg); opacity: .62; }
    50% { transform: translate3d(-2%, -4%, 0) rotate(-7deg); opacity: .94; }
}

@keyframes efcAmbientFloat {
    0%, 100% { transform: translate3d(0,0,0) scale(1); opacity: .74; }
    33% { transform: translate3d(-2%, -3%, 0) scale(1.08); opacity: .92; }
    66% { transform: translate3d(2%, 2%, 0) scale(.98); opacity: .82; }
}

@keyframes efcHeroArtFloat {
    0%, 100% { transform: translate3d(0, 0, 0) scale(1.02); }
    50% { transform: translate3d(-1.1%, -1.0%, 0) scale(1.045); }
}

@keyframes efcFaceSparkle {
    0%, 100% { opacity: .86; transform: translate3d(0,0,0) scale(1); }
    50% { opacity: 1; transform: translate3d(.8%, -1.2%, 0) scale(1.03); }
}

@keyframes efcFaceGlow {
    0%, 100% { opacity: .84; transform: translate3d(0,0,0) scale(1); }
    50% { opacity: 1; transform: translate3d(-.8%, 1%, 0) scale(1.04); }
}

@keyframes efcArcFloat {
    0%, 100% { transform: translate3d(0,0,0) rotate(var(--efc-arc-rot, 0deg)); opacity: .72; }
    50% { transform: translate3d(-1.2%, -2%, 0) rotate(calc(var(--efc-arc-rot, 0deg) + 2deg)); opacity: 1; }
}

.ring-line-one { --efc-arc-rot: -10deg; }
.ring-line-two { --efc-arc-rot: 6deg; }
.ring-line-three { --efc-arc-rot: 12deg; }

@keyframes efcTwinkle {
    0%, 100% { opacity: .4; transform: scale(.8); }
    50% { opacity: 1; transform: scale(1.4); }
}

@keyframes efcSlowDrift {
    0%, 100% { transform: translate3d(0,0,0); }
    50% { transform: translate3d(0, -2%, 0); }
}

@media (max-width: 1180px) {
    .efc-hero-grid {
        grid-template-columns: 1fr;
    }
    .efc-hero-visual {
        min-height: 620px;
        order: -1;
        opacity: 1;
    }
    .efc-stage {
        inset: -110px -80px -2% 0;
    }
    .efc-hero-art {
        background-position: right 50%;
        background-size: auto 108%;
        -webkit-mask-image: radial-gradient(circle at center, #000 58%, rgba(0,0,0,.9) 70%, transparent 100%);
        mask-image: radial-gradient(circle at center, #000 58%, rgba(0,0,0,.9) 70%, transparent 100%);
    }
}

@media (max-width: 900px) {
    .efc-header {
        background: rgba(3, 8, 24, .82);
    }
    .efc-nav {
        background: rgba(3,7,18,.95);
    }
    .efc-hero {
        padding-top: 116px;
    }
    .efc-hero-visual {
        min-height: 440px;
    }
    .efc-hero h1 {
        font-size: clamp(52px, 12vw, 84px);
    }
    .efc-subheadline {
        font-size: 18px;
    }
    .ring-line-one {
        width: 82%;
        height: 72%;
        right: -8%;
    }
    .ring-line-two,
    .ring-line-three {
        opacity: .72;
    }
}

@media (max-width: 560px) {
    .efc-hero-grid {
        width: min(100% - 34px, 720px);
    }
    .efc-hero-visual {
        min-height: 360px;
    }
    .efc-stage {
        transform: none;
        inset: -40px -56px 0 0;
    }
    .efc-hero-art {
        background-size: auto 100%;
        background-position: right 50%;
    }
    .efc-scroll {
        bottom: 6px;
        font-size: 10px;
        letter-spacing: .26em;
    }
}


/* v3.1.6 full-width static-page homepage support and right-edge hero lock */
body.efora-channel-theme.page,
body.efora-channel-theme.home {
    overflow-x: hidden;
}

body.efora-channel-theme .entry-content,
body.efora-channel-theme .site-content,
body.efora-channel-theme .wp-site-blocks {
    max-width: none;
    width: 100%;
    padding: 0;
    margin: 0;
}

.efc-hero-art {
    right: 0;
}


/* v3.1.7 credibility / women-led editorial mission section */
.efc-credibility {
    position: relative;
    overflow: hidden;
}

.efc-credibility::before {
    content: "";
    position: absolute;
    inset: 4% auto auto 50%;
    width: min(760px, 82vw);
    height: min(760px, 82vw);
    transform: translateX(-50%);
    border-radius: 999px;
    background:
        radial-gradient(circle, rgba(82,232,255,.14), transparent 38%),
        radial-gradient(circle at 72% 32%, rgba(159,105,255,.18), transparent 34%);
    filter: blur(38px);
    opacity: .72;
    pointer-events: none;
}

.efc-credibility .efc-section-head {
    position: relative;
    z-index: 1;
    max-width: 980px;
}

.efc-credibility .efc-section-head p {
    max-width: 760px;
    margin: 14px auto 0;
    color: rgba(230, 240, 255, .74);
    font-size: clamp(17px, 1.35vw, 21px);
    line-height: 1.65;
}

.efc-credibility-grid {
    position: relative;
    z-index: 1;
    width: min(1200px, calc(100% - 48px));
    margin: 42px auto 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.efc-cred-card {
    position: relative;
    min-height: 250px;
    padding: 28px 24px 26px;
    border: 1px solid rgba(142, 173, 255, .16);
    border-radius: 26px;
    background:
        linear-gradient(145deg, rgba(12, 19, 48, .82), rgba(6, 10, 28, .62)),
        radial-gradient(circle at 18% 0, rgba(82,232,255,.10), transparent 42%);
    box-shadow:
        0 26px 90px rgba(0,0,0,.30),
        inset 0 1px rgba(255,255,255,.08),
        0 0 0 1px rgba(75,115,255,.06);
    backdrop-filter: blur(18px);
    overflow: hidden;
}

.efc-cred-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--efc-accent-1), var(--efc-accent-2));
    box-shadow: 0 0 24px rgba(82,232,255,.34);
}

.efc-cred-card::after {
    content: "";
    position: absolute;
    width: 120px;
    height: 120px;
    right: -42px;
    top: -42px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(82,232,255,.16), rgba(159,105,255,.08) 42%, transparent 70%);
    pointer-events: none;
}

.efc-cred-card span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 999px;
    margin-bottom: 18px;
    color: #061024;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .12em;
    background: linear-gradient(135deg, #53e9ff, #9f69ff);
    box-shadow: 0 0 26px rgba(82,232,255,.34);
}

.efc-cred-card h3 {
    margin: 0 0 12px;
    color: #fff;
    font-size: 19px;
    line-height: 1.18;
    letter-spacing: -.02em;
}

.efc-cred-card p {
    margin: 0;
    color: rgba(226, 235, 252, .75);
    font-size: 14.5px;
    line-height: 1.58;
}

@media (max-width: 1100px) {
    .efc-credibility-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .efc-cred-card { min-height: 218px; }
}

@media (max-width: 640px) {
    .efc-credibility-grid { grid-template-columns: 1fr; width: min(100% - 34px, 720px); }
    .efc-cred-card { min-height: auto; padding: 24px 22px; }
}


/* v3.1.9 logo, all-channels button, launch countdown, and hero edge polish */
.efc-brand-logo,
.efc-brand-logo img,
.efc-logo-img {
    display: block;
}

.efc-brand-logo img,
.efc-logo-img {
    width: auto;
    max-width: 220px;
    max-height: 54px;
    object-fit: contain;
    filter: drop-shadow(0 0 18px rgba(82,232,255,.14));
}

.efc-brand:has(.efc-brand-logo) {
    min-width: auto;
}

.efc-all-channels-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid rgba(82,232,255,.28);
    background:
        radial-gradient(circle at 10% 0%, rgba(82,232,255,.18), transparent 42%),
        linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.025));
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .16em;
    font-size: 11px;
    font-weight: 800;
    white-space: nowrap;
    box-shadow: inset 0 1px rgba(255,255,255,.08), 0 0 24px rgba(82,232,255,.10);
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.efc-all-channels-btn:hover {
    transform: translateY(-1px);
    border-color: rgba(159,105,255,.56);
    box-shadow: inset 0 1px rgba(255,255,255,.10), 0 0 28px rgba(82,232,255,.22), 0 0 44px rgba(159,105,255,.14);
}

.efc-countdown {
    margin-top: 34px;
    max-width: 580px;
    padding: 15px;
    border: 1px solid rgba(132,166,255,.18);
    border-radius: 26px;
    background:
        radial-gradient(circle at 18% 8%, rgba(82,232,255,.13), transparent 40%),
        radial-gradient(circle at 85% 92%, rgba(159,105,255,.15), transparent 42%),
        linear-gradient(145deg, rgba(7,13,36,.66), rgba(2,5,18,.38));
    box-shadow: 0 24px 80px rgba(0,0,0,.26), inset 0 1px rgba(255,255,255,.07), 0 0 44px rgba(82,232,255,.08);
    backdrop-filter: blur(18px);
}

.efc-countdown-label {
    display: block;
    margin: 0 0 11px;
    color: rgba(239,246,255,.82);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .26em;
    text-transform: uppercase;
}

.efc-countdown-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.efc-countdown-grid div {
    min-height: 76px;
    padding: 12px 8px 10px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.10);
    background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
    text-align: center;
    box-shadow: inset 0 1px rgba(255,255,255,.06);
}

.efc-countdown-grid strong {
    display: block;
    color: #fff;
    font-size: clamp(24px, 3vw, 42px);
    line-height: 1;
    font-weight: 750;
    letter-spacing: -.04em;
    text-shadow: 0 0 18px rgba(82,232,255,.32), 0 0 28px rgba(159,105,255,.16);
}

.efc-countdown-grid small {
    display: block;
    margin-top: 8px;
    color: rgba(231,239,255,.62);
    font-size: 10px;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 800;
}

.efc-countdown.is-live .efc-countdown-grid {
    grid-template-columns: 1fr;
}

.efc-countdown.is-live .efc-countdown-grid div:not(:first-child) {
    display: none;
}

.efc-countdown.is-live .efc-countdown-grid strong {
    font-size: clamp(30px, 4vw, 58px);
}

@media (max-width: 1120px) {
    .efc-header {
        gap: 16px;
    }
    .efc-menu,
    .efc-footer-menu {
        gap: clamp(14px, 2vw, 26px);
    }
    .efc-all-channels-btn {
        padding: 0 14px;
        letter-spacing: .12em;
    }
}

@media (max-width: 900px) {
    .efc-brand-logo img,
    .efc-logo-img {
        max-width: 180px;
        max-height: 46px;
    }
    .efc-nav.is-open .efc-all-channels-btn,
    .efc-nav .efc-all-channels-btn {
        margin-top: 8px;
        width: 100%;
    }
    .efc-countdown {
        max-width: none;
    }
}

@media (max-width: 560px) {
    .efc-countdown-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .efc-countdown-grid div {
        min-height: 68px;
    }
    .efc-countdown-grid strong {
        font-size: 28px;
    }
}


/* v3.1.8 right-edge hero lock refinement */
.efora-channel-v318 .efc-stage {
    inset: -176px -9% -6% -2%;
}

.efora-channel-v318 .efc-hero-art {
    background-position: right 48%;
    background-size: auto 122%;
}

@media (max-width: 1180px) {
    .efora-channel-v318 .efc-stage {
        inset: -110px -8% -2% -4%;
    }
    .efora-channel-v318 .efc-hero-art {
        background-position: right 50%;
        background-size: auto 112%;
    }
}

@media (max-width: 560px) {
    .efora-channel-v318 .efc-stage {
        inset: 0 -8% 0 -4%;
    }
    .efora-channel-v318 .efc-hero-art {
        background-position: right 50%;
        background-size: auto 104%;
    }
}


/* v3.1.9 final polish: menu spacing, hero edge lock, countdown numeric fix support */
.efora-channel-v319 .efc-nav{
    gap: clamp(16px, 2.2vw, 34px) !important;
}
.efora-channel-v319 .efc-nav .efc-menu{
    gap: clamp(18px, 2.25vw, 34px) !important;
}
.efora-channel-v319 .efc-all-channels-btn{
    margin-left: clamp(14px, 1.6vw, 28px) !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    flex: 0 0 auto;
}

/* Keep the hero artwork flush to the viewport right side on wide screens. */
.efora-channel-v319 .efc-hero,
.efora-channel-v319 .efc-hero-grid,
.efora-channel-v319 .efc-hero-visual{
    overflow: visible !important;
}
.efora-channel-v319 .efc-stage{
    right: -10vw !important;
    left: -2% !important;
    top: -176px !important;
    bottom: -6% !important;
    border-radius: 42px 0 0 42px !important;
    box-shadow: none !important;
    background: transparent !important;
}
.efora-channel-v319 .efc-hero-art{
    background-position: right center !important;
    background-size: auto 120% !important;
    background-origin: border-box;
    background-clip: border-box;
}

@media (min-width: 1501px){
    .efora-channel-v319 .efc-stage{
        right: calc((1500px - 100vw) / 2 - 118px) !important;
        border-radius: 42px 0 0 42px !important;
    }
    .efora-channel-v319 .efc-hero-art{
        background-position: right center !important;
        background-size: auto 120% !important;
    }
}

@media (max-width: 1180px){
    .efora-channel-v319 .efc-stage{
        right: -10vw !important;
        left: -4% !important;
        top: -110px !important;
        bottom: -2% !important;
    }
    .efora-channel-v319 .efc-hero-art{
        background-position: right center !important;
        background-size: auto 112% !important;
    }
}

@media (max-width: 900px){
    .efora-channel-v319 .efc-nav .efc-menu{
        gap: 0 !important;
    }
    .efora-channel-v319 .efc-nav .efc-all-channels-btn{
        margin-left: 0 !important;
        margin-top: 10px !important;
    }
}

@media (max-width: 560px){
    .efora-channel-v319 .efc-stage{
        right: -12vw !important;
        left: -4% !important;
        top: 0 !important;
        bottom: 0 !important;
    }
    .efora-channel-v319 .efc-hero-art{
        background-position: right center !important;
        background-size: auto 104% !important;
    }
}


/* v3.1.10 mobile normalization + countdown precision fix */
.efora-channel-v3110 .efc-nav{
    gap: clamp(16px, 2.2vw, 34px) !important;
}
.efora-channel-v3110 .efc-nav .efc-menu{
    gap: clamp(18px, 2.25vw, 34px) !important;
}
.efora-channel-v3110 .efc-all-channels-btn{
    margin-left: clamp(14px, 1.6vw, 28px) !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    flex: 0 0 auto;
}
.efora-channel-v3110 .efc-hero,
.efora-channel-v3110 .efc-hero-grid,
.efora-channel-v3110 .efc-hero-visual{
    overflow: visible !important;
}
.efora-channel-v3110 .efc-stage{
    right: -10vw !important;
    left: -2% !important;
    top: -176px !important;
    bottom: -6% !important;
    border-radius: 42px 0 0 42px !important;
    box-shadow: none !important;
    background: transparent !important;
}
.efora-channel-v3110 .efc-hero-art{
    background-position: right center !important;
    background-size: auto 120% !important;
    background-origin: border-box;
    background-clip: border-box;
}
.efora-channel-v3110 .efc-countdown-grid{
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

@media (min-width: 1501px){
    .efora-channel-v3110 .efc-stage{
        right: calc((1500px - 100vw) / 2 - 118px) !important;
        border-radius: 42px 0 0 42px !important;
    }
    .efora-channel-v3110 .efc-hero-art{
        background-position: right center !important;
        background-size: auto 120% !important;
    }
}

@media (max-width: 1180px){
    .efora-channel-v3110 .efc-stage{
        right: -10vw !important;
        left: -4% !important;
        top: -110px !important;
        bottom: -2% !important;
    }
    .efora-channel-v3110 .efc-hero-art{
        background-position: right center !important;
        background-size: auto 112% !important;
    }
}

@media (max-width: 900px){
    html, body.efora-channel-theme{
        max-width: 100%;
        overflow-x: hidden !important;
    }
    .efora-channel-v3110 .efc-site-shell{
        overflow-x: clip;
    }
    .efora-channel-v3110 .efc-header{
        width: min(100% - 24px, 1500px);
    }
    .efora-channel-v3110 .efc-nav.is-open{
        overflow-x: hidden;
    }
    .efora-channel-v3110 .efc-nav .efc-menu{
        gap: 0 !important;
    }
    .efora-channel-v3110 .efc-nav .efc-all-channels-btn,
    .efora-channel-v3110 .efc-nav.is-open .efc-all-channels-btn{
        width: auto !important;
        min-height: auto !important;
        margin: 0 !important;
        padding: 14px 6px !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        justify-content: flex-start !important;
        color: rgba(255,255,255,.78) !important;
        font-size: 12px !important;
        letter-spacing: .18em !important;
        text-align: left !important;
        transform: none !important;
    }
    .efora-channel-v3110 .efc-nav .efc-all-channels-btn:hover{
        color: #fff !important;
        text-shadow: 0 0 18px rgba(23,215,255,.65);
        transform: none !important;
        box-shadow: none !important;
    }
    .efora-channel-v3110 .efc-hero,
    .efora-channel-v3110 .efc-hero-grid,
    .efora-channel-v3110 .efc-hero-visual{
        overflow: hidden !important;
    }
    .efora-channel-v3110 .efc-hero-grid{
        width: min(100% - 34px, 720px) !important;
    }
    .efora-channel-v3110 .efc-hero-visual{
        min-height: 430px !important;
        max-width: 100% !important;
        overflow: hidden !important;
        border-radius: 28px;
    }
    .efora-channel-v3110 .efc-stage{
        inset: -80px 0 0 0 !important;
        right: 0 !important;
        left: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        transform: none !important;
        border-radius: 28px !important;
        overflow: hidden !important;
    }
    .efora-channel-v3110 .efc-hero-art{
        background-position: 72% 50% !important;
        background-size: auto 108% !important;
        max-width: 100% !important;
    }
    .efora-channel-v3110 .efc-countdown-grid{
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 8px;
    }
    .efora-channel-v3110 .efc-countdown-grid div{
        min-height: 64px;
        padding: 10px 5px 8px;
        border-radius: 15px;
    }
    .efora-channel-v3110 .efc-countdown-grid strong{
        font-size: 24px;
    }
    .efora-channel-v3110 .efc-countdown-grid small{
        font-size: 8px;
        letter-spacing: .09em;
    }
}

@media (max-width: 560px){
    .efora-channel-v3110 .efc-hero-visual{
        min-height: 350px !important;
        border-radius: 24px;
    }
    .efora-channel-v3110 .efc-stage{
        inset: -48px 0 0 0 !important;
        border-radius: 24px !important;
    }
    .efora-channel-v3110 .efc-hero-art{
        background-position: 70% 50% !important;
        background-size: auto 100% !important;
    }
    .efora-channel-v3110 .efc-countdown-grid{
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 5px;
    }
    .efora-channel-v3110 .efc-countdown{
        padding: 10px;
        border-radius: 20px;
    }
    .efora-channel-v3110 .efc-countdown-grid div{
        min-height: 58px;
        padding: 9px 3px 7px;
    }
    .efora-channel-v3110 .efc-countdown-grid strong{
        font-size: 20px;
    }
    .efora-channel-v3110 .efc-countdown-grid small{
        margin-top: 6px;
        font-size: 7px;
        letter-spacing: .04em;
    }
}

/* v3.2.0 Efora Theater channel variant: grand hall + opening night atmosphere */
body.efora-channel-theater {
    --efc-bg: #060006;
    --efc-bg-2: #150610;
    --efc-muted: rgba(255, 241, 218, .78);
    --efc-soft: rgba(241, 182, 90, .14);
    --efc-line: rgba(255, 206, 136, .18);
    --efc-accent-1: #f1b65a;
    --efc-accent-2: #8c1436;
    --efc-accent-3: #fff0bd;
    --efc-glow: 0 0 54px rgba(241,182,90,.38), 0 0 120px rgba(140,20,54,.28), 0 0 160px rgba(255,236,184,.13);
    background:
        radial-gradient(circle at 72% 22%, rgba(241,182,90,.18), transparent 20%),
        radial-gradient(circle at 88% 74%, rgba(140,20,54,.20), transparent 30%),
        linear-gradient(180deg, #050006 0%, #12060e 44%, #050006 100%);
}

body.efora-channel-theater .efc-site-shell {
    background:
        radial-gradient(circle at 68% 18%, rgba(241,182,90,.16), transparent 22%),
        radial-gradient(circle at 86% 58%, rgba(156,30,60,.24), transparent 30%),
        radial-gradient(circle at 18% 80%, rgba(77,15,22,.22), transparent 28%),
        linear-gradient(180deg, #050006 0%, #12060e 42%, #070006 100%);
}

body.efora-channel-theater .efc-site-shell::before {
    opacity: .10;
    background-image:
        linear-gradient(rgba(255,222,165,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,222,165,.028) 1px, transparent 1px);
}

body.efora-channel-theater .efc-site-shell::after {
    background:
        radial-gradient(circle at 66% 20%, rgba(255,207,122,.14), transparent 22%),
        radial-gradient(circle at 86% 66%, rgba(140,20,54,.22), transparent 24%),
        radial-gradient(circle at 56% 76%, rgba(255,158,70,.10), transparent 26%);
}

body.efora-channel-theater .efc-header {
    background: rgba(8, 1, 8, .66);
    border-color: rgba(255, 214, 150, .16);
    box-shadow: 0 22px 70px rgba(0,0,0,.48), inset 0 1px rgba(255,240,210,.06), 0 0 0 1px rgba(255,200,122,.04);
}

body.efora-channel-theater .efc-brand-mark span {
    background: linear-gradient(90deg, #fff0bd, #f1b65a, #b91846);
    box-shadow: 0 0 20px rgba(241,182,90,.46);
}

body.efora-channel-theater .efc-brand-text em,
body.efora-channel-theater .efc-kicker {
    color: #f1b65a;
}

body.efora-channel-theater .efc-menu a:hover,
body.efora-channel-theater .efc-footer a:hover {
    text-shadow: 0 0 22px rgba(241,182,90,.56);
}

body.efora-channel-theater .efc-hero::before {
    background: radial-gradient(circle, rgba(255,211,128,.26) 0%, rgba(255,176,74,.12) 28%, rgba(140,20,54,.12) 48%, transparent 72%);
}

body.efora-channel-theater .efc-hero::after {
    background: linear-gradient(90deg, transparent 2%, rgba(140,20,54,.14) 18%, rgba(241,182,90,.22) 44%, rgba(255,236,184,.18) 70%, transparent 98%);
}

body.efora-channel-theater .efc-eyebrow span {
    background: linear-gradient(90deg, #fff0bd, #f1b65a, #8c1436);
    box-shadow: 0 0 22px rgba(241,182,90,.55);
}

body.efora-channel-theater .efc-hero h1 span {
    background: linear-gradient(98deg, #fff0bd 4%, #f1b65a 42%, #b91846 96%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 0 18px rgba(241,182,90,.14));
}

body.efora-channel-theater .efc-btn-primary {
    background: linear-gradient(135deg, rgba(255,230,165,.96), rgba(241,182,90,.95) 40%, rgba(140,20,54,.96));
    border-color: rgba(255, 221, 156, .42);
    color: #13060a;
    box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset, 0 0 34px rgba(241,182,90,.34), 0 0 72px rgba(140,20,54,.20), 0 14px 38px rgba(0,0,0,.38);
}

body.efora-channel-theater .efc-btn-ghost {
    border-color: rgba(255,205,130,.34);
    color: rgba(255,246,230,.94);
    background: linear-gradient(180deg, rgba(255,232,190,.055), rgba(255,255,255,.018));
}

body.efora-channel-theater .efc-play::before {
    border-left-color: #14060a;
}

body.efora-channel-theater .efc-people::before,
body.efora-channel-theater .efc-people::after {
    border-color: rgba(255, 228, 190, .78);
}

body.efora-channel-theater .efc-stage {
    inset: -170px -2vw -6% -3%;
    border-radius: 0;
    overflow: visible;
}

body.efora-channel-theater .efc-stage::before {
    background: radial-gradient(circle at 54% 42%, rgba(255,214,130,.34), rgba(241,182,90,.16) 34%, rgba(140,20,54,.16) 56%, transparent 78%);
    filter: blur(26px);
}

body.efora-channel-theater .efc-stage::after {
    background: linear-gradient(90deg, transparent 0%, rgba(140,20,54,.18) 18%, rgba(255,195,90,.26) 40%, rgba(255,236,184,.20) 60%, transparent 100%);
    filter: blur(26px);
}

body.efora-channel-theater .ambience-one {
    background: radial-gradient(circle, rgba(255,226,160,.95), rgba(241,182,90,.34) 35%, rgba(140,20,54,.10) 56%, transparent 78%);
}

body.efora-channel-theater .ambience-two {
    background: radial-gradient(circle, rgba(140,20,54,.96), rgba(140,20,54,.34) 36%, rgba(241,182,90,.10) 56%, transparent 76%);
}

body.efora-channel-theater .ambience-three {
    background: radial-gradient(circle, rgba(255,184,82,.80), rgba(255,184,82,.22) 38%, rgba(140,20,54,.12) 60%, transparent 80%);
}

body.efora-channel-theater .efc-hero-art {
    background-size: auto 118%;
    background-position: 98% 52%;
    opacity: var(--efc-hero-image-opacity, .88);
    filter: saturate(1.08) brightness(.86) contrast(1.06) drop-shadow(0 0 44px rgba(241,182,90,.18)) drop-shadow(0 0 110px rgba(140,20,54,.16));
    -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.22) 10%, rgba(0,0,0,.88) 20%, #000 31%, #000 100%);
    mask-image: linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.22) 10%, rgba(0,0,0,.88) 20%, #000 31%, #000 100%);
}

body.efora-channel-theater .efc-hero-art::before {
    background:
        radial-gradient(circle at 51% 30%, rgba(255,245,210,.78) 0 1px, rgba(241,182,90,.32) 2px, transparent 8px),
        radial-gradient(circle at 62% 26%, rgba(255,245,210,.82) 0 1.2px, rgba(241,182,90,.32) 3px, transparent 10px),
        radial-gradient(circle at 64% 48%, rgba(255,236,184,.72) 0 1px, rgba(241,182,90,.26) 2px, transparent 9px),
        radial-gradient(circle at 72% 38%, rgba(255,236,184,.58), transparent 12%),
        radial-gradient(circle at 60% 64%, rgba(140,20,54,.20), transparent 18%);
    filter: blur(.2px) drop-shadow(0 0 12px rgba(241,182,90,.46));
}

body.efora-channel-theater .efc-hero-art::after {
    background:
        radial-gradient(circle at 62% 44%, rgba(255,214,130,.18), transparent 18%),
        linear-gradient(112deg, transparent 52%, rgba(255,230,170,.10) 64%, transparent 76%);
    filter: blur(14px);
}

body.efora-channel-theater .ring-line {
    border-color: rgba(255,212,142,.20);
    box-shadow: 0 0 30px rgba(241,182,90,.16);
}

body.efora-channel-theater .ring-line-one { border-bottom-color: rgba(241,182,90,.44); }
body.efora-channel-theater .ring-line-two { border-left-color: rgba(255,236,184,.32); }
body.efora-channel-theater .ring-line-three { border-top-color: rgba(241,182,90,.22); }

body.efora-channel-theater .efc-stage-star {
    background: #fff0bd;
    box-shadow: 0 0 18px rgba(255,226,160,.92), 0 0 34px rgba(241,182,90,.52), 0 0 62px rgba(140,20,54,.24);
}

body.efora-channel-theater .efc-mini-grid div,
body.efora-channel-theater .efc-card,
body.efora-channel-theater .efc-proof-card,
body.efora-channel-theater .efc-entry,
body.efora-channel-theater .efc-cred-card {
    border-color: rgba(255, 206, 136, .16);
    background: linear-gradient(145deg, rgba(24, 6, 14, .82), rgba(10, 3, 8, .58));
    box-shadow: 0 26px 90px rgba(0,0,0,.34), inset 0 1px rgba(255,240,210,.06), 0 0 0 1px rgba(255,190,120,.05);
}

body.efora-channel-theater .efc-card::before,
body.efora-channel-theater .efc-what {
    background-image: radial-gradient(circle at 20% 0, rgba(241,182,90,.13), transparent 38%);
}

body.efora-channel-theater .efc-partners,
body.efora-channel-theater .efc-credibility {
    background: radial-gradient(circle at 50% 0, rgba(140,20,54,.18), transparent 44%);
}

@media (max-width: 1180px) {
    body.efora-channel-theater .efc-stage { inset: -90px 0 -2% 0; }
    body.efora-channel-theater .efc-hero-art { background-position: center 50%; background-size: cover; }
}

@media (max-width: 900px) {
    body.efora-channel-theater .efc-hero-visual { min-height: 430px; }
    body.efora-channel-theater .efc-stage { inset: -24px 0 0 0; overflow: hidden; border-radius: 26px; }
    body.efora-channel-theater .efc-hero-art { background-size: cover; background-position: center center; opacity: .72; }
}

@media (max-width: 560px) {
    body.efora-channel-theater .efc-hero-visual { min-height: 340px; }
    body.efora-channel-theater .efc-stage { inset: 0; }
    body.efora-channel-theater .efc-hero-art { background-size: cover; background-position: center center; }
}
