:root{
  --bg:#f5f7fb;
  --panel:#ffffff;
  --muted:#5a6573;
  --text:#1f2430;
  --accent:#f0d090;
  --accent-2:#f0a0a0;
  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.25);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 600px at 80% -10%, rgba(123,220,255,.20), transparent),
              radial-gradient(1000px 700px at -10% 0%, rgba(199,255,107,.15), transparent),
              var(--bg);
  line-height:1.6;
}

/* Layout */
.container{width:min(1100px,92%);margin:0 auto}
.site-header{position:sticky;top:0;z-index:60;background:rgba(11,12,16,.8);backdrop-filter:blur(10px);border-bottom:1px solid rgba(20,24,31,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{font-weight:800;letter-spacing:.4px}
.nav a{margin-left:18px;color:var(--text);text-decoration:none;opacity:.88}
.nav a:hover{opacity:1}

.hero{padding:56px 0 18px}
.hero-inner h1{margin:0 0 12px;font-size:clamp(26px,4vw,40px)}
.hero-inner p{margin:0 0 22px;color:var(--muted)}

.filters{display:flex;flex-wrap:wrap;gap:10px}
.filter-btn{
  border:1px solid rgba(20,24,31,.16);
  background:linear-gradient(180deg,rgba(20,24,31,.06),rgba(255,255,255,.02));
  color:var(--text);
  padding:8px 14px;border-radius:999px;cursor:pointer;transition:.2s;box-shadow:var(--shadow)
}
.filter-btn.active, .filter-btn:hover{border-color:rgba(20,24,31,.36)}

.grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(240px,1fr));
  gap:16px;
  margin:20px 0 40px;
}
.card{
  background:var(--panel);
  border:1px solid rgba(20,24,31,.08);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease;
  cursor:pointer;
}
.card:hover{transform:translateY(-2px)}
.card img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.card figcaption{padding:12px 12px 14px;color:var(--muted);font-size:.95rem}

/* Sections */
.about,.contact{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid rgba(20,24,31,.08);border-radius:var(--radius);padding:22px;margin:18px 0 26px;box-shadow:var(--shadow)}
.about h2,.contact h2{margin-top:0}
.badges{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:10px 0 0;list-style:none}
.badges li{background:rgba(20,24,31,.06);border:1px solid rgba(20,24,31,.12);padding:6px 10px;border-radius:10px}

.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.contact-card{display:flex;flex-direction:column;gap:6px;text-decoration:none;color:var(--text);background:var(--panel);border:1px solid rgba(20,24,31,.08);border-radius:14px;padding:14px}
.contact-card:hover{border-color:rgba(20,24,31,.24)}

.site-footer{padding:30px 0;color:var(--muted);text-align:center}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.85);
  display:none;align-items:center;justify-content:center;flex-direction:column;gap:10px;
  z-index:100;
}
.lightbox.open{display:flex}
.lightbox img{max-width:min(92vw,1200px);max-height:78vh;border-radius:12px}
.lightbox__close{
  position:absolute;top:18px;right:22px;
  font-size:32px;line-height:1;border:0;border-radius:10px;
  color:var(--text);background:rgba(20,24,31,.12);cursor:pointer;padding:6px 10px
}
.lightbox figcaption{color:#cdd6df;opacity:.9}

/* Consent banner */
.consent-banner{
  position:fixed;
  bottom:0;left:0;right:0;
  background:rgba(20,20,20,0.95);
  color:#fff;
  padding:16px;
  font-size:14px;
  z-index:200;
  box-shadow:0 -2px 10px rgba(0,0,0,0.4);
}
.cb-inner{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.cb-buttons{display:flex;gap:10px}
.cb-buttons button{
  padding:8px 14px;border:none;border-radius:6px;cursor:pointer;font-weight:600
}
#acceptBtn{background:#4caf50;color:#fff}
#declineBtn{background:#e53935;color:#fff}


/* === Elegant Refresh === */
h1,h2,h3{font-family:'Playfair Display', serif; letter-spacing:.2px}
.hero-inner h1{text-shadow:0 6px 30px #f0d09033}
.filter-btn.active{
  border-color: #f0d090;
  box-shadow: 0 6px 16px #f0d09033;
  background: linear-gradient(180deg, #f0d09022, rgba(255,255,255,.04));
}
.card:hover{
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 16px 40px #f0a0a022;
  border-color: #f0d09055;
}
.card figcaption{color:#cfd7e3}
.logo{background:linear-gradient(90deg,#f0d090, #f0a0a0);-webkit-background-clip:text;background-clip:text;color:transparent}
.site-header{border-bottom:1px solid #f0d09022}
.contact-card:hover{border-color:#f0a0a0aa; box-shadow:0 10px 26px #f0a0a022}
.lightbox__close{background: #f0d09044}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, #f0d09022, transparent),
    radial-gradient(1000px 700px at -10% 0%, #f0a0a022, transparent),
    var(--bg);
}


/* Dynamic light background */
body{
  background: var(--bg);
  position: relative;
  overflow-x: hidden;
}
body::before, body::after{
  content:"";
  position: fixed;
  inset: -20% -10% auto auto;
  width: 70vmax; height: 70vmax;
  background: radial-gradient(closest-side, var(--accent)22, transparent 65%);
  filter: blur(40px);
  z-index: -1;
  animation: floaty 18s linear infinite;
  pointer-events: none;
}
body::after{
  inset: auto auto -25% -10%;
  width: 60vmax; height: 60vmax;
  background: radial-gradient(closest-side, var(--accent-2)22, transparent 65%);
  animation-duration: 22s;
  animation-direction: reverse;
}
@keyframes floaty{
  0%{transform: translate3d(0,0,0) rotate(0deg)}
  50%{transform: translate3d(-2%,2%,0) rotate(180deg)}
  100%{transform: translate3d(0,0,0) rotate(360deg)}
}
/* Adjust header for light mode */
.site-header{background:rgba(255,255,255,.6); border-bottom:1px solid rgba(20,24,31,.08); backdrop-filter: blur(10px)}
.nav a{color:var(--text)}
/* Cards and sections */
.card{border:1px solid rgba(20,24,31,.08); background:var(--panel)}
.about,.contact{border:1px solid rgba(20,24,31,.08); background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.01))}
.card figcaption{color:var(--muted)}
/* Lightbox close contrast */
.lightbox__close{background: rgba(0,0,0,.4); color:#fff}
/* Consent banner stays dark for contrast */
