/* ===== ALL STAR STUDIO — FanTown blue/white PIXEL theme ===== */
@font-face{font-family:'Zpix';src:url('public/fonts/zpix.ttf') format('truetype');font-display:swap}
body, body *{font-family:'Zpix','Press Start 2P','VT323',monospace !important}
:root{
  --blue:#1B45B0;       /* brand blue */
  --blue-lt:#3A66D6;
  --blue-dk:#0E2570;
  --red:#D01A33;        /* brand red accent */
  --white:#ffffff;
  --paper:#eef3ff;      /* very light blue-white */
  --ink:#0c1a3a;
  --line:#1B45B0;
  --shadow:#0E2570;
}
*{box-sizing:border-box;margin:0;padding:0}
/* CRITICAL: the HTML `hidden` attribute must beat the .as-loading/.as-lightbox
   display:flex rules, otherwise the full-screen blue overlay covers the page. */
[hidden]{display:none!important}
.as-body{
  font-family:'VT323',monospace;
  background:var(--paper);
  color:var(--ink);
  font-size:20px;
  line-height:1.35;
  /* subtle CRT scanlines */
  background-image:repeating-linear-gradient(0deg, rgba(27,69,176,.035) 0 2px, transparent 2px 4px);
  min-height:100vh;
}
.pixel{font-family:'Press Start 2P',monospace}

/* ===== TOP BAR ===== */
.as-topbar{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
  background:var(--white);
  border-bottom:4px solid var(--blue);
  box-shadow:0 4px 0 var(--blue-dk);
  padding:10px 16px;position:sticky;top:0;z-index:50;
}
.as-brand{display:flex;align-items:center;gap:10px}
.as-brand-logo{height:34px;width:auto;image-rendering:auto;border:2px solid var(--blue);background:#fff}
.as-brand-name{font-family:'Press Start 2P',monospace;font-size:13px;color:var(--blue)}
.as-topnav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.as-topnav a{
  font-family:'Press Start 2P',monospace;font-size:9px;text-decoration:none;
  color:var(--blue);padding:8px 10px;border:2px solid var(--blue);background:#fff;
  box-shadow:2px 2px 0 var(--blue-dk);
}
.as-topnav a:hover{background:var(--blue);color:#fff}
.as-topnav a.active{background:var(--blue);color:#fff;box-shadow:2px 2px 0 var(--red)}
.as-badge{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--red);margin-left:4px}

/* ===== HERO ===== */
.as-hero{
  text-align:center;padding:46px 16px 38px;
  background:linear-gradient(180deg,var(--blue) 0%,var(--blue-dk) 100%);
  color:#fff;border-bottom:4px solid var(--blue-dk);position:relative;overflow:hidden;
}
/* evenly tiled team crests behind the hero content */
.as-hero-crests{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:1fr;
  gap:10px;padding:14px;
  align-items:center;justify-items:center;
  opacity:.18;
}
.as-hero-crests img{
  width:100%;height:100%;max-width:96px;max-height:96px;
  object-fit:contain;
  mix-blend-mode:screen;          /* drops the white box, keeps the crest glowing on blue */
  filter:brightness(1.1) contrast(1.05);
}
/* hero content above the crest layer */
.as-hero > *:not(.as-hero-crests){position:relative;z-index:1}
@media(max-width:700px){.as-hero-crests{grid-template-columns:repeat(4,1fr);opacity:.14}}
.as-hero-banner{
  display:inline-block;font-family:'Press Start 2P',monospace;font-size:9px;
  background:#fff;color:var(--blue);padding:8px 14px;border:3px solid #fff;
  box-shadow:3px 3px 0 var(--red);margin-bottom:20px;letter-spacing:1px;
}
.as-hero-logo{width:120px;height:120px;object-fit:contain;image-rendering:auto;display:block;margin:0 auto 14px;border:3px solid #fff;background:#fff;box-shadow:4px 4px 0 var(--blue-dk)}
.as-hero-title{font-family:'Press Start 2P',monospace;font-size:34px;line-height:1.25;text-shadow:4px 4px 0 var(--blue-dk),8px 8px 0 rgba(0,0,0,.25)}
.ttl-blue{color:#bcd0ff}
.as-hero-sub{font-size:21px;margin:14px auto 22px;max-width:640px;opacity:.95}
.as-cta{
  display:inline-block;font-family:'Press Start 2P',monospace;font-size:13px;text-decoration:none;
  background:var(--red);color:#fff;padding:14px 26px;border:3px solid #fff;
  box-shadow:4px 4px 0 var(--blue-dk);animation:aspulse 1.4s infinite;
}
@keyframes aspulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* ===== SECTION / BLOCKS ===== */
.as-section{max-width:880px;margin:0 auto;padding:30px 16px 60px}
.as-block{
  background:#fff;border:3px solid var(--blue);box-shadow:5px 5px 0 var(--blue-dk);
  padding:18px;margin-bottom:24px;
}
.as-blk-title{font-family:'Press Start 2P',monospace;font-size:13px;color:var(--blue);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.as-blk-title small{font-family:'VT323',monospace;font-size:18px;color:var(--blue-lt);font-weight:normal}
.as-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:var(--blue);color:#fff;border:2px solid var(--blue-dk);font-size:11px}

/* ===== TYPE PICKER ===== */
.as-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.as-type{
  font-family:'Press Start 2P',monospace;font-size:11px;cursor:pointer;
  background:#fff;color:var(--blue);border:3px solid var(--blue);
  box-shadow:3px 3px 0 var(--blue-dk);padding:16px 10px;display:flex;flex-direction:column;gap:8px;align-items:center;
}
.as-type small{font-family:'VT323',monospace;font-size:16px;color:var(--blue-lt);font-weight:normal}
.as-type:hover{background:var(--paper)}
.as-type.active{background:var(--blue);color:#fff;box-shadow:3px 3px 0 var(--red)}
.as-type.active small{color:#cfe}

/* ===== CONNECTION / LOGIN STATUS ===== */
.as-conn{border:3px solid var(--blue);background:var(--paper);padding:12px;margin-bottom:14px}
.as-conn-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:18px;color:var(--blue-dk)}
.as-jk-dot{width:14px;height:14px;border:2px solid var(--blue-dk);background:#bbb;display:inline-block}
.as-jk-dot.on{background:#2ecc40}
.as-jk-dot.off{background:var(--red)}
.as-conn-btn{font-family:'VT323',monospace;font-size:16px;cursor:pointer;text-decoration:none;background:#fff;color:var(--blue);border:2px solid var(--blue);box-shadow:2px 2px 0 var(--blue-dk);padding:5px 10px}
.as-conn-btn:hover{background:var(--blue);color:#fff}
.as-conn-btn.rd{background:var(--blue);color:#fff}
.as-conn-btn.rd:hover{background:var(--blue-lt)}
.as-conn-hint{display:block;margin-top:8px;font-size:15px;color:#6a7da8}

/* ===== SKU SEARCH ===== */
.as-sku{margin-bottom:16px}
.as-sku-row{display:flex;gap:8px;margin-bottom:8px}
.as-sku-input{flex:1;font-family:'VT323',monospace;font-size:20px;padding:10px 12px;border:3px solid var(--blue);background:#fff;color:var(--ink)}
.as-sku-input:focus{outline:none;box-shadow:3px 3px 0 var(--blue-dk)}
.as-sku-btn{font-family:'Press Start 2P',monospace;font-size:10px;cursor:pointer;background:var(--blue);color:#fff;border:3px solid var(--blue-dk);box-shadow:3px 3px 0 var(--blue-dk);padding:0 16px}
.as-sku-btn:hover{background:var(--blue-lt)}
.as-sku-srcs{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:17px;color:var(--blue-dk)}
.as-sku-srcs label{cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.as-src-ic{height:16px;width:16px;vertical-align:middle;border-radius:3px}
.as-sku-hint{flex-basis:100%;font-size:15px;color:#6a7da8}
.as-sku-results{margin-top:12px}
.as-sku-loading{font-size:18px;color:var(--blue);padding:10px}
.as-sku-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.as-sku-card{position:relative;border:3px solid var(--blue);background:#fff;box-shadow:3px 3px 0 var(--blue-dk);overflow:hidden}
.as-sku-card img{width:100%;height:120px;object-fit:cover;display:block;cursor:zoom-in}
.as-sku-tag{position:absolute;top:0;left:0;font-family:'Press Start 2P',monospace;font-size:7px;background:var(--blue);color:#fff;padding:3px 5px;z-index:2}
.as-sku-actions{position:absolute;bottom:0;left:0;right:0;display:flex}
.as-sku-actions button{flex:1;cursor:pointer;border:none;font-family:'Press Start 2P',monospace;font-size:11px;padding:6px 0}
.as-sku-yes{background:var(--blue);color:#fff}
.as-sku-no{background:var(--red);color:#fff}
.as-sku-login{margin-top:10px;font-size:16px;color:var(--red)}
.as-sku-login a{color:var(--blue);font-weight:bold}

/* ===== UPLOAD ===== */
.as-upload{
  border:3px dashed var(--blue);background:var(--paper);
  padding:28px 16px;text-align:center;cursor:default;transition:.15s;
}
.as-upload.dragover{background:#dde8ff;border-color:var(--red)}
.as-upload-ic{font-family:'Press Start 2P',monospace;font-size:24px;color:var(--blue);display:block;margin-bottom:10px}
.as-upload-inner p{font-size:19px;color:var(--blue-dk)}
.as-upload-inner small{font-size:16px;color:#6a7da8}
.as-browse{font-family:'VT323',monospace;font-size:16px;cursor:pointer;background:var(--blue);color:#fff;border:2px solid var(--blue-dk);padding:3px 8px}
.as-thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.as-thumb{position:relative;width:90px;height:90px;border:3px solid var(--blue);box-shadow:2px 2px 0 var(--blue-dk);overflow:hidden}
.as-thumb img{width:100%;height:100%;object-fit:cover}
.as-thumb-x{position:absolute;top:0;right:0;background:var(--red);color:#fff;border:none;cursor:pointer;font-family:'Press Start 2P',monospace;font-size:9px;padding:3px 5px}
.as-tip{display:block;margin-top:10px;font-size:15px;color:#6a7da8}

/* ===== INPUTS ===== */
.as-input,.as-ta{width:100%;font-family:'VT323',monospace;font-size:20px;padding:10px 12px;border:3px solid var(--blue);background:#fff;color:var(--ink);margin-bottom:12px}
.as-input:focus,.as-ta:focus{outline:none;box-shadow:3px 3px 0 var(--blue-dk)}
.as-ta{min-height:80px;resize:vertical}
.as-check{display:flex;align-items:center;gap:8px;font-size:18px;color:var(--blue-dk);margin-bottom:12px;cursor:pointer}
.as-chips{display:flex;flex-wrap:wrap;gap:8px}
.as-chip{font-family:'VT323',monospace;font-size:16px;cursor:pointer;background:#fff;color:var(--blue);border:2px solid var(--blue);box-shadow:2px 2px 0 var(--blue-dk);padding:5px 10px}
.as-chip:hover{background:var(--blue);color:#fff}

/* ===== OPTIONS ===== */
.as-opt-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.as-opt-label{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--blue);min-width:96px}
.as-ratios{display:flex;gap:8px;flex-wrap:wrap}
.as-ratio{font-family:'Press Start 2P',monospace;font-size:10px;cursor:pointer;background:#fff;color:var(--blue);border:3px solid var(--blue);box-shadow:2px 2px 0 var(--blue-dk);padding:9px 12px}
.as-ratio:hover{background:var(--paper)}
.as-ratio.active{background:var(--blue);color:#fff;box-shadow:2px 2px 0 var(--red)}
.as-engine-fixed{font-family:'VT323',monospace;font-size:18px;color:var(--blue-dk);background:var(--paper);border:2px solid var(--blue);padding:8px 12px}

/* ===== ACTIONS ===== */
.as-actions{text-align:center;margin:8px 0}
.as-gen{font-family:'Press Start 2P',monospace;font-size:14px;cursor:pointer;background:var(--red);color:#fff;border:3px solid var(--blue-dk);box-shadow:5px 5px 0 var(--blue-dk);padding:18px 26px;width:100%;max-width:520px}
.as-gen:hover{background:#e8324b}
.as-gen:disabled{opacity:.5;cursor:not-allowed}
.as-note{text-align:center;font-size:15px;color:#6a7da8;margin:12px 0 26px}

/* ===== RESULTS ===== */
.as-results{background:#fff;border:3px solid var(--blue);box-shadow:5px 5px 0 var(--blue-dk);padding:18px}
.as-result-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.as-rcard{border:3px solid var(--blue);box-shadow:3px 3px 0 var(--blue-dk);overflow:hidden;background:#fff}
.as-rcard img{width:100%;display:block;cursor:zoom-in}
.as-rcard .as-dl{display:block;text-align:center;font-family:'Press Start 2P',monospace;font-size:9px;background:var(--blue);color:#fff;text-decoration:none;padding:8px}
.as-rcard .as-dl:hover{background:var(--blue-lt)}
.as-clear{font-family:'Press Start 2P',monospace;font-size:9px;cursor:pointer;background:var(--red);color:#fff;border:2px solid var(--blue-dk);padding:5px 8px;margin-left:auto}

/* ===== FOOTER ===== */
.as-footer{text-align:center;padding:30px 16px;background:var(--blue);color:#fff;border-top:4px solid var(--blue-dk)}
.as-footer-logo{height:40px;background:#fff;border:2px solid #fff;padding:2px;margin-bottom:10px}
.as-footer-banner{font-family:'Press Start 2P',monospace;font-size:9px;letter-spacing:1px}

/* ===== LOADING ===== */
.as-loading{position:fixed;inset:0;background:rgba(14,37,112,.94);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:200;color:#fff}
.as-prog-stage{width:min(560px,80vw);text-align:center}
.as-prog-track{position:relative;height:26px;background:#0a1c52;border:3px solid #fff;box-shadow:4px 4px 0 var(--red)}
.as-prog-fill{height:100%;width:0;background:repeating-linear-gradient(90deg,var(--blue-lt) 0 10px,#5b86e8 10px 20px);transition:width .5s}
.as-prog-pct{font-family:'Press Start 2P',monospace;font-size:14px;margin-top:14px}
.as-loading-txt{font-family:'Press Start 2P',monospace;font-size:12px;margin-top:18px}
.as-loading-banner{font-family:'Press Start 2P',monospace;font-size:10px;color:#bcd0ff;margin-top:14px}

/* ===== LIGHTBOX ===== */
.as-lightbox{position:fixed;inset:0;background:rgba(14,37,112,.96);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:300}
.as-lb-inner img,.as-lb-inner video{max-width:90vw;max-height:80vh;border:4px solid #fff;box-shadow:6px 6px 0 var(--red)}
.as-lb-x{position:absolute;top:18px;right:18px;font-family:'Press Start 2P',monospace;font-size:14px;background:var(--red);color:#fff;border:3px solid #fff;cursor:pointer;padding:8px 12px}
.as-lb-dl{margin-top:18px;font-family:'Press Start 2P',monospace;font-size:11px;background:var(--blue);color:#fff;text-decoration:none;border:3px solid #fff;padding:12px 20px;box-shadow:4px 4px 0 var(--red)}

@media(max-width:600px){
  .as-hero-title{font-size:24px}
  .as-brand-name{font-size:10px}
}

/* ===== MOBILE (≤640px) — comprehensive responsive ===== */
@media(max-width:640px){
  html,body{max-width:100%;overflow-x:hidden}
  *{max-width:100%}
  .as-topnav{gap:5px;justify-content:flex-end}
  .as-topnav a{font-size:8px;padding:7px 8px}
  .as-topbar{padding:8px 10px}
  .as-hero-title{font-size:26px}
  .as-hero-sub{font-size:16px}
  .as-hero-logo{width:90px;height:90px}
  .as-cta{font-size:13px;padding:13px 20px}
  .as-block{padding:14px}
  /* type picker: 2 per row */
  .as-types{grid-template-columns:repeat(2,1fr)}
  /* sku row stack */
  .as-sku-row{flex-wrap:wrap}
  .as-sku-input{flex:1 1 100%;min-width:0;font-size:16px}
  .as-sku-btn{flex:1 1 100%;padding:12px}
  .as-sku-srcs{flex-wrap:wrap;gap:8px}
  .as-conn-row{flex-wrap:wrap;gap:8px}
  .as-conn-btn{flex:1 1 auto;text-align:center}
  .as-input,.as-ta{font-size:16px}
  .as-ratios{flex-wrap:wrap}
  .as-gen{width:100%;font-size:13px;padding:16px}
  .as-result-grid{grid-template-columns:repeat(2,1fr)}
  .as-opt-row{align-items:flex-start}
  .as-lb-inner img,.as-lb-inner video{max-width:94vw}
}
@media(max-width:380px){
  .as-types{grid-template-columns:1fr 1fr}
  .as-hero-title{font-size:22px}
  .as-topnav a{font-size:7px;padding:6px 6px}
}
