/* ===== Atelier Studio — landing styles (marsala palette, ported from handoff) ===== */
:root{
  --bg:#F7F4EF; --bg2:#F1EBE4; --panel:#E9E1D8;
  --ink:#3A332E; --inkSoft:#6A625A; --mute:#9A8E80;
  --accent:#6E1F2B; --accentSoft:#B07F87;
  --line:rgba(58,51,46,.14); --dark:#2A2421; --onDark:#F7F4EF;
  --ts:1.16;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Helvetica Neue', Helvetica, Arial, sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-weight:400; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block; max-width:100%;}
a{color:inherit;}
::selection{background:rgba(110,31,43,.12);}

@keyframes asMarquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@keyframes asLine{0%{transform:scaleX(0);}100%{transform:scaleX(1);}}
@keyframes asFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(7px);}}

/* GSAP drives reveals; this is the no-JS / reduced-motion fallback (never hide content). */
.reveal{opacity:1; transform:none;}
.js .reveal{opacity:0; transform:translateY(26px);}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1!important; transform:none!important;}
  html{scroll-behavior:auto;}
}

.eyebrow{display:flex; align-items:center; gap:12px; font-size:10.5px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--mute);}
.eyebrow .tick{width:26px; height:1px; background:var(--accent); display:inline-block;}
.section{padding:clamp(80px,12vh,140px) clamp(24px,5vw,80px);}

/* ===== Preloader ===== */
#preloader{position:fixed; inset:0; z-index:200; background:var(--bg);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:22px;
  transition:opacity .7s ease, visibility .7s ease;}
#preloader.hidden{opacity:0; visibility:hidden;}
#preloader .pl-logo{font-family:var(--serif); font-weight:500; font-size:13px; letter-spacing:.42em;
  text-transform:uppercase; color:var(--ink);}
#preloader .pl-rule{width:120px; height:1px; background:var(--line); overflow:hidden;}
#preloader .pl-rule i{display:block; width:100%; height:100%; background:var(--accent);
  transform-origin:left; animation:asLine 1s ease forwards;}

/* ===== Nav ===== */
nav.site{position:fixed; top:0; left:0; right:0; z-index:90; display:flex; align-items:center;
  justify-content:space-between; padding:22px clamp(20px,5vw,64px);
  background:transparent; border-bottom:1px solid transparent;
  transition:background .4s ease, border-color .4s ease, backdrop-filter .4s ease;}
nav.site.scrolled{background:rgba(247,244,239,.82); backdrop-filter:blur(10px); border-bottom-color:var(--line);}
.brand{flex-shrink:0; font-family:var(--serif); font-size:15px; font-weight:500; letter-spacing:.34em;
  text-transform:uppercase; color:var(--ink); text-decoration:none;}
.nav-links{display:flex; gap:clamp(14px,1.9vw,34px); list-style:none; margin:0; padding:0;}
.nav-links a{font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--inkSoft);
  text-decoration:none; white-space:nowrap; transition:color .25s;}
.nav-links a:hover{color:var(--accent);}
.nav-right{display:flex; align-items:center; gap:18px; flex-shrink:0;}
.lang{display:flex; align-items:center; gap:6px; font-size:10.5px; letter-spacing:.12em;}
.lang a{text-decoration:none; padding:2px; color:var(--mute); transition:color .25s;}
.lang a.active{color:var(--ink);}
.lang .sep{color:var(--line);}
.cta-pill{display:inline-flex; align-items:center; gap:9px; padding:11px 22px; border:1px solid var(--accent);
  border-radius:100px; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent);
  text-decoration:none; transition:background .3s, color .3s;}
.cta-pill:hover{background:var(--accent); color:var(--bg);}
.burger{display:none; flex-direction:column; justify-content:center; gap:5px; width:30px; height:30px;
  background:none; border:none; cursor:pointer; padding:0;}
.burger span{display:block; width:24px; height:1.5px; background:var(--ink);}

/* mobile menu overlay */
#menu{position:fixed; inset:0; z-index:100; background:var(--bg); display:flex; flex-direction:column;
  justify-content:center; padding:0 clamp(24px,8vw,80px); gap:6px; opacity:0; visibility:hidden;
  transition:opacity .45s ease, visibility .45s ease;}
#menu.open{opacity:1; visibility:visible;}
#menu a{font-family:var(--serif); font-weight:300; font-size:clamp(34px,8vw,56px); color:var(--ink);
  text-decoration:none; line-height:1.5; transition:color .25s;}
#menu a:hover{color:var(--accent);}
#menu .close{position:absolute; top:24px; right:clamp(20px,5vw,64px); width:36px; height:36px;
  background:none; border:none; cursor:pointer; font-family:var(--serif); font-size:34px; line-height:1; color:var(--ink);}

/* ===== Hero ===== */
.hero{position:relative; min-height:100vh; display:grid; grid-template-columns:1.05fr .95fr; align-items:stretch;}
.hero-text{display:flex; flex-direction:column; justify-content:center;
  padding:clamp(96px,12vh,150px) clamp(24px,5vw,80px) 60px;}
.hero-text .eyebrow{margin-bottom:34px;}
.hero h1{font-family:var(--serif); font-weight:300; font-size:clamp(56px,7.4vw,118px); line-height:.92;
  letter-spacing:-.01em; margin:0 0 28px;}
.hero h1 em{font-style:italic; color:var(--accent);}
.hero .sub{font-family:var(--serif); font-style:italic; font-size:clamp(19px,2vw,25px); color:var(--inkSoft);
  margin:0 0 26px; max-width:26ch;}
.hero .desc{font-size:calc(13.5px*var(--ts)); line-height:1.95; color:var(--inkSoft); max-width:42ch; margin:0 0 40px;}
.hero-ctas{display:flex; align-items:center; gap:26px; flex-wrap:wrap;}
.btn-solid{display:inline-flex; align-items:center; gap:12px; padding:16px 30px; background:var(--accent);
  color:var(--onDark); border-radius:100px; font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  text-decoration:none; transition:transform .3s, background .3s;}
.btn-solid:hover{background:var(--ink); transform:translateY(-1px);}
.link-underline{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink);
  text-decoration:none; border-bottom:1px solid var(--line); padding-bottom:3px; transition:border-color .3s;}
.link-underline:hover{border-color:var(--accent);}
.hero-media{position:relative; overflow:hidden; min-height:60vh; background:var(--bg2);}
.hero-media img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:50% 30%;}
.hero-media .vcap{position:absolute; left:0; bottom:0; padding:22px 26px; writing-mode:vertical-rl;
  transform:rotate(180deg); font-size:10px; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(255,255,255,.85); mix-blend-mode:difference;}
.scrollcue{position:absolute; left:clamp(24px,5vw,80px); bottom:30px; display:flex; align-items:center; gap:10px;
  font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--mute);
  animation:asFloat 2.6s ease-in-out infinite; z-index:5;}
.scrollcue span{width:1px; height:30px; background:var(--line);}

/* ===== Marquee ===== */
.marquee{border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:26px 0;
  overflow:hidden; white-space:nowrap;}
.marquee .track{display:inline-flex; gap:56px; animation:asMarquee 26s linear infinite; will-change:transform;}
.marquee .item{font-family:var(--serif); font-style:italic; font-size:clamp(26px,3vw,46px); color:var(--ink);
  display:inline-flex; align-items:center; gap:56px;}
.marquee .item .star{font-style:normal; color:var(--accent); font-size:.4em;}

/* ===== About ===== */
.about{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(36px,6vw,90px); align-items:center;}
.about-img{position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--bg2);}
.about-img img{width:100%; height:100%; object-fit:cover; object-position:50% 25%;}
.about .eyebrow{color:var(--accent); margin-bottom:26px;}
.about h2{font-family:var(--serif); font-weight:300; font-size:clamp(34px,4.4vw,62px); line-height:1.08; margin:0 0 30px;}
.about h2 em{font-style:italic; color:var(--accent); display:block;}
.about p{font-size:calc(14px*var(--ts)); line-height:2; color:var(--inkSoft); max-width:50ch; margin:0 0 22px;}
.about p.last{margin-bottom:40px;}
.stats{display:flex; gap:clamp(30px,5vw,64px); flex-wrap:wrap; padding-top:30px; border-top:1px solid var(--line);}
.stats .num{font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(30px,3.4vw,44px); color:var(--accent); line-height:1;}
.stats .lab{font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); margin-top:10px;}

/* ===== Services (accent) ===== */
.services{background:var(--accent); color:var(--onDark); position:relative;}
.services .head{display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:20px; margin-bottom:64px;}
.services .eyebrow{color:rgba(247,244,239,.72); margin-bottom:22px;}
.services .eyebrow .tick{background:rgba(247,244,239,.72);}
.services h2{font-family:var(--serif); font-weight:300; font-size:clamp(34px,4.6vw,64px); line-height:1.05; margin:0; max-width:16ch;}
.services .intro{font-size:calc(13.5px*var(--ts)); line-height:1.9; color:rgba(255,255,255,.6); max-width:40ch; margin:0;}
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.16);}
.svc{background:var(--accent); padding:40px 34px 46px; transition:background .35s ease;}
.svc:hover{background:rgba(0,0,0,.14);}
.svc .n{font-family:var(--serif); font-style:italic; font-size:26px; color:rgba(255,255,255,.32); display:block; margin-bottom:18px;}
.svc h3{font-family:var(--serif); font-weight:500; font-size:25px; letter-spacing:.02em; margin:0 0 14px;}
.svc p{font-size:calc(12.5px*var(--ts)); line-height:1.85; color:rgba(255,255,255,.6); margin:0;}

/* ===== Process ===== */
.process .head{text-align:center; max-width:60ch; margin:0 auto 70px;}
.process .eyebrow{display:inline-flex; color:var(--accent); margin-bottom:22px;}
.process h2{font-family:var(--serif); font-weight:300; font-size:clamp(32px,4.4vw,58px); line-height:1.08; margin:0 0 18px;}
.process .intro{font-size:calc(13.5px*var(--ts)); line-height:1.9; color:var(--inkSoft); margin:0;}
.proc-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,40px);}
.proc{border-top:1px solid var(--ink); padding-top:24px;}
.proc .top{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:26px;}
.proc .n{font-family:var(--serif); font-style:italic; font-size:40px; color:var(--accent); line-height:1;}
.proc .icon{font-size:14px; color:var(--mute);}
.proc h3{font-size:12px; letter-spacing:.16em; text-transform:uppercase; margin:0 0 12px;}
.proc p{font-size:calc(12.5px*var(--ts)); line-height:1.85; color:var(--inkSoft); margin:0;}

/* ===== Portfolio ===== */
.portfolio{padding:clamp(40px,6vh,80px) clamp(24px,5vw,80px) clamp(80px,12vh,140px);}
.portfolio .head{display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:20px; margin-bottom:50px;}
.portfolio .eyebrow{color:var(--accent); margin-bottom:22px;}
.portfolio h2{font-family:var(--serif); font-weight:300; font-size:clamp(34px,4.6vw,64px); line-height:1.05; margin:0;}
.grid{display:grid; grid-template-columns:repeat(12,1fr); grid-auto-flow:dense;
  grid-auto-rows:clamp(150px,18vw,220px); gap:clamp(10px,1.4vw,18px);}
.tile{grid-column:span 4; position:relative; overflow:hidden; background:var(--bg2);
  text-decoration:none; display:block; cursor:pointer;}
.tile.span2{grid-row:span 2;}
.tile.span1{grid-row:span 1;}
.tile img{width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.2,.7,.2,1);}
.tile:hover img{transform:scale(1.05);}
.tile .cat{position:absolute; left:14px; bottom:12px; font-size:9.5px; letter-spacing:.2em;
  text-transform:uppercase; color:#fff; mix-blend-mode:difference; opacity:.9; z-index:2;}
.tile .play{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2;
  pointer-events:none;}
.tile .play i{width:54px; height:54px; border-radius:50%; background:rgba(0,0,0,.34);
  backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.5); transition:background .3s, transform .3s;}
.tile .play i::after{content:''; margin-left:3px; border-style:solid; border-width:8px 0 8px 13px;
  border-color:transparent transparent transparent #fff;}
.tile:hover .play i{background:var(--accent); transform:scale(1.08);}

/* ===== Testimonials ===== */
.testi{background:var(--bg2);}
.testi .eyebrow{color:var(--accent); margin-bottom:50px;}
.testi-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,44px); margin-bottom:70px;}
.tcard{background:var(--bg); padding:38px 34px; border:1px solid var(--line);}
.tcard .q{font-family:var(--serif); font-size:40px; color:var(--accent); line-height:.6; margin-bottom:20px;}
.tcard p{font-family:var(--serif); font-style:italic; font-size:calc(19px*var(--ts)); line-height:1.5; color:var(--ink); margin:0 0 28px;}
.tcard .au{font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink);}
.tcard .ro{font-size:10.5px; letter-spacing:.08em; color:var(--mute); margin-top:4px;}
.brands{border-top:1px solid var(--line); padding-top:40px;}
.brands .lab{font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--mute); text-align:center; margin-bottom:30px;}
.brands .row{display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(28px,5vw,72px);}
.brands .row span{font-family:var(--serif); font-style:italic; font-size:clamp(18px,2vw,26px); color:var(--mute); opacity:.65;}

/* ===== FAQ ===== */
.faq{display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(30px,5vw,80px);}
.faq .eyebrow{color:var(--accent); margin-bottom:22px;}
.faq h2{font-family:var(--serif); font-weight:300; font-size:clamp(32px,4vw,54px); line-height:1.08; margin:0;}
.faq-item{border-top:1px solid var(--line);}
.faq-q{width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; padding:26px 0;
  background:none; border:none; cursor:pointer; text-align:left; font:inherit; color:var(--ink);}
.faq-q .qt{font-family:var(--serif); font-size:clamp(19px,2vw,25px); font-weight:400;}
.faq-q .sign{font-size:20px; color:var(--accent); flex-shrink:0; transition:transform .3s;}
.faq-a{max-height:0; overflow:hidden; transition:max-height .4s ease;}
.faq-a p{font-size:calc(13.5px*var(--ts)); line-height:1.95; color:var(--inkSoft); margin:0; padding:0 0 28px; max-width:60ch;}
.faq-item.open .faq-q .sign{transform:rotate(180deg);}

/* ===== Contact ===== */
.contact{background:var(--dark); color:var(--onDark);}
.contact-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(40px,6vw,90px); align-items:start;}
.contact .eyebrow{color:var(--accentSoft); margin-bottom:28px;}
.contact .eyebrow .tick{background:var(--accentSoft);}
.contact h2{font-family:var(--serif); font-weight:300; font-size:clamp(40px,5.6vw,84px); line-height:1; margin:0 0 30px;}
.contact h2 em{font-style:italic; color:var(--accentSoft); display:block;}
.contact .intro{font-size:calc(14px*var(--ts)); line-height:1.95; color:rgba(255,255,255,.62); max-width:40ch; margin:0 0 48px;}
.contact-list{display:flex; flex-direction:column; gap:22px;}
.contact-list a{display:flex; align-items:baseline; gap:18px; text-decoration:none; color:var(--onDark);
  border-bottom:1px solid rgba(255,255,255,.12); padding-bottom:16px; transition:border-color .3s;}
.contact-list a:hover{border-color:var(--accentSoft);}
.contact-list .lab{font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.5); width:86px; flex-shrink:0;}
.contact-list .val{font-family:var(--serif); font-style:italic; font-size:clamp(18px,2vw,24px);}
.form-wrap{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); padding:clamp(28px,3vw,42px);}
.form-wrap form{display:flex; flex-direction:column; gap:22px;}
.form-wrap label{display:block; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:10px;}
.form-wrap input, .form-wrap select, .form-wrap textarea{width:100%; background:transparent; border:none;
  border-bottom:1px solid rgba(255,255,255,.2); color:var(--onDark); font:inherit; font-size:15px; padding:8px 0;
  outline:none;}
.form-wrap textarea{resize:vertical;}
.form-wrap select{background:var(--dark);}
.form-wrap select option{color:#111;}
.form-wrap input:focus, .form-wrap select:focus, .form-wrap textarea:focus{border-color:var(--accentSoft);}
.form-wrap button{margin-top:8px; padding:16px; background:var(--bg); color:var(--dark); border:none;
  border-radius:100px; font:inherit; font-size:11px; letter-spacing:.16em; text-transform:uppercase; cursor:pointer; transition:background .3s;}
.form-wrap button:hover{background:var(--accentSoft);}
.form-wrap button:disabled{opacity:.6; cursor:default;}
.sent-state{display:none; flex-direction:column; align-items:center; justify-content:center; text-align:center; min-height:320px; gap:16px;}
.sent-state .mark{font-size:34px; color:var(--accentSoft);}
.sent-state .h{font-family:var(--serif); font-style:italic; font-size:26px;}
.sent-state p{font-size:13px; line-height:1.8; color:rgba(255,255,255,.6); margin:0; max-width:32ch;}
.form-wrap.done form{display:none;}
.form-wrap.done .sent-state{display:flex;}

/* ===== Footer ===== */
footer.site{display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px;
  padding:30px clamp(24px,5vw,80px); background:var(--dark); color:rgba(255,255,255,.55); border-top:1px solid rgba(255,255,255,.1);}
footer.site .fb{font-family:var(--serif); font-size:13px; letter-spacing:.26em; text-transform:uppercase; color:rgba(255,255,255,.85);}
footer.site .fc{font-size:10.5px; letter-spacing:.08em;}

/* ===== GLightbox brand tweak ===== */
.glightbox-clean .gslide-description{background:var(--dark);}
.glightbox-clean .gdesc-inner{padding:14px 20px;}
.gslide-title{font-family:var(--serif)!important; font-style:italic; color:var(--onDark)!important;}

/* ===== Responsive ===== */
@media (max-width:1080px){
  .nav-links{display:none;}
  .burger{display:flex;}
}
@media (max-width:960px){
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .proc-grid{grid-template-columns:repeat(2,1fr);}
  .tile{grid-column:span 6;}
}
@media (max-width:860px){
  .about{grid-template-columns:1fr;}
  .faq{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
}
@media (max-width:760px){
  .hero{grid-template-columns:1fr;}
  .hero-media{min-height:78vh; order:-1;}
  .testi-grid{grid-template-columns:1fr;}
}
@media (max-width:600px){
  .svc-grid{grid-template-columns:1fr;}
  .proc-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .tile{grid-column:span 12; grid-row:span 1!important;}
}
