/*
 * Boleiragem — design system. Dark, gramado + dourado.
 */

:root {
  --color-primary: #16a34a;        /* verde gramado */
  --color-primary-hover: #15803d;
  --color-accent: #f5d90a;         /* dourado/bola */

  --color-success: #10B981;
  --color-danger: #FF4757;
  --color-warning: #F59E0B;

  --color-bg: #07120c;             /* verde quase preto */
  --color-bg-card: #0d1c14;
  --color-bg-elevated: #112619;
  --color-bg-hover: rgba(255, 255, 255, 0.04);

  --color-border: rgba(255, 255, 255, 0.09);
  --color-border-strong: rgba(245, 217, 10, 0.35);

  --color-text: #f4fbf6;
  --color-text-muted: rgba(244, 251, 246, 0.68);
  --color-text-faded: rgba(244, 251, 246, 0.4);

  --space-xs: 4px; --space-sm: 8px; --space-md: 16px; --space-lg: 24px;
  --space-xl: 32px; --space-2xl: 48px; --space-3xl: 64px; --space-4xl: 96px;

  --radius-sm: 8px; --radius-md: 12px; --radius-lg: 16px; --radius-xl: 24px; --radius-full: 9999px;

  --shadow-sm: 0 2px 8px rgba(0,0,0,.35);
  --shadow-md: 0 4px 16px rgba(0,0,0,.45);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.55);

  --transition-fast: 150ms ease; --transition-normal: 250ms ease;

  --font-body: "Inter", system-ui, -apple-system, Segoe UI, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Monaco, monospace;

  --z-sticky: 50; --z-toast: 300;
  --container-max: 1180px; --container-narrow: 720px;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(22,163,74,.18), transparent),
    var(--color-bg);
  color: var(--color-text);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}
img, svg, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
h1, h2, h3 { line-height: 1.15; }

.container { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-lg); }
.container--narrow { max-width: var(--container-narrow); }

/* App header */
.appbar { position: sticky; top: 0; z-index: var(--z-sticky); background: rgba(7,18,12,.82); backdrop-filter: blur(10px); border-bottom: 1px solid var(--color-border); }
.appbar__inner { display: flex; align-items: center; justify-content: space-between; height: 60px; }
.brand { display: flex; align-items: center; gap: var(--space-sm); font-weight: 800; letter-spacing: -.02em; font-size: 1.15rem; }
.brand__ball { font-size: 1.3rem; }
.appbar__cash { font-family: var(--font-mono); color: var(--color-accent); font-weight: 700; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm); padding: var(--space-sm) var(--space-lg); border-radius: var(--radius-md); font-weight: 700; font-size: .95rem; border: 1px solid transparent; transition: all var(--transition-fast); }
.btn--primary { background: linear-gradient(135deg, var(--color-primary), #22c55e); color: #03110a; box-shadow: 0 4px 18px rgba(22,163,74,.35); }
.btn--primary:hover { transform: translateY(-1px); }
.btn--gold { background: linear-gradient(135deg, var(--color-accent), #fbbf24); color: #1a1500; box-shadow: 0 4px 18px rgba(245,217,10,.25); }
.btn--gold:hover { transform: translateY(-1px); }
.btn--ghost { background: transparent; border-color: var(--color-border); color: var(--color-text); }
.btn--ghost:hover { background: var(--color-bg-hover); border-color: var(--color-border-strong); }
.btn--danger { background: var(--color-danger); color: white; }
.btn--sm { padding: var(--space-xs) var(--space-md); font-size: .82rem; }
.btn--lg { padding: var(--space-md) var(--space-xl); font-size: 1.05rem; }
.btn--block { width: 100%; }

/* Card */
.card { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-lg); }
.card--interactive { transition: border-color var(--transition-fast), transform var(--transition-fast); }
.card--interactive:hover { border-color: var(--color-border-strong); transform: translateY(-2px); }
.card__title { margin: 0; font-size: 1.15rem; }
.card__subtitle { margin: var(--space-xs) 0 0; color: var(--color-text-muted); font-size: .9rem; }

/* Forms */
.field { display: flex; flex-direction: column; gap: var(--space-sm); margin-bottom: var(--space-md); }
.field label { font-size: .9rem; color: var(--color-text-muted); }
.field input, .field textarea, .field select { background: var(--color-bg-elevated); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); color: var(--color-text); font: inherit; font-size: 1rem; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--color-primary); }
input[type=text], input[type=email], input[type=password], input[type=search] { background: var(--color-bg-elevated); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); color: var(--color-text); font: inherit; }
input[type=text]:focus { outline: none; border-color: var(--color-primary); }

/* Layout helpers */
.stack { display: flex; flex-direction: column; }
.stack--sm { gap: var(--space-sm); } .stack--md { gap: var(--space-md); } .stack--lg { gap: var(--space-lg); }
.row { display: flex; align-items: center; } .row--between { justify-content: space-between; } .row--gap { gap: var(--space-md); } .row--wrap { flex-wrap: wrap; }
.grid { display: grid; gap: var(--space-md); }
.grid--2 { grid-template-columns: 1fr 1fr; } .grid--3 { grid-template-columns: repeat(3, 1fr); }
.text-gradient { background: linear-gradient(135deg, #22c55e, var(--color-accent)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.text-muted { color: var(--color-text-muted); } .text-faded { color: var(--color-text-faded); }
.text-center { text-align: center; } .mono { font-family: var(--font-mono); }
.page { padding: var(--space-xl) 0 var(--space-4xl); }
.section-title { font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; color: var(--color-text-faded); margin: 0 0 var(--space-sm); }

/* Badges & crest */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 10px; border-radius: var(--radius-full); font-size: .72rem; font-weight: 700; background: var(--color-bg-elevated); border: 1px solid var(--color-border); }
.crest { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; font-weight: 900; font-size: .8rem; color: #fff; box-shadow: var(--shadow-sm); flex: none; }

/* Mood */
.mood { font-size: .72rem; font-weight: 700; padding: 2px 8px; border-radius: var(--radius-full); white-space: nowrap; }
.mood--neutral { background: #1f2937; color: #cbd5e1; }
.mood--confident { background: rgba(16,185,129,.18); color: #34d399; }
.mood--inspired { background: rgba(245,217,10,.18); color: var(--color-accent); }
.mood--angry { background: rgba(255,71,87,.18); color: #ff6b78; }
.mood--fearful { background: rgba(123,97,255,.18); color: #a99bff; }

/* Player / squad */
.squad { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--space-sm); }
.player { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-sm) var(--space-md); border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-bg-card); transition: border-color var(--transition-fast); }
.player:hover { border-color: var(--color-border-strong); }
.player__ovr { font-family: var(--font-mono); font-weight: 800; font-size: 1.1rem; width: 34px; text-align: center; color: var(--color-accent); flex: none; }
.player__pos { font-size: .7rem; color: var(--color-text-faded); font-weight: 700; width: 28px; flex: none; }
.player__name { font-weight: 600; }
.player__meta { font-size: .78rem; color: var(--color-text-muted); }

/* Hub de gestão */
.hubnav { display: flex; gap: var(--space-xs); overflow-x: auto; border-bottom: 1px solid var(--color-border); padding-bottom: 2px; }
.hubnav__item { display: inline-flex; align-items: center; gap: 6px; padding: var(--space-sm) var(--space-md); border-radius: var(--radius-md) var(--radius-md) 0 0; font-weight: 600; font-size: .9rem; color: var(--color-text-muted); white-space: nowrap; border-bottom: 2px solid transparent; transition: all var(--transition-fast); }
.hubnav__item:hover { color: var(--color-text); background: var(--color-bg-hover); }
.hubnav__item.is-active { color: var(--color-accent); border-bottom-color: var(--color-accent); }
.hubnav__item.is-disabled { color: var(--color-text-faded); cursor: not-allowed; }
.hubnav__icon { font-size: 1rem; }

/* Linha de posição (escalação por setor) */
.squad-line { margin-bottom: var(--space-lg); }
.squad-line__head { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.squad-line__dot { width: 10px; height: 10px; border-radius: var(--radius-full); background: var(--line, var(--color-primary)); box-shadow: 0 0 8px var(--line); }
.squad-line .player { border-left: 3px solid var(--line, var(--color-border)); }
.player--starter { border-color: var(--color-border-strong); background: linear-gradient(90deg, rgba(245,217,10,.05), var(--color-bg-card)); }
.tag-titular { font-size: .62rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--color-accent); background: rgba(245,217,10,.12); padding: 1px 6px; border-radius: var(--radius-full); margin-left: 6px; vertical-align: middle; }
.poschip { display: inline-flex; align-items: center; padding: 4px 12px; border-radius: var(--radius-full); font-weight: 700; font-size: .8rem; border: 1px solid; }

@media (max-width: 760px) { .hubnav__item span:not(.hubnav__icon) { display: none; } .hubnav__item { padding: var(--space-sm); } }

/* Standings table */
.table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.table th { text-align: left; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--color-text-faded); padding: var(--space-sm); border-bottom: 1px solid var(--color-border); }
.table td { padding: var(--space-sm); border-bottom: 1px solid var(--color-border); }
.table tr.is-me td { background: rgba(245,217,10,.07); }
.table td.num, .table th.num { text-align: center; font-family: var(--font-mono); }

/* Feed (interlude) */
.feed { display: flex; flex-direction: column; gap: var(--space-sm); }
.feed__item { padding: var(--space-sm) var(--space-md); border-left: 3px solid var(--color-primary); background: var(--color-bg-card); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-size: .9rem; }

/* Match result rows */
.result { display: flex; align-items: center; justify-content: space-between; padding: var(--space-sm) var(--space-md); border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-bg-card); }
.result__score { font-family: var(--font-mono); font-weight: 800; font-size: 1.1rem; }
.result--mine { border-color: var(--color-border-strong); }

/* Hero (landing) */
.hero { padding: var(--space-4xl) 0 var(--space-3xl); text-align: center; }
.hero h1 { font-size: clamp(2.4rem, 6vw, 4rem); margin: 0 0 var(--space-md); letter-spacing: -.03em; }
.hero p.lead { font-size: 1.15rem; color: var(--color-text-muted); max-width: 640px; margin: 0 auto var(--space-xl); }
.pillars { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-md); margin-top: var(--space-2xl); text-align: left; }

/* Chat */
.chat { display: flex; flex-direction: column; gap: var(--space-sm); max-height: 420px; overflow-y: auto; padding: var(--space-sm); }
.bubble { max-width: 80%; padding: var(--space-sm) var(--space-md); border-radius: var(--radius-md); font-size: .92rem; }
.bubble--user { align-self: flex-end; background: var(--color-primary); color: #03110a; }
.bubble--player { align-self: flex-start; background: var(--color-bg-elevated); border: 1px solid var(--color-border); }

/* Flash */
.flash { position: fixed; top: var(--space-lg); right: var(--space-lg); padding: var(--space-md) var(--space-lg); border-radius: var(--radius-md); background: var(--color-bg-elevated); border-left: 4px solid var(--color-primary); box-shadow: var(--shadow-lg); z-index: var(--z-toast); max-width: 420px; animation: slideIn 250ms ease; }
.flash--alert { border-left-color: var(--color-danger); }
@keyframes slideIn { from { transform: translateX(120%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

.empty-state { text-align: center; padding: var(--space-3xl) var(--space-lg); color: var(--color-text-muted); }
.empty-state__icon { font-size: 3rem; margin-bottom: var(--space-md); }

@media (max-width: 760px) { .grid--2, .grid--3 { grid-template-columns: 1fr; } }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } }
