/* ══════════════════════════════════════════
     DESIGN TOKENS
  ══════════════════════════════════════════ */
  :root {
    /* Core palette */
    --cream:        #FFF8F0;   /* main background */
    --cream-deep:   #F5EDE0;   /* slightly richer cream for alternating sections */
    --orange:       #E8651A;
    --orange-lt:    #F07B30;
    --orange-pale:  #FDECD9;   /* very light orange tint for cards/accents */
    --royal:        #2F5FC4;   /* lighter royal blue */
    --royal-lt:     #4A74D8;   /* hover / lighter royal */
    --royal-pale:   #E8EFFC;   /* very light royal blue for card tints */
    --navy:         #1B2D4F;   /* dark text / borders */
    --navy-mid:     #243A63;
    --mid:          #5A6E8A;   /* secondary text */
    --white:        #FFFFFF;
    --ink:          #1B2D4F;

    --r:    16px;
    --r-lg: 28px;
    --r-xl: 40px;
  }

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }

  body {
    font-family: 'DM Sans', sans-serif;
    background: var(--cream);
    color: var(--ink);
    overflow-x: hidden;
  }

  /* ══════════════════════════════════════════
     NAV  — transparent until scrolled
  ══════════════════════════════════════════ */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 200;
    height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 5%;
    background: transparent;
    border-bottom: 1px solid transparent;
    transition: background 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
  }

  nav.scrolled {
    background: rgba(255,248,240,0.97);
    backdrop-filter: blur(16px);
    border-bottom: 2px solid var(--navy);
    box-shadow: 0 2px 16px rgba(27,45,79,0.08);
  }

  .nav-logo {
    font-family: 'Abril Fatface', serif;
    font-size: 1.65rem;
    color: #fff;
    text-decoration: none;
    letter-spacing: -0.5px;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    transition: color 0.3s;
  }
  nav.scrolled .nav-logo { color: var(--navy); }
  .nav-logo .heart { color: var(--orange); }

  .nav-links {
    display: flex;
    align-items: center;
    gap: 1.8rem;
    list-style: none;
  }
  .nav-links a {
    text-decoration: none;
    font-weight: 500;
    color: rgba(255,255,255,0.88);
    font-size: 0.92rem;
    transition: color 0.2s;
  }
  .nav-links a:hover { color: #fff; }
  nav.scrolled .nav-links a { color: var(--mid); }
  nav.scrolled .nav-links a:hover { color: var(--navy); }

  .nav-ticket-btn {
    background: var(--orange) !important;
    color: #fff !important;
    padding: 0.48rem 1.2rem;
    border-radius: 50px;
    font-weight: 700 !important;
    font-size: 0.88rem !important;
    transition: background 0.2s, transform 0.15s !important;
  }
  .nav-ticket-btn:hover { background: var(--orange-lt) !important; transform: scale(1.05) !important; }

  .hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
  .hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; transition: background 0.3s; }
  nav.scrolled .hamburger span { background: var(--navy); }

  /* ══════════════════════════════════════════
     BUTTONS
  ══════════════════════════════════════════ */
  .btn {
    display: inline-block;
    padding: 0.85rem 2rem;
    border-radius: 50px;
    font-weight: 700;
    font-size: 1rem;
    text-decoration: none;
    cursor: pointer;
    border: 2px solid transparent;
    transition: transform 0.15s, box-shadow 0.2s, background 0.2s;
    font-family: 'DM Sans', sans-serif;
  }
  .btn:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.15); }

  .btn-orange   { background: var(--orange); color: #fff; border-color: var(--orange); }
  .btn-orange:hover { background: var(--orange-lt); }

  .btn-royal    { background: var(--royal); color: #fff; border-color: var(--royal); }
  .btn-royal:hover { background: var(--royal-lt); }

  .btn-navy     { background: var(--navy); color: #fff; border-color: var(--navy); }
  .btn-navy:hover { background: var(--navy-mid); }

  .btn-outline  { background: transparent; color: var(--navy); border-color: var(--navy); }
  .btn-outline:hover { background: var(--navy); color: var(--cream); }

  .btn-outline-orange { background: transparent; color: var(--orange); border-color: var(--orange); }
  .btn-outline-orange:hover { background: var(--orange); color: #fff; }

  /* ══════════════════════════════════════════
     SECTION SHARED
  ══════════════════════════════════════════ */
  .section-wrap {
    max-width: 1180px;
    margin: 0 auto;
    padding: 6rem 5%;
  }

  .section-tag {
    display: inline-block;
    font-family: 'Caveat', cursive;
    font-size: 1.2rem;
    color: var(--orange);
    margin-bottom: 0.4rem;
  }
  .section-tag.royal { color: var(--royal); }

  .section-title {
    font-family: 'Abril Fatface', serif;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.12;
    margin-bottom: 0.9rem;
  }

  .section-sub {
    font-size: 1rem;
    color: var(--mid);
    line-height: 1.75;
    max-width: 520px;
  }

  /* ══════════════════════════════════════════
     ANIMATIONS
  ══════════════════════════════════════════ */
  @keyframes fadeUp   { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
  @keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
  @keyframes spin-slow{ from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
  @keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }

  .fade-up { opacity:0; animation: fadeUp 0.7s ease forwards; animation-play-state:paused; }

  /* ══════════════════════════════════════════
     HERO  — full background image
  ══════════════════════════════════════════ */
  #home {
    min-height: 100vh;
    /*
      TO REPLACE WITH YOUR OWN IMAGE:
      1. Place your image file (e.g. hero-bg.jpg) in the same folder as index.html
      2. Change the url() below to: url('hero-bg.jpg')
      The dark gradient overlay on top ensures text stays readable.
    */
    background:
      linear-gradient(to bottom,
        rgba(15,25,50,0.52) 0%,
        rgba(15,25,50,0.35) 50%,
        rgba(15,25,50,0.62) 100%),
      url('img/hero.png')
      center center / cover no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    overflow: hidden;
    padding: 9rem 5% 5rem;
  }

  .hero-free-badge {
    position: absolute;
    top: 90px; right: 6%;
    background: var(--orange);
    color: #fff;
    font-family: 'Abril Fatface', serif;
    font-size: 1rem;
    padding: 0.6rem 1.3rem;
    border-radius: 50px;
    border: 3px solid rgba(255,255,255,0.8);
    animation: float 4s ease-in-out infinite;
    z-index: 2;
    letter-spacing: 0.03em;
  }

  .hero-content { position:relative; z-index:2; max-width:820px; }

  .hero-eyebrow {
    font-family: 'Caveat', cursive;
    font-size: 1.4rem;
    color: rgba(255,255,255,0.82);
    display: block;
    margin-bottom: 1.5rem;
    animation: fadeUp 0.6s ease 0.1s both;
    letter-spacing: 0.04em;
  }

  /* ── Logo image replaces the text title ── */
  .hero-logo-img {
    display: block;
    margin: 0 auto 2rem;
    max-width: min(720px, 78vw);
    width: 100%;
    animation: fadeUp 0.65s ease 0.2s both;
    filter: drop-shadow(0 4px 28px rgba(0,0,0,0.5));
  }

  @media (max-width: 430px ) {
      .hero-logo-img {
        max-width: 800px;
        margin-bottom: 0;
      }
      .hero-details-strip {
        flex-direction: column;
      }
      .hero-eyebrow {
        margin-bottom: 0;
      }
  }

  /* Dashed placeholder — remove once real logo is swapped in */
  
  .hero-details-strip {
    display: inline-flex;
    gap: 0;
    border: 2px solid rgba(255,255,255,0.4);
    border-radius: var(--r-lg);
    overflow: hidden;
    margin-bottom: 2.2rem;
    animation: fadeUp 0.6s ease 0.38s both;
    flex-wrap: wrap;
    justify-content: center;
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(10px);
  }

  .hd-item {
    padding: 0.8rem 1.7rem;
    border-right: 2px solid rgba(255,255,255,0.2);
    text-align: center;
  }
  .hd-item:last-child { border-right: none; }
  .hd-label { font-size: 0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--orange); display:block; margin-bottom:0.2rem; }
  .hd-val   { font-weight:700; color:#fff; font-size:0.97rem; }

  .hero-actions { animation: fadeUp 0.6s ease 0.52s both; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

  /* outline btn readable over dark hero bg */
  #home .btn-outline {
    color: #fff;
    border-color: rgba(255,255,255,0.55);
    background: transparent;
  }
  #home .btn-outline:hover {
    background: rgba(255,255,255,0.12);
    border-color: #fff;
    color: #fff;
    box-shadow: none;
  }

  /* ══════════════════════════════════════════
     TICKER BAND
  ══════════════════════════════════════════ */
  .ticker {
    background: var(--royal);
    overflow: hidden;
    padding: 0.85rem 0;
    border-top: 2px solid var(--navy);
    border-bottom: 2px solid var(--navy);
  }
  .ticker-track {
    display: flex;
    width: max-content;
    gap: 3rem;
    animation: marquee 30s linear infinite;
  }
  .ticker:hover .ticker-track { animation-play-state:paused; }
  .ticker-item {
    display:flex; align-items:center; gap:0.5rem;
    color:#fff; font-weight:700; font-size:0.88rem;
    letter-spacing:0.04em; white-space:nowrap;
  }
  .ticker-sep { opacity:0.45; }

  /* ══════════════════════════════════════════
     HIGHLIGHTS  — cream-deep background
  ══════════════════════════════════════════ */
  #highlights { background: var(--cream-deep); }

  .highlights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 1.5rem;
    margin-top: 3rem;
  }

  .hl-card {
    background: var(--white);
    border: 2px solid var(--navy);
    border-radius: var(--r-lg);
    padding: 2rem 1.6rem;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s;
    cursor: default;
  }
  .hl-card:hover { transform:translateY(-5px); box-shadow:6px 6px 0 var(--navy); }

  .hl-icon {
    width:64px; height:64px;
    border-radius:18px;
    display:flex; align-items:center; justify-content:center;
    font-size:1.8rem;
    margin: 0 auto 1.1rem;
    border: 2px solid var(--navy);
  }
  .hl-icon.orange { background: var(--orange-pale); }
  .hl-icon.royal  { background: var(--royal-pale); }

  .hl-card h3 { font-family:'Abril Fatface',serif; font-size:1.2rem; margin-bottom:0.4rem; }
  .hl-card p  { color:var(--mid); font-size:0.9rem; line-height:1.55; }

  /* ══════════════════════════════════════════
     EVENT INFO  — cream background
  ══════════════════════════════════════════ */
  #event { background: var(--cream); }

  .event-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
    margin-top: 3rem;
  }

  .event-details { display:flex; flex-direction:column; gap:1.1rem; }

  .ev-row {
    display:flex; align-items:flex-start; gap:1rem;
    background: var(--white);
    border: 2px solid var(--navy);
    border-radius: var(--r);
    padding: 1.2rem 1.4rem;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .ev-row:hover { transform:translateX(5px); box-shadow:4px 4px 0 var(--navy); }

  .ev-icon {
    width:46px; height:46px;
    border-radius:12px;
    border: 2px solid var(--navy);
    display:flex; align-items:center; justify-content:center;
    font-size:1.3rem; flex-shrink:0;
  }
  .ev-icon.orange { background: var(--orange-pale); }
  .ev-icon.royal  { background: var(--royal-pale); }

  .ev-row h4 { font-weight:700; font-size:0.78rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--mid); margin-bottom:0.15rem; }
  .ev-row p  { font-weight:700; font-size:1rem; color:var(--ink); }
  .ev-row p small { font-weight:400; font-size:0.85rem; color:var(--mid); display:block; margin-top:0.1rem; }

  /* Schedule */
  .schedule-card {
    background: var(--royal);
    border-radius: var(--r-lg);
    padding: 2rem 2rem 1.5rem;
    border: 2px solid var(--navy);
  }
  .schedule-card h3 {
    font-family:'Abril Fatface',serif;
    color:#fff;
    font-size:1.3rem;
    margin-bottom:1.5rem;
  }
  .sched-line {
    display:flex; gap:1rem; align-items:flex-start;
    padding:0.75rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.12);
  }
  .sched-line:last-child { border-bottom:none; }
  .sched-dot { width:10px; height:10px; background:var(--orange); border-radius:50%; flex-shrink:0; margin-top:5px; }
  .sched-time { font-family:'Caveat',cursive; font-size:1rem; color:var(--orange); min-width:70px; }
  .sched-label { color:#fff; font-size:0.92rem; font-weight:500; }
  .sched-label small { color:rgba(255,255,255,0.45); font-size:0.8rem; display:block; margin-top:0.1rem; }

  /* ══════════════════════════════════════════
     TICKETS  — cream background, big + simple
  ══════════════════════════════════════════ */
  #tickets {
    background: var(--cream);
    border-top: 2px solid rgba(27,45,79,0.08);
    border-bottom: 2px solid rgba(27,45,79,0.08);
    position: relative;
    overflow: hidden;
  }

  .tickets-wrap {
    max-width: 1180px;
    margin: 0 auto;
    padding: 6rem 5%;
    text-align: center;
    position: relative;
    z-index: 2;
  }

  /* Soft decorative stars in background */
  .t-deco {
    position: absolute;
    pointer-events: none;
    font-family: 'Abril Fatface', serif;
  }
  .td1 { font-size:16rem; color:var(--orange); opacity:0.04; top:-3rem; left:-2rem; animation:spin-slow 40s linear infinite; }
  .td2 { font-size:12rem; color:var(--royal);  opacity:0.04; bottom:-2rem; right:-1rem; animation:spin-slow 30s linear infinite reverse; }

  .tickets-eyebrow {
    font-family: 'Caveat', cursive;
    font-size: 1.3rem;
    color: var(--royal);
    display: block;
    margin-bottom: 0.5rem;
  }

  .tickets-title {
    font-family: 'Abril Fatface', serif;
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    line-height: 1.05;
    color: var(--navy);
    margin-bottom: 0.5rem;
  }
  .tickets-title .free-word { color: var(--orange); }

  .tickets-sub {
    font-size: 1.1rem;
    color: var(--mid);
    line-height: 1.75;
    max-width: 520px;
    margin: 0 auto 2.5rem;
  }

  .tickets-free-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--orange-pale);
    border: 2px solid var(--orange);
    border-radius: 50px;
    padding: 0.55rem 1.5rem;
    font-weight: 700;
    font-size: 1rem;
    color: var(--orange);
    margin-bottom: 2rem;
    letter-spacing: 0.02em;
  }

  .tickets-main-btn {
    display: inline-block;
    padding: 1.1rem 3rem;
    background: var(--orange);
    color: #fff;
    font-family: 'Abril Fatface', serif;
    font-size: 1.4rem;
    border-radius: 50px;
    border: 3px solid var(--navy);
    text-decoration: none;
    transition: transform 0.15s, box-shadow 0.2s, background 0.2s;
    letter-spacing: 0.02em;
    box-shadow: 5px 5px 0 var(--navy);
  }
  .tickets-main-btn:hover { background: var(--orange-lt); transform:translateY(-3px); box-shadow: 7px 7px 0 var(--navy); }

  .tickets-note {
    display: block;
    margin-top: 1.2rem;
    font-size: 0.82rem;
    color: var(--mid);
  }

  /* ══════════════════════════════════════════
     MISSION  — cream-deep, centered
  ══════════════════════════════════════════ */
  #mission {
    background: var(--cream-deep);
    padding: 6rem 5%;
    text-align: center;
    position: relative;
    overflow: hidden;
  }

  .mission-inner { max-width: 760px; margin: 0 auto; position:relative; z-index:2; }
  .mission-inner .section-tag { color: var(--royal); }

  /* Decorative quote marks */
  .mission-qmark {
    font-family: 'Abril Fatface', serif;
    font-size: 8rem;
    line-height: 0.7;
    color: var(--orange);
    opacity: 0.12;
    display: block;
    margin-bottom: -1rem;
  }

  .mission-quote {
    font-family: 'Abril Fatface', serif;
    font-size: clamp(1.5rem, 3.5vw, 2.3rem);
    color: var(--navy);
    line-height: 1.38;
    margin: 0.5rem 0 1.5rem;
  }
  .mission-quote .royal  { color: var(--royal); }
  .mission-quote .orange { color: var(--orange); }

  .mission-divider {
    width: 60px; height: 3px;
    background: var(--orange);
    border-radius: 3px;
    margin: 0 auto 1.5rem;
  }

  .mission-body {
    font-size: 1.05rem;
    color: var(--mid);
    line-height: 1.8;
    max-width: 580px;
    margin: 0 auto;
  }

  /* corner deco stars */
  .m-star { position:absolute; font-size:3.5rem; opacity:0.06; pointer-events:none; font-family:'Abril Fatface',serif; }
  .ms1 { top:1rem;    left:3%;  color:var(--orange); animation:spin-slow 18s linear infinite; }
  .ms2 { bottom:1rem; right:3%; color:var(--royal);  font-size:2.5rem; animation:spin-slow 14s linear infinite reverse; }
  .ms3 { top:40%;     left:8%;  color:var(--royal);  font-size:2rem; animation:float 8s ease-in-out infinite; }

  /* ══════════════════════════════════════════
     VENDORS & ARTISTS  — cream background
  ══════════════════════════════════════════ */
  #vendors { background: var(--cream); }

  .vendors-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.8rem;
    margin-top: 3rem;
  }

  .vendor-card {
    border: 2px solid var(--navy);
    border-radius: var(--r-lg);
    padding: 2.2rem;
    position: relative;
    overflow: hidden;
    transition: transform 0.2s, box-shadow 0.2s;
  }
  .vendor-card:hover { transform:translateY(-5px); box-shadow:6px 6px 0 var(--navy); }

  /* Each card gets its own tint */
  .vc-navy   { background: var(--navy); }
  .vc-orange { background: var(--orange-pale); }
  .vc-royal  { background: var(--royal-pale); }

  .vc-badge {
    display: inline-block;
    font-family: 'Caveat', cursive;
    font-size: 1.1rem;
    padding: 0.2rem 0.9rem;
    border-radius: 50px;
    margin-bottom: 1rem;
    border: 2px solid var(--navy);
    font-weight: 700;
  }
  .vc-navy   .vc-badge { background:rgba(232,101,26,0.2);   color:var(--orange);  border-color:rgba(232,101,26,0.4); }
  .vc-orange .vc-badge { background:var(--navy);            color:#fff;           border-color:var(--navy); }
  .vc-royal  .vc-badge { background:var(--royal);           color:#fff;           border-color:var(--royal); }

  .vendor-card h3 { font-family:'Abril Fatface',serif; font-size:1.75rem; margin-bottom:0.6rem; }
  .vc-navy   h3 { color:#fff; }
  .vc-orange h3 { color:var(--navy); }
  .vc-royal  h3 { color:var(--navy); }

  .vendor-card > p { line-height:1.7; font-size:0.93rem; margin-bottom:1.2rem; }
  .vc-navy   > p { color:rgba(255,248,240,0.55); }
  .vc-orange > p { color:var(--mid); }
  .vc-royal  > p { color:var(--mid); }

  .vc-list { list-style:none; display:flex; flex-direction:column; gap:0.45rem; margin-bottom:1.8rem; }
  .vc-list li { font-size:0.9rem; display:flex; align-items:center; gap:0.6rem; }
  .vc-list li::before { content:''; width:7px; height:7px; border-radius:50%; flex-shrink:0; }
  .vc-navy   .vc-list li { color:rgba(255,248,240,0.75); }
  .vc-navy   .vc-list li::before { background:var(--orange); }
  .vc-orange .vc-list li { color:var(--ink); }
  .vc-orange .vc-list li::before { background:var(--navy); }
  .vc-royal  .vc-list li { color:var(--ink); }
  .vc-royal  .vc-list li::before { background:var(--royal); }

  /* Steps */
  .steps-row {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 1.5rem;
    margin: 2.5rem 0 0;
  }

  .step-box {
    background: var(--white);
    border: 2px solid var(--navy);
    border-radius: var(--r-lg);
    padding: 1.8rem 1.4rem;
    text-align: center;
    transition: box-shadow 0.2s, transform 0.2s;
  }
  .step-box:hover { box-shadow:5px 5px 0 var(--navy); transform:translateY(-3px); }

  .step-num {
    font-family: 'Abril Fatface', serif;
    font-size: 3.5rem;
    color: var(--orange);
    line-height: 1;
    -webkit-text-stroke: 2px var(--navy);
    margin-bottom: 0.5rem;
  }
  .step-box h4 { font-weight:700; margin-bottom:0.3rem; }
  .step-box p  { color:var(--mid); font-size:0.88rem; line-height:1.55; }

  /* ══════════════════════════════════════════
     CONTACT  — cream-deep background
  ══════════════════════════════════════════ */
  #contact { background: var(--cream-deep); }

  .contact-layout {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 4rem;
    align-items: start;
    margin-top: 3rem;
  }

  .contact-left h3 { font-family:'Abril Fatface',serif; font-size:1.6rem; margin-bottom:0.6rem; }
  .contact-left > p { color:var(--mid); line-height:1.75; margin-bottom:1.5rem; font-size:0.97rem; }

  .c-method {
    display:flex; gap:0.9rem; align-items:flex-start;
    background: var(--white);
    border: 2px solid var(--navy);
    border-radius: var(--r);
    padding: 1.1rem 1.2rem;
    margin-bottom: 0.75rem;
    transition: transform 0.18s, box-shadow 0.18s;
  }
  .c-method:hover { transform:translateX(4px); box-shadow:4px 4px 0 var(--navy); }

  .c-icon {
    width:42px; height:42px;
    border:2px solid var(--navy);
    border-radius:10px;
    display:flex; align-items:center; justify-content:center;
    font-size:1.1rem; flex-shrink:0;
  }
  .c-icon.orange { background:var(--orange-pale); }
  .c-icon.royal  { background:var(--royal-pale); }

  .c-method h4 { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--mid); margin-bottom:0.12rem; }
  .c-method a, .c-method p { color:var(--ink); font-size:0.93rem; font-weight:600; text-decoration:none; }
  .c-method a:hover { color:var(--orange); }

  .social-row { display:flex; gap:0.6rem; flex-wrap:wrap; margin-top:1.2rem; }
  .social-pill {
    display:inline-flex; align-items:center; gap:0.4rem;
    padding:0.45rem 1rem;
    border:2px solid var(--navy);
    border-radius:50px;
    font-size:0.83rem; font-weight:700;
    color:var(--navy); text-decoration:none;
    background:var(--white);
    transition: background 0.2s, color 0.2s, transform 0.15s;
  }
  .social-pill:hover { background:var(--navy); color:#fff; transform:scale(1.05); }

  /* Form */
  .form-box {
    background: var(--white);
    border: 2px solid var(--navy);
    border-radius: var(--r-xl);
    padding: 2.5rem;
    box-shadow: 6px 6px 0 var(--navy);
  }
  .form-box h3 { font-family:'Abril Fatface',serif; font-size:1.5rem; margin-bottom:0.3rem; }
  .form-box > p { color:var(--mid); font-size:0.88rem; margin-bottom:1.6rem; }

  .form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

  .fg { margin-bottom:1rem; }
  .fg label { display:block; font-size:0.8rem; font-weight:700; color:var(--ink); margin-bottom:0.35rem; }
  .fg input, .fg select, .fg textarea {
    width:100%;
    padding:0.72rem 1rem;
    border:2px solid rgba(27,45,79,0.15);
    border-radius:var(--r);
    font-family:'DM Sans',sans-serif;
    font-size:0.93rem;
    color:var(--ink);
    background:var(--cream);
    outline:none;
    transition: border-color 0.2s, box-shadow 0.2s;
    resize:none;
  }
  .fg input:focus, .fg select:focus, .fg textarea:focus {
    border-color:var(--royal);
    box-shadow:0 0 0 3px rgba(47,95,196,0.1);
    background:#fff;
  }
  .fg textarea { height:120px; }

  .form-submit {
    width:100%;
    padding:0.9rem;
    background:var(--royal);
    color:#fff;
    border:2px solid var(--navy);
    border-radius:50px;
    font-family:'DM Sans',sans-serif;
    font-size:1rem; font-weight:700;
    cursor:pointer;
    transition: background 0.2s, transform 0.15s;
  }
  .form-submit:hover { background:var(--royal-lt); transform:translateY(-2px); }

  .form-note { font-size:0.78rem; color:var(--mid); text-align:center; margin-top:0.6rem; }

  .form-success { display:none; text-align:center; padding:2.5rem 1rem; }
  .form-success .fs-icon { font-size:2.8rem; display:block; margin-bottom:0.75rem; }
  .form-success h3 { font-family:'Abril Fatface',serif; font-size:1.5rem; margin-bottom:0.4rem; }
  .form-success p  { color:var(--mid); font-size:0.93rem; }

  /* ══════════════════════════════════════════
     FOOTER
  ══════════════════════════════════════════ */
  footer {
    background: var(--navy);
    color: #fff;
    padding: 3.5rem 5% 2rem;
    text-align: center;
    border-top: 3px solid var(--orange);
  }
  .footer-logo { font-family:'Abril Fatface',serif; font-size:2rem; margin-bottom:0.6rem; }
  .footer-logo .heart { color:var(--orange); }
  .footer-links { display:flex; justify-content:center; flex-wrap:wrap; gap:1.8rem; list-style:none; margin:1rem 0; }
  .footer-links a { color:rgba(255,248,240,0.55); text-decoration:none; font-size:0.88rem; transition:color 0.2s; }
  .footer-links a:hover { color:var(--orange); }
  .footer-copy { color:rgba(255,248,240,0.28); font-size:0.8rem; margin-top:1.2rem; }

  /* ══════════════════════════════════════════
     CONFETTI
  ══════════════════════════════════════════ */
  #confetti-canvas { position:fixed; top:0;left:0;width:100%;height:100%; pointer-events:none; z-index:9999; }

  /* ══════════════════════════════════════════
     RESPONSIVE
  ══════════════════════════════════════════ */
  @media (max-width:960px) {
    .vendors-grid { grid-template-columns:1fr 1fr; }
  }
  @media (max-width:900px) {
    .event-layout   { grid-template-columns:1fr; }
    .contact-layout { grid-template-columns:1fr; }
    .steps-row      { grid-template-columns:1fr; }
  }
  @media (max-width:700px) {
    .vendors-grid { grid-template-columns:1fr; }
  }
  @media (max-width:768px) {
    .nav-links { display:none; flex-direction:column; position:absolute; top:72px; left:0;right:0; background:rgba(255,248,240,0.98); border-bottom:2px solid var(--navy); padding:1.5rem 5%; gap:1.2rem; }
    .nav-links.open { display:flex; }
    .hamburger { display:flex; }
    .hero-free-badge { top:82px; right:3%; font-size:0.85rem; padding:0.5rem 1rem; }
    .form-row-2 { grid-template-columns:1fr; }
    .tickets-main-btn { font-size:1.15rem; padding:0.95rem 2rem; }
  }

/* ── Extra utility classes referenced in HTML ── */
.sched-note {
  color: rgba(255,255,255,0.25);
  font-size: 0.78rem;
  margin-top: 1rem;
}

.social-label {
  font-weight: 700;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--mid);
}

.footer-tagline {
  color: rgba(255,248,240,0.45);
  font-size: 0.88rem;
  max-width: 360px;
  margin: 0 auto 1rem;
  line-height: 1.6;
}
