:root{
  --stone:#E7E2D8;
  --stone-deep:#DBD5C8;
  --mat:#F7F4EE;
  --ink:#2A2520;
  --ink-soft:#6E6457;
  --line:#C7BFB1;
  --frame:#39332B;
  --gilt:#B49A68;
  --accent:#4E5E54;
  --accent-deep:#3B4840;
  --serif:"EB Garamond",Georgia,"Times New Roman",serif;
  --sans:"Archivo","Helvetica Neue",Arial,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--stone);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-deep)}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.label{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}

/* NAV */
header.nav{position:sticky;top:0;z-index:50;background:rgba(231,226,216,.9);backdrop-filter:saturate(1.1) blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:16px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:500;letter-spacing:.01em;color:var(--ink);white-space:nowrap;line-height:1.05}
.brand span{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-top:3px}
nav.links{display:flex;gap:24px;align-items:center}
nav.links a{font-family:var(--sans);font-size:.8rem;font-weight:500;letter-spacing:.05em;color:var(--ink);text-transform:uppercase;padding:4px 0;border-bottom:1px solid transparent;white-space:nowrap}
nav.links a:hover{border-bottom-color:var(--ink)}
nav.links a.active{border-bottom-color:var(--accent);color:var(--accent-deep)}
nav.links a.cta{color:var(--accent-deep);border:1px solid var(--accent);border-radius:2px;padding:9px 16px}
nav.links a.cta:hover{background:var(--accent);color:var(--mat);border-color:var(--accent)}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:2px;padding:8px 12px;font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);cursor:pointer}
@media (max-width:980px){
  .menu-btn{display:block}
  nav.links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--stone);border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .3s ease}
  nav.links.open{max-height:540px}
  nav.links a{padding:15px 28px;border-bottom:1px solid var(--line)}
  nav.links a.cta{margin:14px 28px;text-align:center}
}

/* PAGE HEAD */
.page-head{padding:64px 0 26px}
.page-head .label{display:block;margin-bottom:12px}
.page-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.3rem,5vw,3.4rem);line-height:1.02;letter-spacing:-.01em}
.page-head p{margin-top:16px;max-width:54ch;color:var(--ink-soft);font-size:1.08rem}

/* HERO (home) */
.hero{position:relative;padding:64px 0 60px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-140px;left:50%;transform:translateX(-50%);width:780px;height:540px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(255,252,244,.7),rgba(255,252,244,0) 68%);pointer-events:none}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center;position:relative}
.hero .eyebrow{margin-bottom:20px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,5.4vw,4.1rem);line-height:1.03;letter-spacing:-.01em;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--accent-deep)}
.hero .lede{font-size:1.18rem;max-width:34ch;margin-bottom:30px;line-height:1.5}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:760px){
  .hero{padding:40px 0 36px}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-art{order:-1}
  .hero .lede{max-width:none}
}

.btn{font-family:var(--sans);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:14px 26px;border-radius:2px;cursor:pointer;border:1px solid var(--ink);background:var(--ink);color:var(--mat);transition:all .2s ease;display:inline-block}
.btn:hover{background:transparent;color:var(--ink)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--ink)}

/* FRAMED FEATURE IMAGE */
.feature-frame{background:linear-gradient(135deg,#4a4036,#2e281f);padding:14px;border-radius:1px;box-shadow:0 1px 0 rgba(180,154,104,.35) inset,0 18px 40px -18px rgba(40,34,26,.55);position:relative;max-width:420px;margin:0 auto}
.feature-frame::after{content:"";position:absolute;inset:9px;border:1px solid var(--gilt);opacity:.5;pointer-events:none}
.feature-frame .mat{background:var(--mat);padding:14px}
.feature-frame img{width:100%}

/* FEATURED GALLERY CARDS (home) */
.cards{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(3,1fr);gap:34px 30px}
@media (max-width:860px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.cards{grid-template-columns:1fr}}
.card{display:block;color:var(--ink)}
.card .card-img{background:var(--mat);padding:8px;box-shadow:0 10px 26px -16px rgba(40,34,26,.5);overflow:hidden}
.card .card-img img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .4s ease}
.card:hover .card-img img{transform:scale(1.04)}
.card .card-cap{margin-top:14px;display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:12px}
.card .card-cap h3{font-family:var(--serif);font-style:italic;font-weight:500;font-size:1.35rem}
.card .card-cap span{font-family:var(--sans);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}

/* SECTIONS */
.section{padding:70px 0}
.section.alt{background:var(--stone-deep)}
.section-head{max-width:var(--maxw);margin:0 auto 38px;padding:0 28px}
.section-head .label{display:block;margin-bottom:10px}
.section-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.5rem);line-height:1.05}
.section-head p{margin-top:12px;max-width:52ch;color:var(--ink-soft)}

/* GALLERY (masonry columns — never crops artwork) */
.gallery{max-width:var(--maxw);margin:0 auto;padding:0 28px;column-count:3;column-gap:40px}
@media (max-width:900px){.gallery{column-count:2;column-gap:28px}}
@media (max-width:560px){.gallery{column-count:1}}
.piece{break-inside:avoid;margin-bottom:46px;display:inline-block;width:100%}
.art{background:var(--mat);padding:10px;box-shadow:0 1px 2px rgba(40,34,26,.12),0 16px 34px -20px rgba(40,34,26,.5);cursor:zoom-in;transition:transform .28s ease,box-shadow .28s ease}
.piece:hover .art{transform:translateY(-4px);box-shadow:0 1px 2px rgba(40,34,26,.14),0 26px 46px -22px rgba(40,34,26,.6)}
.piece:focus-visible .art{outline:2px solid var(--accent);outline-offset:4px}
.art img{width:100%}
.placard{padding:14px 2px 0;margin-top:2px}
.placard .ttl{font-family:var(--serif);font-style:italic;font-size:1.2rem;line-height:1.2;color:var(--ink)}
.placard .meta{font-family:var(--sans);font-size:.8rem;color:var(--ink-soft);margin-top:4px;line-height:1.5}
.placard .row{display:flex;justify-content:space-between;align-items:center;margin-top:11px;gap:12px}
.placard .price{font-family:var(--sans);font-size:.92rem;font-weight:600;color:var(--ink)}
.placard .status{font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.sold .art{filter:saturate(.6) brightness(.98)}
.sold .placard .ttl{color:var(--ink-soft)}
.buy{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:transparent;border:1px solid var(--line);color:var(--ink);padding:9px 15px;border-radius:2px;cursor:pointer;transition:all .2s ease;white-space:nowrap}
.buy:hover{border-color:var(--ink);background:var(--ink);color:var(--mat)}
.sub-label{max-width:var(--maxw);margin:0 auto 26px;padding:0 28px}
.sub-label span{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--line);padding-bottom:8px;display:inline-block}

/* BAND CTA */
.band{background:var(--frame);color:#e7e1d5;padding:64px 0;text-align:center}
.band h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:14px;color:#f3eee3}
.band p{max-width:44ch;margin:0 auto 26px;color:#c4bbab}
.band .btn{background:var(--mat);color:var(--ink);border-color:var(--mat)}
.band .btn:hover{background:transparent;color:#f3eee3;border-color:#bdb4a4}

/* COMMISSIONS */
.commission-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media (max-width:860px){.commission-inner{grid-template-columns:1fr;gap:40px}}
.commission-copy .lede{font-size:1.12rem;margin-bottom:8px}
.steps{list-style:none;margin:26px 0 0;counter-reset:step}
.steps li{position:relative;padding:18px 0 18px 56px;border-top:1px solid var(--line);counter-increment:step}
.steps li:last-child{border-bottom:1px solid var(--line)}
.steps li::before{content:counter(step);position:absolute;left:0;top:18px;width:36px;height:36px;border-radius:50%;border:1px solid var(--accent);color:var(--accent-deep);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.1rem}
.steps li strong{display:block;font-family:var(--sans);font-weight:600;font-size:1rem;margin-bottom:3px}
.steps li span{color:var(--ink-soft);font-size:.96rem}
.pricing-note{margin-top:24px;font-size:1rem}
.reassure{margin-top:24px;font-size:.98rem;color:var(--ink-soft);background:var(--mat);border:1px solid var(--line);border-radius:2px;padding:18px 20px}
.reassure strong{color:var(--ink)}

/* ABOUT */
.prose{max-width:680px;margin:0 auto;padding:0 28px}
.prose .statement{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2rem);line-height:1.4;margin-bottom:28px;text-align:center}
.prose .statement em{font-style:italic;color:var(--accent-deep)}
.prose p{font-size:1.08rem;margin-bottom:16px}
.exhibits{max-width:680px;margin:54px auto 0;padding:0 28px}
.exhibits h2{font-family:var(--serif);font-weight:500;font-size:1.8rem;margin-bottom:8px}
.exhibits .label{display:block;margin-bottom:10px}
.exhibits ul{list-style:none;margin-top:14px}
.exhibits li{padding:13px 0;border-top:1px solid var(--line);display:flex;gap:18px;font-size:1rem}
.exhibits li .yr{font-family:var(--sans);font-weight:600;color:var(--ink-soft);min-width:54px}
.note{font-size:.9rem;color:var(--ink-soft);font-style:italic}

/* CONTACT */
.contact-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start}
@media (max-width:860px){.contact-inner{grid-template-columns:1fr;gap:40px}}
.contact-aside p{color:var(--ink-soft);margin-bottom:26px;max-width:34ch}
.contact-detail{margin-bottom:18px}
.contact-detail .label{display:block;margin-bottom:4px}
.contact-detail a,.contact-detail span{font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.contact-detail a:hover{color:var(--accent-deep)}
form{display:grid;gap:18px}
.field{display:grid;gap:7px}
.field label{font-family:var(--sans);font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.field input,.field textarea,.field select{font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--mat);border:1px solid var(--line);border-radius:2px;padding:13px 14px;width:100%}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.field textarea{min-height:130px;resize:vertical}
.field.two{grid-template-columns:1fr 1fr;gap:18px}
.field.two>div{display:grid;gap:7px}
@media (max-width:540px){.field.two{grid-template-columns:1fr}}
form .btn{justify-self:start}
.form-note{font-size:.85rem;color:var(--ink-soft)}

/* FOOTER */
footer{background:var(--frame);color:#d8d2c6;padding:54px 0 38px;margin-top:0}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;display:flex;justify-content:space-between;gap:32px;flex-wrap:wrap;align-items:flex-start}
footer .brand{color:#f0ebe0}
footer .brand span{color:#a59c8c}
.foot-links{display:flex;gap:22px;flex-wrap:wrap}
.foot-links a{color:#cfc7b8;font-family:var(--sans);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}
.foot-links a:hover{color:#fff}
.foot-base{max-width:var(--maxw);margin:34px auto 0;padding:22px 28px 0;border-top:1px solid rgba(255,255,255,.14);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.foot-base p{font-size:.76rem;color:#a59c8c}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(28,24,19,.9);display:none;align-items:center;justify-content:center;padding:5vh 5vw}
.lightbox.open{display:flex}
.lightbox .lb-card{max-width:min(680px,92vw);width:100%}
.lightbox .art{background:var(--mat);padding:12px;cursor:auto}
.lightbox .lb-placard{text-align:center;margin-top:16px;color:#e9e3d6}
.lightbox .lb-placard .ttl{font-family:var(--serif);font-style:italic;font-size:1.4rem}
.lightbox .lb-placard .meta{font-family:var(--sans);font-size:.85rem;color:#bdb4a4;margin-top:6px}
.lb-close{position:absolute;top:22px;right:26px;background:none;border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:2px;padding:8px 14px;font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}
.lb-close:hover{background:rgba(255,255,255,.12)}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--mat);padding:10px 16px;z-index:200}
.skip:focus{left:12px;top:12px}
