@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@700;900&family=Space+Grotesk:wght@400;500;700&family=Fira+Code:wght@400;500&display=swap');

:root {
    --bg: #010103;
    --card-bg: rgba(6, 6, 14, 0.85);
    --neon-green: #39ff14;
    --neon-cyan: #00f0ff;
    --border: rgba(0, 240, 255, 0.2);
    --text: #e0e6ed;
    --muted: #5c6975;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    background-color: var(--bg);
    color: var(--text);
    font-family: 'Space Grotesk', sans-serif;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow-x: hidden;
    position: relative;
    padding: 20px;
}

/* --- FONDS ET EFFETS SATELLITES --- */
.stars-layer { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; }
.star-dot { position: absolute; background: rgba(0, 240, 255, 0.4); border-radius: 50%; }

.radar-grid {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-image: radial-gradient(rgba(57, 255, 20, 0.03) 1px, transparent 0);
    background-size: 30px 30px; z-index: 2; pointer-events: none;
}

.glow-effect {
    position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 600px; height: 600px; background: rgba(0, 240, 255, 0.04);
    filter: blur(120px); border-radius: 50%; z-index: 3; pointer-events: none;
}

.crt-lines {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(rgba(0,0,0,0) 50%, rgba(0,0,0,0.2) 50%); background-size: 100% 4px;
    z-index: 100; pointer-events: none;
}

/* --- CADRE INTERFACE --- */
.osint-container {
    position: relative; z-index: 10; width: 100%; max-width: 950px;
    background: rgba(3, 3, 8, 0.9); border: 1px solid var(--border);
    border-radius: 16px; padding: 40px;
    box-shadow: 0 30px 80px rgba(0,0,0,0.9), inset 0 0 40px rgba(0, 240, 255, 0.03);
    backdrop-filter: blur(20px);
}

/* En-tête */
.osint-header { margin-bottom: 35px; border-bottom: 1px solid rgba(0, 240, 255, 0.1); padding-bottom: 20px; }
.header-top { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.pulse-node { width: 8px; height: 8px; background: var(--neon-green); border-radius: 50%; box-shadow: 0 0 10px var(--neon-green); animation: pulse 1.2s infinite; }
@keyframes pulse { 0%, 100% { transform: scale(0.8); opacity: 0.4; } 50% { transform: scale(1.2); opacity: 1; } }
.console-title { font-family: 'Orbitron', sans-serif; font-size: 11px; color: var(--muted); letter-spacing: 2px; }

h1 { font-family: 'Orbitron', sans-serif; font-size: 36px; font-weight: 900; letter-spacing: 4px; color: #fff; }
.subtitle { font-size: 12px; color: var(--neon-cyan); letter-spacing: 3px; margin-top: 5px; text-transform: uppercase; }

/* --- BARRE DE RECHERCHE TACTIQUE --- */
.search-section { margin-bottom: 35px; }
.search-wrapper {
    display: flex; background: #030308; border: 1px solid rgba(0, 240, 255, 0.3);
    padding: 6px; border-radius: 6px; align-items: center;
}
.search-prefix { font-family: 'Orbitron', sans-serif; font-size: 12px; font-weight: 900; color: var(--neon-cyan); padding: 0 15px; }
input {
    flex-grow: 1; background: transparent; border: none; outline: none;
    color: #fff; font-family: 'Fira Code', monospace; font-size: 13px; padding: 10px;
}
button {
    background: var(--neon-cyan); color: #000; border: none; padding: 12px 24px;
    font-family: 'Orbitron', sans-serif; font-size: 11px; font-weight: 900; letter-spacing: 1px;
    border-radius: 4px; cursor: pointer; transition: 0.2s;
}
button:hover { background: #fff; box-shadow: 0 0 15px var(--neon-cyan); }

/* --- GRILLE DES RESULTATS REAL-TIME --- */
.data-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(400px, 1fr)); gap: 25px; margin-bottom: 35px; }
@media (max-width: 600px) { .data-grid { grid-template-columns: 1fr; } }

.data-card {
    background: var(--card-bg); border: 1px solid rgba(255,255,255,0.05);
    border-radius: 10px; padding: 25px; position: relative; overflow: hidden;
}
.data-card.full-width { grid-column: 1 / -1; }
.card-accent { position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: var(--neon-cyan); }
.data-card:nth-child(2) .card-accent { background: var(--neon-green); }

h3 { font-family: 'Orbitron', sans-serif; font-size: 12px; color: var(--muted); letter-spacing: 1.5px; margin-bottom: 20px; }

.info-group { display: flex; flex-direction: column; gap: 14px; }
.info-row { display: flex; justify-content: space-between; border-bottom: 1px dashed rgba(255,255,255,0.03); padding-bottom: 8px; font-size: 14px; }
.label { color: var(--muted); font-weight: 500; }
.value { font-family: 'Fira Code', monospace; color: #fff; font-weight: 500; }
.value.neon-cyan { color: var(--neon-cyan); text-shadow: 0 0 5px rgba(0,240,255,0.2); }

.hardware-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
@media (max-width: 500px) { .hardware-grid { grid-template-columns: 1fr; } }

/* Effet de chargement */
.loading { opacity: 0.5; font-style: italic; color: var(--neon-cyan) !important; }

/* --- SYSTEM LOG BOX --- */
.console-box {
    background: #020205; border: 1px solid rgba(255,255,255,0.06);
    border-radius: 8px; padding: 15px; font-family: 'Fira Code', monospace; font-size: 12px;
}
.console-header { font-family: 'Orbitron', sans-serif; font-size: 10px; color: var(--muted); margin-bottom: 10px; letter-spacing: 1px; }
.console-content { color: var(--neon-green); max-height: 80px; overflow-y: auto; display: flex; flex-direction: column; gap: 5px; }
.log-entry { line-height: 1.4; }
.log-ts { color: var(--muted); margin-right: 8px; }
