/* ============================================================
   ATELIER — Photography by Steve Edwards design system
   Paper / ink monochrome · Jost (display) + Inter (body)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@300;400;500&family=Inter:wght@300;400;500&display=swap');

:root{
  --paper:#FBFAF8; --paper-2:#F2EFE8; --card:#ffffff;
  --ink:#1B1A17; --muted:#8C857A; --line:#E6E0D5; --gold:#b08d4f;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--paper);color:var(--ink);line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased;}
h1,h2,h3,.display{font-family:'Jost',sans-serif;font-weight:300;line-height:1.08;letter-spacing:-.5px;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.wrap{max-width:1280px;margin:0 auto;padding:0 40px;}
@media(max-width:600px){.wrap{padding:0 22px;}}

.label{font-family:'Jost',sans-serif;font-weight:400;letter-spacing:4px;text-transform:uppercase;font-size:12px;color:var(--muted);}
.btn{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;font-family:'Jost',sans-serif;font-weight:400;letter-spacing:2px;text-transform:uppercase;font-size:13px;padding:16px 30px;transition:.25s;cursor:pointer;border:0;}
.btn-ink{background:var(--ink);color:var(--paper);}
.btn-ink:hover{background:#000;}
.btn-line{border:1px solid var(--ink);color:var(--ink);background:none;}
.btn-line:hover{background:var(--ink);color:var(--paper);}
.btn-light{border:1px solid rgba(255,255,255,.6);color:#fff;background:none;}
.btn-light:hover{background:#fff;color:var(--ink);}
.link-u{font-family:'Jost',sans-serif;font-weight:400;letter-spacing:2px;text-transform:uppercase;font-size:13px;border-bottom:1px solid var(--ink);padding-bottom:3px;transition:.2s;}
.link-u:hover{color:var(--muted);border-color:var(--muted);}

/* HEADER */
header{position:sticky;top:0;z-index:50;background:rgba(251,250,248,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px;}
.logo-img{height:46px;width:auto;display:block;}
.navlinks{display:flex;gap:38px;align-items:center;}
.navlinks a:not(.btn){font-family:'Jost',sans-serif;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;font-size:13px;color:var(--ink);transition:.15s;}
.navlinks a:not(.btn):hover{color:var(--muted);}
.navlinks .btn{padding:12px 24px;}

/* dropdown */
.dropdown{position:relative;}
.dropdown-trigger{background:none;border:0;font:inherit;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:7px;color:var(--ink);font-family:'Jost',sans-serif;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;font-size:13px;transition:.15s;}
.dropdown-trigger:hover,.dropdown.open .dropdown-trigger{color:var(--muted);}
.chev{font-size:9px;transition:.2s;}
.dropdown.open .chev,.dropdown:hover .chev{transform:rotate(180deg);}
.dropdown-menu{position:absolute;top:calc(100% + 24px);right:0;min-width:230px;background:var(--card);border:1px solid var(--line);padding:10px 0;opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s ease;z-index:60;box-shadow:0 24px 50px rgba(27,26,23,.1);max-height:72vh;overflow-y:auto;}
.dropdown:hover .dropdown-menu,.dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown-menu a{display:block;padding:11px 22px;color:var(--ink);font-size:15px;}
.dropdown-menu a:hover{background:var(--paper-2);}
.dropdown-menu a.here{color:var(--muted);}
.dropdown-divider{height:1px;background:var(--line);margin:8px 0;}
.dropdown-all{color:var(--muted) !important;letter-spacing:1px;}

/* mobile nav */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:120;}
.hamburger span{display:block;width:26px;height:1.5px;background:var(--ink);transition:.25s;}
.mnav{position:fixed;inset:0;background:var(--paper);z-index:110;transform:translateY(-100%);transition:transform .4s cubic-bezier(.6,0,.2,1);display:flex;flex-direction:column;padding:110px 32px 40px;overflow-y:auto;}
.mnav.open{transform:translateY(0);}
.mnav a{font-family:'Jost',sans-serif;font-weight:300;letter-spacing:.5px;font-size:26px;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line);}
.mnav .mlabel{font-family:'Jost',sans-serif;letter-spacing:3px;text-transform:uppercase;font-size:11px;color:var(--muted);margin-top:26px;margin-bottom:4px;}
.mnav .mtowns{display:grid;grid-template-columns:1fr 1fr;gap:0 20px;}
.mnav .mtowns a{font-size:17px;padding:9px 0;}
.mnav .mbook{margin-top:30px;}
body.menu-open{overflow:hidden;}
@media(max-width:900px){
  .navlinks a:not(.btn),.navlinks .dropdown,.navlinks .btn{display:none;}
  .hamburger{display:flex;}
}
@media(min-width:901px){ .mnav{display:none;} }

/* BREADCRUMB */
.crumb{border-bottom:1px solid var(--line);}
.crumb .wrap{padding:14px 40px;font-family:'Jost',sans-serif;letter-spacing:1.5px;text-transform:uppercase;font-size:11px;color:var(--muted);}
@media(max-width:600px){.crumb .wrap{padding:14px 22px;}}
.crumb a{color:var(--muted);}
.crumb a:hover{color:var(--ink);}
.crumb span{color:var(--ink);}
.crumb .sep{margin:0 10px;opacity:.5;}

/* HOMEPAGE HERO */
.hero{padding:74px 0 0;}
.hero-head{display:grid;grid-template-columns:1.3fr .9fr;gap:50px;align-items:end;margin-bottom:46px;}
@media(max-width:820px){.hero-head{grid-template-columns:1fr;gap:24px;}}
.hero h1{font-size:clamp(46px,6.6vw,94px);font-weight:300;letter-spacing:-1.5px;}
.hero h1 em{font-style:italic;color:var(--muted);}
.hero-sub p{color:var(--muted);font-size:18px;max-width:380px;margin-bottom:26px;}
.hero-cta{display:flex;gap:26px;align-items:center;flex-wrap:wrap;}
.hero-figure{position:relative;height:clamp(380px,64vh,680px);overflow:hidden;}
.hero-figure img{width:100%;height:100%;object-fit:cover;}
.hero-cap{position:absolute;left:26px;bottom:24px;color:#fff;font-family:'Jost',sans-serif;letter-spacing:3px;text-transform:uppercase;font-size:12px;text-shadow:0 1px 14px rgba(0,0,0,.5);}

/* SUBPAGE HERO (towns / services / gallery) */
.subhero{position:relative;min-height:60vh;display:flex;align-items:flex-end;overflow:hidden;}
.subhero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.subhero::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,14,12,.82) 0%,rgba(15,14,12,.25) 45%,rgba(15,14,12,.1) 100%);}
.subhero .wrap{position:relative;z-index:2;padding-top:70px;padding-bottom:54px;}
.subhero .label{color:rgba(255,255,255,.82);}
.subhero h1{color:#fff;font-size:clamp(40px,6vw,82px);font-weight:300;letter-spacing:-1.5px;margin:18px 0 18px;max-width:14ch;}
.subhero h1 em{font-style:italic;color:rgba(255,255,255,.7);}
.subhero p{color:rgba(255,255,255,.9);font-size:18px;max-width:520px;margin-bottom:28px;}
.subhero-cta{display:flex;gap:24px;align-items:center;flex-wrap:wrap;}

/* STRIP */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);}
@media(max-width:680px){.strip .wrap{grid-template-columns:1fr 1fr;}}
.strip .item{padding:34px 0;border-left:1px solid var(--line);padding-left:26px;}
.strip .item:first-child{border-left:0;padding-left:0;}
@media(max-width:680px){.strip .item:nth-child(odd){border-left:0;padding-left:0;}.strip .item{padding-left:0;}.strip .item:nth-child(even){border-left:1px solid var(--line);padding-left:26px;}}
.strip .num{font-family:'Jost',sans-serif;font-weight:300;font-size:34px;letter-spacing:-1px;}
.strip .lbl{font-size:13px;color:var(--muted);margin-top:2px;}

section{padding:108px 0;}
@media(max-width:700px){section{padding:72px 0;}}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:54px;flex-wrap:wrap;}
.sec-head h2{font-size:clamp(32px,4.4vw,56px);font-weight:300;max-width:680px;}
.sec-head .label{margin-bottom:18px;display:block;}

/* INTRO (prose) */
.intro .wrap{max-width:880px;}
.intro .label{display:block;margin-bottom:20px;}
.intro h2{font-size:clamp(30px,4vw,46px);font-weight:300;margin-bottom:30px;}
.intro p{font-size:18.5px;color:#43403a;margin-bottom:22px;line-height:1.75;}
.intro p b{color:var(--ink);font-weight:400;}

/* SERVICES — typographic index */
.svc-list{border-top:1px solid var(--line);}
.svc-row{display:grid;grid-template-columns:64px 1fr minmax(0,430px);gap:30px;align-items:baseline;padding:30px 4px;border-bottom:1px solid var(--line);transition:.25s;}
.svc-row:hover{padding-left:18px;background:linear-gradient(90deg,var(--paper-2),transparent);}
.svc-row .no{font-family:'Jost',sans-serif;color:var(--muted);font-size:14px;letter-spacing:2px;}
.svc-row h3{font-family:'Jost',sans-serif;font-weight:400;font-size:clamp(22px,2.6vw,30px);letter-spacing:-.5px;}
.svc-row p{color:var(--muted);font-size:15px;max-width:430px;text-align:left;}
@media(max-width:760px){.svc-row{grid-template-columns:44px 1fr;gap:20px;}.svc-row p{display:none;}}

/* WORK — editorial grid */
.gal{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;}
.gal figure{position:relative;overflow:hidden;margin:0;}
.gal img{width:100%;height:100%;object-fit:cover;transition:.6s cubic-bezier(.2,.7,.2,1);}
.gal figure:hover img{transform:scale(1.05);}
.gal figcaption{position:absolute;left:16px;bottom:14px;color:#fff;font-family:'Jost',sans-serif;letter-spacing:2px;text-transform:uppercase;font-size:11px;text-shadow:0 1px 12px rgba(0,0,0,.55);}
.g-wide{grid-column:span 4;aspect-ratio:16/9;}
.g-tall{grid-column:span 2;aspect-ratio:3/4;}
.g-sq{grid-column:span 2;aspect-ratio:1/1;}
.g-half{grid-column:span 3;aspect-ratio:3/2;}
.g-full{grid-column:span 6;aspect-ratio:21/9;}
@media(max-width:760px){.gal{grid-template-columns:1fr 1fr;}.g-wide,.g-tall,.g-sq,.g-half,.g-full{grid-column:span 2;aspect-ratio:3/2;}}

/* AREAS */
.areas{background:var(--paper-2);}
.area-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:40px;}
@media(max-width:760px){.area-tiles{grid-template-columns:1fr;}}
.area{position:relative;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:flex-end;}
.area img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s;}
.area::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,18,15,.7),transparent 60%);}
.area:hover img{transform:scale(1.05);}
.area .meta{position:relative;z-index:2;padding:22px;color:#fff;}
.area .meta span{font-family:'Jost',sans-serif;letter-spacing:2px;text-transform:uppercase;font-size:11px;opacity:.85;}
.area .meta h3{font-family:'Jost',sans-serif;font-weight:400;font-size:26px;letter-spacing:-.5px;}
.town-index{column-count:4;column-gap:30px;border-top:1px solid var(--line);padding-top:26px;}
@media(max-width:760px){.town-index{column-count:2;}}
.town-index a{display:block;padding:7px 0;font-size:15px;color:var(--ink);width:fit-content;}
.town-index a:hover{color:var(--muted);}

/* NEARBY chips */
.nearby{display:flex;flex-wrap:wrap;gap:12px;}
.nearby a{border:1px solid var(--line);padding:11px 20px;font-family:'Jost',sans-serif;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;font-size:12px;color:var(--ink);transition:.2s;}
.nearby a:hover{border-color:var(--ink);background:var(--ink);color:var(--paper);}

/* WHY */
.why{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;}
@media(max-width:820px){.why{grid-template-columns:1fr;gap:34px;}}
.why-img{aspect-ratio:4/5;overflow:hidden;}
.why-img img{width:100%;height:100%;object-fit:cover;}
.why h2{font-size:clamp(30px,4vw,48px);font-weight:300;margin:16px 0 18px;}
.why>div>p{color:var(--muted);font-size:17px;}
.why ul{list-style:none;margin-top:26px;}
.why li{padding:16px 0;border-top:1px solid var(--line);color:var(--muted);font-size:15px;}
.why li b{color:var(--ink);font-weight:400;font-family:'Jost',sans-serif;letter-spacing:.3px;}

/* CTA */
.cta{text-align:center;}
.cta h2{font-size:clamp(38px,6vw,82px);font-weight:300;letter-spacing:-1.5px;margin-bottom:20px;}
.cta h2 em{font-style:italic;color:var(--muted);}
.cta p{color:var(--muted);font-size:18px;margin-bottom:34px;}
.cta .phone{display:block;margin-top:30px;font-family:'Jost',sans-serif;font-weight:300;font-size:30px;letter-spacing:1px;}
.cta .phone:hover{color:var(--muted);}

/* FOOTER */
footer{border-top:1px solid var(--line);padding:64px 0 34px;}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;}
@media(max-width:700px){.foot{grid-template-columns:1fr;gap:28px;}}
footer h4{font-family:'Jost',sans-serif;font-weight:400;letter-spacing:2px;text-transform:uppercase;font-size:12px;color:var(--muted);margin-bottom:16px;}
footer a{color:var(--ink);font-size:15px;display:block;padding:5px 0;}
footer a:hover{color:var(--muted);}
.foot>div:first-child p{color:var(--muted);font-size:15px;max-width:330px;margin-top:8px;}
.social{display:flex;gap:12px;margin-top:20px;}
.social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--line);border-radius:50%;color:var(--ink);transition:.2s;}
.social a:hover{color:#0d0d0f;background:var(--gold);border-color:var(--gold);}
.social svg{width:18px;height:18px;display:block;}
.copy{border-top:1px solid var(--line);margin-top:48px;padding-top:26px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:13px;}

/* GALLERY page: filter + lightbox */
.filterbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px;}
.filterbar button{border:1px solid var(--line);background:none;color:var(--ink);font-family:'Jost',sans-serif;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;font-size:12px;padding:10px 16px;cursor:pointer;transition:.18s;}
.filterbar button:hover{border-color:var(--ink);}
.filterbar button.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.ggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media(max-width:760px){.ggrid{grid-template-columns:1fr 1fr;}}
@media(max-width:460px){.ggrid{grid-template-columns:1fr;}}
.gitem{position:relative;overflow:hidden;aspect-ratio:3/2;cursor:pointer;margin:0;}
.gitem img{width:100%;height:100%;object-fit:cover;transition:.5s cubic-bezier(.2,.7,.2,1);}
.gitem:hover img{transform:scale(1.05);}
.gitem .tag{position:absolute;left:0;bottom:0;background:rgba(20,18,15,.78);color:#fff;font-family:'Jost',sans-serif;font-weight:400;letter-spacing:1.5px;font-size:11px;padding:7px 13px;text-transform:uppercase;margin:0;}
.gitem.hide{display:none;}
.lightbox{position:fixed;inset:0;background:rgba(15,14,12,.96);display:none;align-items:center;justify-content:center;z-index:200;padding:30px;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:88vh;box-shadow:0 30px 80px rgba(0,0,0,.6);}
.lightbox .close{position:absolute;top:18px;right:28px;color:#fff;font-size:40px;line-height:1;cursor:pointer;font-family:'Jost',sans-serif;font-weight:300;z-index:3;}
.lightbox .close:hover{color:var(--muted);}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:56px;height:56px;border:none;border-radius:50%;background:rgba(0,0,0,.4);color:#fff;font-size:34px;line-height:1;cursor:pointer;transition:background .2s,color .2s;z-index:3;padding:0;}
.lightbox .lb-nav:hover{background:var(--gold,#c9a86a);color:#0d0d0f;}
.lightbox .lb-prev{left:24px;}
.lightbox .lb-next{right:24px;}
.lightbox .lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;font-family:'Jost',sans-serif;letter-spacing:2px;font-size:13px;z-index:3;}
@media(max-width:600px){
  .lightbox .lb-nav{width:46px;height:46px;font-size:26px;}
  .lightbox .lb-prev{left:10px;}
  .lightbox .lb-next{right:10px;}
}

/* video embed */
.videowrap{overflow:hidden;border:1px solid var(--line);}
.videowrap video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#000;}
.videowrap iframe{width:100%;aspect-ratio:16/9;display:block;border:0;}
.yt-facade{display:block;width:100%;aspect-ratio:16/9;border:0;padding:0;margin:0;cursor:pointer;background:#000 center/cover no-repeat;position:relative;}
.yt-facade::after{content:"";position:absolute;inset:0;background:rgba(13,13,15,.28);transition:background .25s;}
.yt-facade:hover::after{background:rgba(13,13,15,.12);}
.yt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:88px;height:88px;border-radius:50%;background:rgba(201,168,106,.94);z-index:2;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s;}
.yt-facade:hover .yt-play{transform:translate(-50%,-50%) scale(1.06);background:var(--gold,#c9a86a);}
.yt-play::before{content:"";width:0;height:0;border-left:28px solid #0d0d0f;border-top:17px solid transparent;border-bottom:17px solid transparent;margin-left:7px;}

/* TESTIMONIALS */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
@media(max-width:760px){.quotes{grid-template-columns:1fr;}}
.quote{background:var(--card);border:1px solid var(--line);padding:32px 30px;display:flex;flex-direction:column;gap:14px;}
.quote .stars{color:var(--gold);letter-spacing:3px;font-size:14px;}
.quote>p{font-size:16.5px;line-height:1.65;color:var(--ink);font-weight:300;}
.quote .qby{margin-top:6px;display:flex;flex-direction:column;}
.quote .qby b{font-family:'Jost',sans-serif;font-weight:400;letter-spacing:.3px;font-size:15px;color:var(--ink);}
.quote .qby span{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:3px;}

/* FAQ ACCORDION */
.faqlist{max-width:880px;margin:0 auto;border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:28px 4px;font-family:'Jost',sans-serif;font-weight:400;font-size:21px;line-height:1.4;color:var(--ink);transition:color .2s ease;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary:hover{color:var(--gold);}
.faq-item .sign{flex:none;width:22px;height:22px;position:relative;margin-top:6px;transition:transform .3s ease;}
.faq-item .sign::before,.faq-item .sign::after{content:"";position:absolute;background:var(--gold);border-radius:2px;}
.faq-item .sign::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%);}
.faq-item .sign::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);transition:opacity .3s ease,transform .3s ease;}
.faq-item[open] .sign{transform:rotate(180deg);}
.faq-item[open] .sign::after{opacity:0;transform:translateX(-50%) scaleY(0);}
.faq-item .answer{padding:0 4px 30px;max-width:760px;}
.faq-item .answer p{font-size:16.5px;line-height:1.7;color:var(--muted);font-weight:300;}
.faq-item .answer a{color:var(--gold);border-bottom:1px solid currentColor;}
