/* =========================================================
   Atelier Verrent — contemporary art gallery
   Image-led, restrained, quiet. Inspired by real gallery sites.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400&family=Inter:wght@300;400;500&display=swap');

:root{
  --paper:#ffffff;
  --off:#f6f5f2;
  --ink:#1c1a17;
  --ink-soft:#565049;
  --ink-faint:#8f887f;
  --line:#e6e3dc;
  --line-strong:#d3cec4;
  --accent:#1c1a17;        /* near-black, gallery-neutral */
  --max:1320px;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.narrow{max-width:820px;margin:0 auto;padding:0 32px}

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

.eyebrow{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.3em;
  text-transform:uppercase;color:var(--ink-faint)}

/* link with underline reveal */
.ulink{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  padding-bottom:3px;border-bottom:1px solid var(--ink);transition:opacity .2s}
.ulink:hover{opacity:.55}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:12px;
  font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:14px 30px;cursor:pointer;
  border:1px solid var(--ink);background:var(--ink);color:#fff;transition:background .2s,color .2s}
.btn:hover{background:transparent;color:var(--ink)}
.btn.line{background:transparent;color:var(--ink)}
.btn.line:hover{background:var(--ink);color:#fff}
.btn svg{width:15px;height:15px}

/* =============== HEADER =============== */
.topbar{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 0}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--serif);font-size:28px;font-weight:500;letter-spacing:.04em;color:var(--ink)}
.brand .tag{font-size:9.5px;letter-spacing:.36em;text-transform:uppercase;color:var(--ink-faint);margin-top:5px}
.links{display:flex;align-items:center;gap:36px}
.links a{color:var(--ink-soft);font-size:12px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  position:relative;padding:3px 0;transition:color .2s}
.links a:hover{color:var(--ink)}
.links a.active{color:var(--ink)}
.links a.active::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--ink)}
.menuBtn{display:none;background:transparent;border:none;padding:6px;cursor:pointer;color:var(--ink)}
.menuBtn svg{width:24px;height:24px;display:block}
.mobileNav{display:none;flex-direction:column;padding-bottom:16px}
.mobileNav a{padding:13px 2px;color:var(--ink-soft);border-top:1px solid var(--line);
  font-size:12px;font-weight:500;letter-spacing:.18em;text-transform:uppercase}
.mobileNav a.active{color:var(--ink)}
.mobileNav.open{display:flex}
@media (max-width:820px){.links{display:none}.menuBtn{display:inline-flex}}

/* =============== HERO (full-bleed image) =============== */
.hero{position:relative;height:82vh;min-height:520px;overflow:hidden;background:var(--off)}
.hero img{width:100%;height:100%;object-fit:cover}
.hero-veil{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,18,15,.72) 0%,rgba(20,18,15,.20) 45%,rgba(20,18,15,.34) 100%)}
.hero-cap{position:absolute;left:0;right:0;bottom:0;padding:0 0 44px}
.hero-cap .wrap{color:#fff}
.hero-cap .eyebrow{color:rgba(255,255,255,.8);display:block;margin-bottom:16px}
.hero-cap h1{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5vw,60px);line-height:1.05;
  margin:0 0 18px;max-width:20ch;letter-spacing:.01em}
.hero-cap .meta{font-size:14px;color:rgba(255,255,255,.85);letter-spacing:.02em;margin-bottom:24px}
.hero-cap .ulink{color:#fff;border-color:#fff}
@media (max-width:820px){.hero{height:70vh}.hero-cap{padding-bottom:32px}}

/* =============== STATEMENT =============== */
.statement{padding:90px 0}
.statement p{font-family:var(--serif);font-size:clamp(22px,2.8vw,32px);line-height:1.45;
  color:var(--ink);font-weight:400;text-align:center;margin:0}
.statement .eyebrow{display:block;text-align:center;margin-bottom:28px}
@media (max-width:820px){.statement{padding:60px 0}}

/* =============== FEATURE (image + text) =============== */
.feature{padding:20px 0 90px}
.feature-in{display:grid;grid-template-columns:1.1fr .9fr;gap:0;align-items:stretch}
.feature.flip .feature-in{grid-template-columns:.9fr 1.1fr}
.feature.flip .feature-img{order:2}
.feature-img{overflow:hidden;background:var(--off)}
.feature-img img{width:100%;height:100%;object-fit:cover;min-height:420px}
.feature-text{display:flex;flex-direction:column;justify-content:center;padding:56px 64px}
.feature-text .eyebrow{display:block;margin-bottom:18px}
.feature-text h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.2vw,38px);
  line-height:1.12;margin:0 0 18px;letter-spacing:.01em}
.feature-text p{color:var(--ink-soft);font-size:15.5px;margin:0 0 16px}
.feature-text .cta{margin-top:14px}
@media (max-width:820px){
  .feature-in,.feature.flip .feature-in{grid-template-columns:1fr}
  .feature.flip .feature-img{order:0}
  .feature-text{padding:40px 8px}
  .feature-img img{min-height:300px}
}

/* =============== WORKS GRID =============== */
.works-head{text-align:center;padding:80px 0 0}
.works-head .eyebrow{display:block;margin-bottom:16px}
.works-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.6vw,44px);margin:0 0 12px}
.works-head p{color:var(--ink-soft);font-size:16px;max-width:60ch;margin:0 auto}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:56px 0 90px}
@media (max-width:1080px){.grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:760px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:440px){.grid{grid-template-columns:1fr}}
.piece{cursor:pointer;background:none;border:none;padding:0;text-align:left;font-family:inherit;display:flex;flex-direction:column}
.piece-img{width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--off)}
.piece-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease,opacity .4s}
.piece:hover .piece-img img{transform:scale(1.04)}
.piece-info{padding:14px 2px 0}
.piece-artist{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}
.piece-title{font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.2;margin-bottom:5px}
.piece-meta{font-size:12.5px;color:var(--ink-faint);margin-bottom:6px}
.piece-price{font-size:13px;color:var(--ink)}
.piece-price.sold{color:var(--ink-faint)}
.empty{grid-column:1/-1;text-align:center;padding:60px;color:var(--ink-faint)}

/* filter (simple text row) */
.filterbar{display:flex;justify-content:center;gap:26px;flex-wrap:wrap;padding:8px 0 0}
.filterbar button{background:none;border:none;font-family:var(--sans);cursor:pointer;
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);
  padding:6px 0;border-bottom:1px solid transparent;transition:color .2s,border-color .2s}
.filterbar button:hover{color:var(--ink)}
.filterbar button.active{color:var(--ink);border-color:var(--ink)}

/* =============== LIGHTBOX =============== */
.lb{position:fixed;inset:0;z-index:100;display:none;background:rgba(255,255,255,.98);padding:0;overflow-y:auto}
.lb.open{display:block}
.lb-top{position:sticky;top:0;display:flex;justify-content:flex-end;padding:20px 28px;z-index:2}
.lb-close{background:none;border:none;cursor:pointer;color:var(--ink);padding:8px;line-height:0}
.lb-close:hover{opacity:.5}
.lb-close svg{width:26px;height:26px}
.lb-card{max-width:1180px;margin:0 auto;padding:0 32px 80px;
  display:grid;grid-template-columns:1.2fr .8fr;gap:56px;align-items:start}
.lb-img{display:flex;align-items:flex-start;justify-content:center}
.lb-img img{max-width:100%;max-height:80vh;width:auto}
.lb-detail{position:sticky;top:80px;padding-top:10px}
.lb-artist{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px}
.lb-title{font-family:var(--serif);font-style:italic;font-weight:400;font-size:36px;line-height:1.08;margin:0 0 26px}
.lb-specs{list-style:none;padding:0;margin:0 0 26px;border-top:1px solid var(--line)}
.lb-specs li{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.lb-specs li .k{color:var(--ink-faint);letter-spacing:.04em}
.lb-specs li .v{color:var(--ink);text-align:right}
.lb-desc{font-size:14.5px;color:var(--ink-soft);line-height:1.75;margin:0 0 28px}
.lb-price{font-family:var(--serif);font-size:26px;margin-bottom:6px}
.lb-price.sold{color:var(--ink-faint)}
.lb-price-note{font-size:12px;color:var(--ink-faint);margin-bottom:24px;letter-spacing:.02em}
.lb-actions{display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:820px){
  .lb-card{grid-template-columns:1fr;gap:28px;padding-bottom:60px}
  .lb-detail{position:static}
  .lb-img img{max-height:56vh}
  .lb-title{font-size:28px}
}

/* =============== CONTACT =============== */
.page-head{text-align:center;padding:72px 0 0}
.page-head .eyebrow{display:block;margin-bottom:16px}
.page-head h1{font-family:var(--serif);font-weight:400;font-size:clamp(32px,4.4vw,52px);margin:0 0 14px}
.page-head p{color:var(--ink-soft);font-size:16.5px;max-width:56ch;margin:0 auto}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;padding:56px 0 90px}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr;gap:44px}}
.contact-form .field{margin-bottom:20px}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:520px){.contact-form .row{grid-template-columns:1fr}}
label{display:block;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:9px}
input,textarea,select{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:var(--paper);
  border:none;border-bottom:1px solid var(--line-strong);border-radius:0;padding:10px 0;outline:none;transition:border-color .2s}
input:focus,textarea:focus,select:focus{border-color:var(--ink)}
textarea{resize:vertical;min-height:110px}
.contact-form .btn{margin-top:10px}
.form-note{font-size:13px;color:var(--ink-faint);margin-top:16px}
.form-ok{display:none;border-top:2px solid var(--ink);padding-top:24px}
.form-ok.show{display:block}
.form-ok h3{font-family:var(--serif);font-style:italic;font-size:24px;margin:0 0 8px}
.form-ok p{color:var(--ink-soft);font-size:14.5px;margin:0}

.contact-info h2{font-family:var(--serif);font-weight:400;font-size:26px;margin:0 0 22px}
.info-line{padding:16px 0;border-bottom:1px solid var(--line)}
.info-line:first-of-type{border-top:1px solid var(--line)}
.info-line .k{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px}
.info-line .v{font-size:15.5px;color:var(--ink)}
.info-line .v a:hover{opacity:.6}
.contact-img{margin-top:32px}
.contact-img img{width:100%;border:1px solid var(--line)}

/* =============== FOOTER =============== */
.footer{background:var(--off);border-top:1px solid var(--line);margin-top:0}
.footer-in{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding:60px 0 30px}
.footer .name{font-family:var(--serif);font-size:26px;color:var(--ink)}
.footer .tag{font-size:9.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-faint);margin-top:5px}
.footer p{font-size:14px;color:var(--ink-soft);margin-top:16px;max-width:34ch}
.footer h5{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 16px}
.footer a,.footer span.fl{display:block;color:var(--ink-soft);font-size:14px;margin-bottom:10px}
.footer a:hover{color:var(--ink)}
.footer-bottom{border-top:1px solid var(--line);padding:22px 0;font-size:12px;color:var(--ink-faint);
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;letter-spacing:.03em}
@media (max-width:820px){.footer-in{grid-template-columns:1fr;gap:30px}}
