/* ============================================================
   M.A. CHRISTIAN — SHARED STYLES
============================================================ */
:root{
  --bg:#1B1024;
  --bg-2:#241634;
  --panel:#271838;
  --line:#34243F;
  --line-2:#3A2A48;
  --cream:#F4ECE0;
  --cream-bright:#F6EEE2;
  --mauve:#C3B2CE;
  --mauve-dim:#9C8AA8;
  --mauve-soft:#B7A6C2;
  --coral:#D85A30;
  --coral-light:#F0997B;
  --coral-soft:#F3A98C;
  --purple:#7F77DD;
  --purple-light:#AFA9EC;
  --teal:#1D9E75;
  --teal-light:#5DCAA5;
  --pink:#D4537E;
  --amber:#EF9F27;
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --wrap:1080px;
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--cream);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img,svg{display:block;max-width:100%}
a{color:inherit}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.serif{font-family:var(--serif)}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--mauve);font-weight:500}
.skip{position:absolute;left:-9999px;top:0;background:var(--coral);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:100}
.skip:focus{left:0}
:focus-visible{outline:2px solid var(--coral-light);outline-offset:3px;border-radius:4px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(27,16,36,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{font-family:var(--serif);font-size:20px;letter-spacing:.06em;color:var(--cream);text-decoration:none;font-weight:600}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{color:var(--mauve);text-decoration:none;font-size:14px;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}
.nav-links a.active{position:relative}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--coral)}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;text-decoration:none;border-radius:999px;padding:11px 22px;border:1px solid transparent;cursor:pointer;transition:transform .2s,background .2s,border-color .2s}
.btn-coral{background:var(--coral);color:#fff}
.btn-coral:hover{transform:translateY(-2px);background:#e8693c}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--cream)}
.btn-ghost:hover{transform:translateY(-2px);background:rgba(244,236,224,.08)}
.btn-sm{padding:8px 16px}
.nav-toggle{display:none;background:none;border:0;color:var(--cream);font-size:26px;cursor:pointer;line-height:1}
section{position:relative}
.divline{border-top:1px solid var(--line)}
.pad{padding:clamp(56px,9vw,96px) 0}
.pad-sm{padding:clamp(40px,6vw,64px) 0}
.hero-ribbons{position:absolute;inset:0;width:100%;height:100%;opacity:.9;pointer-events:none}
.ribbon-div{width:100%;height:46px;display:block;opacity:.85}
.hero{position:relative;background:var(--bg);overflow:hidden}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:24px;min-height:min(78vh,640px);padding:48px 0}
.hero-copy h1{font-family:var(--serif);font-weight:600;font-size:clamp(48px,8vw,86px);line-height:.98;color:var(--cream-bright);margin:18px 0 14px;letter-spacing:-.01em}
.hero-motto{font-family:var(--serif);font-size:clamp(17px,2.4vw,21px);color:var(--coral-soft);letter-spacing:.02em}
.hero-sub{font-family:var(--serif);font-style:italic;color:var(--mauve);font-size:16px;margin-top:6px}
.hero-cta{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
.hero-art{width:100%;height:auto;max-height:560px}
.page-hero{position:relative;overflow:hidden;background:var(--bg);padding:clamp(56px,10vw,104px) 0 clamp(40px,7vw,72px)}
.page-hero .inner{position:relative;z-index:2;max-width:760px}
.page-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(40px,7vw,68px);line-height:1.02;color:var(--cream-bright);margin:14px 0 14px;letter-spacing:-.01em}
.page-hero .lead{color:var(--mauve-soft);font-size:clamp(16px,2.2vw,19px);max-width:60ch}
.statement{font-family:var(--serif);font-size:clamp(22px,3.2vw,32px);line-height:1.5;color:#EDE2D6;max-width:760px}
.statement .accent{color:var(--coral-light)}
.section-head .serif{font-family:var(--serif);font-size:clamp(26px,4vw,38px);color:var(--cream-bright);margin:10px 0 6px}
.section-head p{color:var(--mauve-dim);font-size:15px;margin-bottom:34px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--panel);border:1px solid var(--line-2);border-radius:var(--radius);padding:28px 26px;transition:transform .25s,border-color .25s}
.card:hover{transform:translateY(-4px)}
.card .ico{font-size:26px;line-height:1}
.card h3{font-family:var(--serif);font-weight:500;font-size:20px;color:var(--cream);margin:14px 0 8px}
.card p{color:var(--mauve-soft);font-size:14px;margin-bottom:16px}
.card a{font-size:14px;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.card a:hover{gap:10px}
.card--artist{border-top:2px solid var(--coral)}
.card--artist .ico,.card--artist a{color:var(--coral-light)}
.card--dtltd{border-top:2px solid var(--purple)}
.card--dtltd .ico,.card--dtltd a{color:var(--purple-light)}
.card--fit{border-top:2px solid var(--teal)}
.card--fit .ico,.card--fit a{color:var(--teal-light)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.stat .num{font-family:var(--serif);font-size:clamp(30px,5vw,40px);line-height:1}
.stat:nth-child(1) .num{color:var(--coral-soft)}
.stat:nth-child(2) .num{color:var(--purple-light)}
.stat:nth-child(3) .num{color:var(--teal-light)}
.stat .lbl{color:var(--mauve-dim);font-size:14px;margin-top:6px}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.pill{font-size:13px;color:#D8C9E2;border:1px solid var(--line-2);border-radius:999px;padding:8px 15px}
.contact{background:var(--bg-2);text-align:center}
.contact h2{font-family:var(--serif);font-size:clamp(26px,4vw,38px);color:var(--cream-bright);margin-bottom:10px}
.contact .lead{color:var(--mauve-soft);margin-bottom:4px}
.contact .meta{color:var(--mauve-dim);font-size:14px;margin-bottom:24px}
.contact .meta a{color:var(--mauve-dim);text-decoration:none}
.contact .meta a:hover{color:var(--cream)}
.bio-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,56px);align-items:start}
.portrait{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;background:var(--panel);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--mauve-dim);font-size:13px;letter-spacing:.1em;text-align:center}
.portrait img{width:100%;height:100%;object-fit:cover}
.prose p{font-size:17px;line-height:1.75;color:#E4D9CD;margin-bottom:18px}
.prose p .accent{color:var(--coral-light)}
.prose h2{font-family:var(--serif);font-size:24px;color:var(--cream-bright);margin:34px 0 12px;font-weight:500}
.role-list{list-style:none;display:grid;gap:10px;margin-top:6px}
.role-list li{display:flex;gap:12px;align-items:flex-start;color:var(--mauve-soft);font-size:15px}
.role-list .dot{color:var(--coral-light);font-size:18px;line-height:1.4}
.pullquote{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3.6vw,30px);line-height:1.45;color:var(--coral-soft);border-left:2px solid var(--coral);padding-left:24px;margin:8px 0}
.resume{display:grid;gap:clamp(30px,5vw,48px)}
.credit-group h2{font-family:var(--serif);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--coral-light);font-weight:500;margin-bottom:18px}
.credit-row{display:grid;grid-template-columns:1.4fr 1fr auto;gap:16px;align-items:baseline;padding:14px 0;border-top:1px solid var(--line)}
.credit-row:first-of-type{border-top:0}
.credit-row .role{color:var(--cream);font-size:16px}
.credit-row .ctx{color:var(--mauve-soft);font-size:14px}
.credit-row .yr{color:var(--mauve-dim);font-size:13px;justify-self:end;white-space:nowrap}
.video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.video-card .embed{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:var(--panel);border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center}
.video-card .embed iframe{width:100%;height:100%;border:0}
.video-card .play{font-size:34px;color:var(--coral-light);opacity:.8}
.video-card h3{font-family:var(--serif);font-weight:500;font-size:18px;color:var(--cream);margin:14px 0 4px}
.video-card p{color:var(--mauve-dim);font-size:14px}
.gallery{columns:3;column-gap:16px}
.gallery figure{break-inside:avoid;margin:0 0 16px;border-radius:var(--radius);overflow:hidden;background:var(--panel);border:1px solid var(--line-2);cursor:pointer;position:relative}
.gallery img{width:100%;display:block;transition:transform .4s}
.gallery figure:hover img{transform:scale(1.05)}
.gallery .ph{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;color:var(--mauve-dim);font-size:13px;letter-spacing:.08em}
.gallery .ph.wide{aspect-ratio:4/3}
.gallery .ph.tall{aspect-ratio:2/3}
.lightbox{position:fixed;inset:0;background:rgba(15,8,22,.94);display:none;align-items:center;justify-content:center;z-index:200;padding:24px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px}
.lightbox .close{position:absolute;top:20px;right:26px;color:var(--cream);font-size:34px;background:none;border:0;cursor:pointer;line-height:1}
.site-footer{border-top:1px solid var(--line)}
.foot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:24px 0;color:var(--mauve-dim);font-size:13px}
.foot .brand{font-size:16px}
.foot .social{display:flex;gap:18px;font-size:20px}
.foot .social a{color:var(--mauve-dim);text-decoration:none;transition:color .2s}
.foot .social a:hover{color:var(--coral-light)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.float{animation:drift 9s ease-in-out infinite}
.float-2{animation:drift 11s ease-in-out infinite reverse}
@keyframes drift{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important;scroll-behavior:auto}.reveal{opacity:1;transform:none}}
@media (max-width:860px){
  .nav-links{position:absolute;top:68px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--bg);border-bottom:1px solid var(--line);padding:8px 0;display:none}
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:14px clamp(20px,5vw,48px);width:100%}
  .nav-links a.active::after{display:none}
  .nav-links .btn{margin:10px clamp(20px,5vw,48px)}
  .nav-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;min-height:0;gap:8px;padding:40px 0 20px;text-align:center}
  .hero-cta{justify-content:center}
  .hero-art{max-height:360px;margin:0 auto}
  .hero-copy{order:1}.hero-media{order:2}
  .cards{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr;gap:20px;text-align:center}
  .bio-grid{grid-template-columns:1fr}
  .portrait{max-width:360px;margin:0 auto}
  .video-grid{grid-template-columns:1fr}
  .gallery{columns:2}
  .credit-row{grid-template-columns:1fr auto;gap:6px 16px}
  .credit-row .ctx{grid-column:1/-1}
}
@media (max-width:560px){.pills{justify-content:center}.gallery{columns:1}}