/*
Theme Name: MonoGlow Portfolio
Theme URI: https://example.com/monoglow-portfolio
Author: ChatGPT
Description: Thème portfolio sombre avec une seule couleur d’accent, idéal pour un portfolio BTS SIO SISR.
Version: 1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: monoglow-portfolio
*/

:root{
  --bg:#020617;
  --panel:#020617;
  --card:rgba(15,23,42,0.96);
  --accent:#38bdf8;
  --accent-soft:rgba(56,189,248,0.2);
  --text:#e5e7eb;
  --muted:#9ca3af;
  --radius:24px;
}

*,
*::before,
*::after{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:
    radial-gradient(circle at 10% 0%, rgba(56,189,248,0.16) 0, transparent 55%),
    radial-gradient(circle at 90% 0%, rgba(56,189,248,0.08) 0, transparent 50%),
    radial-gradient(circle at 50% 100%, rgba(8,47,73,0.8) 0, #020617 55%);
  color:var(--text);
}

img{max-width:100%;display:block;}

a{text-decoration:none;color:inherit;}

.main-wrapper{
  min-height:100vh;
  padding:32px 16px 48px;
}

.container{
  max-width:1120px;
  margin:0 auto;
}

/* HEADER */

.site-header{
  position:sticky;
  top:16px;
  z-index:40;
  margin-bottom:28px;
}

.nav-shell{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 18px;
  border-radius:999px;
  background:linear-gradient(to bottom right, rgba(15,23,42,0.98), rgba(15,23,42,0.9));
  border:1px solid rgba(148,163,184,0.4);
  box-shadow:0 18px 60px rgba(15,23,42,0.9);
  backdrop-filter:blur(18px);
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
}

.brand-avatar{
  width:32px;
  height:32px;
  border-radius:999px;
  background:radial-gradient(circle at 30% 0, var(--accent), #0f172a 55%, #000);
  border:1px solid rgba(148,163,184,0.6);
  box-shadow:0 0 0 1px #020617,0 0 25px rgba(56,189,248,0.6);
}

.brand-main{
  font-size:.9rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.brand-sub{
  font-size:.7rem;
  color:var(--muted);
}

.nav-links{
  display:none;
  gap:18px;
  font-size:.82rem;
  color:var(--muted);
}

.nav-links a{
  position:relative;
  padding:4px 0;
}

.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-2px;
  width:0;
  height:1px;
  background:linear-gradient(to right,var(--accent),transparent);
  transition:width .18s ease;
}

.nav-links a:hover{color:var(--text);}
.nav-links a:hover::after{width:18px;}

.badge{
  padding:6px 10px;
  border-radius:999px;
  background:radial-gradient(circle at top, #e0f2fe, var(--accent));
  color:#0b1120;
  font-size:.72rem;
  font-weight:600;
  box-shadow:0 10px 32px rgba(56,189,248,0.6);
}

/* HERO */

.layout-grid{
  display:grid;
  gap:24px;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
}

.hero{
  padding:22px 22px 20px;
  border-radius:var(--radius);
  background:
    radial-gradient(circle at top left, var(--accent-soft), transparent 55%),
    linear-gradient(to bottom right, rgba(15,23,42,0.98), rgba(15,23,42,0.93));
  border:1px solid rgba(148,163,184,0.4);
  box-shadow:0 24px 80px rgba(15,23,42,0.95);
}

.hero-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:5px 11px;
  border-radius:999px;
  background:rgba(15,23,42,0.95);
  border:1px solid rgba(148,163,184,0.5);
  font-size:.75rem;
  color:var(--muted);
  margin-bottom:18px;
}

.hero-dot{
  width:8px;height:8px;border-radius:999px;
  background:radial-gradient(circle,var(--accent),#0b1120);
  box-shadow:0 0 18px rgba(56,189,248,0.9);
}

.hero-title{
  font-size:clamp(2.1rem,3vw,2.7rem);
  line-height:1.05;
  margin:0 0 10px;
}

.hero-title span{color:var(--accent);}

.hero-sub{
  font-size:1.02rem;
  color:var(--muted);
  max-width:32rem;
  margin:0 0 22px;
}

.hero-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:24px;
}

.tag-pill{
  padding:6px 12px;
  border-radius:999px;
  background:rgba(15,23,42,0.95);
  border:1px solid rgba(148,163,184,0.45);
  font-size:.78rem;
  color:var(--muted);
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:22px;
}

.btn-primary,
.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  padding:10px 18px;
  font-size:.88rem;
  cursor:pointer;
  border:none;
}

.btn-primary{
  background:radial-gradient(circle at top,#e0f2fe,var(--accent));
  color:#0b1120;
  font-weight:600;
  box-shadow:0 18px 40px rgba(56,189,248,0.7);
}

.btn-ghost{
  background:rgba(15,23,42,0.96);
  color:var(--muted);
  border:1px solid rgba(148,163,184,0.5);
}

.btn-primary:hover{transform:translateY(-1px);}
.btn-ghost:hover{border-color:rgba(148,163,184,0.8);}

.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  font-size:.8rem;
  color:var(--muted);
}

.hero-meta-block{
  padding:8px 10px;
  border-radius:14px;
  background:rgba(15,23,42,0.96);
  border:1px solid rgba(148,163,184,0.45);
}

.hero-meta-block strong{
  display:block;
  color:var(--text);
}

/* PROFILE */

.profile{
  border-radius:28px;
  overflow:hidden;
  background:
    radial-gradient(circle at top, var(--accent-soft), transparent 60%),
    radial-gradient(circle at 15% 90%, rgba(15,23,42,1), #020617);
  border:1px solid rgba(148,163,184,0.5);
  box-shadow:0 24px 80px rgba(15,23,42,0.95);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.profile-top{
  padding:24px 22px 4px;
}

.profile-frame{
  position:relative;
  border-radius:26px;
  padding:12px;
  background:linear-gradient(145deg, rgba(15,23,42,0.96), rgba(8,47,73,0.98));
  border:1px solid rgba(148,163,184,0.4);
  overflow:hidden;
}

.profile-photo{
  height:230px;
  border-radius:18px;
  background:
    radial-gradient(circle at 10% 0, rgba(248,250,252,0.95), rgba(56,189,248,0.08)),
    radial-gradient(circle at 80% 100%, rgba(15,23,42,1), #020617);
  position:relative;
}

.profile-photo::after{
  content:"Ta photo ici";
  position:absolute;
  bottom:12px;
  left:14px;
  font-size:.8rem;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#020617;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(248,250,252,0.98);
}

.profile-ring{
  position:absolute;
  inset:22px;
  border-radius:22px;
  border:1px solid rgba(148,163,184,0.35);
  pointer-events:none;
}

.profile-strip{
  position:absolute;
  top:18px;
  left:18px;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(15,23,42,0.96);
  border:1px solid rgba(148,163,184,0.55);
  font-size:.75rem;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.profile-strip span.dot{
  width:7px;height:7px;border-radius:999px;
  background:var(--accent);
  box-shadow:0 0 18px rgba(56,189,248,0.9);
}

.profile-bottom{
  padding:10px 18px 18px;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.profile-stat{
  padding:10px 12px;
  border-radius:18px;
  background:rgba(15,23,42,0.97);
  border:1px solid rgba(148,163,184,0.4);
  font-size:.76rem;
  color:var(--muted);
}

.profile-stat strong{display:block;color:var(--text);}

.profile-cta{
  grid-column:span 2;
  padding:10px 12px;
  border-radius:18px;
  background:radial-gradient(circle at 0 0, rgba(56,189,248,0.8), rgba(8,47,73,1));
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  text-align:center;
}

/* SECTIONS */

.section{
  margin-top:40px;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:10px;
  margin-bottom:16px;
}

.section-kicker{
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--accent);
}

.section-title{
  font-size:1.1rem;
  font-weight:600;
}

.section-sub{
  font-size:.86rem;
  color:var(--muted);
}

.grid{
  display:grid;
  gap:16px;
}

.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}

.card{
  padding:14px 14px 16px;
  border-radius:20px;
  background:
    radial-gradient(circle at top left, rgba(56,189,248,0.12), transparent 55%),
    linear-gradient(to bottom right, rgba(15,23,42,0.98), rgba(15,23,42,0.95));
  border:1px solid rgba(148,163,184,0.4);
  box-shadow:0 22px 70px rgba(15,23,42,0.9);
}

.card-label{
  font-size:.75rem;
  color:var(--muted);
  margin-bottom:4px;
}

.card-title{
  font-size:.95rem;
  font-weight:600;
  margin-bottom:6px;
}

.card-meta{
  font-size:.76rem;
  color:var(--muted);
  margin-bottom:8px;
}

.card-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  font-size:.7rem;
  margin-bottom:6px;
}

.card-tag{
  padding:4px 9px;
  border-radius:999px;
  background:rgba(15,23,42,0.95);
  border:1px solid rgba(148,163,184,0.45);
}

.card-text{
  font-size:.8rem;
  color:var(--text);
}

/* TIMELINE */

.timeline{
  position:relative;
  padding-left:18px;
  border-left:1px solid rgba(148,163,184,0.4);
}

.timeline-item{
  position:relative;
  padding-bottom:16px;
  margin-bottom:4px;
}

.timeline-dot{
  position:absolute;
  left:-9px;
  top:4px;
  width:13px;
  height:13px;
  border-radius:999px;
  background:radial-gradient(circle,var(--accent),#0b1120);
  box-shadow:0 0 22px rgba(56,189,248,0.9);
}

/* CONTACT */

.contact-layout{
  display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);
  gap:18px;
}

.contact-form{
  display:grid;
  gap:10px;
}

.field{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.field label{
  font-size:.75rem;
  color:var(--muted);
}

.field input,
.field textarea{
  border-radius:14px;
  padding:9px 11px;
  border:1px solid rgba(148,163,184,0.5);
  background:rgba(15,23,42,0.96);
  color:var(--text);
  font-size:.85rem;
  outline:none;
}

.field input:focus,
.field textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(56,189,248,0.45);
}

.field textarea{min-height:120px;resize:vertical;}

.contact-aside{
  font-size:.82rem;
  color:var(--muted);
}

.contact-aside strong{color:var(--accent);}

/* FOOTER */

.site-footer{
  margin-top:40px;
  padding-top:16px;
  border-top:1px solid rgba(30,64,175,0.7);
  font-size:.75rem;
  color:var(--muted);
  display:flex;
  justify-content:space-between;
  gap:10px;
}

/* RESPONSIVE */

@media(min-width:768px){
  .nav-links{display:flex;}
}

@media(max-width:767px){
  .main-wrapper{padding:20px 12px 40px;}
  .layout-grid{grid-template-columns:1fr;}
  .profile{order:-1;}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr));}
  .contact-layout{grid-template-columns:1fr;}
  .site-footer{flex-direction:column;}
}

@media(max-width:540px){
  .grid-3{grid-template-columns:1fr;}
}
