/* =============================================
   Stride Fotbal — MINIMAL CSS
   Doar ce e imposibil de facut cu Tailwind.
   ============================================= */

/* FONT */
body { font-family: 'Plus Jakarta Sans', system-ui, sans-serif; }

/* Animatii */
@keyframes slideDown {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes spin    { to { transform: rotate(360deg); } }
@keyframes pulse   { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
@keyframes fadeIn  { from{opacity:0;transform:translateY(-3px)} to{opacity:1;transform:translateY(0)} }

.alert    { animation: slideDown .3s ease; }
.spinner  { animation: spin .7s linear infinite; }
.live-dot { animation: pulse 1.2s ease infinite; }
.log-item { animation: fadeIn .25s ease; }

/* Auth tabs toggle */
.auth-form        { display: none; }
.auth-form.active { display: block; }

/* Auth tabs JS active */
.auth-tab.active { background: #fff; color: #111827; box-shadow: 0 1px 3px rgba(0,0,0,.08); border-radius: 6px; }

/* Filtru tabs JS active */
.filtru-tab { cursor: pointer; display: inline-flex; align-items: center; gap: 4px; padding: 6px 14px; border-radius: 8px; font-size: 13px; font-weight: 600; color: rgba(248,243,217,0.45); background: transparent; border: none; transition: all .15s; white-space: nowrap; }
.filtru-tab:hover  { color: rgba(248,243,217,0.8); }
/* Schimbat in ROZ */
.filtru-tab.active { background: #D62828; color: #fff; }

/* Tabel clasament — grid custom */
.clasament-row {
    display: grid;
    grid-template-columns: 44px 1fr repeat(3, 58px);
    align-items: center; gap: 8px;
    padding: 11px 14px;
    transition: background 150ms;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    color: inherit; text-decoration: none;
}
.clasament-row:last-child { border-bottom: none; }
.clasament-row:hover { background: rgba(255,255,255,0.04); }
/* Rândul utilizatorului curent */
.clasament-row.my-row { background: rgba(214,40,40,0.06); }
.clasament-row-header { background: rgba(255,255,255,0.04); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(248,243,217,0.35); }
.clasament-row-header:hover { background: rgba(255,255,255,0.04); }
@media (min-width: 640px) {
    .clasament-row { grid-template-columns: 44px 1fr repeat(4, 70px); }
}

/* Pozitie badge */
.pozitie-nr { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; border-radius: 8px; background: rgba(255,255,255,0.08); color: rgba(248,243,217,0.5); }
/* Locul 1 - fundal Galben, text negru pentru contrast */
.pozitie-nr.top1 { background: #D62828; color: #000; }
.pozitie-nr.top2 { background: rgba(255,255,255,0.08); color: rgba(248,243,217,0.5); }
.pozitie-nr.top3 { background: rgba(234,88,12,0.15); color: #fb923c; }

/* Clasament value cell */
.clasament-value { text-align: center; font-size: 13px; font-weight: 600; color: rgba(248,243,217,0.65); }
/* Highlight valoare in ROZ */
.clasament-value.highlight { color: #D62828; font-weight: 700; }

/* Clasament jucator cell */
.clasament-jucator { display: flex; align-items: center; gap: 8px; min-width: 0; }
.clasament-jucator-info { flex: 1; min-width: 0; }
.clasament-jucator-name { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #f8f3d9; }
.clasament-jucator-sub { font-size: 11px; color: rgba(248,243,217,0.35); }

/* Bottom nav safe area */
.bottom-nav { padding-bottom: env(safe-area-inset-bottom); }

/* Avatar */
.avatar-initiale { border-radius: 50%; display:flex; align-items:center; justify-content:center; font-weight:700; color:#fff; flex-shrink:0; }
.avatar { border-radius:50%; object-fit:cover; flex-shrink:0; }

/* Podium bars */
.podium { display: flex; align-items: flex-end; justify-content: center; gap: 12px; }
.podium-item { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.podium-item:nth-child(1) { order: 2; }
.podium-item:nth-child(2) { order: 1; }
.podium-item:nth-child(3) { order: 3; }
.podium-bar { border-radius: 6px 6px 0 0; display:flex; align-items:center; justify-content:center; font-size:18px; width: 100%; }
/* Locul 1 - Glow Galben */
.podium-item:nth-child(1) .podium-bar { height:72px; background:linear-gradient(to top,rgba(214,40,40,.15),transparent); color:#D62828; }
.podium-item:nth-child(2) .podium-bar { height:50px; background:linear-gradient(to top,rgba(148,163,184,.1),transparent); color:#94a3b8; }
.podium-item:nth-child(3) .podium-bar { height:38px; background:linear-gradient(to top,rgba(205,124,78,.1),transparent); color:#cd7c4e; }

/* Podium content */
.podium-name { font-size: 12px; font-weight: 700; text-align: center; color: #f8f3d9; }
.podium-puncte { font-size: 11px; color: rgba(248,243,217,0.4); font-weight: 600; }
.podium-avatar { position: relative; }
/* Coroana locului 1 - Galbena */
.podium-crown { position: absolute; top: -18px; left: 50%; transform: translateX(-50%); font-size: 16px; color: #D62828; }

/* Achievement locked */
.achievement-locked { opacity:.35; filter:grayscale(1); }

/* Progress bar width e setat inline din PHP */
.progress-fill { transition: width .5s ease; }

/* Hide mobile */
.hide-mobile { display:none !important; }
@media (min-width:640px) { .hide-mobile { display:block !important; } }

/* Page bottom padding pe mobile */
@media (max-width:767px) { body { padding-bottom: 72px; } }

/* Stars rating input - folosesc GALBEN (#D62828) */
.stars-input { display: flex; gap: 4px; }
.star-btn { font-size: 22px; color: #d1d5db; background: none; border: none; cursor: pointer; transition: color .1s; padding: 0; line-height: 1; }
.star-btn.active { color: #D62828; }
.star-btn:hover { color: #D62828; }

/* Modal overlay */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 1000; align-items: flex-end; justify-content: center; padding: 0; }
.modal-overlay.open { display: flex; }
@media (min-width: 640px) {
    .modal-overlay { align-items: center; padding: 16px; }
}
.modal { background: #1a1c1a; border: 1px solid rgba(255,255,255,0.08); border-radius: 24px 24px 0 0; width: 100%; max-height: 90vh; overflow-y: auto; padding: 24px; box-shadow: 0 -4px 40px rgba(0,0,0,.6); color: #f8f3d9; }
@media (min-width: 640px) {
    .modal { border-radius: 24px; max-width: 480px; }
}

/* Flash/notification container */
.flash-container { pointer-events: none; display: flex; flex-direction: column; gap: 8px; }

/* Arbitru timer */
/* Timerul activ este acum ROZ */
.arb-timer { font-size: 36px; font-weight: 900; font-variant-numeric: tabular-nums; color: #D62828; min-width: 100px; text-align: center; line-height: 1; }
/* Pentru timer pe pauza am schimbat din alb (pt dark mode) in negru cu transparenta (pt light mode) */
.arb-timer.paused  { color: rgba(0,0,0,0.3); }
.arb-timer.overtime { color: #f87171; animation: pulse 1s ease infinite; }

/* Live badge - Am facut badge-ul ROZ pentru vizibilitate mare */
.live-badge { display:inline-flex;align-items:center;gap:5px;background:rgba(214,40,40,0.1);border:1px solid rgba(214,40,40,0.25);color:#D62828;font-size:10px;font-weight:700;padding:3px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.06em; }

/* Arbitru action buttons - modificate pentru Light Mode */
.btn-actiune { display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 2px;border-radius:8px;border:1px solid rgba(0,0,0,0.05);background:rgba(0,0,0,0.03);cursor:pointer;transition:all .12s;font-size:14px;color:rgba(0,0,0,0.6);min-height:44px; }
.btn-actiune span { font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;line-height:1;color:rgba(0,0,0,0.4); }
.btn-actiune:hover { transform:scale(1.06); background:rgba(0,0,0,0.06); color:#111827; }
.btn-actiune:active { transform:scale(.93); }
/* Hover-ul la butonul de gol a devenit ROZ */
.btn-actiune.btn-gol:hover    { background:rgba(214,40,40,.1);border-color:rgba(214,40,40,.3); }
.btn-actiune.btn-galben:hover { background:rgba(214,40,40,.15);border-color:rgba(214,40,40,.4); }
.btn-actiune.btn-rosu:hover   { background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.4); }

/* Log item - modificate pentru Light Mode */
.log-item { display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid rgba(0,0,0,0.05);font-size:13px;animation:fadeIn .25s ease; }
.log-item:last-child { border-bottom:none; }
/* Minutul evenimentului e in ROZ */
.log-minut { font-size:10px;font-weight:700;color:#D62828;min-width:26px;text-align:right; }
.log-icon { font-size:15px; }
.log-text { flex:1;color:rgba(0,0,0,0.6);font-size:12px; }
.log-text strong { color:rgba(0,0,0,0.9);font-weight:600; }
.log-echipa-dot { width:7px;height:7px;border-radius:50%;flex-shrink:0; }

/* Swipe to register */
.swipe-track { position:relative; height:56px; border-radius:28px; overflow:hidden; cursor:grab; user-select:none; -webkit-user-select:none; background:rgba(214,40,40,0.1); border:1.5px solid rgba(214,40,40,0.25); }
.swipe-track:active { cursor:grabbing; }
.swipe-text { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:rgba(214,40,40,0.6); letter-spacing:0.02em; pointer-events:none; transition:opacity .2s; }
.swipe-thumb { position:absolute; left:4px; top:4px; width:48px; height:48px; background:linear-gradient(135deg,#D62828,#a01818); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; box-shadow:0 4px 16px rgba(214,40,40,0.45); will-change:transform; }
.swipe-track.swipe-done { background:rgba(214,40,40,0.18); border-color:rgba(214,40,40,0.5); }
.swipe-track.swipe-done .swipe-text { color:#D62828; }
