/* ========= THEME (Cyber Dev + Glass) ========= */
:root{
  --bg-0:#080c19;
  --bg-1:#0d1428;
  --grid:#0e1a35;
  --glass:rgba(255,255,255,.06);
  --glass-2:rgba(0,245,212,.06);
  --border:rgba(0,245,212,.25);
  --ink:#E6FFF9;
  --muted:#8CEAD9;
  --accent:#00F5D4;
  --accent-2:#7CFF6B;
  --shadow:0 10px 40px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0; color:var(--ink);
  font:16px/1.6 ui-monospace,"SFMono-Regular",Menlo,Consolas;
  background:
    radial-gradient(80vmax 60vmax at 15% -10%, #10234a 0, transparent 60%),
    radial-gradient(70vmax 60vmax at 100% 0%, #061a2a 0, transparent 55%),
    linear-gradient(180deg, var(--bg-0), var(--bg-1));
  overflow-x:hidden;
}

/* GRID BACKGROUND */
.grid-bg::before{
  content:"";
  position:fixed; inset:0; pointer-events:none;
  background:
    linear-gradient(0deg, transparent 24px, var(--grid) 25px),
    linear-gradient(90deg, transparent 24px, var(--grid) 25px);
  background-size:25px 25px;
  opacity:.25;
  mask-image: radial-gradient(70vmax 50vmax at 50% 40%, black 40%, transparent 90%);
}

/* ========= NAV ========= */
.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px) saturate(120%);
  background:linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.25));
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:1100px;margin:0 auto;
  padding:12px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.badge{
  width:34px;height:34px;display:grid;place-items:center;
  border-radius:8px;font-weight:900;color:#03201a;
  background: radial-gradient(120% 120% at 30% 20%, var(--accent) 0, var(--accent-2) 60%);
  box-shadow:0 0 14px rgba(0,245,212,.55), inset 0 0 10px rgba(255,255,255,.25);
}
.nav a{color:var(--ink);text-decoration:none;opacity:.9;transition:.15s ease}
.nav a:hover{text-shadow:0 0 8px rgba(0,245,212,.6);opacity:1}
.links{display:flex;gap:18px}

/* ========= LAYOUT ========= */
.wrap{max-width:1100px;margin:0 auto;padding:28px 20px}
h1{margin:.2rem 0 .6rem;font-size:clamp(26px,4vw,40px)}
.muted{color:var(--muted)}

/* ========= HERO ========= */
.hero{
  display:grid;gap:26px;align-items:start;
  grid-template-columns:1.05fr .95fr;
  margin-top:30px;
}
.card{
  background:linear-gradient(180deg,var(--glass),var(--glass-2));
  border:1px solid var(--border);
  border-radius:16px;box-shadow:var(--shadow);
}
.panel{padding:28px}

/* Intro */
.kicker{color:var(--muted);font-weight:700}
.lead{opacity:.95}
.highlight{
  background:linear-gradient(90deg, rgba(0,245,212,.18), rgba(124,255,107,.18));
  padding:.1em .35em;border-radius:.35rem;
  box-shadow:inset 0 0 0 1px rgba(0,245,212,.25);
}
.cta{display:flex;gap:12px;margin-top:18px}
.btn{
  display:inline-flex;align-items:center;
  gap:8px;padding:12px 16px;
  border-radius:12px;border:1px solid var(--border);
  text-decoration:none;color:var(--ink);
  background:rgba(255,255,255,.04);
  transition:.15s ease;
}
.btn:hover{box-shadow:0 0 0 3px rgba(0,245,212,.2)}
.btn.primary{background:var(--accent);color:#05201b;font-weight:800;border-color:transparent}
.meta{margin-top:14px;display:flex;gap:12px;flex-wrap:wrap}
.pill{
  border:1px solid var(--border);color:var(--muted);
  background:rgba(0,245,212,.07);padding:6px 10px;border-radius:999px;
}

/* ========= TERMINAL ========= */
.terminal{position:relative;height:auto;display:flex;flex-direction:column;border-radius:16px;overflow:hidden}
.term-top{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px 8px;border-bottom:1px solid var(--border);
  background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.15));
}
.dot{width:10px;height:10px;border-radius:50%}
.dot:nth-child(1){background:#ff6b6b}
.dot:nth-child(2){background:#ffd93d}
.dot:nth-child(3){background:#51ffa6}
.term-title{margin-left:6px;color:var(--muted);font-weight:600}

.term-body{
  padding:8px 22px 26px;
  font-size:15.5px;line-height:1.6;
  overflow-y:auto;flex:1;
}
.entry{
  margin:12px 0 18px;padding-bottom:14px;
  border-bottom:1px dashed rgba(0,245,212,.12);
}
.entry:first-child{margin-top:0!important}
.cmd{
  white-space:pre;display:flex;gap:8px;
  color:#90ffe1;font-weight:600;margin:0 0 6px;
}
.cmd::before{
  content:"›";color:var(--accent);font-weight:900;opacity:.9;
}
.prompt{color:#7cffcf;font-weight:700}
.out{
  white-space:pre-wrap;margin:0;padding-left:28px;color:#c8fff1;opacity:.95;
}
.cursor{
  width:9px;height:1.1em;display:inline-block;
  background:var(--accent);box-shadow:0 0 8px var(--accent);
  margin-left:4px;animation:blink .9s steps(1,end) infinite;
}
@keyframes blink{50%{opacity:0}}

/* ========= PROJETS ========= */
.grid{display:grid;gap:18px;margin-top:22px;grid-template-columns:repeat(3,1fr)}
.card h3{margin:.2rem 0 .4rem}
.tag{
  display:inline-block;border:1px solid var(--border);
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.05);color:#b9fff1;font-weight:600;
}
.soon{font-style:italic}

/* ========= BANNIÈRE WIP ========= */
.wip{
  display:flex;align-items:center;gap:12px;
  background:linear-gradient(180deg,var(--glass),var(--glass-2));
  border:1px solid var(--border);
  border-radius:14px;padding:16px 18px;box-shadow:var(--shadow);
}
.wip .dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 10px var(--accent);
  animation:pulse 1.2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.35);opacity:.7}
}

/* ========= FOOTER ========= */
footer{
  text-align:center;padding:36px 0;margin-top:44px;
  border-top:1px solid var(--border);color:var(--muted);
}

/* ========= RESPONSIVE ========= */
@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}

/* ===== Titres pages ===== */
.page-title{
  font-size: clamp(30px, 5vw, 48px);
  font-weight: 900;
  letter-spacing: .4px;
  margin: .2rem 0 18px;
  text-shadow: 0 0 22px rgba(0,245,212,.12);
}

/* ===== Grille des projets ===== */
.projects .cards-grid{
  margin-top: 22px;
  gap: 22px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

/* ===== Cartes projets ===== */
.card.project{
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid rgba(0,245,212,.22);
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(0,245,212,.08) 0, rgba(0,245,212,0) 55%),
    linear-gradient(180deg, var(--glass), var(--glass-2));
  box-shadow:
    0 8px 30px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(255,255,255,.04);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  display:flex; flex-direction:column; justify-content:space-between;
  min-height: 170px;
}

.card.project:hover{
  transform: translateY(-3px);
  border-color: rgba(0,245,212,.38);
  box-shadow:
    0 16px 42px rgba(0,0,0,.45),
    0 0 24px rgba(0,245,212,.08);
}

.card.project h3{
  margin:.2rem 0 .45rem;
  font-size: 18.5px;
  font-weight: 800;
  letter-spacing:.2px;
}

.card.project .desc{
  color: var(--muted);
  margin: 0 0 14px;
  font-style: italic;
}

/* ===== Tag techno (pill) ===== */
.tag{
  display:inline-block;
  border:1px solid rgba(0,245,212,.28);
  padding:7px 12px;
  border-radius: 999px;
  color:#b9fff1;
  background:
    linear-gradient(180deg, rgba(0,245,212,.10), rgba(0,245,212,.06));
  font-weight: 800;
  letter-spacing:.2px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.05);
}

/* ===== Bannière WIP (un peu plus classe) ===== */
.wip{
  margin-bottom: 16px;
  border-radius: 16px;
  border: 1px solid rgba(0,245,212,.25);
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,245,212,.06));
}
.wip strong{
  font-weight: 900;
  letter-spacing: .3px;
}

/* ===== Petites retouches globales ===== */
.card{
  /* uniformise l'arrondi et le fond si d'autres cartes existent */
  border-radius: 16px;
}

@media (max-width:900px){
  .page-title{ margin-bottom: 14px; }
}

/* ===== CONTACT SIMPLE ===== */
.contact-info{
  padding: 26px;
}

.contact-info h2{
  margin:.2rem 0 10px;
  font-size: 22px;
  font-weight:800;
}

.contact-list{
  list-style:none;
  padding:0;
  margin:12px 0 0;
}
.contact-list li{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 0;
  font-size:17px;
  border-bottom:1px dashed rgba(0,245,212,.12);
}
.contact-list li:last-child{
  border-bottom:none;
}
.contact-list .ico{
  width:22px;
  text-align:center;
  opacity:.85;
}
