/* Lightbox Digital — handcrafted paper aesthetic */
:root{
  --paper:#f7f3ec; --ink:#191613; --muted:#7d766c; --accent:#b5522a;
  --line:#e3dccf; --serif:'Fraunces',Georgia,serif; --sans:'Inter',system-ui,sans-serif;
  --max:1060px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.7;font-size:16.5px;-webkit-font-smoothing:antialiased;position:relative}
/* paper grain */
body::before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.35;z-index:1;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.03 0'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)'/%3E%3C/svg%3E")}
main,header,footer{position:relative;z-index:2}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px;text-decoration-thickness:1.5px}
a:hover{color:var(--accent)}
h1,h2{font-family:var(--serif);font-weight:420;line-height:1.12;letter-spacing:-.015em}
h1{font-size:clamp(2.1rem,5.2vw,3.7rem)}
h2{font-size:clamp(1.5rem,3.2vw,2.3rem)}
h1 em,h2 em{font-style:italic;font-weight:480}
.squiggle{position:relative;white-space:nowrap}
.squiggle::after{content:"";position:absolute;left:0;right:0;bottom:-.12em;height:.3em;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 12' preserveAspectRatio='none'%3E%3Cpath d='M2 8 C 18 2, 32 11, 50 6 S 86 3, 118 7' fill='none' stroke='%23b5522a' stroke-width='2.4' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/100% 100%}
.eyebrow{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:1.1rem}
.label{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:1.05rem;margin-bottom:1.6rem;border-bottom:1px solid var(--line);padding-bottom:.55rem}
.note{color:var(--muted);max-width:38rem;margin-top:1.2rem;font-size:1.02rem}
.note .arrow{color:var(--accent)}
.prose{max-width:40rem;color:#3d3833}
.prose p{margin-bottom:1rem}
.more{margin-top:1.8rem;font-family:var(--serif);font-style:italic}

/* buttons */
.btn{display:inline-block;background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:500;font-size:.92rem;
  padding:.75rem 1.7rem;border:0;border-radius:2px;cursor:pointer;text-decoration:none;transition:.2s}
.btn:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}
.or{color:var(--muted);font-style:italic;font-family:var(--serif);margin:0 .3rem}

/* nav */
.nav{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem clamp(1rem,4vw,2rem) 1.2rem;border-bottom:1px solid var(--line)}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:1.18rem;font-weight:480;text-decoration:none}
.brand img{width:30px}
.nav-links{display:flex;align-items:center;gap:1.5rem;font-size:.93rem}
.nav-links a{text-decoration:none;color:var(--ink);opacity:.8}
.nav-links a:hover{color:var(--accent);opacity:1}
.nav-links a.active{border-bottom:2px solid var(--accent);opacity:1}
.contact-link{font-family:var(--serif);font-style:italic;color:var(--accent) !important;opacity:1 !important}
.burger{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}

/* sections */
.intro{max-width:var(--max);margin:0 auto;padding:clamp(3.5rem,9vw,6.5rem) clamp(1rem,4vw,2rem) 2.5rem}
.intro.small{padding-bottom:1rem}
.section{max-width:var(--max);margin:0 auto;padding:clamp(2.6rem,6vw,4.5rem) clamp(1rem,4vw,2rem)}
.cta{max-width:var(--max);margin:0 auto;padding:clamp(3rem,8vw,5.5rem) clamp(1rem,4vw,2rem);text-align:center;border-top:1px solid var(--line)}
.cta p{margin-top:1.6rem}

/* reel */
.reelwrap{max-width:var(--max);margin:0 auto;padding:0 clamp(1rem,4vw,2rem) 1rem}

/* work pieces */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2.4rem 2rem}
.piece.big{grid-column:1/-1}
.piece figcaption{margin-top:.7rem;font-size:.92rem;display:flex;gap:.6rem;align-items:baseline;flex-wrap:wrap}
.piece figcaption strong{font-family:var(--serif);font-weight:520;font-size:1.02rem}
.piece figcaption em{color:var(--muted);font-family:var(--serif)}
.pdur{margin-left:auto;color:var(--muted);font-size:.8rem}
.pthumb{position:relative;display:block;width:100%;padding:0;border:1px solid var(--ink);cursor:pointer;background:var(--ink);
  box-shadow:4px 4px 0 rgba(25,22,19,.12);transition:.25s}
.pthumb:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 rgba(181,82,42,.25)}
.pthumb img{aspect-ratio:16/9;object-fit:cover;width:100%;transition:.3s}
.pthumb:hover img{opacity:.88}
.pplay{position:absolute;inset:0;display:grid;place-items:center}
.pplay::before{content:"";width:58px;height:60px;background:url("../assets/img/mark-ink.png") no-repeat center/contain;
  filter:invert(1) drop-shadow(0 2px 8px rgba(0,0,0,.5));transition:.25s}
.pthumb:hover .pplay::before{transform:scale(1.1)}

/* filters */
.filters{display:flex;gap:.4rem 1.4rem;flex-wrap:wrap;margin-bottom:2.2rem;font-size:.95rem}
.fbtn{background:none;border:0;cursor:pointer;font:inherit;color:var(--muted);padding:.2rem 0;border-bottom:2px solid transparent}
.fbtn:hover{color:var(--ink)}
.fbtn.active{color:var(--ink);border-bottom-color:var(--accent);font-weight:500}

/* services */
.svc{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.1rem 2.4rem}
.svc li{border-bottom:1px solid var(--line);padding:.7rem 0;display:flex;justify-content:space-between;gap:1rem;align-items:baseline}
.svc strong{font-family:var(--serif);font-weight:520}
.svc span{color:var(--muted);font-size:.9rem;text-align:right}

/* quotes */
.quotes{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:2rem}
.quotes.col{grid-template-columns:1fr;max-width:44rem}
.quote p{font-family:var(--serif);font-style:italic;font-size:1.08rem;line-height:1.6}
.quote cite{display:block;margin-top:.7rem;font-style:normal;font-size:.85rem;color:var(--muted)}
.quote{border-left:2px solid var(--accent);padding-left:1.2rem}

/* faq */
.faqwrap{max-width:44rem}
.faq{border-bottom:1px solid var(--line);padding:.9rem 0}
.faq summary{cursor:pointer;font-family:var(--serif);font-size:1.05rem;font-weight:500;list-style:none;position:relative;padding-right:1.8rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;top:0;color:var(--accent);font-size:1.2rem;transition:.2s}
.faq[open] summary::after{transform:rotate(45deg)}
.faq p{color:var(--muted);margin-top:.6rem;font-size:.97rem}

/* photography */
.masonry{columns:3 290px;column-gap:1.4rem}
.pitem{break-inside:avoid;margin-bottom:1.4rem}
.pimg{display:block;width:100%;padding:0;border:1px solid var(--ink);cursor:zoom-in;background:none;
  box-shadow:4px 4px 0 rgba(25,22,19,.12);transition:.25s}
.pimg:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 rgba(181,82,42,.25)}
.pimg img{width:100%}

/* about / contact */
.about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-grid.flip{grid-template-columns:1.3fr 1fr}
.about-grid img{border:1px solid var(--ink);box-shadow:5px 5px 0 rgba(25,22,19,.12)}
.about-grid .btn{margin-top:.6rem}

/* form */
.form{display:grid;gap:1.1rem;border:1px solid var(--ink);padding:clamp(1.4rem,3vw,2rem);background:#fffdf8;box-shadow:5px 5px 0 rgba(25,22,19,.12)}
.form label{display:grid;gap:.35rem;font-size:.88rem;font-weight:500}
.form input,.form select,.form textarea{background:var(--paper);border:1px solid var(--line);color:var(--ink);
  padding:.65rem .8rem;font:inherit;font-size:.95rem;border-radius:2px}
.form input:focus,.form select:focus,.form textarea:focus{outline:2px solid var(--accent);border-color:transparent}

/* footer */
.footer{border-top:1px solid var(--line);margin-top:2rem}
.footer-inner{max-width:var(--max);margin:0 auto;padding:2.8rem clamp(1rem,4vw,2rem);text-align:center}
.fmark{font-family:var(--serif);font-size:1.05rem;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.8rem}
.footer p{color:var(--muted);font-size:.92rem;margin-bottom:.6rem}
.fsoc a,.fnav a{color:var(--ink)}
.fcopy{font-size:.8rem;margin-top:1.4rem}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(20,17,14,.94);display:grid;place-items:center;padding:4vh 4vw}
.lightbox[hidden]{display:none}
.lb-frame{width:min(1080px,92vw)}
.lb-frame iframe,.lb-frame video{width:100%;aspect-ratio:16/9;border:0;background:#000}
.lb-frame img{max-height:88vh;width:auto;max-width:92vw;margin:0 auto}
.lb-close{position:absolute;top:1.1rem;right:1.4rem;background:none;border:0;color:#f7f3ec;font-size:1.6rem;cursor:pointer;opacity:.8}
.lb-close:hover{opacity:1;color:#e8a87c}

/* reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* responsive */
@media (max-width:820px){
  .burger{display:block}
  .nav-links{position:fixed;inset:0;background:var(--paper);flex-direction:column;justify-content:center;
    gap:1.7rem;font-size:1.25rem;transform:translateY(-102%);transition:transform .3s,visibility .3s;visibility:hidden;z-index:60}
  .nav-links.open{transform:none;visibility:visible}
  body.navlock{overflow:hidden}
  .burger{z-index:61}
  .burger.x span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
  .burger.x span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}
  .about-grid,.about-grid.flip{grid-template-columns:1fr}
  .about-grid img{max-height:430px;object-fit:cover;width:100%}
  .svc span{text-align:left}
  .svc li{flex-direction:column;gap:.1rem}
}
