:root{
  --bg: #0b0d10;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.08);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.68);
  --soft: rgba(255,255,255,.14);
  --accent: #ffcf6b;
  --accent2:#72e6ff;
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius: 18px;
  --radius2: 26px;
  --max: 1160px;
  --font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial;
  --serif: "Fraunces", ui-serif, Georgia, serif;
}

:root[data-theme="light"]{
  --bg: #f7f7fb;
  --panel: rgba(0,0,0,.05);
  --panel2: rgba(0,0,0,.07);
  --text: rgba(0,0,0,.88);
  --muted: rgba(0,0,0,.62);
  --soft: rgba(0,0,0,.12);
  --shadow: 0 18px 60px rgba(0,0,0,.12);
  --accent:#b15b00;
  --accent2:#006a7e;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: var(--font);
  background:
    radial-gradient(900px 500px at 15% 12%, rgba(255,207,107,.14), transparent 55%),
    radial-gradient(900px 500px at 85% 18%, rgba(114,230,255,.12), transparent 55%),
    radial-gradient(900px 500px at 50% 75%, rgba(255,255,255,.06), transparent 60%),
    var(--bg);
  color: var(--text);
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
p{ line-height:1.65; color:var(--muted); }
h1,h2,h3{ color:var(--text); margin:0 0 .6rem; }
h2{ font-family: var(--serif); font-size: clamp(1.6rem, 2.2vw, 2.2rem); letter-spacing:.2px; }
h3{ font-size:1.05rem; }

.progress{
  position:fixed; top:0; left:0;
  height:3px; width:0;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  z-index:9999;
  box-shadow: 0 0 22px rgba(255,207,107,.35);
}

.topbar{
  position:sticky; top:0;
  z-index:1000;
  backdrop-filter: blur(16px);
  background: linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.15));
  border-bottom:1px solid var(--soft);
}
:root[data-theme="light"] .topbar{
  background: linear-gradient(to bottom, rgba(255,255,255,.85), rgba(255,255,255,.55));
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 18px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:700;
}
.brand-mark{
  width:36px; height:36px;
  border-radius:12px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color:#111;
  font-family: var(--serif);
  box-shadow: var(--shadow);
}
.brand-text{ letter-spacing:.2px; }

.nav{
  display:flex; gap:18px; align-items:center;
  font-size:.95rem;
}
.nav a{ color:var(--muted); padding:8px 10px; border-radius:12px; }
.nav a:hover{ background: var(--panel); color:var(--text); }

.actions{ display:flex; align-items:center; gap:10px; }

.pill{
  border:1px solid var(--soft);
  background: var(--panel);
  padding:8px 12px;
  border-radius:999px;
}
.pill:hover{ background: var(--panel2); }

.small{ padding:7px 10px; font-size:.92rem; }

.icon-btn{
  border:1px solid var(--soft);
  background: var(--panel);
  color: var(--text);
  border-radius: 12px;
  padding: 9px 10px;
  cursor:pointer;
}
.icon-btn:hover{ background: var(--panel2); }
.icon{ font-size:1rem; }

.lang{ position:relative; }
.lang-btn{
  border:1px solid var(--soft);
  background: var(--panel);
  color: var(--text);
  border-radius: 12px;
  padding: 9px 10px;
  cursor:pointer;
  display:flex; gap:8px; align-items:center;
}
.lang-btn:hover{ background: var(--panel2); }
.lang-menu{
  position:absolute;
  right:0; top:calc(100% + 10px);
  background: rgba(20,22,26,.95);
  border:1px solid var(--soft);
  border-radius: 14px;
  box-shadow: var(--shadow);
  padding:8px;
  min-width: 160px;
  display:none;
}
:root[data-theme="light"] .lang-menu{
  background: rgba(255,255,255,.95);
}
.lang-menu button{
  width:100%;
  border:0;
  background:transparent;
  color: var(--text);
  padding:10px 10px;
  border-radius:10px;
  text-align:left;
  cursor:pointer;
}
.lang-menu button:hover{ background: var(--panel); }

.burger{
  display:none;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius:12px;
  padding:10px;
  cursor:pointer;
}
.burger span{
  display:block;
  width:18px; height:2px;
  background: var(--text);
  margin:4px 0;
  opacity:.85;
}

main{ width:100%; }

.hero{
  padding: 48px 18px 24px;
}
.hero-inner{
  max-width: var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns: 1.2fr .9fr;
  gap: 22px;
  align-items: start;
}
.kicker{
  display:inline-flex;
  padding:7px 11px;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius:999px;
  font-size:.92rem;
  margin: 0 0 14px;
  color: var(--muted);
}
.hero-title{
  font-family: var(--serif);
  font-weight:700;
  font-size: clamp(2.2rem, 4vw, 3.6rem);
  line-height:1.05;
  letter-spacing: .2px;
  margin: 0 0 12px;
}
.accent{
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}
.hero-sub{ font-size: 1.05rem; max-width: 48ch; margin: 0 0 18px; }

.hero-ctas{ display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 11px 14px;
  border-radius: 14px;
  border:1px solid var(--soft);
  background: var(--panel);
  color: var(--text);
  cursor:pointer;
}
.btn:hover{ background: var(--panel2); }
.btn.primary{
  background: linear-gradient(135deg, rgba(255,207,107,.22), rgba(114,230,255,.16));
  border-color: rgba(255,255,255,.22);
}
:root[data-theme="light"] .btn.primary{
  border-color: rgba(0,0,0,.10);
}

.hero-badges{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
}
.badge{
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: 16px;
  padding: 12px 12px;
}
.badge-top{ font-size:.9rem; color: var(--muted); }
.badge-bottom{ margin-top:4px; font-weight:600; }

.hero-card{
  border:1px solid var(--soft);
  background: linear-gradient(180deg, var(--panel), transparent);
  border-radius: var(--radius2);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.hero-media{
  position:relative;
  aspect-ratio: 16 / 10;
  background:
    radial-gradient(650px 260px at 30% 20%, rgba(255,207,107,.18), transparent 60%),
    radial-gradient(650px 260px at 80% 20%, rgba(114,230,255,.16), transparent 60%),
    rgba(255,255,255,.04);
  border-bottom:1px solid var(--soft);
}
.media-placeholder{
  height:100%;
  display:grid;
  place-items:center;
  color: var(--muted);
  font-size:.95rem;
}
.media-placeholder.big{ min-height: 46vh; }

.glow{
  position:absolute; inset:-80px -80px auto auto;
  width: 260px; height: 260px;
  background: radial-gradient(circle, rgba(255,207,107,.25), transparent 55%);
  filter: blur(1px);
  transform: rotate(20deg);
}

.hero-meta{
  padding: 14px 16px 16px;
}
.meta-row{
  display:flex; align-items:center; gap:10px;
  padding: 8px 0;
  color: var(--muted);
  font-size:.95rem;
}
.dot{
  width:9px; height:9px;
  border-radius:999px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 0 18px rgba(255,207,107,.22);
}

.quote{
  margin-top: 14px;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px 14px;
}
.quote p{ margin: 0 0 8px; color: var(--text); opacity:.92; }
.quote-by{ color: var(--muted); font-size:.92rem; }

.scroll-hint{
  max-width: var(--max);
  margin: 16px auto 0;
  display:flex;
  gap:6px;
  justify-content:center;
}
.scroll-hint span{
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--muted);
  opacity:.5;
  animation: pulse 1.3s infinite ease-in-out;
}
.scroll-hint span:nth-child(2){ animation-delay:.15s; }
.scroll-hint span:nth-child(3){ animation-delay:.3s; }
@keyframes pulse{
  0%,100%{ transform: translateY(0); opacity:.35; }
  50%{ transform: translateY(6px); opacity:.85; }
}

.section{
  padding: 34px 18px;
}
.section.alt{
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.03), transparent);
}
.section-head{
  max-width: var(--max);
  margin: 0 auto 16px;
}
.section-head p{ max-width: 70ch; margin: 0; }

.filters{
  max-width: var(--max);
  margin: 14px auto 16px;
  display:flex; gap:10px; flex-wrap:wrap;
}
.chip{
  border:1px solid var(--soft);
  background: var(--panel);
  color: var(--text);
  padding:9px 12px;
  border-radius:999px;
  cursor:pointer;
  font-size:.95rem;
}
.chip:hover{ background: var(--panel2); }
.chip.active{
  background: linear-gradient(135deg, rgba(255,207,107,.22), rgba(114,230,255,.15));
  border-color: rgba(255,255,255,.22);
}

.grid{
  max-width: var(--max);
  margin: 0 auto;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}
.tile{
  margin:0;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius);
  overflow:hidden;
  cursor:pointer;
  transition: transform .18s ease, background .18s ease;
  grid-column: span 4;
}
.tile:hover{ transform: translateY(-3px); background: var(--panel2); }
.tile-media{
  aspect-ratio: 4 / 3;
  display:grid;
  place-items:center;
  color: var(--muted);
  border-bottom:1px solid var(--soft);
}
.tile-media.ph{
  background:
    radial-gradient(500px 220px at 20% 20%, rgba(255,207,107,.12), transparent 60%),
    radial-gradient(500px 220px at 85% 15%, rgba(114,230,255,.12), transparent 60%),
    rgba(255,255,255,.03);
}
figcaption{ padding: 12px 12px; }
.cap-title{ font-weight:700; }
.cap-sub{ margin-top:4px; color: var(--muted); font-size:.92rem; }

.cards{
  max-width: var(--max);
  margin: 0 auto;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.card{
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px 14px;
}
.list{ margin: 10px 0 0 18px; color: var(--muted); }
.list li{ margin: 6px 0; }

.split{
  max-width: var(--max);
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 14px;
  align-items:start;
}
.lead{ font-size:1.05rem; color: var(--text); opacity:.92; }
.stats{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.stat{
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: 16px;
  padding: 12px;
}
.stat-num{ font-size:1.35rem; font-weight:800; font-family: var(--serif); }
.stat-lbl{ margin-top:4px; color: var(--muted); font-size:.92rem; }

.story-panel{
  border:1px solid var(--soft);
  background: linear-gradient(180deg, var(--panel), transparent);
  border-radius: var(--radius2);
  padding: 16px 16px;
  box-shadow: var(--shadow);
}
.pill-row{ display:flex; flex-wrap:wrap; gap:8px; margin: 8px 0 0; }
.divider{ height:1px; background: var(--soft); margin: 14px 0; }
.contact-mini-row{
  display:flex; justify-content:space-between; gap:14px;
  padding: 8px 0;
}
.label{ color: var(--muted); }
.value{ color: var(--text); opacity:.92; }
.hint{ font-size:.92rem; color: var(--muted); margin: 10px 0 0; }

.timeline{
  max-width: var(--max);
  margin: 0 auto;
  display:grid;
  gap: 12px;
}
.tl-item{
  position:relative;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px 14px;
  overflow:hidden;
}
.tl-dot{
  position:absolute;
  left: 14px; top: 18px;
  width:10px; height:10px;
  border-radius:999px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 0 18px rgba(255,207,107,.22);
}
.tl-content{ padding-left: 16px; }
.tl-top{
  display:flex; justify-content:space-between; gap:10px;
  align-items:baseline;
}
.tl-title{ font-weight:700; }
.tl-year{ color: var(--muted); }

.shops{
  max-width: var(--max);
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 12px;
}
.shop{
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px 14px;
}
.shop.big{
  border-radius: var(--radius2);
  background: linear-gradient(135deg, rgba(255,207,107,.16), rgba(114,230,255,.08));
}
.shop-meta{ display:flex; gap:8px; flex-wrap:wrap; margin-top: 10px; }

.collab{
  max-width: var(--max);
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 12px;
}
.collab-box{
  margin-top: 14px;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius2);
  padding: 14px;
}
.form{ display:grid; gap: 12px; margin-top: 8px; }
.form .row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
label span{ display:block; margin-bottom: 6px; color: var(--muted); font-size:.92rem; }
input, select, textarea{
  width:100%;
  border-radius: 14px;
  border:1px solid var(--soft);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding: 11px 12px;
  outline:none;
}
:root[data-theme="light"] input,
:root[data-theme="light"] select,
:root[data-theme="light"] textarea{
  background: rgba(0,0,0,.03);
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(255,207,107,.55);
  box-shadow: 0 0 0 3px rgba(255,207,107,.12);
}
.form-actions{ display:flex; gap:10px; flex-wrap:wrap; }

.callout{
  border:1px solid var(--soft);
  background: linear-gradient(180deg, var(--panel), transparent);
  border-radius: var(--radius2);
  padding: 14px;
  box-shadow: var(--shadow);
}
.ideas{ margin: 10px 0 0 18px; color: var(--muted); }
.footer-card{
  margin-top: 12px;
  border:1px solid var(--soft);
  background: var(--panel);
  border-radius: var(--radius);
  padding: 14px;
}
.footer-row{
  display:flex; justify-content:space-between; gap:14px;
  padding: 8px 0;
}

.footer{
  padding: 22px 18px 34px;
  border-top: 1px solid var(--soft);
}
.footer-inner{
  max-width: var(--max);
  margin: 0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  flex-wrap:wrap;
}
.to-top{ color: var(--muted); }
.to-top:hover{ color: var(--text); }

.lightbox{
  position:fixed; inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background: rgba(0,0,0,.65);
  z-index: 2000;
  padding: 18px;
}
.lightbox-inner{
  width: min(980px, 100%);
  border-radius: 22px;
  background: rgba(20,22,26,.95);
  border:1px solid var(--soft);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}
:root[data-theme="light"] .lightbox-inner{
  background: rgba(255,255,255,.95);
}
.lb-close{
  position:absolute;
  top: 12px; right: 12px;
}
.lb-media{
  min-height: 52vh;
  border-bottom:1px solid var(--soft);
}
.lb-meta{
  padding: 14px 16px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.lb-title{ font-weight:800; font-size:1.05rem; }
.lb-sub{ color: var(--muted); }

.drawer{
  position:fixed;
  top:0; right:0;
  width: min(360px, 88vw);
  height:100%;
  background: rgba(20,22,26,.96);
  border-left: 1px solid var(--soft);
  box-shadow: var(--shadow);
  transform: translateX(110%);
  transition: transform .22s ease;
  z-index: 1800;
  padding: 14px;
}
:root[data-theme="light"] .drawer{
  background: rgba(255,255,255,.96);
}
.drawer.open{ transform: translateX(0); }
.backdrop{
  position:fixed; inset:0;
  background: rgba(0,0,0,.45);
  display:none;
  z-index:1700;
}
.backdrop.show{ display:block; }
.drawer-head{
  display:flex; justify-content:space-between; align-items:center;
  padding: 6px 2px 10px;
}
.drawer-title{ font-weight:800; }
.drawer-nav{
  display:grid; gap:8px;
  padding: 10px 2px;
}
.drawer-nav a{
  padding: 10px 12px;
  border-radius: 14px;
  border:1px solid var(--soft);
  background: var(--panel);
  color: var(--text);
}
.drawer-nav a:hover{ background: var(--panel2); }
.drawer-footer{
  margin-top: 14px;
  border-top: 1px solid var(--soft);
  padding-top: 12px;
  display:grid; gap:10px;
}
.drawer-row{
  display:flex; justify-content:space-between; align-items:center;
  gap:10px;
}
.drawer-langs{ display:flex; gap:8px; }

@media (max-width: 980px){
  .hero-inner{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .cards{ grid-template-columns: 1fr; }
  .shops{ grid-template-columns: 1fr; }
  .collab{ grid-template-columns: 1fr; }
  .hero-badges{ grid-template-columns: 1fr; }
}
@media (max-width: 860px){
  .nav{ display:none; }
  .burger{ display:block; }
  .tile{ grid-column: span 6; }
}
@media (max-width: 520px){
  .tile{ grid-column: span 12; }
  .form .row{ grid-template-columns: 1fr; }
}
/* FORCE hero image block not to be huge */
.hero-media{
  aspect-ratio: auto !important;
  height: 320px !important;
  max-height: 320px !important;
}

.hero-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.tile-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* === FIX gallery images layout === */
.tile-media{
  aspect-ratio: 4 / 3;      /* keeps all tiles same height */
  overflow: hidden;
  border-bottom: 1px solid var(--soft);
}

.tile-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;           /* removes inline image gaps */
}

/* optional: keep tile hover smooth */
.tile{
  overflow: hidden;
}.media-placeholder{
  display: none;
}