/* ============ TOKENS ============ */
  :root{
    --ink:        #060810;
    --ink-2:      #0a0f1c;
    --ink-3:      #111a2e;
    --panel:      #0e1525;
    --line:       rgba(221,184,99,.16);
    --line-soft:  rgba(255,255,255,.07);

    --gold:       #ddb863;
    --gold-bright:#f3d897;
    --gold-deep:  #a97e34;
    --gold-grad:  linear-gradient(135deg, #f6e0a4 0%, #ddb863 42%, #b5852f 100%);

    --text:       #ece7da;
    --muted:      #98a2b6;
    --muted-2:    #6f7a90;

    --maxw: 1240px;
    --r:   18px;
    --r-lg: 26px;
    --ease: cubic-bezier(.16,1,.3,1);
    --font-d: "Fraunces", Georgia, serif;
    --font-b: "Sora", system-ui, sans-serif;
  }

  *{ box-sizing:border-box; margin:0; padding:0; }
  html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
  body{
    font-family:var(--font-b);
    background:var(--ink);
    color:var(--text);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  ::selection{ background:var(--gold); color:#10131c; }
  a{ color:inherit; text-decoration:none; }
  img{ max-width:100%; display:block; }
  h1,h2,h3,h4{ font-family:var(--font-d); font-weight:600; line-height:1.05; letter-spacing:-.02em; }

  /* grain + glow atmosphere */
  body::before{
    content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
    background:
      radial-gradient(1100px 700px at 78% -8%, rgba(221,184,99,.10), transparent 60%),
      radial-gradient(900px 600px at 8% 6%, rgba(40,70,130,.18), transparent 55%),
      radial-gradient(1200px 900px at 50% 120%, rgba(221,184,99,.06), transparent 60%);
  }
  body::after{
    content:""; position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.45;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
    mix-blend-mode:overlay;
  }
  main, header, footer{ position:relative; z-index:1; }

  .wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
  section{ position:relative; padding:clamp(72px,9vw,140px) 0; }

  /* ============ SHARED ============ */
  .kicker{
    display:inline-flex; align-items:center; gap:10px;
    font-size:.72rem; letter-spacing:.34em; text-transform:uppercase;
    color:var(--gold); font-weight:600;
  }
  .kicker::before{ content:""; width:30px; height:1px; background:var(--gold); opacity:.7; }
  .eyebrow-c{ justify-content:center; }
  .eyebrow-c::after{ content:""; width:30px; height:1px; background:var(--gold); opacity:.7; }

  .h-sec{ font-size:clamp(2rem,4.6vw,3.6rem); line-height:1.04; }
  .lead{ color:var(--muted); font-size:clamp(1rem,1.4vw,1.18rem); max-width:62ch; }
  .gold-t{
    background:var(--gold-grad); -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent; color:transparent;
  }
  em.serif{ font-style:italic; font-family:var(--font-d); font-weight:500; }

  .btn{
    display:inline-flex; align-items:center; gap:.6em; justify-content:center;
    font-family:var(--font-b); font-weight:600; font-size:.97rem;
    padding:16px 30px; border-radius:100px; cursor:pointer; border:1px solid transparent;
    transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .3s, color .3s;
    white-space:nowrap;
  }
  .btn-gold{
    background:var(--gold-grad); color:#181206;
    box-shadow:0 10px 30px -10px rgba(221,184,99,.6), inset 0 1px 0 rgba(255,255,255,.4);
  }
  .btn-gold:hover{ transform:translateY(-3px); box-shadow:0 18px 44px -12px rgba(221,184,99,.75), inset 0 1px 0 rgba(255,255,255,.5); }
  .btn-ghost{ background:transparent; color:var(--text); border-color:var(--line); }
  .btn-ghost:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-3px); }
  .btn .ar{ transition:transform .4s var(--ease); }
  .btn:hover .ar{ transform:translateX(4px); }

  /* ============ HEADER ============ */
  header{
    position:fixed; top:0; left:0; right:0; z-index:50;
    transition:background .4s var(--ease), border-color .4s, padding .4s;
    border-bottom:1px solid transparent;
  }
  header.scrolled{
    background:rgba(6,8,16,.78); backdrop-filter:blur(18px) saturate(140%);
    border-bottom-color:var(--line-soft);
  }
  .nav{ display:flex; align-items:center; justify-content:space-between; padding:20px 0; transition:padding .4s; }
  header.scrolled .nav{ padding:13px 0; }
  .brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-d); font-weight:600; font-size:1.05rem; letter-spacing:-.01em; }
  .brand .mark{
    width:34px; height:34px; border-radius:9px; flex:0 0 auto;
    background:var(--gold-grad); color:#13100a; display:grid; place-items:center;
    font-weight:700; font-family:var(--font-b); font-size:.95rem;
    box-shadow:0 6px 18px -6px rgba(221,184,99,.6);
  }
  .brand small{ display:block; font-family:var(--font-b); font-weight:400; font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-top:1px; }
  .nav-links{ display:flex; align-items:center; gap:34px; }
  .nav-links a{ font-size:.9rem; color:var(--muted); font-weight:500; transition:color .25s; position:relative; }
  .nav-links a:hover{ color:var(--text); }
  .nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0; background:var(--gold); transition:width .3s var(--ease); }
  .nav-links a:hover::after{ width:100%; }
  .nav-cta{ display:flex; align-items:center; gap:18px; }
  .nav-cta .btn{ padding:11px 22px; font-size:.88rem; }
  .burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
  .burger span{ width:24px; height:2px; background:var(--text); transition:.3s; border-radius:2px; }

  .mobile-menu{
    position:fixed; inset:0; z-index:49; background:rgba(6,8,16,.97); backdrop-filter:blur(10px);
    display:flex; flex-direction:column; justify-content:center; gap:8px; padding:40px;
    transform:translateY(-100%); transition:transform .5s var(--ease); visibility:hidden;
  }
  .mobile-menu.open{ transform:translateY(0); visibility:visible; }
  .mobile-menu a{ font-family:var(--font-d); font-size:2rem; padding:10px 0; border-bottom:1px solid var(--line-soft); }
  .mobile-menu .btn{ margin-top:24px; }

  /* ============ HERO ============ */
  .hero{ padding-top:clamp(150px,18vw,220px); padding-bottom:clamp(60px,8vw,110px); text-align:center; overflow:hidden; }
  .hero .aurora{
    position:absolute; z-index:0; width:1000px; height:1000px; left:50%; top:-30%;
    transform:translateX(-50%); pointer-events:none;
    background:conic-gradient(from 0deg, transparent, rgba(221,184,99,.16), transparent 40%, rgba(60,90,160,.16), transparent 75%);
    filter:blur(80px); border-radius:50%; animation:spin 32s linear infinite; opacity:.85;
  }
  @keyframes spin{ to{ transform:translateX(-50%) rotate(360deg); } }
  .hero-inner{ position:relative; z-index:2; }
  .hero-meta{
    display:inline-flex; align-items:center; gap:16px; padding:9px 18px; border-radius:100px;
    border:1px solid var(--line); background:rgba(255,255,255,.02);
    font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
    margin-bottom:34px;
  }
  .hero-meta b{ color:var(--gold-bright); font-weight:600; }
  .hero-meta .dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); }
  .hero h1{
    font-size:clamp(2.5rem,6.6vw,5.6rem); line-height:1.02; letter-spacing:-.03em;
    max-width:16ch; margin:0 auto 26px;
  }
  .hero h1 .line{ display:block; overflow:hidden; }
  .hero p.sub{ max-width:60ch; margin:0 auto 40px; color:var(--muted); font-size:clamp(1rem,1.5vw,1.22rem); }
  .hero-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

  /* hero reveal */
  .reveal-up{ opacity:0; transform:translateY(26px); }
  .hero .anim{ animation:rise .9s var(--ease) forwards; }
  .hero .d1{ animation-delay:.05s } .hero .d2{ animation-delay:.18s } .hero .d3{ animation-delay:.31s }
  .hero .d4{ animation-delay:.44s } .hero .d5{ animation-delay:.57s } .hero .d6{ animation-delay:.7s }
  @keyframes rise{ to{ opacity:1; transform:translateY(0); } }

  /* marquee */
  .marquee{ border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); padding:22px 0; overflow:hidden; background:rgba(255,255,255,.015); position:relative; z-index:2; }
  .marquee-track{ display:flex; gap:60px; width:max-content; animation:scroll 38s linear infinite; }
  .marquee:hover .marquee-track{ animation-play-state:paused; }
  .marquee span{ font-family:var(--font-d); font-size:1.5rem; color:var(--muted-2); white-space:nowrap; display:inline-flex; align-items:center; gap:60px; }
  .marquee span::after{ content:"✦"; color:var(--gold); font-size:1rem; }
  @keyframes scroll{ to{ transform:translateX(-50%); } }

  /* ============ STATS ============ */
  .stats{ padding:clamp(56px,7vw,90px) 0; }
  .stat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
  .stat{ text-align:center; padding:34px 18px; border:1px solid var(--line-soft); border-radius:var(--r); background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0)); transition:border-color .4s, transform .4s var(--ease); }
  .stat:hover{ border-color:var(--line); transform:translateY(-4px); }
  .stat .num{ font-family:var(--font-d); font-size:clamp(2.6rem,5vw,3.7rem); font-weight:600; line-height:1; }
  .stat .lbl{ margin-top:10px; font-size:.84rem; color:var(--muted); letter-spacing:.04em; }

  /* ============ TWO-COL INTRO ============ */
  .split{ display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center; }
  .prose p{ color:var(--muted); margin-bottom:18px; font-size:1.05rem; }
  .prose p:last-child{ margin-bottom:0; }
  .quote-card{
    border:1px solid var(--line); border-radius:var(--r-lg); padding:42px;
    background:linear-gradient(165deg, rgba(221,184,99,.07), rgba(255,255,255,.01));
    position:relative; overflow:hidden;
  }
  .quote-card::before{ content:"”"; position:absolute; top:-30px; right:20px; font-family:var(--font-d); font-size:11rem; color:var(--gold); opacity:.12; }
  .quote-card p{ font-family:var(--font-d); font-size:1.5rem; line-height:1.4; font-weight:500; }
  .quote-card .by{ margin-top:26px; font-family:var(--font-b); font-size:.85rem; color:var(--gold); letter-spacing:.06em; }

  /* ============ WHY (emotional) ============ */
  .why{ text-align:center; }
  .why .h-sec{ max-width:18ch; margin:18px auto 26px; }
  .why .lead{ margin:0 auto; }
  .needs{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:48px; max-width:880px; margin-left:auto; margin-right:auto; }
  .need{ padding:12px 22px; border:1px solid var(--line); border-radius:100px; font-size:.92rem; color:var(--text); background:rgba(255,255,255,.02); transition:.3s; }
  .need:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-3px); }

  /* ============ VALUE CARDS ============ */
  .head-row{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; margin-bottom:54px; flex-wrap:wrap; }
  .head-row .h-sec{ max-width:16ch; }
  .cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
  .card{
    border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:34px 30px;
    background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.008));
    transition:transform .5s var(--ease), border-color .4s, background .4s; position:relative; overflow:hidden;
  }
  .card:hover{ transform:translateY(-6px); border-color:var(--line); }
  .card .idx{ font-family:var(--font-d); font-size:.95rem; color:var(--gold); letter-spacing:.1em; }
  .card h3{ font-size:1.45rem; margin:16px 0 12px; }
  .card p{ color:var(--muted); font-size:.97rem; }
  .card.span2{ grid-column:span 2; }
  .card .glow{ position:absolute; inset:auto -40% -60% auto; width:240px; height:240px; background:radial-gradient(circle, rgba(221,184,99,.18), transparent 70%); opacity:0; transition:opacity .5s; }
  .card:hover .glow{ opacity:1; }

  /* ============ PROGRAM / PANELS ============ */
  .panels{ display:grid; gap:14px; }
  .panel{
    border:1px solid var(--line-soft); border-radius:var(--r); overflow:hidden;
    background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,0)); transition:border-color .4s;
  }
  .panel:hover{ border-color:var(--line); }
  .panel-head{ display:flex; align-items:center; gap:24px; padding:26px 30px; cursor:pointer; user-select:none; }
  .panel-no{ font-family:var(--font-d); font-size:1.5rem; color:var(--gold); width:48px; flex:0 0 auto; }
  .panel-title{ flex:1; }
  .panel-title h3{ font-size:1.3rem; }
  .panel-title .q{ color:var(--muted); font-size:.92rem; margin-top:4px; }
  .panel-toggle{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; flex:0 0 auto; transition:.4s var(--ease); color:var(--gold); }
  .panel.open .panel-toggle{ background:var(--gold); color:#13100a; transform:rotate(45deg); border-color:var(--gold); }
  .panel-body{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease); }
  .panel-body-inner{ padding:0 30px 28px 102px; }
  .tags{ display:flex; flex-wrap:wrap; gap:9px; }
  .tag{ font-size:.82rem; color:var(--muted); padding:7px 15px; border-radius:100px; border:1px solid var(--line-soft); background:rgba(255,255,255,.02); }
  @media(max-width:640px){ .panel-body-inner{ padding-left:30px; } }

  /* ============ SPEAKERS ============ */
  .speakers{ background:linear-gradient(180deg, transparent, rgba(221,184,99,.025), transparent); }
  .sp-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; margin-top:50px; }
  .sp{
    aspect-ratio:3/4; border-radius:var(--r); border:1px solid var(--line-soft); position:relative; overflow:hidden;
    background:linear-gradient(165deg, var(--ink-3), var(--ink-2)); display:grid; place-items:center; transition:.5s var(--ease);
  }
  .sp:hover{ transform:translateY(-6px); border-color:var(--gold); }
  .sp .av{ width:54%; height:54%; border-radius:50%; background:radial-gradient(circle at 50% 35%, rgba(221,184,99,.22), rgba(255,255,255,.03)); display:grid; place-items:center; color:var(--gold); }
  .sp .badge{ position:absolute; left:10px; bottom:10px; right:10px; font-size:.7rem; color:var(--muted); letter-spacing:.16em; text-transform:uppercase; text-align:center; }
  .sp.soon{ border-style:dashed; border-color:var(--line); }
  .sp.soon .av{ background:rgba(255,255,255,.025); color:var(--muted-2); }
  .sp-note{ text-align:center; margin-top:34px; color:var(--muted-2); font-size:.9rem; }
  .sp-note b{ color:var(--gold); font-weight:500; }

  /* ============ AUDIENCE ============ */
  .aud-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px 40px; margin-top:14px; }
  .aud-list li{ list-style:none; display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--line-soft); color:var(--text); font-size:1.02rem; }
  .aud-list .ck{ flex:0 0 auto; width:26px; height:26px; border-radius:50%; background:rgba(221,184,99,.14); color:var(--gold); display:grid; place-items:center; margin-top:2px; }
  .aud-foot{ margin-top:36px; font-family:var(--font-d); font-style:italic; font-size:1.4rem; }

  /* ============ MOVEMENT (banner) ============ */
  .movement{ text-align:center; }
  .movement .band{
    border:1px solid var(--line); border-radius:var(--r-lg);
    background:linear-gradient(160deg, rgba(221,184,99,.10), rgba(20,28,48,.5));
    padding:clamp(48px,7vw,90px) clamp(24px,5vw,80px); position:relative; overflow:hidden;
  }
  .movement .band::after{ content:""; position:absolute; inset:0; background:radial-gradient(700px 300px at 50% -20%, rgba(221,184,99,.14), transparent 70%); pointer-events:none; }
  .movement h2{ font-size:clamp(2rem,4.4vw,3.4rem); max-width:20ch; margin:18px auto 24px; }
  .movement p{ color:var(--muted); max-width:60ch; margin:0 auto 8px; font-size:1.06rem; }

  /* ============ TICKETS ============ */
  .tickets-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; margin-top:54px; }
  .ticket{
    border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:38px 32px;
    background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
    display:flex; flex-direction:column; transition:transform .5s var(--ease), border-color .4s; position:relative;
  }
  .ticket:hover{ transform:translateY(-6px); border-color:var(--line); }
  .ticket.feat{ border-color:var(--gold); background:linear-gradient(180deg, rgba(221,184,99,.12), rgba(255,255,255,.01)); box-shadow:0 30px 60px -30px rgba(221,184,99,.4); }
  .ticket .tier{ font-size:.78rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); font-weight:600; }
  .ticket .pill{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--gold-grad); color:#13100a; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:6px 16px; border-radius:100px; }
  .ticket h3{ font-size:2rem; margin:18px 0 6px; }
  .ticket .price{ font-family:var(--font-d); color:var(--muted); font-size:1rem; margin-bottom:22px; }
  .ticket .price b{ color:var(--text); font-size:1.6rem; font-weight:600; }
  .ticket .desc{ color:var(--muted); font-size:.96rem; margin-bottom:26px; flex:1; }
  .ticket .btn{ width:100%; }
  .ticket ul{ list-style:none; margin-bottom:26px; }
  .ticket ul li{ display:flex; gap:11px; padding:9px 0; font-size:.92rem; color:var(--text); border-bottom:1px solid var(--line-soft); }
  .ticket ul li svg{ flex:0 0 auto; color:var(--gold); margin-top:3px; }
  .ticket-note{ text-align:center; color:var(--muted-2); font-size:.86rem; margin-top:26px; }

  /* ============ FAQ ============ */
  .faq{ max-width:860px; margin:50px auto 0; }
  .faq-item{ border-bottom:1px solid var(--line-soft); }
  .faq-q{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding:26px 4px; cursor:pointer; font-family:var(--font-d); font-size:1.2rem; font-weight:500; }
  .faq-q .pm{ flex:0 0 auto; width:30px; height:30px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center; color:var(--gold); transition:.4s var(--ease); }
  .faq-item.open .pm{ transform:rotate(45deg); background:var(--gold); color:#13100a; border-color:var(--gold); }
  .faq-a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
  .faq-a p{ color:var(--muted); padding:0 4px 26px; font-size:1rem; }

  /* ============ FINAL CTA ============ */
  .final{ text-align:center; }
  .final .h-sec{ max-width:22ch; margin:18px auto 26px; font-size:clamp(2.2rem,5vw,4rem); }
  .final p{ color:var(--muted); max-width:56ch; margin:0 auto 14px; font-size:1.06rem; }
  .final .tri{ display:flex; gap:34px; justify-content:center; margin:36px 0 40px; flex-wrap:wrap; font-family:var(--font-d); font-size:1.2rem; color:var(--gold); }
  .final .tri span{ display:flex; align-items:center; gap:34px; }
  .final .tri span:not(:last-child)::after{ content:"·"; color:var(--muted-2); }

  /* ============ FOOTER ============ */
  footer{ border-top:1px solid var(--line-soft); padding:60px 0 40px; }
  .foot-grid{ display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; }
  .foot-brand p{ color:var(--muted); max-width:38ch; margin-top:16px; font-size:.94rem; }
  .foot-links{ display:flex; gap:60px; flex-wrap:wrap; }
  .foot-col h4{ font-family:var(--font-b); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
  .foot-col a{ display:block; color:var(--muted); font-size:.92rem; padding:5px 0; transition:color .25s; }
  .foot-col a:hover{ color:var(--text); }
  .foot-bottom{ margin-top:50px; padding-top:26px; border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; color:var(--muted-2); font-size:.84rem; }

  /* ============ SCROLL REVEAL ============ */
  [data-rev]{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
  [data-rev].in{ opacity:1; transform:none; }
  [data-rev][data-d="1"]{ transition-delay:.08s } [data-rev][data-d="2"]{ transition-delay:.16s }
  [data-rev][data-d="3"]{ transition-delay:.24s } [data-rev][data-d="4"]{ transition-delay:.32s }
  [data-rev][data-d="5"]{ transition-delay:.4s }

  /* ============ RESPONSIVE ============ */
  @media(max-width:980px){
    .nav-links{ display:none; }
    .nav-cta .btn{ display:none; }
    .burger{ display:flex; }
    .split{ grid-template-columns:1fr; gap:40px; }
    .cards{ grid-template-columns:1fr 1fr; }
    .card.span2{ grid-column:span 2; }
    .stat-grid{ grid-template-columns:1fr 1fr; }
    .sp-grid{ grid-template-columns:repeat(4,1fr); }
    .tickets-grid{ grid-template-columns:1fr; }
    .aud-list{ grid-template-columns:1fr; }
  }
  @media(max-width:600px){
    .cards{ grid-template-columns:1fr; }
    .card.span2{ grid-column:span 1; }
    .stat-grid{ grid-template-columns:1fr 1fr; }
    .sp-grid{ grid-template-columns:repeat(3,1fr); }
    .panel-head{ padding:20px; gap:14px; }
    .panel-no{ width:32px; font-size:1.2rem; }
    .hero-meta{ flex-wrap:wrap; justify-content:center; gap:10px; }
    .head-row{ flex-direction:column; align-items:flex-start; }
  }
  @media (prefers-reduced-motion: reduce){
    *{ animation:none !important; transition-duration:.001s !important; }
    .reveal-up,[data-rev]{ opacity:1 !important; transform:none !important; }
  }

  /* ============ THEME ADDITIONS ============ */

  /* fejléc logó */
  .brand-logo{ height:46px; width:auto; display:block; transition:height .4s var(--ease); }
  header.scrolled .brand-logo{ height:38px; }
  .brand .custom-logo{ height:46px; width:auto; transition:height .4s var(--ease); }
  header.scrolled .brand .custom-logo{ height:38px; }
  .foot-brand .brand-logo{ height:50px; margin-bottom:4px; }
  @media(max-width:600px){ .brand-logo{ height:38px; } header.scrolled .brand-logo{ height:32px; } }

  /* ============ PROGRAM PANEL BLOKK ============ */
  .panel-block{
    border:1px solid var(--line-soft); border-radius:var(--r-lg);
    background:linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,0));
    padding:38px 34px; margin-bottom:20px; transition:border-color .4s;
  }
  .panel-block:hover{ border-color:var(--line); }
  .panel-block-head{ display:flex; gap:26px; align-items:flex-start; margin-bottom:30px; padding-bottom:26px; border-bottom:1px solid var(--line-soft); }
  .panel-block-head .panel-no{ font-family:var(--font-d); font-size:2.2rem; color:var(--gold); line-height:1; width:auto; flex:0 0 auto; opacity:.9; }
  .panel-block-title{ flex:1; }
  .panel-block-title h3{ font-size:1.6rem; }
  .panel-block-title .q{ color:var(--muted); font-size:.98rem; margin:8px 0 16px; max-width:70ch; }
  @media(max-width:640px){
    .panel-block{ padding:26px 20px; }
    .panel-block-head{ gap:16px; flex-direction:column; }
    .panel-block-head .panel-no{ font-size:1.6rem; }
  }

  /* ============ ELŐADÓ KÁRTYÁK ============ */
  .sp-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:16px; margin-top:0; }
  .speakers .sp-grid{ margin-top:50px; }
  .sp-card{
    border:1px solid var(--line-soft); border-radius:var(--r); overflow:hidden;
    background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.006));
    transition:transform .45s var(--ease), border-color .4s; display:flex; flex-direction:column;
  }
  .sp-card.has-bio{ cursor:pointer; }
  .sp-card:hover{ transform:translateY(-6px); border-color:var(--gold); }
  .sp-card:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }
  .sp-photo{ position:relative; aspect-ratio:3/4; overflow:hidden; background:linear-gradient(165deg, var(--ink-3), var(--ink-2)); display:grid; place-items:center; }
  .sp-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
  .sp-card:hover .sp-photo img{ transform:scale(1.05); }
  .sp-initials{ font-family:var(--font-d); font-size:2.6rem; color:var(--gold); opacity:.5; letter-spacing:.04em; }
  .sp-more{
    position:absolute; left:0; right:0; bottom:0; padding:30px 16px 12px;
    display:flex; align-items:center; gap:6px; justify-content:center;
    font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:#12100a; font-weight:600;
    background:linear-gradient(180deg, transparent, var(--gold) 80%);
    transform:translateY(101%); transition:transform .4s var(--ease);
  }
  .sp-card:hover .sp-more, .sp-card:focus-visible .sp-more{ transform:translateY(0); }
  .sp-more .ar{ transition:transform .4s var(--ease); }
  .sp-card:hover .sp-more .ar{ transform:translateX(4px); }
  .sp-info{ padding:16px 18px 20px; }
  .sp-info h4{ font-family:var(--font-d); font-size:1.12rem; font-weight:600; line-height:1.2; letter-spacing:-.01em; }
  .sp-info p{ color:var(--muted); font-size:.85rem; margin-top:6px; line-height:1.45; }
  .sp-info p.muted{ color:var(--muted-2); font-style:italic; }
  @media(max-width:520px){ .sp-grid{ grid-template-columns:1fr 1fr; gap:12px; } .sp-info{ padding:12px 14px 16px; } .sp-info h4{ font-size:1rem; } }

  /* ============ ELŐADÓ MODAL ============ */
  .sp-modal{ position:fixed; inset:0; z-index:120; display:none; }
  .sp-modal.open{ display:block; }
  .sp-modal-backdrop{ position:absolute; inset:0; background:rgba(4,6,12,.82); backdrop-filter:blur(8px); animation:fade .3s var(--ease); }
  @keyframes fade{ from{ opacity:0 } to{ opacity:1 } }
  .sp-modal-box{
    position:relative; z-index:1; max-width:880px; margin:6vh auto; width:calc(100% - 36px);
    max-height:88vh; overflow:auto; border:1px solid var(--line); border-radius:var(--r-lg);
    background:linear-gradient(170deg, var(--ink-3), var(--ink)); box-shadow:0 40px 90px -30px rgba(0,0,0,.8);
    animation:pop .4s var(--ease);
  }
  @keyframes pop{ from{ opacity:0; transform:translateY(20px) scale(.98) } to{ opacity:1; transform:none } }
  .sp-modal-close{ position:absolute; top:14px; right:16px; z-index:2; width:42px; height:42px; border-radius:50%; border:1px solid var(--line); background:rgba(0,0,0,.3); color:var(--text); font-size:1.6rem; line-height:1; cursor:pointer; transition:.3s; }
  .sp-modal-close:hover{ background:var(--gold); color:#12100a; border-color:var(--gold); }
  .sp-modal-grid{ display:grid; grid-template-columns:300px 1fr; }
  .sp-modal-photo{ background:var(--ink-2); }
  .sp-modal-photo img{ width:100%; height:100%; object-fit:cover; min-height:100%; }
  .sp-modal-body{ padding:46px 44px; }
  .sp-modal-panel{ display:inline-block; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:14px; padding:6px 14px; border:1px solid var(--line); border-radius:100px; }
  .sp-modal-body h3{ font-family:var(--font-d); font-size:2rem; line-height:1.1; }
  .sp-modal-role{ color:var(--gold-bright); font-size:1rem; margin:10px 0 22px; font-weight:500; }
  .sp-modal-bio p{ color:var(--muted); font-size:1.02rem; line-height:1.7; margin-bottom:16px; }
  .sp-modal-bio p:last-child{ margin-bottom:0; }
  @media(max-width:680px){
    .sp-modal-grid{ grid-template-columns:1fr; }
    .sp-modal-photo{ aspect-ratio:16/10; }
    .sp-modal-body{ padding:32px 26px; }
    .sp-modal-box{ margin:4vh auto; max-height:92vh; }
  }

  /* ============ ELŐADÓ CAROUSEL ============ */
  .sp-carousel{ margin-top:46px; position:relative; }
  .sp-carousel-controls{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:18px; flex-wrap:wrap; }
  .sp-hint{ font-size:.82rem; color:var(--muted-2); letter-spacing:.04em; }
  .sp-hint .ar{ color:var(--gold); }
  .sp-cnav-wrap{ display:flex; gap:10px; }
  .sp-cnav{ width:48px; height:48px; border-radius:50%; border:1px solid var(--line); background:rgba(255,255,255,.02); color:var(--gold); font-size:1.5rem; line-height:1; cursor:pointer; transition:.3s var(--ease); display:grid; place-items:center; }
  .sp-cnav:hover{ background:var(--gold); color:#12100a; border-color:var(--gold); transform:translateY(-2px); }
  .sp-cnav:disabled{ opacity:.28; cursor:default; transform:none; background:rgba(255,255,255,.02); color:var(--gold); }
  .sp-track{
    display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
    padding:6px max(28px, calc((100vw - var(--maxw)) / 2 + 28px)) 18px;
    -ms-overflow-style:none; scrollbar-width:none; cursor:grab;
  }
  .sp-track.dragging{ cursor:grabbing; scroll-behavior:auto; scroll-snap-type:none; }
  .sp-track::-webkit-scrollbar{ display:none; }
  .sp-track > .sp-card{ flex:0 0 232px; width:232px; scroll-snap-align:start; }
  .sp-carousel::before, .sp-carousel::after{ content:""; position:absolute; top:0; bottom:18px; width:70px; z-index:2; pointer-events:none; }
  .sp-carousel::before{ left:0; background:linear-gradient(90deg, var(--ink), transparent); }
  .sp-carousel::after{ right:0; background:linear-gradient(270deg, var(--ink), transparent); }
  @media(max-width:600px){
    .sp-track > .sp-card{ flex-basis:172px; width:172px; }
    .sp-track{ padding:6px 16px 16px; }
    .sp-carousel::before, .sp-carousel::after{ width:32px; }
  }
