/* =========================
   Loz Town Patrol — Clean CSS
   ========================= */

/* ---------- Tokens ---------- */
:root{
  --bg:#0e0e0e;
  --ink:#f2f2e6;
  --ink-dim:#bdbdac;
  --line:#2a2a2a;
  --gold:#e6b422;
  --green:#2e7d32;
  --red:#c62828;

  --sans:"Space Grotesk", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --mono:"IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --fs-1: clamp(28px, 3.2vw, 40px);
  --fs-2: 20px;
  --fs-3: 15px;

  --radius: 10px;
  --pad: 18px;
  --gap: 22px;
}

/* ---------- Base ---------- */
*{ box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  line-height:1.5;
  letter-spacing:.2px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.container{ max-width: 980px; margin:0 auto; padding: 0 16px; }
.hidden{ display:none !important; }

/* ---------- Accents ---------- */
.rasta{
  height:6px;
  background:linear-gradient(90deg,var(--green) 0 33.33%,var(--gold) 33.33% 66.66%,var(--red) 66.66% 100%);
}

/* ---------- Header ---------- */
header{ border-bottom:1px solid var(--line); background:#0b0b0b; }
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0; gap:10px;
}
.logo{
  font-weight:700; font-size:20px; text-decoration:none; color:var(--ink);
  letter-spacing:.5px;
}
.logo span{ color: var(--gold); }
nav ul{ list-style:none; display:flex; gap:18px; padding:0; margin:0; }
nav a{
  color:var(--ink); text-decoration:none; font-size:14px; opacity:.9;
  border-bottom:1px solid transparent; padding-bottom:2px;
}
nav a:hover, nav a.active{ border-color: var(--gold); color: var(--gold); }

/* header glow */
.header-glow{ position: relative; }
.header-glow::after{
  content:""; position:absolute; inset:auto 0 -2px 0; height:2px;
  background: linear-gradient(90deg, transparent, var(--green), var(--gold), var(--red), transparent);
  opacity:.5;
}

/* ---------- Page titles / generic ---------- */
.page-head{ padding: 32px 0 14px; border-bottom:1px dashed var(--line); text-align:center; }
.page-head h1{ margin:0 0 6px 0; font-size: var(--fs-1); letter-spacing:1px; text-transform: uppercase; }
.page-head p{ margin:0; color:var(--ink-dim); font-size:13px; font-family: var(--mono); }

/* ---------- Cards ---------- */
.card{
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--pad);
  background:#101010;
}
.card h2{ margin:0 0 10px 0; font-size: var(--fs-2); text-transform: uppercase; letter-spacing:.8px; }
.sep{
  height:2px; margin:10px 0 16px;
  background: linear-gradient(90deg, var(--green), var(--gold), var(--red));
  opacity:.7;
}

/* ---------- Lists / info ---------- */
.info-list{ display:flex; flex-direction:column; gap:14px; padding:0; margin:0; list-style:none; }
.info{ display:flex; gap:12px; align-items:flex-start; font-size: var(--fs-3); }
.tag{
  width:36px; height:36px; display:grid; place-items:center; flex-shrink:0;
  border:1px solid var(--line); border-radius:7px; background:#0f0f0f;
}
.tag i{ font-size:14px; color:#111; background:linear-gradient(135deg,var(--green),var(--gold)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.label{ font-weight:600; }
.muted{ color: var(--ink-dim); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 20px; border-radius:999px; border:1px solid var(--line);
  background:#0f0f0f; color:var(--ink); font-weight:700; letter-spacing:.3px;
  text-transform: uppercase; font-size:12px; cursor:pointer;
  transition: transform .15s ease, color .15s ease, border-color .15s ease, background .15s ease;
}
.btn:hover{ border-color: var(--gold); color: var(--gold); }
.btn:active{ transform: translateY(1px) scale(.99); }

/* ---------- Forms ---------- */
.form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.form label{ grid-column: span 2; font-size:13px; color: var(--gold); margin-top:4px; }
.form input, .form select, .form textarea{
  grid-column: span 2;
  width:100%; padding:12px 12px;
  border:1px solid var(--line); border-radius:8px;
  background:#121212; color:var(--ink); font-size:15px;
}
.form textarea{ min-height:140px; resize:vertical; }
.form input:focus, .form select:focus, .form textarea:focus{
  outline:none; border-color: var(--green); box-shadow: 0 0 0 2px rgba(46,125,50,.2);
}

/* ---------- Footer ---------- */
footer{ border-top:1px solid var(--line); padding:18px 0; background:#0b0b0b; }
.foot{ text-align:center; color: var(--ink-dim); font-size:12px; }
.social{ display:flex; gap:12px; margin-top:16px; }
.social a{ color:var(--ink); font-size:20px; opacity:.9; }
.social a:hover{ color: var(--gold); }

/* =========================
   HOME
   ========================= */

/* Hero */
.hero{
  background:#101010;
  border-bottom:1px dashed var(--line);
}
.hero-designed .container{ max-width: 1100px; } /* hero plus large que le reste */

.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;         /* texte dominant */
  align-items:center;
  column-gap: clamp(28px, 5vw, 72px);
  row-gap: clamp(18px, 3.5vw, 36px);
  padding: clamp(36px, 6vw, 84px) 0;
  text-align:left;
}
.hero-copy > * + *{ margin-top: clamp(10px, 1.6vw, 18px); }

.hero-title{
  margin:2px 0 clamp(10px, 2vw, 18px) 0;
  font-size: clamp(36px, 7vw, 68px);
  line-height:1.04;
  text-transform:uppercase;
  letter-spacing:.6px;
}
.hero-sub{
  max-width: 640px;
  margin: 0;
  font-size:15px;
  color: var(--ink-dim);
}
.hero-ctas{
  display:flex; gap: clamp(12px, 1.6vw, 20px);
  margin-top: clamp(12px, 2vw, 24px);
}

/* Chips */
.chips{ display:none; } /* par défaut caché */
.chips-show{
  display:flex !important;
  flex-wrap: wrap;
  gap: 10px 12px;
  margin-top: clamp(12px, 2vw, 22px);
  max-width: 640px;
}
.chip{
  font-family: var(--mono);
  font-size: 11px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid var(--line);
  background:#0f0f0f;
  opacity:.95;
}

/* Vinyl */
.hero-visual{ margin-top: clamp(8px, 1.5vw, 14px); display:grid; place-items:center; }
.vinyl{
  position:relative;
  width: clamp(110px, 16vw, 150px);
  aspect-ratio:1/1;
  border-radius:50%;
  animation: vinyl-spin 32s linear infinite;
  box-shadow: inset 0 0 0 2px #000, 0 6px 20px rgba(0,0,0,.35);
  background:
    radial-gradient(circle at 48% 45%, rgba(255,255,255,.08), transparent 35%),
    radial-gradient(circle at 50% 50%, #0f0f0f 0 33%, #0a0a0a 33% 100%);
  border: 1px solid var(--line);
}
.vinyl-lg{ width: clamp(200px, 30vw, 360px); animation: vinyl-spin 26s linear infinite; }
@keyframes vinyl-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce){ .vinyl, .vinyl-lg{ animation: none; } }

.vinyl-grooves{
  position:absolute; inset: 9% 9%;
  border-radius:50%;
  background: repeating-radial-gradient(circle, rgba(255,255,255,.06) 0 1px, transparent 1px 3px);
  opacity:.22;
}
.vinyl .label{
  position:absolute; inset: 38% 38%;
  border-radius:50%;
  background:#e9e2c0;
  border:1px solid #111;
  display:grid; place-items:center; text-align:center;
  color:#0b0b0b; font-family: var(--mono);
  font-size:11px; font-weight:700; letter-spacing:.7px;
  padding-top:7px;
  padding-bottom: 7px;
}

.vinyl-sheen{
  content:""; position:absolute; inset:0; border-radius:50%;
  background:
    radial-gradient(120% 80% at 20% 15%, rgba(255,255,255,.16), rgba(255,255,255,0) 45%),
    radial-gradient(120% 80% at 70% 80%, rgba(255,255,255,.06), rgba(255,255,255,0) 50%);
  mix-blend-mode: screen; opacity:.7; pointer-events:none;
}

/* Grain */
.grain{ opacity:.9; mix-blend-mode: soft-light; }

/* Events / Flyers */
.events{ padding: 32px 0 52px; }
.section-title{
  text-align:center; margin:0 0 18px 0; text-transform: uppercase;
  letter-spacing:.8px; font-size: var(--fs-2);
}
.event-list{ display:grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
@media (max-width: 820px){ .event-list{ grid-template-columns: 1fr; } }
.event .event-meta{ font-family: var(--mono); font-size: 13px; color: var(--ink-dim); }
.event .event-title{ margin:6px 0 8px; }

.events-designed .section-title{ letter-spacing: 1px; }
.flyers{ align-items: stretch; }
.flyer{
  position:relative; overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)) padding-box,
    radial-gradient(120% 120% at 0% 0%, rgba(46,125,50,.18), transparent 60%) border-box;
  border:1px solid var(--line);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.flyer .event-head{ margin-bottom:6px; }
.flyer .event-title{ margin:6px 0 2px; }
.flyer:hover{
  transform: translateY(-4px);
  border-color: rgba(230,180,34,.45);
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
}
.flyer-edge{
  content:""; position:absolute; inset:auto -10% 0 -10%; height:8px;
  background: linear-gradient(90deg, var(--green), var(--gold), var(--red));
  filter: blur(8px); opacity:.35;
}
.flyer.alt{
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)) padding-box,
    radial-gradient(120% 120% at 100% 0%, rgba(198,40,40,.15), transparent 60%) border-box;
}

/* Slider */
.slider-wrap{ padding: 18px 0 56px; }
.slider{
  position:relative; overflow:hidden; border:1px solid var(--line);
  border-radius: var(--radius);
  background: radial-gradient(200% 90% at 50% -10%, rgba(46,125,50,.12), transparent 60%), #0f0f0f;
}
.slides{ display:flex; transition: transform .4s ease; }
.slide{ min-width:100%; aspect-ratio: 16/9; background-size:cover; background-position:center; }
.slider-nav{
  position:absolute; left:0; right:0; bottom:10px; display:flex; justify-content:center; gap:8px;
}
.slider-nav button{
  width:10px; height:10px; border-radius:50%; border:1px solid var(--line);
  background:#0f0f0f; cursor:pointer;
}
.slider-nav button.active{ background: var(--gold); border-color: var(--gold); }
.slide-arrows{
  position:absolute; inset:0; display:flex; justify-content:space-between; align-items:center; padding:0 8px;
}
.arrow{
  width:36px; height:36px; border-radius:50%; background:#0f0f0f;
  border:1px solid var(--line); color:var(--ink); display:grid; place-items:center; cursor:pointer;
}
.arrow:hover{ border-color: var(--gold); color: var(--gold); }

/* ---------- Focus visible ---------- */
a:focus-visible, button:focus-visible, .btn:focus-visible{
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: 6px;
}

/* ---------- Responsive hero ---------- */
@media (max-width: 880px){
  .hero-grid{
    grid-template-columns: 1fr;
    text-align:center;
  }
  .hero-copy{ order: 1; }
  .hero-visual{ order: 2; }
}

/* ---------- Spacing between sections ---------- */
.hero + .events{ padding-top: clamp(18px, 3vw, 32px); }
/* =========================
   MEDIA QUERIES
   ========================= */

/* --- Mobile compact (≤360px) --- */
@media (max-width: 360px){
  .container{ padding: 0 12px; }
  .logo{ font-size:18px; }
  nav ul{ gap:10px; }
  .btn{ padding:10px 16px; font-size:11px; }

  .hero-designed .container{ max-width: 100%; }
  .hero-grid{ padding: 28px 0 48px; row-gap: 14px; }
  .hero-title{ font-size: clamp(28px, 9vw, 36px); letter-spacing:.4px; }
  .hero-sub{ font-size:14px; }
  .hero-ctas{ flex-direction: column; align-items: stretch; gap:10px; }
  .vinyl-lg{ width: clamp(150px, 48vw, 200px); }
  .chips-show{ gap: 8px; }
  .chip{ font-size:10px; padding: 5px 9px; }

  .event-list{ gap: 16px; }
  .slider-wrap{ padding: 12px 0 36px; }
  .slide{ aspect-ratio: 4/3; } /* + haut en mobile */
}

/* --- Mobile / small (≤600px) --- */
@media (max-width: 600px){
  .nav{ padding: 12px 0; }
  nav ul{ gap:12px; flex-wrap: wrap; }
  .hero-grid{
    grid-template-columns: 1fr;
    text-align:center;
    column-gap: 0;
    row-gap: clamp(14px, 4vw, 22px);
  }
  .hero-copy > * + *{ margin-top: clamp(8px, 2.4vw, 16px); }
  .hero-title{ font-size: clamp(32px, 9vw, 44px); line-height:1.06; }
  .hero-sub{ max-width: 520px; margin: 0 auto; }
  .hero-ctas{ justify-content:center; }
  .hero-visual{ margin-top: 8px; }
  .vinyl-lg{ width: clamp(180px, 52vw, 260px); }

  .event-list{ grid-template-columns: 1fr; }
  .slider-nav button{ width:12px; height:12px; }
  .arrow{ width:34px; height:34px; }
}

/* --- Tablet (601px–1024px) --- */
@media (min-width: 601px) and (max-width: 1024px){
  .container{ max-width: 860px; }
  .hero-designed .container{ max-width: 980px; }
  .hero-grid{
    grid-template-columns: 1.1fr 0.9fr;
    column-gap: clamp(24px, 5vw, 54px);
    padding: clamp(28px, 6vw, 68px) 0;
  }
  .hero-title{ font-size: clamp(40px, 7.2vw, 56px); }
  .vinyl-lg{ width: clamp(220px, 32vw, 300px); }
  .event-list{ grid-template-columns: 1fr 1fr; }
}

/* --- Desktop large (≥1200px) --- */
@media (min-width: 1200px){
  .container{ max-width: 1060px; }
  .hero-designed .container{ max-width: 1180px; }
  .hero-grid{
    column-gap: clamp(36px, 5vw, 80px);
    padding: clamp(44px, 6vw, 96px) 0;
  }
  .hero-title{ font-size: clamp(56px, 6.2vw, 72px); }
  .vinyl-lg{ width: clamp(280px, 28vw, 360px); }
}

/* --- Ultra-wide (≥1600px) --- */
@media (min-width: 1600px){
  .container{ max-width: 1200px; }
  .hero-designed .container{ max-width: 1320px; }
  .hero-grid{
    column-gap: 96px;
    padding: 108px 0 120px;
  }
  .hero-title{ font-size: 76px; }
  .hero-sub{ font-size: 16px; }
  .vinyl-lg{ width: 380px; }
  .event-list{ grid-template-columns: repeat(2, 1fr); gap: 28px; }
}

/* =========================
   EVENTS ARCHIVE
   ========================= */

.events-archive{ padding: 28px 0 64px; }

.year-section + .year-section{ margin-top: 36px; }
.year-title{
  margin: 0 0 14px;
  font-size: clamp(18px, 2.6vw, 22px);
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--ink);
  border-bottom: 1px dashed var(--line);
  padding-bottom: 10px;
}

.event-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: var(--gap);
}
@media (max-width: 1024px){
  .event-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px){
  .event-grid{ grid-template-columns: 1fr; }
}

.event-card{
  display:flex; flex-direction:column; overflow:hidden;
  border:1px solid var(--line); border-radius: var(--radius);
  background:#101010;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.event-card:hover{
  transform: translateY(-3px);
  border-color: rgba(230,180,34,.45);
  box-shadow: 0 10px 26px rgba(0,0,0,.32);
}

.event-media{
  display:block; aspect-ratio: 16/10; background:#0f0f0f; overflow:hidden;
}
.event-media img{
  width:100%; height:100%; object-fit:cover; display:block;
  transform: scale(1.02);
  transition: transform .35s ease, filter .35s ease;
}
.event-card:hover .event-media img{ transform: scale(1.06); filter: saturate(1.05) contrast(1.03); }

.event-body{ padding: 14px; display:flex; flex-direction:column; gap: 10px; }
.event-meta{
  font-family: var(--mono); font-size: 12px; color: var(--ink-dim);
}
.event-name{
  margin:0; font-size: 18px; letter-spacing:.3px;
}
.event-desc{
  margin:0; color: var(--ink-dim); font-size: 14px; line-height:1.55;
}

.event-tags{ display:flex; flex-wrap:wrap; gap: 8px; }
.event-tags .chip{
  font-family: var(--mono);
  font-size: 11px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid var(--line);
  background:#0f0f0f;
  opacity:.95;
}

.event-actions{ margin-top: 4px; }
.btn.is-disabled{
  opacity:.6; cursor:not-allowed;
  border-color: var(--line);
}
/* =========================
   CONTACT — layout 2 colonnes
   ========================= */

/* compat: .contact (nouveau) OU .contact-section (ancien) */
.contact,
.contact-section{
  padding: 32px 0 64px;
}

/* compat: .grid (nouveau) OU .contact-container (ancien) */
.contact .grid,
.contact-section .contact-container{
  display: grid;
  grid-template-columns: 1fr 1fr; /* 2 colonnes */
  gap: clamp(16px, 3vw, 28px);
  align-items: start;
}

/* cartes au même niveau visuel */
.contact .card,
.contact-section .card{
  height: 100%;
}

/* formulaire en 2 colonnes sur desktop */
.contact .form,
.contact-section .form{
  grid-template-columns: 1fr 1fr;
}

/* Responsive */
@media (max-width: 900px){
  .contact .grid,
  .contact-section .contact-container{
    grid-template-columns: 1fr; /* 1 colonne en mobile/tablette */
  }
}

@media (max-width: 620px){
  /* champs du form en 1 colonne */
  .contact .form,
  .contact-section .form{
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .contact .form label,
  .contact-section .form label,
  .contact .form input,
  .contact-section .form input,
  .contact .form select,
  .contact-section .form select,
  .contact .form textarea,
  .contact-section .form textarea{
    grid-column: auto;
  }
}

/* =========================
   CONTACT — colonne gauche
   ========================= */
.contact .card:first-child{
  padding: 28px 26px;               /* + padding interne */
  display: flex;
  flex-direction: column;
  gap: 26px;                        /* espace entre les blocs (titre, infos, réseaux) */
}

.contact .card:first-child h2{
  margin-bottom: 8px;
}

.info-list{ gap: 20px; }            /* + espace entre chaque info */
.info{ line-height: 1.6; }

.social{ margin-top: 12px; gap: 16px; }
.social a{ font-size: 22px; }       /* icônes légèrement plus grandes */

/* ---------- About page ---------- */
.about{ padding: 40px 0 64px; }
.about .card p{
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-dim);
}
/* Alignement des barres (sep) sur contact */
.contact .card .sep{
  height: 2px;
  margin: 6px 0 18px;
  background: linear-gradient(90deg, var(--green), var(--gold), var(--red));
  border-radius: 2px;
  /* force la barre à s'aligner avec la grille */
  margin-left: -4px;
  margin-right: -4px;
}

/* 1) Pad des cartes piloté par une variable */
.card{
  --card-pad: var(--pad);               /* défaut */
  padding: var(--card-pad);
}

/* 2) Carte gauche : même layout mais on déclare son pad */
.contact .card:first-child{
  --card-pad: 26px;                     /* correspond à tes 28px 26px (on garde 26px horizontal) */
  padding: 28px var(--card-pad);
}

/* 3) Barre "sep" qui s'aligne pile avec la grille (full-bleed dans la card) */
.contact .card .sep{
  height: 2px;
  margin: 6px 0 18px;
  background: linear-gradient(90deg, var(--green), var(--gold), var(--red));
  border-radius: 2px;
  /* déborde des deux côtés exactement de la valeur du padding */
  margin-left: calc(var(--card-pad) * -1);
  margin-right: calc(var(--card-pad) * -1);
}