
:root{
  --bg:#0b1020;
  --panel:#101a33;
  --panel2:#0f1730;
  --text:#eef2ff;
  --muted:#b7c0e2;
  --line:rgba(255,255,255,.12);
  --accent:#7cf7d4;
  --accent2:#d8b4fe;
  --shadow: 0 18px 50px rgba(0,0,0,.45);
  --radius: 18px;
  --radius2: 26px;
  --max: 1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 20% -10%, rgba(124,247,212,.18), transparent 60%),
    radial-gradient(900px 600px at 110% 10%, rgba(216,180,254,.14), transparent 55%),
    radial-gradient(900px 600px at 40% 120%, rgba(59,130,246,.10), transparent 55%),
    var(--bg);
  line-height:1.5;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(var(--max), 92vw); margin:0 auto}
.skip-link{position:absolute; left:-999px; top:12px; background:#fff; color:#000; padding:10px 12px; border-radius:12px}
.skip-link:focus{left:12px; z-index:9999}
.site-header{position:sticky; top:0; z-index:100; backdrop-filter: blur(10px); background: rgba(11,16,32,.68); border-bottom: 1px solid var(--line)}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding: 12px 0}
.brand{display:flex; gap:12px; align-items:center}
.brand-dot{width:14px; height:14px; border-radius:50%; background: linear-gradient(135deg, var(--accent), var(--accent2)); box-shadow: 0 0 0 6px rgba(124,247,212,.08)}
.brand-name{font-weight:700; letter-spacing:.2px}
.brand-sub{font-size:12px; color:var(--muted); margin-top:1px}
.nav{display:flex; align-items:center; gap:10px}
.nav-links{display:flex; align-items:center; gap:18px}
.nav-links a{font-size:14px; color:var(--muted)}
.nav-links a:hover{color:var(--text); text-decoration:none}
.nav-toggle{display:none; background:transparent; border:1px solid var(--line); border-radius:12px; padding:10px; color:var(--text)}
.burger{width:18px; height:2px; background:var(--text); display:block; position:relative}
.burger:before,.burger:after{content:""; position:absolute; left:0; width:18px; height:2px; background:var(--text)}
.burger:before{top:-6px}.burger:after{top:6px}
.btn{display:inline-flex; align-items:center; justify-content:center; padding: 12px 16px; background: linear-gradient(135deg, rgba(124,247,212,.95), rgba(216,180,254,.95)); color:#08101f; font-weight:700; border-radius: 14px; border:0; box-shadow: 0 14px 35px rgba(0,0,0,.35); text-decoration:none !important}
.btn:hover{filter:brightness(1.03)}
.btn-ghost{background:transparent; color:var(--text); border:1px solid var(--line); box-shadow:none}
.btn-small{padding:10px 12px; border-radius:12px; font-size:14px}
.hero{position:relative; padding: 56px 0 34px; overflow:hidden}
.hero-bg{position:absolute; inset:-1px; background: linear-gradient(180deg, rgba(11,16,32,.15), rgba(11,16,32,.95) 72%), radial-gradient(900px 600px at 30% 10%, rgba(124,247,212,.16), transparent 60%), radial-gradient(700px 500px at 85% 0%, rgba(216,180,254,.14), transparent 55%), url("assets/tina-contemple-la-lune.png"); background-size: cover; background-position: center; filter:saturate(1.02)}
.hero-grid{position:relative; display:grid; grid-template-columns: 1.1fr .9fr; gap: 34px; align-items:center}
.kicker{display:inline-flex; font-size:12px; letter-spacing:.16em; color: rgba(255,255,255,.82); background: rgba(255,255,255,.10); border: 1px solid var(--line); padding: 8px 10px; border-radius: 999px; margin:0 0 12px}
h1{font-family: Fraunces, Georgia, serif; font-weight:700; font-size: clamp(34px, 4vw, 56px); line-height:1.02; margin: 0 0 12px; text-shadow: 0 2px 18px rgba(0,0,0,.35)}
.accent{background: linear-gradient(135deg, var(--accent), var(--accent2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.lead{color:rgba(255,255,255,.92); font-size:18px; max-width: 60ch; margin: 0 0 18px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin: 18px 0 20px}
.quick-facts{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px; margin: 0 0 16px}
.quick-facts div{background: rgba(16,26,51,.55); border: 1px solid var(--line); border-radius: 16px; padding: 12px; box-shadow: var(--shadow)}
.quick-facts dt{font-size:12px; color:var(--muted); margin-bottom:4px}
.quick-facts dd{margin:0; font-weight:700}
.note{margin:0; color: rgba(255,255,255,.78); font-size: 13px; border-left: 3px solid rgba(124,247,212,.55); padding-left: 12px}
.poster{margin:0; background: rgba(16,26,51,.55); border: 1px solid var(--line); border-radius: var(--radius2); overflow:hidden; box-shadow: var(--shadow)}
.poster img{width:100%}
.poster figcaption{padding: 10px 12px; font-size: 12px; color: var(--muted); border-top: 1px solid var(--line)}
.section{padding: 56px 0}
.section-alt{background: radial-gradient(700px 500px at 15% 0%, rgba(216,180,254,.10), transparent 60%), radial-gradient(900px 600px at 90% 10%, rgba(124,247,212,.10), transparent 55%), rgba(255,255,255,.03); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-cta{background: radial-gradient(1000px 700px at 30% 0%, rgba(124,247,212,.14), transparent 60%), radial-gradient(800px 600px at 90% 10%, rgba(216,180,254,.12), transparent 60%), rgba(255,255,255,.02); border-top:1px solid var(--line)}
.section-grid{display:grid; grid-template-columns: 1.15fr .85fr; gap: 24px; align-items:start}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:16px}
h2{font-family: Fraunces, Georgia, serif; font-size: 34px; letter-spacing:.2px; margin:0 0 10px}
h3{margin:0 0 8px; font-size:18px}
.body{margin: 0 0 12px; color: rgba(255,255,255,.88)}
.muted{color:var(--muted)}
.small{font-size:13px; color: rgba(255,255,255,.82)}
.aside-card,.contact-card{background: rgba(16,26,51,.55); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; box-shadow: var(--shadow)}
.callout{display:flex; gap:12px; align-items:flex-start; background: rgba(124,247,212,.08); border: 1px solid rgba(124,247,212,.18); border-radius: var(--radius); padding: 14px; margin-top: 18px}
.callout-icon{width:34px; height:34px; border-radius: 12px; display:grid; place-items:center; background: rgba(216,180,254,.16); border:1px solid rgba(255,255,255,.14)}
.callout-title{margin:0; font-weight:700}
.callout-text{margin:4px 0 0; color:rgba(255,255,255,.86)}
.info-list{display:grid; gap:10px; margin-top:12px}
.info-list div{display:flex; justify-content:space-between; gap:14px; padding:10px 12px; border:1px solid rgba(255,255,255,.1); border-radius:14px; background:rgba(255,255,255,.03)}
.info-list span{color:var(--muted); font-size:13px}
.info-list strong{text-align:right; font-size:14px}
.info-btn{margin-top:14px}
.gallery{display:grid; grid-template-columns: repeat(12, 1fr); gap: 12px}
.card{border: 1px solid var(--line); background: rgba(16,26,51,.55); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow)}
.media-card{padding:0; cursor:pointer; text-align:left; transition: transform .18s ease, filter .18s ease}
.media-card:hover{transform: translateY(-3px); filter:brightness(1.03)}
.media-card img{width:100%; height: 250px; object-fit:cover}
.card-cap{display:flex; justify-content:space-between; align-items:center; padding: 10px 12px; border-top:1px solid var(--line); font-size:13px; color: rgba(255,255,255,.86)}
.tag{font-size:12px; padding: 4px 10px; border-radius: 999px; border:1px solid rgba(255,255,255,.14); color: var(--muted); background: rgba(255,255,255,.06)}
.gallery .media-card:nth-child(1){grid-column: span 6}
.gallery .media-card:nth-child(2){grid-column: span 3}
.gallery .media-card:nth-child(3){grid-column: span 3}
.gallery .media-card:nth-child(4){grid-column: span 5}
.gallery .media-card:nth-child(5){grid-column: span 3}
.gallery .media-card:nth-child(6){grid-column: span 4}
.tech-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; margin-top:10px}
.clean-list{margin:0; padding-left:18px; display:grid; gap:8px}
.cta{display:grid; grid-template-columns: 1.25fr .75fr; gap: 20px; align-items:start}
.contact-grid{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-top: 14px}
.cta-aside{background: rgba(16,26,51,.55); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; box-shadow: var(--shadow); display:flex; flex-direction:column; gap:10px}
.site-footer{border-top: 1px solid var(--line); padding: 18px 0 30px; background: rgba(11,16,32,.75)}
.footer-inner{display:flex; flex-direction:column; gap:6px}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}
.lightbox{position:fixed; inset:0; z-index:200; display:grid; place-items:center}
.lightbox[hidden]{display:none}
.lightbox-backdrop{position:absolute; inset:0; background: rgba(0,0,0,.76); backdrop-filter: blur(6px)}
.lightbox-figure{position:relative; width:min(980px, 92vw); max-height: 88vh; margin:0; border-radius: 20px; border: 1px solid rgba(255,255,255,.14); overflow:hidden; background: rgba(16,26,51,.9); box-shadow: 0 28px 80px rgba(0,0,0,.6)}
.lightbox-figure img{width:100%; max-height: 74vh; object-fit:contain; background: #050814}
.lightbox-figure figcaption{padding: 10px 12px}
.lightbox-close{position:absolute; top:10px; right:10px; width:40px; height:40px; border-radius: 14px; border:1px solid rgba(255,255,255,.18); background: rgba(0,0,0,.35); color: #fff; font-size: 26px; cursor:pointer}
.lightbox-close:hover{background: rgba(0,0,0,.5)}
@media (max-width: 920px){
  .hero-grid,.section-grid,.cta{grid-template-columns:1fr}
  .gallery .media-card,.tech-grid,.contact-grid{grid-column: span 12; grid-template-columns:1fr}
  .gallery .media-card{grid-column: span 12}
  .media-card img{height: 220px}
  .quick-facts{grid-template-columns:1fr}
  .nav-toggle{display:inline-flex}
  .nav-links{display:none; position:absolute; right: 4vw; top: 64px; background: rgba(11,16,32,.92); border: 1px solid var(--line); border-radius: 16px; padding: 10px; flex-direction:column; align-items:stretch; gap: 10px; min-width: 220px}
  .nav-links a{padding: 10px 10px; border-radius: 12px}
  .nav-links a:hover{background: rgba(255,255,255,.06)}
  .nav-links.is-open{display:flex}
}
