:root{--cream:#e8e7df;--ink:#2f2f2b;--muted:#8a8a82;}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:"Roboto Condensed",sans-serif;color:var(--ink);background:var(--cream);}
.site-header{display:flex;align-items:center;justify-content:space-between;
  padding:22px 30px;position:sticky;top:0;background:var(--cream);z-index:50;}
.site-header .logo{font-family:"Cormorant Garamond",serif;font-size:30px;text-decoration:none;color:var(--ink);}
.site-header .logo sup{font-size:11px;}
.site-header nav{display:flex;gap:26px;}
.site-header nav a{font-size:12px;letter-spacing:2px;font-weight:400;text-decoration:none;color:var(--muted);}
.site-header nav a.active,.site-header nav a:hover{color:var(--ink);}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);transition:transform .3s,opacity .3s;}
.site-header.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.site-header.nav-open .nav-toggle span:nth-child(2){opacity:0;}
.site-header.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* full-width stacked gallery */
.gallery{display:flex;flex-direction:column;gap:6px;}
.gallery .item{position:relative;height:48vh;overflow:hidden;text-decoration:none;
  background:linear-gradient(135deg,#9c958a,#6f685e);
  display:flex;align-items:center;justify-content:center;cursor:pointer;}
.gallery .item .caption{color:#fff;font-weight:700;letter-spacing:3px;font-size:20px;
  opacity:0;transition:.3s;text-align:center;padding:0 20px;}
.gallery .item:hover .caption{opacity:1;}
.gallery .item .ph{position:absolute;bottom:12px;right:14px;color:#fff;opacity:.45;font-size:11px;letter-spacing:1px;}
.gallery .item img.thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.4s;}
.gallery .item:hover img.thumb{filter:brightness(.55);}
.gallery .item .caption{position:relative;z-index:2;}

.page-wrap{max-width:1100px;margin:0 auto;padding:50px 30px;}
.page-wrap h1{font-size:24px;letter-spacing:3px;margin-bottom:24px;}
.page-wrap p{line-height:1.7;margin-bottom:16px;font-size:15px;}
.gear-list{list-style:none;line-height:1.9;font-size:15px;}
@media(max-width:800px){
  .site-header{flex-direction:row;gap:0;align-items:center;}
  .nav-toggle{display:flex;}
  .site-header nav{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--cream);border-bottom:1px solid rgba(47,47,43,.12);padding:6px 0;
    transform:translateY(-10px);opacity:0;pointer-events:none;transition:transform .25s,opacity .25s;}
  .site-header.nav-open nav{transform:none;opacity:1;pointer-events:auto;}
  .site-header nav a{padding:14px 32px;font-size:14px;}
  .gallery .item{height:42vh;}
  .gallery .item .caption{opacity:1;}
}

/* case-study cover hero */
.case-hero{position:relative;width:100%;height:78vh;overflow:hidden;background:#1a1a18;}
.case-hero img{width:100%;height:100%;object-fit:cover;display:block;}
.case-hero__title{position:absolute;left:30px;bottom:28px;right:30px;color:#fff;
  font-family:"Cormorant Garamond",serif;font-style:italic;font-size:clamp(30px,6vw,68px);
  line-height:1;text-shadow:0 2px 24px rgba(0,0,0,.35);}

/* project meta */
.project-meta{display:flex;flex-wrap:wrap;gap:40px;margin:34px 0 0;border-top:1px solid rgba(47,47,43,.15);padding-top:26px;}
.project-meta div span{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}

/* about / cv layout */
.about{max-width:1100px;margin:0 auto;padding:46px 30px 20px;display:grid;grid-template-columns:300px 1fr;gap:54px;}
.about__side{display:flex;flex-direction:column;gap:34px;}
.about__cover{width:100%;margin:0;padding:0;}
.about__cover img{width:100%;height:clamp(300px,46vh,500px);object-fit:cover;object-position:center 45%;
  display:block;background:#1a1a18;}

/* contact cover banner with logo overlay */
.contact-cover{position:relative;width:100%;background:#1a1a18;}
.contact-cover__bg{width:100%;height:clamp(320px,52vh,560px);object-fit:cover;object-position:center 30%;display:block;}
.contact-cover::after{content:"";position:absolute;inset:0;background:rgba(20,20,18,.4);}
.contact-cover__logo{position:absolute;inset:0;margin:auto;width:min(320px,42vw);height:auto;z-index:2;}

/* contact two-column: form left, map right */
.contact-grid{max-width:1150px;margin:0 auto;padding:50px 30px;display:grid;
  grid-template-columns:1fr 1fr;gap:44px;align-items:stretch;}
.contact-grid h1{font-size:24px;letter-spacing:3px;margin-bottom:16px;}
.contact-grid p{line-height:1.7;font-size:15px;}
.contact-map{width:100%;height:100%;min-height:420px;}
.contact-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:grayscale(1);}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr;gap:28px;}}
.about__heading{margin-bottom:30px;}
.about__name{font-family:"Cormorant Garamond",serif;font-size:46px;line-height:.98;letter-spacing:1px;}
.about__name b{display:block;font-weight:600;}
.about__role{font-size:16px;letter-spacing:1.5px;color:var(--muted);margin-top:10px;}
.about__lead{font-family:"Cormorant Garamond",serif;font-size:22px;line-height:1.4;color:var(--ink);margin:22px 0 30px;font-style:italic;}
.about h2{font-size:15px;letter-spacing:5px;font-weight:700;margin-bottom:16px;}
.about__side h2{letter-spacing:4px;}
.about__main h2{border-bottom:1px solid rgba(47,47,43,.18);padding-bottom:10px;margin-bottom:18px;}
.about p{line-height:1.7;font-size:15px;margin-bottom:14px;}
.about__contact{list-style:none;font-size:14px;line-height:2;}
.about__contact li span{color:var(--muted);}
.about__block{font-size:14px;line-height:1.6;margin-bottom:16px;}
.about__block b{display:block;}
.about__block span{color:var(--muted);}
.about__job b{display:block;font-size:16px;}
.about__job .meta{color:var(--muted);font-size:14px;margin:2px 0 14px;}
.about__main ul{margin:0 0 16px 18px;font-size:15px;line-height:1.6;}
.about__main ul li{margin-bottom:8px;}
.about__tags{font-size:14px;color:var(--muted);line-height:1.7;}
@media(max-width:800px){.about{grid-template-columns:1fr;gap:34px;}}

/* outline button (contact submit, etc.) */
.btn{display:inline-block;border:1px solid var(--ink);padding:12px 26px;font-size:12px;
  letter-spacing:2px;font-weight:700;text-decoration:none;color:var(--ink);
  background:none;cursor:pointer;transition:.25s;}
.btn:hover{background:var(--ink);color:var(--cream);}

/* ---------- project (case-study) masonry layout ---------- */
.proj-hero{width:100%;}
.proj-hero img{width:100%;height:clamp(170px,35vh,360px);object-fit:cover;object-position:center 30%;
  display:block;background:#1a1a18;}
.proj-hero .ph-hero{width:100%;height:clamp(170px,35vh,360px);background:linear-gradient(135deg,#9c958a,#6f685e);
  display:flex;align-items:center;justify-content:center;color:#fff;letter-spacing:2px;font-size:12px;}

.proj-intro{max-width:1100px;margin:40px auto;padding:0 30px;}
.proj-intro h1{font-size:19px;font-weight:700;text-transform:uppercase;letter-spacing:7px;margin-bottom:22px;}
.proj-intro p{font-size:17px;line-height:1.7;max-width:760px;margin-bottom:18px;}
.proj-intro .proj-link{display:inline-block;font-size:13px;text-transform:uppercase;letter-spacing:2px;
  color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:2px;}

.proj-gallery{max-width:1100px;margin:0 auto;padding:0 30px;column-count:3;column-gap:14px;}
.proj-gallery figure{break-inside:avoid;margin-bottom:14px;}
.proj-gallery img{width:100%;height:auto;display:block;}
.proj-gallery .ph-fig{break-inside:avoid;margin-bottom:14px;background:linear-gradient(135deg,#9c958a,#6f685e);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;letter-spacing:1px;}

.proj-social{display:flex;justify-content:center;gap:22px;margin:48px 0;}
.proj-social a{color:var(--ink);font-size:15px;letter-spacing:1px;text-decoration:none;opacity:.7;text-transform:uppercase;}
.proj-social a:hover{opacity:1;}

.proj-next{text-align:center;padding:20px 0 80px;}
.proj-next span{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.proj-next a{font-size:clamp(28px,5vw,40px);font-weight:700;letter-spacing:6px;text-transform:uppercase;
  text-decoration:none;color:var(--ink);}
.proj-next a:hover{color:var(--muted);}

@media(max-width:900px){.proj-gallery{column-count:2;}}
@media(max-width:600px){.proj-gallery{column-count:1;}}

/* Fresh Stop — reels as editorial split entries on a dark band (phone + side text, alternating) */
.fs-reels{background:var(--cream);padding:clamp(40px,7vh,80px) 0 clamp(50px,8vh,90px);overflow:hidden;}
.fs-reels__intro{max-width:1100px;margin:0 auto clamp(14px,3vh,30px);padding:0 30px;text-align:center;}
.fs-reels__intro .eyebrow{display:block;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.fs-reels__intro h2{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(28px,4.5vw,44px);color:var(--ink);line-height:1.1;}

.fs-entry{max-width:1000px;margin:0 auto;padding:clamp(32px,6vh,64px) 30px;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;}
.fs-entry__text .eyebrow{display:block;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.fs-entry__text h3{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(24px,3.5vw,36px);color:var(--ink);line-height:1.12;margin-bottom:14px;}
.fs-entry__text p{font-size:15px;line-height:1.7;color:var(--ink);max-width:440px;}
.fs-entry__media{display:flex;justify-content:center;}
.fs-entry__media .cf-phone--still{width:clamp(190px,24vw,250px);transition:transform .45s ease;}
.fs-entry__media .cf-phone--still:hover{transform:translateY(-10px);}
/* alternate: even rows put the phone on the left, text on the right */
.fs-entry:nth-child(even) .fs-entry__text{order:2;}
/* directional scroll reveal — text & phone slide in from opposite sides */
.fs-entry__text,.fs-entry__media{opacity:0;transition:opacity 1s cubic-bezier(.16,.7,.18,1), transform 1s cubic-bezier(.16,.7,.18,1);}
.fs-entry__text{transform:translateX(-48px);}
.fs-entry__media{transform:translateX(48px);}
.fs-entry:nth-child(even) .fs-entry__text{transform:translateX(48px);}
.fs-entry:nth-child(even) .fs-entry__media{transform:translateX(-48px);}
.fs-entry.in .fs-entry__text,.fs-entry.in .fs-entry__media{opacity:1;transform:none;}
@media(max-width:720px){
  .fs-entry{grid-template-columns:1fr;gap:20px;text-align:center;}
  .fs-entry__text{order:0 !important;}
  .fs-entry__text p{margin:0 auto;}
  .fs-entry__text,.fs-entry__media,
  .fs-entry:nth-child(even) .fs-entry__text,.fs-entry:nth-child(even) .fs-entry__media{transform:translateY(34px);}
  .fs-entry.in .fs-entry__text,.fs-entry.in .fs-entry__media{transform:none;}
}

/* Fresh Stop — section heading, autoplay deal grid + social phone rows on the dark band */
.fs-head{max-width:1000px;margin:clamp(40px,7vh,80px) auto clamp(20px,3vh,32px);padding:0 30px;text-align:center;}
.fs-head .eyebrow{display:block;font-size:11px;letter-spacing:3px;text-transform:uppercase;
  font-weight:400;color:var(--muted);margin-bottom:10px;}
.fs-head h2{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(26px,4vw,40px);
  color:var(--ink);line-height:1.1;}
.fs-row{max-width:1100px;margin:0 auto;padding:0 30px;display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(22px,4vw,48px);align-items:flex-start;}
.fs-row + .fs-row{margin-top:clamp(22px,4vw,48px);}
.fs-row .reveal-up{display:flex;flex-direction:column;align-items:center;width:clamp(170px,21vw,220px);}
.fs-row .cf-phone--still{width:100%;transition:transform .45s ease;}
.fs-row .cf-phone--still:hover{transform:translateY(-10px);}
.fs-caption{margin-top:14px;text-align:center;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);line-height:1.4;}
/* socials rotate in from alternating sides */
.fs-row .reveal-up:nth-child(odd){transform:translateX(-46px) rotate(-3deg);}
.fs-row .reveal-up:nth-child(even){transform:translateX(46px) rotate(3deg);}
.fs-row .reveal-up.in{transform:none;}
@media(prefers-reduced-motion:reduce){.fs-row .reveal-up:nth-child(odd),.fs-row .reveal-up:nth-child(even){transform:none;}}

/* generic scroll-reveal (slide + fade up) — used by the contact map & misc */
.reveal-up{opacity:0;transform:translateY(44px);
  transition:opacity 1.2s cubic-bezier(.16,.7,.18,1), transform 1.2s cubic-bezier(.16,.7,.18,1);}
.reveal-up.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .reveal-up{transition:opacity .4s ease;transform:none;}
  .fs-entry__text,.fs-entry__media{transition:opacity .4s ease;transform:none;}
}

/* vertical media grids (reels + product stills) — inherit the .proj-gallery fade-reveal */
.proj-gallery--reels,.proj-gallery--stills{column-count:auto;column-gap:0;display:grid;gap:14px;}
.proj-gallery--reels{grid-template-columns:repeat(3,1fr);}
.proj-gallery--stills{grid-template-columns:repeat(4,1fr);}
.proj-gallery--reels figure,.proj-gallery--stills figure{margin:0;}
.proj-gallery--reels .cell,.proj-gallery--stills .cell{aspect-ratio:9/16;border-radius:2px;overflow:hidden;background:var(--dark);}
.proj-gallery--reels .cell video,.proj-gallery--reels .cell img,
.proj-gallery--stills .cell video,.proj-gallery--stills .cell img{width:100%;height:100%;object-fit:cover;display:block;}
@media(max-width:760px){.proj-gallery--reels,.proj-gallery--stills{grid-template-columns:repeat(2,1fr);}}
@media(max-width:460px){.proj-gallery--reels,.proj-gallery--stills{grid-template-columns:1fr;}}

/* structured gallery — uniform grid, equal cells line up in neat rows */
.proj-gallery--grid{column-count:auto;column-gap:0;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.proj-gallery--grid figure{margin:0;break-inside:auto;}
.proj-gallery--grid img{width:100%;height:100%;aspect-ratio:4/5;object-fit:cover;display:block;}
@media(max-width:900px){.proj-gallery--grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.proj-gallery--grid{grid-template-columns:1fr;}}

/* gallery — uniform side-by-side grid (Shortstache style), 2 across */
.proj-gallery--lg{column-count:auto;column-gap:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}

/* scroll reveal for ALL project gallery images (personal + every project page) — videos stay static */
.proj-gallery figure{opacity:0;transform:translateY(34px);
  transition:opacity 1.4s cubic-bezier(.16,.7,.18,1), transform 1.4s cubic-bezier(.16,.7,.18,1);}
.proj-gallery figure.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){
  .proj-gallery figure{transition:opacity .4s ease;transform:none;}
}
.proj-gallery--lg figure{margin:0;break-inside:auto;}
.proj-gallery--lg img{width:100%;height:100%;aspect-ratio:16/9;object-fit:cover;display:block;}
@media(max-width:600px){.proj-gallery--lg{grid-template-columns:1fr;}}

/* Oaklands — paragraph beside the larger clip (reuses .fs-entry grid + directional reveal) */
.oak-feature .fs-entry__media{display:block;}
.oak-feature .fs-entry__media video{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:2px;background:var(--dark);}
/* Oaklands supporting clips — equal-height row keeps the mixed orientation tidy */
.oak-clips{column-count:auto;column-gap:0;max-width:1100px;margin:18px auto clamp(46px,8vh,80px);padding:0 30px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;}
.oak-clips figure{margin:0;}
.oak-clips video{height:clamp(240px,34vw,380px);width:auto;max-width:100%;display:block;border-radius:2px;background:var(--dark);}
@media(max-width:600px){.oak-clips video{height:auto;width:100%;}}

/* category landing intro (Professional / Personal) */
.cat-intro{max-width:1100px;margin:0 auto;padding:clamp(36px,6vh,64px) 30px clamp(10px,2vh,20px);text-align:center;}
.cat-intro h1{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(30px,5vw,52px);color:var(--ink);line-height:1.05;margin-bottom:12px;}
.cat-intro p{font-size:14px;line-height:1.7;color:var(--muted);max-width:540px;margin:0 auto;}

/* shorter hero variant (50% of the standard height, still full width) */
.proj-hero--short img{height:clamp(170px,35vh,360px);}

/* inset hero — small gap so the image doesn't touch the edges */
.proj-hero--inset{padding:30px 30px 0;}

/* feature video — aligned to the content column */
.proj-feature{max-width:1100px;margin:40px auto;padding:0 30px;}
.proj-feature video{width:100%;display:block;border-radius:2px;}
.proj-feature .pf-placeholder{width:100%;aspect-ratio:16/9;
  background:linear-gradient(135deg,#9c958a,#6f685e);
  display:flex;align-items:center;justify-content:center;
  color:#fff;letter-spacing:2px;font-size:12px;text-transform:uppercase;}

/* footer */
.site-footer{padding:50px 30px;text-align:center;border-top:1px solid rgba(47,47,43,.12);margin-top:20px;}
.site-footer .logo{font-family:"Cormorant Garamond",serif;font-size:26px;display:block;margin-bottom:12px;
  color:var(--ink);text-decoration:none;}
.site-footer .copy{font-size:11px;letter-spacing:1px;color:var(--muted);}

/* creative flow — phone showcase */
.cf-showcase{background:var(--dark);padding:clamp(60px,12vh,120px) 30px;overflow:hidden;}
.cf-stage{max-width:1100px;margin:0 auto;display:flex;justify-content:center;align-items:center;
  gap:clamp(16px,4vw,54px);perspective:1600px;}

/* explanatory notes flanking the phones */
.cf-note{flex:1 1 0;max-width:230px;color:#cfcec6;}
.cf-note__label{display:block;font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:#8a8a82;margin-bottom:10px;}
.cf-note p{font-size:14px;line-height:1.7;}
.cf-note--left{text-align:right;}
.cf-note--right{text-align:left;}
@media(max-width:800px){
  .cf-stage{flex-wrap:wrap;}
  .cf-note{flex:1 1 100%;max-width:420px;margin:0 auto;text-align:center;order:3;}
  .cf-note--left{text-align:center;}
}

/* scroll-reveal: slides in from the sides */
.cf-reveal{flex:0 0 auto;opacity:0;transition:opacity 1s ease,transform 1s ease;}
.cf-reveal--left{transform:translateX(-110px);}
.cf-reveal--right{transform:translateX(110px);}
.cf-reveal.in{opacity:1;transform:translateX(0);}

/* continuous float */
.cf-float{animation:cf-float 5.5s ease-in-out infinite;}
.cf-float--b{animation-delay:-2.75s;}
@keyframes cf-float{0%,100%{transform:translateY(0);}50%{transform:translateY(-16px);}}

.cf-phone{position:relative;width:clamp(128px,17vw,195px);aspect-ratio:9/19.5;
  background:linear-gradient(150deg,#3a3a35,#1f1f1c);border-radius:32px;padding:7px;
  box-shadow:0 30px 60px rgba(0,0,0,.55),inset 0 0 0 1px rgba(255,255,255,.08);
  transition:transform .5s ease;}
.cf-phone .screen{position:relative;width:100%;height:100%;border-radius:26px;overflow:hidden;background:#000;}
.cf-phone .screen video{width:100%;height:100%;object-fit:cover;display:block;}
.cf-phone .island{position:absolute;top:9px;left:50%;transform:translateX(-50%);
  width:32%;height:11px;background:#000;border-radius:9px;z-index:2;}
.cf-phone--a{transform:rotate(-7deg) translateY(20px);}
.cf-phone--b{transform:rotate(6deg) translateY(-20px);}
.cf-phone--a:hover{transform:rotate(-3deg) translateY(8px);}
.cf-phone--b:hover{transform:rotate(3deg) translateY(-8px);}
@media(max-width:600px){
  .cf-stage{gap:10px;}
  .cf-phone--a{transform:rotate(-4deg) translateY(12px);}
  .cf-phone--b{transform:rotate(4deg) translateY(-12px);}
}
@media(prefers-reduced-motion:reduce){
  .cf-float{animation:none;}
  .cf-reveal{transition:opacity .4s ease;}
  .cf-reveal--left,.cf-reveal--right{transform:none;}
}

/* creative flow — editorial entries (curated project index) */
.cf-entries{max-width:1100px;margin:0 auto;padding:20px 30px;}
.cf-entry{margin:84px 0;}
.cf-entry__label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.cf-entry__title{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:clamp(26px,4vw,40px);
  line-height:1.1;margin-bottom:12px;}
.cf-entry__text{font-size:15px;line-height:1.7;color:var(--ink);max-width:520px;}
/* split entries: head + media side by side, alternating */
.cf-entry--split{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(24px,4vw,56px);align-items:center;}
.cf-entry--split.flip .cf-entry__head{order:2;}
@media(max-width:760px){
  .cf-entry--split{grid-template-columns:1fr;gap:20px;}
  .cf-entry--split.flip .cf-entry__head{order:0;}
}
/* phone frame inside an entry (upright, centred — reuses .cf-phone) */
.cf-phone--still{margin:0 auto;width:clamp(215px,26vw,280px);transform:none;border-radius:38px;padding:9px;
  box-shadow:0 26px 60px rgba(0,0,0,.22), 0 4px 14px rgba(0,0,0,.14), inset 0 0 0 1px rgba(255,255,255,.10);}
.cf-phone--still .screen{border-radius:30px;}
.cf-phone--still video{cursor:pointer;}
/* media frames */
.cf-vert{margin:0 auto;width:min(300px,80%);aspect-ratio:9/16;border-radius:14px;overflow:hidden;
  background:var(--dark);box-shadow:0 20px 45px rgba(0,0,0,.28);}
.cf-vert video,.cf-vert img{width:100%;height:100%;object-fit:cover;display:block;}
.cf-feature16{width:100%;aspect-ratio:16/9;border-radius:2px;overflow:hidden;}
.cf-feature16 video,.cf-feature16 img{width:100%;height:100%;object-fit:cover;display:block;}
/* grids */
.cf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px;}
.cf-grid--imgs{grid-template-columns:repeat(3,1fr);}
.cf-grid figure{margin:0;}
.cf-grid .cell{aspect-ratio:4/5;border-radius:2px;overflow:hidden;}
.cf-grid--clips .cell{aspect-ratio:9/16;}
.cf-grid .cell video,.cf-grid .cell img{width:100%;height:100%;object-fit:cover;display:block;}
@media(max-width:760px){.cf-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:460px){.cf-grid{grid-template-columns:1fr;}}
/* placeholder fill (until real media is dropped in) */
.cf-ph{width:100%;height:100%;min-height:100%;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:14px;background:linear-gradient(135deg,#9c958a,#6f685e);
  color:#fff;letter-spacing:1.5px;font-size:11px;text-transform:uppercase;line-height:1.5;}

/* ---- scroll reveal: entries fade + slide in as they enter view ---- */
.cf-entry .cf-entry__head,
.cf-entry .cf-entry__media,
.cf-entry > .cf-feature16,
.cf-entry .cf-grid figure{
  opacity:0;transform:translateY(38px);
  transition:opacity 1.4s cubic-bezier(.16,.7,.18,1) .05s, transform 1.4s cubic-bezier(.16,.7,.18,1) .05s;
}
/* split entries come from the sides (matches the alternating rhythm) */
.cf-entry--split .cf-entry__head{transform:translateX(-46px);}
.cf-entry--split .cf-entry__media{transform:translateX(46px);}
.cf-entry--split.flip .cf-entry__head{transform:translateX(46px);}
.cf-entry--split.flip .cf-entry__media{transform:translateX(-46px);}
/* revealed state */
.cf-entry.in .cf-entry__head,
.cf-entry.in .cf-entry__media,
.cf-entry.in > .cf-feature16,
.cf-entry.in .cf-grid figure{opacity:1;transform:none;}
/* staggered grid cells */
.cf-entry.in .cf-grid figure:nth-child(2){transition-delay:.08s;}
.cf-entry.in .cf-grid figure:nth-child(3){transition-delay:.16s;}
.cf-entry.in .cf-grid figure:nth-child(4){transition-delay:.24s;}
.cf-entry.in .cf-grid figure:nth-child(5){transition-delay:.32s;}
.cf-entry.in .cf-grid figure:nth-child(6){transition-delay:.40s;}

/* ---- gentle parallax on the media inside frames (skips click-to-play videos with controls) ---- */
.cf-feature16 video:not([controls]),.cf-feature16 img,
.cf-vert video:not([controls]),.cf-vert img{transform:scale(1.12);will-change:transform;}

@media(prefers-reduced-motion:reduce){
  .cf-entry .cf-entry__head,.cf-entry .cf-entry__media,
  .cf-entry > .cf-feature16,.cf-entry .cf-grid figure{transition:opacity .4s ease;transform:none;}
  .cf-feature16 video,.cf-feature16 img,.cf-vert video,.cf-vert img{transform:none;}
}
