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

/* === Variables CSS globales (reste global — valeurs pour body.theme-summer actif) === */
:root {
  --bg-0: #07090d;
  --bg-1: #0c0f15;
  --bg-2: #131820;
  --bg-3: #1c2330;
  --border: #1e2530;
  --border-strong: #2d3648;
  --text-0: #f0f4f9;
  --text-1: #b4bcc7;
  --text-2: #6a7280;
  --accent: #f59e0b;
  --accent-bright: #fbbf24;
  --accent-dim: rgba(245, 158, 11, 0.3);
  --accent-bg: rgba(245, 158, 11, 0.1);
  --accent-glow: rgba(245, 158, 11, 0.5);
  --green: #00d97e;
  --green-bg: rgba(0, 217, 126, 0.1);
  --green-dim: rgba(0, 217, 126, 0.3);
  --red: #ff4d6d;
  --amber: #fbbf24;
  --font-mono: 'JetBrains Mono', monospace;
}

/* === Scopé body.theme-summer : s'applique UNIQUEMENT quand ce thème est actif === */

body.theme-summer,
body.theme-summer button,
body.theme-summer input,
body.theme-summer select,
body.theme-summer textarea { font-family: var(--font-mono) !important; }

body.theme-summer {
  background:
    radial-gradient(ellipse 60% 40% at 50% 0%, rgba(245, 158, 11, 0.1) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 20% 60%, rgba(251, 191, 36, 0.05) 0%, transparent 60%),
    linear-gradient(180deg, #07090d 0%, #0a0d12 100%) !important;
  background-attachment: fixed !important;
}

body.theme-summer::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(3px 3px at 20% 25%, rgba(251, 191, 36, 0.7), transparent),
    radial-gradient(2px 2px at 70% 45%, rgba(245, 158, 11, 0.6), transparent),
    radial-gradient(2.5px 2.5px at 85% 75%, rgba(251, 191, 36, 0.5), transparent),
    radial-gradient(2px 2px at 30% 90%, rgba(245, 158, 11, 0.6), transparent),
    radial-gradient(2.5px 2.5px at 55% 15%, rgba(251, 191, 36, 0.4), transparent),
    radial-gradient(2px 2px at 12% 60%, rgba(245, 158, 11, 0.5), transparent);
  background-size: 300px 300px;
  background-repeat: repeat;
  animation: fireflies 4s ease-in-out infinite alternate;
}

@keyframes fireflies {
  0%   { opacity: 0.2; transform: translateY(0) translateX(0); }
  50%  { opacity: 0.6; }
  100% { opacity: 0.3; transform: translateY(-30px) translateX(20px); }
}

body.theme-summer .sidebar { background: linear-gradient(180deg, #050709 0%, #0a0d12 100%) !important; border-right: 1px solid var(--border) !important; position: relative; z-index: 1; }
body.theme-summer #main { position: relative; z-index: 1; }
body.theme-summer .nav-item.active { background: linear-gradient(90deg, var(--accent-bg) 0%, transparent 100%) !important; color: var(--accent-bright) !important; border-left: 2px solid var(--accent) !important; padding-left: 10px !important; }
body.theme-summer .btn-primary  { background: linear-gradient(135deg, var(--accent) 0%, #d97706 100%) !important; color: #1c0d00 !important; box-shadow: 0 0 12px var(--accent-glow) !important; font-weight: 700; }
body.theme-summer .btn-start    { background: linear-gradient(135deg, #00d97e 0%, #059669 100%) !important; color: #04110a !important; }
body.theme-summer .btn-stop     { background: linear-gradient(135deg, var(--red) 0%, #dc2626 100%) !important; color: #fff !important; }
body.theme-summer .btn-restart  { background: linear-gradient(135deg, var(--amber) 0%, #d97706 100%) !important; color: #1a0f00 !important; }
body.theme-summer .server-card  { background: linear-gradient(180deg, var(--bg-1) 0%, #080b10 100%) !important; border: 1px solid var(--border) !important; }
body.theme-summer .stat-box     { background: rgba(0, 0, 0, 0.4) !important; border: 1px solid var(--border) !important; }
body.theme-summer input, body.theme-summer select, body.theme-summer textarea, body.theme-summer .form-input { background: var(--bg-0) !important; border: 1px solid var(--border) !important; color: var(--text-0) !important; font-family: var(--font-mono) !important; }
body.theme-summer input:focus, body.theme-summer select:focus { border-color: var(--accent) !important; box-shadow: 0 0 0 1px var(--accent), 0 0 12px var(--accent-glow) !important; }
body.theme-summer .login-logo-mark { color: var(--accent-bright) !important; }
body.theme-summer .login-logo-mark svg { filter: drop-shadow(0 0 12px var(--accent-glow)); }
body.theme-summer .login-logo-version, body.theme-summer .sidebar-logo-version { background: var(--accent-bg) !important; color: var(--accent-bright) !important; border: 1px solid var(--accent-dim) !important; }
body.theme-summer ::selection { background: var(--accent-dim); }

body.theme-summer #login-page,
body.theme-summer .login-page-wrap { background: transparent !important; }

body.theme-summer .login-logo-version { display: inline-block !important; padding: 3px 12px !important; border-radius: 20px !important; box-shadow: none !important; }
body.theme-summer .login-logo { background: none !important; border: none !important; box-shadow: none !important; padding: 24px 0 !important; }

/* Modal de confirmation */
body.theme-summer .gp-confirm-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0, 0, 0, 0.5); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  animation: gp-confirm-fadein 0.15s ease;
}
body.theme-summer .gp-confirm-modal {
  background: rgba(12, 15, 21, 0.92); backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 12px;
  width: 420px; max-width: 92vw;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6), inset 0 1px 0 rgba(255, 255, 255, 0.05);
  animation: gp-confirm-popin 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
  font-family: var(--font-mono); overflow: hidden;
}
body.theme-summer .gp-confirm-header { padding: 20px 24px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 14px; }
body.theme-summer .gp-confirm-icon { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; }
body.theme-summer .gp-confirm-icon.warning { background: rgba(255, 176, 32, 0.15); color: #ffb020; }
body.theme-summer .gp-confirm-icon.danger  { background: rgba(255, 77, 109, 0.15); color: #ff4d6d; }
body.theme-summer .gp-confirm-title { font-size: 16px; font-weight: 700; color: var(--text-0); }
body.theme-summer .gp-confirm-body { padding: 20px 24px; color: var(--text-1); font-size: 13px; line-height: 1.6; }
body.theme-summer .gp-confirm-body strong { color: var(--text-0); }
body.theme-summer .gp-confirm-actions { padding: 16px 24px; border-top: 1px solid var(--border); display: flex; gap: 10px; justify-content: flex-end; background: rgba(0, 0, 0, 0.2); }
body.theme-summer .gp-confirm-btn { padding: 8px 16px; border-radius: 6px; font-family: var(--font-mono); font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.15s ease; border: 1px solid var(--border); }
body.theme-summer .gp-confirm-btn-cancel { background: var(--bg-2); color: var(--text-1); }
body.theme-summer .gp-confirm-btn-cancel:hover { background: var(--bg-3); color: var(--text-0); }
body.theme-summer .gp-confirm-btn-confirm-stop { background: linear-gradient(135deg, var(--red) 0%, #dc2626 100%); color: #fff; border: 1px solid var(--red); }
body.theme-summer .gp-confirm-btn-confirm-restart { background: linear-gradient(135deg, var(--amber) 0%, #d97706 100%); color: #1a0f00; border: 1px solid var(--amber); }
body.theme-summer .gp-confirm-btn-confirm-stop:hover,
body.theme-summer .gp-confirm-btn-confirm-restart:hover { transform: translateY(-1px); filter: brightness(1.1); }

@keyframes gp-confirm-fadein { from { opacity: 0; } to { opacity: 1; } }
@keyframes gp-confirm-popin  { from { opacity: 0; transform: scale(0.9) translateY(-20px); } to { opacity: 1; transform: scale(1) translateY(0); } }
