/* ========= Dala cosmic — casino-italia ========= */
:root{
  --void:#000000; --bone:#ffffff; --ash:#bdbdbd; --smoke:#9a9a9a;
  --plum:#8052ff; --amber:#ffb829; --lichen:#15846e;
  --hair:rgba(255,255,255,.10); --hair2:rgba(255,255,255,.18);
  --font:'Inter',ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --max:1200px; --gap:60px; --rad:24px;
}
*{box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{margin:0;background:var(--void);color:var(--bone);font-family:var(--font);
  font-weight:400;line-height:1.5;letter-spacing:.025em;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

a{color:var(--bone);text-decoration:none}
a:hover{color:var(--plum)}

/* Typo display ultra-fine */
h1{font-weight:200;font-size:clamp(2.6rem,7vw,4.9rem);line-height:.95;
  letter-spacing:-.04em;margin:.1em 0 .4em}
h2{font-weight:200;font-size:clamp(1.7rem,3.6vw,2.25rem);line-height:1.05;
  letter-spacing:-.02em;margin:1.8em 0 .6em}
h3{font-weight:600;font-size:1.05rem;letter-spacing:.01em;margin:0}
.lead{font-size:1.125rem;line-height:1.55;color:var(--ash);max-width:60ch}
p{max-width:62ch}

/* Eyebrow kicker */
.eyebrow{display:inline-block;font-weight:600;font-size:.75rem;text-transform:uppercase;
  letter-spacing:.14em;color:var(--plum);margin:0 0 18px}
.eyebrow.bone{color:var(--bone)}

/* ===== Nav ===== */
.site-head{position:sticky;top:0;z-index:20;background:rgba(0,0,0,.72);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--hair)}
.site-head .wrap{display:flex;align-items:center;gap:24px;
  padding-top:18px;padding-bottom:18px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:1.125rem;
  letter-spacing:-.01em;color:var(--bone)}
.brand:hover{color:var(--bone)}
.brand .mark{width:22px;height:22px;flex:none}
.site-head nav{display:flex;gap:26px;margin-left:auto;align-items:center;flex-wrap:wrap}
.site-head nav a{font-weight:400;font-size:.875rem;letter-spacing:.02em;color:var(--smoke)}
.site-head nav a:hover{color:var(--bone)}
.pill{display:inline-block;background:var(--plum);color:var(--bone);
  font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;
  padding:13px 18px;border-radius:var(--rad);line-height:1}
.pill:hover{color:var(--bone);filter:brightness(1.12)}
.pill-ghost{background:transparent;border:1px solid var(--amber);color:var(--amber)}
.pill-ghost:hover{color:var(--amber);background:rgba(255,184,41,.08)}

.crumbs{font-size:.8rem;color:var(--smoke);padding-top:28px;letter-spacing:.02em}
.crumbs a{color:var(--smoke)} .crumbs a:hover{color:var(--bone)}
.crumbs span[aria-current]{color:var(--ash)}
.crumbs span{color:var(--plum)}

main.wrap{padding-top:36px;padding-bottom:96px}
section{margin-top:var(--gap)}

/* ===== Hero ===== */
.hero{position:relative;min-height:78vh;display:grid;
  grid-template-columns:minmax(0,480px) 1fr;align-items:center;gap:40px;
  padding-top:40px}
.hero-text{position:relative;z-index:2}
.hero-canvas{position:relative;height:100%;min-height:60vh}
.hero-canvas canvas{position:absolute;inset:0;width:100%;height:100%}

/* particle blocks (ambient sous une section) */
.field{position:relative}
.field canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.7}
.field>*:not(canvas){position:relative;z-index:1}

/* ===== Cards / grilles ===== */
.card-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.city-grid,.region-list{display:grid;gap:14px;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));list-style:none;padding:0}
.card,.city-grid a,.region-list a{display:flex;flex-direction:column;gap:6px;
  border:1px solid var(--hair);border-radius:var(--rad);padding:22px;color:var(--bone);
  transition:border-color .2s}
.card:hover,.city-grid a:hover,.region-list a:hover{border-color:var(--plum);color:var(--bone)}
.card strong{font-weight:600;font-size:1.05rem}
.card span,.city-grid span,.region-list span{color:var(--smoke);font-size:.8rem}
.city-grid a,.region-list a{flex-direction:row;justify-content:space-between;align-items:center}
.city-grid span,.region-list span{background:rgba(128,82,255,.14);color:var(--plum);
  padding:2px 9px;border-radius:20px;font-weight:600}

ul.pillars{list-style:none;padding:0;display:grid;gap:14px;max-width:560px}
ul.pillars a{display:flex;justify-content:space-between;align-items:center;
  border:1px solid var(--hair);border-radius:var(--rad);padding:20px 24px;
  font-weight:600;font-size:1.05rem}
ul.pillars a::after{content:"→";color:var(--plum)}
ul.pillars a:hover{border-color:var(--plum)}

/* ===== Établissements ===== */
ul.venues{list-style:none;padding:0;display:grid;gap:12px}
.venue{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;
  border:1px solid var(--hair);border-radius:var(--rad);padding:16px 20px}
.venue:hover{border-color:var(--hair2)}
.v-icon{width:20px;height:20px;flex:none}
.v-name{font-weight:600}
.v-type{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--lichen);border:1px solid rgba(21,132,110,.4);padding:3px 10px;border-radius:20px}
.v-addr{color:var(--smoke);font-size:.85rem;flex:1 1 100%}
.v-map{font-size:.8rem;color:var(--amber)}
.v-map:hover{color:var(--amber);text-decoration:underline}

/* ===== Destination (hero photo duotone) ===== */
.dest-hero{position:relative;border-radius:var(--rad);overflow:hidden;
  border:1px solid var(--hair);margin-bottom:30px;aspect-ratio:16/9}
.dest-hero img{width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) contrast(1.05) brightness(.62);mix-blend-mode:luminosity}
.dest-hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(128,82,255,.30),rgba(0,0,0,.85)),
            radial-gradient(120% 80% at 30% 10%,rgba(128,82,255,.35),transparent 60%);
  mix-blend-mode:screen;pointer-events:none}
.dest-hero .cap{position:absolute;left:24px;bottom:20px;z-index:2;
  font-weight:200;letter-spacing:-.02em}

dl.facts{display:grid;grid-template-columns:auto 1fr;gap:.5em 1.5em;
  border:1px solid var(--hair);border-radius:var(--rad);padding:22px;max-width:640px}
dl.facts dt{color:var(--smoke);font-size:.85rem}
dl.facts dd{margin:0}
ul.games{columns:2;max-width:520px;color:var(--ash)}

.btn{display:inline-block;background:var(--plum);color:var(--bone);font-weight:600;
  font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;
  padding:14px 20px;border-radius:var(--rad)}
.btn:hover{color:var(--bone);filter:brightness(1.12)}

/* ===== FAQ ===== */
.faq details{border:1px solid var(--hair);border-radius:var(--rad);padding:16px 22px;margin:10px 0}
.faq details[open]{border-color:var(--hair2)}
.faq summary{cursor:pointer;font-weight:600;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";color:var(--plum);margin-right:12px;font-weight:400}
.faq details[open] summary::before{content:"–"}
.faq p{color:var(--ash);margin:.7em 0 0}

.related{margin-top:2.4em}
.related ul{list-style:none;padding:0;display:grid;gap:8px;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.related a{color:var(--ash);font-size:.92rem}
.related a:hover{color:var(--plum)}

/* ===== Footer ===== */
.site-foot{border-top:1px solid var(--hair);margin-top:96px;padding:40px 0;
  font-size:.82rem;color:var(--smoke);letter-spacing:.02em}
.site-foot .age{color:var(--ash)}
.site-foot .age strong{color:var(--plum)}
.site-foot p{max-width:none;margin:.5em 0}

/* ===== Responsive ===== */
@media(max-width:820px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-canvas{order:-1;min-height:46vh;width:100%}
  ul.games{columns:1}
}
@media(max-width:520px){
  .site-head nav{gap:16px}
  .site-head nav a:not(.pill){display:none}
}
