/*
  Amy Bianconi Studio — Design System
  Gulf Coast Fine Art Gallery Website
  =====================================
*/

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

/* =====================
   CSS CUSTOM PROPERTIES
   ===================== */

:root {
  /* Estate Gallery palette — warm, archival, editorial */
  --cream:        #F4F0EA;   /* Archival Linen — primary canvas */
  --cream-light:  #FAF8F3;   /* lifted linen for raised surfaces */
  --cream-dark:   #EAE3D8;   /* Parchment — cards / footer / secondary surface */
  --charcoal:     #2C2A29;   /* Iron Ore — primary text & structure */
  --charcoal-soft:#3C3835;   /* softer iron ore */
  --gray-warm:    #6E665E;   /* muted lead / body-secondary text */
  --gray-light:   #6B635B;   /* readable small text on linen */
  --taupe:        #5C534C;   /* Raw Umber — primary accent / interactive */
  --taupe-deep:   #4A423B;   /* higher-contrast umber for numerals, labels & eyebrows */
  --taupe-light:  #8A7F73;   /* muted umber for decorative details & hover */
  --taupe-pale:   #E5DCCE;   /* pale parchment */
  --rule:         #D7CFC1;   /* hairline borders on linen */
  --white:        #FBF8F3;   /* near-white text on dark accents / overlays */
  --overlay:      rgba(44,42,41,0.55);
  --overlay-lt:   rgba(44,42,41,0.30);

  --font-display: 'Cormorant Garamond','Times New Roman',serif;
  --font-body:    'EB Garamond','Georgia',serif;
  --font-ui:      'Jost','Helvetica Neue',sans-serif;

  --nav-h:        70px;
  --banner-h:     0px;
  --max-w:        1400px;
  --pad:          clamp(1.5rem,4vw,4rem);

  --ease-out:     cubic-bezier(0,0,0.2,1);
  --ease-io:      cubic-bezier(0.4,0,0.2,1);
  --fast:         180ms;
  --mid:          380ms;
  --slow:         560ms;
}

/* =====================
   RESET
   ===================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--cream);color:var(--charcoal);font-family:var(--font-body);line-height:1.7;min-height:100vh}
img{display:block;max-width:100%;height:auto;-webkit-user-drag:none;user-drag:none;user-select:none;-webkit-touch-callout:none}

/* =====================
   ARTWORK IMAGE PROTECTION
   Greys artwork on hover and shields it from right-click / drag / save.
   Pointer-events:none means a right-click lands on the wrapper (handled in
   main.js), so the browser never offers "Save image" or "Open image in new tab".
   ===================== */
img.art-img{
  pointer-events:none;
  -webkit-touch-callout:none;
  -webkit-user-select:none;user-select:none;
  transition:filter var(--mid) var(--ease-out), transform var(--slow) var(--ease-out);
}
.art-wrap:hover img.art-img,
.featured__item:hover img.art-img,
.about-portrait:hover img.art-img,
.commission-intro__image:hover img.art-img,
.artist-intro__image:hover img.art-img,
.rep-mosaic__cell:hover img.art-img,
.instagram__cell:hover img.art-img,
.masonry__item:hover img.art-img{
  filter:grayscale(1) brightness(0.5);
}
a{color:inherit;text-decoration:none}
button{cursor:pointer}
ul{list-style:none}

/* =====================
   TYPOGRAPHY
   ===================== */

h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:400;line-height:1.12;letter-spacing:-0.01em}
h1{font-size:clamp(2.6rem,5.5vw,5rem)}
h2{font-size:clamp(2rem,3.5vw,3.2rem)}
h3{font-size:clamp(1.4rem,2.2vw,1.9rem)}
h4{font-size:clamp(1.15rem,1.8vw,1.45rem)}

.eyebrow{
  font-family:var(--font-ui);
  font-size:0.7rem;
  font-weight:400;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--taupe-deep);
}

.lead{
  font-size:clamp(1rem,1.4vw,1.2rem);
  line-height:1.8;
  color:var(--gray-warm);
}

/* =====================
   LAYOUT
   ===================== */

.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad)}
.section{padding:clamp(5rem,9vw,10rem) 0}
.section--tight{padding:clamp(3rem,5vw,5.5rem) 0}

hr.rule{border:none;border-top:1px solid var(--rule)}

/* =====================
   NAVIGATION
   ===================== */

.nav{
  position:fixed;top:var(--banner-h);left:0;right:0;
  z-index:100;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background var(--mid) var(--ease-out),box-shadow var(--mid) var(--ease-out);
}

.nav.scrolled{
  background:rgba(245,240,232,0.96);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--rule);
}

/* On pages with a full-bleed hero image the nav sits over dark artwork —
   switch logo + links to white until the user scrolls and the cream bar appears. */
.has-hero .nav:not(.scrolled) .nav__logo,
.has-hero .nav:not(.scrolled) .nav__links a{
  color:var(--white);
}
.has-hero .nav:not(.scrolled) .nav__hamburger span{
  background:var(--white);
}

.nav__inner{
  display:flex;align-items:center;
  justify-content:space-between;width:100%;
}

.nav__logo{
  font-family:var(--font-display);
  font-size:1.3rem;font-weight:400;letter-spacing:0.02em;
  color:var(--charcoal);transition:opacity var(--fast);
}
.nav__logo:hover{opacity:0.6}
.nav__logo em{font-style:italic;font-weight:300;opacity:0.7}

.nav__links{
  display:flex;align-items:center;gap:2.25rem;
}
.nav__links a{
  font-family:var(--font-ui);
  font-size:0.67rem;font-weight:400;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--charcoal);opacity:0.65;
  transition:opacity var(--fast);
  position:relative;
}
.nav__links a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--taupe);
  transition:width var(--mid) var(--ease-out);
}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after,
.nav__links a.active::after{width:100%}
.nav__links a.active{opacity:1}

.nav__hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;padding:4px;
}
.nav__hamburger span{
  display:block;width:22px;height:1px;
  background:var(--charcoal);
  transition:transform var(--mid) var(--ease-io),opacity var(--fast);
}
.nav__hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav__hamburger.open span:nth-child(2){opacity:0}
.nav__hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.nav__mobile{
  display:none;position:fixed;
  top:calc(var(--banner-h) + var(--nav-h));left:0;right:0;
  background:var(--cream-light);
  border-top:1px solid var(--rule);
  box-shadow:0 8px 24px rgba(0,0,0,0.08);
  flex-direction:column;padding:2rem var(--pad);gap:1.5rem;
  z-index:99;
}
.nav__mobile.open{display:flex}
.nav__mobile a{
  font-family:var(--font-ui);
  font-size:0.8rem;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--charcoal);
  opacity:0.7;transition:opacity var(--fast);
}
.nav__mobile a:hover{opacity:1}

/* =====================
   EXHIBITION BANNER
   ===================== */

/* Home page renders the banner, so reserve space up front (JS refines this to
   the exact measured height, and resets it to 0 when the banner is dismissed). */
body.has-banner{ --banner-h:52px; }
/* On narrow screens the banner wraps to two lines — increase the fallback so
   the nav doesn't sit under the bottom edge of the banner before JS measures. */
@media (max-width:600px){
  body.has-banner{ --banner-h:76px; }
}
.exhibition-banner{
  background:var(--taupe);
  color:var(--white);
  text-align:center;
  padding:1.05rem 3rem;
  font-family:var(--font-ui);
  font-size:0.72rem;
  line-height:1.45;
  letter-spacing:0.18em;
  text-transform:uppercase;
  position:fixed;
  top:0;left:0;right:0;
  z-index:300;
}
.exhibition-banner a{
  text-decoration:underline;text-underline-offset:3px;opacity:0.85;
}
.exhibition-banner a:hover{opacity:1}

/* =====================
   HERO
   ===================== */

.hero{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:100vh;overflow:hidden;
  padding-top:calc(var(--nav-h) + var(--banner-h));
}

.hero__content{
  display:flex;flex-direction:column;
  justify-content:center;
  padding:clamp(3rem,6vw,7rem) var(--pad);
}
.hero__eyebrow{margin-bottom:1.5rem}
.hero__title{
  font-size:clamp(2.8rem,5vw,5.5rem);
  font-weight:300;font-style:italic;
  line-height:1.08;margin-bottom:1.75rem;
}
.hero__body{
  font-size:clamp(0.95rem,1.1vw,1.08rem);
  color:var(--gray-warm);line-height:1.85;
  max-width:40ch;margin-bottom:2.5rem;
}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}

.hero__image{
  position:relative;overflow:hidden;
}
.hero__image img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform 1.2s var(--ease-out);
}
.hero:hover .hero__image img{transform:scale(1.02)}
.hero__image::before{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to right,var(--cream) 0%,transparent 18%);
}

/* =====================
   BUTTONS
   ===================== */

.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-family:var(--font-ui);
  font-size:0.68rem;font-weight:400;letter-spacing:0.2em;
  text-transform:uppercase;padding:0.85rem 2rem;
  border:none;transition:all var(--mid) var(--ease-out);
  white-space:nowrap;
}
.btn--primary{background:var(--charcoal);color:var(--white)}
.btn--primary:hover{background:var(--taupe)}
.btn--outline{background:transparent;color:var(--charcoal);border:1px solid var(--rule)}
.btn--outline:hover{border-color:var(--taupe);color:var(--taupe)}
.btn--ghost{
  background:transparent;color:var(--taupe);
  padding:0.4rem 0;border-bottom:1px solid var(--taupe);
}
.btn--ghost:hover{color:var(--charcoal);border-color:var(--charcoal)}
.btn--wide{width:100%;justify-content:center}

/* =====================
   FEATURED WORKS
   ===================== */

.featured{background:var(--cream-light)}
.featured__header{
  display:flex;align-items:flex-end;
  justify-content:space-between;margin-bottom:2.5rem;
}
.featured__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
}
.featured__item{
  position:relative;overflow:hidden;
  aspect-ratio:4/5;cursor:pointer;
}
.featured__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform var(--slow) var(--ease-out);
  pointer-events:none;
}
.featured__item:hover img{transform:scale(1.04)}

.featured__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,12,10,0.72) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.5rem;
  opacity:0;transition:opacity var(--mid) var(--ease-out);
}
.featured__item:hover .featured__overlay{opacity:1}
.featured__overlay h4{
  font-family:var(--font-display);
  font-size:1.35rem;font-style:italic;
  color:var(--white);margin-bottom:0.3rem;
}
.featured__overlay p{
  font-family:var(--font-ui);font-size:0.65rem;
  letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(255,255,255,0.65);
}

/* =====================
   ARTIST INTRO
   ===================== */

.artist-intro{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,7vw,9rem);align-items:center;
}
.artist-intro__image{position:relative}
.artist-intro__image img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
}
.artist-intro__image::after{
  content:'';position:absolute;
  bottom:-2rem;right:-2rem;
  width:55%;height:55%;
  border:1px solid var(--rule);
  z-index:-1;pointer-events:none;
}
.artist-intro__text .eyebrow{margin-bottom:1.25rem}
.artist-intro__text h2{margin-bottom:1.25rem}
.artist-intro__text p{
  color:var(--gray-warm);line-height:1.88;
  margin-bottom:1rem;
}
.artist-intro__text p:last-of-type{margin-bottom:2rem}

/* =====================
   NEWSLETTER
   ===================== */

.newsletter{
  background:var(--charcoal);color:var(--white);
  text-align:center;
}
.newsletter .eyebrow{color:var(--taupe-light);margin-bottom:1.25rem}
.newsletter h2{
  font-size:clamp(1.8rem,3.5vw,3rem);
  color:var(--white);margin-bottom:0.75rem;
}
.newsletter p{
  color:rgba(255,255,255,0.55);font-size:1rem;
  max-width:52ch;margin:0 auto 2.5rem;line-height:1.75;
}
.newsletter__form{
  display:flex;max-width:480px;margin:0 auto;
}
.newsletter__input{
  flex:1;padding:0.9rem 1.25rem;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.14);
  border-right:none;
  color:var(--white);font-family:var(--font-ui);font-size:0.85rem;
  outline:none;transition:border-color var(--fast);
}
.newsletter__input::placeholder{color:rgba(255,255,255,0.3)}
.newsletter__input:focus{border-color:var(--taupe-light)}
.newsletter__btn{
  padding:0.9rem 1.5rem;background:var(--taupe);color:var(--white);
  font-family:var(--font-ui);font-size:0.67rem;
  font-weight:400;letter-spacing:0.2em;text-transform:uppercase;
  border:none;transition:background var(--fast);
}
.newsletter__btn:hover{background:var(--taupe-light)}
.newsletter__note{
  margin-top:0.85rem;font-size:0.7rem;
  color:rgba(255,255,255,0.25);font-family:var(--font-ui);
}

/* =====================
   INSTAGRAM
   ===================== */

.instagram{text-align:center}
.instagram .eyebrow{margin-bottom:1.25rem}
.instagram__handle{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,3vw,2.5rem);margin-bottom:0.4rem;
}
.instagram__sub{color:var(--gray-warm);margin-bottom:2.5rem}
.instagram__grid{
  display:grid;grid-template-columns:repeat(6,1fr);
  gap:3px;margin-bottom:2rem;
}
.instagram__cell{
  aspect-ratio:1;overflow:hidden;
  background:var(--taupe-pale);
}
.instagram__cell img{
  width:100%;height:100%;object-fit:cover;
  transition:transform var(--slow) var(--ease-out);
}
.instagram__cell:hover img{transform:scale(1.06)}

/* =====================
   FOOTER
   ===================== */

.footer{
  background:var(--charcoal-soft);
  color:rgba(255,255,255,0.45);
  padding:2.75rem 0;
}
.footer__inner{
  display:flex;align-items:center;
  justify-content:space-between;gap:2rem;flex-wrap:wrap;
}
.footer__logo{
  font-family:var(--font-display);
  font-size:1.1rem;color:rgba(255,255,255,0.7);
}
.footer__nav{display:flex;gap:1.75rem;flex-wrap:wrap}
.footer__nav a{
  font-family:var(--font-ui);font-size:0.66rem;
  letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.38);
  transition:color var(--fast);
}
.footer__nav a:hover{color:rgba(255,255,255,0.75)}
.footer__copy{font-family:var(--font-ui);font-size:0.68rem}
.footer__social{display:flex;gap:1.25rem}
.footer__social a{
  font-family:var(--font-ui);font-size:0.66rem;
  letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.38);
  transition:color var(--fast);
}
.footer__social a:hover{color:var(--taupe-light)}

/* =====================
   PAGE HEADER (inner pages)
   ===================== */

.page-header{
  padding-top:calc(var(--nav-h) + 4rem);
  padding-bottom:3rem;
  border-bottom:1px solid var(--rule);
  margin-bottom:3rem;
}
.page-header .eyebrow{margin-bottom:0.75rem}
.page-header h1{font-weight:300;font-style:italic}
.page-header p{
  color:var(--gray-warm);max-width:56ch;
  margin-top:1rem;font-size:1.05rem;line-height:1.8;
}

/* Page hero (full-bleed with image) */
.page-hero{
  padding-top:var(--nav-h);
  min-height:50vh;display:flex;align-items:flex-end;
  position:relative;overflow:hidden;
}
.page-hero--tall{min-height:65vh}
.page-hero__bg{
  position:absolute;inset:0;
  object-fit:cover;width:100%;height:100%;
  pointer-events:none;
}
.page-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,16,13,0.7) 0%,rgba(20,16,13,0.15) 100%);
}
.page-hero__content{
  position:relative;z-index:2;
  padding:4rem var(--pad);width:100%;
  max-width:var(--max-w);margin:0 auto;
}
.page-hero__content .eyebrow{color:rgba(255,255,255,0.55);margin-bottom:0.75rem}
.page-hero__content h1{color:var(--white);font-weight:300;font-style:italic}

/* =====================
   GALLERY FILTERS
   ===================== */

.gallery-filters{
  display:flex;gap:0;
  border-bottom:1px solid var(--rule);
  margin-bottom:2.5rem;
}
.filter-btn{
  font-family:var(--font-ui);font-size:0.67rem;
  font-weight:400;letter-spacing:0.18em;text-transform:uppercase;
  padding:0.8rem 1.5rem;background:none;border:none;
  color:var(--gray-warm);position:relative;
  transition:color var(--fast);
}
.filter-btn::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;
  height:2px;background:var(--charcoal);
  transform:scaleX(0);
  transition:transform var(--mid) var(--ease-out);
}
.filter-btn.active{color:var(--charcoal)}
.filter-btn.active::after{transform:scaleX(1)}
.filter-btn:hover{color:var(--charcoal)}

/* =====================
   MASONRY GALLERY
   ===================== */

.masonry{
  columns:3;column-gap:5px;
}
.masonry__item{
  break-inside:avoid;margin-bottom:5px;
  position:relative;overflow:hidden;cursor:pointer;
  display:block;
}
.masonry__item img{
  width:100%;height:auto;display:block;
  transition:transform var(--slow) var(--ease-out);
  pointer-events:none;
}
.masonry__item:hover img{transform:scale(1.025)}

/* JKB-style overlay */
.masonry__overlay{
  position:absolute;inset:0;
  background:rgba(20,16,13,0.54);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.25rem 1.5rem;
  opacity:0;
  transition:opacity var(--mid) var(--ease-out);
}
.masonry__item:hover .masonry__overlay{opacity:1}

.masonry__title{
  font-family:var(--font-display);
  font-size:1.35rem;font-style:italic;
  color:var(--white);margin-bottom:0.25rem;
  transform:translateY(8px);
  transition:transform var(--mid) var(--ease-out);
}
.masonry__item:hover .masonry__title{transform:translateY(0)}

.masonry__meta{
  font-family:var(--font-ui);font-size:0.63rem;
  letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.6);
  transform:translateY(8px);
  transition:transform var(--mid) var(--ease-out) 40ms;
}
.masonry__item:hover .masonry__meta{transform:translateY(0)}

.masonry__badge{
  display:inline-block;
  font-family:var(--font-ui);font-size:0.58rem;
  letter-spacing:0.14em;text-transform:uppercase;
  padding:0.18rem 0.55rem;
  border:1px solid rgba(255,255,255,0.38);
  color:rgba(255,255,255,0.75);
  margin-top:0.45rem;
}
.masonry__badge--sold{
  border-color:rgba(255,255,255,0.2);
  color:rgba(255,255,255,0.4);
}
.masonry__badge--print{
  border-color:var(--taupe-light);
  color:var(--taupe-light);
}

/* Gallery count */
.gallery-count{
  font-family:var(--font-ui);font-size:0.7rem;
  letter-spacing:0.08em;color:var(--gray-light);
  margin-bottom:1.5rem;
}

/* =====================
   ARTWORK MODAL
   ===================== */

.modal-backdrop{
  position:fixed;inset:0;z-index:200;
  background:rgba(8,6,4,0.88);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity var(--mid) var(--ease-out),visibility var(--mid);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:1rem;
}
.modal-backdrop.open{opacity:1;visibility:visible}

.modal{
  background:var(--cream);
  display:grid;grid-template-columns:1fr 360px;
  max-width:min(1100px,95vw);
  max-height:92vh;width:100%;
  overflow:hidden;
  transform:translateY(22px) scale(0.99);
  transition:transform var(--mid) var(--ease-out);
  position:relative;
}
.modal-backdrop.open .modal{transform:translateY(0) scale(1)}

.modal__image-pane{
  background:var(--cream-dark);
  display:flex;align-items:center;justify-content:center;
  padding:2.5rem;overflow:hidden;min-height:300px;
}
.modal__image-pane img{
  max-width:100%;max-height:80vh;
  width:auto;height:auto;object-fit:contain;
  pointer-events:none;user-select:none;
}

.modal__info{
  padding:2.25rem 1.75rem;
  display:flex;flex-direction:column;
  overflow-y:auto;
  border-left:1px solid var(--rule);
}
.modal__close{
  position:absolute;top:1rem;right:1rem;
  background:rgba(245,240,232,0.92);
  border:none;width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.05rem;color:var(--charcoal);
  transition:background var(--fast);z-index:5;
}
.modal__close:hover{background:var(--white)}

.modal__eyebrow{margin-bottom:0.65rem}

.modal__title{
  font-family:var(--font-display);
  font-size:1.85rem;font-style:italic;
  color:var(--charcoal);margin-bottom:0.25rem;line-height:1.2;
}

.modal__details{
  margin:1.25rem 0;display:flex;flex-direction:column;gap:0.55rem;
}
.modal__detail{display:flex;gap:0.75rem;align-items:baseline}
.modal__detail .lbl{
  font-family:var(--font-ui);font-size:0.62rem;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gray-light);min-width:75px;
}
.modal__detail .val{
  font-family:var(--font-body);font-size:0.9rem;
  color:var(--charcoal);
}

.modal__divider{border:none;border-top:1px solid var(--rule);margin:1.25rem 0}

.modal__description{
  font-family:var(--font-body);font-size:0.92rem;
  color:var(--gray-warm);line-height:1.85;
  flex:1;margin-bottom:1.5rem;
}

.modal__status-tag{
  display:inline-block;
  font-family:var(--font-ui);font-size:0.6rem;
  letter-spacing:0.18em;text-transform:uppercase;
  padding:0.25rem 0.75rem;
  border:1px solid var(--taupe);color:var(--taupe);
  margin-bottom:1.25rem;
}
.modal__status-tag--sold{
  border-color:var(--rule);color:var(--gray-light);
}
.modal__status-tag--print{
  border-color:var(--taupe-light);color:var(--taupe-light);
}

.modal__cta{margin-top:auto}
.modal__cta .btn{margin-bottom:0.6rem;width:100%;justify-content:center}
.modal__cta-note{
  font-family:var(--font-ui);font-size:0.65rem;
  color:var(--gray-light);text-align:center;
}

/* =====================
   ABOUT PAGE
   ===================== */

.about-layout{
  display:grid;grid-template-columns:2fr 3fr;
  gap:clamp(3rem,6vw,8rem);align-items:start;
}
.about-portrait{
  position:sticky;top:calc(var(--nav-h) + 2rem);
}
.about-portrait img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
}
.about-portrait figcaption{
  margin-top:0.85rem;
  font-family:var(--font-ui);font-size:0.65rem;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--gray-light);
}

.about-text h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:1.5rem}
.about-text p{
  color:var(--gray-warm);line-height:1.92;
  margin-bottom:1.25rem;font-size:1.02rem;
}

.artist-statement{
  background:var(--cream-dark);
  padding:clamp(2.5rem,5vw,4.5rem) clamp(2rem,4vw,4.5rem);
  margin:3rem 0;position:relative;
}
.artist-statement::before{
  content:'\201C';
  font-family:var(--font-display);font-size:9rem;
  color:var(--taupe-pale);position:absolute;
  top:-1.5rem;left:1.5rem;line-height:1;
  pointer-events:none;
}
.artist-statement p{
  font-family:var(--font-display);
  font-size:clamp(1.35rem,2.2vw,1.85rem);
  font-style:italic;color:var(--charcoal);
  line-height:1.6;position:relative;z-index:1;
}

.about-credits{margin-top:3rem}
.about-credits h3{margin-bottom:1.5rem}
.credential{
  display:flex;gap:1rem;padding:1rem 0;
  border-top:1px solid var(--rule);
}
.credential:last-child{border-bottom:1px solid var(--rule)}
.credential__year{
  font-family:var(--font-ui);font-size:0.7rem;
  letter-spacing:0.1em;color:var(--taupe-deep);
  min-width:50px;padding-top:0.1rem;
}
.credential__detail{font-size:0.95rem;color:var(--gray-warm)}

/* =====================
   COMMISSIONS PAGE
   ===================== */

.commission-intro{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,6vw,8rem);align-items:center;
}
.commission-intro__image img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
}

.process-steps{counter-reset:step;margin-top:3rem}
.process-step{
  display:grid;grid-template-columns:80px 1fr;
  gap:1.75rem;padding:2.25rem 0;
  border-bottom:1px solid var(--rule);
}
.process-step:last-child{border-bottom:none}
.step-num{
  font-family:var(--font-display);font-size:3.5rem;
  color:var(--taupe-deep);font-weight:500;line-height:1;
  text-align:right;padding-top:0.2rem;
}
.step-body h3{
  font-size:1.25rem;margin-bottom:0.5rem;
}
.step-body p{color:var(--gray-warm);line-height:1.82}

.commission-faq{margin-top:4rem}
.commission-faq h2{margin-bottom:2.5rem}
.faq-item{padding:1.75rem 0;border-top:1px solid var(--rule)}
.faq-item:last-child{border-bottom:1px solid var(--rule)}
.faq-item h4{margin-bottom:0.65rem}
.faq-item p{color:var(--gray-warm);line-height:1.8;font-size:0.97rem}

/* =====================
   EXHIBITIONS PAGE
   ===================== */

.exhibition-entry{
  display:grid;grid-template-columns:120px 1fr;
  gap:2rem;padding:2.5rem 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
}
.exhibition-entry:first-child{border-top:1px solid var(--rule)}
.exhibition-date .month{
  font-family:var(--font-ui);font-size:0.7rem;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--taupe-deep);display:block;
}
.exhibition-date .year{
  font-family:var(--font-display);font-size:2.5rem;font-weight:500;
  color:var(--taupe-deep);line-height:1;
}

.exhibition-badge{
  display:inline-block;
  font-family:var(--font-ui);font-size:0.6rem;
  letter-spacing:0.2em;text-transform:uppercase;
  padding:0.2rem 0.7rem;border:1px solid;
  margin-bottom:0.65rem;
}
.exhibition-badge--current{color:var(--taupe);border-color:var(--taupe)}
.exhibition-badge--upcoming{color:var(--gray-warm);border-color:var(--rule)}
.exhibition-badge--past{color:var(--gray-light);border-color:var(--rule)}

.exhibition-body h3{font-size:1.3rem;margin-bottom:0.25rem}
.exhibition-venue{
  font-family:var(--font-ui);font-size:0.78rem;
  color:var(--taupe-deep);letter-spacing:0.04em;margin-bottom:0.65rem;
}
.exhibition-body p{color:var(--gray-warm);font-size:0.93rem;line-height:1.75}

/* =====================
   REPRESENTATION PAGE
   ===================== */

.rep-mosaic{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;margin-bottom:4rem;
}
.rep-mosaic__cell{
  aspect-ratio:1;overflow:hidden;background:var(--cream-dark);
}
.rep-mosaic__cell img{
  width:100%;height:100%;object-fit:cover;
  transition:transform var(--slow) var(--ease-out);
}
.rep-mosaic__cell:hover img{transform:scale(1.04)}

.rep-inquiry{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,6vw,8rem);align-items:start;
}
.rep-info h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:1rem}
.rep-info p{color:var(--gray-warm);line-height:1.85;margin-bottom:1.25rem}
.rep-info ul{margin:1.5rem 0;display:flex;flex-direction:column;gap:0.6rem}
.rep-info ul li{
  font-family:var(--font-ui);font-size:0.78rem;
  letter-spacing:0.06em;color:var(--charcoal);
  padding-left:1.25rem;position:relative;
}
.rep-info ul li::before{
  content:'—';position:absolute;left:0;
  color:var(--taupe);
}

/* =====================
   CONTACT PAGE
   ===================== */

.contact-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,6vw,8rem);align-items:start;
}
.contact-info h2{
  font-size:clamp(1.8rem,3.5vw,3rem);margin-bottom:1rem;
}
.contact-info p{
  color:var(--gray-warm);line-height:1.85;margin-bottom:2rem;font-size:1rem;
}

.contact-detail{
  display:flex;gap:1.25rem;
  padding:1.25rem 0;border-top:1px solid var(--rule);
}
.contact-detail:last-child{border-bottom:1px solid var(--rule)}
.contact-detail__label{
  font-family:var(--font-ui);font-size:0.64rem;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--taupe);min-width:80px;padding-top:0.15rem;
}
.contact-detail__value{font-size:0.95rem;color:var(--charcoal)}
.contact-detail__value a:hover{color:var(--taupe);text-decoration:underline}

/* Icon-based contact list (no divider lines) */
.contact-list{margin:1.75rem 0 0;display:flex;flex-direction:column;gap:1.1rem}
.contact-list__item{display:flex;align-items:center;gap:0.9rem}
.contact-list__icon{
  flex-shrink:0;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--cream-dark);color:var(--taupe-deep);
}
.contact-list__icon svg{width:18px;height:18px}
.contact-list__text{font-size:0.97rem;color:var(--charcoal);line-height:1.4}
.contact-list__text a{color:var(--charcoal)}
.contact-list__text a:hover{color:var(--taupe-deep);text-decoration:underline}

/* Social brand icon buttons */
.contact-socials{margin-top:2rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.contact-socials__label{
  font-family:var(--font-ui);font-size:0.64rem;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--taupe-deep);
}
.contact-socials__icons{display:flex;gap:0.65rem}
.social-btn{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--charcoal);color:var(--white);
  transition:background var(--fast),transform var(--fast);
}
.social-btn svg{width:20px;height:20px}
.social-btn:hover{background:var(--taupe-deep);transform:translateY(-2px)}

.contact-aside{margin-top:2.5rem}
.contact-photo{margin-top:2rem}
.contact-photo img{width:100%;max-width:400px;aspect-ratio:4/3;object-fit:cover}

/* =====================
   LEGAL / POLICY PAGES
   ===================== */

.legal{max-width:760px}
.legal h2{font-size:clamp(1.3rem,2.2vw,1.7rem);margin:2.25rem 0 0.75rem}
.legal p{color:var(--gray-warm);line-height:1.85;margin-bottom:1rem;font-size:0.97rem}
.legal a{color:var(--taupe-deep);text-decoration:underline}
.legal strong{color:var(--charcoal)}

/* =====================
   FORMS
   ===================== */

.form-group{margin-bottom:1.4rem}
.form-label{
  display:block;
  font-family:var(--font-ui);font-size:0.63rem;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gray-warm);margin-bottom:0.45rem;
}
.form-control{
  width:100%;padding:0.78rem 1rem;
  background:var(--cream-light);
  border:1px solid var(--rule);
  color:var(--charcoal);
  font-family:var(--font-body);font-size:0.97rem;
  outline:none;transition:border-color var(--fast);
  border-radius:0;-webkit-appearance:none;
}
.form-control:focus{border-color:var(--taupe)}
textarea.form-control{resize:vertical;min-height:130px}
select.form-control{
  cursor:pointer;
  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='%238C7A5E' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center;
  padding-right:2.5rem;
}

.form-note{
  font-family:var(--font-ui);font-size:0.7rem;
  color:var(--gray-light);margin-top:0.4rem;
}

/* =====================
   TESTIMONIALS / PULL QUOTES
   ===================== */

.pull-quote{
  border-left:2px solid var(--taupe);
  padding:0.5rem 0 0.5rem 1.75rem;
  margin:2.5rem 0;
}
.pull-quote p{
  font-family:var(--font-display);
  font-size:clamp(1.25rem,2vw,1.6rem);
  font-style:italic;color:var(--charcoal);
  line-height:1.5;
}
.pull-quote cite{
  display:block;margin-top:0.75rem;
  font-family:var(--font-ui);font-size:0.68rem;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--taupe);font-style:normal;
}

/* =====================
   SCROLL REVEAL
   ===================== */

.reveal{
  opacity:0;transform:translateY(22px);
  transition:opacity var(--slow) var(--ease-out),
              transform var(--slow) var(--ease-out);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:80ms}
.reveal-delay-2{transition-delay:160ms}
.reveal-delay-3{transition-delay:240ms}

/* =====================
   LOADING SKELETON
   ===================== */

.skeleton{
  background:linear-gradient(90deg,var(--cream-dark) 25%,var(--rule) 37%,var(--cream-dark) 63%);
  background-size:400px 100%;
  animation:skeleton-loading 1.4s ease infinite;
  min-height:200px;
}
@keyframes skeleton-loading{
  0%{background-position:-400px 0}
  100%{background-position:400px 0}
}

/* =====================
   COPYRIGHT WATERMARK
   ===================== */

.art-wrap{position:relative;display:inline-block;width:100%}
.art-wrap::after{
  content:'© Amy Bianconi';
  position:absolute;bottom:6px;right:8px;
  font-family:var(--font-ui);font-size:0.55rem;
  letter-spacing:0.06em;
  color:rgba(255,255,255,0.35);
  pointer-events:none;z-index:2;
}

/* =====================
   UTILITY
   ===================== */

.text-center{text-align:center}
.text-italic{font-style:italic}
.color-taupe{color:var(--taupe)}
.mb-1{margin-bottom:0.5rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.5rem}
.mb-4{margin-bottom:2rem}
.mb-6{margin-bottom:3rem}
.mt-auto{margin-top:auto}
.gap-1{gap:0.5rem}
.flex{display:flex}
.flex-col{flex-direction:column}
.align-center{align-items:center}
.hidden{display:none !important}

/* =====================
   ADMIN PANEL
   ===================== */

.admin-login{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;background:var(--charcoal);
}
.admin-login__box{
  background:var(--cream);padding:3rem;width:100%;max-width:400px;
  text-align:center;
}
.admin-login__box h2{margin-bottom:0.5rem}
.admin-login__box p{color:var(--gray-warm);margin-bottom:2rem;font-size:0.9rem}
.admin-login__box .form-control{margin-bottom:1rem}

.admin-nav{
  background:var(--charcoal);color:var(--white);
  padding:0 2rem;height:60px;display:flex;
  align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:50;
}
.admin-nav h1{font-size:1rem;font-family:var(--font-ui);font-weight:300;letter-spacing:0.1em}
.admin-nav a{
  font-family:var(--font-ui);font-size:0.7rem;letter-spacing:0.1em;
  color:rgba(255,255,255,0.55);transition:color var(--fast);
}
.admin-nav a:hover{color:rgba(255,255,255,0.9)}

.admin-sidebar{
  width:220px;background:var(--cream-light);
  border-right:1px solid var(--rule);
  padding:2rem 0;position:fixed;
  top:60px;bottom:0;left:0;overflow-y:auto;
}
.admin-sidebar nav a{
  display:block;padding:0.65rem 1.75rem;
  font-family:var(--font-ui);font-size:0.7rem;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gray-warm);transition:all var(--fast);
  border-left:2px solid transparent;
}
.admin-sidebar nav a:hover,
.admin-sidebar nav a.active{
  color:var(--charcoal);border-left-color:var(--taupe);
  background:var(--cream);
}

.admin-main{
  margin-left:220px;padding:2.5rem;min-height:calc(100vh - 60px);
}
.admin-section{display:none}
.admin-section.active{display:block}

.admin-section h2{
  font-size:1.5rem;margin-bottom:0.35rem;
}
.admin-section .admin-subtitle{
  color:var(--gray-warm);font-size:0.85rem;margin-bottom:2rem;
}

.admin-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1.5rem;
}
.admin-card{
  background:var(--white);border:1px solid var(--rule);
  overflow:hidden;
}
.admin-card__img{
  aspect-ratio:4/3;overflow:hidden;background:var(--cream-dark);
}
.admin-card__img img{
  width:100%;height:100%;object-fit:cover;
}
.admin-card__body{padding:1rem}
.admin-card__title{
  font-family:var(--font-display);font-size:1rem;font-style:italic;
  margin-bottom:0.25rem;
}
.admin-card__meta{
  font-family:var(--font-ui);font-size:0.65rem;
  letter-spacing:0.08em;color:var(--gray-light);margin-bottom:0.75rem;
}
.admin-card__actions{display:flex;gap:0.5rem;flex-wrap:wrap}
.admin-btn{
  font-family:var(--font-ui);font-size:0.62rem;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:0.3rem 0.75rem;border:1px solid var(--rule);
  background:none;color:var(--gray-warm);transition:all var(--fast);
}
.admin-btn:hover{border-color:var(--taupe);color:var(--taupe)}
.admin-btn--danger:hover{border-color:#c0392b;color:#c0392b}

.admin-modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,0.5);
  z-index:300;display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:all var(--fast);
}
.admin-modal-backdrop.open{opacity:1;visibility:visible}
.admin-modal{
  background:var(--cream);padding:2rem;width:100%;max-width:540px;
  max-height:90vh;overflow-y:auto;
}
.admin-modal h3{margin-bottom:1.5rem}

.admin-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem;
}
.admin-success{
  background:#d4edda;color:#155724;
  padding:0.75rem 1rem;font-family:var(--font-ui);font-size:0.8rem;
  margin-bottom:1.5rem;display:none;
}

/* =====================
   RESPONSIVE
   ===================== */

@media (max-width:1024px){
  .hero{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .hero__content{
    padding-top:4rem;padding-bottom:3rem;
    order:1;
  }
  .hero__image{
    order:0;height:55vw;min-height:280px;
  }
  .hero__image::before{
    background:linear-gradient(to bottom,var(--cream) 0%,transparent 20%);
  }
  .artist-intro{grid-template-columns:1fr}
  .artist-intro__image::after{display:none}
  .about-layout{grid-template-columns:1fr}
  .about-portrait{position:static;max-width:360px}
  .commission-intro{grid-template-columns:1fr}
  .contact-layout{grid-template-columns:1fr}
  .rep-inquiry{grid-template-columns:1fr}
  .modal{
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
    height:92vh;
    max-height:92vh;
    overflow:hidden;
  }
  .modal__image-pane{max-height:45vh;overflow:hidden;flex-shrink:0}
  /* min-height:0 is required so a grid child can shrink below its content
     size and allow overflow-y:auto to actually scroll. */
  .modal__info{border-left:none;border-top:1px solid var(--rule);overflow-y:auto;min-height:0}
}

/* Exhibitions page — Join button centred beneath the email input */
.newsletter__form--centered{
  flex-direction:column;
  align-items:center;
}
.newsletter__form--centered .newsletter__input{
  border-right:1px solid rgba(255,255,255,0.14);
  border-bottom:none;
  width:100%;
  max-width:360px;
}
.newsletter__form--centered .newsletter__btn{
  width:auto;
  min-width:120px;
}

@media (max-width:768px){
  .nav__links{display:none}
  .nav__hamburger{display:flex}
  .masonry{columns:2}
  .featured__grid{grid-template-columns:1fr 1fr}
  .instagram__grid{grid-template-columns:repeat(3,1fr)}
  .exhibition-entry{
    grid-template-columns:1fr;gap:0.65rem;
  }
  .exhibition-date{display:flex;align-items:center;gap:0.65rem}
  .exhibition-date .year{font-size:1.8rem}
  .footer__inner{flex-direction:column;text-align:center}
  .footer__nav{flex-wrap:wrap;justify-content:center;gap:0.85rem}
  .process-step{grid-template-columns:55px 1fr;gap:1rem}
  .step-num{font-size:2.5rem}
  .newsletter__form{flex-direction:column}
  .newsletter__input{border-right:1px solid rgba(255,255,255,0.14);border-bottom:none}
  .rep-mosaic{grid-template-columns:1fr 1fr}
  .admin-sidebar{display:none}
  .admin-main{margin-left:0}
}

@media (max-width:480px){
  .masonry{columns:1}
  .featured__grid{grid-template-columns:1fr}
  .instagram__grid{grid-template-columns:repeat(2,1fr)}
  .hero__actions{flex-direction:column}
  .rep-mosaic{grid-template-columns:1fr}
  .gallery-filters{flex-wrap:wrap}
  .filter-btn{padding:0.7rem 1rem}
}
