
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0A0A0A;
  --dark:#111111;
  --card:#1A1A1A;
  --card2:#222222;
  --gold:#C8A96E;
  --goldlt:#D4BA8A;
  --white:#F5F0E8;
  --muted:#888880;
  --line:#2A2A2A;
}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--white);font-family:'Josefin Sans',sans-serif;font-weight:300;overflow-x:hidden}

/* ===== SIGNATURE: 35mm FRAME RAIL =====
   A running film-strip index fixed to the left edge. It is the actual
   table of contents of the page (10 sections = 10 frames), not decoration:
   sprocket holes mark scroll progress, the frame number + name update as
   sections pass, functioning as a persistent "you are here" for a studio
   whose whole business is exposing frames in sequence. */
#filmRail{
  position:fixed;left:0;top:0;bottom:0;width:34px;z-index:940;
  background:var(--black);border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;
  padding:24px 0
}
.rail-sprockets{
  flex:1;width:100%;
  background-image:repeating-linear-gradient(to bottom,var(--line) 0 2px,transparent 2px 22px);
  background-position:center top;background-repeat:repeat-y;background-size:6px 22px;
  position:relative
}
.rail-progress{
  position:absolute;left:0;top:0;width:100%;height:0%;
  background:linear-gradient(to bottom,transparent,rgba(200,169,110,0.35));
  transition:height 0.2s linear
}
.rail-frame{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-90deg);
  white-space:nowrap;font-size:8px;letter-spacing:0.35em;text-transform:uppercase;color:var(--gold)
}
.rail-frame small{color:var(--muted);letter-spacing:0.3em;margin-left:10px}
html{background:var(--black)}
body{margin-left:34px}
nav{margin-left:34px}
@media(max-width:900px){
  #filmRail{display:none}
  body{margin-left:0}
  nav{margin-left:0}
}

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

.lang-toggle{
  position:fixed;top:0;right:0;z-index:950;
  display:flex;align-items:center;gap:0;
  background:rgba(10,10,10,0.9);border:1px solid var(--line);
  margin:20px 20px 0 0;
}
.lang-btn{
  font-size:8px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--muted);padding:8px 14px;background:none;border:none;cursor:pointer;transition:all 0.3s
}
.lang-btn.active{color:var(--black);background:var(--gold)}
.lang-btn:hover:not(.active){color:var(--white)}

nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 60px;
  background:linear-gradient(to bottom,rgba(10,10,10,0.95) 0%,transparent 100%);
  transition:background 0.4s
}
nav.scrolled{background:rgba(10,10,10,0.97);border-bottom:1px solid var(--line)}
.nav-logo{text-decoration:none;display:block}
.nav-logo-img{width:140px;height:auto;display:block;filter:drop-shadow(0 0 12px rgba(200,169,110,0.35));transition:filter 0.3s}
.nav-logo:hover .nav-logo-img{filter:drop-shadow(0 0 20px rgba(200,169,110,0.6))}
.nav-logo-text{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;letter-spacing:0.2em;display:none;
  background:linear-gradient(90deg,var(--gold) 0%,var(--goldlt) 50%,var(--gold) 100%);
  background-size:200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmer 3s infinite linear}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{font-size:10px;letter-spacing:0.25em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.3s}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-cta{font-size:9px;letter-spacing:0.3em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:10px 24px;text-decoration:none;transition:opacity 0.3s;margin-right:80px}
.nav-cta:hover{opacity:0.85}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:var(--white)}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--black);z-index:880;flex-direction:column;align-items:center;justify-content:center;gap:36px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:12px;letter-spacing:0.35em;text-transform:uppercase;color:var(--white);text-decoration:none}
.mobile-menu a:hover{color:var(--gold)}
.mobile-close{position:absolute;top:28px;right:28px;font-size:28px;cursor:pointer;background:none;border:none;color:var(--white)}

#hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 60px 80px;
  position:relative;overflow:hidden;
  background:var(--black)
}
.hero-parallax-bg{
  position:absolute;inset:-10% 0;
  background:linear-gradient(160deg,#0A0A0A 0%,#0f0c08 100%);
  will-change:transform;
}
.hero-glow{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 75% 40%,rgba(200,169,110,0.07) 0%,transparent 70%);pointer-events:none}
.hero-logo-bg{
  position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  width:760px;opacity:0.16;
  will-change:transform;
  pointer-events:none;
}
.hero-logo-bg img{width:100%;height:auto;display:block}
.hero-content{position:relative;z-index:2}
.vf-corner{position:absolute;width:22px;height:22px;border:1px solid rgba(200,169,110,0.4);z-index:3;pointer-events:none}
.vf-tl{top:32px;left:32px;border-right:none;border-bottom:none}
.vf-tr{top:32px;right:32px;border-left:none;border-bottom:none}
.vf-bl{bottom:32px;left:32px;border-right:none;border-top:none}
.vf-br{bottom:32px;right:32px;border-left:none;border-top:none}
.hero-label{font-size:9px;letter-spacing:0.5em;text-transform:uppercase;color:var(--gold);margin-bottom:32px}
.hero-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(56px,9vw,120px);line-height:0.92;color:var(--white);margin-bottom:40px}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:11px;letter-spacing:0.2em;color:var(--muted);max-width:320px;line-height:1.8;margin-bottom:56px}
.hero-actions{display:flex;gap:24px;align-items:center}
.btn-primary{font-size:9px;letter-spacing:0.35em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:16px 40px;text-decoration:none;transition:opacity 0.3s}
.btn-primary:hover{opacity:0.85}
.btn-ghost{font-size:9px;letter-spacing:0.35em;text-transform:uppercase;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:2px;transition:color 0.3s,border-color 0.3s}
.btn-ghost:hover{color:var(--white);border-color:var(--muted)}

.hero-stats{position:absolute;right:60px;bottom:80px;display:flex;flex-direction:column;gap:32px;text-align:right;z-index:2}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:300;color:var(--gold);line-height:1}
.stat-label{font-size:8px;letter-spacing:0.4em;text-transform:uppercase;color:var(--muted);margin-top:4px}

section{padding:120px 60px}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-size:9px;letter-spacing:0.5em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;display:flex;align-items:center;gap:16px}
.section-label::before{content:'';width:60px;height:1px;background:var(--gold)}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(36px,4vw,58px);color:var(--white);line-height:1.1;margin-bottom:24px}
.section-title em{font-style:italic;color:var(--gold)}

#philosophy{background:var(--dark)}
.philosophy-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:60px}
.philosophy-text p{font-size:13px;line-height:2;color:var(--muted);margin-bottom:20px}
.philosophy-text p strong{color:var(--white);font-weight:300}
.pillars{display:flex;flex-direction:column;gap:1px;background:var(--line)}
.pillar{background:var(--card);padding:32px 36px;position:relative;transition:background 0.3s}
.pillar::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--gold),var(--goldlt));opacity:0;transition:opacity 0.3s}
.pillar:hover::before{opacity:1}
.pillar:hover{background:#1e1e1e}
.pillar-num{font-size:9px;letter-spacing:0.3em;color:var(--gold);margin-bottom:10px;text-transform:uppercase}
.pillar-num small{color:var(--muted);letter-spacing:0.2em;margin-left:6px}
.pillar-title{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.pillar-text{font-size:11px;line-height:1.8;color:var(--muted)}

#founder{background:var(--black)}
.founder-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;margin-top:60px}
.founder-photo-wrap{position:relative;overflow:hidden}
.founder-photo{
  width:100%;aspect-ratio:3/4;object-fit:cover;display:block;
  filter:grayscale(15%);
  opacity:0;
  transition:opacity 1.4s ease,filter 1.2s ease;
}
.founder-photo.loaded{opacity:1;filter:grayscale(0%)}
.founder-photo-border{position:absolute;inset:-12px 12px 12px -12px;border:1px solid var(--line);z-index:-1;pointer-events:none}
.founder-info{padding-top:12px}
.founder-name{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:300;color:var(--white);margin-bottom:4px}
.founder-role{font-size:9px;letter-spacing:0.5em;text-transform:uppercase;color:var(--gold);margin-bottom:40px}
.founder-bio{font-size:13px;line-height:2;color:var(--muted);margin-bottom:20px}
.founder-contact{display:flex;flex-direction:column;gap:12px;margin-top:32px;padding-top:32px;border-top:1px solid var(--line)}
.contact-chip{font-size:10px;letter-spacing:0.15em;color:var(--muted)}
.founder-years{margin-top:48px;padding-top:40px;border-top:1px solid var(--line)}
.years-num{font-family:'Cormorant Garamond',serif;font-size:64px;font-weight:300;color:var(--gold);line-height:1}
.years-label{font-size:9px;letter-spacing:0.4em;text-transform:uppercase;color:var(--muted);margin-top:8px}

#services{background:var(--dark)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:60px}
.service-card{background:var(--card);padding:48px 36px;position:relative;overflow:hidden;transition:background 0.3s}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--gold),var(--goldlt));transform:scaleX(0);transform-origin:left;transition:transform 0.4s}
.service-card:hover::after{transform:scaleX(1)}
.service-card:hover{background:#1e1e1e}
.service-icon{font-size:22px;margin-bottom:24px;opacity:0.5}
.service-name{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:var(--white);margin-bottom:12px}
.service-desc{font-size:11px;line-height:1.9;color:var(--muted);margin-bottom:28px}
.service-price-from{font-size:8px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted)}
.service-price{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:var(--gold)}

#ai{background:var(--black);position:relative;overflow:hidden}
#ai::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(200,169,110,0.04) 0%,transparent 70%)}
.ai-inner{max-width:800px;margin:0 auto;text-align:center}
.ai-inner .section-label{justify-content:center}
.ai-inner .section-label::before{display:none}
.ai-inner .section-title{margin:0 auto 24px}
.ai-desc{font-size:13px;line-height:2;color:var(--muted);margin-bottom:60px}
.ai-features{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);text-align:left}
.ai-feat{background:var(--card);padding:32px 28px}
.ai-feat-title{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.ai-feat-text{font-size:11px;line-height:1.8;color:var(--muted)}

#pricing{background:var(--dark)}
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:60px;overflow-x:auto}
.tab-btn{font-size:9px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);padding:16px 28px;background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.3s;white-space:nowrap;margin-bottom:-1px}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab-btn:hover{color:var(--white)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.pricing-table{width:100%;border-collapse:collapse}
.pricing-table th{font-size:8px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);padding:16px 20px;text-align:left;border-bottom:1px solid var(--line)}
.pricing-table td{padding:20px;border-bottom:1px solid var(--line);font-size:12px;color:var(--muted)}
.pricing-table td:first-child{color:var(--white)}
.pricing-table .price{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:var(--gold)}
.pricing-table tr:last-child td{border-bottom:none}
.pricing-note{font-size:10px;color:var(--muted);margin-top:20px;line-height:1.8}

#memberships{background:var(--black)}
.mem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:60px}
.mem-card{background:var(--card);padding:48px 36px;position:relative}
.mem-card.featured{background:var(--card2)}
.mem-badge{position:absolute;top:24px;right:24px;font-size:7px;letter-spacing:0.3em;text-transform:uppercase;background:var(--gold);color:var(--black);padding:6px 12px}
.mem-name{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:var(--white);margin-bottom:8px}
.mem-price{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:300;color:var(--gold);margin-bottom:4px}
.mem-price-label{font-size:8px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);margin-bottom:40px}
.mem-features{list-style:none;display:flex;flex-direction:column;gap:0;margin-bottom:40px}
.mem-features li{font-size:11px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}
.mem-features li:last-child{border-bottom:none}
.mem-features li span:last-child{color:var(--white)}
.mem-features li span:last-child.gold{color:var(--gold)}
.mem-cta{display:inline-block;font-size:9px;letter-spacing:0.3em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:14px 32px;text-decoration:none;transition:opacity 0.3s}
.mem-cta:hover{opacity:0.85}
.mem-cta-ghost{display:inline-block;font-size:9px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:14px 32px;text-decoration:none;transition:all 0.3s}
.mem-cta-ghost:hover{color:var(--white);border-color:var(--muted)}

#prepaid{background:var(--dark)}
.prepaid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:60px}
.prepaid-card{background:var(--card);padding:44px 36px;position:relative}
.prepaid-card.highlight{background:var(--card2);border-top:2px solid var(--gold)}
.prepaid-label{font-size:8px;letter-spacing:0.45em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.prepaid-name{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:300;color:var(--white);margin-bottom:28px}
.prepaid-price-row{display:flex;align-items:baseline;gap:16px;margin-bottom:6px}
.prepaid-price{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:300;color:var(--gold)}
.prepaid-regular{font-size:11px;color:var(--muted);text-decoration:line-through}
.prepaid-savings{display:inline-block;font-size:8px;letter-spacing:0.25em;text-transform:uppercase;color:#6dbf67;margin-bottom:28px}
.prepaid-includes{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:36px}
.prepaid-includes li{font-size:11px;color:var(--muted);padding-left:16px;position:relative;line-height:1.6}
.prepaid-includes li::before{content:'—';position:absolute;left:0;color:var(--gold);font-size:10px}
.prepaid-validity{font-size:9px;letter-spacing:0.2em;color:var(--muted);padding-top:20px;border-top:1px solid var(--line)}

#why{background:var(--dark)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:60px}
.why-list{display:flex;flex-direction:column;gap:40px}
.why-item{display:flex;gap:32px}
.why-icon{font-size:18px;flex-shrink:0;margin-top:4px;opacity:0.5}
.why-item-title{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--white);margin-bottom:10px}
.why-item-text{font-size:12px;line-height:1.9;color:var(--muted)}
.why-quote{background:var(--card);padding:48px;border-left:3px solid var(--gold)}
.why-quote blockquote{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,2.5vw,28px);font-weight:300;font-style:italic;color:var(--white);line-height:1.6;margin-bottom:32px}
.why-quote cite{font-size:9px;letter-spacing:0.35em;text-transform:uppercase;color:var(--gold)}

#contact{background:var(--black);padding:120px 60px}
.contact-inner{max-width:800px;margin:0 auto;text-align:center}
.contact-inner .section-label{justify-content:center}
.contact-inner .section-label::before{display:none}
.contact-links{display:flex;justify-content:center;gap:60px;margin:60px 0}
.contact-link{text-align:center;text-decoration:none}
.contact-link-label{font-size:8px;letter-spacing:0.4em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.contact-link-value{font-size:12px;letter-spacing:0.1em;color:var(--white);transition:color 0.3s}
.contact-link:hover .contact-link-value{color:var(--gold)}
.contact-cta{margin-top:60px}
.contact-cta a{display:inline-block;font-size:10px;letter-spacing:0.4em;text-transform:uppercase;color:var(--black);background:var(--gold);padding:20px 56px;text-decoration:none;transition:opacity 0.3s}
.contact-cta a:hover{opacity:0.85}

footer{background:var(--black);border-top:1px solid var(--line);padding:40px 60px;display:flex;align-items:center;justify-content:space-between}
.footer-logo-img{width:110px;height:auto;display:block;opacity:0.9}
.footer-copy{font-size:9px;letter-spacing:0.2em;color:var(--muted)}
.footer-links{display:flex;gap:32px}
.footer-links a{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.3s}
.footer-links a:hover{color:var(--gold)}

.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.8s ease,transform 0.8s ease}
.reveal.visible{opacity:1;transform:none}

@media(max-width:900px){
  nav{padding:20px 24px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .lang-toggle{margin:14px 14px 0 0}
  section{padding:80px 24px}
  #hero{padding:0 24px 60px;min-height:100svh}
  .hero-stats{
    position:static;right:auto;bottom:auto;
    flex-direction:row;justify-content:space-between;
    text-align:left;gap:12px;margin-top:44px;width:100%
  }
  .hero-stats>div{flex:1}
  .hero-stats .stat-num{font-size:26px}
  .hero-stats .stat-label{font-size:7px;letter-spacing:0.22em;line-height:1.3}
  .hero-logo-bg{width:420px;right:-10px}
  .vf-corner{display:none}
  .hero-actions{flex-wrap:wrap;row-gap:16px}
  .philosophy-grid,.founder-grid,.why-grid{grid-template-columns:1fr;gap:48px}
  .services-grid,.ai-features,.mem-grid,.prepaid-grid{grid-template-columns:1fr}
  footer{flex-direction:column;gap:20px;text-align:center;padding:32px 24px}
  .contact-links{flex-direction:column;gap:32px}
}

/* ===== CINEMATIC SHUTTER REVEAL =====
   A single frame that "opens" like a camera diaphragm as the visitor
   scrolls — the same optical language as the 35mm rail: this studio
   exposes frames, it doesn't just show pictures. */
.cinema-reveal{position:relative;height:240vh;background:var(--black)}
.cinema-sticky{position:sticky;top:0;height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;background:var(--black)}
.cinema-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  will-change:clip-path,transform;filter:brightness(0.92) saturate(1.05)}
.cinema-vignette{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(ellipse 75% 75% at 50% 50%,transparent 45%,rgba(10,10,10,0.6) 100%)}
.cinema-caption{position:absolute;z-index:3;left:60px;bottom:52px;max-width:520px;
  opacity:0;transform:translateY(16px);transition:opacity 0.8s ease,transform 0.8s ease}
.cinema-caption.visible{opacity:1;transform:translateY(0)}
.cinema-caption .cap-label{font-size:9px;letter-spacing:0.5em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.cinema-caption .cap-title{font-family:'Cormorant Garamond',serif;font-weight:300;font-style:italic;
  font-size:clamp(22px,2.6vw,32px);color:var(--white);line-height:1.35}
@media(max-width:900px){
  .cinema-reveal{height:200vh}
  .cinema-caption{left:24px;right:24px;bottom:36px;max-width:none}
}

/* ===== PARALLAX GALLERY ===== */
.gallery-section{padding:100px 60px 140px;background:var(--dark);overflow:hidden}
.gallery-wrap{max-width:1140px;margin:64px auto 0;position:relative}
.gallery-img{display:block;width:100%;height:auto;will-change:transform;
  filter:grayscale(10%) brightness(0.97);transition:filter 0.5s ease}
.gallery-img:hover{filter:grayscale(0%) brightness(1)}
.gallery-item{position:relative}
.gallery-item .gallery-cap{margin-top:14px;font-size:8px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted)}
.g-1{width:32%}
.g-2{width:64%;margin:-140px auto 0}
.g-3{width:30%;margin:-90px 0 0 auto}
.g-4{width:44%;margin:-160px 0 0 100px}
@media(max-width:900px){
  .gallery-section{padding:80px 24px 100px}
  .gallery-wrap{margin-top:40px}
  .g-1,.g-2,.g-3,.g-4{width:100%;margin:0 0 40px 0}
  .gallery-item:last-child .gallery-cap{margin-bottom:0}
}

