*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --black: #080808;
  --dark: #111010;
  --dark2: #1a1a1a;
  --gold: #c9a96e;
  --gold-light: #e2c897;
  --white: #f5f2ee;
  --muted: #666;
  --grey: #2a2a2a;
  --gap: 3px;
}

html { scroll-behavior:smooth; }

body {
  background: var(--black);
  color: var(--white);
  font-family: 'Montserrat', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}

/* ── CURSOR (desktop only) ── */
@media (pointer: fine) {
  #cur, #cur-r { display: block; }
}
#cur {
  display:none;
  width:10px;
  height:10px;
  background:var(--gold);
  border-radius:50%;
  position:fixed;
  top:0;
  left:0;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,transform .2s;
}
#cur-r {
  display:none;
  width:36px;
  height:36px;
  border:1px solid rgba(201,169,110,.4);
  border-radius:50%;
  position:fixed;
  top:0;
  left:0;
  pointer-events:none;
  z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s;
}

/* ── NAV ── */
nav {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:200;
  padding:20px 48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(8,8,8,.97);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.nav-brand {
  text-align:center;
  flex:1;
}
.nav-brand h1 {
  
  font-weight:400;
  font-size:2rem;
  letter-spacing:.4em;
  text-transform:uppercase;
}
.nav-brand p {
  font-size:.8rem;
  letter-spacing:.5em;
  color:#fff;
  text-transform:uppercase;
  margin-top:3px;
}

/* ── HAMBURGER ── */
.hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:4px;
  z-index:300;
  background:none;
  border:none;
}
.hamburger span {
  display:block;
  width:22px;
  height:1px;
  background:var(--white);
  transition:all .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

/* ── DESKTOP MENU ── */
.menu {
  position:fixed;
  top:90px;
  left:0;
  right:0;
  z-index:199;
  display:flex;
  justify-content:center;
  gap:28px;
  padding:12px 24px;
  background:rgba(8,8,8,.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.04);
  flex-wrap:wrap;
}
.menu a {
  font-size:.78rem;
  letter-spacing:.18em;
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  transition:color .3s;
  position:relative;
  white-space:nowrap;
}
.menu a::after {
  content:'';
  position:absolute;
  bottom:-4px;
  left:0;
  right:0;
  height:1px;
  background:var(--gold);
  transform:scaleX(0);
  transition:transform .3s;
}
.menu a:hover { color:var(--white); }
.menu a:hover::after { transform:scaleX(1); }
.menu a.active {
  color:var(--gold);
  font-style:italic;
  font-weight:600;
}
.menu a.active::after { transform:scaleX(1); }

/* ── MOBILE MENU OVERLAY ── */
.menu-overlay {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(8,8,8,.98);
  z-index:198;
  flex-direction:column;
}
.menu-overlay.open { display:flex; }

.menu-overlay-close {
  flex-shrink:0;
  display:flex;
  justify-content:flex-end;
  padding:18px 20px 0;
}
.menu-overlay-close button {
  background:none;
  border:none;
  color:rgba(201,169,110,.5);
  font-family:'Montserrat', sans-serif;
  font-size:.52rem;
  letter-spacing:.35em;
  text-transform:uppercase;
  cursor:pointer;
  padding:6px 8px;
  transition:color .3s;
}
.menu-overlay-close button:hover { color:var(--gold); }

.menu-overlay-inner {
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:12px 0 40px;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,169,110,.2) transparent;
}
.menu-overlay-inner::-webkit-scrollbar { width:3px; }
.menu-overlay-inner::-webkit-scrollbar-track { background:transparent; }
.menu-overlay-inner::-webkit-scrollbar-thumb {
  background:rgba(201,169,110,.2);
  border-radius:2px;
}
.menu-overlay-inner a {
  font-family:'Cormorant Garamond', serif;
  font-size:2rem;
  font-weight:300;
  letter-spacing:.2em;
  color:var(--white);
  text-decoration:none;
  text-transform:uppercase;
  transition:color .3s;
  padding:9px 32px;
  width:100%;
  text-align:center;
  flex-shrink:0;
}
.menu-overlay-inner a:hover,
.menu-overlay-inner a.active {
  color:var(--gold);
}

/* ── PAGE TITLE ── */
.page-title {
  padding-top:126px;
  text-align:center;
  background:var(--black);
}
.page-title h2 {
  
  font-size:2rem;
  font-weight:400;
  letter-spacing:.55em;
  text-transform:uppercase;
  color:var(--white);
  padding:24px 0 20px;
  border-bottom:1px solid rgba(255,255,255,.06);
}

/* ── GRID ── */
.grid-wrap {
  background:var(--black);
  padding:var(--gap);
}
.grid {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-auto-rows:220px;
  gap:var(--gap);
}
.cell {
  position:relative;
  overflow:hidden;
  background:#111;
  cursor:pointer;
}
.r2 { grid-row: span 2; }
.r3 { grid-row: span 3; }

.cell img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:brightness(.9) saturate(.88);
  transition:transform .7s cubic-bezier(.16,1,.3,1), filter .5s ease;
}
.cell:hover img {
  transform:scale(1.05);
  filter:brightness(1) saturate(1.05);
}

.cell.white-bg { background:#f8f8f8; }
.cell.white-bg img {
  object-fit:contain;
  padding:20px;
  filter:none;
}
.cell.white-bg:hover img {
  transform:scale(1.04);
  filter:none;
}

.cell.grey-bg { background:#b8b4ae; }
.cell.grey-bg img {
  object-fit:cover;
  filter:brightness(.95) saturate(.7);
}

/* Overlay */
.ov {
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 55%);
  opacity:0;
  transition:opacity .4s;
  display:flex;
  align-items:flex-end;
  padding:14px;
}
.cell:hover .ov { opacity:1; }
.ov span {
  font-size:.48rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--gold);
}

/* Play btn */
.play {
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:44px;
  height:44px;
  border:1px solid rgba(255,255,255,.6);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:opacity .4s,border-color .3s;
}
.play svg {
  fill:#fff;
  width:14px;
  margin-left:3px;
}
.cell:hover .play {
  opacity:1;
  border-color:var(--gold);
}

/* ── NEXT PAGE ── */
.next-page {
  background:#181818;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:48px;
  margin-top:var(--gap);
}
.next-page a {
  
  font-size:2rem;
  font-weight:300;
  color:var(--white);
  text-decoration:underline;
  letter-spacing:.05em;
  transition:color .3s;
}
.next-page a:hover { color:var(--gold); }

/* ── FOOTER ── */
footer {
  background:var(--black);
  padding:48px 8% 32px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  border-top:1px solid rgba(255,255,255,.04);
}
.f-name {
  
  font-size:1.5rem;
  font-weight:400;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--gold);
}
.f-sub {
  font-size:.48rem;
  letter-spacing:.52em;
  text-transform:uppercase;
  color:var(--gold);
  opacity:.7;
}
.f-tag {
  font-size:.48rem;
  letter-spacing:.55em;
  text-transform:uppercase;
  color:var(--muted);
  text-decoration:underline;
  text-underline-offset:4px;
  margin-top:6px;
  transition:color .3s;
}
.f-tag:hover { color:var(--gold); }

/* ── LIGHTBOX ── */
.lb {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.97);
  z-index:1000;
  align-items:center;
  justify-content:center;
  flex-direction:column;
}
.lb.on { display:flex; }

.lb-img-wrap {
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  max-width:90vw;
  max-height:85vh;
}
.lb-img-wrap img {
  max-width:90vw;
  max-height:85vh;
  object-fit:contain;
  border-radius:2px;
  box-shadow:0 20px 80px rgba(0,0,0,.8);
  opacity:0;
  transform:scale(0.97);
  transition:opacity .25s ease, transform .25s ease;
}
.lb-img-wrap img.visible {
  opacity:1;
  transform:scale(1);
}

.lb-x {
  position:absolute;
  top:18px;
  right:22px;
  font-size:.55rem;
  letter-spacing:.3em;
  color:#fff;
  text-transform:uppercase;
  cursor:pointer;
  padding:8px 12px;
  border:1px solid rgb(255, 255, 255);
  transition:color .2s, border-color .2s;
  user-select:none;
}
.lb-x:hover { color:var(--gold); border-color:var(--gold); }

.lb-counter {
  margin-top:16px;
  font-size:.55rem;
  letter-spacing:.2em;
  color:rgba(255,255,255,.3);
  text-transform:uppercase;
}

.lb-nav {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);
  width:48px;
  height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:18px;
  transition:background .2s, color .2s, border-color .2s;
  user-select:none;
  border-radius:50%;
}
.lb-nav:hover { background:rgba(201,169,110,.12); color:var(--gold); border-color:var(--gold); }
#prevBtn { left:20px; }
#nextBtn { right:20px; }

.lb-hint {
  position:absolute;
  bottom:16px;
  font-size:.5rem;
  letter-spacing:.15em;
  color:rgba(255,255,255,.18);
  text-transform:uppercase;
}

@keyframes fi { from{opacity:0} to{opacity:1} }

.reveal {
  opacity:0;
  transform:translateY(16px);
  transition:opacity .8s ease,transform .8s ease;
}
.reveal.in {
  opacity:1;
  transform:translateY(0);
}

/* ════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ════════════════════════════════════ */
@media (max-width:900px) {
  nav { padding:18px 24px; }
  .nav-brand h1 { font-size:1.1rem; letter-spacing:.3em; }
  .nav-brand p { font-size:.5rem; letter-spacing:.35em; }
  .menu { display:none; }
  .hamburger { display:flex; }
  .page-title { padding-top:72px; }
  .page-title h2 {
    font-size:1.1rem;
    letter-spacing:.4em;
    padding:18px 0 16px;
  }
  .grid {
    grid-template-columns:1fr 1fr;
    grid-auto-rows:180px;
  }
  .cell.r3 { grid-row:span 2; }
  .cell.r2 { grid-row:span 2; }
  .next-page { padding:36px; }
  .next-page a { font-size:1.6rem; }
}

/* ── MOBILE: Portrait images fix ── */
@media (max-width:540px) {
  nav { padding:14px 16px; }
  .nav-brand h1 { font-size:.95rem; letter-spacing:.25em; }
  .nav-brand p { display:none; }
  .page-title { padding-top:64px; }
  .page-title h2 {
    font-size:.9rem;
    letter-spacing:.35em;
    padding:14px 0 12px;
  }

  /* ── KEY FIX: Single column, height auto — image poori dikhegi ── */
  .grid {
    grid-template-columns: 1fr;
    grid-auto-rows: unset;     /* fixed height hatao */
    display: flex;
    flex-direction: column;
    gap: var(--gap);
  }

  /* Har cell apni image ki height le */
  .grid .cell {
    width: 100%;
    height: auto;
    grid-row: unset !important;
  }

  /* Image naturally full width, apni asli height mein */
  .grid .cell img {
    width: 100%;
    height: auto;
    object-fit: unset;        /* cover nahi — contain bhi nahi, natural */
    max-height: none;
  }

  .cell .ov {
    opacity:1;
    background:linear-gradient(to top, rgba(0,0,0,.4) 0%, transparent 60%);
  }
  .cell .play { opacity:1; }
  .next-page { padding:28px 16px; }
  .next-page a { font-size:1.3rem; }
  footer { padding:36px 16px 24px; }
  .f-name { font-size:1.2rem; }
  .lb-x { top:12px; right:12px; font-size:.6rem; }
  #prevBtn { left:8px; }
  #nextBtn { right:8px; }
  .lb-nav { width:38px; height:38px; font-size:14px; }

  .menu-overlay-inner a {
    font-size:1.6rem;
    padding:8px 24px;
  }
}

@media (max-width:360px) {
  .nav-brand h1 { font-size:.82rem; letter-spacing:.18em; }

  .menu-overlay-inner a {
    font-size:1.35rem;
    padding:7px 20px;
  }
}

.video-cell { cursor: pointer; }

.cell-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(.9) saturate(.88);
  transition: transform .7s cubic-bezier(.16,1,.3,1), filter .5s ease;
  pointer-events: none;
}
.video-cell:hover .cell-video {
  transform: scale(1.05);
  filter: brightness(1) saturate(1.05);
}

.video-cell .play { opacity: .55; }
.video-cell:hover .play { opacity: 1; border-color: var(--gold); }

#lb-video {
  border-radius: 2px;
  background: #000;
}
#lb-video::-webkit-media-controls { opacity: .8; }
