/* ════════════════════════════════════════════════════════
   TIITII NBA — main.css (reset + layout + toutes sections)
   ════════════════════════════════════════════════════════ */

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--c-bg);color:var(--c-text);font-family:var(--f-body);
  font-size:var(--t-md);line-height:var(--lh-normal);overflow-x:hidden;cursor:none}
@media(hover:none){body{cursor:auto}}
img,video,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{background:none;border:none;cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
::selection{background:var(--c-accent);color:#fff}
:focus-visible{outline:2px solid var(--c-accent);outline-offset:3px;border-radius:var(--r-sm)}

/* ── Skip link ───────────────────────────────────────── */
.skip-link{position:fixed;top:-100%;left:var(--s-4);background:var(--c-accent);
  color:#fff;padding:var(--s-2) var(--s-5);border-radius:0 0 var(--r-md) var(--r-md);
  font-size:var(--t-sm);font-weight:600;z-index:var(--z-cursor);
  transition:top var(--dur-fast)}
.skip-link:focus{top:0}

/* ── Cursor ──────────────────────────────────────────── */
.cursor{position:fixed;pointer-events:none;z-index:var(--z-cursor);
  border-radius:var(--r-full);transform:translate(-50%,-50%)}
.cursor-dot{width:6px;height:6px;background:var(--c-accent);top:0;left:0}
.cursor-ring{width:34px;height:34px;border:1.5px solid rgba(8,135,248,.5);
  top:0;left:0;
  transition:width var(--dur-base) var(--ease-spring),
             height var(--dur-base) var(--ease-spring),
             background var(--dur-base) var(--ease),
             border-color var(--dur-base) var(--ease)}
body.cur-hover .cursor-ring{width:52px;height:52px;
  background:var(--c-accent-dim);border-color:var(--c-accent)}
@media(hover:none){.cursor{display:none}}

/* ── Loader ──────────────────────────────────────────── */
#loader{position:fixed;inset:0;background:var(--c-bg);display:flex;
  flex-direction:column;align-items:center;justify-content:center;
  gap:var(--s-5);z-index:9999;
  transition:opacity var(--dur-slow) var(--ease),
             visibility var(--dur-slow) var(--ease)}
#loader.out{opacity:0;visibility:hidden;pointer-events:none}
.ld-logo{font-family:var(--f-title);font-size:clamp(2.5rem,8vw,5rem);
  letter-spacing:var(--ls-3);color:var(--c-text)}
.ld-logo span{color:var(--c-accent)}
.ld-bar{width:clamp(180px,36vw,320px);height:2px;background:var(--c-border);
  border-radius:var(--r-full);overflow:hidden}
.ld-bar-fill{height:100%;width:0;background:var(--c-accent);
  border-radius:var(--r-full);transition:width .25s var(--ease-out);
  box-shadow:0 0 12px var(--c-accent-glow)}
.ld-sub{font-family:var(--f-sub);font-size:var(--t-xs);
  letter-spacing:var(--ls-3);text-transform:uppercase;color:var(--c-dim);
  font-weight:600}

/* ── Header ──────────────────────────────────────────── */
#header{position:fixed;top:0;left:0;right:0;height:var(--header-h);
  z-index:var(--z-header);
  transition:background var(--dur-base) var(--ease),
             border-color var(--dur-base) var(--ease),
             box-shadow var(--dur-base) var(--ease)}
#header.scrolled{background:rgba(16,16,16,.93);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--c-border);
  box-shadow:0 4px 28px rgba(0,0,0,.45)}
.nav{display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);gap:var(--s-6)}
.nav-logo{font-family:var(--f-title);font-size:var(--t-3xl);
  letter-spacing:var(--ls-2);color:var(--c-text);flex-shrink:0;
  transition:color var(--dur-fast)}
.nav-logo:hover{color:var(--c-accent)}
.nav-logo span{color:var(--c-accent)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-family:var(--f-sub);font-size:.7rem;letter-spacing:var(--ls-2);
  text-transform:uppercase;color:var(--c-muted);padding:var(--s-2) var(--s-3);
  border-radius:var(--r-sm);font-weight:600;white-space:nowrap;
  transition:color var(--dur-fast),background var(--dur-fast)}
.nav-links a:hover,.nav-links a.active{color:var(--c-text);
  background:rgba(255,255,255,.06)}
.nav-cta{background:var(--c-accent)!important;color:#fff!important;
  padding:var(--s-2) var(--s-5)!important}
.nav-cta:hover{background:var(--c-accent-2)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;
  padding:var(--s-2);z-index:var(--z-10);flex-shrink:0}
.nav-burger span{display:block;width:24px;height:2px;background:var(--c-text);
  border-radius:var(--r-full);
  transition:transform var(--dur-base) var(--ease),
             opacity var(--dur-base) var(--ease)}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:920px){
  .nav-burger{display:flex}
  .nav-links{position:fixed;inset:0;background:rgba(16,16,16,.97);
    backdrop-filter:blur(20px);flex-direction:column;align-items:center;
    justify-content:center;gap:var(--s-5);transform:translateX(100%);
    transition:transform var(--dur-slow) var(--ease);z-index:99}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:var(--t-md);padding:var(--s-3) var(--s-8)}
}

/* ── Containers ──────────────────────────────────────── */
.wrap{width:100%;max-width:var(--w-max);margin-inline:auto;padding-inline:var(--s-6)}
.wrap--wide{max-width:var(--w-wide)}
.wrap--md{max-width:var(--w-md)}
.wrap--sm{max-width:var(--w-sm)}

/* ── Sections ────────────────────────────────────────── */
.sec{padding-block:var(--s-24)}
.sec-label{display:inline-block;font-family:var(--f-sub);font-size:var(--t-xs);
  letter-spacing:var(--ls-3);text-transform:uppercase;color:var(--c-accent);
  font-weight:700;margin-bottom:var(--s-3)}
.sec-title{font-family:var(--f-title);
  font-size:clamp(var(--t-5xl),8vw,var(--t-9xl));
  line-height:var(--lh-tight);letter-spacing:var(--ls-n);
  margin-bottom:var(--s-4)}
.sec-rule{width:48px;height:2px;background:var(--c-accent);
  margin-bottom:var(--s-10);box-shadow:0 0 14px var(--c-accent-glow)}
.sec-sub{font-size:var(--t-lg);color:var(--c-muted);
  line-height:var(--lh-relaxed);max-width:58ch}
.glow-sep{height:1px;
  background:linear-gradient(90deg,transparent,var(--c-accent-dim) 20%,
    var(--c-accent-glow) 50%,var(--c-accent-dim) 80%,transparent)}

/* ── Boutons ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:var(--s-2);
  font-family:var(--f-sub);font-size:var(--t-xs);letter-spacing:var(--ls-2);
  text-transform:uppercase;font-weight:700;
  padding:var(--s-3) var(--s-6);border-radius:var(--r-sm);
  border:1px solid transparent;cursor:pointer;user-select:none;
  white-space:nowrap;
  transition:background var(--dur-fast),color var(--dur-fast),
             border-color var(--dur-fast),box-shadow var(--dur-fast),
             transform var(--dur-fast)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}
.btn-primary:hover{background:var(--c-accent-2);border-color:var(--c-accent-2);
  box-shadow:var(--sh-glow)}
.btn-outline{background:transparent;color:var(--c-text);border-color:var(--c-border-h)}
.btn-outline:hover{border-color:var(--c-accent);color:var(--c-accent);
  box-shadow:0 0 18px var(--c-accent-dim)}
.btn-lg{padding:var(--s-4) var(--s-10);font-size:var(--t-sm)}
.btn-sm{padding:var(--s-2) var(--s-4);font-size:.65rem}
.btn-full{width:100%;justify-content:center}

/* ── Formulaires ─────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-5)}
.field label{font-family:var(--f-sub);font-size:var(--t-xs);
  letter-spacing:var(--ls-2);text-transform:uppercase;color:var(--c-muted);font-weight:600}
.field input,.field select,.field textarea{
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-sm);color:var(--c-text);
  padding:var(--s-3) var(--s-4);resize:vertical;
  appearance:none;-webkit-appearance:none;
  transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--c-accent);
  box-shadow:0 0 0 3px var(--c-accent-dim)}
.field input::placeholder,.field textarea::placeholder{color:var(--c-dim)}
.field input.err,.field textarea.err{border-color:var(--c-error)}
.field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(242,242,242,.35)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right var(--s-4) center;
  padding-right:var(--s-10);cursor:pointer}
.field input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer}

/* ── Social links ────────────────────────────────────── */
.socials{display:flex;align-items:center;gap:var(--s-3);flex-wrap:wrap}
.soc-link{display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:var(--r-full);
  border:1px solid var(--c-border);color:var(--c-muted);
  transition:color var(--dur-fast),border-color var(--dur-fast),
             background var(--dur-fast),transform var(--dur-fast)}
.soc-link svg{width:18px;height:18px;fill:currentColor}
.soc-link:hover{color:var(--c-accent);border-color:var(--c-accent);
  background:var(--c-accent-dim);transform:translateY(-2px)}

/* ── Reveal animations ───────────────────────────────── */
.rv,.rv-l,.rv-r{opacity:0;
  transition:opacity var(--dur-slow) var(--ease-out),
             transform var(--dur-slow) var(--ease-out)}
.rv{transform:translateY(28px)}
.rv-l{transform:translateX(-28px)}
.rv-r{transform:translateX(28px)}
.rv.vis,.rv-l.vis,.rv-r.vis{opacity:1;transform:translate(0)}
.rv-d1{transition-delay:80ms}
.rv-d2{transition-delay:160ms}
.rv-d3{transition-delay:240ms}
.rv-d4{transition-delay:320ms}

/* ══════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════ */
#hero{position:relative;min-height:100svh;display:flex;align-items:center;
  overflow:hidden}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-grid{position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(8,135,248,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(8,135,248,.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 75% 75% at 50% 45%,#000,transparent)}
.hero-glow{position:absolute;top:10%;left:50%;transform:translateX(-50%);
  width:min(700px,90vw);height:min(700px,90vw);
  background:radial-gradient(circle,rgba(8,135,248,.10) 0%,transparent 68%);
  pointer-events:none}
.hero-content{position:relative;z-index:1;
  padding-top:var(--header-h);padding-bottom:var(--s-16)}
.hero-eye{font-family:var(--f-sub);font-size:var(--t-xs);
  letter-spacing:var(--ls-3);text-transform:uppercase;
  color:var(--c-accent);font-weight:700;margin-bottom:var(--s-4);
  opacity:0;animation:fadeUp .8s .5s var(--ease-out) forwards}
.hero-title{font-family:var(--f-title);
  font-size:clamp(4.5rem,18vw,14rem);line-height:.88;
  letter-spacing:var(--ls-n);margin-bottom:var(--s-4);
  opacity:0;animation:fadeUp .8s .7s var(--ease-out) forwards}
.hero-title-acc{display:block;color:var(--c-accent);
  text-shadow:0 0 100px rgba(8,135,248,.45)}
.hero-tag{font-size:clamp(var(--t-md),2.5vw,var(--t-xl));
  color:var(--c-muted);margin-bottom:var(--s-8);font-style:italic;
  letter-spacing:.02em;
  opacity:0;animation:fadeUp .8s .9s var(--ease-out) forwards}
.hero-ctas{display:flex;gap:var(--s-4);flex-wrap:wrap;margin-bottom:var(--s-10);
  opacity:0;animation:fadeUp .8s 1.1s var(--ease-out) forwards}
.hero-socials{opacity:0;animation:fadeUp .8s 1.3s var(--ease-out) forwards}
.hero-scroll{position:absolute;bottom:var(--s-8);left:50%;
  transform:translateX(-50%);display:flex;flex-direction:column;
  align-items:center;gap:var(--s-2);z-index:1;
  opacity:0;animation:fadeIn 1s 2s var(--ease-out) forwards}
.scroll-line{width:1px;height:52px;
  background:linear-gradient(to bottom,transparent,var(--c-accent));
  animation:scrollPulse 2.2s ease-in-out infinite}
.hero-scroll span{font-family:var(--f-sub);font-size:var(--t-2xs);
  letter-spacing:var(--ls-3);text-transform:uppercase;color:var(--c-dim);font-weight:700}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollPulse{0%,100%{opacity:.35}50%{opacity:1}}

/* ══════════════════════════════════════════════════════
   STREAMING STRIP
══════════════════════════════════════════════════════ */
#streaming{background:var(--c-surface);border-block:1px solid var(--c-border);
  padding-block:var(--s-5);overflow:hidden}
.stream-track{display:flex;gap:var(--s-6);align-items:center;width:max-content;
  animation:scroll-x 28s linear infinite}
.stream-track:hover{animation-play-state:paused}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.stream-item{display:flex;align-items:center;gap:var(--s-3);white-space:nowrap;
  font-family:var(--f-sub);font-size:var(--t-xs);font-weight:700;
  letter-spacing:var(--ls-2);text-transform:uppercase;color:var(--c-muted);
  padding:var(--s-2) var(--s-5);border-radius:var(--r-full);
  border:1px solid var(--c-border);
  transition:color var(--dur-fast),border-color var(--dur-fast)}
.stream-item svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}
.stream-item:hover{color:var(--c-accent);border-color:var(--c-accent)}
.stream-sep{color:var(--c-border-h);font-size:var(--t-2xl);font-family:var(--f-title)}

/* ══════════════════════════════════════════════════════
   MUSIQUE
══════════════════════════════════════════════════════ */
.music-embed{border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--c-border);margin-bottom:var(--s-8)}
.music-embed iframe{display:block;width:100%}
.music-plats{display:flex;gap:var(--s-3);flex-wrap:wrap;justify-content:center}
.plat-btn{display:inline-flex;align-items:center;gap:var(--s-2);
  font-family:var(--f-sub);font-size:var(--t-xs);font-weight:700;
  letter-spacing:var(--ls-2);text-transform:uppercase;
  padding:var(--s-3) var(--s-5);border-radius:var(--r-sm);
  border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-muted);
  transition:all var(--dur-fast)}
.plat-btn svg{width:18px;height:18px;flex-shrink:0}
.plat-btn:hover{border-color:var(--c-border-h);color:var(--c-text);
  background:var(--c-surface-2);transform:translateY(-2px)}

/* ══════════════════════════════════════════════════════
   VIDÉOS — Lazy façades
══════════════════════════════════════════════════════ */
.vids-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5)}
.vid-facade{position:relative;aspect-ratio:16/9;
  border-radius:var(--r-md);overflow:hidden;cursor:pointer;
  background:var(--c-surface-2);border:1px solid var(--c-border);
  transition:box-shadow var(--dur-base),border-color var(--dur-base)}
.vid-facade:hover{box-shadow:var(--sh-md);border-color:var(--c-border-h)}
.vid-facade img{width:100%;height:100%;object-fit:cover;
  transition:transform var(--dur-slow) var(--ease)}
.vid-facade:hover img{transform:scale(1.04)}
.vid-facade-ph{width:100%;height:100%;display:flex;align-items:center;
  justify-content:center;font-family:var(--f-title);font-size:var(--t-4xl);
  color:var(--c-accent-dim)}
.vid-play{position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;background:rgba(0,0,0,.35);
  transition:background var(--dur-fast)}
.vid-facade:hover .vid-play{background:rgba(0,0,0,.15)}
.vid-play-btn{width:64px;height:64px;border-radius:var(--r-full);
  background:rgba(8,135,248,.9);border:2px solid #fff;
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--dur-fast),background var(--dur-fast)}
.vid-facade:hover .vid-play-btn{transform:scale(1.1);background:var(--c-accent)}
.vid-play-btn svg{width:24px;height:24px;fill:#fff;margin-left:4px}
.vid-meta{padding:var(--s-3) 0 var(--s-2)}
.vid-title-text{font-family:var(--f-sub);font-size:var(--t-sm);font-weight:700;
  letter-spacing:var(--ls-1);color:var(--c-text);margin-bottom:var(--s-1)}
.vid-date{font-size:var(--t-xs);color:var(--c-dim)}
.vid-facade iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
@media(max-width:900px){.vids-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.vids-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════
   GALERIE + LIGHTBOX
══════════════════════════════════════════════════════ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;gap:var(--s-3)}
.g-item{position:relative;overflow:hidden;border-radius:var(--r-md);
  cursor:pointer;border:1px solid var(--c-border);
  transition:box-shadow var(--dur-base),border-color var(--dur-base)}
.g-item:nth-child(1),.g-item:nth-child(5){grid-column:span 2;grid-row:span 2}
.g-item:hover{box-shadow:var(--sh-glow);border-color:var(--c-accent-dim)}
.g-ph{width:100%;height:100%;display:flex;align-items:center;
  justify-content:center;font-family:var(--f-title);
  font-size:clamp(var(--t-2xl),4vw,var(--t-5xl));
  color:rgba(8,135,248,.25);
  background:linear-gradient(135deg,var(--c-surface),var(--c-surface-2));
  transition:transform var(--dur-slow) var(--ease)}
.g-item img{width:100%;height:100%;object-fit:cover;
  transition:transform var(--dur-slow) var(--ease)}
.g-item:hover .g-ph,.g-item:hover img{transform:scale(1.06)}
.g-over{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,135,248,.18),transparent);
  opacity:0;transition:opacity var(--dur-base)}
.g-item:hover .g-over{opacity:1}
@media(max-width:768px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g-item:nth-child(1),.g-item:nth-child(5){grid-column:span 1;grid-row:span 1}}
@media(max-width:480px){
  .gallery{grid-template-columns:1fr;grid-auto-rows:180px}}
/* Lightbox */
#lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  z-index:var(--z-modal);opacity:0;visibility:hidden;
  transition:opacity var(--dur-base),visibility var(--dur-base)}
#lightbox.open{opacity:1;visibility:visible}
.lb-inner{position:relative;max-width:90vw;max-height:90vh}
.lb-img{max-width:90vw;max-height:82vh;object-fit:contain;border-radius:var(--r-md)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(0,0,0,.5);
  border:1px solid var(--c-border-h);border-radius:var(--r-full);
  color:var(--c-text);width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  font-size:var(--t-lg);cursor:pointer;
  transition:background var(--dur-fast),border-color var(--dur-fast)}
.lb-close{top:-52px;right:0}
.lb-prev{left:-56px;top:50%;transform:translateY(-50%)}
.lb-next{right:-56px;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{
  background:var(--c-accent);border-color:var(--c-accent)}
.lb-caption{position:absolute;bottom:-40px;left:50%;transform:translateX(-50%);
  font-size:var(--t-xs);color:var(--c-muted);white-space:nowrap}

/* ══════════════════════════════════════════════════════
   AGENDA
══════════════════════════════════════════════════════ */
.events{display:flex;flex-direction:column;gap:var(--s-4)}
.ev-card{display:grid;grid-template-columns:80px 1fr auto;
  align-items:center;gap:var(--s-6);
  padding:var(--s-5) var(--s-6);background:var(--c-surface);
  border:1px solid var(--c-border);border-radius:var(--r-md);
  transition:border-color var(--dur-base),background var(--dur-base),
             box-shadow var(--dur-base)}
.ev-card:hover{border-color:var(--c-accent-dim);background:var(--c-surface-2);
  box-shadow:var(--sh-md)}
.ev-date{text-align:center;border-right:1px solid var(--c-border);
  padding-right:var(--s-6)}
.ev-day{font-family:var(--f-title);font-size:var(--t-5xl);
  line-height:1;color:var(--c-accent)}
.ev-month{font-family:var(--f-sub);font-size:var(--t-xs);
  letter-spacing:var(--ls-2);text-transform:uppercase;
  color:var(--c-dim);font-weight:600}
.ev-name{font-family:var(--f-sub);font-size:var(--t-xl);font-weight:700;
  letter-spacing:var(--ls-1);margin-bottom:var(--s-1)}
.ev-venue{font-size:var(--t-sm);color:var(--c-muted)}
.ev-badge{font-family:var(--f-sub);font-size:var(--t-2xs);font-weight:700;
  letter-spacing:var(--ls-2);text-transform:uppercase;
  padding:var(--s-2) var(--s-4);border-radius:var(--r-full);border:1px solid}
.ev-badge.open{color:var(--c-success);border-color:var(--c-success);
  background:rgba(34,197,94,.1)}
.ev-badge.soon{color:var(--c-warn);border-color:var(--c-warn);
  background:rgba(245,158,11,.1)}
.ev-badge.sold{color:var(--c-error);border-color:var(--c-error);
  background:rgba(255,77,77,.1)}
@media(max-width:640px){
  .ev-card{grid-template-columns:60px 1fr;gap:var(--s-4)}
  .ev-card>:last-child{grid-column:2}}

/* ══════════════════════════════════════════════════════
   BOUTIQUE
══════════════════════════════════════════════════════ */
.shop-cs{max-width:520px;margin:0 auto;text-align:center;
  padding:var(--s-20) var(--s-6)}
.shop-cs-big{font-family:var(--f-title);
  font-size:clamp(4.5rem,14vw,9rem);line-height:.9;
  letter-spacing:var(--ls-n);margin-bottom:var(--s-6)}
.shop-cs-big span{color:var(--c-accent);
  text-shadow:0 0 80px rgba(8,135,248,.5)}
.shop-cs-sub{color:var(--c-muted);margin-bottom:var(--s-8);
  line-height:var(--lh-relaxed)}
.notify-form{display:flex;gap:var(--s-2);max-width:420px;margin:0 auto}
.notify-form input{flex:1;background:var(--c-surface);
  border:1px solid var(--c-border);border-radius:var(--r-sm);
  color:var(--c-text);padding:var(--s-3) var(--s-4);
  transition:border-color var(--dur-fast)}
.notify-form input:focus{outline:none;border-color:var(--c-accent)}
.notify-form input::placeholder{color:var(--c-dim)}
@media(max-width:480px){.notify-form{flex-direction:column}}

/* ══════════════════════════════════════════════════════
   À PROPOS
══════════════════════════════════════════════════════ */
.about-grid{display:grid;grid-template-columns:1fr 1.8fr;
  gap:var(--s-16);align-items:center}
.about-img-wrap{position:relative}
.about-deco{position:absolute;width:60px;height:60px;
  border-color:var(--c-accent);border-style:solid}
.about-deco-tl{top:-20px;left:-20px;border-width:2px 0 0 2px}
.about-deco-br{bottom:-20px;right:-20px;border-width:0 2px 2px 0}
.about-frame{aspect-ratio:3/4;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--c-border)}
.about-ph{width:100%;height:100%;display:flex;align-items:center;
  justify-content:center;font-family:var(--f-title);
  font-size:clamp(4rem,10vw,7rem);color:rgba(8,135,248,.2);
  background:linear-gradient(135deg,var(--c-surface),var(--c-surface-2))}
.about-ph img{width:100%;height:100%;object-fit:cover}
.about-bio{font-size:var(--t-lg);color:var(--c-muted);
  line-height:var(--lh-relaxed);margin-bottom:var(--s-5)}
.about-quote{font-style:italic;color:var(--c-accent)!important;
  font-size:var(--t-xl)!important}
.about-stats{display:flex;gap:var(--s-10);margin-top:var(--s-8);
  padding-top:var(--s-8);border-top:1px solid var(--c-border)}
.stat-val{display:block;font-family:var(--f-title);font-size:var(--t-5xl);
  color:var(--c-accent);line-height:1;margin-bottom:var(--s-1)}
.stat-lbl{font-family:var(--f-sub);font-size:var(--t-2xs);
  letter-spacing:var(--ls-3);text-transform:uppercase;color:var(--c-dim);font-weight:700}
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr}
  .about-img-wrap{max-width:300px;margin:0 auto}
  .about-stats{gap:var(--s-6)}}

/* ══════════════════════════════════════════════════════
   RÉSEAUX
══════════════════════════════════════════════════════ */
.soc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
.soc-card{display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:var(--s-2);padding:var(--s-10) var(--s-4);
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-md);text-align:center;
  transition:border-color var(--dur-base),background var(--dur-base),
             transform var(--dur-base) var(--ease-spring),
             box-shadow var(--dur-base)}
.soc-card:hover{border-color:var(--c-accent);background:var(--c-surface-2);
  transform:translateY(-5px);box-shadow:var(--sh-glow)}
.soc-icon{font-size:2.2rem;margin-bottom:var(--s-2)}
.soc-name{font-family:var(--f-sub);font-size:var(--t-sm);font-weight:700;
  letter-spacing:var(--ls-1);text-transform:uppercase}
.soc-handle{font-size:var(--t-xs);color:var(--c-dim)}
@media(max-width:768px){.soc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.soc-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════
   BOOKING
══════════════════════════════════════════════════════ */
.booking-grid{display:grid;grid-template-columns:1fr 1.3fr;
  gap:var(--s-12);align-items:start}
.bk-info{display:flex;flex-direction:column;gap:var(--s-6)}
.bk-item{display:flex;gap:var(--s-4);align-items:flex-start}
.bk-icon{font-size:1.6rem;flex-shrink:0;margin-top:2px}
.bk-label{font-family:var(--f-sub);font-size:var(--t-sm);font-weight:700;
  letter-spacing:var(--ls-1);text-transform:uppercase;margin-bottom:var(--s-1)}
.bk-text{font-size:var(--t-sm);color:var(--c-muted);line-height:var(--lh-relaxed)}
.bk-form-card{background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:var(--s-8)}
.bk-form-title{font-family:var(--f-sub);font-size:var(--t-xl);font-weight:700;
  letter-spacing:var(--ls-1);text-transform:uppercase;margin-bottom:var(--s-6)}
@media(max-width:900px){.booking-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════════
   COLLAB
══════════════════════════════════════════════════════ */
.collab-tabs{display:flex;gap:var(--s-2);
  margin-bottom:var(--s-8);border-bottom:1px solid var(--c-border);
  padding-bottom:var(--s-3)}
.c-tab{font-family:var(--f-sub);font-size:var(--t-xs);font-weight:700;
  letter-spacing:var(--ls-2);text-transform:uppercase;
  padding:var(--s-2) var(--s-6);border-radius:var(--r-sm);
  color:var(--c-dim);border:1px solid transparent;cursor:pointer;
  transition:all var(--dur-fast)}
.c-tab.active,.c-tab:hover{color:var(--c-accent);border-color:var(--c-accent);
  background:var(--c-accent-dim)}
.c-panel{display:none}
.c-panel.active{display:block}
.c-form-wrap{max-width:600px;margin:0 auto;
  background:var(--c-surface);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:var(--s-8)}

/* ══════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════ */
#footer{padding-block:var(--s-16) var(--s-10);
  border-top:1px solid var(--c-border)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:var(--s-8);margin-bottom:var(--s-12)}
.footer-brand{font-family:var(--f-title);font-size:var(--t-4xl);
  letter-spacing:var(--ls-2);margin-bottom:var(--s-2)}
.footer-brand span{color:var(--c-accent)}
.footer-tagline{font-size:var(--t-sm);color:var(--c-dim);
  font-style:italic;margin-bottom:var(--s-5)}
.footer-head{font-family:var(--f-sub);font-size:var(--t-2xs);
  letter-spacing:var(--ls-3);text-transform:uppercase;
  color:var(--c-dim);margin-bottom:var(--s-4);font-weight:700}
.footer-ul{display:flex;flex-direction:column;gap:var(--s-3)}
.footer-ul a{font-size:var(--t-sm);color:var(--c-muted);
  transition:color var(--dur-fast)}
.footer-ul a:hover{color:var(--c-accent)}
.footer-bot{display:flex;align-items:center;justify-content:space-between;
  padding-top:var(--s-6);border-top:1px solid var(--c-border);
  gap:var(--s-4);flex-wrap:wrap}
.footer-copy{font-size:var(--t-xs);color:var(--c-dim)}
.footer-legal{display:flex;gap:var(--s-5);flex-wrap:wrap}
.footer-legal a{font-size:var(--t-xs);color:var(--c-dim);
  transition:color var(--dur-fast)}
.footer-legal a:hover{color:var(--c-accent)}
@media(max-width:800px){
  .footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bot{flex-direction:column;align-items:flex-start}}

/* ══════════════════════════════════════════════════════
   TOAST
══════════════════════════════════════════════════════ */
#toast{position:fixed;bottom:var(--s-6);right:var(--s-6);
  z-index:var(--z-toast);display:flex;flex-direction:column;
  gap:var(--s-2);max-width:360px;pointer-events:none}
.toast-item{background:var(--c-surface-2);border:1px solid var(--c-border);
  border-radius:var(--r-md);padding:var(--s-4) var(--s-5);
  font-size:var(--t-sm);box-shadow:var(--sh-lg);pointer-events:auto;
  animation:toastIn var(--dur-base) var(--ease-out) forwards}
.toast-item.success{border-left:3px solid var(--c-success)}
.toast-item.error{border-left:3px solid var(--c-error)}
.toast-item.info{border-left:3px solid var(--c-accent)}
.toast-item.out{animation:toastOut var(--dur-base) var(--ease) forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
@keyframes toastOut{from{opacity:1;transform:none}to{opacity:0;transform:translateX(20px)}}

/* ══════════════════════════════════════════════════════
   COOKIE BANNER
══════════════════════════════════════════════════════ */
#cookie{position:fixed;bottom:var(--s-4);left:var(--s-4);right:var(--s-4);
  max-width:520px;background:var(--c-surface-2);
  border:1px solid var(--c-border);border-radius:var(--r-lg);
  padding:var(--s-5) var(--s-6);z-index:var(--z-over);
  box-shadow:var(--sh-lg);
  animation:slideUp var(--dur-slow) var(--ease-out) forwards}
#cookie[hidden]{display:none}
#cookie p{font-size:var(--t-sm);color:var(--c-muted);
  line-height:var(--lh-relaxed);margin-bottom:var(--s-4)}
#cookie a{color:var(--c-accent)}
.cookie-btns{display:flex;gap:var(--s-3)}
.c-btn{font-family:var(--f-sub);font-size:var(--t-xs);font-weight:700;
  letter-spacing:var(--ls-1);text-transform:uppercase;
  padding:var(--s-2) var(--s-5);border-radius:var(--r-sm);
  border:1px solid var(--c-border);color:var(--c-muted);
  background:transparent;cursor:pointer;
  transition:all var(--dur-fast)}
.c-btn:hover{border-color:var(--c-border-h);color:var(--c-text)}
.c-btn.ok{background:var(--c-accent);border-color:var(--c-accent);color:#fff}
.c-btn.ok:hover{background:var(--c-accent-2);border-color:var(--c-accent-2)}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ══════════════════════════════════════════════════════
   PAGES LÉGALES (mentions, RGPD…)
══════════════════════════════════════════════════════ */
.legal-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);
  background:rgba(16,16,16,.95);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--c-border);z-index:var(--z-header);
  display:flex;align-items:center}
.legal-main{padding-top:calc(var(--header-h) + var(--s-12));
  padding-bottom:var(--s-20)}
.legal-h1{font-family:var(--f-title);
  font-size:clamp(var(--t-4xl),7vw,var(--t-7xl));
  letter-spacing:var(--ls-n);margin-bottom:var(--s-10)}
.legal-h2{font-family:var(--f-sub);font-size:var(--t-xl);font-weight:700;
  letter-spacing:var(--ls-2);text-transform:uppercase;
  color:var(--c-accent);margin-bottom:var(--s-3);margin-top:var(--s-8)}
.legal-p{color:var(--c-muted);line-height:var(--lh-relaxed);
  margin-bottom:var(--s-4)}
.legal-footer{padding-block:var(--s-6);border-top:1px solid var(--c-border);
  text-align:center;font-size:var(--t-xs);color:var(--c-dim)}

/* ══════════════════════════════════════════════════════
   UTILITAIRES
══════════════════════════════════════════════════════ */
.text-accent{color:var(--c-accent)}
.text-muted{color:var(--c-muted)}
.text-center{text-align:center}
.mt-8{margin-top:var(--s-8)}
.mt-6{margin-top:var(--s-6)}
