/* === Lea Chauvet Photographie - theme noir & or (luxe 3D) ============ */
:root{
  --bg:#08060a;
  --bg-soft:#0d0a0e;
  --panel:#15110f;
  --panel-2:#1c1713;
  --line:#2a2018;
  --text:#efe6d6;
  --muted:#9c917f;
  --gold:#c9a24b;
  --gold-soft:#e9cd84;
  --gold-bright:#f0d896;
  --gold-deep:#8a6a2c;
  --ember:#b5701f;
  --danger:#e2574c;
  --radius:14px;
  --shadow:0 30px 70px -28px rgba(0,0,0,.9);
  --gold-grad:linear-gradient(120deg,#9a7531 0%,#e9cd84 45%,#fff3c9 52%,#c9a24b 70%,#8a6a2c 100%);
  --ease:cubic-bezier(.16,.84,.44,1);
  --font:"Jost",-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --cinzel:"Cinzel","Cormorant Garamond",Georgia,serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(1200px 600px at 50% -10%,#1a1612 0%,var(--bg) 55%) no-repeat,var(--bg);
  color:var(--text);font-family:var(--font);line-height:1.55;
  min-height:100vh;display:flex;flex-direction:column;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:1240px;margin:0 auto;padding:0 22px}

/* --- Header ---------------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:50;
  background:rgba(10,10,11,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);
  font-size:1.45rem;letter-spacing:.06em}
.brand .mark{width:38px;height:38px;border-radius:50%;
  border:2px solid var(--gold);display:grid;place-items:center;
  font-family:var(--serif);font-weight:600;color:var(--gold);font-size:1rem;
  background:radial-gradient(circle at 50% 30%,rgba(212,175,55,.18),transparent 70%)}
.brand .logo-img{width:42px;height:42px;border-radius:50%;object-fit:cover;
  box-shadow:0 0 0 1px rgba(212,175,55,.4),0 4px 14px rgba(0,0,0,.5)}
.site-footer .brand .logo-img{width:54px;height:54px}
.brand b{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;font-weight:600}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{color:var(--muted);font-size:.92rem;letter-spacing:.03em;transition:color .2s}
.nav-links a:hover{color:var(--gold-soft)}
.cart-link{display:inline-flex;align-items:center;gap:7px;color:var(--text)!important}
.cart-badge{background:var(--gold);color:#1a1407;font-weight:700;border-radius:999px;
  min-width:20px;height:20px;padding:0 6px;font-size:.74rem;display:grid;place-items:center}

/* --- Boutons -------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:0;cursor:pointer;font-family:var(--font);font-weight:600;font-size:.92rem;
  padding:12px 22px;border-radius:999px;transition:transform .15s,box-shadow .2s,opacity .2s}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold-grad);color:#241a05;box-shadow:0 8px 24px rgba(212,175,55,.25)}
.btn-gold:hover{box-shadow:0 10px 30px rgba(212,175,55,.4)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-soft)}
.btn-danger{background:transparent;border:1px solid #5a2b27;color:#e9837a}
.btn-danger:hover{background:#2a1614}
.btn-sm{padding:8px 14px;font-size:.82rem}
.btn-block{width:100%}

/* --- Banniere d'accueil (image fournie) ----------------------------- */
.banner-hero{position:relative;width:100%;
  aspect-ratio:1490/1040;max-height:78vh;
  background:#000 center/cover no-repeat;
  display:flex;align-items:flex-end;justify-content:center}
.banner-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,var(--bg) 2%,rgba(10,10,11,.25) 30%,transparent 55%)}
.banner-hero .cta{position:relative;z-index:2;text-align:center;padding-bottom:38px}
.banner-hero .cta p{color:var(--text);margin:0 0 18px;font-size:1.05rem;
  text-shadow:0 2px 12px rgba(0,0,0,.8)}

/* --- Hero ------------------------------------------------------------ */
.hero{position:relative;padding:90px 0 70px;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(700px 280px at 50% 0,rgba(212,175,55,.16),transparent 70%)}
.hero-inner{position:relative}
.hero .eyebrow{color:var(--gold);letter-spacing:.32em;text-transform:uppercase;
  font-size:.78rem;margin-bottom:18px}
.hero h1{font-family:var(--serif);font-size:clamp(2.6rem,6vw,4.6rem);font-weight:600;
  margin:0 0 14px;line-height:1.05}
.hero h1 .gold{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent}
.hero p{color:var(--muted);max-width:620px;margin:0 auto 30px;font-size:1.08rem}
.gold-line{width:120px;height:2px;margin:26px auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}

/* --- Sections ------------------------------------------------------- */
.section{padding:54px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:30px;gap:16px;flex-wrap:wrap}
.section-head h2{font-family:var(--serif);font-size:2rem;font-weight:600;margin:0}
.section-head p{color:var(--muted);margin:6px 0 0}

/* --- Grille des competitions --------------------------------------- */
.comp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:26px}
.comp-card{position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);
  transition:transform .25s,border-color .25s}
.comp-card:hover{transform:translateY(-5px);border-color:rgba(212,175,55,.5)}
.comp-card .thumb{aspect-ratio:4/3;background:#000 center/cover no-repeat;position:relative}
.comp-card .thumb::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.94) 0%,rgba(0,0,0,.55) 35%,transparent 70%)}
.comp-card .body{position:absolute;left:0;right:0;bottom:0;padding:20px;z-index:2}
.comp-card .date{color:var(--gold-soft);font-size:.85rem;letter-spacing:.1em;
  text-transform:uppercase;font-weight:600;text-shadow:0 2px 8px rgba(0,0,0,.9)}
.comp-card h3{font-family:var(--serif);font-weight:700;
  font-size:clamp(1.8rem,2.6vw,2.3rem);line-height:1.1;margin:6px 0 3px;color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.95),0 0 30px rgba(0,0,0,.8)}
.comp-card .loc{color:#e8e3d8;font-size:.95rem;text-shadow:0 2px 8px rgba(0,0,0,.9)}
.comp-card .count{position:absolute;top:14px;right:14px;z-index:3;
  background:rgba(0,0,0,.6);border:1px solid var(--line);border-radius:999px;
  padding:5px 12px;font-size:.78rem;color:var(--gold-soft)}

/* --- Carte compétition SANS photo (infos mises en valeur) ----------- */
.info-card{position:relative;overflow:hidden;display:flex;flex-direction:column;
  min-height:230px;padding:26px;border-radius:var(--radius);
  background:linear-gradient(160deg,#1b1813 0%,var(--panel) 55%,#141417 100%);
  border:1px solid var(--line);box-shadow:var(--shadow);
  transition:transform .25s,border-color .25s}
.info-card:hover{transform:translateY(-5px);border-color:rgba(212,175,55,.6)}
.info-card .ic-glow{position:absolute;top:-60px;right:-60px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(212,175,55,.16),transparent 70%);pointer-events:none}
.info-card .ic-date{color:var(--gold-soft);font-size:.85rem;letter-spacing:.14em;
  text-transform:uppercase;font-weight:600}
.info-card h3{font-family:var(--serif);font-weight:700;
  font-size:clamp(1.8rem,2.7vw,2.4rem);line-height:1.08;margin:8px 0 4px;color:#fff}
.info-card .ic-loc{color:var(--muted);font-size:1rem}
.info-card .ic-line{height:1px;margin:16px 0;
  background:linear-gradient(90deg,var(--gold),transparent)}
.info-card .ic-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}
.info-card .ic-badge{border:1px solid rgba(212,175,55,.4);color:var(--gold-soft);
  border-radius:999px;padding:6px 14px;font-size:.85rem;font-weight:600;
  background:rgba(212,175,55,.06)}
.info-card .ic-cta{margin-top:16px;color:var(--text);font-size:.92rem;font-weight:600;
  opacity:.85;transition:color .2s}
.info-card:hover .ic-cta{color:var(--gold-soft)}

/* --- Galerie photos ------------------------------------------------- */
.search-bar{display:flex;gap:10px;margin-bottom:28px;max-width:520px}
.search-bar input{flex:1;background:var(--panel);border:1px solid var(--line);
  color:var(--text);padding:13px 18px;border-radius:999px;font-size:.95rem;outline:none}
.search-bar input:focus{border-color:var(--gold)}
.photo-grid{columns:4 250px;column-gap:18px}
.photo-item{break-inside:avoid;margin-bottom:18px;position:relative;
  border-radius:12px;overflow:hidden;background:var(--panel);border:1px solid var(--line);
  cursor:pointer;transition:border-color .2s}
.photo-item:hover{border-color:rgba(212,175,55,.55)}
.photo-item img{width:100%;user-select:none;-webkit-user-drag:none}
.photo-item .overlay{position:absolute;inset:0;display:flex;align-items:flex-end;
  justify-content:center;padding:16px;opacity:0;transition:opacity .2s;
  background:linear-gradient(to top,rgba(0,0,0,.8),transparent 60%)}
.photo-item:hover .overlay{opacity:1}
.photo-item .photo-name{position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:14px 12px 8px;font-size:.82rem;color:#fff;font-weight:600;text-align:center;
  letter-spacing:.02em;text-shadow:0 1px 6px rgba(0,0,0,.95);pointer-events:none;
  background:linear-gradient(to top,rgba(0,0,0,.82),transparent);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* --- Galerie coverflow (album glissant) ----------------------------- */
.coverflow{position:relative;margin:6px 0 22px;user-select:none;outline:none}
.cf-stage{position:relative;height:min(64vh,560px);overflow:hidden;
  touch-action:pan-y;cursor:grab}
.cf-stage:active{cursor:grabbing}
.cf-item{position:absolute;top:0;left:50%;height:100%;
  width:min(72%,520px);margin-left:calc(min(72%,520px) / -2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:transform .45s cubic-bezier(.22,.61,.36,1),opacity .45s;
  will-change:transform,opacity;cursor:pointer}
.cf-item img{max-width:100%;max-height:calc(100% - 38px);object-fit:contain;
  border-radius:12px;background:#000;border:1px solid var(--line);
  box-shadow:0 20px 50px rgba(0,0,0,.6);-webkit-user-drag:none;user-select:none}
.cf-item .cf-caption{margin-top:12px;color:#fff;font-family:var(--serif);
  font-size:1.15rem;letter-spacing:.02em;text-align:center;max-width:92%;
  text-shadow:0 2px 10px rgba(0,0,0,.85);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cf-item.is-active img{border-color:rgba(212,175,55,.55);
  box-shadow:0 26px 60px rgba(212,175,55,.28),0 12px 34px rgba(0,0,0,.7)}
.cf-item .overlay-hint{position:absolute;bottom:46px;opacity:0;transition:opacity .25s}
.cf-item.is-active .overlay-hint{opacity:1}
/* carte epreuve en coverflow */
.cf-item.cf-card .cf-cardbox{width:100%;height:calc(100% - 38px);border-radius:14px;
  position:relative;overflow:hidden;border:1px solid var(--line);
  background:#1b1813 center/cover no-repeat;box-shadow:0 20px 50px rgba(0,0,0,.6)}
.cf-item.cf-card .cf-cardbox::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.92),rgba(0,0,0,.3) 55%,transparent)}
.cf-item.cf-card.is-active .cf-cardbox{border-color:rgba(212,175,55,.55);
  box-shadow:0 26px 60px rgba(212,175,55,.28),0 12px 34px rgba(0,0,0,.7)}
.cf-item.cf-card .cf-cardtitle{position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:22px 18px;font-family:var(--serif);font-weight:700;color:#fff;
  font-size:clamp(1.5rem,2.6vw,2.2rem);line-height:1.1;text-align:center;
  text-shadow:0 2px 16px rgba(0,0,0,.95)}
.cf-item.cf-card .cf-count{position:absolute;top:14px;right:14px;z-index:3;
  background:rgba(0,0,0,.6);border:1px solid var(--line);border-radius:999px;
  padding:5px 12px;font-size:.78rem;color:var(--gold-soft)}
/* selection pack en coverflow */
.cf-item .pick{position:absolute;top:14px;left:14px;width:30px;height:30px;border-radius:50%;
  background:rgba(0,0,0,.6);border:2px solid #fff;z-index:5;display:none;
  place-items:center;color:#fff;font-size:1rem;font-weight:700;opacity:.9}
.cf-item.picked img{outline:3px solid var(--gold);outline-offset:-3px}
.cf-item.picked .pick{background:var(--gold-grad);border-color:transparent;color:#241a05;opacity:1}
/* fleches navigation */
.cf-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:60;
  width:52px;height:52px;border-radius:50%;border:1px solid var(--line);
  background:rgba(10,10,11,.7);backdrop-filter:blur(6px);color:var(--gold-soft);
  font-size:1.7rem;line-height:1;cursor:pointer;display:grid;place-items:center;
  transition:border-color .2s,color .2s,background .2s}
.cf-nav:hover{border-color:var(--gold);color:#fff;background:rgba(10,10,11,.92)}
.cf-nav:disabled{opacity:.25;cursor:default}
.cf-prev{left:4px}.cf-next{right:4px}
.cf-counter{text-align:center;color:var(--muted);font-size:.9rem;margin-top:2px}
.cf-counter b{color:var(--gold-soft)}
@media(max-width:680px){
  .cf-item{width:80%;margin-left:-40%}
  .cf-nav{width:44px;height:44px;font-size:1.4rem}
}

/* --- Modale photo --------------------------------------------------- */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;
  justify-content:center;padding:24px;background:rgba(0,0,0,.85);backdrop-filter:blur(4px)}
.modal.open{display:flex}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  max-width:980px;width:100%;max-height:90vh;overflow:auto;display:grid;
  grid-template-columns:1.4fr 1fr;box-shadow:var(--shadow)}
.modal-card .ph{background:#000;display:flex;align-items:center;justify-content:center;
  min-height:300px}
.modal-card .ph img{max-width:100%;max-height:78vh;object-fit:contain;display:block}
.modal-card .side{padding:28px}
.modal-card h3{font-family:var(--serif);font-size:1.5rem;margin:0 0 6px}
.price-tag{color:var(--gold-soft);font-size:1.6rem;font-family:var(--serif)}
.opt{border:1px solid var(--line);border-radius:10px;padding:14px;margin:10px 0;
  display:flex;align-items:center;justify-content:space-between;gap:12px}
.opt select{background:var(--panel-2);color:var(--text);border:1px solid var(--line);
  border-radius:8px;padding:8px 10px}
.modal-close{position:absolute;top:18px;right:22px;font-size:1.6rem;color:#fff;
  cursor:pointer;z-index:101;background:rgba(0,0,0,.5);width:42px;height:42px;
  border-radius:50%;display:grid;place-items:center;border:1px solid var(--line)}

/* --- Tables / panier ------------------------------------------------ */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow)}
.cart-row{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid var(--line)}
.cart-row img{width:78px;height:78px;object-fit:cover;border-radius:10px}
.cart-row .grow{flex:1}
.cart-total{display:flex;justify-content:space-between;align-items:center;
  font-size:1.3rem;font-family:var(--serif);margin-top:18px}
.cart-total b{color:var(--gold-soft)}
.tag{display:inline-block;background:var(--panel-2);border:1px solid var(--line);
  border-radius:999px;padding:3px 12px;font-size:.78rem;color:var(--muted)}
.tag.gold{color:var(--gold-soft);border-color:rgba(212,175,55,.4)}

/* --- Formulaires ---------------------------------------------------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;background:var(--panel-2);
  border:1px solid var(--line);color:var(--text);padding:12px 14px;border-radius:10px;
  font-size:.95rem;outline:none;font-family:var(--font)}
.field input:focus,.field textarea:focus{border-color:var(--gold)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* --- Layout deux colonnes (checkout) -------------------------------- */
.two-col{display:grid;grid-template-columns:1.3fr .9fr;gap:28px;align-items:start}

/* --- Admin ---------------------------------------------------------- */
.admin-wrap{display:grid;grid-template-columns:230px 1fr;min-height:calc(100vh - 72px)}
.admin-side{background:var(--bg-soft);border-right:1px solid var(--line);padding:24px 16px}
.admin-side a{display:block;padding:11px 14px;border-radius:9px;color:var(--muted);
  font-size:.92rem;margin-bottom:4px}
.admin-side a:hover,.admin-side a.active{background:var(--panel);color:var(--gold-soft)}
.admin-main{padding:30px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.stat .n{font-family:var(--serif);font-size:2rem;color:var(--gold-soft)}
.stat .l{color:var(--muted);font-size:.85rem}
table.data{width:100%;border-collapse:collapse}
table.data th,table.data td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);font-size:.9rem}
table.data th{color:var(--muted);font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
.pill{padding:3px 11px;border-radius:999px;font-size:.76rem;font-weight:600}
.pill.paid{background:rgba(70,160,90,.15);color:#7fd49a}
.pill.pending{background:rgba(212,175,55,.15);color:var(--gold-soft)}
.pill.shipped{background:rgba(90,130,220,.15);color:#9ab4ee}
.pill.cancelled{background:rgba(226,87,76,.15);color:#e9837a}
.pill.refunded{background:rgba(90,130,220,.15);color:#9ab4ee}

/* --- Annulation commande -------------------------------------------- */
.cancel-box{margin-top:12px}
.cancel-box summary{cursor:pointer;color:#e9837a;font-size:.85rem;
  list-style:none;display:inline-block;padding:4px 0}
.cancel-box summary::-webkit-details-marker{display:none}
.cancel-box textarea{width:100%;background:var(--panel-2);border:1px solid var(--line);
  color:var(--text);padding:10px 12px;border-radius:8px;margin:8px 0;font-family:var(--font);font-size:.9rem}

/* --- Edition des formats de tirage ---------------------------------- */
.fmt-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  padding:10px 0;border-bottom:1px solid var(--line)}
.fmt-edit{display:flex;gap:10px;align-items:center;flex-wrap:wrap;flex:1}
.fmt-edit input{background:var(--panel-2);border:1px solid var(--line);color:var(--text);
  padding:9px 12px;border-radius:8px;font-size:.9rem}
.fmt-edit input[name=label]{flex:1;min-width:160px}
.fmt-price{display:flex;align-items:center;gap:6px;color:var(--muted)}
.fmt-price input{width:90px}

/* --- Selection Pack (galerie epreuve) ------------------------------- */
.pack-bar{position:sticky;top:72px;z-index:30;display:flex;align-items:center;gap:14px;
  flex-wrap:wrap;background:rgba(23,23,26,.96);backdrop-filter:blur(8px);
  border:1px solid rgba(212,175,55,.4);border-radius:12px;padding:12px 18px;margin-bottom:20px}
.pack-bar .pb-info{color:var(--text);font-size:.92rem}
.pack-bar .pb-info b{color:var(--gold-soft)}
.pack-bar .pb-actions{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}
.photo-item.selectable{cursor:pointer}
.photo-item .pick{position:absolute;top:10px;left:10px;width:26px;height:26px;border-radius:50%;
  background:rgba(0,0,0,.55);border:2px solid #fff;z-index:4;display:grid;place-items:center;
  color:#fff;font-size:.9rem;font-weight:700;opacity:.85;transition:.15s}
.photo-item.picked{outline:3px solid var(--gold);outline-offset:-3px}
.photo-item.picked .pick{background:var(--gold-grad);border-color:transparent;color:#241a05;opacity:1}

/* --- Admin photo grid ----------------------------------------------- */
.admin-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.admin-photo{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.admin-photo img{aspect-ratio:1;object-fit:cover}
.admin-photo .acts{position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;transition:opacity .2s}
.admin-photo:hover .acts{opacity:1}

.dropzone{border:2px dashed var(--line);border-radius:12px;padding:34px;text-align:center;
  color:var(--muted);transition:border-color .2s,background .2s;cursor:pointer}
.dropzone:hover,.dropzone.drag{border-color:var(--gold);background:rgba(212,175,55,.05)}

/* --- Barre de progression upload ------------------------------------ */
.progress-wrap{margin-top:18px}
.progress-track{height:14px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:999px;overflow:hidden}
.progress-bar{height:100%;width:0;background:var(--gold-grad);
  transition:width .2s ease;border-radius:999px}
.progress-meta{display:flex;justify-content:space-between;align-items:center;
  margin-top:10px;font-size:.88rem;color:var(--muted);gap:12px;flex-wrap:wrap}
.progress-meta b{color:var(--gold-soft)}
.progress-err{color:#e9837a}
.upload-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:14px}

/* --- Regroupement par epreuve --------------------------------------- */
.epreuve-block{margin-bottom:26px}
.epreuve-head{display:flex;align-items:center;gap:12px;margin:0 0 12px}
.epreuve-head h4{font-family:var(--serif);font-size:1.2rem;margin:0;color:var(--gold-soft)}
.epreuve-head .line{flex:1;height:1px;background:var(--line)}
.epreuve-head .n{color:var(--muted);font-size:.82rem}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.chip{padding:7px 16px;border-radius:999px;border:1px solid var(--line);
  background:var(--panel);color:var(--muted);font-size:.86rem;cursor:pointer;transition:.2s}
.chip:hover{border-color:rgba(212,175,55,.5);color:var(--gold-soft)}
.chip.active{background:var(--gold-grad);color:#241a05;border-color:transparent;font-weight:600}

/* --- Carte "dossier" d'epreuve : titre bien lisible en gros ---------- */
.epreuve-card .body{padding:0;left:0;right:0;top:0;bottom:0;display:flex;
  align-items:center;justify-content:center;text-align:center}
.epreuve-card .ep-title{font-family:var(--serif);font-weight:700;
  font-size:clamp(1.5rem,2.4vw,2.2rem);color:#fff;line-height:1.15;padding:0 16px;
  text-shadow:0 2px 14px rgba(0,0,0,.9),0 0 30px rgba(0,0,0,.8)}
.epreuve-card .count{top:auto;bottom:14px;right:14px}
.epreuve-card .thumb::after{background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,.35))}

/* --- Commandes admin : item + retouche ------------------------------ */
.order-item{display:flex;gap:14px;align-items:flex-start;padding:12px;
  background:var(--panel-2);border:1px solid var(--line);border-radius:10px}
.order-item img{width:84px;height:84px;object-fit:cover;border-radius:8px;flex:none}
.order-item .grow{flex:1;min-width:0}
.order-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px}
.deliver-form-wrap{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* --- Zone drag-drop retouches -------------------------------------- */
.drop-retouche{border:2px dashed var(--line);border-radius:10px;padding:10px 16px;
  text-align:center;color:var(--muted);font-size:.82rem;cursor:pointer;
  transition:border-color .2s,background .2s;min-width:180px;user-select:none}
.drop-retouche:hover{border-color:rgba(212,175,55,.5);color:var(--gold-soft)}
.drop-retouche.drag{border-color:var(--gold);background:rgba(212,175,55,.08);color:var(--gold-soft)}
.drop-retouche.has-file{border-color:#5a8a5a;background:rgba(70,160,90,.07);color:#7fd49a}
.drop-retouche.uploading{border-color:var(--gold);background:rgba(212,175,55,.1);color:var(--gold-soft);
  cursor:progress;pointer-events:none}
.drop-retouche.error{border-color:#5a2b27;background:rgba(226,87,76,.08);color:#e9837a}
.drop-retouche *{pointer-events:none}
.drop-retouche .dr-icon{font-size:1.4rem;line-height:1;margin-bottom:4px}
.drop-retouche small{color:var(--muted);font-size:.76rem}

/* --- Footer --------------------------------------------------------- */
.site-footer{margin-top:auto;border-top:1px solid var(--line);padding:30px 0;
  color:var(--muted);font-size:.85rem;text-align:center}
.site-footer .brand{justify-content:center;margin-bottom:10px;font-size:1.1rem}

.empty{text-align:center;padding:70px 20px;color:var(--muted)}
.empty .big{font-family:var(--serif);font-size:1.6rem;color:var(--text);margin-bottom:8px}
.flash{background:rgba(226,87,76,.12);border:1px solid #5a2b27;color:#e9837a;
  padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:.9rem}

@media(max-width:860px){
  .two-col,.modal-card{grid-template-columns:1fr}
  .admin-wrap{grid-template-columns:1fr}
  .admin-side{display:flex;gap:6px;overflow-x:auto;border-right:0;border-bottom:1px solid var(--line)}
  .nav-links{gap:16px}
  .nav-links .hide-mobile{display:none}
}

/* ====================================================================== */
/* ===============  THEME LUXE 3D (pages publiques)  ==================== */
/* ====================================================================== */

/* grain de film */
.film-grain{position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

/* marque / nav en Cinzel */
.brand b{font-family:var(--cinzel);font-weight:600;letter-spacing:.22em}
.brand span{font-family:var(--cinzel);letter-spacing:.22em;font-size:1rem}

/* boutons luxe */
.btn-gold{background:linear-gradient(120deg,#e9cd84,#c9a24b 45%,#9a7531 100%);
  color:#1c1407;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  box-shadow:0 10px 30px -8px rgba(201,162,75,.6),inset 0 1px 0 rgba(255,255,255,.5)}
.btn-gold:hover{transform:translateY(-3px);
  box-shadow:0 18px 44px -10px rgba(201,162,75,.75),inset 0 1px 0 rgba(255,255,255,.6)}
.btn-ghost{letter-spacing:.12em;text-transform:uppercase;font-size:.82rem}

/* eyebrow + titres section facon mockup */
.lux-eyebrow{font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px}
.lux-title{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,4.4vw,2.9rem);
  line-height:1.05;color:var(--text);margin:0}
.lux-sub{color:var(--muted);font-size:.95rem;margin-top:8px;letter-spacing:.03em}

/* ---------------- HERO emblème ---------------- */
.lux-hero{position:relative;min-height:90vh;overflow:hidden;perspective:1400px;
  display:flex;flex-direction:column;align-items:center;justify-content:center}
.lux-hero .hero-bg{position:absolute;inset:-8%;z-index:0;
  background:
    radial-gradient(60% 75% at 8% 50%,rgba(181,112,31,.5),transparent 60%),
    radial-gradient(60% 80% at 92% 42%,rgba(201,142,40,.55),transparent 62%),
    radial-gradient(120% 120% at 50% 120%,rgba(140,92,30,.32),transparent 55%),
    var(--bg)}
.lux-hero .hero-photo{position:absolute;inset:-4%;z-index:1;
  background:center/cover no-repeat;transform:scale(1.04);
  will-change:transform;backface-visibility:hidden}
.lux-hero .hero-vig{position:absolute;inset:0;z-index:5;pointer-events:none;
  background:radial-gradient(110% 100% at 50% 46%,transparent 70%,rgba(8,6,10,.4) 92%,var(--bg) 100%)}
.lux-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:42%;z-index:5;
  pointer-events:none;background:linear-gradient(180deg,transparent,rgba(8,6,10,.6) 55%,var(--bg))}
.lux-emblem{position:relative;z-index:4;width:min(42vw,420px);aspect-ratio:1;border-radius:50%;
  display:grid;place-items:center;background:#0b0809;
  box-shadow:0 0 0 2px rgba(201,162,75,.15),0 0 0 10px rgba(8,6,10,.9),
    0 0 0 12px var(--gold),0 0 0 13px rgba(233,205,132,.7),
    0 0 60px rgba(201,162,75,.35),inset 0 0 80px rgba(0,0,0,.9)}
.lux-emblem::before{content:"";position:absolute;inset:-12px;border-radius:50%;
  background:conic-gradient(from 0deg,#7a5a22,#e9cd84,#8a6a2c,#f0d896,#7a5a22);
  filter:blur(8px);opacity:.45;z-index:-1;animation:emblemspin 18s linear infinite}
@keyframes emblemspin{to{transform:rotate(360deg)}}
.lux-emblem .lc{position:absolute;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(60px,10vw,120px);line-height:.7;opacity:.9;transform:translateY(-4px);
  background:linear-gradient(180deg,#f4e6c2,#c9a24b 60%,#8a6a2c);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.lux-emblem .wm{position:relative;text-align:center;z-index:2}
.lux-emblem .wm h1{font-family:var(--cinzel);font-weight:600;letter-spacing:.12em;
  font-size:clamp(20px,3vw,34px);
  background:linear-gradient(180deg,#fdf6e6,#dcbf7e 55%,#a07e3c);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.lux-emblem .wm p{font-family:var(--cinzel);letter-spacing:.5em;font-size:clamp(8px,1vw,11px);
  color:var(--gold-soft);margin-top:8px;padding-left:.5em}
.lux-hero-foot{position:absolute;bottom:7vh;z-index:6;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:18px}
.lux-hero-foot p{color:var(--muted);font-size:.95rem;letter-spacing:.05em;
  text-shadow:0 2px 12px rgba(0,0,0,.8)}

/* ---------------- Cartes compétitions 3D ---------------- */
.lux-comp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;margin-top:36px}
.lux-comp-card{position:relative;border-radius:12px;padding:26px 24px;cursor:pointer;
  background:linear-gradient(160deg,rgba(30,24,18,.9),rgba(13,10,12,.95));
  border:1px solid rgba(201,162,75,.16);transform-style:preserve-3d;will-change:transform;
  transition:border-color .4s,box-shadow .4s;min-height:230px;
  display:flex;flex-direction:column;justify-content:space-between}
.lux-comp-card:hover{border-color:rgba(201,162,75,.5);
  box-shadow:0 30px 60px -28px rgba(0,0,0,.9),0 0 30px -10px rgba(201,162,75,.25)}
.lux-comp-card .glow{position:absolute;inset:0;border-radius:12px;opacity:0;pointer-events:none;
  background:radial-gradient(220px 160px at var(--gx,50%) var(--gy,30%),rgba(233,205,132,.16),transparent 70%);
  transition:opacity .4s}
.lux-comp-card:hover .glow{opacity:1}
.lux-comp-card .date{font-size:.7rem;letter-spacing:.3em;color:var(--gold);
  text-transform:uppercase;transform:translateZ(30px)}
.lux-comp-card h3{font-family:var(--serif);font-weight:500;font-size:1.85rem;
  margin-top:12px;color:#fff;transform:translateZ(45px)}
.lux-comp-card .loc{color:var(--muted);font-size:.85rem;margin-top:4px;transform:translateZ(30px)}
.lux-comp-card .tags{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap;transform:translateZ(35px)}
.lux-comp-card .tag{font-size:.72rem;letter-spacing:.06em;color:var(--gold-soft);
  border:1px solid rgba(201,162,75,.3);border-radius:30px;padding:6px 14px;background:rgba(201,162,75,.05)}
.lux-comp-card .cta{margin-top:16px;color:var(--gold-soft);font-size:.82rem;
  letter-spacing:.1em;transform:translateZ(25px)}

/* ---------------- Galerie : reflets + relief sur les photos ---------- */
.photo-item .shine{position:absolute;inset:0;pointer-events:none;opacity:0;z-index:2;
  transition:opacity .4s;
  background:linear-gradient(115deg,transparent 35%,rgba(255,240,200,.18) 50%,transparent 65%)}
.photo-item:hover .shine{opacity:1}
.photo-item{transition:box-shadow .4s,border-color .2s}
.photo-item:hover{box-shadow:0 36px 70px -30px rgba(0,0,0,.95),0 0 32px -12px rgba(201,162,75,.3)}

@media(max-width:980px){
  .lux-comp-grid{grid-template-columns:repeat(2,1fr)}
  .lux-emblem{width:min(70vw,320px)}
}

/* --- Page conditions de vente / legal -------------------------------- */
.legal h3{font-family:var(--serif);color:var(--gold-soft);font-size:1.25rem;
  margin:22px 0 8px}
.legal h3:first-child{margin-top:0}
.legal p,.legal li{color:var(--text);font-size:.94rem;line-height:1.7}
.legal ul{margin:6px 0 6px 20px}
.legal b{color:#fff}

/* --- Bloc INFORMATIONS (page concours) ------------------------------- */
.info-notice{margin:22px 0 30px;padding:24px 26px;border-radius:14px;
  background:linear-gradient(160deg,rgba(30,24,18,.9),rgba(13,10,12,.95));
  border:1px solid rgba(201,162,75,.3);box-shadow:var(--shadow)}
.info-notice .in-head{display:flex;align-items:center;gap:10px;
  font-family:var(--cinzel);letter-spacing:.28em;color:var(--gold-soft);
  font-size:.95rem;margin-bottom:14px}
.info-notice .in-head::before{content:"\25C8";color:var(--gold)}
.info-notice p{color:var(--text);font-size:.9rem;line-height:1.65;margin:0 0 12px}
.info-notice p:last-child{margin-bottom:0}
.info-notice .hl{color:var(--gold-soft);font-weight:500}
.info-notice .warn{color:#e9c06a}

/* --- Lien Instagram (footer) ----------------------------------------- */
.ig-link{display:inline-flex;align-items:center;gap:8px;margin:10px 0 4px;
  color:var(--gold-soft);font-size:.9rem;letter-spacing:.02em;
  transition:color .25s,transform .25s}
.ig-link:hover{color:var(--gold-bright);transform:translateY(-1px)}
.ig-link svg{display:block}

/* ====================================================================== */
/* ===============  AJUSTEMENTS MOBILE  ================================= */
/* ====================================================================== */
/* Empeche le bouton de la barre de recherche de deborder (input flexible) */
.search-bar input{min-width:0}

@media(max-width:600px){
  /* Compétitions : 1 colonne pleine largeur sur téléphone */
  .lux-comp-grid{grid-template-columns:1fr}
  /* Barre de recherche : passe a la ligne proprement */
  .search-bar{flex-wrap:wrap}
  .search-bar input{flex:1 1 100%}
  .search-bar .btn{flex:1 1 100%;justify-content:center}
  /* Sections un peu plus compactes */
  .section{padding:42px 0}
  .info-notice{padding:18px 18px}
  .info-notice .in-head{letter-spacing:.18em}
  /* Hero un peu moins haut sur petit ecran */
  .lux-hero{min-height:78vh}
  /* Titres legaux/section plus mesures */
  .lux-title{font-size:clamp(1.8rem,7vw,2.4rem)}
}

/* Tableaux (admin/compta) scrollables horizontalement sur petit ecran */
@media(max-width:680px){
  table.data{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  /* Modale commande : image au-dessus, infos en dessous */
  .modal-card .ph{min-height:200px}
  /* Boutons pleine largeur dans la modale */
  .opt{flex-wrap:wrap}
  .opt select{flex:1 1 100%}
}
