/* ====================================================================
   ASE Events — Course de caisses à savon
   Charte : noir profond #070707, or champagne #C9A465
   ==================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap');

:root{
  --gold:#C9A465; --gold-2:#e0c590; --champ:#EEE4D0;
  --bg:#070707; --warm:#1f1813; --panel:#111010; --panel-2:#171514;
  --line:rgba(201,164,101,.18); --line-strong:rgba(201,164,101,.4);
  --txt:#EDE7DC; --muted:#9a9389; --ok:#7bbf6a; --warn:#d98b3a; --bad:#cf5b52;
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'DM Sans',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--body); color:var(--txt); background:var(--bg);
  line-height:1.5; min-height:100vh; -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(900px 500px at 85% -10%, rgba(201,164,101,.10), transparent 60%),
    radial-gradient(700px 600px at -10% 110%, rgba(31,24,19,.8), transparent 55%);
  background-attachment:fixed;
}
a{color:var(--gold);text-decoration:none}
img{max-width:100%;display:block}

/* ---- Layout ---- */
.wrap{max-width:1180px;margin:0 auto;padding:22px 18px 80px}
.topbar{display:flex;align-items:center;gap:14px;justify-content:space-between;
  padding:14px 0 18px;border-bottom:1px solid var(--line);margin-bottom:26px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:40px;height:40px;border:1px solid var(--gold);border-radius:50%;
  display:grid;place-items:center;font-family:var(--display);font-weight:700;color:var(--gold);
  font-size:19px;letter-spacing:.5px;background:rgba(201,164,101,.06)}
.brand h1{font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:.3px;line-height:1.1}
.brand .sub{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);opacity:.85}

/* ---- Logo ---- */
.logo{height:34px;width:auto;display:block}
.logo-wordmark{font-family:var(--display);font-weight:700;line-height:1;display:inline-flex;
  align-items:baseline;gap:.18em;white-space:nowrap}
.logo-wordmark b{font-size:1.55em;color:var(--champ);letter-spacing:.5px}
.logo-wordmark i{font-style:italic;font-weight:500;font-size:1.15em;color:var(--gold);letter-spacing:.5px}
.logo-lg{height:auto}
.logo-lg.logo{height:min(9vw,14vh)}
.logo-lg.logo-wordmark{font-size:min(4vw,7vh)}
.eyebrow{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}

h2{font-family:var(--display);font-weight:600;font-size:26px;letter-spacing:.3px;margin:30px 0 14px}
h3{font-family:var(--display);font-weight:600;font-size:20px;margin:0 0 10px}

.nav{display:flex;gap:8px;flex-wrap:wrap}
.nav a{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  padding:7px 12px;border:1px solid var(--line);border-radius:999px;transition:.2s}
.nav a:hover,.nav a.active{color:var(--bg);background:var(--gold);border-color:var(--gold)}

/* ---- Cartes ---- */
.card{background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:16px;padding:20px}
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

/* ---- Tableaux ---- */
table{width:100%;border-collapse:collapse;font-size:14px}
th{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);
  text-align:left;padding:10px 12px;border-bottom:1px solid var(--line-strong);font-weight:600}
td{padding:11px 12px;border-bottom:1px solid var(--line)}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:rgba(201,164,101,.04)}
.num{font-variant-numeric:tabular-nums}
.chrono{font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:.5px}
.rang{font-family:var(--display);font-size:20px;font-weight:700;color:var(--gold);width:46px}
.rang.r1{color:#f4d987}.rang.r2{color:#d8d8d8}.rang.r3{color:#cd9a6b}
.dossard{display:inline-grid;place-items:center;min-width:30px;height:30px;padding:0 7px;
  border:1px solid var(--line-strong);border-radius:8px;font-weight:700;color:var(--gold);
  font-variant-numeric:tabular-nums;font-size:13px}

.badge{font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:999px;
  border:1px solid var(--line);color:var(--muted)}
.badge.en_cours{color:#0b0b0b;background:var(--gold);border-color:var(--gold)}
.badge.terminee{color:var(--ok);border-color:rgba(123,191,106,.4)}
.badge.dnf,.badge.dsq,.badge.dns{color:var(--bad);border-color:rgba(207,91,82,.4)}

/* ---- Formulaires ---- */
label{display:block;font-size:12px;letter-spacing:.06em;color:var(--muted);margin:0 0 6px;text-transform:uppercase}
input,select,textarea{width:100%;font-family:var(--body);font-size:15px;color:var(--txt);
  background:#0c0b0a;border:1px solid var(--line);border-radius:10px;padding:11px 13px;transition:.2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,164,101,.13)}
.field{margin-bottom:15px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:140px}

/* ---- Boutons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:12px 20px;border-radius:10px;border:1px solid var(--gold);color:var(--gold);
  background:transparent;transition:.18s}
.btn:hover{background:rgba(201,164,101,.1)}
.btn.solid{background:var(--gold);color:#0b0b0b;border-color:var(--gold)}
.btn.solid:hover{background:var(--gold-2)}
.btn.ghost{border-color:var(--line);color:var(--muted)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold);background:transparent}
.btn.danger{border-color:rgba(207,91,82,.5);color:var(--bad)}
.btn.danger:hover{background:rgba(207,91,82,.12)}
.btn.lg{font-size:15px;padding:16px 30px}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

.muted{color:var(--muted)}
.tiny{font-size:12px}
.center{text-align:center}
.flash{padding:12px 16px;border-radius:10px;margin:14px 0;font-size:14px;
  border:1px solid var(--line);background:rgba(201,164,101,.06)}
.flash.ok{border-color:rgba(123,191,106,.4);color:var(--ok)}
.flash.err{border-color:rgba(207,91,82,.4);color:var(--bad)}
hr{border:none;border-top:1px solid var(--line);margin:22px 0}

.thumb{width:54px;height:54px;border-radius:10px;object-fit:cover;border:1px solid var(--line);background:#0c0b0a}
.empty{padding:34px;text-align:center;color:var(--muted);font-style:italic}
