  :root{
    --bg: #0b0b0f;
    --bg-2: #0f0f15;
    --ink: #f4f1ec;
    --ink-dim: #b3acaa;
    --ink-mute: #6b6770;
    --line: rgba(255,255,255,0.08);
    --line-strong: rgba(255,255,255,0.16);
    --accent: #FA9300;
    --accent-2: #ffb84d;
    --accent-soft: rgba(250, 147, 0, 0.22);
    --serif: "Space Grotesk", system-ui, sans-serif;
    --sans: "Inter", system-ui, sans-serif;
    --mono: "JetBrains Mono", ui-monospace, monospace;
  }
  *{ box-sizing: border-box; margin:0; padding:0; }
  html,body{ background: var(--bg); color: var(--ink); font-family: var(--sans); font-weight: 400; line-height: 1.6; -webkit-font-smoothing: antialiased; }
  body{ overflow-x: hidden; }
  a{ color: inherit; text-decoration: none; }
  img{ display:block; max-width:100%; height:auto; }
  ::selection{ background: var(--accent); color: #0b0b0f; }

  /* ============ NAV ============ */
  .nav{
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    display: flex; align-items:center; justify-content: space-between;
    padding: 18px 40px;
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    background: rgba(11,11,15,0.6);
    border-bottom: 1px solid var(--line);
    transition: padding .3s ease, background .3s ease;
  }
  .nav.scrolled{ padding: 12px 40px; background: rgba(11,11,15,0.85); }
  .nav__brand{ display:flex; align-items:center; gap: 14px; font-family: var(--serif); font-weight: 600; letter-spacing: -0.01em; }
  .nav__logo{ height: 38px; width: auto; display: block; filter: brightness(0) invert(1); transition: filter .3s ease; }
  .nav__logo--color{ filter: none; }
  .nav__brand:hover .nav__logo{ filter: none; }
  .nav__sep{ width: 1px; height: 22px; background: var(--line-strong); }
  .nav__brand-text{ font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim); font-weight: 400; line-height: 1.4; }

  .nav__links{ display: flex; gap: 28px; align-items:center; }
  .nav__links a{
    font-size: 14px; color: var(--ink-dim); position: relative;
    transition: color .25s ease;
  }
  .nav__links a:hover{ color: var(--ink); }
  .nav__links a::after{
    content:""; position: absolute; left: 0; bottom: -6px; width: 0; height: 1px; background: var(--accent);
    transition: width .3s ease;
  }
  .nav__links a:hover::after{ width: 100%; }
  .nav__cta{
    font-family: var(--serif); font-size: 14px; font-weight: 500;
    padding: 10px 18px; border-radius: 999px;
    background: var(--accent); color: #0b0b0f;
    transition: transform .25s ease, box-shadow .25s ease;
  }
  .nav__cta:hover{ transform: translateY(-1px); box-shadow: 0 10px 30px -8px var(--accent-soft); }

  .nav__burger{ display:none; width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--line-strong); background: transparent; cursor: pointer; align-items: center; justify-content: center; }
  .nav__burger span{ display:block; width: 18px; height: 1.5px; background: var(--ink); position: relative; }
  .nav__burger span::before, .nav__burger span::after{ content:""; position: absolute; left:0; width: 18px; height: 1.5px; background: var(--ink); transition: transform .3s ease; }
  .nav__burger span::before{ top: -6px; }
  .nav__burger span::after{ top: 6px; }
  .nav.is-open .nav__burger span{ background: transparent; }
  .nav.is-open .nav__burger span::before{ transform: translateY(6px) rotate(45deg); }
  .nav.is-open .nav__burger span::after{ transform: translateY(-6px) rotate(-45deg); }

  /* ============ HERO ============ */
  .hero{
    position: relative; min-height: 100vh; padding: 140px 40px 120px;
    display: flex; align-items: center;
    overflow: hidden;
    background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(250, 147, 0, 0.20), transparent 60%), var(--bg);
  }
  .hero__bg{ position:absolute; inset:0; z-index: 0; pointer-events:none; }
  .hero__bg svg{ width:100%; height:100%; }

  .hero__inner{
    position: relative; z-index: 2;
    max-width: 1280px; margin: 0 auto; width: 100%;
    display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 60px; align-items: center;
  }
  .hero__eyebrow{
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ink-dim);
    padding: 8px 14px; border-radius: 999px; border: 1px solid var(--line-strong);
    background: rgba(255,255,255,0.02);
  }
  .hero__eyebrow .dot{ width: 6px; height: 6px; border-radius: 999px; background: var(--accent); box-shadow: 0 0 10px var(--accent); animation: pulse 2.4s ease-in-out infinite; }
  @keyframes pulse{ 0%,100%{ opacity: 1; transform: scale(1); } 50%{ opacity: .55; transform: scale(1.4); } }

  .hero__title{
    font-family: var(--serif); font-weight: 500; letter-spacing: -0.025em;
    font-size: clamp(44px, 6.4vw, 96px); line-height: 1.02;
    margin-top: 28px;
  }
  .hero__title .accent{ color: var(--accent); font-style: italic; font-weight: 400; }
  .hero__title .stroke{
    -webkit-text-stroke: 1px var(--ink);
    color: transparent;
  }
  .hero__sub{
    margin-top: 28px; font-size: 18px; color: var(--ink-dim); max-width: 540px; line-height: 1.55;
  }
  .hero__cta-row{ display: flex; gap: 14px; margin-top: 38px; flex-wrap: wrap; }
  .btn{
    font-family: var(--serif); font-weight: 500; font-size: 15px;
    padding: 16px 28px; border-radius: 999px; cursor: pointer;
    transition: transform .3s ease, box-shadow .3s ease, background .3s ease;
    display: inline-flex; align-items:center; gap: 10px;
    border: 1px solid transparent;
  }
  .btn--primary{ background: var(--accent); color: #0b0b0f; }
  .btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 20px 40px -12px var(--accent-soft); }
  .btn--ghost{ border-color: var(--line-strong); color: var(--ink); }
  .btn--ghost:hover{ background: rgba(255,255,255,0.04); border-color: var(--ink-dim); }
  .btn .arrow{ transition: transform .3s ease; }
  .btn:hover .arrow{ transform: translateX(4px); }

  .hero__meta{
    margin-top: 80px; display: flex; gap: 48px; flex-wrap: wrap;
  }
  .hero__meta-item .num{ font-family: var(--serif); font-size: 36px; font-weight: 500; letter-spacing: -0.02em; }
  .hero__meta-item .num span{ color: var(--accent); }
  .hero__meta-item .lbl{ font-size: 12px; color: var(--ink-mute); letter-spacing: 0.08em; text-transform: uppercase; margin-top: 4px; }

  /* hero visual */
  .hero__visual{
    position: relative; aspect-ratio: 4/5; border-radius: 24px; overflow: hidden;
    border: 1px solid var(--line-strong);
  }
  .hero__visual::before{
    content:""; position:absolute; inset:0; z-index: 2;
    background: linear-gradient(180deg, transparent 50%, rgba(11,11,15,0.7) 100%);
  }
  .hero__visual img{
    width: 100%; height: 100%; object-fit: cover;
    filter: saturate(1.05) contrast(1.05);
    transition: transform 1.2s cubic-bezier(.2,.7,.2,1);
  }
  .hero__visual:hover img{ transform: scale(1.04); }

  .hero__visual-tag{
    position: absolute; left: 20px; bottom: 20px; z-index: 3;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--ink); padding: 8px 12px; border-radius: 999px;
    background: rgba(11,11,15,0.7); backdrop-filter: blur(8px);
    border: 1px solid var(--line-strong);
    display: inline-flex; align-items:center; gap: 8px;
  }

  .hero__floating{
    position: absolute; right: -28px; top: 30px; z-index: 4;
    background: var(--bg-2); border: 1px solid var(--line-strong);
    padding: 16px 18px; border-radius: 16px; min-width: 220px;
    box-shadow: 0 30px 60px -20px rgba(0,0,0,.6);
    animation: floatY 5s ease-in-out infinite;
  }
  @keyframes floatY{ 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-10px); } }
  .hero__floating .lbl{ font-family: var(--mono); font-size: 10px; color: var(--ink-mute); letter-spacing: .14em; text-transform: uppercase; }
  .hero__floating .val{ font-family: var(--serif); font-size: 17px; margin-top: 6px; }
  .hero__floating .bar{ height: 4px; background: var(--line); border-radius: 999px; margin-top: 12px; overflow: hidden; }
  .hero__floating .bar div{ height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); width: 78%; border-radius: 999px; animation: barflow 3s ease-in-out infinite; }
  @keyframes barflow{ 0%,100%{ width: 78%; } 50%{ width: 92%; } }

  /* SVG decorative shapes */
  .shape{ position: absolute; pointer-events:none; }
  .shape--blob{
    width: 480px; height: 480px;
    right: -120px; top: -120px;
    filter: blur(60px); opacity: .35;
    background: radial-gradient(circle, var(--accent) 0%, transparent 70%);
    border-radius: 50%;
    animation: floatBlob 14s ease-in-out infinite;
  }
  .shape--blob.b2{
    left: -200px; top: 40%;
    background: radial-gradient(circle, var(--accent-2) 0%, transparent 70%);
    width: 380px; height: 380px;
    animation-delay: -6s;
  }
  @keyframes floatBlob{
    0%,100%{ transform: translate(0,0) scale(1); }
    33%{ transform: translate(30px, -20px) scale(1.05); }
    66%{ transform: translate(-20px, 30px) scale(0.95); }
  }

  /* ============ MARQUEE ============ */
  .marquee{
    position: relative; padding: 28px 0; overflow: hidden;
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
    background: var(--bg-2);
  }
  .marquee__track{
    display: flex; gap: 64px; white-space: nowrap; align-items: center;
    animation: marquee 38s linear infinite;
  }
  .marquee__item{
    font-family: var(--serif); font-size: 22px; color: var(--ink-dim); letter-spacing: -0.01em;
    display: inline-flex; align-items: center; gap: 64px;
  }
  .marquee__item::after{
    content:""; width: 6px; height: 6px; border-radius: 999px; background: var(--accent);
  }
  @keyframes marquee{ to{ transform: translateX(-50%); } }

  /* ============ SECTION ============ */
  section{ position: relative; padding: 120px 40px; }
  .container{ max-width: 1280px; margin: 0 auto; position: relative; z-index: 2; }
  .section-head{
    display: grid; grid-template-columns: 0.4fr 0.6fr; gap: 60px; margin-bottom: 80px;
    align-items: end;
  }
  .section-tag{
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent);
    display: inline-flex; align-items:center; gap: 10px;
  }
  .section-tag::before{ content: ""; width: 28px; height: 1px; background: var(--accent); }
  .section-title{
    font-family: var(--serif); font-weight: 400; letter-spacing: -0.022em;
    font-size: clamp(36px, 4.4vw, 60px); line-height: 1.04; margin-top: 18px;
  }
  .section-title .accent{ color: var(--accent); font-style: italic; }
  .section-lede{
    font-size: 17px; color: var(--ink-dim); max-width: 540px; line-height: 1.65;
  }

  /* ============ ABOUT ============ */
  .about{ background: var(--bg); }
  .about__grid{
    display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  }
  .about__card{
    grid-column: span 4;
    border: 1px solid var(--line); border-radius: 20px; padding: 36px;
    background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
    position: relative; overflow: hidden;
    transition: border-color .4s ease, transform .4s ease;
  }
  .about__card:hover{ border-color: var(--line-strong); transform: translateY(-4px); }
  .about__card::before{
    content:""; position: absolute; top:0; left:0; right:0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    opacity: 0; transition: opacity .4s ease;
  }
  .about__card:hover::before{ opacity: 1; }
  .about__card .num{ font-family: var(--mono); font-size: 12px; color: var(--ink-mute); letter-spacing: 0.14em; }
  .about__card h3{ font-family: var(--serif); font-weight: 500; font-size: 24px; letter-spacing: -0.015em; margin-top: 16px; line-height: 1.2; }
  .about__card p{ color: var(--ink-dim); font-size: 15px; margin-top: 14px; line-height: 1.65; }
  .about__card .icon{
    width: 44px; height: 44px; border-radius: 12px;
    border: 1px solid var(--line-strong);
    display: grid; place-items: center; margin-bottom: 24px;
    background: rgba(255,255,255,0.02);
  }

  /* ============ SERVICES ============ */
  .services{
    background: var(--bg-2);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .services__list{
    border-top: 1px solid var(--line);
  }
  .service{
    display: grid; grid-template-columns: 80px 0.4fr 0.6fr 60px;
    gap: 32px; padding: 36px 0;
    border-bottom: 1px solid var(--line);
    align-items: center;
    transition: padding .4s ease;
    cursor: pointer;
  }
  .service:hover{ padding-left: 16px; }
  .service__num{ font-family: var(--mono); font-size: 13px; color: var(--ink-mute); letter-spacing: 0.16em; }
  .service__title{ font-family: var(--serif); font-size: clamp(22px, 2.2vw, 32px); font-weight: 500; letter-spacing: -0.015em; }
  .service__desc{ color: var(--ink-dim); font-size: 15px; line-height: 1.6; }
  .service__arrow{
    width: 44px; height: 44px; border-radius: 999px;
    border: 1px solid var(--line-strong);
    display: grid; place-items:center; transition: background .3s ease, border-color .3s ease, transform .3s ease;
  }
  .service:hover .service__arrow{ background: var(--accent); border-color: var(--accent); transform: rotate(-45deg); }
  .service:hover .service__arrow svg{ stroke: #0b0b0f; }

  /* ============ EVENT TYPES ============ */
  .events{ background: var(--bg); position: relative; }
  .events__grid{
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 60px;
  }
  .events__chip{
    border: 1px solid var(--line); border-radius: 999px; padding: 14px 22px;
    font-family: var(--serif); font-size: 16px; color: var(--ink-dim);
    text-align: center;
    transition: all .3s ease; cursor: default;
    position: relative; overflow: hidden;
  }
  .events__chip:hover{ color: var(--ink); border-color: var(--accent); transform: scale(1.03); }
  .events__chip::before{
    content:""; position:absolute; inset:0; background: var(--accent); opacity: 0;
    transform: scale(0.5); transition: all .4s ease; border-radius: 999px;
    z-index: -1;
  }

  /* ============ DJ FOCUS ============ */
  .dj{
    background: var(--bg-2); position: relative; overflow: hidden;
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  }
  .dj__inner{ display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
  .dj__copy h2{
    font-family: var(--serif); font-weight: 400; letter-spacing: -0.02em;
    font-size: clamp(36px, 4.6vw, 64px); line-height: 1.04;
  }
  .dj__copy h2 .accent{ color: var(--accent); font-style: italic; }
  .dj__copy p{ font-size: 17px; color: var(--ink-dim); margin-top: 24px; max-width: 540px; line-height: 1.65; }
  .dj__list{ margin-top: 36px; display: flex; flex-direction: column; gap: 14px; }
  .dj__list li{
    list-style: none;
    display: flex; gap: 16px; padding: 16px 0; border-top: 1px solid var(--line);
    align-items: center;
  }
  .dj__list li:last-child{ border-bottom: 1px solid var(--line); }
  .dj__list .check{
    flex: 0 0 28px; width: 28px; height: 28px; border-radius: 999px; border: 1px solid var(--accent);
    display: grid; place-items:center; color: var(--accent);
  }
  .dj__list strong{ font-family: var(--serif); font-weight: 500; font-size: 17px; display: block; }
  .dj__list small{ font-size: 13px; color: var(--ink-mute); display: block; margin-top: 2px; }

  .dj__visual{
    aspect-ratio: 1/1; position: relative; border-radius: 24px; overflow: hidden;
    border: 1px solid var(--line-strong);
  }
  .dj__visual img{ width: 100%; height: 100%; object-fit: cover; }
  .dj__visual::before{
    content:""; position: absolute; inset:0;
    background: linear-gradient(180deg, transparent 50%, rgba(11,11,15,0.4));
    z-index: 2;
  }
  .dj__visual-stamp{
    position: absolute; right: 24px; top: 24px; z-index: 3;
    width: 110px; height: 110px; border-radius: 999px;
    background: var(--accent); color: #0b0b0f;
    display: grid; place-items: center;
    font-family: var(--serif); font-weight: 600; font-size: 14px; line-height: 1.1; text-align: center;
    transform: rotate(-8deg);
    animation: spin 22s linear infinite;
  }
  @keyframes spin{ to{ transform: rotate(355deg); } }
  .dj__visual-stamp svg{ animation: spin 22s linear infinite reverse; }

  /* ============ GEAR / BRANDS ============ */
  .gear{ background: var(--bg); }
  .gear__grid{
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
    border: 1px solid var(--line); border-radius: 20px; overflow: hidden;
    background: var(--line);
    margin-top: 60px;
  }
  .gear__item{
    background: var(--bg);
    aspect-ratio: 5/3;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--serif); font-weight: 500; font-size: 18px; letter-spacing: -0.01em;
    color: var(--ink-dim);
    position: relative; overflow: hidden;
    transition: background .3s ease;
  }
  .gear__item:hover{ background: var(--bg-2); color: var(--ink); }
  .gear__item small{
    position: absolute; bottom: 14px; left: 14px;
    font-family: var(--mono); font-size: 10px; color: var(--ink-mute); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 400;
  }

  /* ============ IMPRESSIONS / GALLERY ============ */
  .impressions{
    background: var(--bg-2); position: relative; padding-bottom: 160px;
    border-top: 1px solid var(--line);
  }
  .gallery{
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 110px;
    gap: 12px;
    margin-top: 60px;
  }
  .gallery__item{
    position: relative; overflow: hidden; border-radius: 14px;
    border: 1px solid var(--line);
    cursor: pointer;
  }
  .gallery__item img{
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 1s cubic-bezier(.2,.7,.2,1), filter .6s ease;
    filter: grayscale(0.2) brightness(0.85);
  }
  .gallery__item:hover img{ transform: scale(1.06); filter: grayscale(0) brightness(1); }
  .gallery__item::after{
    content: attr(data-label); position: absolute; bottom: 0; left: 0; right: 0;
    padding: 14px;
    font-family: var(--mono); font-size: 11px; color: var(--ink); letter-spacing: 0.14em; text-transform: uppercase;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
    opacity: 0; transform: translateY(8px);
    transition: all .4s ease;
  }
  .gallery__item:hover::after{ opacity: 1; transform: translateY(0); }

  .gallery__item.s-h2{ grid-column: span 4; grid-row: span 4; }
  .gallery__item.s-h3{ grid-column: span 4; grid-row: span 5; }
  .gallery__item.s-w2{ grid-column: span 4; grid-row: span 3; }
  .gallery__item.s-w3{ grid-column: span 4; grid-row: span 3; }
  .gallery__item.s-sq{ grid-column: span 4; grid-row: span 3; }
  .gallery__item.s-wide{ grid-column: span 8; grid-row: span 3; }

  /* ============ CTA ============ */
  .cta{
    background: var(--bg); position: relative; overflow: hidden;
    padding: 160px 40px;
  }
  .cta__inner{
    max-width: 1080px; margin: 0 auto;
    text-align: center;
    position: relative; z-index: 2;
  }
  .cta__title{
    font-family: var(--serif); font-weight: 400; letter-spacing: -0.025em;
    font-size: clamp(48px, 8vw, 132px); line-height: 0.96;
  }
  .cta__title .accent{ color: var(--accent); font-style: italic; }
  .cta__title .stroke{ -webkit-text-stroke: 1px var(--ink); color: transparent; }
  .cta__sub{ color: var(--ink-dim); font-size: 18px; margin-top: 28px; max-width: 560px; margin-inline: auto; }
  .cta__cta{ margin-top: 40px; display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

  .cta__bg{ position: absolute; inset: 0; pointer-events: none; opacity: .65; }

  /* ============ FOOTER ============ */
  .footer{
    background: #060609;
    border-top: 1px solid var(--line);
    padding: 80px 40px 32px;
  }
  .footer__inner{ max-width: 1280px; margin: 0 auto; }
  .footer__top{
    display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px;
    padding-bottom: 60px; border-bottom: 1px solid var(--line);
  }
  .footer__brand .nav__brand{ font-size: 19px; }
  .footer__brand p{ margin-top: 18px; color: var(--ink-dim); font-size: 14px; max-width: 320px; line-height: 1.7; }
  .footer__col h5{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); font-weight: 500; margin-bottom: 18px; }
  .footer__col ul{ list-style: none; display: flex; flex-direction: column; gap: 10px; }
  .footer__col a{ color: var(--ink-dim); font-size: 14px; transition: color .25s ease; }
  .footer__col a:hover{ color: var(--ink); }
  .footer__bottom{
    display: flex; justify-content: space-between; align-items:center;
    margin-top: 32px;
    font-family: var(--mono); font-size: 11px; color: var(--ink-mute); letter-spacing: 0.12em; text-transform: uppercase;
  }

  /* reveal animation */
  .reveal{ opacity: 0; transform: translateY(24px); transition: opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1); }
  .reveal.in{ opacity: 1; transform: none; }

  /* mobile menu */
  .mobile-menu{
    position: fixed; top: 0; right: 0; bottom: 0; width: min(420px, 88vw);
    background: var(--bg-2);
    border-left: 1px solid var(--line);
    padding: 100px 32px 32px;
    transform: translateX(100%); transition: transform .4s cubic-bezier(.2,.7,.2,1);
    z-index: 49;
    display: flex; flex-direction: column;
  }
  .mobile-menu.is-open{ transform: translateX(0); }
  .mobile-menu a{ font-family: var(--serif); font-size: 28px; padding: 16px 0; border-bottom: 1px solid var(--line); }
  .mobile-menu a:last-of-type{ border-bottom: none; }
  .mobile-menu .btn{ margin-top: 24px; align-self: flex-start; }

  /* ============ MOBILE ============ */
  @media (max-width: 900px){
    .nav{ padding: 14px 20px; }
    .nav__links{ display: none; }
    .nav__cta{ display: none; }
    .nav__burger{ display: flex; }

    .hero{ padding: 120px 20px 80px; }
    .hero__inner{ grid-template-columns: 1fr; gap: 40px; }
    .hero__visual{ aspect-ratio: 4/5; max-width: 480px; margin: 0 auto; }
    .hero__floating{ right: -8px; top: 16px; min-width: 180px; padding: 12px; }
    .hero__meta{ margin-top: 48px; gap: 28px; }
    .hero__meta-item .num{ font-size: 28px; }

    section{ padding: 80px 20px; }
    .section-head{ grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }

    .about__card{ grid-column: span 12; }

    .service{ grid-template-columns: 60px 1fr 36px; gap: 16px; padding: 24px 0; }
    .service__desc{ display: none; }
    .service:hover{ padding-left: 0; }

    .events__grid{ grid-template-columns: repeat(2, 1fr); }

    .dj{ padding: 80px 20px; }
    .dj__inner{ grid-template-columns: 1fr; gap: 48px; }
    .dj__visual{ aspect-ratio: 4/5; }

    .gear__grid{ grid-template-columns: repeat(2, 1fr); }

    .gallery{ grid-template-columns: repeat(6, 1fr); grid-auto-rows: 80px; gap: 8px; }
    .gallery__item.s-h2{ grid-column: span 3; grid-row: span 3; }
    .gallery__item.s-h3{ grid-column: span 3; grid-row: span 4; }
    .gallery__item.s-w2,
    .gallery__item.s-w3,
    .gallery__item.s-sq{ grid-column: span 3; grid-row: span 3; }
    .gallery__item.s-wide{ grid-column: span 6; grid-row: span 3; }

    .cta{ padding: 100px 20px; }
    .footer{ padding: 60px 20px 24px; }
    .footer__top{ grid-template-columns: 1fr 1fr; gap: 36px; }
    .footer__bottom{ flex-direction: column; gap: 12px; align-items: flex-start; }
  }
