/* ============================================================
   VILLA LEIEPARK — Premium lead-gen landing (compact)
   Mobile-first. Restraint over decoration.
   ============================================================ */

:root{
  --bone:#f4efe6; --bone-2:#ece4d6; --paper:#faf7f1;
  --ink:#211f1a; --ink-soft:#423e35; --muted:#7d776a; --line:#d8cfbf;
  --olive:#2c3023; --olive-2:#373c2d; --brass:#9a8253; --brass-soft:#c2a972; --white:#fff;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Jost", system-ui, -apple-system, sans-serif;
  --maxw:1240px; --gut:clamp(20px,6vw,80px); --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }
body{margin:0; background:var(--bone); color:var(--ink); font-family:var(--sans); font-weight:400; line-height:1.7; font-size:16px; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden}
img,video{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.sprite{position:absolute}

.wrap{max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut)}
.wrap-narrow{max-width:740px; margin:0 auto; padding-inline:var(--gut)}
.section{padding-block:clamp(64px,11vw,120px)}

/* ---------- type ---------- */
.kicker{font-family:var(--sans); font-weight:500; font-size:.72rem; letter-spacing:.34em; text-transform:uppercase; color:var(--brass); margin:0 0 1.3rem}
.kicker-light{color:var(--brass-soft); text-shadow:0 1px 12px rgba(0,0,0,.45)}
.section-title{font-family:var(--serif); font-weight:400; font-size:clamp(2.1rem,7vw,3.3rem); line-height:1.08; letter-spacing:.005em; margin:0}
em{font-style:italic}

.emblem-mark{width:78px; height:78px; color:var(--brass); display:block; margin:0 auto 1.8rem}
.emblem-light{color:var(--brass-soft)}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; font-family:var(--sans); font-weight:500; font-size:.76rem; letter-spacing:.18em; text-transform:uppercase; padding:1.05em 2.1em; border:1px solid transparent; cursor:pointer; transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease); white-space:nowrap}
.btn-primary{background:var(--olive); color:var(--bone)}
.btn-primary:hover{background:var(--ink); transform:translateY(-2px)}
.btn-line-light{border-color:rgba(244,239,230,.55); color:var(--bone)}
.btn-line-light:hover{background:var(--bone); color:var(--ink); border-color:var(--bone); transform:translateY(-2px)}
.btn-ghost{border-color:var(--line); color:var(--ink); padding:.85em 1.4em}
.btn-ghost:hover{background:var(--ink); color:var(--bone); border-color:var(--ink)}
.btn-block{width:100%}

.scroll-progress{position:fixed; top:0; left:0; height:2px; width:0; background:var(--brass); z-index:200; transition:width .1s linear}

.grain{position:absolute; inset:0; pointer-events:none; z-index:0; opacity:.07; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}

/* ============================================================ HEADER */
.site-header{position:fixed; top:0; left:0; right:0; z-index:100; transition:background .5s var(--ease), backdrop-filter .5s var(--ease), border-color .5s var(--ease); border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(244,239,230,.94); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom-color:var(--line)}
.header-inner{max-width:var(--maxw); margin:0 auto; padding:1.05rem var(--gut); display:flex; align-items:center; justify-content:space-between; gap:1rem}
.wordmark{display:flex; flex-direction:column; line-height:1; color:var(--bone); transition:color .5s var(--ease); text-shadow:0 1px 16px rgba(0,0,0,.35)}
.scrolled .wordmark{color:var(--ink); text-shadow:none}
.wordmark-main{font-family:var(--serif); font-size:1.4rem; font-weight:500; letter-spacing:.02em}
.wordmark-sub{font-family:var(--sans); font-size:.58rem; letter-spacing:.32em; text-transform:uppercase; margin-top:.35em; opacity:.85}
.header-nav{display:none; gap:2.2rem}
.header-nav a{font-size:.74rem; font-weight:500; letter-spacing:.16em; text-transform:uppercase; color:var(--bone); position:relative; padding-bottom:3px; text-shadow:0 1px 14px rgba(0,0,0,.4); transition:color .5s var(--ease)}
.scrolled .header-nav a{color:var(--ink-soft); text-shadow:none}
.header-nav a::after{content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:currentColor; transition:width .4s var(--ease)}
.header-nav a:hover::after{width:100%}
.header-cta{color:var(--bone); border-color:rgba(244,239,230,.5)}
.header-cta:hover{background:var(--bone); color:var(--ink); border-color:var(--bone)}
.scrolled .header-cta{color:var(--ink); border-color:var(--line)}
.scrolled .header-cta:hover{background:var(--ink); color:var(--bone); border-color:var(--ink)}

/* ============================================================ HERO */
.hero{position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:flex-end; padding:0 var(--gut) 0; overflow:hidden}
.hero-media{position:absolute; inset:0; z-index:-2}
.hero-video{width:100%; height:100%; object-fit:cover; filter:brightness(.62) contrast(1.06) saturate(1.04)}
.hero-scrim{position:absolute; inset:0; background:
  linear-gradient(180deg, rgba(18,16,12,.55) 0%, rgba(18,16,12,.12) 26%, rgba(18,16,12,.2) 55%, rgba(18,16,12,.82) 100%),
  radial-gradient(120% 90% at 15% 80%, rgba(18,16,12,.5) 0%, transparent 55%);}
.hero-media .grain{z-index:1}
.hero-content{position:relative; z-index:2; max-width:780px; color:var(--bone)}
.hero-title{font-family:var(--serif); font-weight:300; font-size:clamp(3.4rem,15vw,7.5rem); line-height:.96; letter-spacing:.01em; margin:.2em 0 .42em; text-shadow:0 2px 50px rgba(0,0,0,.5)}
.hero-title em{font-weight:400}
.hero-lede{font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(1.3rem,4.7vw,1.75rem); line-height:1.45; max-width:30ch; color:#fbf8f2; margin:0 0 2.2em; text-shadow:0 2px 26px rgba(0,0,0,.6)}
.hero-actions{display:flex; flex-wrap:wrap; gap:.9rem}
.hero-actions .btn{flex:0 0 auto}
.hero-stats{position:relative; z-index:2; list-style:none; margin:1.5rem calc(-1 * var(--gut)) 0; display:grid; grid-template-columns:repeat(2,1fr); border-top:1px solid rgba(244,239,230,.22); background:linear-gradient(180deg, transparent, rgba(16,14,10,.55))}
.hero-stats li{padding:1.15rem var(--gut); color:var(--bone); border-bottom:1px solid rgba(244,239,230,.14)}
.hero-stats li:nth-child(odd){border-right:1px solid rgba(244,239,230,.14)}
.hero-stats span{display:block; font-family:var(--serif); font-size:1.8rem; line-height:1; font-weight:500; text-shadow:0 1px 18px rgba(0,0,0,.4)}
.hero-stats small{display:block; font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(244,239,230,.72); margin-top:.5em}
.scroll-cue{position:absolute; left:50%; bottom:128px; transform:translateX(-50%); z-index:3; display:none}
.scroll-cue span{display:block; width:1px; height:54px; background:linear-gradient(var(--bone),transparent); position:relative; overflow:hidden}
.scroll-cue span::after{content:""; position:absolute; top:0; left:0; width:100%; height:40%; background:var(--bone); animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-100%)}60%,100%{transform:translateY(260%)}}

/* ============================================================ VILLA (intro + specs) */
.villa{background:var(--paper)}
.villa-intro{text-align:center; margin-bottom:clamp(44px,7vw,72px)}
.manifesto{font-family:var(--serif); font-weight:400; font-size:clamp(1.5rem,5.2vw,2.35rem); line-height:1.4; margin:0; color:var(--ink)}
.manifesto em{color:var(--ink-soft)}
.exclusivity{font-family:var(--serif); font-style:italic; font-size:clamp(1.05rem,3.4vw,1.3rem); color:var(--brass); margin:1.6rem 0 0; line-height:1.5}
.spec-grid{margin:0; display:grid; grid-template-columns:repeat(2,1fr); border-top:1px solid var(--line); border-left:1px solid var(--line)}
.spec{border-right:1px solid var(--line); border-bottom:1px solid var(--line); padding:1.7rem 1.3rem}
.spec-ic{width:26px; height:26px; fill:none; stroke:var(--brass); stroke-width:1.3; stroke-linecap:round; stroke-linejoin:round; display:block; margin-bottom:1rem}
.spec dt{font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:.5rem}
.spec dd{margin:0; font-family:var(--serif); font-size:clamp(1.4rem,5vw,1.9rem); font-weight:500; line-height:1}

/* ============================================================ PEEK (compacte grid) */
.peek{background:var(--bone); padding-block:clamp(56px,9vw,96px)}
.peek-head{text-align:center; margin-bottom:clamp(28px,4vw,44px)}
.peek-head .kicker{margin-bottom:.6rem}
.peek-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.peek-item{position:relative; overflow:hidden; margin:0; aspect-ratio:1/1}
.peek-item.peek-tall{grid-column:1 / -1; aspect-ratio:16/9}
.peek-item img{width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease)}
.peek-item:hover img{transform:scale(1.05)}
.peek-item figcaption{position:absolute; left:0; right:0; bottom:0; padding:1.4rem 1.2rem .9rem; font-family:var(--serif); font-style:italic; font-size:1.05rem; color:var(--bone); background:linear-gradient(180deg, transparent, rgba(16,14,10,.72)); text-shadow:0 1px 12px rgba(0,0,0,.5)}

/* ============================================================ FOTOGALERIJ */
.photogrid-section{background:var(--ink)}
.photogrid-wrap{position:relative; overflow:hidden; transition:max-height 1.1s var(--ease)}
.photogrid{display:grid; grid-template-columns:repeat(2,1fr); gap:2px}
.pg-item{margin:0; overflow:hidden; aspect-ratio:1/1; position:relative}
.pg-item img{width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease), filter .6s var(--ease); filter:brightness(.88) saturate(.9)}
.pg-item:hover img{transform:scale(1.06); filter:brightness(1) saturate(1)}
.photogrid-fade{position:absolute; left:0; right:0; bottom:0; height:160px; background:linear-gradient(to bottom, transparent, var(--ink)); pointer-events:none; transition:opacity .6s var(--ease)}
.gallery-toggle-wrap{text-align:center; padding:1.4rem var(--gut) 0}
.gallery-toggle{background:none; border:1px solid rgba(244,239,230,.28); color:rgba(244,239,230,.75); font-family:var(--sans); font-size:.72rem; font-weight:500; letter-spacing:.22em; text-transform:uppercase; padding:.9em 2em; cursor:pointer; display:inline-flex; align-items:center; gap:.75rem; transition:border-color .3s, color .3s}
.gallery-toggle:hover{border-color:rgba(244,239,230,.65); color:var(--bone)}
.gallery-toggle svg{transition:transform .55s var(--ease); flex-shrink:0}
.gallery-toggle[aria-expanded="true"] svg{transform:rotate(180deg)}
.photogrid-cta{padding:clamp(48px,8vw,88px) var(--gut); text-align:center}
.photogrid-lede{font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,4vw,1.7rem); color:#e0d9cc; margin:0 0 1.8rem; line-height:1.4}

/* ============================================================ BUITEN */
.outside{background:var(--olive); color:var(--bone)}
.outside-hero{position:relative; margin:0; overflow:hidden}
.outside-hero img{width:100%; height:92vw; max-height:680px; object-fit:cover; transform:scale(1.15); will-change:transform}
.outside-overlay{position:absolute; inset:0; z-index:1; display:flex; flex-direction:column; justify-content:flex-end; padding:var(--gut); background:linear-gradient(180deg, transparent 35%, rgba(16,14,10,.72))}
.outside-title{font-family:var(--serif); font-weight:300; font-size:clamp(2rem,8vw,3.2rem); line-height:1.05; margin:0; color:var(--bone); text-shadow:0 2px 24px rgba(0,0,0,.5)}
.outside-body{padding-block:clamp(48px,8vw,84px)}
.outside-lede{font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(1.3rem,4.4vw,1.7rem); line-height:1.5; max-width:46ch; margin:0 0 clamp(36px,5vw,48px); color:#f3eee4}
.outside-features{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid rgba(244,239,230,.2); border-left:1px solid rgba(244,239,230,.2)}
.outside-features li{border-right:1px solid rgba(244,239,230,.2); border-bottom:1px solid rgba(244,239,230,.2); padding:1.5rem 1.1rem; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(244,239,230,.68)}
.feat-ic{width:24px; height:24px; fill:none; stroke:var(--brass-soft); stroke-width:1.3; stroke-linecap:round; stroke-linejoin:round; display:block; margin-bottom:.9rem}
.outside-features span{display:block; font-family:var(--serif); font-size:1.35rem; letter-spacing:.01em; text-transform:none; color:var(--bone); margin-bottom:.35rem}

.outside-garden{margin:0; overflow:hidden; position:relative}
.outside-garden img{width:100%; height:75vw; max-height:600px; object-fit:cover; object-position:center 40%; transform:scale(1.15); will-change:transform}
.outside-garden-fade{position:absolute; left:0; right:0; bottom:0; height:65%; background:linear-gradient(to bottom, transparent 0%, rgba(16,14,10,.55) 50%, rgba(16,14,10,.92) 100%); pointer-events:none; z-index:2}

/* ============================================================ CTA BAND */
.cta-band{position:relative; overflow:hidden; text-align:center; color:var(--bone); padding-block:clamp(80px,14vw,150px); padding-inline:var(--gut)}
.cta-band-media{position:absolute; inset:0; z-index:0}
.cta-band-media img{width:100%; height:100%; object-fit:cover; transform:scale(1.15); will-change:transform}
.cta-band-scrim{position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(16,14,10,.64), rgba(16,14,10,.74))}
.cta-band-inner{position:relative; z-index:2; max-width:720px; margin:0 auto}
.cta-band-title{font-family:var(--serif); font-weight:300; font-size:clamp(1.85rem,6vw,2.9rem); line-height:1.16; margin:0 0 2rem; color:var(--bone); text-shadow:0 2px 30px rgba(0,0,0,.5)}

/* ============================================================ LIGGING + MAP */
.location{background:var(--bone)}
.location-inner{display:grid; gap:clamp(36px,6vw,64px)}
.location .section-title{margin:.3rem 0 1.3rem}
.location-text{font-size:1.05rem; line-height:1.8; color:var(--ink-soft); margin:0 0 2rem; max-width:50ch}
.location-points{list-style:none; margin:0 0 2rem; padding:0; border-top:1px solid var(--line)}
.location-points li{border-bottom:1px solid var(--line); padding:1.25rem 0; display:grid; grid-template-columns:auto 1fr; column-gap:1.1rem; align-items:center; font-size:.95rem; color:var(--ink-soft)}
.loc-ic{grid-row:1/3; width:25px; height:25px; fill:none; stroke:var(--brass); stroke-width:1.3; stroke-linecap:round; stroke-linejoin:round}
.location-points span{font-family:var(--serif); font-size:1.45rem; color:var(--ink); font-weight:500; line-height:1.1}
.location-addr{display:flex; align-items:center; gap:.7rem; font-family:var(--serif); font-size:1.2rem; color:var(--ink); margin:0}
.loc-ic-inline{width:22px; height:22px; flex:0 0 auto}
.location-map{margin:0; overflow:hidden; border:1px solid var(--line); min-height:300px; background:var(--bone-2)}
.location-map iframe{width:100%; height:100%; min-height:300px; border:0; display:block; filter:grayscale(.35) contrast(.96) sepia(.06)}

/* ============================================================ CONTACT */
.contact{background:var(--olive-2); color:var(--bone); padding-block:clamp(64px,11vw,120px)}
.contact-grid{max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); display:grid; gap:clamp(40px,6vw,72px)}
.contact-intro .emblem-mark{margin:0 0 1.6rem}
.contact-title{font-family:var(--serif); font-weight:300; font-size:clamp(2.1rem,7.5vw,3.2rem); line-height:1.06; margin:0 0 1.1rem; color:var(--bone)}
.contact-lede{font-size:1.04rem; line-height:1.75; color:#e9e3d6; max-width:42ch; margin:0 0 1.8rem}
.contact-trust{list-style:none; margin:0 0 2rem; padding:0; display:flex; flex-direction:column; gap:.7rem}
.contact-trust li{position:relative; padding-left:1.6rem; font-size:.95rem; color:#efe9dc}
.contact-trust li::before{content:""; position:absolute; left:0; top:.5em; width:7px; height:7px; border:1px solid var(--brass-soft); transform:rotate(45deg)}
.contact-direct{font-size:.95rem; color:#d8d1c2; line-height:1.6}
.contact-direct a{color:var(--brass-soft); border-bottom:1px solid rgba(194,169,114,.45); padding-bottom:1px}
.contact-form-wrap{position:relative; background:var(--bone); color:var(--ink); padding:clamp(28px,6vw,44px)}
.lead-form .hp{position:absolute; left:-9999px; width:1px; height:1px; opacity:0}
.field{margin-bottom:1.1rem}
.field-row{display:grid; gap:1.1rem}
.field label{display:block; font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:.55rem}
.field label .opt{text-transform:none; letter-spacing:0; color:var(--line)}
.field input, .field textarea{width:100%; font-family:var(--sans); font-weight:400; font-size:1rem; color:var(--ink); background:transparent; border:0; border-bottom:1px solid var(--line); padding:.7rem 0; transition:border-color .3s var(--ease)}
.field input::placeholder, .field textarea::placeholder{color:#b3a892}
.field input:focus, .field textarea:focus{outline:none; border-bottom-color:var(--olive)}
.field textarea{resize:vertical; min-height:3rem}
.consent{display:flex; gap:.7rem; align-items:flex-start; margin:1.4rem 0 1.6rem; font-size:.8rem; line-height:1.55; color:var(--ink-soft); cursor:pointer}
.consent input{margin-top:.2rem; accent-color:var(--olive); width:16px; height:16px; flex:0 0 auto}
.field.invalid input{border-bottom-color:#a4533f}
.consent.invalid span{color:#a4533f}
.form-note{margin:1rem 0 0; font-size:.82rem; min-height:1.2em; color:#a4533f}
.form-success{position:absolute; inset:0; background:var(--bone); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:2rem; animation:fadeIn .6s var(--ease)}
.form-success[hidden]{display:none}
.success-emblem{width:68px; height:68px; margin:0 auto 1.4rem}
.form-success h3{font-family:var(--serif); font-weight:400; font-size:1.8rem; margin:0 0 .7rem}
.form-success p{margin:0; color:var(--ink-soft); max-width:34ch; line-height:1.7}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ============================================================ FOOTER */
.site-footer{background:var(--ink); color:rgba(244,239,230,.62); padding-block:clamp(40px,6vw,60px); border-top:1px solid rgba(244,239,230,.12)}
.footer-inner{display:flex; flex-direction:column; gap:1.6rem}
.footer-brand{display:flex; flex-direction:column; gap:.5rem}
.footer-brand .wordmark-main{font-family:var(--serif); font-size:1.5rem; color:var(--bone); font-weight:500}
.footer-addr{font-size:.85rem; letter-spacing:.04em}
.footer-meta a{color:var(--brass-soft); font-size:.95rem; border-bottom:1px solid rgba(194,169,114,.35); padding-bottom:1px}
.footer-fine{font-size:.72rem; line-height:1.7; margin:1rem 0 0; color:rgba(244,239,230,.42)}

/* ============================================================ STICKY MOBILE CTA */
.sticky-cta{position:fixed; left:0; right:0; bottom:0; z-index:90; background:var(--olive); color:var(--bone); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:.85rem 1rem calc(.85rem + env(safe-area-inset-bottom,0)); text-align:center; border-top:1px solid var(--brass); transform:translateY(100%); transition:transform .5s var(--ease); box-shadow:0 -10px 30px rgba(16,14,10,.3)}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta span{font-size:.82rem; font-weight:500; letter-spacing:.16em; text-transform:uppercase}
.sticky-cta em{font-style:normal; font-size:.66rem; letter-spacing:.1em; color:var(--brass-soft); margin-top:.25em}

/* ============================================================ REVEAL */
.reveal{opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease)}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .scroll-cue span::after{animation:none}
  [data-parallax]{transform:none !important}
}

/* ============================================================ DESKTOP */
@media (min-width:760px){
  body{font-size:17px}
  .header-nav{display:flex}
  .scroll-cue{display:block}
  .sticky-cta{display:none}

  .hero{padding-inline:0; padding-bottom:clamp(120px,16vh,160px)}
  .hero-content{width:100%; max-width:var(--maxw); padding-inline:var(--gut); margin:0 auto}
  .hero-stats{position:absolute; left:0; right:0; bottom:0; margin:0; grid-template-columns:repeat(4,1fr)}
  .hero-stats li{border-right:1px solid rgba(244,239,230,.14) !important}
  .hero-stats li:last-child{border-right:0 !important}

  .spec-grid{grid-template-columns:repeat(4,1fr)}
  .photogrid{grid-template-columns:repeat(4,1fr)}

  .peek-grid{grid-template-columns:repeat(3,1fr); grid-template-rows:repeat(2, clamp(220px,26vw,330px)); gap:16px}
  .peek-item{aspect-ratio:auto; height:100%}
  .peek-item.peek-tall{grid-column:1; grid-row:1 / span 2; aspect-ratio:auto}

  .outside-hero img{height:60vh; max-height:720px}
  .outside-body{display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:center}
  .outside-lede{margin-bottom:0}

  .location-inner{grid-template-columns:1fr 1fr; align-items:center; gap:clamp(40px,5vw,72px)}
  .location-map{height:100%; min-height:440px}
  .location-map iframe{min-height:440px}

  .contact-grid{grid-template-columns:1fr 1fr; align-items:start}
  .field-row{grid-template-columns:1fr 1fr}
  .footer-inner{flex-direction:row; justify-content:space-between; align-items:flex-end}
  .footer-meta{text-align:right}
}

@media (min-width:1100px){
  .hero-title{font-size:clamp(5rem,9vw,8rem)}
  .photogrid{grid-template-columns:repeat(5,1fr)}
}
