:root{
    --cream:#FBFAF7;
    --cream-2:#F3F0E8;
    --cream-3:#ECE8DD;
    --ink:#211F1B;
    --ink-soft:#6E6A61;
    --olive:#6B6C26;
    --olive-2:#83842F;
    --line:#DAD5C7;
    --serif:'Cormorant Garamond',Georgia,serif;
    --sans:'Jost','Helvetica Neue',Arial,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--cream);
    color:var(--ink);
    font-family:var(--sans);
    font-weight:300;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}

  /* ---------- header: long lockup left, nav right ---------- */
  .masthead{position:relative;display:flex;align-items:center;justify-content:space-between;
    padding:13px clamp(20px,4vw,48px);border-bottom:1px solid var(--line);background:var(--cream)}
  .masthead .mh-logo img{height:48px;width:auto;display:block}
  .topnav{display:flex;gap:clamp(14px,2vw,34px);margin-left:auto}
  .topnav a{font-family:var(--sans);font-weight:400;font-size:12px;letter-spacing:.2em;
    text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid transparent;
    padding-bottom:3px;transition:color .25s,border-color .25s;white-space:nowrap}
  .topnav a:hover{color:var(--olive);border-color:var(--olive)}
  @media(max-width:820px){.masthead .mh-logo img{height:38px}.topnav{gap:13px}}
  @media(max-width:560px){.masthead{flex-wrap:wrap;justify-content:center;gap:8px}.masthead .mh-logo img{height:34px}.topnav{gap:10px;flex-wrap:nowrap}.topnav a{font-size:10px;letter-spacing:.08em}}
  @media(max-width:430px){.topnav{gap:7px}.topnav a{font-size:8.5px;letter-spacing:.03em;padding-bottom:2px}}

  /* ---------- sticky slim bar (fades in on scroll) ---------- */
  .stickybar{
    position:fixed;top:0;left:0;right:0;z-index:60;
    display:flex;align-items:center;justify-content:space-between;
    padding:12px clamp(20px,5vw,48px);
    background:rgba(251,250,247,.92);
    backdrop-filter:blur(8px);
    border-bottom:1px solid var(--line);
    transform:translateY(-100%);transition:transform .4s ease;
  }
  .stickybar.show{transform:translateY(0)}
  .stickybar .mark{display:flex;align-items:center;gap:12px}
  .stickybar .mark img{height:26px;width:auto;display:block}
  .stickybar .mark span{
    font-family:var(--sans);font-weight:400;font-size:12px;
    letter-spacing:.26em;text-transform:uppercase;color:var(--ink)
  }
  .stickybar nav{display:flex;gap:clamp(14px,2vw,34px)}
  .stickybar nav a{
    font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);
    transition:color .25s}
  .stickybar nav a:hover{color:var(--olive)}
  @media(max-width:720px){.stickybar nav{display:none}}

  /* ---------- hero ---------- */
  .hero{position:relative;height:82vh;min-height:540px;width:100%;overflow:hidden;background:var(--cream-2)}
  .hero .media{position:absolute;inset:0}
  .hero video,.hero img{width:100%;height:100%;object-fit:cover;display:block}
  .hero .herovid{filter:brightness(.80) saturate(.88)}
  .hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(34,31,27,.30) 0%,rgba(34,31,27,.30) 45%,rgba(34,31,27,.50) 100%)}
  .hero .caption{
    position:absolute;left:0;right:0;bottom:clamp(40px,7vh,90px);
    text-align:center;color:var(--cream);padding:0 24px;
  }
  .hero .caption .eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;opacity:.9;font-weight:400}
  .hero .caption h1{
    font-family:var(--serif);font-weight:300;font-style:italic;
    font-size:clamp(28px,4.6vw,58px);line-height:1.12;margin-top:14px;
    text-shadow:0 1px 30px rgba(0,0,0,.35)
  }
  /* placeholder look for hero until a clip/photo is dropped */
  .ph-hero{
    position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
    background:
      radial-gradient(120% 100% at 50% 0%,#fefdfb 0%,#efece3 55%,#e4ded0 100%);
  }
  .ph-hero .house{width:200px;opacity:.5}
  .ph-hero .label{margin-top:18px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:#a59f8f}

  /* ---------- intro statement ---------- */
  .intro{text-align:center;padding:clamp(64px,10vh,120px) 0}
  .intro p{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(20px,2.5vw,30px);line-height:1.5;color:var(--ink);
    max-width:880px;margin:0 auto;
  }
  .intro .sig{margin-top:30px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--olive)}

  /* ---------- section heading ---------- */
  .sec-head{display:flex;align-items:baseline;justify-content:space-between;
    border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:36px;gap:20px;flex-wrap:wrap}
  .sec-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(24px,3vw,38px);letter-spacing:.01em}
  .sec-head .more{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);
    border-bottom:1px solid transparent;transition:.25s}
  .sec-head .more:hover{color:var(--olive);border-color:var(--olive)}

  /* ---------- projects grid (Pursley B&W) ---------- */
  .projects{padding:clamp(30px,5vh,60px) 0}
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.6vw,22px)}
  @media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.grid{grid-template-columns:1fr}}
  .tile{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--cream-3);cursor:pointer}
  .tile .img{position:absolute;inset:0;background-size:cover;background-position:center;
    filter:grayscale(1) contrast(1.02);transition:filter .6s ease,transform 1.2s ease}
  .tile:hover .img{filter:grayscale(0);transform:scale(1.04)}
  /* placeholder tile fill */
  .tile .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    background:linear-gradient(150deg,#d9d4c8,#c3bdae 60%,#b4ad9c);
    filter:grayscale(1)}
  .tile .ph svg{width:84px;opacity:.45}
  .tile .meta{position:absolute;left:0;right:0;bottom:0;padding:20px 22px;
    background:linear-gradient(0deg,rgba(28,26,22,.62),rgba(28,26,22,0));color:var(--cream);
    transform:translateY(6px);opacity:.96}
  .tile .meta .name{font-family:var(--serif);font-size:23px;font-weight:400;line-height:1.1}
  .tile .meta .loc{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;margin-top:6px;opacity:.85}

  /* ---------- renderings differentiator strip ---------- */
  .renders{margin-top:clamp(70px,9vh,120px);background:var(--ink);color:var(--cream)}
  .renders .inner{display:grid;grid-template-columns:1.05fr 1fr;min-height:62vh}
  @media(max-width:820px){.renders .inner{grid-template-columns:1fr;min-height:0}.renders .shot{height:48vh;min-height:300px}}
  .renders .copy{padding:clamp(40px,6vw,84px);display:flex;flex-direction:column;justify-content:center}
  .renders .copy .eyebrow{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#b9bb6e}
  .renders .copy h2{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.6vw,46px);
    line-height:1.16;margin:18px 0 18px}
  .renders .copy p{color:#cfccc2;max-width:46ch;font-size:15px}
  .renders .copy .more{margin-top:30px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--cream);border-bottom:1px solid #6f6f43;padding-bottom:5px;width:max-content}
  .renders .shot{position:relative;background:#2b2924;overflow:hidden}
  .renders .shot .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    background:radial-gradient(120% 100% at 70% 20%,#3a3830,#23211c)}
  .renders .shot .ph svg{width:150px;opacity:.5}
  .renders .shot .label{position:absolute;bottom:18px;left:0;right:0;text-align:center;
    font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:#8c8772}

  /* ---------- process teaser ---------- */
  .process{padding-top:clamp(70px,10vh,130px);padding-bottom:clamp(70px,10vh,130px)}
  .process .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,40px);margin-top:8px}
  @media(max-width:820px){.process .steps{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:480px){.process .steps{grid-template-columns:1fr}}
  .step .n{font-family:var(--serif);font-style:italic;font-size:34px;color:var(--olive);line-height:1}
  .step h3{font-family:var(--serif);font-weight:500;font-size:21px;margin:14px 0 8px}
  .step p{font-size:14px;color:var(--ink-soft)}

  /* ---------- in progress ---------- */
  .inprog{background:var(--cream-2);padding:clamp(64px,9vh,120px) 0}
  .inprog .row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.4vw,18px)}
  @media(max-width:820px){.inprog .row{grid-template-columns:repeat(2,1fr)}}
  .chip{aspect-ratio:1/1;background:var(--cream-3);position:relative;overflow:hidden}
  .chip .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    background:linear-gradient(150deg,#e7e2d6,#d6d0c1)}
  .chip .ph svg{width:54px;opacity:.4}

  /* ---------- contact / footer ---------- */
  footer{background:var(--ink);color:var(--cream);padding:clamp(64px,9vh,110px) 0 40px;text-align:center}
  footer .house{width:120px;opacity:.85;margin-bottom:26px}
  footer h2{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(26px,3.4vw,44px)}
  footer .email{display:inline-block;margin-top:22px;font-size:14px;letter-spacing:.14em;
    border-bottom:1px solid #5f5f3c;padding-bottom:5px}
  footer .email:hover{color:#c8ca7d;border-color:#c8ca7d}
  footer .fine{margin-top:54px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#807c6f}
  footer .fine a{color:#a8a496}
  footer .fine .sep{margin:0 10px;color:#4d4a40}

  /* ---------- scroll reveal ---------- */
  .reveal{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s ease}
  .reveal.in{opacity:1;transform:none}

/* ============ INTERIOR PAGES ============ */
/* page hero (shorter than home) */
.pagehero{position:relative;height:62vh;min-height:440px;overflow:hidden;background:var(--cream-2)}
.pagehero .media,.pagehero video,.pagehero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pagehero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(33,31,27,.12),rgba(33,31,27,.5))}
.pagehero .cap{position:absolute;left:0;right:0;bottom:clamp(34px,6vh,70px);text-align:center;color:var(--cream);padding:0 24px}
.pagehero .cap .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;opacity:.92}
.pagehero .cap h1{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(30px,5vw,62px);margin-top:12px;text-shadow:0 1px 30px rgba(0,0,0,.4)}

/* simple page title (no image) */
.pagetitle{text-align:center;padding:clamp(60px,9vh,120px) 0 0}
.pagetitle .eyebrow{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--olive)}
.pagetitle h1{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5vw,60px);margin-top:14px}

/* project intro block */
.proj-intro{max-width:760px;margin:0 auto;text-align:center;padding:clamp(50px,7vh,90px) 24px}
.proj-intro .loc{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--olive)}
.proj-intro p{font-family:var(--serif);font-weight:300;font-size:clamp(18px,2.2vw,26px);line-height:1.55;color:var(--ink);margin-top:18px}
.proj-facts{display:flex;justify-content:center;gap:clamp(24px,5vw,70px);flex-wrap:wrap;margin-top:34px}
.proj-facts .f .k{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft,#6E6A61)}
.proj-facts .f .v{font-family:var(--serif);font-size:20px;margin-top:4px}

/* gallery */
.gallery{padding:clamp(20px,4vh,50px) 0 clamp(50px,8vh,110px)}
.gallery .col2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(8px,1.2vw,16px)}
@media(max-width:700px){.gallery .col2{grid-template-columns:1fr}}
.gallery figure{margin:0;overflow:hidden;background:var(--cream-3)}
.gallery figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.4s ease}
.gallery figure:hover img{transform:scale(1.03)}
.gallery .full{grid-column:1 / -1}
.gallery .full img{width:100%;display:block}
.gallery .tall img{aspect-ratio:4/5}
.gallery .wide img{aspect-ratio:3/2}

/* next project */
.nextproj{display:block;position:relative;height:46vh;min-height:320px;overflow:hidden;background:var(--ink)}
.nextproj img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) brightness(.6);transition:filter 1s,transform 1.4s}
.nextproj:hover img{filter:grayscale(0) brightness(.7);transform:scale(1.04)}
.nextproj .lbl{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--cream);text-align:center}
.nextproj .lbl .k{font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.85}
.nextproj .lbl .n{font-family:var(--serif);font-style:italic;font-size:clamp(28px,4vw,48px);margin-top:8px}

/* studio / about */
.studio{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;padding:clamp(50px,8vh,110px) 0}
@media(max-width:820px){.studio{grid-template-columns:1fr}}
.studio .port{width:100%;aspect-ratio:4/5;object-fit:cover;background:var(--cream-3)}
.studio h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.4vw,42px);margin-bottom:18px}
.studio p{margin-bottom:16px;color:var(--ink);max-width:54ch}
.studio .sig{margin-top:10px}.studio .sig{margin-top:18px}
  .studio .sig img{height:140px;width:auto}

/* process (Cardello-style) */
.proc-step{display:grid;grid-template-columns:120px 1fr;gap:clamp(20px,4vw,60px);padding:clamp(34px,5vh,64px) 0;border-bottom:1px solid var(--line)}
@media(max-width:680px){.proc-step{grid-template-columns:1fr;gap:12px}}
.proc-step .n{font-family:var(--serif);font-style:italic;font-size:clamp(40px,6vw,84px);color:var(--olive);line-height:.9}
.proc-step h3{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.8vw,30px);margin-bottom:12px}
.proc-step p{color:var(--ink);max-width:60ch}

/* in progress feed */
.feed{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.4vw,18px);padding:clamp(40px,6vh,80px) 0}
@media(max-width:820px){.feed{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.feed{grid-template-columns:1fr}}
.feed .card{background:var(--cream-2)}
.feed .card .ph{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;background:linear-gradient(150deg,#e7e2d6,#d6d0c1)}
.feed .card .ph svg{width:54px;opacity:.4}
.feed .card .cap{padding:16px 18px}
.feed .card .cap .d{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--olive)}
.feed .card .cap p{font-family:var(--serif);font-size:18px;margin-top:6px}

/* contact */
.contactwrap{max-width:680px;margin:0 auto;text-align:center;padding:clamp(50px,8vh,110px) 24px}
.contactwrap .big{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(28px,4vw,52px)}
.contactwrap .row{display:flex;justify-content:center;gap:clamp(24px,5vw,60px);flex-wrap:wrap;margin-top:40px}
.contactwrap .row .k{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--olive)}
.contactwrap .row .v{font-family:var(--serif);font-size:20px;margin-top:6px}
.contactwrap .v a{border-bottom:1px solid var(--line)}

/* back link */
.backlink{display:inline-block;margin:24px 0 0;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft,#6E6A61)}
.backlink:hover{color:var(--olive)}

/* masonry gallery */
.gallery .masonry{column-count:3;column-gap:14px}
@media(max-width:900px){.gallery .masonry{column-count:2}}
@media(max-width:560px){.gallery .masonry{column-count:1}}
.gallery .masonry figure{break-inside:avoid;margin:0 0 14px;overflow:hidden;background:var(--cream-3)}
.gallery .masonry figure img{width:100%;display:block;transition:transform 1.2s ease}
.gallery .masonry figure:hover img{transform:scale(1.03)}
/* projects index grid reuse .grid but color (not forced B&W) */
.idx .tile .img{filter:grayscale(1) contrast(1.02)}
.idx .tile:hover .img{filter:grayscale(0)}

/* contact form */
.formwrap{max-width:680px;margin:0 auto;padding:clamp(24px,4vh,50px) 24px clamp(60px,9vh,110px);text-align:center}
.formwrap form{text-align:left;margin-top:34px}
.formwrap .field{margin-bottom:20px}
.formwrap label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px}
.formwrap input,.formwrap select,.formwrap textarea{width:100%;background:var(--cream);border:1px solid var(--line);padding:13px 14px;font-family:var(--sans);font-weight:300;font-size:15px;color:var(--ink)}
.formwrap input:focus,.formwrap select:focus,.formwrap textarea:focus{outline:none;border-color:var(--olive)}
.formwrap textarea{min-height:130px;resize:vertical}
.formwrap .two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.formwrap .two{grid-template-columns:1fr}}
.formwrap button{margin-top:6px;background:var(--olive);color:var(--cream);border:none;padding:15px 42px;font-family:var(--sans);font-size:12px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .25s}
.formwrap button:hover{background:#585a1f}
/* footer social */
footer .social{display:inline-flex;gap:22px;margin-top:18px;margin-bottom:4px}
footer .social a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#c8ca7d;border-bottom:1px solid #5f5f3c;padding-bottom:3px}
footer .social a:hover{color:#e2e394}

/* rendering project gallery — grouped by view */
.rgallery{padding:clamp(20px,4vh,46px) 0 clamp(50px,8vh,100px)}
.rgroup{margin-bottom:clamp(30px,4vh,52px)}
.rgroup .vlabel{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--olive);
  border-bottom:1px solid var(--line);padding-bottom:9px;margin-bottom:16px}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(8px,1.2vw,14px)}
@media(max-width:880px){.rgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.rgrid{grid-template-columns:1fr}}
.rgrid figure{margin:0;overflow:hidden;background:var(--cream-3)}
.rgrid figure img{width:100%;display:block;transition:transform 1.1s ease}
.rgrid figure:hover img{transform:scale(1.03)}
/* renderings badge on intro */
.render-badge{display:inline-block;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--olive);border:1px solid var(--olive);border-radius:999px;padding:5px 14px;margin-bottom:6px}

/* footer CTA + instagram icon */
footer .cta{display:block;width:max-content;max-width:88%;margin:24px auto 0;border:1px solid #6f6f43;color:var(--cream);
  padding:13px 36px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;transition:.25s}
footer .cta:hover{background:#5a5b20;border-color:#5a5b20}
footer .ig{display:block;width:36px;margin:24px auto 6px}
footer .ig svg{width:36px;height:36px;display:block}
footer .ig svg rect, footer .ig svg circle{stroke:#c8ca7d;stroke-width:2.4;fill:none}
footer .ig svg .dot{fill:#c8ca7d;stroke:none}
footer .ig:hover svg rect, footer .ig:hover svg circle{stroke:#e2e394}
footer .ig:hover svg .dot{fill:#e2e394}
/* CTA + instagram icon stack at all widths (base rules above handle centering) */

/* commercial / hospitality strip */
.commercial{padding:clamp(58px,9vh,116px) 0;background:var(--cream-2);text-align:center}
.commercial .eyebrow{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--olive)}
.commercial h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.4vw,40px);margin-top:12px}
.commercial .sub{color:var(--ink-soft);max-width:56ch;margin:14px auto 42px}
.commercial .row{display:flex;justify-content:center;gap:clamp(28px,6vw,90px);flex-wrap:wrap}
.commercial .card .nm{font-family:var(--serif);font-size:26px}
.commercial .card .ds{font-size:12px;letter-spacing:.06em;color:var(--ink-soft);margin:8px 0 16px}
.commercial .card a.link{display:inline-flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--olive)}
.commercial .card a.link svg{width:17px;height:17px}
.commercial .card a.link svg rect,.commercial .card a.link svg circle{stroke:var(--olive);stroke-width:3;fill:none}
.commercial .card a.link svg .dot{fill:var(--olive);stroke:none}
.commercial .card a.link:hover{color:var(--ink)}

/* commercial card sizing + venue photo grid */
.commercial .card{width:min(320px,86vw)}
.commercial .vphotos{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:16px 0 18px}
.commercial .vphotos img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:var(--cream-3)}
