/* ======================================================
   BattleUp — clean, section-based (bashParty inspired)
   ====================================================== */

/* Brand */
:root{
    --navy:#131021;
    --blue:#1486C5;
    --green:#85BC26;
    --orange:#EBA926;
    --yellow:#ECC631;
  
    --bg1:#0B0A16;
    --bg2:#0A0814;
  
    --text: rgba(251,251,251,.92);
    --muted: rgba(251,251,251,.70);
    --hair: rgba(251,251,251,.12);
    --panel: rgba(251,251,251,.05);
    --panel2: rgba(251,251,251,.07);
  
    --radius: 22px;
    --radius2: 16px;
  
    --grad: linear-gradient(90deg, var(--blue), var(--green), var(--orange));
    --shadow: 0 28px 70px rgba(0,0,0,.42);
    --shadow2: 0 16px 40px rgba(0,0,0,.28);
  }
  
  /* Reset */
  *{ box-sizing:border-box; }
  html,body{ height:100%; }
body{
    margin:0;
    font-family:"Sora",-apple-system,BlinkMacSystemFont,
                "SF Pro Display","SF Pro Text",
                "Segoe UI",Roboto,Helvetica,Arial;
    color:var(--text);
    letter-spacing:-0.018em;
  
    /* clean, but with subtle brand glow */
    background:
      radial-gradient(1000px 600px at 14% 8%, rgba(20,134,197,.16), transparent 60%),
      radial-gradient(900px 600px at 78% 18%, rgba(133,188,38,.12), transparent 60%),
      radial-gradient(900px 600px at 72% 88%, rgba(235,169,38,.10), transparent 60%),
      linear-gradient(180deg, var(--bg1) 0%, var(--navy) 60%, var(--bg2) 100%);
    overflow-x:hidden;
  }
  
  img{ max-width:100%; height:auto; display:block; }
  a{ color:inherit; text-decoration:none; }
  button,input,select,textarea{ font-family:inherit; }
  
  /* Layout */
  .container{
    width: min(1140px, calc(100% - 48px));
    margin: 0 auto;
  }
  
  /* Type — clean, left-led */
  h1,h2,h3{
    margin:0;
    font-weight:700;
    letter-spacing:-0.05em;
  }
  h1{
    font-size: clamp(34px, 4.6vw, 60px);
    line-height: 1;
    max-width: 14ch;
  }
  h2{
    font-size: clamp(22px, 2.6vw, 34px);
    line-height: 1.08;
  }
  h3{
    font-size: 16px;
    letter-spacing:-0.03em;
  }
  p{
    margin:0;
    color:var(--muted);
    font-weight:500;
    line-height:1.7;
    max-width: 60ch;
  }
  .grad{
    background: var(--grad);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
  }

  .hero-title{
    max-width: 18ch;
    text-align: center;
    margin-top: 18px;
  }

  .hero-title-brand,
  .hero-title-sub{
    display:block;
  }

  .hero-title-brand{
    margin-bottom: 14px;
    font-size: clamp(52px, 7vw, 86px);
    line-height: .94;
    letter-spacing: -0.065em;
  }

  .hero-title-sub{
    color: var(--text);
    font-size: clamp(28px, 3.6vw, 48px);
    line-height: 1.04;
    letter-spacing: -0.05em;
  }
  
  /* Nav — simple like bashParty (CTA right) */
  .nav{
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    background: rgba(19,16,33,.55);
    border-bottom: 1px solid rgba(251,251,251,.08);
  }
  .nav-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 16px;
    padding: 14px 0;
  }
  .brand{
    display:flex;
    align-items:center;
    gap: 12px;
    min-width: 240px;
  }
  .brand img{
    width: 36px;
    height: 36px;
    object-fit: contain;
    border-radius: 12px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
  }
  .brand strong{
    display:block;
    font-size:14px;
    letter-spacing:-0.04em;
    line-height:1.05;
    font-weight:700;
  }
  .brand span{
    display:block;
    margin-top:2px;
    font-size:12px;
    color: rgba(251,251,251,.55);
    font-weight:700;
  }
  
  .nav-links{
    display:flex;
    gap: 14px;
    flex:1;
    justify-content:center;
  }
  .nav-links a{
    font-size:13px;
    font-weight:800;
    color: rgba(251,251,251,.72);
    padding: 8px 10px;
    border-radius: 999px;
    white-space: nowrap;
    transition: .16s ease;
  }
  .nav-links a:hover{
    background: rgba(255,255,255,.06);
    color: var(--text);
  }

  .mobile-menu{
    display:none;
    position: relative;
  }

  .mobile-menu summary{
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap: 5px;
    width: 46px;
    height: 46px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 16px;
    background: rgba(255,255,255,.08);
    cursor:pointer;
    list-style:none;
    padding: 0 12px;
  }

  .mobile-menu summary::-webkit-details-marker{
    display:none;
  }

  .mobile-menu summary span{
    display:block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: var(--text);
    transition: .16s ease;
  }

  .mobile-menu[open] summary span:nth-child(1){
    transform: translateY(7px) rotate(45deg);
  }

  .mobile-menu[open] summary span:nth-child(2){
    opacity:0;
  }

  .mobile-menu[open] summary span:nth-child(3){
    transform: translateY(-7px) rotate(-45deg);
  }

  .mobile-menu nav{
    position:absolute;
    top: calc(100% + 12px);
    right: 0;
    width: min(290px, calc(100vw - 48px));
    display:grid;
    gap: 8px;
    padding: 14px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.14);
    background:
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(19,16,33,.96);
    box-shadow: var(--shadow2);
  }

  .mobile-menu nav a{
    padding: 12px 14px;
    border-radius: 16px;
    color: rgba(251,251,251,.82);
    font-size: 13px;
    font-weight: 800;
    white-space: nowrap;
    background: rgba(255,255,255,.04);
  }

  .mobile-menu nav a:hover{
    color: var(--text);
    background: rgba(255,255,255,.08);
  }

  .nav-cta{
    display:flex;
    gap: 10px;
    justify-content:flex-end;
    min-width: 240px;
  }
  
  /* Buttons — very clean, one primary */
  .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding: 11px 16px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 900;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: var(--text);
    transition: .16s ease;
    white-space: nowrap;
  }
  .btn:hover{
    transform: translateY(-1px);
    background: rgba(255,255,255,.09);
  }
  .btn.primary{
    border: none;
    background: var(--grad);
    color: rgba(19,16,33,.95);
    box-shadow: 0 18px 45px rgba(20,134,197,.16), 0 18px 45px rgba(133,188,38,.10);
  }
  
  /* Sections — bashParty-like: clear blocks, lots of spacing */
  header.hero{
    padding: 56px 0 70px;
  }
  .hero-grid{
    display:grid;
    grid-template-columns: 1.2fr .8fr; /* left-led */
    gap: 72px;
    align-items: start;
  }

  .hero-grid.hero-grid-single{
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .hero-grid > div:first-child{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
  }

  .hero-grid.hero-grid-single > div:first-child{
    width: min(100%, 1040px);
  }
  
  .kicker{
    display:inline-flex;
    align-items:center;
    gap: 10px;
    max-width: min(100%, 880px);
    padding: 12px 18px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.05);
    color: rgba(255,255,255,.72);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.35;
  }
  .kdot{
    width: 9px;
    height: 9px;
    border-radius: 99px;
    background: var(--blue);
    box-shadow: 0 0 0 6px rgba(20,134,197,.14);
  }
  
  .lead{
    margin-top: 14px;
    max-width: 58ch;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
  }

  .offsite-lead-accent{
    margin-top: 8px;
    background: linear-gradient(90deg, var(--blue), var(--green), var(--orange));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-weight: 700;
  }

  .hero-note{
    margin-top: 14px;
    color: rgba(251,251,251,.72);
    font-size: 14px;
    max-width: 50ch;
  }
  
  .hero-actions{
    display:flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 20px;
    justify-content:center;
  }
  
  .meta{
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 16px;
    justify-content:center;
    color: rgba(255,255,255,.58);
    font-size: 12px;
    font-weight: 700;
  }
  .meta span{
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
  }

  .trust-strip{
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 118px;
    width: 100%;
  }
  .trust-item{
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
    padding: 16px;
  }
  .trust-item strong{
    display:block;
    font-size: 15px;
    font-weight: 900;
    color: var(--text);
  }
  .trust-item span{
    display:block;
    margin-top: 6px;
    color: rgba(251,251,251,.62);
    font-size: 13px;
    line-height: 1.5;
    font-weight: 700;
  }

  .inquiry-card{
    border-radius: var(--radius);
    border: 1px solid rgba(255,255,255,.10);
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.18), transparent 45%),
      radial-gradient(circle at bottom right, rgba(235,169,38,.12), transparent 42%),
      rgba(255,255,255,.06);
    box-shadow: var(--shadow);
    padding: 24px;
  }

  .anfrage-section{
    padding: 0 0 72px;
  }

  .inquiry-card-page{
    width: min(100%, 880px);
    margin: 0 auto;
  }

  .anfrage-info-grid{
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    width: min(100%, 880px);
    margin: 22px auto 0;
  }

  .anfrage-info-card{
    padding: 22px;
  }

  .anfrage-info-card h3{
    margin-bottom: 12px;
  }

  .anfrage-info-card p + p{
    margin-top: 6px;
  }

  .anfrage-info-card a{
    color: var(--text);
    text-decoration: underline;
    text-decoration-color: rgba(251,251,251,.35);
    text-underline-offset: 3px;
  }

  .success-card{
    max-width: 860px;
    margin: 0 auto;
    text-align: center;
  }

  .success-card .lead,
  .success-card .legal-box p{
    margin-left:auto;
    margin-right:auto;
    text-align:center;
  }

  .success-card .hero-actions{
    margin-top: 28px;
  }

  .card-badge{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.08);
    color: rgba(251,251,251,.78);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .06em;
  }

  .inquiry-card h2{
    margin-top: 16px;
    font-size: clamp(26px, 2.8vw, 36px);
  }

  .inquiry-copy{
    margin-top: 10px;
    max-width: 48ch;
  }

  .contact-form{
    margin-top: 20px;
  }

  .form-grid{
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .form-actions{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 12px;
    margin-top: 16px;
    flex-wrap: wrap;
  }

  .form-note{
    font-size: 12px;
    color: rgba(251,251,251,.56);
    font-weight: 700;
  }

  .inquiry-meta{
    display:flex;
    flex-wrap:wrap;
    gap: 10px;
    margin-top: 18px;
  }

  .inquiry-meta span{
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
    color: rgba(251,251,251,.68);
    font-size: 12px;
    font-weight: 800;
  }

  .visual-band{
    padding: 0 0 32px;
  }

  .social-band{
    padding: 0 0 32px;
  }

  .story-band{
    padding: 8px 0 56px;
  }

  .story-head{
    margin-bottom: 24px;
  }

  .story-grid{
    display:grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 22px;
  }

  .story-card{
    position:relative;
    min-height: 280px;
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.10);
    overflow:hidden;
    box-shadow: var(--shadow2);
    background:
      linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
      rgba(255,255,255,.04);
  }

  .story-card img{
    width:100%;
    height:100%;
    min-height: 100%;
    object-fit: cover;
    filter: saturate(.92) contrast(.96) brightness(.90);
  }

  .story-card::after{
    content:"";
    position:absolute;
    inset:0;
    background: linear-gradient(180deg, rgba(19,16,33,.10), rgba(19,16,33,.78));
    pointer-events:none;
  }

  .story-card-copy{
    position:absolute;
    inset:auto 20px 20px 20px;
    z-index: 1;
  }

  .story-card-copy h3{
    margin-top: 12px;
    font-size: 22px;
  }

  .story-card-copy p{
    margin-top: 10px;
    max-width: 40ch;
    color: rgba(251,251,251,.76);
  }

  .story-card-photo{
    grid-row: span 2;
    min-height: 582px;
  }

  .story-card-ambient{
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.24), transparent 34%),
      radial-gradient(circle at 72% 24%, rgba(255,255,255,.10), transparent 22%),
      linear-gradient(160deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),
      linear-gradient(180deg, rgba(19,16,33,.92), rgba(8,10,22,.96));
  }

  .story-card-ambient::before{
    content:"";
    position:absolute;
    inset:18px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.10);
    background:
      linear-gradient(135deg, rgba(255,255,255,.06), transparent 36%),
      repeating-linear-gradient(
        90deg,
        rgba(255,255,255,.04) 0,
        rgba(255,255,255,.04) 24px,
        transparent 24px,
        transparent 48px
      );
    opacity:.55;
  }

  .story-card-trophy{
    background:
      radial-gradient(circle at 18% 22%, rgba(235,169,38,.34), transparent 28%),
      radial-gradient(circle at 80% 80%, rgba(20,134,197,.18), transparent 36%),
      linear-gradient(180deg, rgba(31,27,17,.92), rgba(12,12,20,.96));
  }

  .story-card-trophy::before{
    content:"";
    position:absolute;
    width: 120px;
    height: 120px;
    right: 26px;
    top: 24px;
    border-radius: 28px 28px 46px 46px;
    background:
      radial-gradient(circle at 50% 28%, rgba(255,255,255,.30), transparent 30%),
      linear-gradient(180deg, rgba(255,214,110,.98), rgba(197,131,16,.92));
    box-shadow: 0 16px 30px rgba(0,0,0,.24);
    transform: rotate(8deg);
  }

  .story-card-trophy::after{
    background: linear-gradient(180deg, rgba(19,16,33,.08), rgba(19,16,33,.70));
  }

  .story-card-score{
    background:
      radial-gradient(circle at top left, rgba(133,188,38,.20), transparent 30%),
      radial-gradient(circle at bottom right, rgba(20,134,197,.20), transparent 34%),
      linear-gradient(180deg, rgba(13,16,27,.94), rgba(7,8,18,.98));
  }

  .story-card-score::before{
    content:"";
    position:absolute;
    inset:22px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.10);
    background:
      linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
      linear-gradient(90deg, transparent 0 48%, rgba(255,255,255,.08) 48% 52%, transparent 52%),
      linear-gradient(180deg, transparent 0 28%, rgba(255,255,255,.06) 28% 30%, transparent 30% 58%, rgba(255,255,255,.06) 58% 60%, transparent 60%);
    opacity:.6;
  }

  .instagram-banner{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    gap: 24px;
    border-radius: calc(var(--radius) + 4px);
    border: 1px solid rgba(255,255,255,.12);
    background:
      radial-gradient(circle at top left, rgba(235,169,38,.18), transparent 34%),
      radial-gradient(circle at bottom right, rgba(20,134,197,.18), transparent 38%),
      linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(255,255,255,.05);
    padding: 28px;
    box-shadow: var(--shadow2);
    transition: .18s ease;
  }

  .instagram-banner:hover{
    transform: translateY(-2px);
    border-color: rgba(255,255,255,.18);
    background:
      radial-gradient(circle at top left, rgba(235,169,38,.22), transparent 34%),
      radial-gradient(circle at bottom right, rgba(20,134,197,.22), transparent 38%),
      linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.05)),
      rgba(255,255,255,.06);
  }

  .instagram-banner h2{
    margin-top: 14px;
    max-width: 16ch;
    margin-left:auto;
    margin-right:auto;
  }

  .instagram-banner p{
    margin-top: 10px;
    max-width: 50ch;
    margin-left:auto;
    margin-right:auto;
  }

  .instagram-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding: 12px 16px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.08);
    color: var(--text);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    white-space: nowrap;
  }

  .early-band{
    padding-top: 18px;
    padding-bottom: 16px;
  }

  .early-marquee{
    position: relative;
    overflow: hidden;
    border-radius: calc(var(--radius) + 4px);
    border: 1px solid rgba(255,255,255,.12);
    background:
      radial-gradient(circle at top left, rgba(133,188,38,.18), transparent 34%),
      radial-gradient(circle at bottom right, rgba(20,134,197,.16), transparent 38%),
      linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(255,255,255,.05);
    box-shadow: var(--shadow2);
  }

  .early-track{
    display:flex;
    width:max-content;
    gap: 18px;
    padding: 16px 0;
    animation: early-scroll 26s linear infinite;
  }

  .early-marquee:hover .early-track{
    animation-play-state: paused;
  }

  .early-track a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding: 0 22px;
    color: var(--text);
    font-size: 15px;
    font-weight: 900;
    letter-spacing: -0.02em;
    white-space: nowrap;
  }

  @keyframes early-scroll{
    from{ transform: translateX(0); }
    to{ transform: translateX(calc(-33.333% - 12px)); }
  }

  .visual-stage{
    position: relative;
    min-height: 420px;
    border-radius: calc(var(--radius) + 4px);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: var(--shadow);
  }

  .visual-stage img{
    width:100%;
    height:100%;
    min-height: 420px;
    object-fit: cover;
    filter: saturate(.95) contrast(.95) brightness(.92);
    transform: scale(1.01);
  }

  .visual-stage::after{
    content:"";
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at 18% 18%, rgba(20,134,197,.18), transparent 50%),
      radial-gradient(circle at 78% 30%, rgba(133,188,38,.12), transparent 56%),
      linear-gradient(180deg, rgba(19,16,33,.10), rgba(19,16,33,.72));
  }

  .visual-overlay{
    position:absolute;
    inset:auto 24px 24px 24px;
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap: 24px;
    z-index: 1;
  }

  .visual-overlay h2{
    margin-top: 14px;
    max-width: 13ch;
  }

  .visual-overlay p{
    max-width: 42ch;
    color: rgba(251,251,251,.80);
  }

  .contact-grid{
    grid-template-columns: repeat(3, 1fr);
  }

  .faq-grid{
    display:grid;
    grid-template-columns: 1fr;
    gap: 14px;
    max-width: 920px;
    margin: 0 auto;
  }

  .references-band{
    padding-top: 8px;
  }

  .reference-marquee{
    position: relative;
    overflow: hidden;
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.10);
    background:
      linear-gradient(90deg, rgba(20,134,197,.10), rgba(133,188,38,.08), rgba(235,169,38,.10)),
      rgba(255,255,255,.04);
    box-shadow: var(--shadow2);
    padding: 18px 0;
  }

  .reference-marquee::before,
  .reference-marquee::after{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    width: 100px;
    z-index:2;
    pointer-events:none;
  }

  .reference-marquee::before{
    left:0;
    background: linear-gradient(90deg, rgba(11,10,22,.96), transparent);
  }

  .reference-marquee::after{
    right:0;
    background: linear-gradient(270deg, rgba(11,10,22,.96), transparent);
  }

  .reference-track{
    display:flex;
    width:max-content;
    gap: 16px;
    animation: reference-scroll 24s linear infinite;
  }

  .reference-marquee:hover .reference-track{
    animation-play-state: paused;
  }

  .reference-track span{
    min-width: 180px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding: 16px 22px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.08);
    color: var(--text);
    font-size: 18px;
    font-weight: 900;
    letter-spacing: -0.035em;
  }

  @keyframes reference-scroll{
    from{ transform: translateX(0); }
    to{ transform: translateX(calc(-50% - 8px)); }
  }

  .mini-grid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }

  .mini-card{
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.10);
    background:
      linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
      rgba(255,255,255,.04);
    padding: 24px;
    box-shadow: var(--shadow2);
  }

  .mini-icon{
    width: 44px;
    height: 44px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius: 14px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.10);
    font-size: 22px;
  }

  .mini-card h3{
    margin-top: 16px;
    font-size: 20px;
  }

  .mini-card p{
    margin-top: 10px;
    max-width: unset;
    color: rgba(251,251,251,.74);
  }

  .faq-card{
    position: relative;
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.10);
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.10), transparent 34%),
      linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
      rgba(255,255,255,.04);
    padding: 0;
    box-shadow: var(--shadow2);
    overflow:hidden;
    transition: border-color .18s ease, background .18s ease, transform .18s ease;
  }

  .faq-card:hover{
    border-color: rgba(255,255,255,.16);
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.14), transparent 36%),
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(255,255,255,.05);
  }

  .faq-card summary{
    position: relative;
    list-style:none;
    cursor:pointer;
    padding: 22px 72px 22px 24px;
    font-size: 18px;
    line-height: 1.34;
    font-weight: 800;
    color: var(--text);
    transition: color .16s ease;
  }

  .faq-card summary::-webkit-details-marker{
    display:none;
  }

  .faq-card summary::after{
    content:"+";
    position:absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
    width: 34px;
    height: 34px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
    color: var(--text);
    font-size: 19px;
    font-weight: 500;
    transition: transform .18s ease, background .18s ease, border-color .18s ease;
  }

  .faq-card[open] summary::after{
    content:"−";
    transform: translateY(-50%) rotate(180deg);
    border-color: rgba(255,255,255,.16);
    background: linear-gradient(180deg, rgba(20,134,197,.18), rgba(255,255,255,.06));
  }

  .faq-card[open]{
    border-color: rgba(255,255,255,.15);
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.18), transparent 38%),
      radial-gradient(circle at bottom right, rgba(133,188,38,.10), transparent 42%),
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(255,255,255,.05);
  }

  .faq-card[open] summary{
    padding-bottom: 16px;
  }

  .faq-card[open] summary::before{
    content:"";
    position:absolute;
    left: 24px;
    right: 24px;
    bottom: 0;
    height: 1px;
    background: rgba(255,255,255,.10);
  }

  .faq-card p{
    margin: 0;
    padding: 18px 24px 22px;
    max-width: unset;
    color: rgba(251,251,251,.76);
    line-height: 1.72;
  }

  .format-visuals{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
    margin-top: 28px;
  }

  .format-panel{
    position:relative;
    overflow:hidden;
    min-height: 220px;
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.10);
    padding: 24px;
    box-shadow: var(--shadow2);
  }

  .format-panel h3{
    margin-top: 14px;
    font-size: 24px;
  }

  .format-panel p{
    margin-top: 10px;
    max-width: 38ch;
    color: rgba(251,251,251,.76);
  }

  .format-panel-blue{
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.30), transparent 36%),
      radial-gradient(circle at 82% 26%, rgba(255,255,255,.08), transparent 20%),
      linear-gradient(160deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
      linear-gradient(180deg, rgba(9,14,33,.96), rgba(8,11,22,.98));
  }

  .format-panel-gold{
    background:
      radial-gradient(circle at top left, rgba(235,169,38,.28), transparent 34%),
      radial-gradient(circle at bottom right, rgba(133,188,38,.14), transparent 34%),
      linear-gradient(160deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
      linear-gradient(180deg, rgba(26,18,10,.94), rgba(10,10,18,.98));
  }

  .process-strip{
    display:flex;
    flex-wrap:wrap;
    gap: 12px;
    margin-top: 26px;
  }

  .process-pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding: 12px 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
    color: rgba(251,251,251,.74);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .02em;
  }

  .pricing-hero{
    padding: 76px 0 28px;
  }

  .pricing-head{
    max-width: 760px;
    position: relative;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .pricing-head::after{
    content:"";
    position:absolute;
    width: 220px;
    height: 220px;
    left: 50%;
    top: -28px;
    transform: translateX(-50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(235,169,38,.24), rgba(235,169,38,0));
    filter: blur(10px);
    pointer-events:none;
  }

  .pricing-head .lead{
    max-width: 62ch;
    margin-left: auto;
    margin-right: auto;
  }

  .pricing-hero-meta{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap: 10px;
    margin-top: 22px;
  }

  .pricing-hero-meta span{
    padding: 10px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.12);
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
    color: rgba(251,251,251,.74);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .03em;
  }

  .pricing-section{
    padding-top: 12px;
  }

  .pricing-intro{
    margin-bottom: 28px;
    justify-content:center;
    text-align:center;
  }

  .pricing-grid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: stretch;
  }

  .price-card{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.12);
    background:
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      radial-gradient(circle at top left, rgba(20,134,197,.16), transparent 40%),
      radial-gradient(circle at bottom right, rgba(255,255,255,.05), transparent 34%),
      rgba(255,255,255,.05);
    padding: 26px;
    box-shadow: var(--shadow2);
    min-height: 100%;
    position: relative;
    overflow:hidden;
  }

  .price-card::before{
    content:"";
    position:absolute;
    inset:0;
    background: linear-gradient(135deg, rgba(255,255,255,.10), transparent 26%, transparent 78%, rgba(255,255,255,.05));
    opacity:.55;
    pointer-events:none;
  }

  .price-card.featured{
    background:
      linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.05)),
      radial-gradient(circle at top left, rgba(20,134,197,.22), transparent 42%),
      radial-gradient(circle at bottom right, rgba(235,169,38,.20), transparent 45%),
      rgba(255,255,255,.09);
    border-color: rgba(255,255,255,.26);
    transform: translateY(-10px);
    box-shadow: 0 32px 90px rgba(0,0,0,.38);
  }

  .price-card.featured::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(135deg, rgba(255,255,255,.44), rgba(235,169,38,.36), rgba(20,134,197,.24));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events:none;
  }

  .price-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap: 12px;
    margin-bottom: 18px;
  }

  .price-chip{
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    color: rgba(251,251,251,.70);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
  }

  .price-card h2,
  .price-card p,
  .price-card ul,
  .price-card a,
  .price-card .price-main,
  .price-card .price-sub,
  .price-card .price-chip,
  .price-card .card-badge{
    position: relative;
    z-index: 1;
  }

  .price-copy{
    min-height: 72px;
    color: rgba(251,251,251,.76);
  }

  .price-option{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.08);
    color: var(--text);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .01em;
  }

  .price-main{
    margin-top: 22px;
    font-size: clamp(30px, 3.2vw, 44px);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.05em;
    color: var(--text);
  }

  .price-main span{
    display:block;
    margin-top: 8px;
    font-size: 14px;
    letter-spacing: 0;
    color: rgba(251,251,251,.58);
  }

  .price-tax-note{
    margin-top: 10px;
    color: rgba(251,251,251,.54);
    font-size: 11px;
    line-height: 1.45;
    max-width: 32ch;
  }

  .price-sub{
    margin-top: 10px;
    color: rgba(251,251,251,.82);
    font-weight: 800;
  }

  .price-divider{
    width: 100%;
    height: 1px;
    margin: 18px 0 4px;
    background: linear-gradient(90deg, rgba(255,255,255,.20), rgba(255,255,255,.04));
  }

  .price-list{
    margin: 20px 0 24px;
    padding-left: 0;
    list-style: none;
    color: rgba(251,251,251,.76);
    line-height: 1.7;
    font-weight: 700;
    flex: 1;
  }

  .price-footnote{
    margin-bottom: 22px;
    color: rgba(251,251,251,.62);
    font-size: 13px;
    line-height: 1.6;
    min-height: 62px;
  }

  .pricing-facts{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-top: 26px;
  }

  .pricing-asterisk{
    margin: 34px 4px 0;
    color: rgba(251,251,251,.72);
    font-size: 13px;
    line-height: 1.6;
  }

  .pricing-highlight{
    grid-column: 1 / -1;
    display:flex;
    flex-direction:column;
    gap: 14px;
    padding: 24px;
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.14), transparent 34%),
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05)),
      rgba(255,255,255,.05);
  }

  .pricing-highlight p{
    max-width: 62ch;
    color: rgba(251,251,251,.78);
  }

  .jobs-section{
    padding-top: 12px;
  }

  .jobs-head{
    text-align:center;
    margin: 0 auto;
  }

  .jobs-head .lead{
    margin-left:auto;
    margin-right:auto;
    text-align:center;
  }

  .jobs-grid{
    display:grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 24px;
  }

  .job-card{
    border-radius: calc(var(--radius) + 2px);
    border: 1px solid rgba(255,255,255,.12);
    background:
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(255,255,255,.04);
    box-shadow: var(--shadow2);
    padding: 28px;
  }

  .job-card.featured{
    background:
      radial-gradient(circle at top left, rgba(20,134,197,.18), transparent 40%),
      radial-gradient(circle at bottom right, rgba(133,188,38,.12), transparent 42%),
      linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04)),
      rgba(255,255,255,.05);
  }

  .job-card h2{
    margin-top: 16px;
    max-width: 14ch;
  }

  .job-card p{
    margin-top: 12px;
    max-width: 52ch;
  }

  .job-actions{
    margin-top: 20px;
  }

  .offsite-page .job-card,
  .offsite-page .jobs-head{
    text-align:center;
  }

  .offsite-page .job-card{
    max-width: 920px;
    margin: 0 auto;
  }

  .offsite-page .job-card h2,
  .offsite-page .job-card p{
    margin-left:auto;
    margin-right:auto;
    text-align:center;
  }

  .offsite-page .job-actions{
    display:flex;
    flex-direction:column;
    align-items:center;
  }

  .legal-page{
    padding: 64px 0 80px;
  }

  .legal-card{
    border-radius: calc(var(--radius) + 4px);
    border: 1px solid rgba(255,255,255,.12);
    background:
      linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)),
      rgba(255,255,255,.04);
    box-shadow: var(--shadow2);
    padding: 32px;
  }

  .legal-card > h1{
    text-align:center;
    margin-left:auto;
    margin-right:auto;
  }

  .legal-card .lead{
    margin-top: 10px;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
  }

  .legal-card > .card-badge{
    display:flex;
    width: fit-content;
    margin: 0 auto;
  }

  .legal-box{
    margin-top: 24px;
    border-radius: var(--radius);
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
    padding: 24px;
  }

  .legal-box h2 + p,
  .legal-box h3 + p{
    margin-top: 8px;
  }

  .legal-box h2{
    margin-top: 22px;
  }

  .legal-box h2:first-child{
    margin-top: 0;
  }

  .legal-box h3{
    margin-top: 18px;
    font-size: 16px;
    font-weight: 800;
    font-family: inherit;
    letter-spacing: -0.02em;
  }

  .legal-footer{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap: 16px;
    flex-wrap:wrap;
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.10);
    color: rgba(251,251,251,.55);
    font-size: 13px;
    font-weight: 700;
  }
  
  /* Generic section */
  section{
    padding: 72px 0;
  }
  .sec-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    gap: 18px;
    margin-bottom: 22px;
    text-align:left;
  }
  .sec-head p{
    max-width: 48ch;
  }
  
  /* Cards/Grid — clean, minimal borders */
  .grid-3{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .card{
    border-radius: var(--radius);
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.05);
    padding: 20px;
  }
  .card p{
    font-size: 13px;
    max-width: unset;
  }
  
  /* Forms (if you have them) */
  label{
    display:block;
    margin: 12px 0 6px;
    font-size: 12px;
    font-weight: 800;
    color: rgba(255,255,255,.60);
  }
  input,select,textarea{
    width:100%;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(0,0,0,.14);
    color: var(--text);
    padding: 12px 12px;
    font-size: 14px;
    outline: none;
  }
  textarea{ min-height: 120px; resize: vertical; }
  input:focus,select:focus,textarea:focus{
    border-color: rgba(20,134,197,.55);
    box-shadow: 0 0 0 6px rgba(20,134,197,.12);
  }
  .hp-field{
    position:absolute;
    left:-9999px;
    width:1px;
    height:1px;
    opacity:0;
    pointer-events:none;
  }
  .checkbox-row{
    display:flex;
    align-items:flex-start;
    gap: 12px;
    margin-top: 14px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.04);
    cursor:pointer;
  }
  .checkbox-row input{
    width:18px;
    height:18px;
    margin: 1px 0 0;
    accent-color: var(--green);
    flex: 0 0 18px;
  }
  .checkbox-row span{
    color: rgba(251,251,251,.72);
    font-size: 13px;
    line-height: 1.55;
    font-weight: 700;
  }
  .checkbox-row a{
    color: var(--text);
    text-decoration: underline;
    text-decoration-color: rgba(251,251,251,.35);
    text-underline-offset: 3px;
  }
  .btn:disabled{
    opacity:.7;
    cursor:wait;
    transform:none;
  }
  .form-status{
    min-height: 22px;
    margin-top: 12px;
    font-size: 13px;
    font-weight: 800;
  }
  .form-status.is-pending{
    color: rgba(251,251,251,.72);
  }
  .form-status.is-success{
    color: #b7f07b;
  }
  .form-status.is-error{
    color: #ffb0a3;
  }
  
  /* Footer */
  footer{
    padding: 48px 0;
    border-top: 1px solid rgba(255,255,255,.10);
    color: rgba(255,255,255,.55);
    font-size: 12px;
    font-weight: 700;
  }
  .footer-row{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap: 16px;
    flex-wrap:wrap;
  }

  /* Responsive */
  @media (max-width: 980px){
    .nav-links{ display:none; }
    .mobile-menu{ display:block; }
    .nav-cta{ min-width: auto; }
    .hero-grid{
      grid-template-columns: 1fr;
      gap: 34px;
    }
    h1{ max-width: unset; }
    .grid-3{ grid-template-columns: 1fr; }
    .pricing-grid{
      grid-template-columns: 1fr;
      display:flex;
      flex-direction:column;
    }
    .pricing-grid .price-card.featured{ order: -1; }
    .jobs-grid{ grid-template-columns: 1fr; }
    .pricing-facts{ grid-template-columns: 1fr; }
    .anfrage-info-grid{ grid-template-columns: 1fr; }
    .price-card.featured{ transform: none; }
    .legal-card,
    .legal-box{ padding: 22px; }
    .format-visuals{ grid-template-columns: 1fr; }
    .mini-grid{ grid-template-columns: 1fr; }
    .faq-grid{ grid-template-columns: 1fr; }
    .faq-card summary{
      padding: 18px 58px 18px 18px;
      font-size: 17px;
    }
    .faq-card summary::after{
      right: 16px;
      width: 30px;
      height: 30px;
      font-size: 17px;
    }
    .faq-card[open] summary::before{
      left: 18px;
      right: 18px;
    }
    .faq-card p{
      padding: 0 18px 18px;
    }
    .story-grid{ grid-template-columns: 1fr; }
    .story-card-photo{ min-height: 360px; grid-row: auto; }
    .trust-strip{ grid-template-columns: 1fr; }
    .form-grid{ grid-template-columns: 1fr; }
    .instagram-banner{
      flex-direction:column;
      align-items:flex-start;
    }
    .visual-overlay{
      position:absolute;
      inset:auto 18px 18px 18px;
      flex-direction:column;
      align-items:flex-start;
    }
    .visual-stage,
    .visual-stage img{
      min-height: 320px;
    }
  }

  @media (max-width: 720px){
    .container{
      width: min(100% - 32px, 1140px);
    }
    header.hero{
      padding: 34px 0 54px;
    }
    .hero-grid > div:first-child,
    .pricing-head,
    .sec-head{
      text-align:center;
      display:flex;
      flex-direction:column;
      align-items:center;
    }
    h1{
      font-size: clamp(31px, 10.5vw, 44px);
      line-height: 1.06;
      letter-spacing: -0.058em;
      margin-left:auto;
      margin-right:auto;
    }
    .kicker{
      max-width: 100%;
      align-items:flex-start;
      gap: 9px;
      padding: 9px 12px;
      border-radius: 18px;
      font-size: 12px;
      line-height: 1.35;
      justify-content:center;
      text-align:left;
    }
    .kdot{
      flex: 0 0 auto;
      margin-top: 4px;
    }
    .lead{
      margin-top: 18px;
      font-size: 16px;
      line-height: 1.6;
      max-width: 34ch;
      margin-left:auto;
      margin-right:auto;
      text-align:center;
    }
    .hero-actions{
      margin-top: 22px;
      justify-content:center;
    }
    .meta{
      gap: 8px;
      margin-top: 18px;
      justify-content:center;
    }
    .meta span{
      border-radius: 14px;
      line-height: 1.35;
    }
    .reference-marquee{
      padding: 14px 0;
    }
    .early-track{
      padding: 14px 0;
      gap: 12px;
    }
    .early-track a{
      padding: 0 16px;
      font-size: 13px;
    }
    .reference-marquee::before,
    .reference-marquee::after{
      width: 48px;
    }
    .reference-track span{
      min-width: 140px;
      padding: 14px 18px;
      font-size: 16px;
    }
    .nav-inner{
      flex-wrap: wrap;
      align-items: center;
      justify-content:center;
      gap: 14px;
    }
    .brand{
      min-width: 0;
      flex: 0 0 100%;
      flex-direction:column;
      justify-content:center;
      text-align:center;
      gap: 10px;
      order: 1;
    }
    .brand img{
      width: 84px;
      height: 84px;
      border-radius: 22px;
    }
    .brand strong{
      font-size: 0;
    }
    .brand strong::after{
      content: "BattleUp Team Events";
      font-size: 22px;
      line-height: 1.05;
    }
    .brand span{
      display:none;
    }
    .mobile-menu{ order: 2; }
    .nav-cta{
      order: 3;
      width: 100%;
      justify-content:center;
    }
    .nav-cta .btn:not(.primary){
      display:none;
    }
  }
  
