/* ============ September Studio — Quiet Luxury theme ============ */
:root{
  --bg:#ece7df; --bg2:#e4ded3; --paper:#f4f0e9;
  --ink:#26231f; --charcoal:#1d1c19; --muted:#8c8579; --line:#d2c9bb; --white:#fff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Be Vietnam Pro',sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:500;line-height:1.12}
.it{font-family:'Playfair Display',serif;font-style:italic}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 34px}
.label{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--muted);font-weight:400}
.pill{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:9px;background:var(--charcoal);color:#f3efe8;padding:13px 26px;border-radius:40px;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;transition:.35s;cursor:pointer;border:1px solid var(--charcoal)}
.pill::before{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-20deg);transition:.6s;pointer-events:none}
.pill:hover::before{left:160%}
.pill:hover{background:transparent;color:var(--ink)}
.pill.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.pill.ghost:hover{background:var(--charcoal);color:#f3efe8}
.pill.light{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.5);color:#fff;backdrop-filter:blur(4px)}
.pill.light:hover{background:#fff;color:var(--ink)}
.arr{transition:.35s}.pill:hover .arr{transform:translateX(4px)}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:50;padding:24px 0;transition:.4s}
header.scrolled,header.solid{background:rgba(236,231,223,.96);backdrop-filter:blur(10px);padding:14px 0;box-shadow:0 1px 0 var(--line)}
.nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
.nav .side{display:flex;gap:26px}.nav .side.r{justify-content:flex-end}
.nav .side a{position:relative;font-size:12px;letter-spacing:1.3px;text-transform:uppercase;color:rgba(255,255,255,.92);transition:.3s;white-space:nowrap}
header.scrolled .nav .side a,header.solid .nav .side a{color:var(--ink)}
.nav .side a::after{content:"";position:absolute;left:0;bottom:-5px;height:1px;width:0;background:currentColor;transition:.35s}
.nav .side a:hover::after{width:100%}
.brand{text-align:center;font-family:'Playfair Display',serif;font-style:italic;font-size:28px;color:#fff;transition:.4s}
header.scrolled .brand,header.solid .brand{color:var(--ink)}
.brand small{display:block;font-family:'Be Vietnam Pro';font-style:normal;font-size:8px;letter-spacing:5px;font-weight:300;margin-top:-2px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;justify-self:end}
.burger span{width:26px;height:1.5px;background:#fff}
header.scrolled .burger span,header.solid .burger span{background:var(--ink)}

/* Hero */
.hero{padding:120px 0 30px}
.hero-frame{position:relative;height:84vh;min-height:560px;border-radius:26px;overflow:hidden;background:#1b1410}
.hero-frame .bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;animation:kb 20s ease-in-out infinite alternate}
@keyframes kb{0%{transform:scale(1)}100%{transform:scale(1.1)}}
.hero-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,12,.30) 0%,rgba(20,16,12,0) 30%,rgba(20,16,12,.55) 100%)}
.hero-top{position:absolute;top:32px;left:34px;right:34px;z-index:2;display:flex;justify-content:space-between;color:#fff}
.hero-top .label{color:rgba(255,255,255,.85)}
.hero-cap{position:absolute;left:34px;bottom:38px;right:34px;z-index:2;color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.hero-cap h1{font-size:clamp(34px,5vw,64px);font-weight:400;max-width:760px}
.hero-cap h1 .it{color:#f0e4d6}
.hero-cap p{max-width:330px;font-size:14.5px;color:rgba(255,255,255,.88)}
.hero-cap .pill{margin-top:16px}

/* page hero (sub pages) */
.pagehero{padding:160px 0 70px;text-align:center;background:var(--paper)}
.pagehero .label{display:block;margin-bottom:16px}
.pagehero h1{font-size:clamp(34px,5vw,60px);font-weight:400}
.pagehero p{color:var(--muted);max-width:600px;margin:16px auto 0}

.pad{padding:100px 0}
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:50px;flex-wrap:wrap}
.head-row h2{font-size:clamp(28px,4vw,50px);font-weight:400;max-width:680px}
.head-row .label{margin-bottom:14px;display:block}

/* story */
.story{background:var(--paper)}
.story-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.story-img{border-radius:20px;overflow:hidden;height:560px}
.story-img img{width:100%;height:100%;object-fit:cover;transition:1s}
.story-img:hover img{transform:scale(1.05)}
.story-txt .label{display:block;margin-bottom:18px}
.story-txt .lead{font-family:'Playfair Display',serif;font-size:clamp(23px,2.7vw,32px);line-height:1.35;margin-bottom:24px}
.story-txt p{color:#6d6459;font-size:15.5px;margin-bottom:16px;line-height:1.85}
.story-txt .accent{font-family:'Playfair Display',serif;font-style:italic;font-size:20px;color:var(--ink);line-height:1.55;margin:22px 0;padding-left:20px;border-left:2px solid var(--line)}
.story-txt .sign{font-family:'Playfair Display',serif;font-style:italic;font-size:20px;margin-top:22px;display:block}
.story-txt .sign small{display:block;font-family:'Be Vietnam Pro';font-style:normal;font-size:12px;letter-spacing:1px;color:var(--muted);margin-top:6px}

/* prose (article) */
.prose{max-width:820px;margin:0 auto}
.prose p{color:#5f564c;font-size:16px;line-height:1.9;margin-bottom:20px}
.prose h2{font-size:30px;margin:38px 0 16px}
.prose h3{font-size:23px;margin:28px 0 12px}
.prose ul{margin:0 0 20px 22px}.prose li{margin-bottom:8px;color:#5f564c}

/* masonry */
.masonry{columns:3;column-gap:16px}
.masonry a{display:block;margin-bottom:16px;border-radius:16px;overflow:hidden;position:relative;break-inside:avoid}
.masonry img{width:100%;transition:.8s}
.masonry a:hover img{transform:scale(1.06)}
.masonry .cap{position:absolute;inset:0;display:flex;align-items:flex-end;padding:18px;background:linear-gradient(transparent 55%,rgba(20,16,12,.65));opacity:0;transition:.4s}
.masonry a:hover .cap{opacity:1}
.masonry .cap span{color:#fff;font-family:'Playfair Display',serif;font-style:italic;font-size:18px}

/* services */
.services{background:var(--bg2)}
.svc-grid{display:grid;grid-template-columns:1fr .85fr;gap:60px;align-items:center}
.svc-list .row{display:grid;grid-template-columns:46px 1fr;gap:18px;padding:24px 0;border-top:1px solid var(--line);transition:.35s}
.svc-list .row:last-child{border-bottom:1px solid var(--line)}
.svc-list .row:hover{padding-left:10px}
.svc-list .no{font-family:'Playfair Display',serif;font-size:18px;color:var(--muted)}
.svc-list h3{font-size:25px;font-weight:500;margin-bottom:6px}
.svc-list p{font-size:14.5px;color:#6d6459;max-width:430px}
.svc-photo{height:560px;border-radius:300px 300px 18px 18px;overflow:hidden}
.svc-photo img{width:100%;height:100%;object-fit:cover;transition:1s}
.svc-photo:hover img{transform:scale(1.05)}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:40px 32px;transition:.4s}
.plan:hover{transform:translateY(-8px);box-shadow:0 30px 60px -38px rgba(60,45,30,.5)}
.plan.feat{background:var(--charcoal);color:#efe9df;border-color:var(--charcoal)}
.plan .label{margin-bottom:18px;display:block}.plan.feat .label{color:#b9ad9c}
.plan .price{font-family:'Playfair Display',serif;font-size:46px;font-weight:500;line-height:1}
.plan .price small{font-family:'Be Vietnam Pro';font-size:14px;color:var(--muted)}
.plan.feat .price small{color:#b9ad9c}
.plan ul{list-style:none;margin:26px 0}
.plan li{padding:9px 0;font-size:14px;border-top:1px solid var(--line);opacity:.92}
.plan.feat li{border-color:rgba(255,255,255,.14)}
.plan .pill{width:100%;justify-content:center;margin-top:8px}

/* price cards gallery */
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.price-cards a{display:block;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:0 18px 40px -30px rgba(60,45,30,.5);transition:.4s;background:var(--paper)}
.price-cards a:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(60,45,30,.55)}
.price-cards img{width:100%;display:block}
@media(max-width:960px){.price-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.price-cards{grid-template-columns:1fr}}

/* blog grid */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post{cursor:pointer}
.post .ph{border-radius:16px;overflow:hidden;height:240px;margin-bottom:16px;background:var(--bg2)}
.post .ph img{width:100%;height:100%;object-fit:cover;transition:.8s}
.post:hover .ph img{transform:scale(1.06)}
.post .meta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.post h3{font-size:21px;font-weight:500;line-height:1.3}
.post:hover h3{text-decoration:underline;text-underline-offset:4px}

/* testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.tcard img{width:100%;height:210px;object-fit:cover}
.tcard .body{padding:24px}
.tcard p{font-family:'Playfair Display',serif;font-style:italic;font-size:17px;line-height:1.55;color:#5f564c}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.info-row{padding:18px 0;border-top:1px solid var(--line)}
.info-row .k{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.info-row .v{font-size:16px}
.form{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form input,.form select,.form textarea{padding:14px 16px;border:1px solid var(--line);background:var(--white);color:var(--ink);font-family:inherit;font-size:14px;border-radius:10px;width:100%}
.form .full{grid-column:span 2}
.form .pill{grid-column:span 2;justify-self:start;border:none}

/* CTA band */
.cta{color:#fff;text-align:center;padding:110px 0}
.cta .label{color:rgba(255,255,255,.8);display:block;margin-bottom:16px}
.cta h2{font-size:clamp(30px,4vw,52px);font-weight:400;margin-bottom:14px}
.cta p{opacity:.9;margin-bottom:30px}

/* footer */
footer{background:var(--charcoal);color:rgba(243,239,232,.72);padding:74px 0 30px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:46px;margin-bottom:50px}
.foot-top .it{color:#fff;font-size:28px;display:block;margin-bottom:14px}
footer h4{color:#fff;font-size:13px;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px;font-family:'Be Vietnam Pro';font-weight:400}
footer p,footer a{font-size:14px;color:rgba(243,239,232,.68);display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;text-align:center;font-size:12px;color:rgba(243,239,232,.45)}

/* reveal */
.rv{opacity:0;transform:translateY(30px);transition:.9s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}

/* hero staggered entrance */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.hero-frame .hero-top,.hero-frame .hero-cap h1,.hero-frame .hero-cap>div{opacity:0}
.hero-frame.in .hero-top{animation:fadeUp .9s ease .35s forwards}
.hero-frame.in .hero-cap h1{animation:fadeUp 1s cubic-bezier(.2,.7,.2,1) .55s forwards}
.hero-frame.in .hero-cap>div{animation:fadeUp 1s cubic-bezier(.2,.7,.2,1) .8s forwards}

/* staggered children inside grids */
.masonry a,.svc-list .row,.price-grid .plan,.blog-grid .post,.testi-grid .tcard{opacity:0;transform:translateY(30px);transition:.85s cubic-bezier(.2,.7,.2,1)}
.masonry.in a,.svc-list.in .row,.price-grid.in .plan,.blog-grid.in .post,.testi-grid.in .tcard{opacity:1;transform:none}
.masonry.in a:nth-child(2){transition-delay:.07s}.masonry.in a:nth-child(3){transition-delay:.14s}
.masonry.in a:nth-child(4){transition-delay:.21s}.masonry.in a:nth-child(5){transition-delay:.28s}
.masonry.in a:nth-child(6){transition-delay:.35s}.masonry.in a:nth-child(7){transition-delay:.42s}
.masonry.in a:nth-child(8){transition-delay:.49s}.masonry.in a:nth-child(9){transition-delay:.56s}
.svc-list.in .row:nth-child(2){transition-delay:.1s}.svc-list.in .row:nth-child(3){transition-delay:.2s}
.svc-list.in .row:nth-child(4){transition-delay:.3s}.svc-list.in .row:nth-child(5){transition-delay:.4s}
.price-grid.in .plan:nth-child(2),.blog-grid.in .post:nth-child(2),.testi-grid.in .tcard:nth-child(2){transition-delay:.13s}
.price-grid.in .plan:nth-child(3),.blog-grid.in .post:nth-child(3),.testi-grid.in .tcard:nth-child(3){transition-delay:.26s}

/* heading wipe-in */
.head-row.rv h2,.story-txt.rv .lead{clip-path:inset(0 0 100% 0);transition:clip-path 1s cubic-bezier(.2,.7,.2,1) .1s}
.head-row.rv.in h2,.story-txt.rv.in .lead{clip-path:inset(0 0 0 0)}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;clip-path:none!important}}

@media(max-width:960px){
  .nav .side{display:none}.burger{display:flex}
  .nav{grid-template-columns:1fr auto}.brand{text-align:left}
  .story-grid,.svc-grid,.contact-grid{grid-template-columns:1fr;gap:34px}
  .story-img,.svc-photo{height:420px}
  .masonry{columns:2}.price-grid,.blog-grid,.testi-grid{grid-template-columns:1fr}
}
@media(max-width:560px){
  .masonry{columns:1}.form{grid-template-columns:1fr}.form .full,.form .pill{grid-column:span 1}
  .foot-top{grid-template-columns:1fr;gap:28px}.hero-cap{flex-direction:column;align-items:flex-start}
}
