/* ============================================
   The Lost Ark — Frontend CSS v2.0
   Tema: Dark Fantasy / Gaming Premium
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Rajdhani:wght@400;500;600;700&display=swap');

:root {
    --tla-gold: #d4af37;
    --tla-gold-light: #f0d060;
    --tla-gold-dark: #9a7b1a;
    --tla-bg-dark: #0c0e12;
    --tla-bg-card: #12151c;
    --tla-bg-card-hover: #181c26;
    --tla-text: #c9c2b4;
    --tla-text-dim: #7a7468;
    --tla-green: #34d399;
    --tla-red: #ef4444;
    --tla-border: rgba(212, 175, 55, 0.15);
    --tla-font-display: 'Cinzel', Georgia, serif;
    --tla-font-body: 'Rajdhani', 'Segoe UI', sans-serif;
}

/* === WIDGET STATO SERVER === */
.tla-server-widget {
    font-family: var(--tla-font-body);
    background: #080a10;
    color: var(--tla-text);
    border-radius: 20px;
    padding: 0;
    border: 1px solid rgba(60, 180, 255, 0.1);
    box-shadow: 0 0 80px rgba(60, 180, 255, 0.05), 0 20px 60px rgba(0,0,0,0.6);
    position: relative;
    overflow: hidden;
}

/* Gradiente di sfondo sottile */
.tla-server-widget::before {
    content: "";
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 15% 10%, rgba(60,180,255,0.07) 0%, transparent 50%),
        radial-gradient(ellipse at 85% 90%, rgba(60,180,255,0.05) 0%, transparent 50%),
        radial-gradient(ellipse at 50% 50%, rgba(20,40,80,0.3) 0%, transparent 70%);
    pointer-events: none; z-index: 0;
}

/* Particelle luminose fluttuanti */
.tla-server-widget::after {
    content: "";
    position: absolute; inset: 0;
    background-image:
        radial-gradient(3px 3px at 8% 15%, rgba(60,200,255,0.9), transparent),
        radial-gradient(2px 2px at 15% 65%, rgba(60,200,255,0.5), transparent),
        radial-gradient(4px 4px at 25% 85%, rgba(80,200,255,0.8), transparent),
        radial-gradient(2px 2px at 35% 30%, rgba(60,200,255,0.4), transparent),
        radial-gradient(3px 3px at 45% 70%, rgba(60,200,255,0.7), transparent),
        radial-gradient(2px 2px at 55% 10%, rgba(100,220,255,0.5), transparent),
        radial-gradient(4px 4px at 65% 50%, rgba(60,200,255,0.9), transparent),
        radial-gradient(2px 2px at 72% 80%, rgba(60,200,255,0.4), transparent),
        radial-gradient(3px 3px at 82% 20%, rgba(80,200,255,0.7), transparent),
        radial-gradient(2px 2px at 90% 60%, rgba(60,200,255,0.5), transparent),
        radial-gradient(3px 3px at 95% 35%, rgba(100,220,255,0.6), transparent),
        radial-gradient(2px 2px at 5% 45%, rgba(60,200,255,0.4), transparent),
        radial-gradient(3px 3px at 50% 90%, rgba(60,200,255,0.7), transparent),
        radial-gradient(2px 2px at 78% 5%, rgba(100,220,255,0.5), transparent),
        radial-gradient(4px 4px at 40% 45%, rgba(60,200,255,0.6), transparent);
    pointer-events: none; z-index: 0;
    animation: tla-particles-float 40s ease-in-out infinite alternate;
}

@keyframes tla-particles-float {
    0% { transform: translateY(0) translateX(0); opacity: 0.5; }
    25% { transform: translateY(-3px) translateX(2px); opacity: 0.7; }
    50% { transform: translateY(-1px) translateX(-1px); opacity: 0.4; }
    75% { transform: translateY(-4px) translateX(3px); opacity: 0.6; }
    100% { transform: translateY(-2px) translateX(-2px); opacity: 0.5; }
}

/* Particelle DOM iniettate via JS */
.tla-server-widget .tla-particle,
.tla-leaderboard .tla-particle {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}
.tla-particle.p-lg {
    width: 8px; height: 8px;
    background: rgba(60,200,255,0.6);
    box-shadow: 0 0 16px 6px rgba(60,200,255,0.3), 0 0 40px 12px rgba(60,200,255,0.1);
    filter: blur(1px);
}
.tla-particle.p-md {
    width: 5px; height: 5px;
    background: rgba(80,210,255,0.5);
    box-shadow: 0 0 12px 4px rgba(60,200,255,0.25), 0 0 30px 8px rgba(60,200,255,0.08);
    filter: blur(0.5px);
}
.tla-particle.p-sm {
    width: 3px; height: 3px;
    background: rgba(100,220,255,0.4);
    box-shadow: 0 0 8px 3px rgba(60,200,255,0.15);
}

@keyframes tla-particle-drift {
    0%, 100% { transform: translateY(0) translateX(0); opacity: 0.2; }
    25% { transform: translateY(-6px) translateX(3px); opacity: 0.7; }
    50% { transform: translateY(-2px) translateX(-2px); opacity: 0.3; }
    75% { transform: translateY(-8px) translateX(4px); opacity: 0.6; }
}

.tla-server-widget > * { position: relative; z-index: 1; }

/* Header */
.tla-widget-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 28px 32px 20px; flex-wrap: wrap; gap: 12px;
    border-bottom: 1px solid rgba(60,180,255,0.1);
}

.tla-widget-title {
    font-family: var(--tla-font-display);
    font-size: 1.7em; font-weight: 700; margin: 0;
    letter-spacing: 2px; text-transform: uppercase;
    background: linear-gradient(135deg, var(--tla-gold-light), var(--tla-gold), var(--tla-gold-dark));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: drop-shadow(0 2px 4px rgba(212,175,55,0.3));
}

/* Badge stato */
.tla-status-badge {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 20px; border-radius: 50px;
    font-family: var(--tla-font-body); font-weight: 700; font-size: 0.85em;
    text-transform: uppercase; letter-spacing: 2px;
}
.tla-status-badge.tla-online {
    background: rgba(52,211,153,0.1); border: 1px solid rgba(52,211,153,0.3);
    color: var(--tla-green); box-shadow: 0 0 20px rgba(52,211,153,0.15);
}
.tla-status-badge.tla-offline {
    background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.3);
    color: var(--tla-red); box-shadow: 0 0 20px rgba(239,68,68,0.15);
}

.tla-status-dot { width: 8px; height: 8px; border-radius: 50%; position: relative; }
.tla-online .tla-status-dot { background: var(--tla-green); box-shadow: 0 0 8px var(--tla-green); }
.tla-online .tla-status-dot::after {
    content: ""; position: absolute; inset: -4px; border-radius: 50%;
    border: 1px solid var(--tla-green);
    animation: tla-ping 2s cubic-bezier(0, 0, 0.2, 1) infinite;
}
.tla-offline .tla-status-dot { background: var(--tla-red); box-shadow: 0 0 8px var(--tla-red); }
@keyframes tla-ping { 0% { transform: scale(1); opacity: 0.8; } 75%,100% { transform: scale(2.5); opacity: 0; } }

/* Stats */
.tla-widget-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 0; border-bottom: 1px solid rgba(60,180,255,0.1);
}
.tla-stat {
    padding: 24px 20px; text-align: center;
    position: relative; transition: background 0.3s;
}
.tla-stat:not(:last-child)::after {
    content: ""; position: absolute; right: 0; top: 20%; bottom: 20%;
    width: 1px; background: rgba(60,180,255,0.1);
}
.tla-stat:hover { background: rgba(60,180,255,0.03); }
.tla-stat-icon { font-size: 1.4em; display: block; margin-bottom: 8px; }
.tla-stat-value {
    display: block; font-family: var(--tla-font-display);
    font-size: 1.3em; font-weight: 700; color: #fff; letter-spacing: 1px;
}
.tla-stat-label {
    display: block; font-size: 0.7em; color: var(--tla-text-dim);
    text-transform: uppercase; letter-spacing: 2px; margin-top: 4px; font-weight: 600;
}

/* IP */
.tla-connect-info { text-align: center; padding: 16px 32px; border-bottom: 1px solid rgba(60,180,255,0.1); }
.tla-connect-ip {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(0,0,0,0.3); padding: 8px 20px; border-radius: 8px;
    font-family: 'Courier New', monospace; font-size: 0.9em;
    color: var(--tla-text-dim); cursor: pointer;
    border: 1px solid transparent; transition: all 0.3s; letter-spacing: 1px;
}
.tla-connect-ip:hover { border-color: rgba(60,200,255,0.4); color: #5cc8ff; background: rgba(60,180,255,0.05); }

.tla-last-update {
    text-align: center; padding: 14px; color: var(--tla-text-dim);
    font-size: 0.78em; letter-spacing: 1px; text-transform: uppercase;
}

/* === RATES GRID === */
.tla-rates-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px; font-family: var(--tla-font-body);
}

.tla-rate-card {
    background: rgba(10,15,25,0.8);
    border: 1px solid rgba(60,180,255,0.12); border-radius: 16px;
    padding: 24px 16px; text-align: center;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative; overflow: hidden;
}
.tla-rate-card::before {
    content: ""; position: absolute; top: 0; left: 20%; right: 20%;
    height: 1px; background: linear-gradient(90deg, transparent, rgba(60,200,255,0.6), transparent);
    opacity: 0; transition: opacity 0.4s;
}
.tla-rate-card:hover {
    transform: translateY(-6px); border-color: rgba(60,200,255,0.35);
    background: rgba(15,20,35,0.9);
    box-shadow: 0 20px 40px rgba(0,0,0,0.3), 0 0 30px rgba(60,180,255,0.08);
}
.tla-rate-card:hover::before { opacity: 1; }

.tla-rate-icon { font-size: 1.8em; display: block; margin-bottom: 10px; }
.tla-rate-value {
    display: block; font-family: var(--tla-font-display);
    font-size: 2.2em; font-weight: 900; letter-spacing: 1px; line-height: 1.1; margin: 4px 0 8px;
    background: linear-gradient(180deg, #fff 20%, #5cc8ff 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.tla-rate-label {
    display: block; font-size: 0.7em; color: var(--tla-text-dim);
    text-transform: uppercase; letter-spacing: 2px; font-weight: 600;
}

/* === LEADERBOARD === */
.tla-leaderboard {
    font-family: var(--tla-font-body);
    background: #080a10;
    border: 1px solid rgba(60,180,255,0.1); border-radius: 20px;
    padding: 28px; color: var(--tla-text); overflow: hidden;
    position: relative;
}
.tla-lb-summary {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 12px; margin-bottom: 24px;
}
.tla-lb-stat {
    background: rgba(10,15,25,0.8); border: 1px solid rgba(60,180,255,0.12);
    border-radius: 12px; padding: 16px; text-align: center;
}
.tla-lb-stat-val {
    display: block; font-family: var(--tla-font-display);
    font-size: 1.8em; font-weight: 700; color: #5cc8ff;
}
.tla-lb-stat-lbl {
    display: block; font-size: 0.68em; color: var(--tla-text-dim);
    text-transform: uppercase; letter-spacing: 1.5px; margin-top: 2px; font-weight: 600;
}

.tla-lb-table { display: flex; flex-direction: column; gap: 4px; }
.tla-lb-row {
    display: flex; align-items: center; gap: 16px;
    padding: 14px 18px; background: var(--tla-bg-card);
    border-radius: 12px; border: 1px solid transparent; transition: all 0.3s;
}
.tla-lb-row:hover { background: var(--tla-bg-card-hover); border-color: rgba(60,180,255,0.1); transform: translateX(4px); }
.tla-lb-row.tla-lb-top:nth-child(1) { border-left: 3px solid #ffd700; background: linear-gradient(90deg, rgba(255,215,0,0.06), transparent 30%); }
.tla-lb-row.tla-lb-top:nth-child(2) { border-left: 3px solid #c0c0c0; background: linear-gradient(90deg, rgba(192,192,192,0.04), transparent 30%); }
.tla-lb-row.tla-lb-top:nth-child(3) { border-left: 3px solid #cd7f32; background: linear-gradient(90deg, rgba(205,127,50,0.04), transparent 30%); }

.tla-lb-rank { font-size: 1.2em; min-width: 40px; text-align: center; font-weight: 700; }
.tla-lb-name { flex: 1; font-weight: 600; color: #e8e0d4; font-size: 1.05em; }
.tla-lb-time { font-family: var(--tla-font-display); color: #5cc8ff; font-weight: 700; min-width: 80px; text-align: right; }
.tla-lb-seen { color: var(--tla-text-dim); font-size: 0.8em; min-width: 100px; text-align: right; }
.tla-lb-empty { text-align: center; color: var(--tla-text-dim); padding: 40px 20px; font-style: italic; }

/* === FORM WHITELIST === */
.tla-wl-form-wrap { max-width: 480px; margin: 0 auto; font-family: var(--tla-font-body); }
.tla-wl-form {
    background: rgba(10,15,25,0.8); padding: 28px;
    border-radius: 16px; border: 1px solid rgba(60,180,255,0.12);
}
.tla-wl-field { margin-bottom: 14px; }
.tla-input {
    width: 100%; padding: 14px 18px;
    border: 1px solid rgba(60,180,255,0.12); border-radius: 10px;
    background: rgba(0,0,0,0.3); color: var(--tla-text);
    font-family: var(--tla-font-body); font-size: 15px; font-weight: 500;
    box-sizing: border-box; transition: all 0.3s; letter-spacing: 0.5px;
}
.tla-input:focus {
    border-color: rgba(60,200,255,0.5); outline: none;
    box-shadow: 0 0 0 3px rgba(60,180,255,0.1), 0 0 20px rgba(60,180,255,0.05);
    background: rgba(0,0,0,0.5);
}
.tla-input::placeholder { color: var(--tla-text-dim); font-weight: 400; }

.tla-button {
    display: inline-block; padding: 14px 28px; border: none; border-radius: 10px;
    font-family: var(--tla-font-body); font-weight: 700; font-size: 15px;
    cursor: pointer; transition: all 0.3s; text-transform: uppercase; letter-spacing: 2px;
}
.tla-button-primary {
    background: linear-gradient(135deg, #1a6fa0, #3cb8e8);
    color: #fff; width: 100%; box-shadow: 0 4px 20px rgba(60,180,255,0.2);
}
.tla-button-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(60,180,255,0.35);
    background: linear-gradient(135deg, #2580b5, #5cc8ff);
}

.tla-wl-result { margin-top: 14px; padding: 14px; border-radius: 10px; text-align: center; font-weight: 600; }
.tla-wl-result.success { background: rgba(52,211,153,0.1); border: 1px solid rgba(52,211,153,0.3); color: var(--tla-green); }
.tla-wl-result.error { background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.3); color: var(--tla-red); }

.tla-inline-count { font-weight: 700; font-family: var(--tla-font-body); letter-spacing: 1px; }

/* === RESPONSIVE === */
@media (max-width: 600px) {
    .tla-server-widget { border-radius: 14px; }
    .tla-widget-header { padding: 20px 20px 16px; }
    .tla-widget-title { font-size: 1.2em; letter-spacing: 1px; }
    .tla-widget-stats { grid-template-columns: 1fr; }
    .tla-stat:not(:last-child)::after { display: none; }
    .tla-stat:not(:last-child) { border-bottom: 1px solid rgba(60,180,255,0.1); }
    .tla-rates-grid { grid-template-columns: repeat(2, 1fr); }
    .tla-rate-value { font-size: 1.8em; }
    .tla-lb-row { flex-wrap: wrap; gap: 8px; }
    .tla-lb-seen { min-width: 100%; text-align: left; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
