/* ═══════════════════════════════════════════════════
   TOKENS
   ═══════════════════════════════════════════════════ */
[data-theme="dark"] {
  --bg:#000; --bg2:#0a0a0a; --bg3:#161616;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.12);
  --text:#f5f5f7; --text2:#adadb0; --text3:#48484a;
  --accent:#2997ff; --accent2:#54aeff; --white:#f5f5f7;
  --shadow:rgba(0,0,0,0.8); --art-glow:rgba(41,151,255,.04);
  --ap1:radial-gradient(ellipse at 45% 40%,#1c1c1e 0%,#111 60%,#080808 100%);
  --ap2:radial-gradient(ellipse at 60% 55%,#1a1a1c 0%,#101010 70%,#080808 100%);
  --ap3:radial-gradient(ellipse at 35% 45%,#1e1e20 0%,#141414 65%,#0b0b0b 100%);
  --ap4:radial-gradient(ellipse at 50% 35%,#1c1c1e 0%,#111 70%);
  --ap5:radial-gradient(ellipse at 55% 60%,#1a1a1c 0%,#0f0f0f 65%);
  --ap6:radial-gradient(ellipse at 40% 50%,#181818 0%,#0e0e0e 70%);
  --hero-block1:linear-gradient(160deg,#141414 0%,#1c1c1e 40%,#111 100%);
  --hero-block2:linear-gradient(140deg,#111 0%,#181818 50%,#131313 100%);
  --about-img:radial-gradient(ellipse at 40% 45%,#1c1c1e 0%,#131313 60%,#0a0a0a 100%);
  --about-img2:radial-gradient(ellipse at 55% 45%,#181818 0%,#111 70%);
  --sw1:linear-gradient(160deg,#111,#1a1a1c 40%,#141414 100%);
  --sw2:linear-gradient(140deg,#0e0e0e,#181818 50%,#111 100%);
  --sw3:linear-gradient(155deg,#101010,#1c1c1e 45%,#131313 100%);
  --glass-bg:        rgba(12,12,14,0.60);
  --glass-border:    rgba(255,255,255,0.14);
  --glass-border-b:  rgba(255,255,255,0.05);
  --glass-shadow:
    0 0 0 0.5px rgba(255,255,255,0.08) inset,
    0 1px 0   rgba(255,255,255,0.10) inset,
    0 24px 48px rgba(0,0,0,0.55),
    0  8px 24px rgba(0,0,0,0.35),
    0  2px  8px rgba(0,0,0,0.25);
  --nav-hover:rgba(255,255,255,0.08);
  --tog-bg:rgba(255,255,255,0.06);
  --nav-border:   rgba(255,255,255,0.14);
  --nav-border-b: rgba(255,255,255,0.05);
  --nav-glint:    rgba(255,255,255,0.38);
}
[data-theme="light"] {
  --bg:#fff; --bg2:#f5f5f7; --bg3:#e8e8ed;
  --border:rgba(0,0,0,0.08); --border2:rgba(0,0,0,0.14);
  --text:#1d1d1f; --text2:#3a3a3c; --text3:#6e6e73;
  --accent:#0071e3; --accent2:#0077ed; --white:#1d1d1f;
  --shadow:rgba(0,0,0,0.06); --art-glow:rgba(0,0,0,.02);
  --ap1:radial-gradient(ellipse at 45% 40%,#d2d2d7 0%,#b8b8c0 60%,#aaaab2 100%);
  --ap2:radial-gradient(ellipse at 60% 55%,#c8c8d0 0%,#b0b0b8 70%,#a0a0a8 100%);
  --ap3:radial-gradient(ellipse at 35% 45%,#ccccd4 0%,#b4b4bc 65%,#a4a4ac 100%);
  --ap4:radial-gradient(ellipse at 50% 35%,#cacad2 0%,#b2b2ba 70%);
  --ap5:radial-gradient(ellipse at 55% 60%,#d0d0d8 0%,#b8b8c0 65%);
  --ap6:radial-gradient(ellipse at 40% 50%,#c6c6ce 0%,#aeaeb6 70%);
  --hero-block1:linear-gradient(160deg,#e8e8ed 0%,#d8d8de 40%,#ccccd2 100%);
  --hero-block2:linear-gradient(140deg,#e2e2e8 0%,#d4d4da 50%,#c8c8ce 100%);
  --about-img:radial-gradient(ellipse at 40% 45%,#d2d2d8 0%,#b8b8c0 60%,#acacb4 100%);
  --about-img2:radial-gradient(ellipse at 55% 45%,#c8c8d0 0%,#b4b4bc 70%);
  --sw1:linear-gradient(160deg,#c8c8d0,#b8b8c0 40%,#acacb4 100%);
  --sw2:linear-gradient(140deg,#c4c4cc,#b4b4bc 50%,#a8a8b0 100%);
  --sw3:linear-gradient(155deg,#c6c6ce,#b6b6be 45%,#aaaab2 100%);
  --glass-bg:        rgba(255,255,255,0.62);
  --glass-border:    rgba(255,255,255,0.90);
  --glass-border-b:  rgba(0,0,0,0.07);
  --glass-shadow:
    0 0 0 0.5px rgba(255,255,255,1.0) inset,
    0 1px 0   rgba(255,255,255,1.0) inset,
    0 24px 48px rgba(0,0,0,0.10),
    0  8px 24px rgba(0,0,0,0.06),
    0  2px  8px rgba(0,0,0,0.04);
  --nav-hover:rgba(0,0,0,0.05);
  --tog-bg:rgba(0,0,0,0.04);
  --nav-border:   rgba(0,0,0,0.10);
  --nav-border-b: rgba(0,0,0,0.04);
  --nav-glint:    rgba(255,255,255,0.65);
}

/* ═══════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:17px;}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none;}
img{display:block;width:100%;}
a{color:inherit;text-decoration:none;}
button{cursor:none;font-family:inherit;}
*,*::before,*::after{transition:background-color .35s ease,border-color .35s ease,color .35s ease;}
.b-fly,.parijat,.scroll-line,.reveal,.reveal.visible,#cur,#cur-ring,.acc-body,.marquee-inner,.pf-flag{transition:none!important;}

/* ═══════════════════════════════════════════════════
   NOISE LAYER
   ═══════════════════════════════════════════════════ */
body::before{content:'';position:fixed;inset:0;z-index:1000;pointer-events:none;opacity:.016;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ═══════════════════════════════════════════════════
   CURSOR
   ═══════════════════════════════════════════════════ */
#cur{position:fixed;z-index:9999;pointer-events:none;width:9px;height:9px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);}
#cur.grow{width:34px;height:34px;background:transparent;border:1px solid rgba(255,255,255,0.55);}
#cur-ring{position:fixed;z-index:9998;pointer-events:none;width:30px;height:30px;border:1px solid rgba(128,128,140,.18);border-radius:50%;transform:translate(-50%,-50%);}

/* ═══════════════════════════════════════════════════
   NAV — GLASS, MOBILE-FIRST
   ═══════════════════════════════════════════════════ */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  height: 64px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px;
}

/* Semi-transparent glass pill — visible at rest, deepens on scroll */
nav::before {
  content: '';
  position: absolute; inset: 10px 12px;
  border-radius: 22px;
  background: rgba(12,12,16,0.20);
  border: 1px solid rgba(255,255,255,0.10);
  border-bottom-color: rgba(255,255,255,0.04);
  backdrop-filter: blur(22px) saturate(180%);
  -webkit-backdrop-filter: blur(22px) saturate(180%);
  z-index: -1;
  transition: background .35s ease, border-color .35s ease, backdrop-filter .35s ease;
}

nav::after {
  content: '';
  position: absolute; top: 10px; left: 12px; right: 12px; height: 1px;
  border-radius: 22px 22px 0 0;
  background: linear-gradient(90deg, transparent 10%, rgba(255,255,255,0.32) 50%, transparent 90%);
  opacity: .38; z-index: 1; pointer-events: none;
}

nav.scrolled::before {
  background: rgba(8,8,10,0.72);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
}

/* Logo — always white for transparent/dark nav */
.nav-logo { font-size: .88rem; font-weight: 700; letter-spacing: -.02em; color: #f5f5f7; position: relative; z-index: 1; user-select: none; }
.nav-logo span { font-weight: 400; color: rgba(255,255,255,0.40); }

/* Desktop links — hidden on mobile, shown at 768px+ */
.nav-links { display: none; gap: 4px; list-style: none; position: relative; z-index: 1; }
.nav-links a { font-size: .80rem; font-weight: 500; letter-spacing: -.01em; color: rgba(255,255,255,0.75); padding: 7px 13px; border-radius: 12px; transition: color .18s ease, background .18s ease; }
.nav-links a:hover { color: #fff; background: rgba(255,255,255,0.09); }
.nav-dot { display: none; }

/* Right cluster */
.nav-right { display: flex; align-items: center; gap: 8px; position: relative; z-index: 1; }

/* Theme toggle — always dark styled */
.theme-toggle { display: flex; align-items: center; gap: 6px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.14); padding: 8px 10px; border-radius: 12px; cursor: none; font-size: .72rem; font-weight: 500; letter-spacing: -.01em; color: rgba(255,255,255,0.62); transition: color .18s, border-color .18s; }
.theme-toggle:hover { color: #fff; border-color: rgba(41,151,255,0.55); }
.theme-toggle svg { stroke: currentColor; flex-shrink: 0; }
.theme-toggle span { display: none; } /* label hidden on mobile */

/* Hamburger button — always dark styled */
.nav-burger { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 5px; width: 42px; height: 42px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.14); border-radius: 12px; cursor: pointer; position: relative; z-index: 1; flex-shrink: 0; }
.nav-burger span { display: block; width: 20px; height: 1.5px; background: #f0f0f0; border-radius: 2px; transform-origin: center; transition: transform .25s ease; }
.nav-burger.open span:first-child { transform: translateY(3.25px) rotate(45deg); }
.nav-burger.open span:last-child  { transform: translateY(-3.25px) rotate(-45deg); }

/* Mobile drawer — always dark */
.nav-drawer {
  position: absolute; top: 56px; left: 12px; right: 12px;
  border-radius: 18px;
  background: rgba(8,8,10,0.94);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.12);
  overflow: hidden;
  max-height: 0; opacity: 0; pointer-events: none;
  transition: max-height .35s cubic-bezier(.4,0,.2,1), opacity .25s ease;
  z-index: 10;
}
.nav-drawer.open { max-height: 520px; opacity: 1; pointer-events: auto; }
.nav-drawer a { display: flex; align-items: center; min-height: 52px; padding: 0 20px; font-size: 1rem; font-weight: 500; letter-spacing: -.01em; color: rgba(255,255,255,0.82); border-bottom: 1px solid rgba(255,255,255,0.08); transition: background .15s ease; }
.nav-drawer a:last-child { border-bottom: none; }
.nav-drawer a:active { background: rgba(255,255,255,0.06); }

/* Desktop: show links, hide burger + drawer */
@media (min-width: 768px) {
  .nav-links { display: flex; }
  .nav-burger { display: none; }
  .nav-drawer { display: none; }
  .theme-toggle span { display: inline; }
  .theme-toggle { padding: 7px 12px 7px 10px; }
}

/* ═══════════════════════════════════════════════════
   HERO — full-bleed video with overlay content
   ═══════════════════════════════════════════════════ */
#hero {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Video layer */
.hero-video-panel {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-video-panel video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Gradient overlay — heavy bottom/left for text, fades up/right */
.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top,  rgba(0,0,0,0.93) 0%, rgba(0,0,0,0.68) 28%, rgba(0,0,0,0.22) 56%, rgba(0,0,0,0.04) 100%),
    linear-gradient(to right, rgba(0,0,0,0.58) 0%, rgba(0,0,0,0.20) 48%, transparent 72%);
  pointer-events: none;
}

/* Content sits over the video */
.hero-content {
  position: relative;
  z-index: 2;
  padding: 0 60px 84px;
  max-width: 700px;
}

.hero-eyebrow {
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.52);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.hero-eyebrow::before {
  content: '';
  width: 22px;
  height: 1px;
  background: rgba(255,255,255,.40);
  flex-shrink: 0;
}

.hero-name {
  font-size: clamp(3.8rem, 7.2vw, 8rem);
  font-weight: 700;
  line-height: .88;
  letter-spacing: -.04em;
  color: #fff;
}
.hero-name em {
  display: block;
  font-style: normal;
  font-weight: 200;
  color: rgba(255,255,255,.38);
}

.hero-tagline {
  margin-top: 28px;
  font-size: 1.05rem;
  font-weight: 400;
  line-height: 1.72;
  color: rgba(255,255,255,.60);
  max-width: 440px;
}

.hero-meta {
  margin-top: 44px;
  display: flex;
  gap: 0;
}
.hero-meta > div {
  padding: 0 32px;
  border-left: 1px solid rgba(255,255,255,.14);
}
.hero-meta > div:first-child { padding-left: 0; border-left: none; }
.hero-meta-num {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -.04em;
  color: #fff;
  line-height: 1;
}
.hero-meta-label {
  font-size: .62rem;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
  margin-top: 6px;
}

.hero-cta-row {
  margin-top: 44px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* Buttons — always on dark background in hero */
.btn-primary {
  font-size: .84rem;
  font-weight: 600;
  letter-spacing: -.01em;
  padding: 14px 30px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 980px;
  transition: opacity .2s, transform .15s;
}
.btn-primary:hover { opacity: .88; transform: translateY(-1px); }

.btn-outline {
  font-size: .84rem;
  font-weight: 500;
  letter-spacing: -.01em;
  padding: 14px 30px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.90);
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 980px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: background .2s, border-color .2s, transform .15s;
}
.btn-outline:hover {
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.52);
  transform: translateY(-1px);
}

/* Floating corner elements */
.hero-location {
  position: absolute;
  top: 84px;
  right: 52px;
  font-size: .62rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.58);
  display: flex;
  align-items: center;
  gap: 7px;
  z-index: 2;
}
.hero-location::before { content: '◉'; color: #dc1515; font-size: .46rem; }

.hero-scroll {
  position: absolute;
  bottom: 44px;
  right: 52px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .62rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.48);
  z-index: 2;
}
.scroll-line {
  width: 36px;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(255,255,255,.52));
  animation: scrollAnim 2s ease-in-out infinite;
}
@keyframes scrollAnim { 0%,100%{transform:scaleX(1);opacity:.4} 50%{transform:scaleX(1.4);opacity:.9} }

/* ═══════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════ */
.marquee{padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg2);overflow:hidden;}
.marquee-inner{display:flex;width:max-content;animation:marquee 22s linear infinite;}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{font-size:.7rem;font-weight:500;letter-spacing:.04em;color:var(--text3);padding:0 34px;white-space:nowrap;}
.marquee-item em{color:var(--accent);font-style:normal;margin:0 8px;}

/* ═══════════════════════════════════════════════════
   SECTION SHARED
   ═══════════════════════════════════════════════════ */
section{position:relative;}
.sec-label{font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:12px;margin-bottom:48px;}
.sec-label::before{content:'';display:block;width:20px;height:1px;background:var(--accent);}
.sec-title{font-size:clamp(2.6rem,4.2vw,4.2rem);font-weight:700;line-height:.93;letter-spacing:-.04em;color:var(--white);}
.sec-title em{font-style:normal;font-weight:200;color:var(--text3);}

/* ═══════════════════════════════════════════════════
   GALLERY — PREMIUM HORIZONTAL SCROLL
   ═══════════════════════════════════════════════════ */
#store{padding:100px 0 0;background:var(--bg);}

/* ── Header ── */
.gallery-header{display:flex;align-items:flex-end;justify-content:space-between;padding:0 56px 52px;gap:24px;}
.gallery-controls{display:flex;align-items:center;gap:14px;flex-shrink:0;padding-bottom:6px;}

.gallery-btn{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:transparent;border:1px solid var(--border2);color:var(--text3);display:flex;align-items:center;justify-content:center;cursor:none;transition:background .18s,color .18s,border-color .18s,opacity .18s;}
.gallery-btn:hover{background:var(--bg3);color:var(--white);border-color:var(--text2);}
.gallery-btn:disabled{opacity:.22;pointer-events:none;}

.gallery-progress-wrap{width:140px;height:1px;background:var(--border2);border-radius:1px;position:relative;overflow:hidden;}
.gallery-progress-thumb{position:absolute;top:0;left:0;height:100%;width:0%;background:var(--accent);border-radius:1px;transition:left .12s ease,width .12s ease;}
.gallery-subtitle{font-size:.70rem;font-weight:400;letter-spacing:.04em;text-transform:uppercase;color:var(--text3);margin-top:14px;opacity:.55;}

/* ── Viewport ── */
.gallery-viewport{position:relative;overflow:hidden;}

/* Ambient ceiling light — broad wash across the whole gallery */
.gallery-viewport::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:55%;
  background:radial-gradient(ellipse at 50% -15%,rgba(255,255,255,.025) 0%,transparent 65%);
  pointer-events:none;z-index:0;
}

/* Right-fade peek indicator */
.gallery-fade-r{position:absolute;top:0;right:0;bottom:0;width:clamp(80px,10vw,160px);background:linear-gradient(to right,transparent,var(--bg) 92%);pointer-events:none;z-index:4;}
[data-theme="light"] .gallery-fade-r{background:linear-gradient(to right,transparent,#fff 92%);}

/* ── Scrollable track ── */
.gallery-track{
  display:flex;
  align-items:flex-start;
  gap:32px;
  padding:8px 56px 120px;  /* extra bottom padding for floor cast shadows */
  overflow-x:scroll;
  scroll-snap-type:x mandatory;
  scroll-padding-left:56px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.09) transparent;
  position:relative;z-index:1;
}
.gallery-track::-webkit-scrollbar{height:2px;}
.gallery-track::-webkit-scrollbar-track{background:transparent;}
.gallery-track::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:2px;}
[data-theme="light"] .gallery-track{scrollbar-color:rgba(0,0,0,.08) transparent;}
[data-theme="light"] .gallery-track::-webkit-scrollbar-thumb{background:rgba(0,0,0,.14);}

/* ── Each artwork figure ── */
.artwork-item{
  flex:0 0 auto;
  scroll-snap-align:start;
  cursor:none;
  display:flex;
  flex-direction:column;
  gap:20px;
  margin:0;
  padding-top:60px;  /* room for per-artwork ceiling spotlight above the frame */
}

/* ── Image frame ── */
.artwork-frame{
  position:relative;
  line-height:0;
  flex-shrink:0;
}

/* Per-artwork spotlight — light cone descending from ceiling onto each piece */
.artwork-frame::before{
  content:'';
  position:absolute;
  bottom:100%;
  left:50%;
  transform:translateX(-50%);
  width:200%;
  height:60px;
  background:radial-gradient(ellipse at 50% 100%,rgba(255,255,255,.07) 0%,transparent 68%);
  pointer-events:none;
}

/* Fixed height → width scales naturally → zero cropping */
.artwork-frame img{
  height:clamp(260px,52vh,620px);
  width:auto;
  display:block;
  max-width:min(76vw,900px);
  /* Layer 1: inner frame lip edge */
  /* Layers 2-6: depth shadows on gallery wall */
  /* Layer 7: cast shadow on gallery floor */
  box-shadow:
    0 0 0 1px rgba(255,255,255,.055),
    0 2px 4px   rgba(0,0,0,.28),
    0 8px 16px  rgba(0,0,0,.34),
    0 20px 36px rgba(0,0,0,.32),
    0 44px 64px rgba(0,0,0,.26),
    0 72px 88px rgba(0,0,0,.18),
    0 88px 72px -32px rgba(0,0,0,.52);
  transition:
    filter .35s ease,
    box-shadow .55s ease;
  will-change:filter;
}
.artwork-item:hover .artwork-frame img{
  filter:blur(3.5px);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.055),
    0 2px 4px   rgba(0,0,0,.28),
    0 8px 16px  rgba(0,0,0,.34),
    0 20px 36px rgba(0,0,0,.32),
    0 44px 64px rgba(0,0,0,.26),
    0 72px 88px rgba(0,0,0,.18),
    0 88px 72px -32px rgba(0,0,0,.52);
}

/* Hover reveal overlay — no dark tint, blur image instead */
.artwork-overlay{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
  transition:none;
}
.artwork-item:hover .artwork-overlay{background:transparent;}
.artwork-overlay span{
  font-size:.60rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.95);
  background:rgba(10,10,12,.55);
  border:1px solid rgba(255,255,255,.22);
  padding:10px 24px;border-radius:3px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;transform:translateY(6px);
  transition:opacity .28s ease,transform .28s ease;
}
.artwork-item:hover .artwork-overlay span{opacity:1;transform:translateY(0);}

/* Status badge */
.artwork-badge{
  position:absolute;top:10px;left:10px;z-index:3;line-height:1;
  font-size:.52rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  padding:4px 10px;border-radius:3px;
  background:rgba(0,0,0,.6);color:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.artwork-badge.in-progress{color:var(--accent);border-color:rgba(41,151,255,.3);}
[data-theme="light"] .artwork-badge{background:rgba(255,255,255,.75);color:rgba(0,0,0,.45);border-color:rgba(0,0,0,.1);}

/* Caption */
.artwork-caption{padding:0 2px;border-top:1px solid rgba(255,255,255,.07);padding-top:16px;}
[data-theme="light"] .artwork-caption{border-top-color:rgba(0,0,0,.08);}
.artwork-num{display:block;font-size:.50rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);opacity:.38;margin-bottom:9px;}
.artwork-name{font-size:1.05rem;font-weight:600;letter-spacing:-.01em;color:#fff;margin-bottom:5px;white-space:nowrap;}
[data-theme="light"] .artwork-name{color:rgba(0,0,0,.92);}
.artwork-sub{font-size:.64rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);white-space:nowrap;}

/* ═══════════════════════════════════════════════════
   ARTWORK DESCRIPTION
   ═══════════════════════════════════════════════════ */
#artwork{padding:120px 56px;background:var(--bg2);border-top:1px solid var(--border);}
.artwork-layout{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:start;}
.artwork-body p{font-size:1.02rem;font-weight:400;line-height:1.84;color:var(--text2);margin-bottom:20px;}
.artwork-body p strong{font-weight:700;color:var(--white);}
.artwork-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:36px;}
.tag{font-size:.7rem;font-weight:500;letter-spacing:.01em;color:var(--text3);padding:7px 14px;border:1px solid var(--border);border-radius:980px;transition:all .18s;}
.tag:hover{color:var(--accent);border-color:var(--accent);}
.accordion{margin-top:0;}
.acc-item{border-bottom:1px solid var(--border);}
.acc-item:first-child{border-top:1px solid var(--border);}
.acc-btn{width:100%;background:none;border:none;display:flex;align-items:center;justify-content:space-between;padding:22px 0;cursor:none;text-align:left;}
.acc-num{font-size:.66rem;font-weight:500;letter-spacing:.02em;color:var(--text3);margin-right:18px;}
.acc-title{font-size:.98rem;font-weight:600;letter-spacing:-.01em;color:var(--white);flex:1;}
.acc-icon{color:var(--text3);font-size:.85rem;transition:transform .3s,color .3s;}
.acc-item.open .acc-icon{transform:rotate(45deg);color:var(--accent);}
.acc-body{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;}
.acc-item.open .acc-body{max-height:240px;padding-bottom:20px;}
.acc-body p{font-size:.95rem;font-weight:400;line-height:1.78;color:var(--text2);}
.medium-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin-top:80px;}
.medium-item{background:var(--bg2);padding:32px 28px;transition:background .2s;}
.medium-item:hover{background:var(--bg3);}
.medium-icon{color:var(--accent);margin-bottom:16px;opacity:.7;line-height:1;}
.medium-name{font-size:.98rem;font-weight:600;letter-spacing:-.01em;color:var(--white);margin-bottom:7px;}
.medium-desc{font-size:.72rem;font-weight:400;color:var(--text3);line-height:1.7;}

/* ═══════════════════════════════════════════════════
   EXHIBITIONS SECTION
   ═══════════════════════════════════════════════════ */
#exhibitions{padding:120px 56px;background:var(--bg);border-top:1px solid var(--border);}
.exhibitions-layout{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start;}
.exhibitions-sidebar p{font-size:1rem;font-weight:400;line-height:1.8;color:var(--text2);margin-bottom:24px;}
.exhibitions-count-badge{display:inline-flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border);border-radius:980px;padding:10px 18px;margin-top:8px;}
.exhibitions-count-badge span:first-child{font-size:1.5rem;font-weight:700;letter-spacing:-.04em;color:var(--white);}
.exhibitions-count-badge span:last-child{font-size:.7rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--text3);}
.exhibitions-list{display:flex;flex-direction:column;gap:0;}
.exh-item{display:grid;grid-template-columns:72px 1fr auto;gap:24px;align-items:start;padding:28px 0;border-bottom:1px solid var(--border);}
.exh-item:first-child{border-top:1px solid var(--border);}
.exh-year{font-size:1.6rem;font-weight:700;letter-spacing:-.04em;color:var(--border2);line-height:1;}
.exh-title{font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--white);margin-bottom:4px;}
.exh-venue{font-size:.82rem;font-weight:400;color:var(--text2);margin-bottom:4px;}
.exh-location{font-size:.72rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text3);}
.exh-type{align-self:center;}
.exh-badge{font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:5px 11px;border-radius:980px;white-space:nowrap;}
.exh-badge.solo{background:rgba(41,151,255,.12);color:var(--accent);border:1px solid rgba(41,151,255,.2);}
.exh-badge.group{background:var(--bg2);color:var(--text3);border:1px solid var(--border);}
[data-theme="light"] .exh-badge.solo{background:rgba(0,113,227,.08);color:#0071e3;border-color:rgba(0,113,227,.18);}

/* ═══════════════════════════════════════════════════
   PRESS & FEATURES SECTION
   ═══════════════════════════════════════════════════ */
#press{padding:120px 56px;background:var(--bg2);border-top:1px solid var(--border);}
.press-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;}
.press-header-right{font-size:.84rem;font-weight:400;color:var(--text3);text-align:right;line-height:1.9;max-width:260px;}
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.press-card{background:var(--bg2);padding:36px 32px;display:flex;flex-direction:column;gap:20px;transition:background .2s;cursor:none;position:relative;overflow:hidden;}
.press-card:hover{background:var(--bg3);}
.press-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;}
.press-card:hover::after{transform:scaleX(1);}
.press-outlet{display:flex;align-items:center;gap:12px;margin-bottom:4px;}
.press-outlet-icon{width:36px;height:36px;border-radius:8px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;letter-spacing:.04em;color:var(--text2);flex-shrink:0;border:1px solid var(--border);}
.press-outlet-logo{height:32px;width:auto;max-width:84px;object-fit:contain;border-radius:6px;background:#fff;padding:3px 6px;flex-shrink:0;border:1px solid var(--border);}
.press-outlet-logo.square{width:32px;height:32px;max-width:32px;padding:2px;border-radius:8px;}
.press-outlet-name{font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text3);}
.press-outlet-type{font-size:.62rem;font-weight:400;color:var(--text3);opacity:.7;}
.press-headline{font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--white);line-height:1.4;flex:1;}
.press-excerpt{font-size:.84rem;font-weight:400;line-height:1.7;color:var(--text2);flex:1;}
.press-meta{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--border);}
.press-date{font-size:.66rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text3);}
.press-link{font-size:.72rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:4px;}
.press-link svg{transition:transform .18s;}
.press-card:hover .press-link svg{transform:translate(3px,-3px);}
.press-card.featured{grid-column:span 2;flex-direction:row;gap:36px;align-items:flex-start;}
.press-card.press-card-tall{grid-row:span 2;}
.press-card-img{flex:1;border-radius:4px;overflow:hidden;min-height:0;}
.press-card-img img{width:100%;height:100%;object-fit:cover;display:block;border-radius:4px;}
.press-card.featured .press-featured-img{width:200px;flex-shrink:0;aspect-ratio:4/3;border-radius:4px;overflow:hidden;}
.press-featured-img-placeholder{width:100%;height:100%;background:var(--ap1);}
[data-theme="light"] .press-featured-img-placeholder{background:var(--ap2);}
.press-card.featured .press-content{flex:1;display:flex;flex-direction:column;gap:14px;}
.press-card.featured .press-headline{font-size:1.25rem;}
.press-card-tall .press-headline{flex:none;}
.press-card-tall .press-card-img{flex:1;min-height:180px;}

/* ═══════════════════════════════════════════════════
   SERIES
   ═══════════════════════════════════════════════════ */
#series{background:var(--bg);border-top:1px solid var(--border);overflow:hidden;}
.series-intro{display:grid;grid-template-columns:55% 45%;min-height:90vh;}
.series-visual-panel{position:relative;background:var(--bg2);overflow:hidden;border-right:1px solid var(--border);}
.series-atmosphere{position:absolute;inset:0;animation:atmo 10s ease-in-out infinite alternate;}
[data-theme="dark"] .series-atmosphere{background:radial-gradient(ellipse at 25% 60%,rgba(41,151,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 75% 30%,rgba(41,151,255,.05) 0%,transparent 45%),radial-gradient(ellipse at 50% 80%,rgba(41,151,255,.06) 0%,transparent 40%);}
[data-theme="light"] .series-atmosphere{background:radial-gradient(ellipse at 25% 60%,rgba(0,113,227,.04) 0%,transparent 50%),radial-gradient(ellipse at 75% 30%,rgba(0,0,0,.025) 0%,transparent 45%),radial-gradient(ellipse at 50% 80%,rgba(0,113,227,.03) 0%,transparent 40%);}
@keyframes atmo{from{opacity:.6;transform:scale(1)}to{opacity:1;transform:scale(1.04)}}
.b-fly{position:absolute;opacity:0;animation:bfly 5s ease-in-out infinite;}
.b-fly:nth-child(2){animation-delay:1.4s;animation-duration:6.5s}
.b-fly:nth-child(3){animation-delay:2.8s;animation-duration:4.8s}
.b-fly:nth-child(4){animation-delay:0.6s;animation-duration:7s}
.b-fly:nth-child(5){animation-delay:3.5s;animation-duration:5.5s}
@keyframes bfly{0%{opacity:0;transform:translateY(10px) scaleX(1)}15%{opacity:.75}50%{transform:translateY(-8px) scaleX(.82)}85%{opacity:.6}100%{opacity:0;transform:translateY(4px) scaleX(.95)}}
[data-theme="light"] .b-fly,[data-theme="light"] .parijat{filter:brightness(0) opacity(.08);}
[data-theme="light"] .sw-butterfly{filter:brightness(0) opacity(.12);}
.parijat{position:absolute;border-radius:50%;animation:pbloom 8s ease-in-out infinite alternate;}
@keyframes pbloom{from{transform:scale(.85) rotate(-5deg);opacity:.5}to{transform:scale(1.08) rotate(8deg);opacity:.85}}
.series-artwork-frame{position:absolute;inset:0;border-radius:0;overflow:hidden;z-index:1;}
.series-artwork-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;}
.series-stamp{position:absolute;bottom:48px;left:40px;writing-mode:vertical-rl;font-size:.58rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--text3);}
.series-year{position:absolute;bottom:48px;right:40px;font-size:5rem;font-weight:200;font-style:italic;color:transparent;-webkit-text-stroke:1px var(--border2);line-height:1;user-select:none;}
.series-text-panel{padding:84px 64px;display:flex;flex-direction:column;justify-content:center;}
.series-text-full{padding:80px 64px;}
@media(max-width:768px){.series-text-full{padding:56px 24px;}}
.series-eyebrow{font-size:.66rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);margin-bottom:22px;display:flex;align-items:center;gap:10px;}
.series-eyebrow::before{content:'';display:block;width:16px;height:1px;background:var(--text3);}
.series-heading{font-size:clamp(2.8rem,4.8vw,4.6rem);font-weight:700;line-height:.92;letter-spacing:-.04em;color:var(--white);margin-bottom:10px;}
.series-heading em{font-style:normal;font-weight:200;color:var(--accent);}
.series-np{font-size:.82rem;font-weight:400;letter-spacing:.05em;color:var(--text3);margin-bottom:36px;display:block;}
.series-translation{font-size:1rem;font-style:italic;font-weight:400;color:var(--text2);margin-bottom:32px;}
.series-text-panel p{font-size:1rem;font-weight:400;line-height:1.82;color:var(--text2);margin-bottom:18px;}
.series-text-panel p strong{font-weight:700;color:var(--white);}
.series-rule{width:28px;height:1px;background:var(--accent);margin:28px 0;}
.series-specs{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:36px;}
.spec{padding:18px 0 18px 18px;border-left:1px solid var(--border);transition:border-color .2s;}
.spec:hover{border-color:var(--accent);}
.spec-label{font-size:.64rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);margin-bottom:8px;display:block;}
.spec-val{font-size:.95rem;font-weight:600;letter-spacing:-.01em;color:var(--white);}
.series-works-row{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border);}
.sw-item{aspect-ratio:2/3;position:relative;overflow:hidden;cursor:pointer;}
.sw-item:nth-child(1){background:var(--sw1)}.sw-item:nth-child(2){background:var(--sw2)}.sw-item:nth-child(3){background:var(--sw3)}
.sw-butterfly{position:absolute;opacity:.22;animation:bfly 6s ease-in-out infinite;}
.sw-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.84) 0%,transparent 58%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px;opacity:0;transition:opacity .3s;}
.sw-item:hover .sw-overlay{opacity:1;}
.sw-title{font-size:1rem;font-weight:600;letter-spacing:-.02em;color:#fff;margin-bottom:4px;}
.sw-meta{font-size:.66rem;font-weight:400;color:rgba(255,255,255,.5);margin-bottom:14px;}
.sw-btn{font-size:.72rem;font-weight:600;padding:8px 14px;background:transparent;color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.3);cursor:none;width:fit-content;border-radius:8px;transition:all .18s;}
.sw-btn:hover{background:#fff;color:#000;border-color:#fff;}

/* ═══════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════ */
#about{padding:120px 56px;background:var(--bg2);border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center;}
.about-visual-wrap{position:relative;}
.about-main-img{width:80%;aspect-ratio:3/4;background:var(--about-img);position:relative;z-index:1;overflow:hidden;}
.about-main-img::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(88deg,transparent,transparent 4px,rgba(128,128,128,.01) 4px,rgba(128,128,128,.01) 5px);}
.about-accent-img{position:absolute;bottom:-20px;right:0;width:52%;aspect-ratio:1;background:var(--about-img2);z-index:2;border:3px solid var(--bg2);}
.about-num-tag{position:absolute;top:30px;right:10px;font-size:7rem;font-weight:200;font-style:italic;color:transparent;-webkit-text-stroke:1px var(--border2);line-height:1;user-select:none;z-index:0;}
.about-text h2{font-size:clamp(2.6rem,3.8vw,3.6rem);font-weight:700;letter-spacing:-.04em;line-height:.93;color:var(--white);margin-bottom:28px;}
.about-text h2 em{font-style:normal;font-weight:200;color:var(--text3);}
.about-text p{font-size:1rem;font-weight:400;line-height:1.85;color:var(--text2);margin-bottom:16px;}
.about-text p strong{font-weight:700;color:var(--white);}
.about-stats{display:flex;gap:32px;margin-top:44px;padding-top:36px;border-top:1px solid var(--border);}
.stat-n{font-size:2.3rem;font-weight:700;letter-spacing:-.05em;color:var(--white);line-height:1;}
.stat-l{font-size:.66rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--text3);margin-top:5px;}

/* ═══════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════ */
#contact{padding:120px 56px;background:var(--bg);border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:88px;}
.contact-left h2{font-size:clamp(2.6rem,4.2vw,4.4rem);font-weight:700;letter-spacing:-.04em;line-height:.93;color:var(--white);margin-bottom:24px;}
.contact-left h2 em{font-style:normal;font-weight:200;color:var(--text3);}
.contact-left p{font-size:1rem;font-weight:400;line-height:1.75;color:var(--text2);max-width:380px;margin-bottom:48px;}
.contact-links{display:flex;flex-direction:column;}
.c-link{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--border);font-size:.84rem;font-weight:500;color:var(--text2);transition:color .2s;}
.c-link:hover{color:var(--white);}
.c-link:hover .c-arrow{transform:translateX(6px);color:var(--accent);}
.c-arrow{transition:transform .2s,color .2s;color:var(--text3);}
.contact-form{display:flex;flex-direction:column;gap:24px;}
.f-group{display:flex;flex-direction:column;gap:8px;}
.f-label{font-size:.66rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);}
.f-input,.f-select,.f-textarea{background:transparent;border:none;border-bottom:1px solid var(--border2);padding:12px 0;font-family:'Inter',sans-serif;font-size:.96rem;font-weight:400;color:var(--white);outline:none;transition:border-color .25s;width:100%;}
.f-input:focus,.f-select:focus,.f-textarea:focus{border-color:var(--accent);}
.f-input::placeholder,.f-textarea::placeholder{color:var(--text3);font-style:normal;}
.f-select{-webkit-appearance:none;appearance:none;}
.f-select option{background:var(--bg);color:var(--text);}
.f-textarea{resize:none;height:106px;}
.f-submit{align-self:flex-start;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:600;letter-spacing:-.01em;padding:13px 28px;background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:8px;position:relative;overflow:hidden;transition:color .3s,border-color .3s;cursor:none;}
.f-submit::before{content:'';position:absolute;inset:0;background:var(--accent);transform:translateX(-102%);transition:transform .3s cubic-bezier(.25,.46,.45,.94);z-index:-1;}
.f-submit:hover{color:#fff;border-color:var(--accent);}
.f-submit:hover::before{transform:translateX(0);}

/* ═══════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════ */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:36px 56px;display:flex;justify-content:space-between;align-items:center;}
.f-logo{font-size:.88rem;font-weight:700;letter-spacing:-.02em;color:var(--white);}
.f-logo span{font-weight:400;color:var(--text3);}
footer p{font-size:.7rem;font-weight:400;color:var(--text3);}

/* ═══════════════════════════════════════════════════
   ARTWORK DETAIL MODAL
   ═══════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,0);display:flex;align-items:center;justify-content:center;padding:40px 24px;pointer-events:none;transition:background .3s ease;}
.modal-overlay.active{background:rgba(0,0,0,0.85);pointer-events:all;}
.modal-box{width:100%;max-width:960px;height:min(90vh,660px);background:var(--bg2);border:1px solid var(--border2);border-radius:16px;transform:translateY(24px) scale(0.97);opacity:0;transition:transform .35s cubic-bezier(.25,.46,.45,.94),opacity .35s ease;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;}
.modal-overlay.active .modal-box{transform:translateY(0) scale(1);opacity:1;}
.modal-img-panel{position:relative;background:#0a0a0a;display:flex;flex-direction:column;overflow:hidden;}
.modal-main-img{flex:1;min-height:0;width:100%;object-fit:contain;display:block;transition:opacity .18s ease;}
.modal-img-thumbnails{display:flex;gap:8px;padding:12px 16px;background:rgba(0,0,0,.6);overflow-x:auto;scrollbar-width:none;flex-shrink:0;}
.modal-img-thumbnails::-webkit-scrollbar{display:none;}
.modal-thumb{flex-shrink:0;width:52px;height:52px;border-radius:4px;background:var(--bg2);border:1px solid var(--border);cursor:none;transition:border-color .18s;overflow:hidden;}
.modal-thumb.active,.modal-thumb:hover{border-color:var(--accent);}
.modal-thumb-inner{width:100%;height:100%;background-size:cover;background-position:center;}
.modal-info-panel{padding:48px 40px;display:flex;flex-direction:column;overflow-y:auto;}
.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:none;color:var(--text3);font-size:1rem;line-height:1;transition:all .18s;z-index:10;}
.modal-close:hover{background:var(--bg2);color:var(--white);}
.modal-series-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(41,151,255,.1);border:1px solid rgba(41,151,255,.2);border-radius:980px;padding:5px 12px;margin-bottom:20px;width:fit-content;}
.modal-series-badge span{font-size:.62rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);}
[data-theme="light"] .modal-series-badge{background:rgba(0,113,227,.08);border-color:rgba(0,113,227,.18);}
[data-theme="light"] .modal-series-badge span{color:#0071e3;}
.modal-title{font-size:1.8rem;font-weight:700;letter-spacing:-.04em;color:var(--white);line-height:1;margin-bottom:8px;}
.modal-year{font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:28px;}
.modal-desc{font-size:.95rem;font-weight:400;line-height:1.8;color:var(--text2);margin-bottom:28px;}
.modal-desc p{margin-bottom:14px;}.modal-desc p:last-child{margin-bottom:0;}
.modal-specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:8px;overflow:hidden;margin-bottom:28px;}
.modal-spec{background:var(--bg2);padding:14px 16px;}
.modal-spec-l{font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);margin-bottom:4px;}
.modal-spec-v{font-size:.88rem;font-weight:600;letter-spacing:-.01em;color:var(--white);}
.modal-themes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:28px;}
.modal-theme-tag{font-size:.66rem;font-weight:500;padding:5px 11px;border:1px solid var(--border);border-radius:980px;color:var(--text3);}
.modal-actions{display:flex;gap:10px;margin-top:auto;padding-top:24px;border-top:1px solid var(--border);}
.modal-btn-primary{flex:1;font-size:.82rem;font-weight:600;letter-spacing:-.01em;padding:13px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;text-align:center;transition:opacity .2s;cursor:none;}
.modal-btn-primary:hover{opacity:.88;}
.modal-btn-secondary{font-size:.82rem;font-weight:500;letter-spacing:-.01em;padding:13px 20px;background:transparent;color:var(--text2);border:1px solid var(--border2);border-radius:8px;transition:color .2s,border-color .2s;cursor:none;}
.modal-btn-secondary:hover{color:var(--white);border-color:var(--text2);}

/* ═══════════════════════════════════════════════════
   REVEAL ANIMATION
   ═══════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════ */
@media(max-width:900px){
  #hero{min-height:100svh;}
  .hero-content{padding:0 24px 72px;max-width:100%;}
  .hero-name{font-size:clamp(3rem,12vw,5rem);}
  .hero-location{top:76px;right:24px;}
  .hero-scroll{right:24px;}
  .gallery-header{flex-direction:column;align-items:flex-start;padding:0 24px 36px;}
  .gallery-track{padding:8px 24px 96px;scroll-padding-left:24px;gap:20px;}
  .gallery-fade-r{width:60px;}
  .artwork-item{padding-top:48px;}
  .artwork-frame img{height:clamp(220px,55vw,480px);max-width:82vw;}
  .artwork-layout{grid-template-columns:1fr;gap:52px;}
  .exhibitions-layout{grid-template-columns:1fr;}
  .exh-item{grid-template-columns:60px 1fr;}.exh-type{display:none;}
  .press-grid{grid-template-columns:1fr;}.press-card.featured{grid-column:span 1;flex-direction:column;}
  .series-intro{grid-template-columns:1fr;}.series-visual-panel{min-height:400px;border-right:none;border-bottom:1px solid var(--border);}.series-text-panel{padding:56px 24px;}
  .series-works-row{grid-template-columns:repeat(2,1fr);}
  #about{grid-template-columns:1fr;padding:80px 24px;}
  #contact{grid-template-columns:1fr;padding:80px 24px;}
  #store,#artwork,#exhibitions,#press{padding:80px 24px;}
  .medium-strip{grid-template-columns:1fr 1fr;}
  footer{flex-direction:column;gap:14px;text-align:center;}
  .store-header,.press-header{flex-direction:column;align-items:flex-start;gap:10px;}
  .modal-box{grid-template-columns:1fr;height:auto;max-height:95vh;overflow-y:auto;}
  .modal-img-panel{height:56vw;min-height:220px;flex-shrink:0;}
  .modal-main-img{min-height:0;}
  .prayer-flags-wrap{display:none;}
}

/* ═══════════════════════════════════════════════════
   PRAYER FLAGS (LUNGTA) — NEPALI LUNGTA
   ═══════════════════════════════════════════════════ */
.prayer-flags-wrap{
  position:absolute;top:76px;left:0;right:0;
  height:150px;z-index:8;pointer-events:none;
}
.pf-rope{
  position:absolute;top:0;left:0;
  width:100%;height:62px;overflow:visible;
}
.pf-flag{
  position:absolute;width:36px;height:54px;
  transform-origin:top center;
  border-radius:0 0 3px 3px;
  opacity:.94;
  animation:pfWave 3.2s ease-in-out infinite;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
/* top binding strip */
.pf-flag::before{
  content:'';position:absolute;top:0;left:0;right:0;height:5px;
  background:rgba(0,0,0,0.22);
}
/* Om symbol centered on flag */
.pf-om{
  font-size:17px;font-weight:700;line-height:1;
  color:rgba(255,255,255,.82);
  text-shadow:0 1px 4px rgba(0,0,0,.5),0 0 8px rgba(0,0,0,.3);
  margin-top:6px;position:relative;z-index:1;
  font-family:serif;
}
.pf-w .pf-om,.pf-w2 .pf-om{color:rgba(0,0,0,.45);}

/* Vibrant Nepali lungta colors */
.pf-b  { background:#0f3fc2; box-shadow:inset 0 0 0 1px rgba(255,255,255,.12); }
.pf-w  { background:#f2edd8; box-shadow:inset 0 0 0 1px rgba(0,0,0,.08); }
.pf-r  { background:#d91010; box-shadow:inset 0 0 0 1px rgba(255,255,255,.12); }
.pf-g  { background:#0b7a32; box-shadow:inset 0 0 0 1px rgba(255,255,255,.12); }
.pf-y  { background:#c99000; box-shadow:inset 0 0 0 1px rgba(255,255,255,.12); }

[data-theme="light"] .pf-flag{opacity:.70;}
[data-theme="light"] .pf-w{background:#ddd8be;}

/* Staggered wave — creates propagating wind effect */
.prayer-flags-wrap .pf-flag:nth-child(2n+3) {animation-delay:-1.35s;animation-duration:3.6s;}
.prayer-flags-wrap .pf-flag:nth-child(3n+2) {animation-delay:-0.55s;}
.prayer-flags-wrap .pf-flag:nth-child(4n+3) {animation-delay:-1.9s;}
.prayer-flags-wrap .pf-flag:nth-child(5n+2) {animation-delay:-0.28s;animation-duration:2.8s;}
.prayer-flags-wrap .pf-flag:nth-child(7n+4) {animation-delay:-2.3s;}
.prayer-flags-wrap .pf-flag:nth-child(11n+5){animation-delay:-0.9s;animation-duration:4.0s;}

@keyframes pfWave{
  0%,100%{transform:rotate(-8deg) skewX(-4deg);}
  28%    {transform:rotate(7deg)  skewX(3.5deg);}
  62%    {transform:rotate(-5deg) skewX(-2deg);}
}

/* ═══════════════════════════════════════════════════
   MANASLU EDITION FEATURE BLOCK
   ═══════════════════════════════════════════════════ */
.manaslu-feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--border);
  background: var(--bg);
  min-height: 380px;
  overflow: hidden;
}
.manaslu-inner {
  padding: 72px 64px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  border-right: 1px solid var(--border);
  justify-content: center;
}
.manaslu-eyebrow {
  font-size: .60rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 10px;
}
.manaslu-pulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  animation: mpulse 2s ease-in-out infinite;
}
@keyframes mpulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.6)} }
.manaslu-title {
  font-size: clamp(2.8rem, 4.6vw, 5.2rem);
  font-weight: 700;
  letter-spacing: -.05em;
  line-height: .88;
  color: var(--white);
}
.manaslu-title em { font-style: normal; font-weight: 200; color: var(--accent); }
.manaslu-chapter {
  font-size: .68rem;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text3);
}
.manaslu-desc {
  font-size: .96rem;
  line-height: 1.82;
  color: var(--text2);
  max-width: 440px;
}
.manaslu-footer {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.manaslu-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .65rem;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text3);
}
.manaslu-notify {
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--accent);
  border: 1px solid rgba(41,151,255,.28);
  padding: 9px 18px;
  border-radius: 8px;
  transition: background .2s, border-color .2s;
  cursor: none;
}
.manaslu-notify:hover { background: rgba(41,151,255,.1); border-color: var(--accent); }
.manaslu-visual {
  position: relative;
  overflow: hidden;
  background: var(--bg2);
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.manaslu-mountain-svg {
  width: 100%;
  position: absolute;
  bottom: -2px;
  left: 0;
}
.manaslu-elev {
  position: absolute;
  top: 36px;
  right: 36px;
  font-size: .55rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text3);
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  opacity: .7;
}
.manaslu-gallery-strip{background:var(--bg2);border-top:1px solid var(--border);overflow:hidden;}
.manaslu-gallery-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;background:var(--border);}
.manaslu-gallery-track::-webkit-scrollbar{display:none;}
.manaslu-gallery-item{flex:0 0 280px;aspect-ratio:3/4;overflow:hidden;scroll-snap-align:start;background:var(--bg3);}
.manaslu-gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;}
.manaslu-gallery-item:hover img{transform:scale(1.05);}
@media(max-width:768px){.manaslu-gallery-item{flex:0 0 70vw;}}
.manaslu-chapter-label {
  padding: 22px 56px;
  font-size: .58rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text3);
  border-top: 1px solid var(--border);
  background: var(--bg);
  display: flex;
  align-items: center;
  gap: 12px;
}
.manaslu-chapter-label::before {
  content: '';
  display: block;
  width: 14px;
  height: 1px;
  background: var(--text3);
  opacity: .5;
}
@media(max-width:900px) {
  .manaslu-feature { grid-template-columns: 1fr; }
  .manaslu-inner { padding: 52px 24px; border-right: none; border-bottom: 1px solid var(--border); }
  .manaslu-visual { min-height: 200px; }
  .manaslu-chapter-label { padding: 18px 24px; }
}

/* ═══════════════════════════════════════════════════
   VIDEO — HIDE NATIVE CONTROLS & TAP CATCHER
   ═══════════════════════════════════════════════════ */
video::-webkit-media-controls,
video::-webkit-media-controls-enclosure,
video::-webkit-media-controls-panel,
video::-webkit-media-controls-play-button,
video::-webkit-media-controls-start-playback-button {
  display: none !important;
  -webkit-appearance: none !important;
  opacity: 0 !important;
}
.hero-video-tap {
  position: absolute;
  inset: 0;
  z-index: 1;
}

/* ═══════════════════════════════════════════════════
   MODAL IMAGE — ZOOM CURSOR (desktop)
   ═══════════════════════════════════════════════════ */
.modal-main-img { cursor: zoom-in; }
.modal-main-img:active { opacity: .82; }

/* ═══════════════════════════════════════════════════
   IMAGE LIGHTBOX
   ═══════════════════════════════════════════════════ */
.img-lightbox {
  position: fixed;
  inset: 0;
  z-index: 600;
  background: rgba(0,0,0,.97);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
  cursor: zoom-out;
}
.img-lightbox.active { opacity: 1; pointer-events: all; }
.img-lightbox #lightboxImg {
  max-width: 100%;
  max-height: calc(100vh - 80px);
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 4px;
  cursor: default;
  user-select: none;
  -webkit-user-select: none;
}
.lightbox-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.24);
  color: #fff;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1;
  transition: background .18s;
}
.lightbox-close:hover { background: rgba(255,255,255,.24); }

/* ═══════════════════════════════════════════════════
   TOUCH DEVICE — RESTORE NATURAL CURSORS
   ═══════════════════════════════════════════════════ */
@media (pointer: coarse) {
  #cur, #cur-ring { display: none !important; }
  body { cursor: auto; }
  button, .gallery-btn, .modal-close, .modal-thumb,
  .modal-btn-primary, .modal-btn-secondary, .acc-btn,
  .sw-btn, .manaslu-notify, .f-submit, .theme-toggle,
  .artwork-item, .press-card, a { cursor: pointer; }
  .modal-main-img { cursor: zoom-in; }
  .gallery-track { touch-action: pan-x; }
}
