/* ==========================================================================
   Madeleine Popper Art  |  madeleinepopperart.com
   Gallery-style design in the spirit of contemporary artist portfolio sites.
   Colours and fonts are set once in :root below.
   ========================================================================== */

:root{
  --paper:#FFFFFF;      /* page background */
  --wash:#F7F5F0;       /* soft section background */
  --ink:#1C1B19;        /* main text */
  --soft:#6B675E;       /* secondary text */
  --accent:#A8352A;     /* deep poppy red, drawn from Madeleine's work */
  --line:#E8E5DE;       /* hairline borders */
  --maxw:1180px;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Atkinson Hyperlegible', Arial, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:1.2rem;line-height:1.7}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:0.005em}
a{color:var(--ink)}
a:focus-visible,button:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
img{max-width:100%;display:block;height:auto}

.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:0.75rem 1.25rem;z-index:100;font-weight:700;text-decoration:none}
.skip-link:focus{left:1rem;top:1rem}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.6rem}
.narrow{max-width:720px;margin:0 auto;padding:0 1.6rem}

/* Small uppercase label, used everywhere */
.eyebrow{
  font-family:var(--sans);font-size:0.85rem;font-weight:700;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--soft);
}

/* Buttons: quiet, letterspaced, bordered */
.btn{
  display:inline-block;font-family:var(--sans);font-size:0.9rem;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;text-decoration:none;
  color:var(--ink);border:1px solid var(--ink);padding:0.95rem 2rem;
  transition:background 0.25s ease,color 0.25s ease;
}
.btn:hover{background:var(--ink);color:#fff}
.btn.on-dark{color:#fff;border-color:#fff}
.btn.on-dark:hover{background:#fff;color:var(--ink)}

/* Header ------------------------------------------------------------------ */
header.site{border-bottom:1px solid var(--line);background:var(--paper)}
.site-bar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem 0;flex-wrap:wrap}
.site-name{font-family:var(--serif);font-size:1.7rem;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;text-decoration:none;color:var(--ink)}
nav.primary ul{list-style:none;display:flex;gap:2.2rem;flex-wrap:wrap}
nav.primary a{
  font-family:var(--sans);font-size:0.88rem;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;text-decoration:none;color:var(--ink);
  border-bottom:2px solid transparent;padding-bottom:3px;
}
nav.primary a:hover{border-bottom-color:var(--accent)}
nav.primary a[aria-current="page"]{border-bottom-color:var(--ink)}

/* Hero -------------------------------------------------------------------- */
.hero-image{width:100%;max-height:74vh;overflow:hidden}
.hero-image img{width:100%;height:100%;max-height:74vh;object-fit:cover}
.hero-intro{text-align:center;padding:4.5rem 1.6rem 5rem}
.hero-intro .eyebrow{margin-bottom:1.4rem}
.hero-intro h1{font-size:clamp(2.6rem,6vw,4.6rem);max-width:18ch;margin:0 auto}
.hero-intro p.sub{font-size:1.3rem;color:var(--soft);max-width:44ch;margin:1.5rem auto 2.4rem}
.hero-caption{text-align:right;font-size:0.95rem;color:var(--soft);padding:0.6rem 1.6rem 0;font-style:italic;font-family:var(--serif);font-size:1.05rem}

/* Sections ---------------------------------------------------------------- */
section{padding:5rem 0}
section.wash{background:var(--wash)}
.sec-intro{text-align:center;margin-bottom:3.2rem}
.sec-intro .eyebrow{margin-bottom:1rem}
.sec-intro h2{font-size:clamp(2rem,4.5vw,3rem)}

/* Featured and full gallery grids ------------------------------------------ */
.works-grid{display:grid;gap:2.6rem 2.2rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.works-grid.featured{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
figure.work{text-align:center}
figure.work .frame{background:var(--wash);margin-bottom:1.2rem;overflow:hidden}
figure.work .frame a{display:block}
figure.work .frame img{width:100%;height:auto;transition:transform 0.4s ease,opacity 0.4s ease}
figure.work .frame a:hover img{transform:scale(1.02);opacity:0.94}
figure.work .title{font-family:var(--serif);font-size:1.55rem;font-weight:500}
figure.work .meta{color:var(--soft);font-size:1rem;margin-top:0.2rem}
figure.work .price{font-size:1rem;font-weight:700;letter-spacing:0.08em;margin-top:0.35rem}
.center-cta{text-align:center;margin-top:3.4rem}

/* Split section: image beside text ----------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split .text h2{font-size:clamp(1.9rem,4vw,2.7rem);margin:0.9rem 0 1.4rem}
.split .text p + p{margin-top:1.1rem}
.split .text .btn{margin-top:2rem}
.split .art img{width:100%}
.split .art figcaption{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--soft);margin-top:0.7rem}

/* Large centred quote -------------------------------------------------------- */
.quote{text-align:center;padding:5.5rem 1.6rem}
.quote blockquote{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(1.7rem,3.6vw,2.5rem);line-height:1.35;max-width:26ch;margin:0 auto;
}
.quote cite{display:block;margin-top:1.6rem;font-style:normal}
.quote cite .eyebrow{color:var(--soft)}

/* Exhibition banner ----------------------------------------------------------- */
.exhibit-banner{background:var(--ink);color:#fff;text-align:center;padding:4.5rem 1.6rem}
.exhibit-banner .eyebrow{color:#CFCBC2;margin-bottom:1rem}
.exhibit-banner h2{font-size:clamp(2rem,4.5vw,3rem);color:#fff}
.exhibit-banner p{color:#DDD9D0;margin-top:0.8rem;font-size:1.15rem}

/* Exhibition list (about page) ------------------------------------------------ */
.exhibits{list-style:none;max-width:680px;margin:0 auto}
.exhibits li{display:grid;grid-template-columns:100px 1fr;gap:1.2rem;padding:1.3rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.exhibits .year{font-family:var(--serif);font-size:1.5rem}
.exhibits .what .name{font-weight:700;font-size:1.15rem}
.exhibits .what .where{color:var(--soft);font-size:1.02rem}

/* Prose --------------------------------------------------------------------- */
.prose p + p{margin-top:1.2rem}
.prose a{text-decoration-color:var(--accent);text-decoration-thickness:2px;text-underline-offset:4px}

/* Contact --------------------------------------------------------------------- */
.contact-block{text-align:center;padding:1rem 0 2rem}
.contact-block .big-link{
  display:inline-block;font-family:var(--serif);font-size:clamp(1.6rem,4.5vw,2.6rem);
  color:var(--ink);text-decoration-color:var(--accent);text-decoration-thickness:3px;
  text-underline-offset:10px;word-break:break-word;margin:1.4rem 0 0.6rem;
}
.contact-note{color:var(--soft);max-width:52ch;margin:1.4rem auto 0}

/* Footer ---------------------------------------------------------------------- */
footer.site{border-top:1px solid var(--line);padding:3.4rem 0 3rem;font-size:1rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:2.5rem}
.foot-grid h3{font-family:var(--sans);font-size:0.85rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--soft);margin-bottom:0.9rem}
.foot-grid .brand{font-family:var(--serif);font-size:1.4rem;letter-spacing:0.06em;text-transform:uppercase}
.foot-grid p{color:var(--soft);margin-top:0.7rem;max-width:34ch}
.foot-grid ul{list-style:none}
.foot-grid li + li{margin-top:0.45rem}
.foot-grid a{color:var(--ink);text-decoration:none}
.foot-grid a:hover{text-decoration:underline;text-decoration-color:var(--accent)}
.foot-legal{border-top:1px solid var(--line);margin-top:2.6rem;padding-top:1.6rem;color:var(--soft);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}

/* Responsive -------------------------------------------------------------------- */
@media (max-width:880px){
  .split{grid-template-columns:1fr;gap:2.4rem}
  .foot-grid{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:600px){
  section{padding:3.4rem 0}
  .hero-intro{padding:3.2rem 1.6rem}
  .exhibits li{grid-template-columns:1fr;gap:0.2rem}
  .site-bar{justify-content:center;text-align:center}
}
