:root{
  --bg:#090909;
  --bg-2:#0f0f0f;
  --bg-3:#141414;
  --text:#f5f1e9;
  --muted:#9a9088;
  --accent:#e9d7b3;
  --accent-h:#f5e8cc;
  --green:#6abf6a;
  --line:rgba(255,255,255,0.07);
  --line-2:rgba(255,255,255,0.11);
  --glass:rgba(14,14,14,0.52);
  --glass-2:rgba(14,14,14,0.72);
  --shadow-xl:0 30px 80px rgba(0,0,0,0.6);
  --shadow-lg:0 16px 48px rgba(0,0,0,0.45);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
  --max:1380px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.5;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;}

/* =========================
   BACKGROUND
========================= */
#background{
  position:fixed;inset:-20vh -20vw;
  display:grid;grid-template-columns:repeat(12,minmax(140px,1fr));
  gap:14px;z-index:0;pointer-events:none;
  transform:translate3d(0,0,0);will-change:transform;opacity:.38;
}
#background img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:18px;
  filter:brightness(.28) saturate(.75) contrast(1.1);
  box-shadow:0 8px 30px rgba(0,0,0,.3);
}
.site-overlay{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(circle at 50% 18%,rgba(0,0,0,.18),rgba(0,0,0,.7) 55%,rgba(0,0,0,.92)),
    linear-gradient(to bottom,rgba(9,9,9,.22),rgba(9,9,9,.62) 30%,rgba(9,9,9,.88));
}
.site-overlay-work{
  background:
    radial-gradient(circle at 72% 32%,rgba(0,0,0,.1),rgba(0,0,0,.6) 45%,rgba(0,0,0,.92)),
    linear-gradient(to bottom,rgba(9,9,9,.22),rgba(9,9,9,.58) 26%,rgba(9,9,9,.92));
}

/* =========================
   HEADER
========================= */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 36px;
  transition:padding .35s ease,background .35s ease,border-color .35s ease;
  background:linear-gradient(to bottom,rgba(9,9,9,.75),rgba(9,9,9,.3));
  backdrop-filter:blur(16px);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  padding:14px 28px;
  background:rgba(9,9,9,.78);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.04em;}
.brand-mark{
  width:11px;height:11px;border-radius:999px;background:var(--accent);
  box-shadow:0 0 0 6px rgba(233,215,179,.07);flex-shrink:0;
}
.brand-text{font-size:.88rem;text-transform:uppercase;letter-spacing:.06em;}
.main-nav{display:flex;align-items:center;gap:20px;}
.main-nav a{
  position:relative;font-size:.86rem;color:rgba(245,241,233,.84);
  transition:color .25s;
}
.main-nav a::after{
  content:"";position:absolute;left:0;bottom:-5px;
  width:0;height:1px;background:var(--accent);transition:width .3s ease;
}
.main-nav a:hover{color:var(--text);}
.main-nav a:hover::after{width:100%;}
.nav-cta{
  font-size:.82rem!important;min-height:36px;padding:0 16px;
  letter-spacing:.02em;
}
.nav-cta::after{display:none!important;}

/* =========================
   NAV TOGGLE
========================= */
.nav-toggle{
  display:none;flex-direction:column;justify-content:center;
  align-items:center;gap:5px;
  width:40px;height:40px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:10px;padding:8px;
  transition:background .2s,border-color .2s;
}
.nav-toggle span{
  display:block;width:17px;height:1.5px;
  background:var(--text);border-radius:2px;
  transition:transform .3s ease,opacity .3s ease;
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-toggle.is-open span:nth-child(2){opacity:0;}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* =========================
   MOBILE NAV
========================= */
.mobile-nav{
  position:fixed;inset:0;z-index:49;
  background:rgba(9,9,9,.97);
  backdrop-filter:blur(24px);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.mobile-nav.is-open{opacity:1;pointer-events:all;}
.mobile-nav-close{
  position:absolute;top:22px;right:22px;
  width:40px;height:40px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--text);font-size:.9rem;display:flex;
  align-items:center;justify-content:center;
}
.mobile-nav-links{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  margin-bottom:40px;
}
.mobile-link{
  font-size:clamp(2rem,6vw,3rem);
  font-family:'Cormorant Garamond',serif;
  font-weight:600;color:rgba(245,241,233,.7);
  transition:color .2s;padding:6px 0;
}
.mobile-link:hover{color:var(--text);}
.mobile-cta{
  font-family:'Inter',sans-serif!important;
  font-size:1rem!important;font-weight:600;
  background:var(--accent);color:#111;
  padding:14px 32px;border-radius:999px;
  margin-top:16px;
}
.mobile-nav-footer{
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.mobile-nav-footer span{font-size:.82rem;color:var(--muted);}

/* =========================
   LIGHTBOX
========================= */
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
  padding:24px;
}
.lightbox.is-open{opacity:1;pointer-events:all;}
.lightbox-inner{
  display:grid;grid-template-columns:1fr 320px;
  max-width:880px;width:100%;
  max-height:calc(100vh - 80px);
  border-radius:28px;overflow:hidden;
  box-shadow:var(--shadow-xl);
}
.lightbox-img-wrap{
  background:#000;overflow:hidden;position:relative;
  min-height:400px;
}
.lightbox-img-wrap img{
  width:100%;height:100%;object-fit:cover;
}
.lightbox-info{
  padding:28px;background:var(--bg-2);
  border-left:1px solid var(--line);
  overflow-y:auto;display:flex;flex-direction:column;gap:0;
}
.lightbox-info h3{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.8rem,2.8vw,2.4rem);
  line-height:.95;margin-bottom:10px;margin-top:8px;
}
.lightbox-info>p{
  color:var(--muted);font-size:.9rem;
  margin-bottom:18px;line-height:1.65;flex:1;
}
.lightbox-meta{
  display:grid;grid-template-columns:1fr 1fr;
  gap:8px;margin-bottom:18px;
}
.lightbox-meta-item{
  padding:11px;border-radius:12px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);
}
.lightbox-meta-item span{
  display:block;font-size:.68rem;text-transform:uppercase;
  letter-spacing:.1em;color:var(--accent);margin-bottom:4px;
}
.lightbox-meta-item strong{font-size:.88rem;}
.lightbox-actions{display:flex;flex-direction:column;gap:10px;}
.lightbox-close{
  position:absolute;top:18px;right:18px;z-index:2;
  width:40px;height:40px;border-radius:999px;
  background:rgba(0,0,0,.65);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);color:var(--text);
  font-size:.85rem;display:flex;align-items:center;justify-content:center;
}
.lightbox-prev,.lightbox-next{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:46px;height:46px;border-radius:999px;
  background:rgba(0,0,0,.65);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);color:var(--text);
  font-size:1.4rem;display:flex;align-items:center;justify-content:center;
  transition:background .2s,border-color .2s;
}
.lightbox-prev{left:18px;}
.lightbox-next{right:18px;}
.lightbox-prev:hover,.lightbox-next:hover{
  background:rgba(0,0,0,.9);border-color:var(--line-2);
}

/* =========================
   LAYOUT
========================= */
main,section,footer{position:relative;z-index:2;}
.content-wrap{width:min(var(--max),calc(100% - 48px));margin:0 auto;}
.glass-soft{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  border:1px solid var(--line);backdrop-filter:blur(14px);
  box-shadow:var(--shadow-lg);
}
.glass-strong{
  background:linear-gradient(180deg,rgba(16,16,16,.82),rgba(16,16,16,.66));
  border:1px solid var(--line-2);backdrop-filter:blur(16px);
  box-shadow:var(--shadow-xl);
}
.eyebrow{
  display:inline-block;font-size:.76rem;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--accent);margin-bottom:14px;font-weight:700;
}
.section-head{
  display:grid;grid-template-columns:1.15fr .85fr;
  gap:30px;align-items:end;margin-bottom:36px;
}
.section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.3rem,4vw,4.2rem);
  line-height:.95;font-weight:700;
}
.section-head p{color:var(--muted);max-width:520px;justify-self:end;}

.section-head-center{
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
  margin-bottom:36px;
}
.section-head-center h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.3rem,4vw,4.2rem);
  line-height:.95;font-weight:700;
  max-width:700px;
}
.section-head-center .eyebrow{margin-bottom:14px;}
.section-head-center p{color:var(--muted);max-width:560px;}

/* =========================
   HERO
========================= */
.hero-shell{
  min-height:100svh;display:flex;
  align-items:center;justify-content:center;
  padding:110px 0 60px;
}
.hero{width:min(1100px,calc(100% - 48px));text-align:center;}
.hero-kicker{margin-bottom:18px;}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.4rem,10vw,8.5rem);
  line-height:.88;letter-spacing:-.02em;
  max-width:1100px;margin:0 auto;
  text-wrap:balance;
  text-shadow:0 12px 40px rgba(0,0,0,.5);
}
.hero-copy{
  max-width:720px;margin:26px auto 0;
  color:rgba(245,241,233,.86);
  font-size:clamp(1rem,1.6vw,1.16rem);
  line-height:1.7;
}
.hero-actions{
  display:flex;justify-content:center;
  gap:13px;margin-top:30px;flex-wrap:wrap;
}
.hero-meta{
  display:flex;justify-content:center;
  flex-wrap:wrap;gap:10px;margin-top:26px;
}
.meta-pill{
  border:1px solid var(--line);
  background:rgba(255,255,255,.025);
  padding:9px 14px;border-radius:999px;
  color:rgba(245,241,233,.82);font-size:.83rem;
  backdrop-filter:blur(10px);
}
.hero-scroll{
  display:flex;flex-direction:column;
  align-items:center;gap:10px;
  margin-top:44px;opacity:.5;
}
.scroll-line{
  width:1px;height:40px;
  background:linear-gradient(to bottom,transparent,var(--accent));
}
.hero-scroll span{
  font-size:.7rem;text-transform:uppercase;
  letter-spacing:.14em;color:var(--accent);
}

/* =========================
   BUTTONS
========================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;min-height:48px;padding:0 22px;
  border-radius:999px;border:1px solid transparent;
  font-weight:600;font-size:.9rem;
  transition:transform .25s ease,background .25s ease,
    border-color .25s ease,color .25s ease,box-shadow .25s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--accent);color:#111;}
.btn-primary:hover{background:var(--accent-h);box-shadow:0 8px 24px rgba(233,215,179,.2);}
.btn-ghost{
  background:rgba(255,255,255,.03);
  border-color:var(--line);color:var(--text);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.06);}
.btn-full{width:100%;}

/* =========================
   WORKS SECTION
========================= */
.works-section{padding:40px 0 20px;}
.filter-bar{
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px;
}
.filter-pill{
  padding:9px 18px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  color:var(--muted);font-size:.82rem;font-weight:500;
  transition:all .2s ease;
}
.filter-pill:hover{color:var(--text);border-color:var(--line-2);}
.filter-pill.active{
  background:var(--accent);border-color:var(--accent);
  color:#111;font-weight:600;
}
.works-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.work-card{
  position:relative;overflow:hidden;
  border-radius:26px;border:1px solid var(--line);
  box-shadow:var(--shadow-lg);background:#111;
  cursor:pointer;aspect-ratio:3/4;
  transition:transform .3s ease,box-shadow .3s ease;
}
.work-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);}
.work-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease,filter .6s ease;
}
.work-card:hover img{transform:scale(1.05);filter:brightness(1.06);}
.work-card-overlay{
  position:absolute;inset:auto 0 0 0;
  padding:22px;
  background:linear-gradient(to top,rgba(0,0,0,.88),rgba(0,0,0,.3) 60%,transparent);
}
.work-card-overlay .eyebrow{margin-bottom:5px;font-size:.7rem;}
.work-card-overlay h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;line-height:.95;margin-bottom:4px;
}
.work-card-overlay p{
  color:rgba(245,241,233,.72);font-size:.83rem;
}
.work-card[data-hidden]{display:none;}

/* =========================
   WORKS CAROUSEL
========================= */
.works-carousel-section{padding:40px 0 20px;}
.works-carousel-outer{position:relative;}
.works-carousel-wrap{overflow:hidden;}
.works-carousel{
  display:flex;gap:24px;
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  will-change:transform;
}
.carousel-card{
  flex:0 0 calc(33.333% - 16px);min-width:0;
  cursor:pointer;border-radius:26px;overflow:hidden;
  background:var(--bg-2);
  border:1px solid var(--line);box-shadow:var(--shadow-lg);
  transition:transform .3s ease,box-shadow .3s ease;
}
.carousel-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);}
.carousel-card-img{
  aspect-ratio:4/5;overflow:hidden;
}
.carousel-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease,filter .4s ease;
}
.carousel-card:hover .carousel-card-img img{transform:scale(1.05);filter:brightness(1.08);}
.carousel-card-body{
  padding:18px 20px 20px;
  border-top:1px solid var(--line);
}
.carousel-card-body .eyebrow{font-size:.72rem;margin-bottom:7px;}
.carousel-card-body h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.45rem;font-weight:600;line-height:1;margin-bottom:5px;
}
.carousel-card-price{font-size:.85rem;color:var(--muted);}
.carousel-nav{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:28px;
}
.carousel-dots{display:flex;gap:8px;}
.carousel-dot{
  width:7px;height:7px;border-radius:50%;padding:0;border:none;
  background:rgba(255,255,255,.18);cursor:pointer;
  transition:background .2s,transform .2s;
}
.carousel-dot.active{background:var(--accent);transform:scale(1.35);}
.carousel-arrows{display:flex;gap:10px;}
.carousel-arrow{
  width:44px;height:44px;
  border:1px solid var(--line-2);background:transparent;
  color:var(--text);font-size:1.1rem;border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s,background .2s;
}
.carousel-arrow:hover{border-color:var(--accent);color:var(--accent);}
.carousel-arrow:disabled{opacity:.25;cursor:default;pointer-events:none;}
.carousel-cta{margin-top:32px;text-align:center;}

/* =========================
   FLASH SECTION
========================= */
.flash-section{padding:80px 0 20px;}
.flash-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.flash-card{
  border-radius:24px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-lg);
  background:var(--bg-2);
  transition:transform .3s ease,box-shadow .3s ease;
}
.flash-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);}
.flash-card-img{
  position:relative;aspect-ratio:1;overflow:hidden;
}
.flash-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .55s ease;
  filter:brightness(.9);
}
.flash-card:hover .flash-card-img img{transform:scale(1.05);}
.flash-badge{
  position:absolute;top:12px;right:12px;
  padding:5px 11px;border-radius:999px;
  font-size:.7rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;
}
.flash-badge.available{
  background:rgba(106,191,106,.12);
  border:1px solid rgba(106,191,106,.25);
  color:var(--green);
}
.flash-badge.taken{
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  color:var(--muted);
  text-decoration:line-through;
}
.flash-card-body{
  padding:16px 18px;
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--line);
}
.flash-card-body h4{font-size:.9rem;margin-bottom:3px;}
.flash-card-body span{font-size:.78rem;color:var(--muted);}
.flash-price{
  font-weight:700;color:var(--accent);font-size:.95rem;
  white-space:nowrap;
}
.flash-footer{
  margin-top:24px;text-align:center;
}
.flash-footer p{
  font-size:.88rem;color:var(--muted);
}
.flash-footer a{color:var(--accent);}
.flash-footer a:hover{text-decoration:underline;}

/* =========================
   SPLIT SECTION (ABOUT)
========================= */
.split-section{
  padding:80px 0 20px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:34px;align-items:center;
}
.split-copy{padding:36px;border-radius:30px;}
.split-copy h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4vw,4.2rem);
  line-height:.95;margin-bottom:18px;
}
.split-copy p{color:var(--muted);margin-bottom:14px;line-height:1.7;}
.studio-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:12px;margin-top:24px;
}
.stat{
  padding:16px;border-radius:18px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);
}
.stat strong{display:block;font-size:1.5rem;margin-bottom:5px;color:var(--text);}
.stat span{font-size:.82rem;color:var(--muted);}
.about-cta{margin-top:24px;display:inline-flex!important;}
.split-visual{min-height:560px;display:flex;align-items:center;justify-content:center;}
.studio-collage{position:relative;width:min(100%,560px);height:560px;}
.studio-card{
  position:absolute;overflow:hidden;
  border-radius:28px;border:1px solid var(--line);
  box-shadow:var(--shadow-xl);
}
.studio-card img{width:100%;height:100%;object-fit:cover;}
.studio-card-large{right:0;top:60px;width:68%;height:74%;}
.studio-card-top{left:0;top:0;width:42%;height:38%;}
.studio-card-bottom{left:8%;bottom:0;width:46%;height:34%;}

/* =========================
   TESTIMONIALS
========================= */
.testimonials-section{padding:80px 0 20px;}
.testimonials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.testimonial-card{
  padding:24px;border-radius:24px;
  border:1px solid var(--line);
  background:linear-gradient(160deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  backdrop-filter:blur(12px);
}
.testimonial-stars{
  color:var(--accent);font-size:.85rem;
  letter-spacing:.1em;margin-bottom:14px;
}
.testimonial-card p{
  color:rgba(245,241,233,.82);font-size:.92rem;
  line-height:1.72;margin-bottom:20px;
  font-style:italic;
}
.testimonial-author{display:flex;align-items:center;gap:11px;}
.testimonial-avatar{
  width:36px;height:36px;border-radius:999px;
  background:rgba(233,215,179,.08);
  border:1px solid rgba(233,215,179,.15);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:var(--accent);
  font-size:.85rem;flex-shrink:0;
}
.testimonial-author strong{display:block;font-size:.88rem;}
.testimonial-author span{font-size:.78rem;color:var(--muted);}

/* =========================
   PROCESS
========================= */
.process-section{padding:80px 0 20px;}
.process-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
.process-card{
  padding:24px;border-radius:24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);
}
.process-no{
  display:inline-flex;width:38px;height:38px;
  border-radius:999px;align-items:center;justify-content:center;
  background:rgba(233,215,179,.07);
  border:1px solid rgba(233,215,179,.14);
  color:var(--accent);font-weight:700;
  font-size:.82rem;margin-bottom:14px;
}
.process-card h3{margin-bottom:10px;font-size:1rem;}
.process-card p{color:var(--muted);font-size:.9rem;line-height:1.65;}

/* =========================
   PRICING
========================= */
.pricing-section{padding:80px 0 20px;}
.pricing-shell{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;
  padding:30px;border-radius:32px;
  border:1px solid var(--line);
  background:linear-gradient(160deg,rgba(255,255,255,.035),rgba(255,255,255,.01));
  backdrop-filter:blur(14px);box-shadow:var(--shadow-xl);
}
.pricing-copy h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3.6rem);
  line-height:.95;margin-bottom:12px;
}
.pricing-copy p{color:var(--muted);margin-bottom:0;line-height:1.65;}
.pricing-cta{margin-top:22px;display:inline-flex!important;}
.pricing-list{display:flex;flex-direction:column;gap:10px;}
.price-row{
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;padding:16px 20px;
  border-radius:16px;border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}
.price-row-info strong{
  display:block;font-size:.9rem;margin-bottom:3px;
  color:var(--text);
}
.price-row-info span{font-size:.78rem;color:var(--muted);}
.price-amount{color:var(--accent);font-weight:700;white-space:nowrap;font-size:.95rem;}
.price-note{
  font-size:.78rem;color:var(--muted);
  text-align:center;padding:10px 0 0;border-top:1px solid var(--line);
}

/* =========================
   AFTERCARE
========================= */
.aftercare-section{padding:80px 0 20px;}
.aftercare-inner{
  display:grid;grid-template-columns:.6fr 1.4fr;
  gap:36px;align-items:center;
  padding:36px;border-radius:32px;
  border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  backdrop-filter:blur(14px);
}
.aftercare-copy h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.5vw,3.2rem);
  line-height:.95;margin-bottom:14px;
}
.aftercare-copy p{color:var(--muted);font-size:.92rem;line-height:1.7;}
.aftercare-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.aftercare-step{
  padding:18px;border-radius:18px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);
}
.aftercare-icon{
  font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);background:rgba(233,215,179,.06);
  border:1px solid rgba(233,215,179,.12);
  border-radius:8px;padding:5px 9px;
  display:inline-block;margin-bottom:11px;font-weight:700;
}
.aftercare-step h4{font-size:.9rem;margin-bottom:7px;}
.aftercare-step p{color:var(--muted);font-size:.84rem;line-height:1.6;}

/* =========================
   FAQ
========================= */
.faq-section{padding:80px 0 20px;}
.faq-list{max-width:860px;margin:0 auto;}
.faq-item{
  border-radius:16px;overflow:hidden;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  margin-bottom:8px;
}
.faq-item.is-open{border-color:var(--line-2);}
.faq-question{
  width:100%;display:flex;justify-content:space-between;
  align-items:center;gap:16px;padding:19px 22px;
  background:none;border:none;color:var(--text);
  font:inherit;font-size:.95rem;font-weight:600;text-align:left;
}
.faq-icon{
  width:26px;height:26px;border-radius:999px;
  border:1px solid var(--line);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s ease,background .3s ease,border-color .3s;
  color:var(--accent);font-size:1.1rem;line-height:1;
}
.faq-icon::after{content:'+';display:block;}
.faq-item.is-open .faq-icon{
  transform:rotate(45deg);
  background:rgba(233,215,179,.07);
  border-color:rgba(233,215,179,.18);
}
.faq-answer{height:0;overflow:hidden;transition:height .35s ease;}
.faq-answer-inner{padding:0 22px 20px;}
.faq-answer p{color:var(--muted);line-height:1.72;font-size:.92rem;}

/* =========================
   MERCH TEASER
========================= */
.merch-teaser{padding:80px 0 20px;}
.merch-teaser-inner{
  display:grid;grid-template-columns:.9fr 1.1fr;
  gap:40px;align-items:center;
}
.merch-teaser-copy h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4vw,4rem);
  line-height:.95;margin-bottom:14px;
}
.merch-teaser-copy p{color:var(--muted);margin-bottom:24px;line-height:1.7;}
.merch-preview-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.merch-preview-card{
  display:block;border-radius:20px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-lg);
  transition:transform .3s ease,box-shadow .3s ease;
}
.merch-preview-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);}
.merch-preview-img{
  aspect-ratio:1;position:relative;display:flex;
  flex-direction:column;align-items:center;justify-content:center;gap:10px;
}
.merch-img-tee{background:linear-gradient(135deg,#1c1c1c,#222,#1a1a1a);}
.merch-img-print{background:linear-gradient(135deg,#161616,#1e1e1e,#181818);}
.merch-img-patch{background:linear-gradient(135deg,#181818,#1d1d1d,#151515);}
.merch-preview-char{
  font-family:'Cormorant Garamond',serif;
  font-size:3.5rem;color:rgba(233,215,179,.18);
  font-weight:700;line-height:1;
}
.merch-preview-label{
  font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--accent);background:rgba(0,0,0,.4);
  padding:5px 10px;border-radius:999px;border:1px solid var(--line);
}
.merch-preview-info{
  padding:13px 15px;display:flex;
  justify-content:space-between;align-items:center;
  background:var(--bg-2);border-top:1px solid var(--line);
}
.merch-preview-info span{font-size:.84rem;color:rgba(245,241,233,.86);}
.merch-preview-info strong{color:var(--accent);font-size:.88rem;}

/* =========================
   CONTACT
========================= */
.contact-section{padding:80px 0 90px;}
.contact-grid{
  display:grid;grid-template-columns:.9fr 1.1fr;
  gap:28px;align-items:start;
}
.contact-copy h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4vw,4rem);
  line-height:.95;margin-bottom:14px;
}
.contact-copy p{color:var(--muted);max-width:520px;line-height:1.7;}
.contact-cards{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:12px;margin-top:24px;
}
.contact-card{
  padding:17px;border-radius:18px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);
  backdrop-filter:blur(10px);transition:border-color .2s;
}
a.contact-card:hover{border-color:var(--line-2);}
.contact-label{
  display:block;font-size:.72rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--accent);margin-bottom:6px;
}
.contact-card strong{font-size:.9rem;}
.social-links{display:flex;flex-direction:column;gap:9px;margin-top:20px;}
.social-link{
  display:flex;align-items:center;gap:9px;
  font-size:.88rem;color:var(--muted);transition:color .2s;
}
.social-link:hover{color:var(--accent);}
.contact-form{padding:26px;border-radius:28px;}
.form-row{margin-bottom:15px;}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.form-row label{
  display:block;font-size:.78rem;color:rgba(245,241,233,.8);
  margin-bottom:7px;text-transform:uppercase;letter-spacing:.08em;
}
input,textarea,select{
  width:100%;border:none;outline:none;
  border-radius:14px;padding:14px 16px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  color:var(--text);font:inherit;font-size:.9rem;
  transition:border-color .2s,background .2s;
}
input:focus,textarea:focus,select:focus{
  border-color:var(--line-2);background:rgba(255,255,255,.06);
}
input::placeholder,textarea::placeholder{color:rgba(245,241,233,.36);}
select{
  cursor:pointer;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%239a9088' stroke-width='1.5' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
}
select option{background:#1a1a1a;color:var(--text);}
.check-label{
  display:flex;align-items:flex-start;gap:9px;
  cursor:pointer;font-size:.82rem;color:var(--muted);
  margin-bottom:16px;line-height:1.5;
}
.check-label input[type="checkbox"]{
  width:16px;height:16px;min-width:16px;border-radius:4px;
  padding:0;margin-top:1px;accent-color:var(--accent);
}
.form-feedback{
  display:none;margin-top:12px;padding:14px;
  border-radius:12px;font-size:.88rem;text-align:center;
}
.form-feedback.success{
  display:block;background:rgba(106,191,106,.08);
  border:1px solid rgba(106,191,106,.2);color:var(--green);
}
.form-feedback.error{
  display:block;background:rgba(220,80,60,.08);
  border:1px solid rgba(220,80,60,.2);color:#e07070;
}

/* =========================
   FOOTER
========================= */
.site-footer{
  position:relative;z-index:2;
  border-top:1px solid var(--line);
  background:rgba(0,0,0,.25);
  backdrop-filter:blur(24px);
}
.footer-inner{
  width:min(var(--max),calc(100% - 48px));
  margin:0 auto;padding:64px 0 40px;
  display:grid;grid-template-columns:1.4fr .55fr .55fr 1.4fr;
  gap:40px;align-items:start;
}
.footer-tagline{
  color:var(--muted);font-size:.88rem;
  line-height:1.65;margin-top:14px;margin-bottom:20px;
}
.footer-socials{display:flex;gap:9px;}
.footer-social-icon{
  width:36px;height:36px;border-radius:999px;
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:color .25s,border-color .25s;
}
.footer-social-icon:hover{
  color:var(--accent);border-color:rgba(233,215,179,.18);
}
.footer-col{display:flex;flex-direction:column;gap:9px;}
.footer-col h4{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;
  color:var(--accent);margin-bottom:5px;
}
.footer-col a{
  font-size:.88rem;color:var(--muted);transition:color .2s;
}
.footer-col a:hover{color:var(--text);}
.footer-newsletter{}
.footer-newsletter h4{
  font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;
  color:var(--accent);margin-bottom:8px;
}
.footer-newsletter p{
  font-size:.86rem;color:var(--muted);margin-bottom:14px;line-height:1.6;
}
.newsletter-form{display:flex;gap:7px;margin-bottom:18px;}
.newsletter-form input{
  flex:1;min-width:0;padding:12px 14px;border-radius:12px;font-size:.85rem;
}
.newsletter-form .btn{
  min-height:42px;padding:0 14px;font-size:.82rem;
  white-space:nowrap;border-radius:12px;
}
.footer-contact-info{display:flex;flex-direction:column;gap:5px;}
.footer-contact-info span{font-size:.8rem;color:var(--muted);}
.footer-bottom{
  width:min(var(--max),calc(100% - 48px));
  margin:0 auto;padding:18px 0;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;
  align-items:center;gap:16px;
}
.footer-bottom span{font-size:.78rem;color:var(--muted);}
.footer-bottom-links{display:flex;gap:18px;}
.footer-bottom-links a{
  font-size:.78rem;color:var(--muted);transition:color .2s;
}
.footer-bottom-links a:hover{color:var(--text);}

/* =========================
   WORK PAGE
========================= */
.work-page{padding-top:108px;}
.work-hero-wrap{
  width:min(var(--max),calc(100% - 48px));
  margin:0 auto;padding:18px 0 30px;
}
.work-hero-top{
  display:flex;align-items:center;
  justify-content:space-between;gap:16px;margin-bottom:20px;
}
.back-link{
  display:inline-flex;align-items:center;
  gap:8px;font-size:.9rem;
  color:rgba(245,241,233,.82);transition:color .2s;
}
.back-link:hover{color:var(--text);}
.work-composition{
  display:grid;grid-template-columns:.86fr 1.14fr;
  gap:26px;align-items:center;min-height:72svh;
}
.work-info-panel{padding:28px;border-radius:30px;}
.work-info-panel h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,6vw,5.8rem);
  line-height:.88;margin-bottom:14px;
}
.work-info-panel>p{
  color:rgba(245,241,233,.84);font-size:1rem;
  margin-bottom:20px;line-height:1.65;
}
.work-meta-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:11px;margin-bottom:18px;
}
.meta-box{
  padding:15px;border-radius:16px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);
}
.meta-box span{
  display:block;font-size:.7rem;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);margin-bottom:7px;
}
.meta-box strong{font-size:.95rem;}
.work-detail-copy{padding:16px 0 6px;}
.work-detail-copy p{color:var(--muted);line-height:1.7;}
.work-cta-row{display:flex;flex-wrap:wrap;gap:11px;margin-top:18px;}
.work-visual-stage{position:relative;min-height:700px;}
.work-main-shot{
  position:absolute;right:0;top:50%;
  transform:translateY(-50%);width:72%;height:78%;
  overflow:hidden;border-radius:34px;
  border:1px solid var(--line);box-shadow:var(--shadow-xl);
}
.work-main-shot img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;
}
.work-main-shot:hover img{transform:scale(1.03);}
.work-float-shot{
  position:absolute;overflow:hidden;
  border-radius:26px;border:1px solid var(--line);
  box-shadow:var(--shadow-xl);
}
.work-float-shot img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;
}
.work-float-shot:hover img{transform:scale(1.05);}
.work-float-top{left:0;top:8%;width:36%;height:32%;z-index:3;}
.work-float-bottom{left:10%;bottom:10%;width:42%;height:28%;z-index:2;}
.work-details-section{padding:40px 0 20px;}
.work-details-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:15px;
}
.detail-card{
  padding:22px;border-radius:22px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);
}
.detail-card h3{margin-bottom:9px;font-size:.95rem;}
.detail-card p{color:var(--muted);font-size:.9rem;line-height:1.65;}
.related-section{padding:40px 0 90px;}
.related-works{
  display:grid;grid-template-columns:repeat(3,1fr);gap:17px;
}
.related-card{
  position:relative;overflow:hidden;border-radius:24px;
  min-height:280px;border:1px solid var(--line);
  box-shadow:var(--shadow-lg);cursor:pointer;
}
.related-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;
}
.related-card:hover img{transform:scale(1.05);}
.related-overlay{
  position:absolute;inset:auto 0 0 0;
  padding:17px;
  background:linear-gradient(to top,rgba(0,0,0,.85),transparent);
}
.related-overlay h4{margin-bottom:3px;font-size:.95rem;}
.related-overlay span{color:rgba(245,241,233,.72);font-size:.86rem;}

/* =========================
   SHOP PAGE
========================= */
.shop-page{padding-top:100px;}
.shop-hero{
  width:min(var(--max),calc(100% - 48px));
  margin:0 auto;padding:40px 0 20px;
}
.shop-hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,6vw,5.5rem);
  line-height:.92;margin-bottom:14px;
}
.shop-hero h1 em{font-style:italic;color:var(--accent);}
.shop-hero p{color:var(--muted);max-width:560px;font-size:1rem;line-height:1.7;}
.shop-main{
  width:min(var(--max),calc(100% - 48px));
  margin:0 auto;padding:20px 0 80px;
}
.shop-filter-bar{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-bottom:30px;
}
.shop-products-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.product-card{
  border-radius:22px;overflow:hidden;
  border:1px solid var(--line);background:var(--bg-2);
  transition:transform .3s ease,box-shadow .3s ease;
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);}
.product-card[data-hidden]{display:none;}
.product-img{
  aspect-ratio:1;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;
}
.product-img-apparel{background:linear-gradient(145deg,#1b1b1b,#222,#191919);}
.product-img-prints{background:linear-gradient(145deg,#171717,#1e1e1e,#161616);}
.product-img-accessories{background:linear-gradient(145deg,#181818,#1c1c1c,#151515);}
.product-img-char{
  font-family:'Cormorant Garamond',serif;
  font-size:3.8rem;color:rgba(233,215,179,.14);
  font-weight:700;line-height:1;
}
.product-badge{
  position:absolute;top:11px;left:11px;
  font-size:.66rem;font-weight:700;letter-spacing:.09em;
  text-transform:uppercase;padding:4px 10px;
  border-radius:999px;
}
.badge-bestseller{
  background:rgba(233,215,179,.12);
  border:1px solid rgba(233,215,179,.22);
  color:var(--accent);
}
.badge-limited{
  background:rgba(180,120,80,.1);
  border:1px solid rgba(180,120,80,.22);
  color:#c8966a;
}
.product-body{
  padding:16px;flex:1;display:flex;flex-direction:column;gap:8px;
}
.product-category{
  font-size:.7rem;text-transform:uppercase;
  letter-spacing:.1em;color:var(--muted);
}
.product-name{font-size:.95rem;font-weight:600;line-height:1.3;}
.product-desc{font-size:.8rem;color:var(--muted);line-height:1.55;flex:1;}
.product-footer{
  display:flex;justify-content:space-between;
  align-items:center;gap:10px;margin-top:4px;
}
.product-price{
  font-size:1.05rem;font-weight:700;color:var(--accent);
}
.product-size-select{
  padding:8px 10px;font-size:.78rem;border-radius:10px;
  width:auto;max-width:90px;
}
.product-add{
  min-height:40px;padding:0 14px;font-size:.8rem;
  border-radius:12px;white-space:nowrap;
  background:var(--accent);color:#111;font-weight:700;
  border:none;transition:transform .2s,background .2s,box-shadow .2s;
}
.product-add:hover{
  background:var(--accent-h);transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(233,215,179,.18);
}
.product-add.added{
  background:rgba(106,191,106,.12);color:var(--green);
  border:1px solid rgba(106,191,106,.2);
}

/* CART SIDEBAR */
.cart-overlay{
  position:fixed;inset:0;z-index:150;
  pointer-events:none;
}
.cart-overlay.is-open{pointer-events:all;}
.cart-backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  opacity:0;transition:opacity .3s ease;
}
.cart-overlay.is-open .cart-backdrop{opacity:1;}
.cart-sidebar{
  position:absolute;top:0;right:0;bottom:0;
  width:min(420px,100vw);
  background:var(--bg-2);border-left:1px solid var(--line);
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .35s ease;
  box-shadow:-20px 0 60px rgba(0,0,0,.4);
}
.cart-overlay.is-open .cart-sidebar{transform:translateX(0);}
.cart-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 24px;border-bottom:1px solid var(--line);
}
.cart-header h3{font-size:1rem;font-weight:700;}
.cart-close{
  width:36px;height:36px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--text);font-size:.85rem;
  display:flex;align-items:center;justify-content:center;
}
.cart-items{flex:1;overflow-y:auto;padding:18px 24px;}
.cart-empty{
  text-align:center;padding:60px 20px;
  color:var(--muted);font-size:.9rem;
}
.cart-item{
  display:flex;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.cart-item-img{
  width:54px;height:54px;border-radius:12px;
  background:linear-gradient(135deg,#1e1e1e,#252525);
  border:1px solid var(--line);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.cart-item-img span{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;color:rgba(233,215,179,.2);font-weight:700;
}
.cart-item-info{flex:1;min-width:0;}
.cart-item-name{font-size:.88rem;font-weight:600;margin-bottom:3px;}
.cart-item-meta{font-size:.76rem;color:var(--muted);}
.cart-item-row{
  display:flex;justify-content:space-between;
  align-items:center;margin-top:8px;
}
.cart-qty{
  display:flex;align-items:center;gap:0;
  border:1px solid var(--line);border-radius:8px;overflow:hidden;
}
.cart-qty button{
  width:28px;height:26px;background:rgba(255,255,255,.03);
  border:none;color:var(--text);font-size:.9rem;
  transition:background .15s;
}
.cart-qty button:hover{background:rgba(255,255,255,.07);}
.cart-qty span{
  font-size:.82rem;font-weight:600;padding:0 10px;
  color:var(--text);border-left:1px solid var(--line);
  border-right:1px solid var(--line);min-width:32px;
  text-align:center;
}
.cart-item-price{font-size:.88rem;font-weight:700;color:var(--accent);}
.cart-remove{
  background:none;border:none;color:var(--muted);
  font-size:.75rem;padding:2px;transition:color .2s;
  display:block;margin-top:5px;text-decoration:underline;
}
.cart-remove:hover{color:#e07070;}
.cart-footer{
  padding:20px 24px;border-top:1px solid var(--line);
}
.cart-subtotal{
  display:flex;justify-content:space-between;
  margin-bottom:14px;font-size:.92rem;
}
.cart-subtotal strong{color:var(--accent);font-size:1rem;}
.cart-shipping-note{
  font-size:.76rem;color:var(--muted);
  margin-bottom:14px;line-height:1.5;
}
.cart-checkout{width:100%;min-height:48px;border-radius:14px;}

/* TOAST */
.toast{
  position:fixed;bottom:28px;left:50%;
  transform:translateX(-50%) translateY(80px);
  z-index:300;background:var(--bg-3);
  border:1px solid var(--line-2);
  padding:13px 22px;border-radius:14px;
  font-size:.88rem;color:var(--text);
  box-shadow:var(--shadow-xl);
  transition:transform .35s ease,opacity .35s ease;
  opacity:0;pointer-events:none;white-space:nowrap;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;}

/* CART ICON IN NAV */
.cart-nav-btn{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:10px;
  color:var(--text);transition:border-color .2s,background .2s;
}
.cart-nav-btn:hover{border-color:var(--line-2);background:rgba(255,255,255,.06);}
.cart-nav-btn svg{display:block;}
.cart-count{
  position:absolute;top:-5px;right:-5px;
  width:17px;height:17px;border-radius:999px;
  background:var(--accent);color:#111;
  font-size:.65rem;font-weight:700;
  display:none;align-items:center;justify-content:center;
}
.cart-count.visible{display:flex;}

/* =========================
   SHOP INFO BANNER
========================= */
.shop-info-banner{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:14px;margin-top:48px;
  padding:24px;border-radius:24px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}
.shop-info-item strong{
  display:block;font-size:.88rem;margin-bottom:4px;
}
.shop-info-item span{font-size:.78rem;color:var(--muted);}
.shop-info-item a{color:var(--accent);}
.shop-info-item a:hover{text-decoration:underline;}
@media (max-width:860px){
  .shop-info-banner{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .shop-info-banner{grid-template-columns:1fr;}
}

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

/* =========================
   RESPONSIVE — 1180px
========================= */
@media (max-width:1180px){
  #background{grid-template-columns:repeat(10,minmax(120px,1fr));}
  .featured-works,.split-section,.pricing-shell,.contact-grid,
  .work-composition,.section-head,.testimonials-grid{grid-template-columns:1fr;}
  .section-head p{justify-self:start;}
  .split-visual{min-height:480px;}
  .process-grid,.work-details-grid{grid-template-columns:repeat(2,1fr);}
  .related-works{grid-template-columns:repeat(2,1fr);}
  .work-visual-stage{min-height:620px;}
  .works-grid{grid-template-columns:repeat(2,1fr);}
  .flash-grid{grid-template-columns:repeat(2,1fr);}
  .merch-teaser-inner{grid-template-columns:1fr;}
  .aftercare-inner{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr 1fr 1fr 1fr;}
  .shop-products-grid{grid-template-columns:repeat(3,1fr);}
  .lightbox-inner{grid-template-columns:1fr;}
  .lightbox-info{border-left:none;border-top:1px solid var(--line);}
  .lightbox-img-wrap{min-height:340px;}
}

/* =========================
   RESPONSIVE — 860px
========================= */
@media (max-width:860px){
  .site-header{padding:15px 18px;}
  .main-nav{display:none;}
  .nav-toggle{display:flex;}
  #background{
    grid-template-columns:repeat(6,minmax(100px,1fr));
    gap:10px;opacity:.28;
  }
  .hero-shell{padding:120px 0 30px;}
  .content-wrap{width:min(var(--max),calc(100% - 24px));}
  .studio-collage{height:420px;}
  .studio-stats,.contact-cards,.form-row.two{grid-template-columns:1fr;}
  .process-grid,.work-details-grid,.related-works{grid-template-columns:1fr;}
  .work-page{padding-top:86px;}
  .work-hero-top{flex-direction:column;align-items:flex-start;}
  .work-visual-stage{
    min-height:auto;display:grid;gap:14px;
  }
  .work-main-shot,.work-float-shot{
    position:relative;inset:auto;width:100%;
    height:auto;transform:none;
  }
  .work-main-shot{aspect-ratio:4/5;}
  .work-float-top,.work-float-bottom{aspect-ratio:16/10;}
  .work-meta-grid{grid-template-columns:1fr;}
  .testimonials-grid{grid-template-columns:1fr;}
  .flash-grid{grid-template-columns:1fr;}
  .works-grid{grid-template-columns:1fr;}
  .aftercare-grid{grid-template-columns:1fr;}
  .carousel-card{flex:0 0 calc(50% - 12px);}
  .footer-inner{
    grid-template-columns:1fr 1fr;
    gap:28px;padding:40px 0 28px;
  }
  .footer-brand{grid-column:1/-1;}
  .footer-newsletter{grid-column:1/-1;}
  .shop-products-grid{grid-template-columns:repeat(2,1fr);}
  .lightbox{padding:0;}
  .lightbox-inner{border-radius:0;max-height:100vh;}
}

/* =========================
   RESPONSIVE — 560px
========================= */
@media (max-width:560px){
  .hero-title{font-size:clamp(2.8rem,14vw,4.6rem);}
  .hero-copy{margin-top:18px;font-size:.95rem;}
  .hero-actions{margin-top:22px;}
  .split-copy,.pricing-shell,.contact-form,.work-info-panel{padding:18px;}
  .aftercare-inner{padding:20px;}
  .merch-preview-grid{grid-template-columns:1fr 1fr;}
  .pricing-shell{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center;}
  .shop-products-grid{grid-template-columns:1fr 1fr;}
  .flash-grid{grid-template-columns:1fr;}
  .works-grid{grid-template-columns:1fr;}
  .carousel-card{flex:0 0 100%;}
  .work-info-panel h1{font-size:clamp(2.4rem,12vw,4rem);}
  .faq-list{max-width:100%;}
  .lightbox-inner{grid-template-columns:1fr;max-height:100vh;}
  .lightbox-info{padding:20px;}
  .cart-sidebar{width:100vw;}
}
