/* ===========================================================
   Lyndsey Quintana Photography — shared styles
   Charcoal / Ivory / Sage Mint / Antique Gold
   Type: Cormorant Garamond (display) + Jost (sans)
   =========================================================== */

:root{
  --charcoal:#1A1A1A;
  --charcoal-2:#222221;
  --charcoal-soft:#2a2a28;
  --ivory:#F7F4EF;
  --ivory-2:#EFEAE1;
  --bone:#E8E2D7;
  --mint:#A8D5C4;        /* sage mint, primary accent */
  --mint-bright:#7EE8C0; /* logo aqua, sparing */
  --gold:#C9A86A;        /* antique gold, fine lines */
  --ink:#1A1A1A;
  --ink-70:rgba(26,26,26,.70);
  --ink-55:rgba(26,26,26,.55);
  --ink-40:rgba(26,26,26,.40);
  --paper-70:rgba(247,244,239,.74);
  --paper-50:rgba(247,244,239,.52);
  --paper-30:rgba(247,244,239,.32);
  --line-ink:rgba(26,26,26,.14);
  --line-paper:rgba(247,244,239,.16);

  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Jost', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --maxw:1320px;
  --gut:clamp(22px,5vw,80px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--ivory);
  color:var(--ink);
  font-weight:300;
  font-size:17px;
  line-height:1.75;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

/* ---------- Type ---------- */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.04;
  letter-spacing:.005em;
  margin:0;
  text-wrap:balance;
}
h1{font-size:clamp(2.7rem,6.6vw,6rem);}
h2{font-size:clamp(2.1rem,4.6vw,4rem);}
h3{font-size:clamp(1.5rem,2.4vw,2.3rem);}
em,.ital{font-style:italic;}
p{margin:0 0 1.1em;}
p:last-child{margin-bottom:0;}

.eyebrow{
  font-family:var(--sans);
  font-weight:400;
  font-size:.72rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--ink-55);
  margin:0 0 1.6em;
  display:inline-block;
}
.eyebrow--paper{color:var(--paper-50);}
.eyebrow .dot{color:var(--gold);}

.lede{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(1.4rem,2.4vw,2rem);
  line-height:1.45;
  letter-spacing:.005em;
}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}
section{position:relative;}
.section{padding-block:clamp(70px,11vw,160px);}
.section--tight{padding-block:clamp(54px,8vw,110px);}
.dark{background:var(--charcoal);color:var(--ivory);}
.dark .eyebrow{color:var(--paper-50);}
.dark .lede{color:var(--ivory);}
.ivory{background:var(--ivory);}
.ivory-2{background:var(--ivory-2);}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--mint);--fg:var(--charcoal);
  display:inline-flex;align-items:center;gap:.75em;
  font-family:var(--sans);font-weight:400;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  padding:1.15em 2.3em;
  background:var(--bg);color:var(--fg);
  border:1px solid var(--bg);
  border-radius:2px;
  position:relative;overflow:hidden;
  transition:color .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease);
  min-height:52px;
}
.btn::after{
  content:"";position:absolute;inset:0;background:var(--charcoal);
  transform:translateY(101%);transition:transform .5s var(--ease);z-index:0;
}
.btn span{position:relative;z-index:1;}
.btn:hover{color:var(--ivory);border-color:var(--charcoal);}
.btn:hover::after{transform:translateY(0);}
.btn--ghost{
  --bg:transparent;--fg:var(--charcoal);border-color:rgba(26,26,26,.32);
}
.btn--ghost::after{background:var(--charcoal);}
.btn--ghost:hover{color:var(--ivory);}
.dark .btn--ghost{--fg:var(--ivory);border-color:var(--line-paper);}
.dark .btn--ghost::after{background:var(--mint);}
.dark .btn--ghost:hover{color:var(--charcoal);}

/* animated underline link */
.ulink{
  position:relative;display:inline-flex;align-items:center;gap:.6em;white-space:nowrap;
  font-family:var(--sans);font-weight:400;font-size:.8rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ink);
  padding-bottom:.45em;
}
.ulink .ar{transition:transform .45s var(--ease);}
.ulink::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:currentColor;opacity:.28;
  transform:scaleX(1);transform-origin:left;
}
.ulink::before{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .55s var(--ease);
}
.ulink:hover::before{transform:scaleX(1);}
.ulink:hover .ar{transform:translateX(5px);}
.dark .ulink{color:var(--ivory);}
.dark .ulink::before{background:var(--mint);}

/* ---------- Header / Nav ---------- */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:120;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(16px,2.2vw,30px) var(--gut);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
}
.nav__logo{position:relative;display:block;width:104px;height:30px;}
.nav__logo img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:left center;transition:opacity .45s var(--ease);}
.nav__links{
  display:flex;align-items:center;gap:clamp(20px,2.4vw,40px);
}
.nav__links a:not(.btn){
  font-family:var(--sans);font-weight:400;font-size:.74rem;
  letter-spacing:.2em;text-transform:uppercase;
  position:relative;padding:4px 0;color:var(--paper-70);
  transition:color .4s var(--ease);
}
.nav__links a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:100%;
  background:var(--mint);transform:scaleX(0);transform-origin:center;
  transition:transform .45s var(--ease);
}
.nav__links a:not(.btn):hover{color:var(--ivory);}
.nav__links a:not(.btn):hover::after,
.nav__links a.is-active::after{transform:scaleX(1);}
.nav__links a.is-active{color:var(--ivory);}
.nav .btn{padding:.85em 1.7em;min-height:0;font-size:.7rem;}

/* transparent-over-hero (default) shows white logo + paper links */
.nav--solid{
  background:var(--ivory);box-shadow:0 1px 0 var(--line-ink);
  padding-top:clamp(12px,1.6vw,18px);padding-bottom:clamp(12px,1.6vw,18px);
}
.nav--solid .nav__links a:not(.btn){color:var(--ink-70);}
.nav--solid .nav__links a:not(.btn):hover,
.nav--solid .nav__links a.is-active{color:var(--ink);}
.nav .lb{opacity:0;}
.nav .lw{opacity:1;}
.nav--solid .lb{opacity:1;}
.nav--solid .lw{opacity:0;}

.nav__toggle{
  display:none;flex-direction:column;gap:6px;width:34px;height:24px;
  background:none;border:0;padding:0;justify-content:center;
}
.nav__toggle span{display:block;height:1.5px;width:100%;background:var(--ivory);transition:.4s var(--ease);}
.nav--solid .nav__toggle span{background:var(--charcoal);}

/* mobile overlay */
.menu{
  position:fixed;inset:0;z-index:130;background:var(--charcoal);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  gap:6px;opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity .55s var(--ease),transform .55s var(--ease),visibility .55s;
}
.menu.open{opacity:1;visibility:visible;transform:none;}
.menu a{
  font-family:var(--serif);font-size:clamp(2rem,9vw,3.4rem);font-weight:500;
  color:var(--ivory);padding:.12em .2em;opacity:0;transform:translateY(14px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s;
}
.menu.open a{opacity:1;transform:none;}
.menu a:nth-child(1){transition-delay:.10s;}
.menu a:nth-child(2){transition-delay:.16s;}
.menu a:nth-child(3){transition-delay:.22s;}
.menu a:nth-child(4){transition-delay:.28s;}
.menu a:nth-child(5){transition-delay:.34s;}
.menu a:hover{color:var(--mint);font-style:italic;}
.menu__close{position:absolute;top:24px;right:var(--gut);width:40px;height:40px;background:none;border:0;}
.menu__close::before,.menu__close::after{content:"";position:absolute;top:50%;left:8px;width:24px;height:1.5px;background:var(--ivory);}
.menu__close::before{transform:rotate(45deg);}
.menu__close::after{transform:rotate(-45deg);}
.menu__foot{position:absolute;bottom:34px;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--paper-50);opacity:0;transition:opacity .5s .4s;}
.menu.open .menu__foot{opacity:1;}
body.no-scroll{overflow:hidden;}

/* ---------- Photo placeholders ---------- */
.ph{
  position:relative;overflow:hidden;background:var(--bone);
  isolation:isolate;
}
.ph::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    repeating-linear-gradient(135deg, rgba(26,26,26,.022) 0 2px, transparent 2px 13px),
    linear-gradient(150deg, var(--bone), var(--ivory-2));
}
.ph::after{
  content:attr(data-label);position:absolute;z-index:1;
  left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--sans);font-size:.62rem;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--ink-40);
  text-align:center;width:84%;line-height:1.9;white-space:pre-line;
}
.ph.dark-ph{background:var(--charcoal-soft);}
.ph.dark-ph::before{
  background:
    repeating-linear-gradient(135deg, rgba(247,244,239,.025) 0 2px, transparent 2px 13px),
    linear-gradient(150deg,#262624,#1e1e1c);
}
.ph.dark-ph::after{color:var(--paper-30);}
.ph .ph__tag{
  position:absolute;z-index:2;left:50%;bottom:18%;transform:translateX(-50%);
  font-size:.55rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);
}
/* when a real image is dropped in via background-image, hide chrome */
.ph[style*="background-image"]::before,
.ph[style*="background-image"]::after,
.ph[style*="background-image"] .ph__tag{display:none;}
.ph[style*="background-image"]{background-size:cover;background-position:center;}

.ph img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;}

/* hover zoom wrapper for gallery / featured */
.zoom{overflow:hidden;}
.zoom .ph,.zoom img{transition:transform 1.2s var(--ease);}
.zoom:hover .ph,.zoom:hover img{transform:scale(1.045);}

/* ---------- Reveal animation (gated on .js so no-JS shows content) ---------- */
.reveal{transition:opacity 1s var(--ease),transform 1.1s var(--ease);}
.js .reveal{opacity:0;transform:translateY(26px);}
.js .reveal.in,.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.09s;}
.reveal.d2{transition-delay:.18s;}
.reveal.d3{transition-delay:.27s;}
.reveal.d4{transition-delay:.36s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  *{scroll-behavior:auto;}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--charcoal);}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media .ph{position:absolute;inset:-4% ;width:108%;height:108%;animation:kenburns 24s ease-in-out infinite alternate;}
@keyframes kenburns{from{transform:scale(1) translate(0,0);}to{transform:scale(1.12) translate(-1.5%,-1.5%);}}
@media (prefers-reduced-motion:reduce){.hero__media .ph{animation:none;}}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(15,15,15,.46) 0%,rgba(15,15,15,.12) 34%,rgba(15,15,15,.22) 62%,rgba(15,15,15,.74) 100%);}
.hero__inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(72px,11vh,150px);padding-top:130px;}
.hero h1{color:var(--ivory);max-width:16ch;}
.hero .eyebrow{color:var(--paper-70);margin-bottom:1.9em;}
.hero__sub{color:var(--paper-70);max-width:40ch;margin:1.7em 0 2.4em;font-size:1.05rem;}
.hero__cta{display:flex;flex-wrap:wrap;gap:18px;align-items:center;}
.scrollcue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--paper-50);}
.scrollcue span{font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;}
.scrollcue i{display:block;width:1px;height:46px;background:linear-gradient(var(--paper-50),transparent);position:relative;overflow:hidden;}
.scrollcue i::after{content:"";position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--mint);animation:drip 2.4s var(--ease) infinite;}
@keyframes drip{0%{top:-46px;}60%,100%{top:46px;}}

/* ---------- Split (welcome / about teaser) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,6vw,96px);align-items:center;}
.split--rev .split__media{order:2;}
.split__media .ph{aspect-ratio:4/5;width:100%;}
.split__body .num{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.2rem;margin-bottom:.6em;display:block;}
.signoff{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink);margin-top:.6em;}
.dark .signoff{color:var(--mint);}

/* ---------- Featured grid ---------- */
.feat{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.5vw,22px);}
.feat .zoom{position:relative;}
.feat .ph{width:100%;height:100%;}
.f-a{grid-column:1/7;}
.f-a .ph{aspect-ratio:4/5;}
.f-b{grid-column:7/13;display:grid;gap:clamp(12px,1.5vw,22px);grid-template-rows:1fr 1fr;}
.f-b .ph{aspect-ratio:auto;height:100%;min-height:200px;}
.f-c{grid-column:1/5;}
.f-c .ph{aspect-ratio:1/1;}
.f-d{grid-column:5/13;}
.f-d .ph{aspect-ratio:16/10;}

/* ---------- "What I photograph" list ---------- */
.cats{border-top:1px solid var(--line-ink);}
.cat{
  display:grid;grid-template-columns:auto minmax(0,1fr);
  column-gap:clamp(16px,3vw,48px);row-gap:.5em;align-items:baseline;
  padding:clamp(22px,3vw,40px) 0;border-bottom:1px solid var(--line-ink);
  position:relative;transition:padding .5s var(--ease);
}
.cat__idx{grid-column:1;grid-row:1;font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;color:var(--ink-40);}
.cat__name{grid-column:2;grid-row:1;font-family:var(--serif);font-size:clamp(1.7rem,4vw,3rem);font-weight:500;line-height:1.05;transition:color .4s,transform .5s var(--ease);}
.cat__line{grid-column:2;grid-row:2;font-size:.98rem;line-height:1.5;color:var(--ink-55);max-width:48ch;}
.cat__media{
  position:absolute;right:clamp(8px,2.5vw,48px);top:50%;transform:translateY(-50%) scale(.92);
  width:clamp(190px,17vw,250px);aspect-ratio:4/5;opacity:0;pointer-events:none;z-index:3;
  transition:opacity .5s var(--ease),transform .6s var(--ease);box-shadow:0 30px 60px rgba(0,0,0,.28);
}
.cat:hover .cat__name{color:var(--gold);transform:translateX(10px);}
@media (min-width:900px){
  .cat{padding-right:clamp(260px,24vw,330px);}
}
@media (hover:hover) and (min-width:900px){
  .cat:hover .cat__media{opacity:1;transform:translateY(-50%) scale(1);}
}
.cat__media .ph{width:100%;height:100%;}

/* category grid fallback layout for mobile shown via simple stack handled by media query */

/* ---------- Testimonials ---------- */
.quotes{text-align:center;max-width:780px;margin-inline:auto;}
.quotes__mark{font-family:var(--serif);font-size:5rem;line-height:.5;color:var(--mint);height:.5em;display:block;margin-bottom:.3em;}
.quote{display:none;}
.quote.on{display:block;animation:qfade 1s var(--ease);}
@keyframes qfade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.quote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3vw,2.5rem);line-height:1.3;color:var(--ivory);font-weight:300;}
.quote cite{display:block;margin-top:1.5em;font-family:var(--sans);font-style:normal;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--paper-50);}
.quotes__dots{display:flex;gap:12px;justify-content:center;margin-top:2.6em;}
.quotes__dots button{width:7px;height:7px;border-radius:50%;border:0;background:var(--paper-30);padding:0;transition:.4s var(--ease);}
.quotes__dots button.on{background:var(--mint);transform:scale(1.35);}

/* ---------- CTA band ---------- */
.cta{position:relative;overflow:hidden;text-align:center;}
.cta .ph{position:absolute;inset:0;z-index:0;}
.cta__scrim{position:absolute;inset:0;z-index:1;background:rgba(20,20,20,.66);}
.cta__inner{position:relative;z-index:2;padding-block:clamp(86px,14vw,200px);}
.cta h2{color:var(--ivory);max-width:18ch;margin-inline:auto;}
.cta .eyebrow{color:var(--mint);}

/* ---------- Footer ---------- */
.foot{background:var(--charcoal);color:var(--paper-70);padding-block:clamp(60px,8vw,110px);}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(30px,5vw,70px);align-items:start;}
.foot__badge{width:118px;height:118px;border-radius:50%;border:1px solid var(--line-paper);display:flex;align-items:center;justify-content:center;padding:18px;}
.foot__badge img{width:100%;}
.foot__bio{margin-top:1.6em;max-width:32ch;font-size:.92rem;color:var(--paper-50);}
.foot h4{font-family:var(--sans);font-size:.7rem;font-weight:400;letter-spacing:.28em;text-transform:uppercase;color:var(--mint);margin-bottom:1.5em;}
.foot__nav{display:flex;flex-direction:column;gap:.85em;}
.foot__nav a,.foot__contact a{font-size:.95rem;color:var(--paper-70);transition:color .3s;}
.foot__nav a:hover,.foot__contact a:hover{color:var(--mint);}
.foot__contact{display:flex;flex-direction:column;gap:.85em;font-size:.95rem;}
.foot__social{display:flex;gap:14px;margin-top:1.6em;}
.foot__social a{width:40px;height:40px;border:1px solid var(--line-paper);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.4s var(--ease);}
.foot__social a:hover{border-color:var(--mint);background:var(--mint);color:var(--charcoal);}
.foot__social svg{width:16px;height:16px;}
.foot__area{margin-top:clamp(40px,6vw,72px);padding-top:30px;border-top:1px solid var(--line-paper);
  display:flex;flex-wrap:wrap;gap:14px 30px;justify-content:space-between;align-items:center;
  font-size:.74rem;letter-spacing:.12em;color:var(--paper-50);}
.foot__area .area-line{max-width:60ch;}

/* ---------- Page intro (sub pages) ---------- */
.pintro{padding-top:clamp(150px,20vh,250px);padding-bottom:clamp(40px,6vw,80px);}
.pintro h1{max-width:14ch;}
.pintro .lede{max-width:46ch;margin-top:1.4em;color:var(--ink-70);}

/* ---------- Gallery (portfolio) ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center;margin-bottom:clamp(34px,5vw,60px);}
.filters button{
  background:none;border:0;font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-40);padding:6px 0;position:relative;transition:color .35s;
}
.filters button::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.filters button:hover{color:var(--ink);}
.filters button.on{color:var(--ink);}
.filters button.on::after{transform:scaleX(1);}
.gallery{columns:3;column-gap:clamp(12px,1.5vw,22px);}
.gallery .gitem{break-inside:avoid;margin-bottom:clamp(12px,1.5vw,22px);cursor:pointer;}
.gallery .ph{width:100%;}
.g-tall .ph{aspect-ratio:3/4;}
.g-sq .ph{aspect-ratio:1/1;}
.g-wide .ph{aspect-ratio:4/3;}
.gitem.hide{display:none;}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(15,15,15,.94);display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s;}
.lb.open{opacity:1;visibility:visible;}
.lb__stage{max-width:min(86vw,1100px);max-height:84vh;width:100%;}
.lb__img{width:100%;height:78vh;}
.lb__img .ph{width:100%;height:100%;}
.lb__cap{text-align:center;margin-top:18px;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--paper-50);}
.lb__close{position:absolute;top:26px;right:var(--gut);width:42px;height:42px;background:none;border:0;}
.lb__close::before,.lb__close::after{content:"";position:absolute;top:50%;left:9px;width:24px;height:1.5px;background:var(--ivory);}
.lb__close::before{transform:rotate(45deg);}.lb__close::after{transform:rotate(-45deg);}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--paper-70);padding:20px;transition:color .3s;}
.lb__nav:hover{color:var(--mint);}
.lb__nav svg{width:26px;height:26px;}
.lb__prev{left:max(10px,calc(var(--gut) - 30px));}
.lb__next{right:max(10px,calc(var(--gut) - 30px));}

/* ---------- Investment ---------- */
.invest{display:grid;grid-template-columns:1fr;gap:0;max-width:880px;margin-inline:auto;}
.price{
  display:grid;grid-template-columns:1fr auto;gap:8px 30px;align-items:baseline;
  padding:clamp(22px,2.6vw,30px) 0;border-top:1px solid var(--line-ink);
}
.price:last-child{border-bottom:1px solid var(--line-ink);}
.price__name{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.1rem);font-weight:500;}
.price__name .tag{display:block;font-family:var(--sans);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-top:.7em;}
.price__desc{font-size:.92rem;color:var(--ink-55);max-width:40ch;grid-column:1;}
.price__amt{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,1.9rem);white-space:nowrap;color:var(--ink);}
.price__amt small{font-family:var(--sans);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-40);display:block;text-align:right;margin-bottom:.3em;}
.note{text-align:center;max-width:52ch;margin:clamp(40px,5vw,60px) auto 0;color:var(--ink-55);font-size:.95rem;}

/* ---------- Contact form ---------- */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,90px);align-items:start;}
.form{display:grid;grid-template-columns:1fr 1fr;gap:26px 30px;}
.field{display:flex;flex-direction:column;gap:.7em;}
.field.full{grid-column:1/-1;}
.field label{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-55);}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:1rem;font-weight:300;color:var(--ink);
  background:transparent;border:0;border-bottom:1px solid var(--line-ink);
  padding:.55em 0;border-radius:0;transition:border-color .4s var(--ease);
}
.field textarea{resize:vertical;min-height:90px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%231A1A1A' fill='none' stroke-width='1.2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .2em center;}
.form .btn{grid-column:1/-1;justify-self:start;margin-top:8px;}
.form__ok{grid-column:1/-1;display:none;padding:1.2em 1.4em;border:1px solid var(--mint);background:rgba(168,213,196,.16);font-size:.95rem;color:var(--ink);border-radius:3px;}
.form__ok.show{display:block;animation:qfade .7s var(--ease);}
.aside h4{font-family:var(--sans);font-size:.7rem;font-weight:400;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-55);margin:0 0 1em;}
.aside .blk{padding:clamp(22px,3vw,30px) 0;border-top:1px solid var(--line-ink);}
.aside .blk:first-child{border-top:0;padding-top:0;}
.aside p{font-size:.96rem;color:var(--ink-70);}
.aside a{color:var(--ink);border-bottom:1px solid var(--gold);}

/* placeholder color for inputs */
::placeholder{color:var(--ink-40);opacity:1;}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .split{grid-template-columns:1fr;gap:36px;}
  .split--rev .split__media{order:0;}
  .contact-grid{grid-template-columns:1fr;}
  .foot__top{grid-template-columns:1fr 1fr;}
  .foot__brand{grid-column:1/-1;}
  .gallery{columns:2;}
  .feat{grid-template-columns:repeat(6,1fr);}
  .f-a{grid-column:1/4;}.f-b{grid-column:4/7;}.f-c{grid-column:1/3;}.f-d{grid-column:3/7;}
}
@media (max-width:760px){
  .nav__links{display:none;}
  .nav__toggle{display:flex;}
  .form{grid-template-columns:1fr;}
  .cat{grid-template-columns:auto 1fr;}
  .cat__line{display:none;}
  .feat{grid-template-columns:1fr;}
  .f-a,.f-b,.f-c,.f-d{grid-column:1/-1;}
  .f-b{grid-template-rows:auto auto;}
  .f-b .ph{min-height:0;aspect-ratio:4/3;}
  .gallery{columns:1;}
  .price{grid-template-columns:1fr;}
  .price__amt{text-align:left;grid-column:1;}
  .price__amt small{text-align:left;}
  .foot__area{flex-direction:column;align-items:flex-start;}
}
@media (max-width:560px){
  .foot__top{grid-template-columns:1fr;}
  body{font-size:16px;}
}
