/* BOBAI Worldcup '26 — Beta App shared styles */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --gold:#F0B90B;--gold2:#ffd54f;--gold-glow:rgba(240,185,11,.12);
  --red:#ff3028;--green:#00e676;--blue:#4040ff;--purple:#a040ff;
  --bg:#050510;--card:rgba(12,12,28,.85);--border:rgba(240,185,11,.08);
  --text:#e4e5f1;--muted:#7b7d9e;
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh}

.bg-grad{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(240,185,11,.10), transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(64,64,255,.10), transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(255,48,40,.05), transparent 60%)}

.page{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}

nav{position:sticky;top:0;z-index:100;background:rgba(5,5,16,.88);backdrop-filter:blur(24px) saturate(1.2);border-bottom:1px solid var(--border)}
.nav{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:58px;gap:12px}
.back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;background:rgba(240,185,11,.08);border:1px solid rgba(240,185,11,.2);color:var(--gold);font-size:12px;font-weight:600;text-decoration:none;letter-spacing:.3px;transition:transform .2s ease,background .2s,border-color .2s;white-space:nowrap}
.back-btn:hover{transform:translateX(-2px);background:rgba(240,185,11,.15);border-color:rgba(240,185,11,.4)}
.back-btn span{font-size:14px;line-height:1}
.nav .brand{font-family:'Space Grotesk';font-weight:700;font-size:14px;letter-spacing:.5px;color:var(--gold);white-space:nowrap}
.brand-link{font-family:'Space Grotesk';font-weight:700;font-size:14px;letter-spacing:.5px;color:var(--gold);white-space:nowrap;text-decoration:none}
.brand-link:hover{opacity:.85}
.nav .user{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40%}
.nav .user b{color:var(--text)}
.nav .user a{color:var(--gold);text-decoration:none}
.nav .user a:hover{text-decoration:underline}

/* Tab navigation under the top bar */
.tabbar{max-width:1200px;margin:0 auto;display:flex;gap:0;overflow-x:auto;padding:0 16px;scrollbar-width:none}
.tabbar::-webkit-scrollbar{display:none}
.tabbar a{padding:11px 14px;font-size:11.5px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;transition:color .15s, border-color .15s;white-space:nowrap;flex-shrink:0;display:inline-flex;align-items:center;gap:6px}
.tabbar a:hover{color:var(--text)}
.tabbar a.active{color:var(--gold);border-bottom-color:var(--gold)}
.tabbar a .ic{font-size:13px;line-height:1}

@media(max-width:560px){
  .nav{padding:0 14px;height:50px}
  .nav .brand,.brand-link{font-size:12px}
  .nav .user{font-size:11px}
  .tabbar{padding:0 8px}
  .tabbar a{padding:10px 10px;font-size:10.5px;letter-spacing:.3px}
  .tabbar a .ic{font-size:12px}
}

main{flex:1;padding:48px 24px}
.container{max-width:520px;margin:0 auto}

/* Inline back row injected by nav.js. Sits between tabbar and main content. */
.back-row{max-width:1200px;margin:0 auto;padding:10px 24px 0}
.back-row button{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-family:inherit;font-size:11.5px;font-weight:600;letter-spacing:.4px;cursor:pointer;transition:transform .15s ease,color .15s,border-color .15s,background .15s}
.back-row button:hover{color:var(--gold);border-color:rgba(240,185,11,.3);background:rgba(240,185,11,.06);transform:translateX(-2px)}
.back-row button .ic{font-size:13px;line-height:1}
@media(max-width:560px){
  .back-row{padding:8px 14px 0}
  .back-row button{font-size:11px;padding:5px 9px}
}

/* CARD */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}

/* HEADINGS */
h1{font-family:'Space Grotesk';font-weight:700;font-size:clamp(28px,4vw,40px);line-height:1.1;letter-spacing:-.02em;margin-bottom:8px;text-align:center}
h1 .accent{background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 60%,#fff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sub{font-size:14px;color:var(--muted);text-align:center;margin-bottom:28px}

/* TABS */
.tabs{display:flex;gap:8px;margin-bottom:24px;background:rgba(0,0,0,.3);padding:4px;border-radius:10px}
.tab{flex:1;padding:10px;font-size:13px;font-weight:600;border:none;background:transparent;color:var(--muted);border-radius:8px;cursor:pointer;transition:all .2s}
.tab.active{background:var(--gold-glow);color:var(--gold)}

/* FORMS */
.field{margin-bottom:16px}
.field label{display:block;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field select{width:100%;padding:12px 14px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;font-family:inherit;transition:border-color .2s}
.field input:focus,.field select:focus{outline:none;border-color:rgba(240,185,11,.4)}
.field .hint{font-size:11px;color:var(--muted);margin-top:6px;line-height:1.5}

/* BUTTON */
.btn{display:block;width:100%;padding:14px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#050510;font-size:14px;font-weight:700;letter-spacing:.4px;cursor:pointer;transition:transform .15s,box-shadow .15s}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(240,185,11,.25)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}

/* ALERTS */
.alert{padding:12px 14px;border-radius:10px;font-size:13px;margin-bottom:16px}
.alert.error{background:rgba(255,48,40,.1);border:1px solid rgba(255,48,40,.3);color:#ff8580}
.alert.ok{background:rgba(0,230,118,.08);border:1px solid rgba(0,230,118,.25);color:#5fffa0}
.alert.info{background:rgba(64,64,255,.08);border:1px solid rgba(64,64,255,.25);color:#9090ff}

/* HIDDEN */
.hidden{display:none !important}

/* TWEMOJI — keep Twitter SVG flags + emojis at glyph-size instead of natural pixel size */
img.emoji{height:1em;width:1em;margin:0 .05em 0 .1em;vertical-align:-.125em;display:inline-block}

/* SHARED AVATAR / ILLUSTRATION SLOTS (assets/avatar.js)
   .wc-ava wraps a country avatar in a circle. The <img> shows the BOBAI
   illustration when delivered; on 404 it auto-fallbacks to a flag emoji span.
   .wc-illus is for non-avatar illustrations (trophy, hero banner, coin icons). */
.wc-ava{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(240,185,11,.06);border:2px solid var(--gold);overflow:hidden;line-height:1;flex-shrink:0;position:relative}
.wc-ava-img{width:100%;height:100%;object-fit:contain;object-position:center;display:block}
.wc-ava[data-empty]{border-style:dashed;border-color:rgba(123,125,158,.4);background:rgba(0,0,0,.2);color:var(--muted)}
.wc-ava-xs{border-width:1px}
.wc-ava-sm{border-width:1.5px}

/* Designer mode (?design=1) — show missing-illustration placeholders explicitly */
.wc-ava-design{border-style:dashed !important;border-color:#ff40b4 !important;background:rgba(255,64,180,.06) !important}
.wc-ava-design.wc-has-art{border-style:solid !important;border-color:var(--gold) !important;background:rgba(240,185,11,.06) !important}
.wc-ava-design .wc-ava-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;opacity:.6}
.wc-ava-design.wc-has-art .wc-ava-fallback{display:none}
.wc-ava-design .wc-ava-tag{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:700;color:#ff40b4;font-family:'Space Grotesk',monospace;letter-spacing:.3px;white-space:nowrap;background:rgba(0,0,0,.85);padding:2px 6px;border-radius:4px;pointer-events:none}
.wc-ava-design.wc-has-art .wc-ava-tag{display:none}

/* Click-to-zoom on delivered BOBAI avatars — applies everywhere avatar.js runs */
.wc-ava.wc-has-art{cursor:zoom-in}
.wc-ava.wc-has-art .wc-ava-img{transition:transform .15s}
.wc-ava.wc-has-art:hover .wc-ava-img{transform:scale(1.06)}
#wc-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(6px);cursor:zoom-out;padding:24px}
#wc-lightbox.open{display:flex}
#wc-lightbox img{max-width:min(640px,90vw);max-height:85vh;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.6);background:rgba(255,255,255,.02)}
#wc-lightbox .lb-cap{position:absolute;top:18px;left:50%;transform:translateX(-50%);font-family:'Space Grotesk';font-weight:700;color:var(--gold);font-size:14px;letter-spacing:.5px;text-align:center;pointer-events:none}
#wc-lightbox .lb-close{position:absolute;top:14px;right:18px;background:transparent;border:none;color:#fff;font-size:32px;cursor:pointer;line-height:1;opacity:.7;padding:6px 12px}
#wc-lightbox .lb-close:hover{opacity:1}

.wc-illus{position:relative;display:inline-flex;align-items:center;justify-content:center}
.wc-illus-design{border:2px dashed #ff40b4;background:repeating-linear-gradient(45deg,rgba(255,64,180,.04),rgba(255,64,180,.04) 8px,rgba(255,64,180,.08) 8px,rgba(255,64,180,.08) 16px);border-radius:10px;min-height:80px}
.wc-illus-design.wc-has-art{border:none;background:none}
.wc-illus-design .wc-illus-tag{position:absolute;top:6px;left:6px;font-size:10px;font-weight:700;color:#ff40b4;font-family:'Space Grotesk',monospace;background:rgba(0,0,0,.85);padding:3px 8px;border-radius:4px;pointer-events:none}
.wc-illus-design.wc-has-art .wc-illus-tag{display:none}

/* Hero banner — full-width landscape illustration above page heading.
   Shown when /illus/<slot>.{webp|png|jpg} exists. In designer mode the
   slot shows a magenta dashed placeholder with the expected filename. */
.wc-hero{display:block;width:100%;margin:0 0 18px;position:relative;text-align:center}
.wc-hero img{max-width:100%;height:auto;max-height:240px;display:inline-block;object-fit:contain}
.wc-hero-design{min-height:120px;border:2px dashed #ff40b4;background:repeating-linear-gradient(45deg,rgba(255,64,180,.05),rgba(255,64,180,.05) 10px,rgba(255,64,180,.10) 10px,rgba(255,64,180,.10) 20px);border-radius:12px;padding:14px}
.wc-hero-design.wc-has-art{border:none;background:none;padding:0}
.wc-hero-design .wc-hero-tag{position:absolute;top:8px;left:10px;font-size:10px;font-weight:700;color:#ff40b4;font-family:'Space Grotesk',monospace;background:rgba(0,0,0,.85);padding:3px 8px;border-radius:4px;pointer-events:none}
.wc-hero-design.wc-has-art .wc-hero-tag{display:none}
@media (max-width: 600px){
  .wc-hero img{max-height:160px}
}

/* Pool-card corner trophy accent (positioned absolutely in .pool top-right). */
.pool{position:relative}
.pool .wc-pool-trophy{position:absolute;top:-18px;right:-10px;width:96px;height:96px;pointer-events:none;z-index:1}
.pool .wc-pool-trophy img{width:100%;height:100%;object-fit:contain}
@media (max-width: 600px){
  .pool .wc-pool-trophy{width:64px;height:64px;top:-12px;right:-6px}
}

/* Generic card corner accent — small BOBAI decoration in top-right of a .card.
   Same positioning recipe as .wc-pool-trophy. Use <div data-card-accent="slot"></div>
   placed directly inside a .card to wire it up. */
.card{position:relative}
.wc-card-accent{position:absolute;top:-18px;right:-10px;width:88px;height:88px;pointer-events:none;z-index:1}
.wc-card-accent img{width:100%;height:100%;object-fit:contain}
@media (max-width: 600px){
  .wc-card-accent{width:60px;height:60px;top:-12px;right:-6px}
}

/* DESIGNER PLACEHOLDER — hot pink callout so the illustrator can spot
   every spot that needs art at a glance. Remove this whole block once
   all illustrations have landed in /worldcup/app/illus/. */
.dp{position:relative;padding:14px 16px;margin:8px 0 14px;background:repeating-linear-gradient(45deg,rgba(255,64,180,.06),rgba(255,64,180,.06) 10px,rgba(255,64,180,.10) 10px,rgba(255,64,180,.10) 20px);border:2px dashed #ff40b4;border-radius:10px}
.dp .dp-badge{position:absolute;top:-10px;left:14px;background:#ff40b4;color:#050510;font-size:10px;font-weight:800;letter-spacing:1.5px;padding:3px 10px;border-radius:6px;text-transform:uppercase;font-family:'Space Grotesk'}
.dp .dp-title{color:#ff40b4;font-family:'Space Grotesk';font-weight:700;font-size:13px;margin-bottom:4px;letter-spacing:.3px}
.dp .dp-body{color:var(--text);font-size:12px;line-height:1.5;opacity:.85}
.dp .dp-body code{background:rgba(0,0,0,.4);padding:1px 6px;border-radius:4px;font-size:11px;color:#ffb1de;font-family:'Space Grotesk'}
.dp .dp-body a{color:#ff8fd0;text-decoration:underline}
.dp.dp-inline{display:inline-block;margin:4px 6px;padding:8px 12px}
.dp.dp-inline .dp-title{margin-bottom:0}

@media (max-width: 600px){
  main{padding:24px 16px}
  .card{padding:24px 20px}
}
