/* ============================================================
   Christy Young | Fine Artist · Oil Painter
   ============================================================ */

/* ---------- self-hosted display face: Felix Titling (Monotype) ----------
   Titling caps, used for headers/titles via --serif. Body copy uses
   Cormorant Garamond (--body). Fallback chain: Cormorant Garamond,
   then Georgia / generic serif. */
@font-face{
  font-family:"Felix Titling";
  src:url("fonts/felix-titling.woff2") format("woff2"),
      url("fonts/felix-titling.woff") format("woff"),
      url("fonts/felix-titling.ttf") format("truetype");
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}

/* ---------- body face: Cormorant Garamond, self-hosted (was Google Fonts) ----------
   Self-hosting drops the gstatic round-trips and lets us preload the italic weight
   the hero epigraph (the LCP element) is set in, so the final text paint is not
   waiting on a third-party font chain. Latin subset; variable file covers 400-600. */
@font-face{
  font-family:"Cormorant Garamond";
  src:url("fonts/cormorant-garamond-latin.woff2") format("woff2");
  font-weight:400 600;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Cormorant Garamond";
  src:url("fonts/cormorant-garamond-italic-latin.woff2") format("woff2");
  font-weight:400;
  font-style:italic;
  font-display:swap;
}

:root{
  /* palette */
  --cream:#c8bdb0;        /* warm taupe background */
  --cream-deep:#b9aa9a;   /* alt band */
  --ink:#2d1830;          /* deep plum/aubergine */
  --white:#f5f0e8;        /* warm off-white */
  --crimson:#7a4060;      /* muted plum accent */
  --crimson-link:#6a3052; /* menu links */
  --crimson-deep:#5a2044; /* button hover */
  --grey:#5a4652;         /* mid plum-grey */
  --tan:#9a8572;          /* warm tan */
  --tan-deep:#8a7060;     /* line */

  --serif:"Felix Titling", "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --body:"Cormorant Garamond", Georgia, "Times New Roman", serif;

  --maxw:1180px;
  --pad:clamp(1.25rem, 4vw, 2.5rem);
  --section-y:clamp(4.5rem, 9vw, 8rem);
  --radius:6.4px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  font-weight:400;
  font-size:clamp(1.02rem,1.05vw,1.15rem);
  line-height:1.8;
  color:var(--ink);
  background:var(--cream);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.menu-open{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.25;
  letter-spacing:0;
}
h1{font-size:clamp(3rem,9vw,7rem);line-height:1.02}
h2{font-size:clamp(2rem,5vw,3.4rem)}
h3{font-size:clamp(1.4rem,2.6vw,2rem)}
p{margin:0 0 1.1em}
p:last-child{margin-bottom:0}

.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding-top:var(--section-y);padding-bottom:var(--section-y)}
.band-cream-deep{background:var(--cream-deep)}
.center{text-align:center}

/* eyebrow / kicker */
.eyebrow{
  font-family:var(--body);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.74rem;
  color:var(--crimson);
  margin-bottom:1.4rem;
}

/* lead paragraph */
.lead{font-size:clamp(1.12rem,1.4vw,1.32rem);line-height:1.75}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--serif);
  font-size:1rem;
  font-weight:400;
  letter-spacing:.02em;
  line-height:1.2;
  padding:1.2em 2.004em;
  border-radius:var(--radius);
  border:1px solid var(--ink);
  cursor:pointer;
  transition:background .35s ease,color .35s ease,border-color .35s ease,transform .35s ease;
  text-align:center;
}
.btn-primary{background:var(--crimson);color:var(--white);border-color:var(--crimson)}
.btn-primary:hover{background:var(--crimson-deep);border-color:var(--crimson-deep)}
.btn-outline{background:transparent;color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--cream)}
.btn + .btn{margin-left:.85rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.btn-row.center{justify-content:center}

/* text link with underline grow */
.link-underline{
  font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.18em;font-size:.8rem;color:var(--crimson);
  display:inline-block;position:relative;padding-bottom:3px;
}
.link-underline::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--crimson);transform:scaleX(.0);transform-origin:left;transition:transform .4s ease}
.link-underline:hover::after{transform:scaleX(1)}

/* ---------- vesica piscis motif ---------- */
.vesica{width:74px;height:48px;margin:0 auto 1.6rem;display:block}
.vesica circle{fill:none;stroke:var(--tan-deep);stroke-width:1.1}
.vesica .seed{stroke:var(--crimson);opacity:.55}
.divider-motif{display:flex;align-items:center;justify-content:center;gap:1.2rem;color:var(--tan-deep)}
.divider-motif::before,.divider-motif::after{content:"";height:1px;width:min(120px,16vw);background:var(--tan-deep);opacity:.7}

/* ============================================================
   HEADER  (transparent, sticky, hamburger only, like reference)
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.2rem var(--pad);
  transition:background .4s ease,padding .4s ease,box-shadow .4s ease;
}
.site-header.scrolled{background:rgba(200,189,176,.94);backdrop-filter:blur(6px);
  box-shadow:0 1px 0 rgba(23,23,23,.06);padding:.8rem var(--pad)}
.site-title{
  font-family:var(--serif);font-size:clamp(1.4rem,2.2vw,2rem);
  color:var(--white);letter-spacing:.01em;line-height:1;white-space:nowrap;
  transition:color .4s ease;
}
.site-title span{display:block;font-family:var(--body);font-weight:600;
  font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(245,240,232,.72);margin-top:.35rem;transition:color .4s ease}
.site-header.scrolled .site-title{color:var(--ink)}
.site-header.scrolled .site-title span{color:var(--crimson)}

/* burger */
.burger{display:flex;flex-direction:column;justify-content:center;gap:6px;
  width:44px;height:44px;background:none;border:0;cursor:pointer;align-items:flex-end}
.burger span{display:block;height:2px;width:30px;background:var(--white);transition:transform .4s ease,opacity .3s ease,background .3s ease}
.site-header.scrolled .burger span{background:var(--ink)}
body.menu-open .burger span{background:var(--crimson-link)}
body.menu-open .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* fullscreen overlay menu */
.nav-overlay{
  position:fixed;inset:0;z-index:999;background:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease;
}
body.menu-open .nav-overlay{opacity:1;visibility:visible}
.nav-overlay ul{list-style:none;text-align:center}
.nav-overlay li{margin:.35em 0;opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
body.menu-open .nav-overlay li{opacity:1;transform:none}
body.menu-open .nav-overlay li:nth-child(1){transition-delay:.12s}
body.menu-open .nav-overlay li:nth-child(2){transition-delay:.18s}
body.menu-open .nav-overlay li:nth-child(3){transition-delay:.24s}
body.menu-open .nav-overlay li:nth-child(4){transition-delay:.30s}
body.menu-open .nav-overlay li:nth-child(5){transition-delay:.36s}
body.menu-open .nav-overlay li:nth-child(6){transition-delay:.42s}
body.menu-open .nav-overlay li:nth-child(7){transition-delay:.48s}
.nav-overlay a{
  font-family:var(--body);font-weight:600;color:var(--crimson-link);
  font-size:clamp(1.7rem,4vmin,3rem);letter-spacing:.06em;text-transform:uppercase;
  transition:color .3s ease,letter-spacing .3s ease;
}
.nav-overlay a:hover{color:var(--ink);letter-spacing:.12em}
.nav-overlay .nav-foot{margin-top:2.6rem;font-family:var(--body);font-size:.85rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--grey)}
.nav-overlay .nav-foot a{font-size:.85rem;color:var(--grey);letter-spacing:.18em}
.nav-overlay .nav-foot a:hover{color:var(--crimson)}

/* ============================================================
   HERO  (text on cream, name + tagline + epigraph)
   ============================================================ */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:8rem var(--pad) 5rem;position:relative;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}
.hero-overlay{position:absolute;inset:0;background:rgba(14,8,12,.48);z-index:1}
.hero .container{position:relative;z-index:2}
.hero-logo{width:clamp(80px,12vw,130px);height:auto;margin:0 auto 1.8rem;display:block;
  filter:brightness(0) invert(1);opacity:.85}
.hero .eyebrow{margin-bottom:1.8rem;color:rgba(245,240,232,.75)}
.hero h1{color:var(--white);margin-bottom:1.4rem;font-size:clamp(2.4rem,6vw,5rem)}
.hero .epigraph{font-style:italic;font-size:clamp(1.15rem,2vw,1.6rem);
  color:rgba(245,240,232,.8);max-width:42ch;margin:0 auto 2.4rem;line-height:1.6}
.hero .epigraph cite{display:block;font-style:normal;font-size:.8rem;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(245,240,232,.6);margin-top:1rem}
.hero .btn-outline{color:var(--white);border-color:rgba(245,240,232,.7)}
.hero .btn-outline:hover{background:var(--white);color:var(--ink)}
.scroll-cue{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);z-index:2;
  font-family:var(--body);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(245,240,232,.6)}
.scroll-cue span{display:block;width:1px;height:42px;background:rgba(245,240,232,.45);margin:.7rem auto 0;animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ============================================================
   ABOUT  (portrait + statement)
   ============================================================ */
.about-grid{display:grid;grid-template-columns:0.85fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.about-portrait{position:relative}
.about-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center top;border-radius:2px}
.about-portrait::after{content:"";position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--tan-deep);z-index:-1;border-radius:2px}
.about-body h2{margin-bottom:1.4rem}
.about-body .eyebrow{font-size:.88rem}
.about-body .sig{font-family:var(--body);font-style:italic;font-size:1.5rem;color:var(--crimson);margin-top:1.6rem}

/* word-reveal bio */
.bio-reveal{font-size:clamp(1.28rem,1.65vw,1.55rem);line-height:1.75;margin-bottom:0}
.bio-reveal .word{color:rgba(45,24,48,.15);transition:color .35s ease;display:inline}
.bio-reveal .word.lit{color:var(--ink)}

/* ============================================================
   AFFILIATIONS marquee
   ============================================================ */
.marquee{padding:2.4rem 0;border-top:1px solid rgba(23,23,23,.08);border-bottom:1px solid rgba(23,23,23,.08);overflow:hidden}
.marquee .label{text-align:center;font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.28em;font-size:.7rem;color:var(--grey);margin-bottom:1.6rem}
.marquee-viewport{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;width:max-content;animation:scroll-x 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track .item{font-family:var(--serif);font-size:clamp(1rem,1.6vw,1.4rem);
  color:var(--grey);letter-spacing:.08em;padding:0 2.6rem;white-space:nowrap;display:flex;align-items:center;gap:2.6rem}
.marquee-track .item::after{content:"\2022";color:var(--tan-deep)}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   GALLERY grid
   ============================================================ */
.gallery-head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.gallery{columns:3;column-gap:1.6rem}
.art{break-inside:avoid;margin:0 0 1.6rem;position:relative;overflow:hidden;border-radius:2px;background:var(--cream-deep)}
.art img{width:100%;height:auto;transition:transform .8s cubic-bezier(.16,.84,.44,1)}
.art:hover img{transform:scale(1.045)}
.art .meta{
  position:absolute;left:.85rem;right:.85rem;bottom:.85rem;
  padding:.85rem 1rem .8rem;
  background:rgba(200,189,176,.94);
  border-radius:3px;
  color:var(--ink);opacity:0;transform:translateY(6px);transition:opacity .45s ease,transform .45s ease;
}
.art:hover .meta{opacity:1;transform:none}
.art .meta .t{font-family:var(--serif);font-size:1.15rem;line-height:1.2;font-weight:500;color:var(--ink)}
.art .meta .d{font-family:var(--body);font-size:.8rem;letter-spacing:.04em;color:var(--grey);margin-top:.18rem}
.art .meta .price{font-family:var(--body);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--crimson);margin-top:.38rem}
.art .tag{position:absolute;top:.9rem;right:.9rem;font-family:var(--body);font-size:.62rem;
  letter-spacing:.18em;text-transform:uppercase;padding:.35em .7em;border-radius:2px;z-index:2;
  opacity:0;transition:opacity .45s ease}
.art:hover .tag{opacity:1}
.art .tag.sold{background:var(--ink);color:var(--cream)}
.art .tag.avail{background:var(--crimson);color:var(--white)}
.gallery-cta{text-align:center;margin-top:clamp(2.5rem,5vw,3.5rem)}

/* ============================================================
   CONTACT / NEWSLETTER
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem)}
.contact form{display:flex;flex-direction:column;gap:1rem}
.field label{display:block;font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.7rem;color:var(--grey);margin-bottom:.4rem}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--white);border:1px solid rgba(23,23,23,.25);border-radius:2px;padding:.85rem 1rem;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--crimson)}
.field textarea{min-height:130px;resize:vertical}
.contact-aside h3{margin-bottom:1rem}
.contact-aside .row{margin-bottom:1.3rem}
.contact-aside .row .k{font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.7rem;color:var(--crimson);margin-bottom:.25rem}
/* a11y: the email link sits in body-coloured text, so underline it to be
   distinguishable by more than colour (WCAG 1.4.1). */
.contact-aside .row a{text-decoration:underline;text-underline-offset:2px}
.socials{display:flex;gap:1rem;margin-top:1.4rem}
.socials a{width:42px;height:42px;border:1px solid var(--ink);border-radius:50%;display:flex;
  align-items:center;justify-content:center;transition:background .3s ease,color .3s ease,border-color .3s ease}
.socials a:hover{background:var(--crimson);border-color:var(--crimson);color:var(--white)}
.socials svg{width:18px;height:18px;fill:currentColor}
.form-note{font-size:.85rem;color:var(--grey);font-style:italic}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--cream);padding:clamp(2.5rem,4vw,3.5rem) 0 2rem;text-align:center}
.footer-logo{width:clamp(80px,11vw,130px);height:auto;margin:0 auto 1rem;display:block;opacity:.85}
.site-footer .fname{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:.3rem}
.site-footer .ftag{font-family:var(--body);letter-spacing:.3em;text-transform:uppercase;font-size:.72rem;color:var(--tan);margin-bottom:1.4rem}
.footer-nav{display:flex;flex-wrap:wrap;gap:.4rem 2rem;justify-content:center;margin-bottom:1.4rem;
  font-family:var(--body);text-transform:uppercase;letter-spacing:.18em;font-size:.75rem}
.footer-nav a{color:var(--cream);opacity:.8;transition:opacity .3s ease,color .3s ease}
.footer-nav a:hover{opacity:1;color:var(--tan)}
.footer-rule{height:1px;background:rgba(246,241,231,.16);max-width:520px;margin:0 auto 1.6rem}
.copyright{font-family:var(--body);font-size:.78rem;letter-spacing:.08em;color:rgba(246,241,231,.6)}
/* a11y: underline so the footer links are distinguishable by more than colour (WCAG 1.4.1). */
.copyright a{color:rgba(246,241,231,.8);text-decoration:underline;text-underline-offset:2px}

/* ============================================================
   LEGAL / 404 PAGES
   ============================================================ */
.legal-wrap{
  max-width:760px;margin:0 auto;
  padding:calc(var(--pad) + 5.5rem) var(--pad) 5rem;
}
.legal-wrap .eyebrow{display:block;margin-bottom:1rem}
.legal-wrap h1{
  font-family:var(--serif);color:var(--ink);
  font-size:clamp(2.1rem,5vw,3.2rem);line-height:1.05;margin:0 0 1.2rem;
}
.legal-wrap h2{
  font-family:var(--serif);color:var(--ink);
  font-size:clamp(1.3rem,2.4vw,1.7rem);margin:2.4rem 0 .7rem;
}
.legal-wrap p,.legal-wrap li{
  font-family:var(--body);color:var(--grey);
  font-size:1.06rem;line-height:1.75;
}
.legal-wrap a{color:var(--crimson);text-decoration:underline}
.legal-wrap a:hover{color:var(--crimson-deep)}
.legal-wrap ul{margin:.4rem 0 1rem 1.2rem}
.legal-wrap li{margin:.3rem 0}
.legal-updated{font-size:.92rem !important;color:var(--tan-deep) !important;margin-bottom:2rem}
.legal-404{text-align:center}
.legal-404 .btn{margin-top:1.6rem}

/* ============================================================
   SKIP LINK (accessibility)
   ============================================================ */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--ink);color:var(--white);
  padding:.7rem 1.1rem;border-radius:0 0 4px 0;
  font-family:var(--body);font-size:.95rem;letter-spacing:.02em;
  text-decoration:none;
}
.skip-link:focus{left:0}

/* ============================================================
   FORM STATUS
   ============================================================ */
.form-status{
  font-family:var(--body);font-size:.95rem;line-height:1.5;
  margin:.9rem 0 0;min-height:1.2em;color:var(--grey);
}
.form-status.is-ok{color:var(--crimson)}
.form-status.is-err{color:#9a3b3b}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,.84,.44,1),transform .9s cubic-bezier(.16,.84,.44,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee-track,.scroll-cue span{animation:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .gallery{columns:2}
}
@media (max-width:768px){
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-portrait{max-width:420px;margin:0 auto}
  .split{grid-template-columns:1fr}
  .split .media{min-height:300px;order:0 !important}
  .split.reverse .media{order:0}
  .contact-grid{grid-template-columns:1fr}
  .gallery{columns:2;column-gap:1rem}
  .art .meta{opacity:1;transform:none;background:linear-gradient(transparent,rgba(23,23,23,.85))}
  .art .tag{opacity:1}
  /* hide scroll cue on mobile: stacked buttons leave no room */
  .scroll-cue{display:none}
}
@media (max-width:520px){
  .gallery{columns:1}
  .btn{display:block;width:100%}
  .btn + .btn{margin-left:0;margin-top:.7rem}
  .btn-row{flex-direction:column;align-items:stretch}
}
