﻿:root{
  --bg:#0b0c0e;
  --card:#0f1113;
  --muted:#9aa0a6;
  --accent:#6ff3ff;
  --glass:rgba(255,255,255,0.03);
  --text:#e6eef6;
}

/* Prefer system light scheme before JS runs */
@media (prefers-color-scheme: light){
  :root{
    --bg:#f6f7f9;
    --card:#ffffff;
    --muted:#5f6770;
    --accent:#27d3df;
    --glass:rgba(0,0,0,0.03);
    --text:#0b0c0e;
  }
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  background: radial-gradient(1200px 600px at 10% 10%, rgba(16,24,32,0.35), transparent), var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
body.no-scroll{overflow:hidden}
body.zoom-open .site-header,
body.zoom-open main,
body.zoom-open .site-footer{filter: blur(10px) saturate(0.9); transform: scale(0.985); transition: filter .3s ease, transform .3s ease}
.site-header{
  position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:18px 32px;background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);backdrop-filter: blur(6px);z-index:40;border-bottom:1px solid rgba(255,255,255,0.02);
}
.brand{display:flex;align-items:center;gap:12px}
.logo{height:36px;width:36px;object-fit:contain}
.brand-name{font-weight:600;letter-spacing:0.6px}
.nav a{color:var(--muted);text-decoration:none;margin-left:18px}
.nav a:hover{color:var(--accent)}
main{padding-top:88px}
.hero{position:relative;min-height:86vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-inner{max-width:920px;padding:48px;text-align:center;z-index:10}
.title{font-size:clamp(28px,6vw,48px);margin:0 0 12px}
.subtitle{color:var(--muted);margin:0 0 20px}
.btn{display:inline-block;padding:12px 18px;border-radius:10px;background:linear-gradient(90deg,var(--accent),#8affff);color:#071018;text-decoration:none;font-weight:600;margin:6px;box-shadow:0 6px 18px rgba(0,0,0,0.45);transition:transform .18s ease,opacity .18s}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--muted)}
.btn:hover{transform:translateY(-4px)}
.bg-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.about, .works, .contact{padding:88px 24px;max-width:1100px;margin:0 auto}
.about h2, .works h2, .contact h2{margin:0 0 24px;font-size:22px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;align-items:stretch}
/* Carousel mode when many cards */
.cards.carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:18px;padding-bottom:8px;position:relative}
.cards.carousel::-webkit-scrollbar{height:8px}
.cards.carousel::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:20px}
.cards.carousel .card{flex:0 0 calc(33.333% - 12px);min-width:280px;max-width:360px;scroll-snap-align:start}
.carousel-controls{position:absolute;left:0;right:0;pointer-events:none}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);height:36px;width:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.06);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;backdrop-filter:blur(4px);pointer-events:auto}
.carousel-btn:hover{background:rgba(255,255,255,0.1)}
.carousel-btn.prev{left:6px}
.carousel-btn.next{right:6px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.card{background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);border:1px solid rgba(255,255,255,0.03);padding:14px;border-radius:12px;overflow:hidden;transform:translateY(0);transition:transform .28s cubic-bezier(.2,.9,.3,1),box-shadow .28s}
.card:hover{transform:translateY(-10px);box-shadow:0 20px 40px rgba(2,6,23,0.6)}
.card-media{height:160px;border-radius:10px;background:linear-gradient(135deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:600;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;display:block}
.card-body{padding:12px}
.placeholder{color:var(--muted)}
[data-zoomable]{cursor:zoom-in}
.rating{display:flex;align-items:center;gap:8px;margin-top:8px;color:var(--muted);font-size:14px}
.rating .stars{position:relative;display:inline-block;line-height:1;font-size:14px;letter-spacing:2px}
.rating .stars{position:relative;display:inline-block;line-height:1;font-size:14px;letter-spacing:2px}
.rating .stars::before{content:\★★★★★\ ; color:rgba(255,255,255,0.15)}
.rating .stars::after{content:\★★★★★\ ; position:absolute;left:0;top:0;white-space:nowrap;overflow:hidden;width:calc((var(--rating,0) / 5) * 100%);color:#ffcc4d}
.site-footer{padding:32px;text-align:center;color:var(--muted)}

/* small animations */
.zoom-overlay{position:fixed;inset:0;display:block;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .28s ease, visibility .28s ease;z-index:100}
.zoom-overlay.active{opacity:1;visibility:visible;pointer-events:auto}
.zoom-overlay::before{content:"";position:absolute;inset:0;background:rgba(8,10,12,0.55);backdrop-filter: blur(6px)}
.zoom-close{position:absolute;top:16px;right:16px;height:36px;width:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);color:var(--text);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;z-index:2;transition:transform .18s ease,opacity .18s ease}
.zoom-close:hover{transform:scale(1.06)}
.zoom-nav{position:absolute;top:50%;transform:translateY(-50%);height:40px;width:40px;border-radius:50%;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.06);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;backdrop-filter:blur(4px)}
.zoom-nav.prev{left:12px}
.zoom-nav.next{right:12px}
.zoom-nav:hover{background:rgba(255,255,255,0.1)}
.zoom-clone{position:fixed;z-index:1;will-change:transform;border-radius:12px;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.06);transition:transform .42s cubic-bezier(.2,.9,.2,1), border-radius .32s ease}
.zoom-clone.expanded{border-radius:16px}
.zoom-overlay.active .zoom-clone{cursor:zoom-out}
/* article-like content inside overlay */
.zoom-content{position:fixed;inset:auto 0 0 0;top:6%;margin:0 auto;max-width:920px;width:92vw;background:linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));border:1px solid rgba(255,255,255,0.06);border-radius:16px;padding:24px 22px;box-shadow:0 40px 120px rgba(0,0,0,0.55);z-index:2;max-height:88vh;overflow:auto;opacity:0;transform:translateY(12px);transition:opacity .28s ease, transform .28s ease}
.zoom-content.visible{opacity:1;transform:none}
.zoom-content header{margin-bottom:12px}
.zoom-content h2{margin:0 0 6px;font-size:clamp(22px,3.2vw,28px)}
.zoom-content .meta{color:var(--muted);font-size:14px;margin:0 0 12px}
.zoom-content p{line-height:1.6;margin:12px 0}
.zoom-content figure{margin:16px 0;border-radius:12px;overflow:hidden;background:linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));border:1px solid rgba(255,255,255,0.06)}
.zoom-content img{display:block;width:100%;height:auto}

/* Buttons */
.btn.small{padding:8px 12px;font-size:14px}

/* Light theme */
html[data-theme="light"]{
  --bg:#f6f7f9;
  --card:#ffffff;
  --muted:#5f6770;
  --accent:#27d3df;
  --glass:rgba(0,0,0,0.03);
  --text:#0b0c0e;
}
/* Explicit dark theme variables (overrides @media light when toggled) */
html[data-theme="dark"]{
  --bg:#0b0c0e;
  --card:#0f1113;
  --muted:#9aa0a6;
  --accent:#6ff3ff;
  --glass:rgba(255,255,255,0.03);
  --text:#e6eef6;
}
html[data-theme="light"] body{
  background: radial-gradient(1200px 600px at 10% 10%, rgba(0,0,0,0.04), transparent), var(--bg);
  color:var(--text);
}
html[data-theme="light"] .site-header{
  background:linear-gradient(180deg, rgba(0,0,0,0.04), transparent);
  border-bottom-color: rgba(0,0,0,0.06);
}
html[data-theme="light"] .card{
  background:linear-gradient(180deg, rgba(0,0,0,0.02), transparent);
  border-color: rgba(0,0,0,0.06);
}
html[data-theme="light"] .card:hover{box-shadow:0 20px 40px rgba(0,0,0,0.12)}
html[data-theme="light"] .carousel-btn{border-color:rgba(0,0,0,0.12);background:rgba(0,0,0,0.06)}
html[data-theme="light"] .zoom-overlay::before{background:rgba(255,255,255,0.55)}
html[data-theme="light"] .zoom-content{
  background:linear-gradient(180deg, rgba(0,0,0,0.03), rgba(0,0,0,0.02));
  border-color: rgba(0,0,0,0.08);
  box-shadow:0 40px 120px rgba(0,0,0,0.2);
}
html[data-theme="light"] .zoom-nav{border-color:rgba(0,0,0,0.12);background:rgba(0,0,0,0.06)}
html[data-theme="light"] .contact-form input,
html[data-theme="light"] .contact-form textarea{border-color:rgba(0,0,0,0.08)} .rating .stars::before{content:" \\2605\\2605\\2605\\2605\\2605\;color:rgba(255,255,255,0.15)"}
html[data-theme="light"] main > section#about::before{background:linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.01))}
html[data-theme="light"] main > section#works::before{background:linear-gradient(180deg, rgba(0,0,0,0.03), rgba(0,0,0,0.015))}
html[data-theme="light"] main > section#art::before{background:linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.01))}
html[data-theme="light"] main > section#jeu::before{background:linear-gradient(180deg, rgba(0,0,0,0.03), rgba(0,0,0,0.015))}
html[data-theme="light"] main > section#contact::before{background:linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.01))}

/* small animations */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.fade-up.inview{opacity:1;transform:none}

/* Full-bleed alternating backgrounds aligned with sections */
main > section{position:relative; isolation:isolate}
main > section:not(.hero)::before{
  content:"";
  position:absolute;
  inset:0 calc(50% - 50vw);
  z-index:-1;
  pointer-events:none;
}
/* Fix alternance per named sections to avoid drift when adding/removing sections */
main > section#about::before{
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
}
main > section#works::before{
  background:linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
}
main > section#art::before{
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
}
main > section#jeu::before{
  background:linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
}
main > section#contact::before{
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
}

@media (max-width:720px){
  .site-header{padding:12px 18px}
  .hero-inner{padding:28px}
  .cards.carousel .card{flex:0 0 80vw;min-width:80vw;max-width:80vw}
}

/* Contact layout (override) */
.contact .contact-form{
  display:grid;
  grid-template-columns:1fr 1fr auto;
  gap:12px;
  align-items:start;
  max-width:900px;
}
.contact .contact-form input,
.contact .contact-form textarea{
  background:var(--card);
  border:1px solid rgba(255,255,255,0.12);
  color:var(--text);
  padding:12px;
  border-radius:8px;
  width:100%;
}
.contact .contact-form textarea{min-height:140px;grid-column:1 / span 2}
.contact .contact-form button{grid-column:3;align-self:end;height:48px}

@media (max-width:720px){
  .contact .contact-form{grid-template-columns:1fr}
  .contact .contact-form textarea{grid-column:1}
  .contact .contact-form button{grid-column:1;height:auto;justify-self:start}
}

/* Stars fix (override any broken rules above) */
.rating .stars{position:relative;display:inline-block;line-height:1;font-size:14px;letter-spacing:2px}
.rating .stars::before{content:"★★★★★";color:rgba(255,255,255,0.15)}
.rating .stars::after{content:"★★★★★";position:absolute;left:0;top:0;white-space:nowrap;overflow:hidden;width:calc((var(--rating,0) / 5) * 100%);color:#ffcc4d}

/* Stars fix: override any broken earlier rules */
.rating .stars{position:relative;display:inline-block;line-height:1;font-size:14px;letter-spacing:2px}
.rating .stars::before{content:"★★★★★";color:rgba(255,255,255,0.15)}
.rating .stars::after{content:"★★★★★";position:absolute;left:0;top:0;white-space:nowrap;overflow:hidden;width:calc((var(--rating,0) / 5) * 100%);color:#ffcc4d}

html[data-theme='dark']{--bg:#0b0c0e;--card:#0f1113;--muted:#9aa0a6;--accent:#6ff3ff;--glass:rgba(255,255,255,0.03);--text:#e6eef6}
html[data-theme='dark'] body{background: radial-gradient(1200px 600px at 10% 10%, rgba(16,24,32,0.35), transparent), var(--bg);}


/* Rating stars (final override for consistency) */
.rating .stars{position:relative;display:inline-block;line-height:1;font-size:14px;letter-spacing:2px}
.rating .stars::before{content:"\2605\2605\2605\2605\2605";color:rgba(255,255,255,0.15)}
.rating .stars::after{content:"\2605\2605\2605\2605\2605";position:absolute;left:0;top:0;white-space:nowrap;overflow:hidden;width:calc((var(--rating,0) / 5) * 100%);color:#ffcc4d}
