/* ============================================================
   The Last Signal - feuille de style unique
   Identite : nuit / signal vert / ambre. Eco-conception :
   un seul fichier CSS, polices systeme (aucun telechargement),
   pas de framework, images optimisees.
   ============================================================ */

:root {
    --nuit:#070A0C; --panneau:#0C1114; --signal:#46E08A; --ambre:#F5A524;
    --clair:#DFE5E2; --attenue:#8A938F; --danger:#e0533e;
    --bordure:rgba(255,255,255,.10); --rayon:10px; --largeur:1100px;
    --mono:ui-monospace,"Cascadia Code","Fira Code",Consolas,monospace;
    --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
* { box-sizing:border-box; margin:0; padding:0; }
body { background:var(--nuit); color:var(--clair); font-family:var(--sans); line-height:1.6; -webkit-font-smoothing:antialiased; }
img { max-width:100%; height:auto; display:block; }
a { color:var(--signal); text-decoration:none; }
a:hover { text-decoration:underline; }
h1,h2,h3 { line-height:1.15; }

.conteneur { width:min(var(--largeur),92vw); margin-inline:auto; }
.lien-evitement { position:absolute; left:-9999px; }
.lien-evitement:focus { left:8px; top:8px; background:var(--signal); color:#000; padding:.5rem; z-index:100; }

/* En-tete */
.entete { position:sticky; top:0; z-index:50; background:rgba(7,10,12,.88); backdrop-filter:blur(8px); border-bottom:1px solid var(--bordure); }
.entete__barre { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.9rem 0; position:relative; }
.logo { font-family:var(--mono); font-weight:700; letter-spacing:.12em; color:var(--clair); font-size:.95rem; }
.logo:hover { color:var(--signal); text-decoration:none; }
.nav { display:flex; gap:1.3rem; align-items:center; }
.nav a { color:var(--clair); font-size:.92rem; }
.nav a:hover { color:var(--signal); text-decoration:none; }
.nav__cta { border:1px solid var(--signal); color:var(--signal); padding:.4rem .9rem; border-radius:999px; }
.burger { display:none; background:none; border:0; color:var(--clair); font-size:1.6rem; cursor:pointer; line-height:1; }

/* Hero */
.hero { padding:5rem 0 3rem; text-align:center;
    background:radial-gradient(600px 320px at 50% -10%,rgba(70,224,138,.12),transparent 60%),
               repeating-linear-gradient(0deg,rgba(255,255,255,.02) 0 1px,transparent 1px 4px); }
.hero--court { padding:3rem 0 1.5rem; }
.hero__kicker { font-family:var(--mono); color:var(--signal); letter-spacing:.18em; font-size:.8rem; margin-bottom:1rem; }
.hero__titre { font-size:clamp(2.2rem,6vw,4rem); letter-spacing:-.01em; text-transform:uppercase; }
.hero__slogan { font-family:var(--mono); color:var(--ambre); margin-top:1rem; font-size:1.1rem; }
.hero__texte { max-width:62ch; margin:1.2rem auto 0; color:var(--attenue); }
.hero__actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2rem; }

/* Boutons */
.bouton { display:inline-block; background:var(--ambre); color:#0A0A0A; font-weight:700; padding:.8rem 1.6rem; border-radius:999px; border:0; cursor:pointer; font-size:1rem; }
.bouton:hover { background:#fff; text-decoration:none; }
.bouton--fantome { background:transparent; color:var(--clair); border:1px solid var(--bordure); }
.bouton--fantome:hover { border-color:var(--signal); color:var(--signal); }
.bouton--petit { padding:.45rem 1rem; font-size:.85rem; }
.bouton--danger { background:var(--danger); color:#fff; }
.bouton--danger:hover { background:#ff6a52; }

/* Blocs */
.bloc { padding:3rem 0; border-top:1px solid var(--bordure); }
.bloc h2 { font-size:clamp(1.5rem,4vw,2.2rem); margin-bottom:1.5rem; text-transform:uppercase; letter-spacing:.02em; }
.bloc--etroit { max-width:560px; margin-inline:auto; }
.bloc--cta { text-align:center; }
.texte-large { max-width:70ch; color:var(--attenue); font-size:1.05rem; }

/* Cartes */
.cartes { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.2rem; }
.carte { background:var(--panneau); border:1px solid var(--bordure); border-left:3px solid var(--signal); border-radius:var(--rayon); padding:1.4rem; }
.carte h3 { margin-bottom:.5rem; }
.carte p { color:var(--attenue); }
.carte__num { font-family:var(--mono); color:var(--signal); font-size:1.4rem; }
.carte__auteur { margin-top:.6rem; color:var(--signal); font-size:.9rem; }
.carte--avis .note { color:var(--ambre); letter-spacing:.1em; margin-bottom:.4rem; }

/* Classement */
.classement { list-style:none; display:grid; gap:.5rem; max-width:520px; }
.classement li { display:flex; justify-content:space-between; gap:1rem; background:var(--panneau); border:1px solid var(--bordure); padding:.7rem 1rem; border-radius:var(--rayon); }
.classement__pts { color:var(--signal); font-family:var(--mono); }

/* Tarifs */
.infos-grille { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:1.2rem; }
.tarif { text-align:center; }
.tarif__prix { font-size:2rem; font-weight:700; color:var(--clair); margin:.5rem 0; }
.tarif__prix span { font-size:.9rem; color:var(--attenue); font-weight:400; }
.tarif--phare { border-color:var(--ambre); border-left-color:var(--ambre); }
.tarif__badge { display:inline-block; background:var(--ambre); color:#000; font-size:.7rem; font-weight:700; text-transform:uppercase; padding:.2rem .6rem; border-radius:999px; margin-bottom:.5rem; }

/* Formulaires */
.form { display:grid; gap:1rem; background:var(--panneau); border:1px solid var(--bordure); padding:1.6rem; border-radius:var(--rayon); }
.form label { display:grid; gap:.35rem; font-size:.9rem; }
.form__ligne { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form input,.form select,.form textarea { width:100%; background:var(--nuit); border:1px solid var(--bordure); color:var(--clair); padding:.65rem .8rem; border-radius:8px; font:inherit; }
.form input:focus,.form select:focus,.form textarea:focus { outline:2px solid var(--signal); outline-offset:1px; border-color:var(--signal); }
.indice { color:var(--attenue); font-weight:400; }
.form__lien { text-align:center; margin-top:1rem; color:var(--attenue); }
.form-inline { display:flex; gap:.5rem; margin-top:.7rem; flex-wrap:wrap; }

/* Messages / encarts */
.flash { background:rgba(70,224,138,.12); border:1px solid var(--signal); padding:.8rem 1rem; border-radius:8px; margin-top:1rem; }
.erreurs { background:rgba(224,83,62,.12); border:1px solid var(--danger); padding:.7rem 1rem .7rem 2.2rem; border-radius:8px; margin-bottom:1rem; }
.erreurs li { color:#ffb3a6; }
.encart,.encart-mini { background:var(--panneau); border:1px solid var(--bordure); border-radius:var(--rayon); padding:1rem 1.2rem; margin-bottom:1rem; }

/* Profil / score */
.profil-grille { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.2rem; }
.carte--score { border-left-color:var(--ambre); text-align:center; }
.score-grand { font-size:3rem; font-weight:800; color:var(--signal); line-height:1; }
.score-grand span { font-size:1rem; color:var(--attenue); font-weight:400; }
.partage { margin-top:1rem; color:var(--attenue); }
.partage a { margin-left:.5rem; }

/* Tableaux (back-office) */
.tableau-scroll { overflow-x:auto; }
.tableau { width:100%; border-collapse:collapse; font-size:.9rem; }
.tableau th,.tableau td { text-align:left; padding:.6rem .7rem; border-bottom:1px solid var(--bordure); white-space:nowrap; }
.tableau th { color:var(--signal); font-family:var(--mono); font-weight:600; font-size:.78rem; text-transform:uppercase; }

/* Pied */
.pied { border-top:1px solid var(--bordure); margin-top:3rem; padding:2.5rem 0; color:var(--attenue); }
.pied__grille { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; align-items:start; }
.pied__logo { font-family:var(--mono); letter-spacing:.12em; color:var(--clair); margin-bottom:.3rem; }
.pied nav { display:grid; gap:.4rem; }
.pied nav a { color:var(--attenue); }
.pied__copy { grid-column:1/-1; border-top:1px solid var(--bordure); padding-top:1rem; font-size:.85rem; }

/* Pages de texte */
.texte-page h2 { margin-top:1.6rem; font-size:1.2rem; }
.texte-page p { color:var(--attenue); margin-top:.4rem; max-width:72ch; }
.note-info { color:var(--attenue); font-size:.9rem; margin-top:.6rem; }

/* Responsive */
@media (max-width:760px) {
    .burger { display:block; }
    .nav { display:none; position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:flex-start; background:var(--panneau); border-bottom:1px solid var(--bordure); padding:1rem; gap:.9rem; }
    .nav--ouvert { display:flex; }
    .form__ligne { grid-template-columns:1fr; }
    .pied__grille { grid-template-columns:1fr; }
}
