/* ══════════════════════════════════════════
   WALY DIA BLOG — STYLES PRINCIPAUX
   Inspiré de Promise of Victory
   ══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@700;900&family=Cinzel:wght@400;600;700&family=Lato:ital,wght@0,300;0,400;0,700;1,300&display=swap');

:root {
  --black: #070707;
  --dark:  #101010;
  --card:  #141414;
  --border:#252525;
  --red:   #c0392b;
  --red-glow: rgba(192,57,43,0.35);
  --silver: #b8b8b8;
  --silver-light: #e0e0e0;
  --white: #f2f2f2;
  --muted: #5a5a5a;
  --muted2:#888;
}

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

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--white);
  font-family: 'Lato', sans-serif;
  font-weight: 300;
  line-height: 1.7;
  min-height: 100vh;
}

/* grain */
body::after {
  content:'';
  position: fixed; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9999; opacity:.6;
}

::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--dark); }
::-webkit-scrollbar-thumb { background:var(--red); }

a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }

/* ── NAV ── */
nav {
  position: fixed; top:0; left:0; right:0;
  padding: 0 48px;
  height: 70px;
  display: flex; align-items:center; justify-content:space-between;
  background: rgba(7,7,7,0.97);
  border-bottom: 1px solid var(--border);
  z-index: 500;
  backdrop-filter: blur(8px);
}

.nav-logo {
  font-family: 'Cinzel Decorative', serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--silver-light);
  cursor:pointer;
}
.nav-logo em { color:var(--red); font-style:normal; }

.nav-links {
  display:flex; gap:32px; align-items:center;
  list-style:none;
}
.nav-links a {
  font-family:'Cinzel', serif;
  font-size:9px; letter-spacing:3px;
  text-transform:uppercase; color:var(--muted);
  transition:color .3s;
}
.nav-links a:hover, .nav-links a.active { color:var(--silver); }

.nav-admin {
  font-family:'Cinzel', serif;
  font-size:9px; letter-spacing:3px;
  text-transform:uppercase; color:var(--silver);
  border:1px solid var(--border);
  padding:8px 20px; cursor:pointer;
  background:transparent; transition:all .3s;
}
.nav-admin:hover { border-color:var(--red); color:var(--white); box-shadow:0 0 15px var(--red-glow); }

/* ── HERO ── */
.hero {
  min-height: 100vh;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
  padding: 120px 24px 80px;
  position:relative; overflow:hidden;
}

.hero-bg {
  position:absolute; inset:0;
  background: radial-gradient(ellipse 70% 60% at 50% 55%, rgba(192,57,43,0.07) 0%, transparent 70%);
}

.hero-line {
  width:1px; height:70px;
  background: linear-gradient(to bottom, transparent, var(--red), transparent);
  margin:0 auto 36px;
  animation: growLine 1.5s ease forwards;
}

@keyframes growLine { from{opacity:0;transform:scaleY(0)} to{opacity:1;transform:scaleY(1)} }
@keyframes up { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

.hero-pre {
  font-family:'Cinzel', serif; font-size:9px;
  letter-spacing:8px; color:var(--red);
  text-transform:uppercase; margin-bottom:20px;
  animation: up 1s .3s both;
}

.hero-title {
  font-family:'Cinzel Decorative', serif;
  font-size: clamp(40px, 9vw, 100px);
  font-weight:900; line-height:1; letter-spacing:4px;
  background: linear-gradient(135deg, #777 0%, #ddd 35%, #aaa 55%, #fff 75%, #999 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  margin-bottom:10px;
  animation: up 1s .5s both;
}

.hero-sub {
  font-family:'Cinzel', serif;
  font-size: clamp(10px,1.8vw,14px);
  letter-spacing:10px; color:var(--silver);
  text-transform:uppercase; margin-bottom:24px;
  animation: up 1s .7s both;
}

.hero-tagline {
  font-size:15px; letter-spacing:1px; color:var(--muted2);
  font-style:italic; max-width:440px; line-height:1.9;
  animation: up 1s .9s both; margin-bottom:52px;
}

.btn {
  font-family:'Cinzel', serif; font-size:9px;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--white); background:transparent;
  border:1px solid var(--red); padding:14px 36px;
  cursor:pointer; transition:all .4s; display:inline-block;
  position:relative; overflow:hidden;
}
.btn::before {
  content:'';position:absolute;inset:0;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform .4s; z-index:-1;
}
.btn:hover::before { transform:scaleX(1); }
.btn:hover { box-shadow:0 0 30px var(--red-glow); }
.btn-ghost { border-color:var(--border); }
.btn-ghost:hover { border-color:var(--silver); }

/* ── SECTION ── */
.section { padding:80px 48px; max-width:1200px; margin:0 auto; }

.section-header { text-align:center; margin-bottom:60px; }

.section-eyebrow {
  font-family:'Cinzel', serif; font-size:9px;
  letter-spacing:6px; color:var(--red);
  text-transform:uppercase; margin-bottom:14px;
}

.section-title {
  font-family:'Cinzel', serif;
  font-size: clamp(18px,3vw,30px);
  font-weight:700; letter-spacing:4px;
  color:var(--silver-light); text-transform:uppercase;
  position:relative; display:inline-block;
}
.section-title::after {
  content:''; position:absolute;
  bottom:-10px; left:50%; transform:translateX(-50%);
  width:36px; height:1px; background:var(--red);
}

/* ── BLOG GRID ── */
.blog-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap:2px;
}

.blog-card {
  background:var(--card);
  border:1px solid var(--border);
  overflow:hidden; cursor:pointer;
  transition: transform .4s, border-color .4s;
  display:flex; flex-direction:column;
}
.blog-card:hover { transform:translateY(-4px); border-color:rgba(192,57,43,.4); }

.card-img {
  aspect-ratio:16/9; overflow:hidden;
  position:relative; background:var(--dark);
  flex-shrink:0;
}
.card-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s; filter:brightness(.8) saturate(.85);
}
.blog-card:hover .card-img img { transform:scale(1.05); }

.card-img-ph {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg,#0d0d0d,#1a1a1a);
  color:var(--border); font-size:40px;
}

.card-badge {
  position:absolute; top:14px; left:14px;
  font-family:'Cinzel',serif; font-size:7px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--white); background:var(--red); padding:4px 10px; z-index:2;
}
.card-video-icon {
  position:absolute; bottom:14px; right:14px;
  background:rgba(7,7,7,.85); border:1px solid var(--red);
  color:var(--red); padding:4px 10px;
  font-size:9px; font-family:'Cinzel',serif; letter-spacing:2px; z-index:2;
}

.card-body { padding:26px; flex:1; display:flex; flex-direction:column; }

.card-date {
  font-size:9px; letter-spacing:3px;
  color:var(--muted); text-transform:uppercase; margin-bottom:12px;
}

.card-title {
  font-family:'Cinzel',serif; font-size:15px;
  font-weight:700; letter-spacing:1px;
  color:var(--silver-light); line-height:1.45;
  margin-bottom:10px; transition:color .3s;
}
.blog-card:hover .card-title { color:var(--white); }

.card-excerpt {
  font-size:12.5px; line-height:1.8; color:var(--muted2);
  margin-bottom:20px; flex:1;
  display:-webkit-box; -webkit-line-clamp:3;
  -webkit-box-orient:vertical; overflow:hidden;
}

.card-more {
  font-family:'Cinzel',serif; font-size:8px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--red); display:flex; align-items:center; gap:8px;
  transition:gap .3s;
}
.blog-card:hover .card-more { gap:14px; }
.card-more::after { content:'→'; }

/* Featured card */
.blog-card.featured {
  grid-column:1/-1;
  flex-direction:row;
}
.blog-card.featured .card-img { aspect-ratio:auto; flex:1; min-height:280px; }
.blog-card.featured .card-body { flex:1; padding:40px; justify-content:center; }
.blog-card.featured .card-title { font-size:22px; margin-bottom:14px; }
.blog-card.featured .card-excerpt { -webkit-line-clamp:5; }

/* ── ARTICLE ── */
.article-wrap { max-width:800px; margin:0 auto; padding:100px 48px 80px; }

.article-meta-top {
  text-align:center; margin-bottom:48px;
}
.article-cat {
  font-family:'Cinzel',serif; font-size:9px;
  letter-spacing:5px; color:var(--red);
  text-transform:uppercase; display:block; margin-bottom:20px;
}
.article-title {
  font-family:'Cinzel',serif; font-size:clamp(22px,4vw,38px);
  font-weight:700; letter-spacing:2px;
  color:var(--silver-light); line-height:1.3; margin-bottom:16px;
}
.article-date {
  font-size:10px; letter-spacing:3px;
  color:var(--muted); text-transform:uppercase;
}

.article-image {
  width:100%; border:1px solid var(--border);
  margin-bottom:40px; filter:brightness(.9);
}

.article-video {
  width:100%; max-height:500px;
  background:#000; border:1px solid var(--border);
  margin-bottom:40px; display:block;
}

.article-divider {
  width:40px; height:1px; background:var(--red);
  margin:40px auto;
}

.article-content {
  font-size:16px; line-height:1.9;
  color:var(--silver);
}
.article-content p { margin-bottom:24px; }
.article-content h2 {
  font-family:'Cinzel',serif; font-size:22px;
  color:var(--silver-light); margin:36px 0 16px;
  letter-spacing:2px;
}
.article-content h3 {
  font-family:'Cinzel',serif; font-size:17px;
  color:var(--silver); margin:28px 0 12px;
}
.article-content blockquote {
  border-left:2px solid var(--red);
  padding:16px 24px; margin:28px 0;
  background:var(--dark); color:var(--muted2);
  font-style:italic;
}
.article-content a { color:var(--red); border-bottom:1px solid rgba(192,57,43,.4); }

.back-link {
  font-family:'Cinzel',serif; font-size:9px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--muted); display:inline-flex;
  align-items:center; gap:8px; margin-bottom:48px;
  transition:color .3s; cursor:pointer;
}
.back-link:hover { color:var(--silver); }
.back-link::before { content:'←'; }

/* ── FOOTER ── */
footer {
  border-top:1px solid var(--border);
  padding:48px; text-align:center;
  margin-top:80px;
}
.footer-logo {
  font-family:'Cinzel Decorative',serif;
  font-size:18px; color:var(--silver);
  margin-bottom:12px;
}
.footer-logo em { color:var(--red); font-style:normal; }
.footer-tagline {
  font-size:12px; letter-spacing:2px;
  color:var(--muted); font-style:italic;
  margin-bottom:24px;
}
.footer-copy {
  font-size:10px; letter-spacing:2px; color:var(--border);
}

/* ── PAGINATION ── */
.pagination {
  display:flex; gap:4px; justify-content:center;
  margin-top:60px;
}
.pagination a {
  font-family:'Cinzel',serif; font-size:9px;
  letter-spacing:2px; padding:10px 18px;
  border:1px solid var(--border); color:var(--muted);
  transition:all .3s;
}
.pagination a:hover, .pagination a.active {
  border-color:var(--red); color:var(--white);
}

/* ── FILTER TABS ── */
.filter-bar {
  display:flex; gap:0; justify-content:center;
  margin-bottom:48px; border:1px solid var(--border);
  width:fit-content; margin-left:auto; margin-right:auto;
}
.filter-btn {
  font-family:'Cinzel',serif; font-size:9px;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--muted); padding:10px 22px;
  background:transparent; border:none;
  border-right:1px solid var(--border);
  cursor:pointer; transition:all .3s;
}
.filter-btn:last-child { border-right:none; }
.filter-btn:hover, .filter-btn.active {
  color:var(--white); background:var(--red);
}

/* ── RESPONSIVE ── */
@media(max-width:768px) {
  nav { padding:0 20px; }
  .nav-links { display:none; }
  .section { padding:60px 20px; }
  .blog-card.featured { flex-direction:column; }
  .blog-card.featured .card-img { min-height:200px; }
  .article-wrap { padding:90px 20px 60px; }
  .blog-grid { grid-template-columns:1fr; }
}

/* ── MESSAGES ── */
.flash {
  padding:14px 24px;
  font-family:'Cinzel',serif; font-size:10px;
  letter-spacing:2px; text-align:center;
  border:1px solid; margin-bottom:24px;
}
.flash.success { border-color:#2ecc71; color:#2ecc71; background:rgba(46,204,113,.08); }
.flash.error   { border-color:var(--red); color:var(--red); background:rgba(192,57,43,.08); }
