*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#C8001A;
  --red2:#E5001E;
  --ink:#0D0D0D;
  --paper:#F5F2EE;
  --warm:#EDE8E1;
  --muted:#9A9490;
  --white:#FFFFFF;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--paper);color:var(--ink);overflow-x:hidden;cursor:none}

.cursor{position:fixed;width:10px;height:10px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width 0.2s,height 0.2s}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid var(--red);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:0.5;transition:width 0.2s,height 0.2s,opacity 0.2s}

nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:0.75rem 3rem;background:rgba(13,13,13,0.95);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,0.06)}
.nav-wordmark{display:flex;align-items:center;text-decoration:none}
.nav-wordmark img{height:72px;width:auto;display:block}
.nav-right{display:flex;align-items:center;gap:2.5rem}
.nav-link{font-family:'Space Mono',monospace;font-size:0.7rem;letter-spacing:0.08em;color:rgba(255,255,255,0.45);text-decoration:none;transition:color 0.2s}
.nav-link:hover{color:var(--red)}
.nav-pill{font-family:'Space Mono',monospace;font-size:0.7rem;letter-spacing:0.08em;background:var(--red);color:var(--white);padding:0.5rem 1.2rem;text-decoration:none;transition:background 0.2s}
.nav-pill:hover{background:#E5001E}

/* HERO */
#hero{min-height:100vh;background:var(--paper);display:grid;grid-template-columns:1fr 1fr;padding-top:5rem;position:relative;overflow:hidden}
.hero-left{padding:6rem 3rem 4rem;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid rgba(0,0,0,0.1)}
.hero-eyebrow{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--red);margin-bottom:2.5rem;display:flex;align-items:center;gap:0.8rem}
.hero-eyebrow::before{content:'';width:20px;height:1px;background:var(--red)}
h1{font-family:'Anton',sans-serif;font-size:clamp(5rem,10vw,10rem);line-height:0.88;text-transform:uppercase;letter-spacing:-0.01em}
h1 em{font-style:italic;color:var(--white);-webkit-text-stroke:2px var(--ink)}
h1 .break{display:block}
.hero-meta{display:flex;flex-direction:column;gap:1.5rem;margin-top:4rem}
.hero-desc{font-size:1rem;line-height:1.75;color:#555;max-width:380px;font-weight:300}
.hero-actions{display:flex;gap:1rem;align-items:center;margin-top:0.5rem}
.btn-main{font-family:'Space Mono',monospace;font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;background:var(--red);color:var(--white);padding:0.85rem 2rem;text-decoration:none;transition:background 0.2s,transform 0.15s;display:inline-block}
.btn-main:hover{background:var(--ink);transform:translateY(-1px)}
.btn-ghost{font-family:'Space Mono',monospace;font-size:0.72rem;letter-spacing:0.08em;color:var(--muted);text-decoration:none;border-bottom:1px solid transparent;transition:color 0.2s,border-color 0.2s}
.btn-ghost:hover{color:var(--ink);border-color:var(--ink)}
.hero-right{position:relative;overflow:hidden;background:var(--ink);display:flex;flex-direction:column;justify-content:flex-end;padding:3rem;min-height:80vh}
.hero-big-year{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Anton',sans-serif;font-size:22vw;color:rgba(255,255,255,0.04);line-height:1;user-select:none;pointer-events:none;white-space:nowrap}
.hero-since{font-family:'Space Mono',monospace;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:0.5rem}
.hero-location{font-family:'Anton',sans-serif;font-size:2rem;color:var(--white);letter-spacing:0.05em;text-transform:uppercase}
.hero-location span{color:var(--red)}
.hero-stat-row{display:flex;gap:3rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,0.1)}
.hstat .n{font-family:'Anton',sans-serif;font-size:2.5rem;color:var(--white);line-height:1}
.hstat .l{font-family:'Space Mono',monospace;font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:0.3rem}

/* MARQUEE */
.marquee-strip{background:var(--red);color:var(--white);overflow:hidden;padding:0.7rem 0}
.marquee-inner{display:flex;white-space:nowrap;animation:marquee 18s linear infinite}
.marquee-inner span{font-family:'Anton',sans-serif;font-size:0.85rem;letter-spacing:0.15em;text-transform:uppercase;padding:0 2.5rem}
.marquee-inner .dot{font-size:0.5rem;opacity:0.5;vertical-align:middle}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* STORY */
#story{display:grid;grid-template-columns:5fr 7fr;min-height:80vh}
.story-left{background:var(--red);color:var(--white);padding:6rem 3rem;display:flex;flex-direction:column;justify-content:space-between}
.story-num{font-family:'Anton',sans-serif;font-size:7rem;line-height:1;color:rgba(255,255,255,0.15);margin-bottom:auto}
.story-left h2{font-family:'Anton',sans-serif;font-size:3.5rem;line-height:1;text-transform:uppercase;letter-spacing:0.02em;margin-top:2rem}
.story-left p{font-size:0.9rem;line-height:1.8;color:rgba(255,255,255,0.7);margin-top:1.5rem;max-width:280px;font-weight:300}
.story-right{background:var(--warm);padding:6rem 4rem;display:flex;flex-direction:column;justify-content:center;gap:2.5rem}
.story-right blockquote{font-family:'Anton',sans-serif;font-size:2.2rem;line-height:1.2;text-transform:uppercase;border-left:3px solid var(--red);padding-left:1.5rem;letter-spacing:0.01em}
.story-right blockquote em{color:var(--red);font-style:normal}
.story-body{font-size:1rem;line-height:1.85;color:#555;font-weight:300;columns:2;gap:2.5rem}
.story-body p+p{margin-top:1rem}
.tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1rem}
.tag{font-family:'Space Mono',monospace;font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;border:1px solid rgba(0,0,0,0.2);padding:0.3rem 0.8rem;color:var(--muted)}

/* PROGRAM */
#program{padding:6rem 3rem;background:var(--paper)}
.program-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4rem;border-bottom:1px solid rgba(0,0,0,0.1);padding-bottom:2rem}
.program-header h2{font-family:'Anton',sans-serif;font-size:clamp(3rem,6vw,6rem);text-transform:uppercase;line-height:0.9;letter-spacing:0.01em}
.program-header h2 em{color:var(--red);font-style:normal}
.program-side{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);text-align:right;line-height:2;margin-top:0.5rem}
.program-list{display:flex;flex-direction:column}
.prog-item{display:grid;grid-template-columns:60px 1fr auto;align-items:start;gap:2.5rem;padding:2.5rem 0;border-bottom:1px solid rgba(0,0,0,0.08);transition:background 0.2s,padding 0.2s,margin 0.2s;cursor:default}
.prog-item:hover{background:rgba(200,0,26,0.03);margin:0 -3rem;padding:2.5rem 3rem}
.prog-n{font-family:'Space Mono',monospace;font-size:0.65rem;color:var(--muted);letter-spacing:0.1em;margin-top:0.4rem}
.prog-body h3{font-family:'Anton',sans-serif;font-size:2rem;text-transform:uppercase;letter-spacing:0.02em;line-height:1;margin-bottom:0.6rem}
.prog-body p{font-size:0.9rem;line-height:1.75;color:#666;max-width:520px;font-weight:300}
.prog-level{font-family:'Space Mono',monospace;font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;padding:0.3rem 0.7rem}
.lv-1{background:rgba(0,0,0,0.05);color:var(--muted)}
.lv-2{background:rgba(200,0,26,0.08);color:var(--red)}
.lv-3{background:var(--ink);color:var(--white)}

/* JADWAL */
#jadwal{background:var(--ink);color:var(--white);padding:6rem 3rem}
.jadwal-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem}
.jadwal-top h2{font-family:'Anton',sans-serif;font-size:clamp(3rem,5vw,5rem);text-transform:uppercase;line-height:0.95}
.jadwal-top h2 em{color:var(--red);font-style:normal}
.jadwal-note{font-family:'Space Mono',monospace;font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.25);text-align:right;line-height:1.8}
.schedule{display:flex;flex-direction:column}
.sched-item{display:grid;grid-template-columns:120px 1fr 140px;align-items:center;gap:2rem;padding:1.5rem 0;border-bottom:1px solid rgba(255,255,255,0.06);transition:background 0.15s,padding 0.15s,margin 0.15s}
.sched-item:hover{background:rgba(200,0,26,0.08);margin:0 -3rem;padding:1.5rem 3rem}
.sched-day{font-family:'Anton',sans-serif;font-size:1.3rem;text-transform:uppercase;letter-spacing:0.05em;color:var(--white)}
.sched-time{font-family:'Space Mono',monospace;font-size:0.7rem;color:rgba(255,255,255,0.35);letter-spacing:0.08em;margin-top:0.2rem}
.sched-name{font-size:0.95rem;color:rgba(255,255,255,0.75)}
.sched-sub{font-family:'Space Mono',monospace;font-size:0.6rem;color:rgba(255,255,255,0.25);letter-spacing:0.08em;margin-top:0.2rem}
.badge{font-family:'Space Mono',monospace;font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;display:inline-block;padding:0.25rem 0.6rem;justify-self:end}
.badge-beg{border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.4)}
.badge-mid{border:1px solid rgba(200,0,26,0.5);color:var(--red)}
.badge-adv{background:var(--red);color:var(--white)}

/* JOIN */
#join{display:grid;grid-template-columns:1fr 1fr;min-height:70vh}
.join-left{background:var(--red);padding:6rem 4rem;display:flex;flex-direction:column;justify-content:space-between}
.join-left h2{font-family:'Anton',sans-serif;font-size:clamp(4rem,7vw,7rem);text-transform:uppercase;line-height:0.88;color:var(--white)}
.join-left h2 em{font-style:normal;color:transparent;-webkit-text-stroke:2px var(--white)}
.join-tagline{font-size:1.05rem;color:rgba(255,255,255,0.75);font-weight:300;line-height:1.7;max-width:300px}
.join-right{background:var(--white);padding:6rem 4rem;display:flex;flex-direction:column;justify-content:center;gap:2.5rem}
.join-right h3{font-family:'Anton',sans-serif;font-size:1.8rem;text-transform:uppercase;letter-spacing:0.03em;margin-bottom:-1rem}
.form-field{display:flex;flex-direction:column;gap:0.5rem}
.form-field label{font-family:'Space Mono',monospace;font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted)}
.form-field input{border:none;border-bottom:1.5px solid rgba(0,0,0,0.15);background:transparent;font-family:'DM Sans',sans-serif;font-size:1rem;padding:0.6rem 0;color:var(--ink);outline:none;transition:border-color 0.2s}
.form-field input:focus{border-color:var(--red)}
.form-field input::placeholder{color:#ccc}
.submit-btn{font-family:'Space Mono',monospace;font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;background:var(--ink);color:var(--white);border:none;padding:1rem 2.5rem;cursor:pointer;align-self:flex-start;transition:background 0.2s,transform 0.15s}
.submit-btn:hover{background:var(--red);transform:translateY(-1px)}
.join-contact{display:flex;flex-direction:column;gap:0.6rem;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,0.08)}
.jc{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.06em;color:var(--muted);text-decoration:none;transition:color 0.2s}
.jc:hover{color:var(--red)}
.jc strong{font-weight:700;color:var(--ink)}

/* FOOTER */
footer{background:var(--ink);border-top:1px solid rgba(255,255,255,0.05);padding:2.5rem 3rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.f-brand{font-family:'Anton',sans-serif;font-size:1rem;letter-spacing:0.2em;color:var(--white);text-transform:uppercase}
.f-brand span{color:var(--red)}
.f-copy{font-family:'Space Mono',monospace;font-size:0.6rem;letter-spacing:0.1em;color:rgba(255,255,255,0.2);text-transform:uppercase}
.f-links{display:flex;gap:2rem}
.f-links a{font-family:'Space Mono',monospace;font-size:0.6rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.3);text-decoration:none;transition:color 0.2s}
.f-links a:hover{color:var(--red)}

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

/* GALERI */
#galeri{padding:6rem 0 6rem 3rem;background:var(--ink);overflow:hidden}
.galeri-header{display:flex;justify-content:space-between;align-items:flex-end;padding-right:3rem;margin-bottom:3rem}
.galeri-eyebrow{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--red);margin-bottom:1rem;display:flex;align-items:center;gap:0.8rem}
.galeri-eyebrow::before{content:'';width:20px;height:1px;background:var(--red)}
#galeri h2{font-family:'Anton',sans-serif;font-size:clamp(3rem,6vw,6rem);text-transform:uppercase;line-height:0.9;color:var(--white)}
#galeri h2 em{color:var(--red);font-style:normal}
.galeri-ig-link{font-family:'Space Mono',monospace;font-size:0.7rem;letter-spacing:0.08em;color:rgba(255,255,255,0.4);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.15);padding-bottom:0.2rem;transition:color 0.2s,border-color 0.2s;white-space:nowrap;align-self:flex-end}
.galeri-ig-link:hover{color:var(--red);border-color:var(--red)}
.galeri-scroll{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;cursor:grab}
.galeri-scroll:active{cursor:grabbing}
.galeri-scroll::-webkit-scrollbar{height:2px}
.galeri-scroll::-webkit-scrollbar-track{background:rgba(255,255,255,0.05)}
.galeri-scroll::-webkit-scrollbar-thumb{background:var(--red)}
.galeri-track{display:flex;gap:1rem;padding-right:3rem}
.galeri-item{flex:0 0 280px;aspect-ratio:3/4;position:relative;overflow:hidden;scroll-snap-align:start}
.galeri-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%);transition:filter 0.4s,transform 0.4s;display:block}
.galeri-item:hover img{filter:grayscale(0%);transform:scale(1.05)}
.galeri-placeholder{width:100%;height:100%;background:linear-gradient(160deg,#1a1a1a 0%,#0d0d0d 100%);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.05);transition:border-color 0.3s}
.galeri-item:hover .galeri-placeholder{border-color:rgba(200,0,26,0.3)}
.galeri-placeholder span{font-family:'Anton',sans-serif;font-size:4rem;color:rgba(255,255,255,0.06);line-height:1}
.galeri-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,0.75));padding:2.5rem 1.2rem 1.2rem;opacity:0;transition:opacity 0.3s}
.galeri-item:hover .galeri-overlay{opacity:1}
.galeri-overlay span{font-family:'Space Mono',monospace;font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--white)}
@media(max-width:900px){
  #galeri{padding:4rem 0 4rem 1.5rem}
  .galeri-header{padding-right:1.5rem;flex-direction:column;align-items:flex-start;gap:1.5rem}
  .galeri-item{flex:0 0 220px}
  .galeri-track{padding-right:1.5rem}
}

/* PELATIH */
#pelatih{padding:6rem 3rem;background:var(--warm)}
.pelatih-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem;border-bottom:1px solid rgba(0,0,0,0.1);padding-bottom:2rem}
.pelatih-header h2{font-family:'Anton',sans-serif;font-size:clamp(3rem,6vw,6rem);text-transform:uppercase;line-height:0.9;letter-spacing:0.01em}
.pelatih-header h2 em{color:var(--red);font-style:normal}
.pelatih-header p{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);text-align:right;line-height:2}
.pelatih-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem 1.5rem;}
.coach-card{display:flex;flex-direction:column;gap:0;cursor:default}
.coach-photo{
  width:100%;aspect-ratio:3/4;background:var(--ink);
  position:relative;overflow:hidden;
}
.coach-photo img{
  width:100%;height:100%;object-fit:cover;
  display:block;filter:grayscale(20%);
  transition:filter 0.4s,transform 0.4s;
}
.coach-card:hover .coach-photo img{filter:grayscale(0%);transform:scale(1.03)}
.coach-photo-placeholder{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:0.8rem;
  background:linear-gradient(160deg,#1a1a1a 0%,#0d0d0d 100%);
}
.coach-photo-placeholder .ph-icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(200,0,26,0.15);border:1px solid rgba(200,0,26,0.3);
  display:flex;align-items:center;justify-content:center;
}
.coach-photo-placeholder .ph-icon svg{width:28px;height:28px;fill:rgba(200,0,26,0.5)}
.coach-photo-placeholder .ph-label{
  font-family:'Space Mono',monospace;font-size:0.55rem;
  letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.2);text-align:center;line-height:1.6;
}
.coach-overlay{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(0,0,0,0.7));
  padding:2rem 1rem 1rem;
  opacity:0;transition:opacity 0.3s;
}
.coach-card:hover .coach-overlay{opacity:1}
.coach-overlay-spec{
  font-family:'Space Mono',monospace;font-size:0.6rem;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--red);
}
.coach-info{padding:1rem 0 0}
.coach-name{
  font-family:'Anton',sans-serif;font-size:1.15rem;
  text-transform:uppercase;letter-spacing:0.03em;
  color:var(--ink);line-height:1;
}
.coach-spec{
  font-family:'Space Mono',monospace;font-size:0.6rem;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--muted);margin-top:0.35rem;
}
.coach-num{
  font-family:'Space Mono',monospace;font-size:0.55rem;
  letter-spacing:0.12em;color:rgba(0,0,0,0.2);
  margin-bottom:0.5rem;
}
@media(max-width:900px){
  #pelatih{padding:4rem 1.5rem}
  .pelatih-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
  .pelatih-header{flex-direction:column;gap:1rem;align-items:flex-start}
  .pelatih-header p{text-align:left}
}

@media(max-width:900px){
  nav{padding:1rem 1.5rem}
  .nav-right .nav-link{display:none}
  #hero{grid-template-columns:1fr;padding-top:4rem}
  .hero-left{padding:4rem 1.5rem 3rem}
  .hero-right{min-height:50vh;padding:2rem 1.5rem}
  h1{font-size:4.5rem}
  #story{grid-template-columns:1fr}
  .story-body{columns:1}
  #program{padding:4rem 1.5rem}
  .prog-item{grid-template-columns:40px 1fr;gap:1rem}
  .prog-level{display:none}
  .program-header{flex-direction:column;gap:1rem}
  #jadwal{padding:4rem 1.5rem}
  .sched-item{grid-template-columns:100px 1fr;gap:1rem}
  .badge{display:none}
  #join{grid-template-columns:1fr}
  .join-left,.join-right{padding:4rem 1.5rem}
  footer{padding:2rem 1.5rem;flex-direction:column;align-items:flex-start;gap:1.5rem}
}
/* ═══ GALLERY ═══ */
#gallery{padding:6rem 3rem;background:var(--ink);color:var(--white)}
.gallery-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem}
.gallery-header h2{font-family:'Anton',sans-serif;font-size:clamp(3rem,5vw,5rem);text-transform:uppercase;line-height:0.95}
.gallery-header h2 em{color:var(--red);font-style:normal}
.gallery-header a{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.35);text-decoration:none;border-bottom:1px solid transparent;transition:color 0.2s,border-color 0.2s}
.gallery-header a:hover{color:var(--red);border-color:var(--red)}

/* Bento Grid */
.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:260px 260px;gap:4px}

/* Layout bento: 1 besar kiri, 2 kecil kanan atas, 1 medium bawah kiri, 1 besar bawah kanan */
.bento-item{position:relative;overflow:hidden;background:#1a1a1a;cursor:pointer}
.bento-item:nth-child(1){grid-column:1/3;grid-row:1/2}
.bento-item:nth-child(2){grid-column:3/5;grid-row:1/2}
.bento-item:nth-child(3){grid-column:5/7;grid-row:1/2}
.bento-item:nth-child(4){grid-column:1/3;grid-row:2/3}
.bento-item:nth-child(5){grid-column:3/5;grid-row:2/3}
.bento-item:nth-child(6){grid-column:5/7;grid-row:2/3}

/* Featured — item pertama lebih besar */
.bento-item.featured{grid-column:1/3;grid-row:1/3}
.bento-item:nth-child(2){grid-column:3/5;grid-row:1/2}
.bento-item:nth-child(3){grid-column:5/7;grid-row:1/2}
.bento-item:nth-child(4){grid-column:3/5;grid-row:2/3}
.bento-item:nth-child(5){grid-column:5/6;grid-row:2/3}
.bento-item:nth-child(6){grid-column:6/7;grid-row:2/3}

.bento-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease,filter 0.3s}
.bento-item:hover img{transform:scale(1.05);filter:brightness(0.75)}

/* Placeholder kalau belum ada foto */
.bento-placeholder{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:0.8rem;
  background:linear-gradient(135deg,#181818 0%,#111 100%);
}
.bento-placeholder .ph-label{
  font-family:'Space Mono',monospace;font-size:0.6rem;
  letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.15);text-align:center;line-height:1.8;
}
.bento-placeholder .ph-icon{font-size:2rem;opacity:0.12}


/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,0.95);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity 0.25s;
}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;display:block}
.lightbox-close{
  position:absolute;top:1.5rem;right:2rem;
  font-family:'Space Mono',monospace;font-size:0.75rem;
  letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.5);background:none;border:none;
  cursor:pointer;transition:color 0.2s;
}
.lightbox-close:hover{color:var(--red)}

@media(max-width:900px){
  #gallery{padding:4rem 1.5rem}
  .gallery-header{flex-direction:column;align-items:flex-start;gap:1rem}
  .bento{grid-template-columns:1fr 1fr;grid-template-rows:repeat(4,180px)}
  .bento-item.featured,.bento-item:nth-child(1){grid-column:1/3;grid-row:1/2}
  .bento-item:nth-child(2){grid-column:1/2;grid-row:2/3}
  .bento-item:nth-child(3){grid-column:2/3;grid-row:2/3}
  .bento-item:nth-child(4){grid-column:1/2;grid-row:3/4}
  .bento-item:nth-child(5){grid-column:2/3;grid-row:3/4}
  .bento-item:nth-child(6){grid-column:1/3;grid-row:4/5}
}