*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--cream:#F5F0EB;--cw:#EDE6DD;--ch:#1A1A1A;--chs:#2D2D2D;--tp:#A69080;--tpl:#C4B5A6;--tpp:#D9CFC5;--ac:#C8956C;--acd:#A87650;--wh:#FDFBF9;--dng:#c85050;--grn:#2d8a5e;--sf:'Cormorant Garamond',Georgia,serif;--sn:'Outfit',sans-serif}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sn);background:var(--cream);color:var(--ch);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}button{font-family:var(--sn)}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.5rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:all .4s}
nav.scrolled{background:rgba(245,240,235,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1rem 3rem;border-bottom:1px solid rgba(166,144,128,.15)}
.nav-logo{font-family:var(--sf);font-size:1.75rem;font-weight:300;letter-spacing:.35em;text-transform:uppercase;color:var(--ch);cursor:pointer;background:none;border:none}
.nav-r{display:flex;gap:2rem;align-items:center}
.nav-link{background:none;border:none;cursor:pointer;font-size:.75rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--ch);font-family:var(--sn);padding-bottom:2px;transition:color .3s;position:relative}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--ac);transition:width .3s}
.nav-link:hover::after,.nav-link.act::after{width:100%}.nav-link.act{color:var(--ac)}
.lang-sw{display:flex;border:1px solid rgba(166,144,128,.2);border-radius:50px;overflow:hidden}
.lang-btn{background:none;border:none;padding:.35rem .7rem;font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;color:var(--tp);transition:all .3s;font-family:var(--sn)}
.lang-btn.act{background:var(--ch);color:var(--cream)}
.adm-pill{border:1px solid rgba(26,26,26,.12);border-radius:50px;padding:.4rem 1rem;font-size:.65rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--tp);cursor:pointer;background:none;transition:all .3s}
.adm-pill.on{border-color:rgba(200,149,108,.3);color:var(--ac)}
.mob-btn{display:none;background:none;border:none;cursor:pointer;color:var(--ch)}
.mob-ov{position:fixed;inset:0;z-index:999;background:var(--cream);display:none;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.mob-ov.open{display:flex}
.mob-ov button{background:none;border:none;cursor:pointer;font-family:var(--sf);font-size:2rem;font-weight:300;color:var(--ch)}
.mob-cl{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--sn)!important;font-size:2rem!important}

/* REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s,transform .8s}.reveal.visible{opacity:1;transform:translateY(0)}
.sl{font-size:.65rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--tp);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}
.sl::before{content:'';width:30px;height:1px;background:var(--tpl)}.sl-c{justify-content:center}.sl-c::after{content:'';width:30px;height:1px;background:var(--tpl)}
.sl-lt::before,.sl-lt::after{background:var(--tp);opacity:.4}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:8rem 2rem 4rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30%;right:-20%;width:70vw;height:70vw;max-width:900px;max-height:900px;border-radius:50%;background:radial-gradient(circle,rgba(200,149,108,.08) 0%,transparent 70%);pointer-events:none;animation:fo 20s ease-in-out infinite}
.hero::after{content:'';position:absolute;bottom:-20%;left:-15%;width:50vw;height:50vw;max-width:700px;max-height:700px;border-radius:50%;background:radial-gradient(circle,rgba(166,144,128,.06) 0%,transparent 70%);pointer-events:none;animation:fo 25s ease-in-out infinite reverse}
@keyframes fo{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}
.hero-ey{font-size:.7rem;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:var(--tp);margin-bottom:2.5rem;opacity:0;animation:fu 1s ease .3s forwards}
.hero-t{font-family:var(--sf);font-weight:300;font-size:clamp(3rem,7.5vw,7rem);line-height:.95;letter-spacing:-.02em;margin-bottom:2rem;opacity:0;animation:fu 1.2s ease .5s forwards}
.hero-t em{font-style:italic;font-weight:300;color:var(--ac)}
.hero-ln{width:50px;height:1px;background:var(--tpl);margin:0 auto 2rem;opacity:0;animation:fu 1s ease .8s forwards}
.hero-sub{font-size:1.05rem;font-weight:300;line-height:1.7;color:var(--tp);max-width:520px;opacity:0;animation:fu 1s ease 1s forwards}
.hero-sc{position:absolute;bottom:3rem;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:.75rem;opacity:0;animation:fu 1s ease 1.4s forwards}
.hero-sc span{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--tpl);display:block;text-align:center;padding-left:.25em}
.scr-ln{width:1px;height:40px;background:linear-gradient(to bottom,var(--tpl),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.3)}}
@keyframes fu{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

.mq{padding:3rem 0;overflow:hidden;border-top:1px solid rgba(166,144,128,.15);border-bottom:1px solid rgba(166,144,128,.15)}
.mq-t{display:flex;width:max-content;animation:mqan 30s linear infinite}
.mq-t span{font-family:var(--sf);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:300;font-style:italic;color:var(--tpp);white-space:nowrap;padding:0 2rem}
.mq-t span::after{content:'\2726';display:inline-block;margin-left:2rem;font-size:.6em;color:var(--ac);opacity:.4;vertical-align:middle}
@keyframes mqan{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.about{padding:6rem 3rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1300px;margin:0 auto;align-items:center}
.ab-vis{position:relative}
.ab-img-wrap{position:relative;border-radius:2px;overflow:hidden;background:var(--ch);padding:1.5rem}
.ab-photo{width:100%;display:block;border-radius:1px;aspect-ratio:3/4;object-fit:cover}
.ab-img-wrap::before{content:'';position:absolute;inset:1.5rem;border:1px solid rgba(200,149,108,.15);z-index:2;pointer-events:none}
.ab-acc{position:absolute;bottom:-2rem;right:0;width:55%;aspect-ratio:1;background:var(--ac);border-radius:2px;opacity:.12}

.svc{padding:6rem 3rem;background:var(--ch);position:relative;overflow:hidden}
.svc::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--tp),transparent);opacity:.2}
.svc-g{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;max-width:1300px;margin:0 auto;background:rgba(166,144,128,.1)}
.sc{background:var(--ch);padding:3.5rem 2.5rem;transition:background .5s}.sc:hover{background:var(--chs)}
.sc-n{font-family:var(--sf);font-size:3.5rem;font-weight:300;color:rgba(200,149,108,.12);line-height:1;margin-bottom:2rem;transition:color .5s}.sc:hover .sc-n{color:rgba(200,149,108,.25)}
.sc h3{font-family:var(--sf);font-size:1.6rem;font-weight:400;color:var(--cream);margin-bottom:.5rem}
.sc-ty{font-size:.65rem;font-weight:400;letter-spacing:.25em;text-transform:uppercase;color:var(--ac);margin-bottom:1.5rem}
.sc p{font-size:.88rem;font-weight:300;line-height:1.8;color:var(--tpl)}
.sc-dv{width:30px;height:1px;background:var(--ac);opacity:.4;margin:1.5rem 0}
.sc-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.sc-tag{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--tp);padding:.35rem .85rem;border:1px solid rgba(166,144,128,.15);border-radius:50px;transition:all .3s}
.sc:hover .sc-tag{border-color:rgba(200,149,108,.3);color:var(--tpl)}

.proc{padding:6rem 3rem;max-width:1300px;margin:0 auto}
.proc-t{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.proc-t::before{content:'';position:absolute;top:38px;left:10%;right:10%;height:1px;background:var(--tpp)}
.proc-s{text-align:center;padding:0 1.5rem}
.proc-d{width:14px;height:14px;border-radius:50%;border:2px solid var(--ac);background:var(--cream);margin:0 auto 2rem;position:relative;z-index:2;transition:background .3s,transform .3s}
.proc-s:hover .proc-d{background:var(--ac);transform:scale(1.3)}
.proc-sn{font-family:var(--sf);font-size:.9rem;color:var(--ac);margin-bottom:.75rem}
.proc-s h3{font-family:var(--sf);font-size:1.35rem;font-weight:400;margin-bottom:.75rem}
.proc-s p{font-size:.82rem;font-weight:300;line-height:1.75;color:var(--tp);max-width:220px;margin:0 auto}

.pg{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;max-width:1300px;margin:0 auto}
.pc{position:relative;aspect-ratio:4/5;border-radius:3px;overflow:hidden;cursor:pointer;display:block}
.pc-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s}.pc:hover .pc-bg{transform:scale(1.05)}
.pc-bdr{position:absolute;inset:1.2rem;border:1px solid rgba(255,255,255,.06);pointer-events:none;transition:border-color .4s}.pc:hover .pc-bdr{border-color:rgba(255,255,255,.12)}
.pc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,26,.7) 0%,rgba(26,26,26,.15) 40%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;transition:background .4s}.pc:hover .pc-ov{background:linear-gradient(to top,rgba(26,26,26,.85) 0%,rgba(26,26,26,.3) 50%,rgba(26,26,26,.1) 100%)}
.pc-ct{transform:translateY(0);opacity:1;transition:transform .4s}
.pc-cat{font-size:.6rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--ac);margin-bottom:.5rem}
.pc-nm{font-family:var(--sf);font-size:1.4rem;font-weight:400;color:#F5F0EB;margin-bottom:.3rem;transition:transform .3s}.pc:hover .pc-nm{transform:translateY(-4px)}
.pc-hover-desc{font-size:.78rem;font-weight:300;color:var(--tpl);line-height:1.5;max-height:0;opacity:0;overflow:hidden;transition:all .4s}.pc:hover .pc-hover-desc{max-height:80px;opacity:1}
.pc-desc{font-size:.78rem;font-weight:300;color:var(--tpl);line-height:1.5}
.g1{background:linear-gradient(145deg,#2D2D2D,#1A1A1A)}.g2{background:linear-gradient(145deg,#C8956C,#A87650)}.g3{background:linear-gradient(145deg,#A69080,#8A7568)}.g4{background:linear-gradient(145deg,#3D3028,#2A1F18)}.g5{background:linear-gradient(145deg,#D9CFC5,#C4B5A6)}.g6{background:linear-gradient(145deg,#111,#222)}

.philo{padding:6rem 3rem;text-align:center;background:var(--ch);position:relative;overflow:hidden}
.philo::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--tp),transparent);opacity:.15}
.philo blockquote{font-family:var(--sf);font-size:clamp(2rem,4.5vw,3.5rem);font-weight:300;font-style:italic;line-height:1.3;margin-bottom:2.5rem;color:var(--cream);max-width:1000px;margin-left:auto;margin-right:auto}
.philo blockquote em{font-style:normal;color:var(--ac)}
.philo .sl::before,.philo .sl::after{background:var(--tp);opacity:.4}
.philo .philo-cr{color:var(--tp)}

.test{padding:6rem 3rem;background:var(--ch);position:relative;overflow:hidden}
.test::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--tp),transparent);opacity:.15}
.test-g{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1300px;margin:0 auto}
.tc{padding:2.5rem;border:1px solid rgba(166,144,128,.1);border-radius:3px;transition:border-color .4s}.tc:hover{border-color:rgba(200,149,108,.25)}
.tc-qm{font-family:var(--sf);font-size:4rem;font-weight:300;color:var(--ac);opacity:.25;line-height:1;margin-bottom:.5rem}
.tc-txt{font-family:var(--sf);font-size:1.05rem;font-weight:300;font-style:italic;line-height:1.7;color:var(--tpl);margin-bottom:2rem}
.tc-au{display:flex;align-items:center;gap:1rem}
.tc-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--ac),var(--acd));display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--sf);font-size:.9rem;color:var(--cream)}
.tc-nm{font-size:.8rem;font-weight:500;color:var(--cream)}.tc-rl{font-size:.7rem;font-weight:300;color:var(--tp)}

/* TEAM */
.team-section{padding:6rem 3rem;max-width:1300px;margin:0 auto}
.team-boxes{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem}
.team-box{border-radius:6px;overflow:hidden;background:var(--wh);border:1px solid rgba(166,144,128,.08)}
.team-box-photo{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top;display:block}
.team-box-body{padding:2rem}
.team-box-body h3{font-family:var(--sf);font-size:1.6rem;font-weight:300;margin-bottom:.3rem;color:var(--ch)}
.team-box-body .tbi-role{font-size:.6rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--ac);margin-bottom:1rem}
.tbi-bio{font-size:.82rem;font-weight:300;line-height:1.75;color:var(--tp)}
.tbi-full{display:none}
.tbi-toggle{background:none;border:none;cursor:pointer;color:var(--tp);padding:0;margin-top:.6rem;display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;font-family:var(--sn);transition:color .3s}
.tbi-toggle:hover{color:var(--ac)}
.tbi-chev{transition:transform .3s}
.tbi-toggle.open .tbi-chev{transform:rotate(180deg)}

.comm{padding:6rem 3rem;background:var(--cw)}
.comm-in{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.comm-st{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.st-n{font-family:var(--sf);font-size:2.5rem;font-weight:300;line-height:1;margin-bottom:.4rem}
.st-l{font-size:.7rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--tp)}
.comm-vis{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:2rem}
.cc{aspect-ratio:3/4;border-radius:3px;position:relative;overflow:hidden}
.cc:nth-child(2){margin-top:3rem}.cc:nth-child(3){margin-top:-1.5rem}.cc:nth-child(4){margin-top:1.5rem}
.cc::before{content:'';position:absolute;inset:0}
.cc:nth-child(1)::before{background:linear-gradient(135deg,var(--tpp),var(--tpl))}.cc:nth-child(2)::before{background:linear-gradient(135deg,var(--ch),var(--chs))}.cc:nth-child(3)::before{background:linear-gradient(135deg,var(--ac),var(--acd))}.cc:nth-child(4)::before{background:linear-gradient(135deg,var(--cream),var(--cw))}
.cc::after{content:'';position:absolute;inset:1.2rem;border:1px solid rgba(255,255,255,.12)}
.comm-vis-single{display:flex;align-items:center;justify-content:center}
.comm-hero-img{width:100%;border-radius:4px;object-fit:cover;aspect-ratio:3/4;display:block}

/* BLOG */
.blog-card{border-radius:6px;overflow:hidden;background:var(--wh);border:1px solid rgba(166,144,128,.08);transition:transform .3s,box-shadow .3s}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(26,26,26,.06)}
.blog-card-img{width:100%;height:220px;background-size:cover;background-position:center}
.blog-card-body{padding:1.5rem}

/* Blog post sidebar */
.bp-sb-box{background:var(--wh);border:1px solid rgba(166,144,128,.08);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}
.bp-sb-label{font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tpl);margin-bottom:1rem}
.bp-toc{display:flex;flex-direction:column;gap:.1rem}
.bp-toc-link{font-size:.8rem;font-weight:300;color:var(--tp);text-decoration:none;padding:.45rem .75rem;border-left:2px solid transparent;border-radius:0 4px 4px 0;transition:all .2s;line-height:1.4}
.bp-toc-link:hover{color:var(--ch);background:rgba(166,144,128,.04)}
.bp-toc-link.active{color:var(--ac);border-left-color:var(--ac);background:rgba(200,149,108,.04);font-weight:400}
.bp-sb-cta{background:var(--ch);border-radius:8px;padding:2rem;margin-bottom:1.5rem}
.bp-sb-cta-btn{display:block;text-align:center;font-size:.65rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);border:1px solid var(--ac);padding:.7rem 1.5rem;border-radius:4px;text-decoration:none;transition:all .3s}
.bp-sb-cta-btn:hover{background:var(--ac);color:#fff}
.bp-sb-post{display:flex;gap:.75rem;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(166,144,128,.06);text-decoration:none;color:var(--ch);transition:color .2s}
.bp-sb-post:last-child{border-bottom:none;padding-bottom:0}
.bp-sb-post:hover{color:var(--ac)}
.bp-sb-post-img{width:50px;height:50px;border-radius:4px;background-size:cover;background-position:center;flex-shrink:0}

/* Blog body */
.blog-body{font-size:.95rem;font-weight:300;line-height:1.95;color:var(--ch)}
.blog-body h2{font-family:var(--sf);font-size:1.8rem;font-weight:400;margin:2.5rem 0 1rem;scroll-margin-top:7rem}
.blog-body h3{font-family:var(--sf);font-size:1.4rem;font-weight:400;margin:2rem 0 .75rem}
.blog-body p{margin-bottom:1.2rem;color:#444}
.blog-body ul,.blog-body ol{margin:1rem 0 1.5rem 1.5rem;color:#444}
.blog-body li{margin-bottom:.5rem;line-height:1.8}
.blog-body blockquote{border-left:3px solid var(--ac);padding:1rem 0 1rem 1.5rem;margin:2rem 0;font-family:var(--sf);font-size:1.15rem;font-style:italic;color:var(--tp)}
.blog-body a{color:var(--ac);text-decoration:underline;text-underline-offset:3px}
.blog-body img{width:100%;border-radius:4px;margin:2rem 0}
.blog-body strong{font-weight:500;color:var(--ch)}
.blog-body *{max-width:100%;box-sizing:border-box}

/* FAQ */
.faq-item{transition:background .3s}
.faq-item[open] summary svg{transform:rotate(180deg)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}

.cta{padding:6rem 3rem;text-align:center;position:relative}
.cta::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60vw;height:60vw;max-width:700px;max-height:700px;border-radius:50%;background:radial-gradient(circle,rgba(200,149,108,.06) 0%,transparent 70%);pointer-events:none}
.cta h2{font-family:var(--sf);font-size:clamp(2.5rem,6vw,5rem);font-weight:300;line-height:1.1;margin-bottom:2rem}.cta h2 em{font-style:italic;color:var(--ac)}
.cta p{font-size:.95rem;font-weight:300;line-height:1.8;color:var(--tp);max-width:450px;margin:0 auto 3rem}

.btn{display:inline-flex;align-items:center;gap:.75rem;font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .3s;font-family:var(--sn)}
.btn-o{background:none;color:var(--ch);border:1px solid var(--ch);padding:.8rem 2rem}.btn-o:hover{background:var(--ch);color:var(--cream)}
.btn-p{background:var(--ch);color:var(--cream);border:1px solid var(--ch);padding:.8rem 2rem;border-radius:3px}.btn-p:hover{background:var(--chs)}

.ph{padding:12rem 3rem 3rem;text-align:center}
.ph h1{font-family:var(--sf);font-size:clamp(2.5rem,6vw,5rem);font-weight:300;line-height:1.05;margin-bottom:1.5rem}.ph h1 em{font-style:italic;color:var(--ac)}
.ph p{font-size:.95rem;font-weight:300;line-height:1.7;color:var(--tp);max-width:500px;margin:0 auto}
.fbar{display:flex;justify-content:center;gap:.5rem;padding:0 3rem 4rem;flex-wrap:wrap}
.fpill{background:transparent;color:var(--tp);border:1px solid rgba(166,144,128,.25);padding:.6rem 1.5rem;border-radius:50px;cursor:pointer;font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;font-family:var(--sn);transition:all .3s}
.fpill:hover{border-color:var(--ch);color:var(--ch)}.fpill.act{background:var(--ch);color:var(--cream);border-color:var(--ch)}
.pag{display:flex;justify-content:center;gap:.5rem;padding:3rem 0}
.pag-btn{width:40px;height:40px;border-radius:50%;border:1px solid rgba(166,144,128,.2);background:none;cursor:pointer;font-size:.8rem;font-weight:500;color:var(--tp);transition:all .3s;font-family:var(--sn);display:flex;align-items:center;justify-content:center}
.pag-btn:hover{border-color:var(--ch);color:var(--ch)}.pag-btn.act{background:var(--ch);color:var(--cream);border-color:var(--ch)}
.pag-btn:disabled{opacity:.3;cursor:default}

/* PROJECT DETAIL — natural image sizing */
.pj-detail{padding-top:8rem;max-width:1100px;margin:0 auto;padding-left:3rem;padding-right:3rem;padding-bottom:6rem}
.pj-back{font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--tp);cursor:pointer;background:none;border:none;margin-bottom:3rem;display:flex;align-items:center;gap:.5rem;transition:color .3s;font-family:var(--sn)}.pj-back:hover{color:var(--ac)}
.pj-gallery{margin-bottom:3rem;position:relative}
.pj-gallery-main{position:relative;display:flex;align-items:center;justify-content:center}
.pj-gallery img{width:auto;max-width:100%;max-height:80vh;border-radius:4px;display:block;margin:0 auto}
.pj-gallery-thumbs{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
.pj-gallery-thumb{width:70px;height:52px;border-radius:3px;background-size:cover;background-position:center;cursor:pointer;border:2px solid transparent;opacity:.5;transition:all .3s}
.pj-gallery-thumb:hover,.pj-gallery-thumb.act{opacity:1;border-color:var(--ac)}
.pj-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(26,26,26,.65);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(26,26,26,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s;z-index:5}
.pj-nav:hover{background:rgba(26,26,26,.85)}.pj-nav.l{left:1rem}.pj-nav.r{right:1rem}
.pj-nav svg{width:22px;height:22px}
.pj-placeholder{width:100%;aspect-ratio:16/9;border-radius:4px;margin-bottom:3rem}
.pj-meta{display:grid;grid-template-columns:2fr 1fr;gap:4rem;align-items:start}
.pj-meta h1{font-family:var(--sf);font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;line-height:1.1;margin-bottom:1rem}
.pj-desc{font-size:1rem;font-weight:300;line-height:1.85;color:var(--tp);margin-bottom:2rem}
.pj-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.pj-tag{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--tp);padding:.4rem 1rem;border:1px solid rgba(166,144,128,.2);border-radius:50px}
.pj-sidebar{padding:2rem;background:var(--wh);border-radius:3px;border:1px solid rgba(166,144,128,.1)}
.pj-si{margin-bottom:1.5rem}.pj-si:last-child{margin-bottom:0}
.pj-si-l{font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--tpl);margin-bottom:.3rem}
.pj-si-v{font-size:.95rem;font-weight:400}

/* CONTACT — title aligned with card */
.cnt-hero{min-height:55vh;display:flex;align-items:flex-end;padding:6rem 0 8rem;background:var(--ch);position:relative;overflow:hidden;margin-top:6rem}
.cnt-hero::before{content:'';position:absolute;top:-20%;right:-10%;width:50vw;height:50vw;max-width:600px;max-height:600px;border-radius:50%;background:radial-gradient(circle,rgba(200,149,108,.1) 0%,transparent 70%);pointer-events:none}
.cnt-hero-inner{max-width:1200px;margin:0 auto;width:100%;position:relative;padding:0 3rem}
.cnt-hero h1{font-family:var(--sf);font-size:clamp(3rem,7vw,6rem);font-weight:300;line-height:.95;color:var(--cream);margin-bottom:1.5rem;text-align:left}
.cnt-hero h1 em{font-style:italic;color:var(--ac)}
.cnt-hero p{font-size:1rem;font-weight:300;line-height:1.7;color:var(--tpl);max-width:500px;text-align:left}
.cnt-body{max-width:1200px;margin:-4rem auto 0;padding:0 3rem 8rem;position:relative;z-index:2}
.cnt-card{background:var(--wh);border-radius:6px;box-shadow:0 30px 80px rgba(26,26,26,.08);overflow:hidden;display:grid;grid-template-columns:1fr 1.3fr}
.cnt-info{padding:4rem 3rem;background:var(--cream);display:flex;flex-direction:column;justify-content:center}
.cnt-info h3{font-family:var(--sf);font-size:1.8rem;font-weight:300;margin-bottom:2.5rem}.cnt-info h3 em{font-style:italic;color:var(--ac)}
.cnt-ii{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}
.cnt-ic{width:40px;height:40px;border-radius:50%;background:rgba(200,149,108,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--ac)}
.cnt-il{font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tpl);margin-bottom:.2rem}
.cnt-iv{font-size:.95rem;font-weight:400}
.cnt-soc{display:flex;gap:1rem;margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(166,144,128,.12)}
.cnt-soc a{font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--tp);transition:color .3s}.cnt-soc a:hover{color:var(--ac)}
.cnt-form{padding:4rem 3rem}
.fg{margin-bottom:1.25rem}
.fg label{display:block;font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--tp);margin-bottom:.5rem}
.fg input,.fg select,.fg textarea{width:100%;padding:.85rem 1rem;border:1px solid rgba(166,144,128,.15);border-radius:6px;background:var(--cream);font-size:.88rem;font-weight:300;color:var(--ch);font-family:var(--sn);outline:none;transition:all .3s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(200,149,108,.08)}
.fg textarea{resize:vertical;line-height:1.7}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.succ-cnt{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem 3rem;margin-top:6rem}
.succ-ic{width:80px;height:80px;border-radius:50%;background:var(--ch);display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;color:var(--ac);font-size:2rem}
.alert{padding:.7rem 1rem;border-radius:3px;font-size:.8rem;margin-bottom:1.5rem}
.alert-err{background:rgba(200,80,80,.08);border:1px solid rgba(200,80,80,.2);color:var(--dng)}

/* ADMIN */
.adm-wrap{padding-top:8rem;max-width:1100px;margin:0 auto;padding:4rem 3rem 8rem}
.adm-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2.5rem}
.adm-sc{background:var(--wh);padding:1.5rem;border-radius:3px;border:1px solid rgba(166,144,128,.1)}
.adm-sc-v{font-family:var(--sf);font-size:2rem;font-weight:300;margin-bottom:.3rem}
.adm-sc-l{font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--tp)}
.adm-tabs{display:flex;gap:0;margin-bottom:2rem;border-bottom:1px solid rgba(166,144,128,.15)}
.adm-tab{padding:.8rem 1.5rem;font-size:.7rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--tp);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:var(--sn);transition:all .3s}
.adm-tab.act{color:var(--ch);border-bottom-color:var(--ac)}
.adm-tbl{background:var(--wh);border-radius:3px;border:1px solid rgba(166,144,128,.1);overflow:hidden}
.adm-tbl-hd{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(166,144,128,.1);display:grid;grid-template-columns:2.5fr 1fr .8fr .6fr 1.2fr;gap:1rem;font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--tp)}
.adm-row{padding:1rem 1.5rem;border-bottom:1px solid rgba(166,144,128,.06);display:grid;grid-template-columns:2.5fr 1fr .8fr .6fr 1.2fr;gap:1rem;align-items:center;transition:background .2s}.adm-row:hover{background:rgba(245,240,235,.5)}
.cat-pill{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--tp);background:rgba(166,144,128,.08);padding:.25rem .7rem;border-radius:50px;display:inline-block}
.star-btn{background:none;border:none;cursor:pointer;padding:.25rem;transition:transform .2s}.star-btn:hover{transform:scale(1.2)}
.btn-sm{font-size:.65rem;font-family:var(--sn);padding:.4rem .6rem;border-radius:3px;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;transition:all .3s}
.btn-ed{background:none;border:1px solid rgba(166,144,128,.15);color:var(--tp)}.btn-ed:hover{border-color:var(--ac);color:var(--ac)}
.btn-del{background:none;border:1px solid rgba(200,80,80,.15);color:var(--dng)}.btn-del:hover{background:rgba(200,80,80,.05)}
.btn-dng{background:var(--dng);color:#fff;border:none}
.btn-grn{background:none;border:1px solid rgba(45,138,94,.2);color:var(--grn)}.btn-grn:hover{background:rgba(45,138,94,.05)}
.editor-card{background:var(--wh);padding:2.5rem;border-radius:3px;border:1px solid rgba(166,144,128,.1)}
.img-up{width:100%;aspect-ratio:16/9;border-radius:3px;border:2px dashed rgba(166,144,128,.25);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:border-color .3s;overflow:hidden;margin-bottom:.5rem}.img-up:hover{border-color:var(--ac)}
.img-thumbs{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.75rem;margin-bottom:1rem}
.img-thumb{width:80px;height:60px;border-radius:3px;background-size:cover;background-position:center;position:relative;border:2px solid transparent;cursor:pointer;transition:border-color .3s}.img-thumb:hover{border-color:var(--ac)}
.img-thumb-rm{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--dng);color:#fff;border:none;cursor:pointer;font-size:.6rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}.img-thumb:hover .img-thumb-rm{opacity:1}
.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}
.tag-i{font-size:.7rem;color:var(--ch);padding:.3rem .8rem;background:rgba(200,149,108,.1);border-radius:50px;display:flex;align-items:center;gap:.4rem}
.tag-rm{background:none;border:none;cursor:pointer;color:var(--tp);font-size:.9rem;line-height:1;padding:0}
.tog-w{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:3px;border:1px solid rgba(166,144,128,.1);cursor:pointer;transition:all .3s;margin-bottom:2.5rem}
.tog-w.act{background:rgba(200,149,108,.06);border-color:rgba(200,149,108,.15)}
.tog-tr{width:40px;height:22px;border-radius:11px;background:var(--tpp);position:relative;transition:background .3s;flex-shrink:0}.tog-tr.act{background:var(--ac)}
.tog-dt{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:left .3s;box-shadow:0 1px 3px rgba(0,0,0,.15)}.tog-tr.act .tog-dt{left:20px}

/* MESSAGE DETAIL / REPLY */
.msg-detail{padding:2.5rem;max-width:700px}
.msg-thread{margin:2rem 0;padding:1.5rem 0;border-top:1px solid rgba(166,144,128,.1)}
.msg-bubble{padding:1rem 1.25rem;border-radius:8px;margin-bottom:1rem;max-width:90%;font-size:.88rem;font-weight:300;line-height:1.7}
.msg-bubble-in{background:rgba(166,144,128,.06);border:1px solid rgba(166,144,128,.08);margin-right:auto}
.msg-bubble-out{background:rgba(200,149,108,.06);border:1px solid rgba(200,149,108,.1);margin-left:auto}
.msg-bubble-meta{font-size:.6rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--tpl);margin-bottom:.4rem}
.msg-status{display:inline-flex;align-items:center;gap:.4rem;font-size:.6rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;padding:.3rem .8rem;border-radius:50px}
.msg-status-new{background:rgba(200,149,108,.08);color:var(--ac)}
.msg-status-replied{background:rgba(45,138,94,.08);color:var(--grn)}
.msg-status-done{background:rgba(166,144,128,.08);color:var(--tp)}
.msg-row{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(166,144,128,.06);cursor:pointer;transition:background .2s}
.msg-row:hover{background:rgba(245,240,235,.5)}
.msg-row.unread{background:rgba(200,149,108,.04)}

footer{background:var(--ch);padding:5rem 3rem 3rem;color:var(--tp)}
.ft-in{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:4rem;border-bottom:1px solid rgba(166,144,128,.1)}
.ft-brand .nav-logo{color:var(--cream);display:inline-block;margin-bottom:1.5rem}
.ft-brand p{font-size:.85rem;font-weight:300;line-height:1.7;max-width:300px}
.ft-col h4{font-size:.65rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--tpl);margin-bottom:1.5rem}
.ft-col a,.ft-col button{display:block;font-size:.85rem;font-weight:300;color:var(--tp);margin-bottom:.8rem;transition:color .3s;background:none;border:none;cursor:pointer;padding:0;font-family:var(--sn);text-align:left}
.ft-col a:hover,.ft-col button:hover{color:var(--cream)}
.ft-bot{max-width:1300px;margin:0 auto;padding-top:2rem;display:flex;justify-content:space-between;align-items:center;font-size:.7rem;font-weight:300;letter-spacing:.1em}

@media(max-width:1024px){.about{grid-template-columns:1fr;gap:3rem;padding:5rem 2rem}.ab-vis{max-width:500px;margin:0 auto}.ab-acc{display:none}.svc-g{grid-template-columns:1fr}.proc-t,.proc-t[style]{grid-template-columns:repeat(3,1fr)!important;gap:2rem}.proc-t::before{display:none}.pg{grid-template-columns:repeat(2,1fr)}.test-g{grid-template-columns:1fr;max-width:600px;margin:0 auto}.team-boxes{grid-template-columns:1fr;max-width:500px;margin-left:auto;margin-right:auto}.comm-in{grid-template-columns:1fr}.comm-vis{max-width:400px}.ft-in{grid-template-columns:1fr 1fr;gap:2.5rem}.cnt-card{grid-template-columns:1fr}.pj-meta{grid-template-columns:1fr;gap:2rem}}
@media(max-width:768px){nav{padding:1.2rem 1.5rem}nav.scrolled{padding:.8rem 1.5rem}.nav-r{display:none!important}.mob-btn{display:block!important}.hero{padding:6rem 1.5rem 3rem;min-height:90vh}.about{padding:3.5rem 1.5rem;gap:2rem}.ab-vis{max-width:100%}.ab-photo{aspect-ratio:4/5}.svc{padding:3.5rem 1.5rem}.sc{padding:2rem 1.5rem}.proc{padding:3.5rem 1.5rem}.proc-t,.proc-t[style]{grid-template-columns:repeat(2,1fr)!important;gap:1.5rem}.proc-s{padding:0 .5rem}.proc-s p{max-width:none}.philo{padding:3.5rem 1.5rem}.philo blockquote{font-size:clamp(1.5rem,5vw,2.5rem)}.test{padding:3.5rem 1.5rem}.test-g{gap:1.5rem}.team-section{padding:3.5rem 1.5rem}.team-boxes{gap:1.5rem;margin-top:2rem;max-width:100%}.team-box-body{padding:1.5rem}.team-box-body h3{font-size:1.3rem}.comm{padding:3.5rem 1.5rem}.comm-st{margin-top:2rem}.cta{padding:3.5rem 1.5rem}.pg{grid-template-columns:1fr;max-width:450px;margin:0 auto}.ph{padding:8rem 1.5rem 2rem}.fbar{padding:0 1.5rem 2rem}.cnt-hero{padding:4rem 0 6rem;min-height:40vh}.cnt-hero-inner{padding:0 1.5rem}.cnt-body{padding:0 1.5rem 4rem}.cnt-form{padding:2rem 1.5rem}.cnt-info{padding:2rem 1.5rem}.fr{grid-template-columns:1fr}.pj-detail{padding:6rem 1.5rem 3rem}.pj-meta{gap:2rem}footer{padding:2.5rem 1.5rem 2rem}.ft-in{grid-template-columns:1fr;gap:1.5rem}.ft-bot{flex-direction:column;gap:1rem;text-align:center}.adm-tbl-hd{display:none}.adm-row{grid-template-columns:1fr}.adm-wrap{padding:6rem 1.5rem 3rem}}
@media(max-width:480px){.proc-t,.proc-t[style]{grid-template-columns:1fr!important;gap:1.5rem}.proc-s{padding:0}.comm-vis{grid-template-columns:1fr 1fr;padding:0;gap:1rem}.cc:nth-child(2){margin-top:2rem}.cc:nth-child(3){margin-top:-1rem}.cc:nth-child(4){margin-top:1rem}}