/* ============================================================
   CROSSY - The Breakthrough Tour 2026
   Concept: spray-painted fly-posters on a blurred-poster backdrop.
   Neon lime + graffiti purple, tape, layered premium shadows.
   ============================================================ */

:root{
  --ink:#0c0a0e;
  --char:#16121c;
  --char-2:#1f1928;
  --lime:#c8ff2e;
  --lime-deep:#a6e000;
  --lime-glow:rgba(200,255,46,.45);
  --purple:#7a2bff;
  --purple-lt:#9a5cff;
  --paper:#efe9da;
  --bone:#f5f3ec;
  --ash:#aaa2b6;
  --line:rgba(200,255,46,.30);
  --display:"Anton","Impact","Arial Narrow",sans-serif;
  --sans:"Barlow Condensed","Oswald",system-ui,sans-serif;
  --marker:var(--sans);
  --serif:var(--display);
  /* premium depth shadows */
  --lift:0 24px 50px -12px rgba(0,0,0,.7), 0 8px 18px -8px rgba(0,0,0,.6);
  --lift-lg:0 40px 80px -20px rgba(0,0,0,.78), 0 12px 28px -10px rgba(0,0,0,.6);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--bone);background:var(--ink);
  font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.5;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
  min-height:100vh;display:flex;flex-direction:column;
}
.stage{flex:1 0 auto}
a{color:inherit}
img{max-width:100%;display:block}

/* Brick-wall backdrop (mobile portrait; desktop landscape) */
body::before{
  content:"";position:fixed;inset:0;z-index:0;
  background:#0c0a0e url("/assets/images/wall.webp") center center/cover no-repeat;
}
@media (min-width:920px){
  body::before{background-image:url("/assets/images/wall-desktop.webp")}
}
/* Scrim for text contrast (keep the wall visible) */
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(10,8,12,.42), rgba(10,8,12,.20) 34%, rgba(10,8,12,.60) 100%),
    radial-gradient(130% 90% at 30% 32%, transparent 42%, rgba(10,8,12,.55) 100%);
}
@media (min-width:920px){
  .grain{background:
    linear-gradient(90deg, rgba(10,8,12,.62) 0%, rgba(10,8,12,.30) 46%, rgba(10,8,12,.08) 70%),
    linear-gradient(180deg, rgba(10,8,12,.30), rgba(10,8,12,.50));}
}
main,header,footer{position:relative;z-index:2}

/* ---------- TOPBAR (street tags) ---------- */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px 4px}
.topbar__mark{font-family:var(--marker);font-size:16px;color:var(--lime);transform:rotate(-2deg);text-shadow:0 2px 8px rgba(0,0,0,.6)}
.topbar__mark--right{color:var(--purple-lt);transform:rotate(2deg)}

/* ---------- HERO (presale/gensale) ---------- */
.hero{display:flex;flex-direction:column;align-items:center;padding:10px 18px 0}
.hero__art{position:relative;width:100%;max-width:560px;margin-top:18px;
  transform:rotate(-1.4deg);border:6px solid #0c0a0e;box-shadow:var(--lift-lg)}
.hero__art img{width:100%;height:auto;display:block}
.hero__head{text-align:center;margin:26px 0 0}
.wordmark{font-family:var(--display);color:var(--lime);font-size:clamp(2.6rem,12vw,5rem);
  line-height:.82;margin:0;text-transform:uppercase;
  -webkit-text-stroke:2px var(--purple);text-shadow:6px 6px 0 var(--purple), 0 14px 30px rgba(0,0,0,.6)}
.hero__sub{font-family:var(--marker);color:var(--bone);font-size:clamp(1rem,3.4vw,1.5rem);margin:.6rem 0 0;transform:rotate(-1deg)}
.hero__sub .spark{color:var(--lime)}
.hero__year{font-family:var(--sans);font-weight:600;text-transform:uppercase;color:var(--ash);font-size:13px;letter-spacing:.35em;margin:.7rem 0 0}

/* ---------- SIGNUP SPLIT ---------- */
.split{display:flex;flex-direction:column;align-items:center;gap:34px;padding:16px 18px 0}
.split__art{position:relative;width:100%;max-width:440px;
  transform:rotate(-1.8deg);border:6px solid #0c0a0e;box-shadow:var(--lift-lg)}
.split__art img{width:100%;height:auto;display:block}
.split__panel{width:100%;max-width:480px;display:flex;justify-content:center}

/* ---------- PANEL (the paste-up flyer card) ---------- */
.panel{padding:32px 18px 8px;display:flex;justify-content:center}
.panel__inner{
  position:relative;width:100%;max-width:480px;
  background:linear-gradient(180deg, rgba(31,25,40,.96), rgba(18,14,24,.97));
  backdrop-filter:blur(2px);
  border:2px solid var(--lime);
  box-shadow:8px 9px 0 var(--purple), var(--lift-lg);
  padding:36px 28px 32px;transform:rotate(-.7deg);
}
.split__panel .panel__inner{margin-top:6px}
.panel__inner > *{transform:rotate(.7deg)}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:700;
  text-transform:uppercase;font-size:13px;letter-spacing:.28em;color:var(--lime);margin:0 0 16px;text-shadow:0 2px 10px rgba(0,0,0,.5)}
.eyebrow span{display:none}
.eyebrow::before{content:"//";color:var(--purple-lt);font-weight:700}

.panel__title{font-family:var(--display);color:var(--bone);text-transform:uppercase;
  font-size:clamp(1.85rem,6.4vw,2.6rem);line-height:1.46;margin:0 0 18px;letter-spacing:.09em;text-shadow:0 6px 22px rgba(0,0,0,.5)}
.panel__title em{font-style:normal;color:var(--lime)}

.panel__lede{font-family:var(--sans);font-weight:400;color:#cfc8da;font-size:17px;line-height:1.5;margin:0 0 22px;max-width:42ch}
.panel__lede strong{color:var(--bone);font-weight:600}
.inline-code{font-family:var(--display);color:#0c0a0e;background:var(--lime);letter-spacing:.06em;padding:1px 9px;box-shadow:2px 2px 0 var(--purple)}

/* ---------- FORM ---------- */
.form{margin-top:18px}
.form__row{margin-bottom:15px}
.form__label{display:block;font-family:var(--sans);font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.14em;color:var(--lime);margin-bottom:7px}
.form__hint{font-weight:400;text-transform:none;letter-spacing:.01em;color:var(--ash);font-size:13px}
.form__input{width:100%;background:rgba(8,7,11,.9);color:var(--bone);font-family:var(--sans);font-weight:500;font-size:17px;
  border:2px solid #3a3346;border-radius:0;padding:12px 13px}
.form__input::placeholder{color:#6c6577}
.form__input:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px var(--lime-glow)}
.form__input[aria-invalid="true"]{border-color:#ff5a5a}
.form__err{color:#ff8f8f;font-family:var(--sans);font-weight:500;font-size:14px;margin:7px 0 0}

/* intl-tel-input */
.iti{width:100%}
.iti__country-list{background:#0e0c11;border:2px solid var(--lime);color:var(--bone)}
.iti__country.iti__highlight,.iti__country:hover{background:rgba(200,255,46,.16)}
.iti__dial-code{color:var(--ash)}
.iti--separate-dial-code .iti__selected-flag{background:rgba(255,255,255,.05)}

/* date dropdown multi-select */
.msel{position:relative}
.msel__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:rgba(8,7,11,.9);color:var(--bone);font-family:var(--sans);font-weight:500;font-size:17px;text-transform:uppercase;
  border:2px solid #3a3346;border-radius:0;padding:12px 13px;cursor:pointer;text-align:left}
.msel__toggle:focus-visible{outline:none;border-color:var(--lime)}
.msel.is-open .msel__toggle{border-color:var(--lime)}
.msel__summary{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msel__summary.is-placeholder{color:#6c6577}
.msel__arrow{flex:0 0 auto;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:7px solid var(--lime);transition:transform .15s}
.msel.is-open .msel__arrow{transform:rotate(180deg)}
.msel__menu{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:30;max-height:280px;overflow-y:auto;
  background:#0e0c11;border:2px solid var(--lime);box-shadow:6px 7px 0 var(--purple), var(--lift);padding:6px}
.msel__opt{display:flex;align-items:center;gap:10px;padding:9px 10px;cursor:pointer}
.msel__opt:hover{background:rgba(200,255,46,.14)}
.msel__opt input{width:17px;height:17px;flex:0 0 17px;accent-color:var(--lime);margin:0}
.msel__opt-face{font-family:var(--sans);font-weight:500;text-transform:uppercase;letter-spacing:.02em;color:var(--bone);font-size:16px}
.msel__opt-face b{color:var(--lime);font-weight:700;margin-right:8px}

/* consent */
.form__consent{display:flex;gap:10px;align-items:flex-start;margin:4px 0 20px;cursor:pointer}
.form__consent input{margin-top:3px;width:18px;height:18px;flex:0 0 18px;accent-color:var(--lime)}
.form__consent span{font-family:var(--sans);font-weight:400;color:var(--ash);font-size:14px;line-height:1.45}
.form__consent a{color:var(--lime)}

/* ---------- BUTTONS (spray-paint sticker) ---------- */
.btn-ticket,.tbtn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:17px;text-decoration:none;cursor:pointer;
  background:var(--lime);color:#0c0a0e;border:2px solid #0c0a0e;border-radius:0;padding:14px 26px;
  box-shadow:5px 5px 0 var(--purple), 0 12px 24px -8px rgba(0,0,0,.7);transition:transform .1s,box-shadow .1s,background .15s}
.btn-ticket{width:100%}
.btn-ticket:hover,.tbtn:hover{background:var(--bone);transform:translate(-1px,-1px);box-shadow:7px 7px 0 var(--purple), 0 16px 30px -8px rgba(0,0,0,.7)}
.btn-ticket:active,.tbtn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--purple)}
.btn__face{display:inline-block}
.tbtn{font-size:15px;padding:10px 18px;box-shadow:4px 4px 0 var(--purple), 0 8px 18px -8px rgba(0,0,0,.6)}
.tbtn--soon{background:transparent;color:var(--ash);border-color:#3a3346;box-shadow:none;cursor:default;pointer-events:none}

/* ---------- DATE FLYERS (presale/gensale) ---------- */
.dates{max-width:1000px;margin:24px auto 0;padding:24px 20px 10px}
.dates__h2{font-family:var(--display);color:var(--lime);text-align:center;text-transform:uppercase;
  font-size:clamp(2rem,7vw,3rem);margin:0 0 32px;-webkit-text-stroke:1.5px var(--purple);text-shadow:4px 4px 0 var(--purple), 0 12px 30px rgba(0,0,0,.6)}
.datelist{list-style:none;margin:0;padding:8px;display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:28px}
.daterow{position:relative;display:flex;flex-direction:column;gap:5px;
  background:var(--lime);color:#0c0a0e;border:3px solid #0c0a0e;padding:18px 18px 20px;
  box-shadow:7px 8px 0 rgba(0,0,0,.45), var(--lift);transition:transform .18s ease,box-shadow .18s ease}
.daterow:nth-child(even){background:var(--paper);transform:rotate(.7deg)}
.daterow:nth-child(odd){transform:rotate(-.7deg)}
.daterow:nth-child(3n){transform:rotate(.3deg)}
.daterow:hover{transform:rotate(0) translateY(-5px);box-shadow:10px 13px 0 var(--purple), var(--lift-lg);z-index:3}
.daterow__date{align-self:flex-start;font-family:var(--sans);font-weight:700;text-transform:uppercase;
  font-size:13px;letter-spacing:.1em;background:#0c0a0e;color:var(--lime);padding:4px 10px}
.daterow__city{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.9rem,5.4vw,2.5rem);line-height:.9;letter-spacing:.01em;color:#0c0a0e;margin-top:7px}
.daterow__venue{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:#3a3340}
.daterow__cta{margin-top:auto;padding-top:14px}
.daterow__cta .tbtn{width:100%;background:#0c0a0e;color:var(--lime);border-color:#0c0a0e;box-shadow:3px 3px 0 var(--purple)}
.daterow__cta .tbtn:hover{background:var(--purple);color:var(--bone);transform:translate(-1px,-1px)}
.daterow__cta .tbtn--soon{background:transparent;color:#5a5360;border:2px dashed #5a5360;box-shadow:none}

/* code reveal */
.code-reveal{position:relative;margin-top:22px;padding:20px 18px;border:2px dashed var(--lime);background:rgba(200,255,46,.06)}
.code-reveal__label{font-family:var(--marker);font-size:15px;color:var(--ash);margin:0 0 6px}
.code-reveal__code{font-family:var(--display);color:var(--lime);font-size:clamp(1.8rem,6vw,2.4rem);letter-spacing:.08em;margin:0;text-shadow:3px 3px 0 var(--purple)}
.code-reveal__hint{font-family:var(--sans);color:var(--ash);font-size:14px;margin:9px 0 0}

/* ---------- FOOTER ---------- */
.foot{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
  width:100%;margin:0;padding:14px clamp(18px,4vw,44px) 16px;
  border-top:1px solid rgba(255,255,255,.13);
  font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(241,245,247,.78)}
.foot a{color:rgba(241,245,247,.85);text-decoration:none}
.foot a:hover{color:var(--lime)}
.foot__left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.foot__legal{margin:0}
.site-built{margin:0}
.site-built a{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .8rem;
  font-weight:600;font-size:11px;letter-spacing:.06em;color:rgba(241,245,247,.85);
  background:rgba(8,11,14,.55);border:1px solid rgba(255,255,255,.18);border-radius:999px;transition:border-color .15s}
.site-built a:hover{border-color:var(--lime);color:#fff}
.site-built img{display:inline-block;height:14px;width:auto;opacity:.95;filter:grayscale(1) brightness(2.4);vertical-align:middle}

/* ---------- Animations ---------- */
@keyframes slam{0%{opacity:0;transform:scale(1.12) rotate(-3deg)}100%{opacity:1}}
.panel__inner,.hero__art,.split__art{animation:slam .45s cubic-bezier(.2,.8,.3,1) both}
@media (prefers-reduced-motion:reduce){*{animation:none!important}}

/* ---------- Responsive ---------- */
@media (min-width:920px){
  .split{flex-direction:row;align-items:center;justify-content:center;gap:64px;max-width:1140px;margin:0 auto;
    padding:30px 32px 0;min-height:calc(100vh - 120px)}
  .split__art{flex:0 0 46%;max-width:480px}
  .split__panel{flex:0 1 480px}
}
@media (max-width:420px){
  .panel__inner{padding:28px 20px 26px}
  .datelist{grid-template-columns:1fr}
}

/* Presale / gensale: clean header (no boxed card), let the flyer cards lead */
body[data-mode="presale"] .panel,
body[data-mode="gensale"] .panel{padding:34px 18px 4px}
body[data-mode="presale"] .panel__inner,
body[data-mode="gensale"] .panel__inner{
  background:none;border:none;box-shadow:none;backdrop-filter:none;transform:none;padding:0;max-width:640px;
}
body[data-mode="presale"] .panel__inner > *,
body[data-mode="gensale"] .panel__inner > *{transform:none}

/* ============================================================
   Brand-asset layout: official logo + breakthrough over brick wall
   ============================================================ */
.stage{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 18px 0}
.stage__inner{width:100%;max-width:560px;display:flex;flex-direction:column;align-items:center}

.brandwrap{width:100%;text-align:center;margin:2px 0 22px}
.brand-logo{display:block;width:min(76%,340px);height:auto;margin:0 auto;filter:drop-shadow(0 14px 28px rgba(0,0,0,.75))}
.brand-bt{display:block;width:min(92%,430px);height:auto;margin:6px auto 0;filter:drop-shadow(0 8px 18px rgba(0,0,0,.6))}

/* form / header panel inside the stage column */
.stage .panel{padding:0;display:block;width:100%}
.stage .panel__inner{width:100%;max-width:none;transform:none;margin:0;
  background:linear-gradient(180deg, rgba(16,12,20,.95), rgba(9,7,13,.97));
  border:2px solid var(--lime);
  box-shadow:7px 8px 0 var(--purple), var(--lift-lg);
  padding:30px 24px 28px}
.stage .panel__inner > *{transform:none}
.nowrap{white-space:nowrap}

/* presale / gensale: clean text header (no boxed card), dates lead */
body[data-mode="presale"] .stage .panel,
body[data-mode="gensale"] .stage .panel{margin:6px 0 4px}
body[data-mode="presale"] .stage .panel__inner,
body[data-mode="gensale"] .stage .panel__inner{
  background:none;border:none;box-shadow:none;padding:0;text-align:center}
.stage .dates{width:100%;max-width:100%;margin-top:14px}

/* Desktop: bias the form left over the wall's hole; artist stays visible right */
@media (min-width:920px){
  .stage{padding-top:28px}
  .stage--form{align-items:flex-start;padding-left:clamp(48px,8vw,150px)}
  .stage--form .stage__inner{align-items:flex-start;max-width:520px;margin-top:1vh}
  .stage--form .brandwrap{text-align:left;margin-bottom:24px}
  .stage--form .brand-logo,.stage--form .brand-bt{margin-left:0}
  .stage:not(.stage--form) .stage__inner{max-width:1060px}
}

/* ============================================================
   Proof layout: full overlay artwork LEFT / sign-up form RIGHT
   over a plain brick wall
   ============================================================ */
.overlay-art{width:100%;max-width:350px;margin:0 auto 12px}
.overlay-art img{width:100%;height:auto;filter:drop-shadow(0 22px 40px rgba(0,0,0,.8))}
.stage--form .stage__inner{align-items:center}

@media (min-width:920px){
  .stage--form{align-items:center;padding:24px 30px 0}
  .stage--form .stage__inner{flex-direction:row;align-items:center;justify-content:center;gap:52px;max-width:1120px;margin:0 auto}
  .stage--form .overlay-art{flex:0 0 46%;max-width:500px;margin:0}
  .stage--form .panel{flex:0 1 460px}
}

/* presale/gensale: date boxes in the right column */
.stage--form .datelist{grid-template-columns:repeat(2,1fr);gap:16px;padding:0;margin-top:8px}
.stage--form .daterow__city{font-size:clamp(1.4rem,4.4vw,1.85rem)}
@media (max-width:400px){ .stage--form .datelist{grid-template-columns:1fr} }
@media (min-width:920px){
  .stage--form .stage__inner{align-items:flex-start}
  .stage--form .panel{flex:0 1 540px}
  body[data-mode="presale"] .stage--form .panel__inner,
  body[data-mode="gensale"] .stage--form .panel__inner{text-align:left}
}

/* ---- Footer on mobile: stack centered ---- */
@media (max-width:680px){
  .foot{flex-direction:column;align-items:center;text-align:center;gap:12px;padding:16px 18px 24px}
  .foot__left{flex-direction:column;align-items:center;gap:10px}
}
/* ---- Tablet (single column, 680-919px): comfortable centered stack ---- */
@media (min-width:680px) and (max-width:919px){
  .stage{padding:26px 24px 0}
  .stage--form .stage__inner{max-width:580px}
  .overlay-art{max-width:430px}
  .stage .panel__inner{max-width:560px}
}

/* Safety: never let lede text overflow the panel */
.panel__lede{overflow-wrap:break-word;word-break:break-word}
