*{margin:0;padding:0;box-sizing:border-box}
:root{
  --maroon:#6B0F1A;
  --maroon-light:#8B1A28;
  --maroon-deep:#4A0A12;
  --black:#0D0D0D;
  --black2:#141414;
  --black3:#1C1C1C;
  --cream:#F2EBD9;
  --cream2:#E8DEC8;
  --gold:#C9A84C;
  --gold-light:#E2C06A;
  --muted:#7A6E60;
}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--cream);font-family:'Outfit',sans-serif;overflow-x:hidden;cursor:none}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:var(--maroon)}

/* CURSOR */
#cursor{position:fixed;width:12px;height:12px;background:var(--maroon);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.12s,background 0.2s,width 0.2s,height 0.2s}
#cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(201,168,76,0.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.18s ease}
#cursor.hover{transform:translate(-50%,-50%) scale(2);background:var(--gold)}
#cursor-ring.hover{width:52px;height:52px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:1.4rem 5rem;display:flex;justify-content:space-between;align-items:center;transition:background 0.4s,padding 0.3s}
nav.scrolled{background:rgba(13,13,13,0.96);backdrop-filter:blur(20px);padding:1rem 5rem;border-bottom:0.5px solid rgba(107,15,26,0.3)}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:700;color:var(--cream);letter-spacing:0.04em;text-decoration:none}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:2.8rem;list-style:none;align-items:center}
.nav-links a{color:rgba(242,235,217,0.55);text-decoration:none;font-size:0.76rem;font-weight:300;letter-spacing:0.13em;text-transform:uppercase;transition:color 0.2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width 0.3s}
.nav-links a:hover,.nav-links a.active{color:var(--cream)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{background:var(--maroon)!important;color:var(--cream)!important;padding:0.5rem 1.5rem;border-radius:0.2rem;transition:background 0.2s!important}
.nav-cta:hover{background:var(--maroon-light)!important}
.nav-cta::after{display:none!important}

/* HERO */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:9rem 4rem 4rem 6rem;position:relative;z-index:2}
.hero-right{position:relative;overflow:hidden}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(15%) contrast(1.05);transition:transform 7s ease}
.hero-img:hover{transform:scale(1.04)}
.hero-right::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--black) 0%,transparent 35%,transparent 65%,rgba(107,15,26,0.1) 100%);z-index:1}
.hero-right::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 55%,var(--black) 100%);z-index:2}
.hero-name{font-family:'Cormorant Garamond',serif;font-size:clamp(3.2rem,5.2vw,5.2rem);font-weight:700;line-height:1.02;margin-bottom:0.5rem;opacity:0;animation:fadeInUp 0.8s ease 0.2s forwards}
.hero-name .first{display:block;color:var(--cream)}
.hero-name .last{display:block;color:var(--maroon)}
.hero-tagline{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-style:italic;color:rgba(242,235,217,0.5);margin-bottom:1.8rem;font-weight:300;opacity:0;animation:fadeInUp 0.8s ease 0.4s forwards}
.hero-desc{font-size:0.92rem;font-weight:300;line-height:1.9;color:rgba(242,235,217,0.55);max-width:440px;margin-bottom:2.5rem;opacity:0;animation:fadeInUp 0.8s ease 0.55s forwards}
.hero-roles{display:flex;flex-wrap:wrap;gap:0.6rem;margin-bottom:2.8rem;opacity:0;animation:fadeInUp 0.8s ease 0.65s forwards}
.hero-role{font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.9rem;border:0.5px solid rgba(201,168,76,0.25);border-radius:2rem;color:var(--gold);font-weight:300}
.hero-btns{display:flex;gap:1.2rem;flex-wrap:wrap;opacity:0;animation:fadeInUp 0.8s ease 0.75s forwards}
.btn-primary{padding:0.85rem 2.2rem;background:var(--maroon);color:var(--cream);text-decoration:none;font-size:0.8rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;border-radius:0.2rem;transition:background 0.2s,transform 0.2s;display:inline-flex;align-items:center;gap:0.5rem;border:none;font-family:'Outfit',sans-serif}
.btn-primary:hover{background:var(--maroon-light);transform:translateY(-2px)}
.btn-outline{padding:0.85rem 2.2rem;background:transparent;color:var(--cream);text-decoration:none;font-size:0.8rem;font-weight:300;letter-spacing:0.1em;text-transform:uppercase;border-radius:0.2rem;border:0.5px solid rgba(242,235,217,0.22);transition:all 0.2s;display:inline-flex;align-items:center;gap:0.5rem}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.hero-stats{position:absolute;bottom:3.5rem;left:6rem;display:flex;gap:3.5rem;opacity:0;animation:fadeInUp 0.8s ease 0.9s forwards}
.hero-stat-num{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:600;color:var(--gold);display:block;line-height:1}
.hero-stat-label{font-size:0.67rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);font-weight:300;display:block;margin-top:0.35rem}
.hero-scroll{position:absolute;right:3rem;bottom:3rem;z-index:5;display:flex;flex-direction:column;align-items:center;gap:0.6rem}
.scroll-text{font-size:0.62rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);writing-mode:vertical-lr}
.scroll-bar{width:1px;height:55px;background:rgba(201,168,76,0.15);overflow:hidden;position:relative}
.scroll-bar::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold);animation:scrollDown 2s ease infinite}
@keyframes scrollDown{0%{top:-100%}100%{top:100%}}

/* SECTIONS SHARED */
section{padding:8rem 6rem}
.section-tag{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.section-tag-line{width:24px;height:1px;background:var(--maroon);flex-shrink:0}
.section-tag span{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--maroon);font-weight:400}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3.2vw,2.9rem);font-weight:600;line-height:1.2;margin-bottom:3rem;color:var(--cream)}
.section-title em{font-style:italic;color:var(--maroon)}

/* ABOUT */
#about{background:var(--black2);position:relative;overflow:hidden}
#about::before{content:'AYOBAMI';position:absolute;top:-3rem;right:-1rem;font-family:'Cormorant Garamond',serif;font-size:13rem;font-weight:700;color:rgba(107,15,26,0.05);line-height:1;pointer-events:none;user-select:none}
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:6rem;align-items:center}
.about-photo-wrap{position:relative}
.about-photo{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:0.3rem;filter:grayscale(10%)}
.about-photo-accent{position:absolute;top:-1.5rem;left:-1.5rem;width:55%;height:55%;border:1px solid rgba(201,168,76,0.18);border-radius:0.3rem;z-index:-1}
.about-photo-label{position:absolute;bottom:1.5rem;right:-2rem;background:var(--maroon);padding:1rem 1.5rem;border-radius:0.2rem}
.about-photo-label p{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--cream)}
.about-photo-label span{font-size:0.67rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(242,235,217,0.55);font-weight:300}
.about-content p{font-size:0.93rem;font-weight:300;line-height:1.9;color:rgba(242,235,217,0.62);margin-bottom:1.2rem}
.about-content p strong{color:var(--cream);font-weight:500}
.about-divider{width:40px;height:1px;background:var(--gold);margin:2rem 0}
.identity-tags{display:flex;flex-wrap:wrap;gap:0.7rem}
.identity-tag{padding:0.4rem 1rem;border:0.5px solid rgba(107,15,26,0.4);border-radius:2rem;font-size:0.75rem;color:rgba(242,235,217,0.55);font-weight:300;background:rgba(107,15,26,0.07)}

/* TRACK RECORD */
#track{background:var(--black)}
.track-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(107,15,26,0.18);border:0.5px solid rgba(107,15,26,0.18);margin-top:4rem}
.track-item{background:var(--black);padding:3rem 2rem;text-align:center;transition:background 0.3s}
.track-item:hover{background:rgba(107,15,26,0.1)}
.track-num{font-family:'Cormorant Garamond',serif;font-size:3.2rem;font-weight:700;color:var(--maroon);line-height:1;display:block}
.track-num sup{font-size:1.4rem;color:var(--gold)}
.track-label{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);font-weight:300;display:block;margin-top:0.5rem;line-height:1.6}

/* RESEARCH */
#research{background:var(--black2)}
.research-list{margin-top:4rem;display:flex;flex-direction:column}
.research-item{display:grid;grid-template-columns:64px 1fr 190px;gap:2rem;padding:2.5rem 0;border-top:0.5px solid rgba(107,15,26,0.18);align-items:start;transition:all 0.3s}
.research-item:hover{padding-left:1rem;background:rgba(107,15,26,0.05)}
.r-num{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:rgba(107,15,26,0.35);font-style:italic;font-weight:300}
.r-info h3{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;color:var(--cream);margin-bottom:0.5rem;line-height:1.3}
.r-info p{font-size:0.83rem;font-weight:300;color:rgba(242,235,217,0.48);line-height:1.7;max-width:520px}
.r-info a{font-size:0.75rem;color:var(--gold);text-decoration:none;display:inline-flex;align-items:center;gap:0.3rem;margin-top:0.6rem;opacity:0.7;transition:opacity 0.2s}
.r-info a:hover{opacity:1}
.r-meta{display:flex;flex-direction:column;gap:0.4rem;align-items:flex-end}
.r-tag{font-size:0.66rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--maroon);background:rgba(107,15,26,0.1);padding:0.22rem 0.7rem;border-radius:2rem;border:0.5px solid rgba(107,15,26,0.22);white-space:nowrap}
.r-status{font-size:0.7rem;color:var(--muted);font-weight:300;text-align:right}

/* CV */
#cv{background:var(--black3)}
.cv-layout{display:grid;grid-template-columns:240px 1fr;gap:5rem;margin-top:4rem;align-items:start}
.cv-sidebar{position:sticky;top:8rem}
.cv-tabs{display:flex;flex-direction:column;gap:0.2rem}
.cv-tab{padding:0.9rem 1.5rem;border-left:2px solid transparent;font-size:0.78rem;letter-spacing:0.08em;text-transform:uppercase;color:rgba(242,235,217,0.38);font-weight:300;cursor:none;transition:all 0.2s;text-align:left;background:none;border-top:none;border-right:none;border-bottom:none;font-family:'Outfit',sans-serif;width:100%}
.cv-tab.active{border-left-color:var(--maroon);color:var(--cream);background:rgba(107,15,26,0.08)}
.cv-tab:hover{color:var(--cream);border-left-color:rgba(107,15,26,0.35)}
.cv-download-btn{display:flex;align-items:center;gap:0.6rem;margin-top:2rem;padding:0.8rem 1.5rem;background:var(--maroon);color:var(--cream);text-decoration:none;font-size:0.75rem;font-weight:400;letter-spacing:0.08em;text-transform:uppercase;border-radius:0.2rem;transition:background 0.2s;font-family:'Outfit',sans-serif;border:none;cursor:none;width:100%;justify-content:center}
.cv-download-btn:hover{background:var(--maroon-light)}
.cv-panel{display:none}
.cv-panel.active{display:block;animation:fadeInUp 0.35s ease}
.cv-entry{padding:2rem 0;border-bottom:0.5px solid rgba(107,15,26,0.13)}
.cv-entry:last-child{border-bottom:none}
.cv-entry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0.5rem;gap:1rem;flex-wrap:wrap}
.cv-entry h3{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--cream);line-height:1.3}
.cv-year{font-size:0.72rem;letter-spacing:0.1em;color:var(--maroon);font-weight:400;white-space:nowrap;margin-top:0.15rem}
.cv-org{font-size:0.8rem;color:var(--gold);font-weight:300;margin-bottom:0.4rem}
.cv-desc{font-size:0.83rem;font-weight:300;color:rgba(242,235,217,0.48);line-height:1.75}
.skill-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem;padding:1rem 0}
.skill-group h4{font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--maroon);margin-bottom:0.7rem;font-weight:400}
.skill-pills{display:flex;flex-wrap:wrap;gap:0.35rem}
.skill-pill{font-size:0.73rem;padding:0.22rem 0.7rem;background:rgba(107,15,26,0.09);border:0.5px solid rgba(107,15,26,0.18);border-radius:2rem;color:rgba(242,235,217,0.55);font-weight:300}
.affil-list{display:flex;flex-direction:column;gap:0.8rem;padding:1rem 0}
.affil-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.2rem;background:rgba(107,15,26,0.05);border-left:2px solid rgba(107,15,26,0.3);border-radius:0 0.2rem 0.2rem 0}
.affil-item span:first-child{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;color:var(--maroon);flex-shrink:0}
.affil-item p{font-size:0.82rem;font-weight:300;color:rgba(242,235,217,0.55);line-height:1.5}
.affil-item strong{color:var(--cream);font-weight:400;display:block;margin-bottom:0.15rem;font-size:0.85rem}

/* PORTFOLIO */
#portfolio{background:var(--black)}
.portfolio-filter{display:flex;gap:0.5rem;margin-top:2.5rem;flex-wrap:wrap}
.filter-btn{padding:0.42rem 1.2rem;background:transparent;border:0.5px solid rgba(107,15,26,0.28);border-radius:2rem;color:rgba(242,235,217,0.4);font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;font-family:'Outfit',sans-serif;cursor:none;transition:all 0.2s;font-weight:300}
.filter-btn.active,.filter-btn:hover{background:var(--maroon);border-color:var(--maroon);color:var(--cream)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.portfolio-card{background:var(--black2);border:0.5px solid rgba(107,15,26,0.13);border-radius:0.3rem;overflow:hidden;transition:transform 0.3s,border-color 0.3s}
.portfolio-card:hover{transform:translateY(-5px);border-color:rgba(107,15,26,0.45)}
.p-img{height:185px;overflow:hidden;position:relative}
.p-img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform 0.5s ease;filter:grayscale(15%)}
.portfolio-card:hover .p-img img{transform:scale(1.06)}
.p-overlay{position:absolute;inset:0;background:rgba(107,15,26,0.65);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.3s}
.portfolio-card:hover .p-overlay{opacity:1}
.p-overlay span{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--cream);border:0.5px solid rgba(242,235,217,0.45);padding:0.38rem 1rem;border-radius:2rem;font-weight:300}
.p-body{padding:1.5rem}
.p-cat{font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--maroon);font-weight:400;margin-bottom:0.45rem}
.p-body h3{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;color:var(--cream);margin-bottom:0.35rem;line-height:1.3}
.p-body p{font-size:0.78rem;font-weight:300;color:rgba(242,235,217,0.42);line-height:1.6}
.p-card-hidden{display:none}

/* IMPACT */
#impact{background:var(--black2)}
.impact-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;margin-top:4rem}
.impact-photo{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center;border-radius:0.3rem;filter:grayscale(12%)}
.impact-items{display:flex;flex-direction:column;gap:1.8rem}
.impact-item{padding:1.4rem 1.6rem;border-left:2px solid var(--maroon);background:rgba(107,15,26,0.05);transition:background 0.2s}
.impact-item:hover{background:rgba(107,15,26,0.1)}
.impact-item h3{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--cream);margin-bottom:0.35rem}
.impact-item p{font-size:0.82rem;font-weight:300;color:rgba(242,235,217,0.48);line-height:1.7}

/* WRITINGS */
#writings{background:var(--black3)}
.writings-tabs{display:flex;gap:0.4rem;margin-top:2rem;margin-bottom:3rem;flex-wrap:wrap}
.w-tab{padding:0.45rem 1.3rem;background:transparent;border:0.5px solid rgba(107,15,26,0.28);border-radius:2rem;color:rgba(242,235,217,0.4);font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;font-family:'Outfit',sans-serif;cursor:none;transition:all 0.2s;font-weight:300}
.w-tab.active,.w-tab:hover{background:var(--maroon);border-color:var(--maroon);color:var(--cream)}
.writings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.writing-card{border:0.5px solid rgba(107,15,26,0.15);border-radius:0.3rem;padding:2rem;background:var(--black2);transition:all 0.3s;cursor:none}
.writing-card:hover{border-color:rgba(107,15,26,0.45);transform:translateY(-3px)}
.w-type{display:inline-flex;align-items:center;gap:0.4rem;font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--maroon);margin-bottom:1rem;font-weight:400}
.w-type-dot{width:5px;height:5px;border-radius:50%;background:var(--maroon);flex-shrink:0}
.writing-card h3{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:var(--cream);margin-bottom:0.5rem;line-height:1.35}
.writing-card p{font-size:0.8rem;font-weight:300;color:rgba(242,235,217,0.45);line-height:1.65;margin-bottom:1.2rem}
.w-meta{display:flex;justify-content:space-between;align-items:center}
.w-date{font-size:0.68rem;color:var(--muted);font-weight:300}
.w-read{font-size:0.7rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);font-weight:300;opacity:0.7;transition:opacity 0.2s}
.writing-card:hover .w-read{opacity:1}
.writings-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.8rem;border:1px dashed rgba(107,15,26,0.3);border-radius:0.3rem;padding:2rem;background:transparent;text-align:center;min-height:220px;color:rgba(242,235,217,0.25)}
.writings-add span:first-child{font-size:2rem;color:rgba(107,15,26,0.35)}
.writings-add span:last-child{font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:300}

/* MUSIC */
#music{background:var(--maroon-deep);padding:8rem 6rem}
.music-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.music-grid .section-tag .section-tag-line{background:var(--gold)}
.music-grid .section-tag span{color:var(--gold)}
.music-photo{width:100%;aspect-ratio:1;object-fit:cover;object-position:center top;border-radius:0.3rem;filter:grayscale(20%) sepia(10%)}
.music-wrap{position:relative}
.music-badge{position:absolute;bottom:-1.5rem;left:-1.5rem;width:82px;height:82px;background:var(--gold);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:0.1rem}
.music-badge-icon{font-size:1.4rem;line-height:1}
.music-badge-text{font-size:0.52rem;letter-spacing:0.06em;text-transform:uppercase;color:var(--black);font-weight:600;line-height:1.2}
.music-content p{font-size:0.92rem;font-weight:300;line-height:1.9;color:rgba(242,235,217,0.58);margin-bottom:1.2rem}
.music-quote{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;color:rgba(201,168,76,0.65);line-height:1.7;border-left:2px solid rgba(201,168,76,0.3);padding-left:1.5rem;margin-top:1.5rem}

/* CONTACT */
#contact{background:var(--black);position:relative;overflow:hidden;padding:8rem 6rem}
#contact::after{content:'';position:absolute;top:-40%;right:-15%;width:600px;height:600px;background:radial-gradient(circle,rgba(107,15,26,0.1) 0%,transparent 65%);pointer-events:none}
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:6rem;align-items:start;margin-top:4rem}
.contact-left .section-title{font-size:clamp(2.2rem,3.5vw,3.3rem)}
.contact-lead{font-size:0.92rem;font-weight:300;color:rgba(242,235,217,0.52);line-height:1.8;margin-bottom:2.5rem}
.contact-links{display:flex;flex-direction:column;gap:1.5rem}
.c-link-item{}
.c-link-label{font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);font-weight:300;margin-bottom:0.3rem}
.c-link-val{color:var(--cream);text-decoration:none;font-size:0.88rem;font-weight:300;transition:color 0.2s;border-bottom:0.5px solid transparent;padding-bottom:1px;display:inline-block}
.c-link-val:hover{color:var(--gold);border-bottom-color:var(--gold)}
.contact-right{padding-top:1rem}
.contact-form label{display:block;font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:300;margin-bottom:0.5rem}
.contact-form input,.contact-form textarea{width:100%;background:rgba(255,255,255,0.03);border:0.5px solid rgba(107,15,26,0.25);border-radius:0.2rem;padding:0.9rem 1rem;color:var(--cream);font-family:'Outfit',sans-serif;font-size:0.87rem;font-weight:300;outline:none;transition:border-color 0.2s;margin-bottom:1.2rem;resize:none}
.contact-form input:focus,.contact-form textarea:focus{border-color:rgba(107,15,26,0.6)}
.contact-form textarea{height:120px}
.contact-form .btn-primary{width:100%;justify-content:center;margin-top:0.5rem}

/* FOOTER */
footer{background:var(--black);border-top:0.5px solid rgba(107,15,26,0.25);padding:2.5rem 6rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:2rem}
.footer-name{font-family:'Cormorant Garamond',serif;font-size:0.95rem;color:var(--cream);font-weight:600}
.footer-name span{color:var(--maroon)}
.footer-copy{font-size:0.72rem;color:var(--muted);font-weight:300;text-align:center}
.footer-links{display:flex;gap:2rem;justify-content:flex-end}
.footer-links a{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.2s;font-weight:300}
.footer-links a:hover{color:var(--gold)}

/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.d1{transition-delay:0.1s}.d2{transition-delay:0.2s}.d3{transition-delay:0.3s}.d4{transition-delay:0.4s}

/* RESPONSIVE */
@media(max-width:960px){
  nav,nav.scrolled{padding-left:1.5rem;padding-right:1.5rem}
  .nav-links li:not(:last-child){display:none}
  .hero{grid-template-columns:1fr}
  .hero-left{padding:7rem 2rem 4rem;order:2}
  .hero-right{height:55vw;max-height:380px;order:1}
  .hero-right::after{background:linear-gradient(to bottom,transparent 30%,var(--black) 100%)}
  .hero-stats{left:2rem;bottom:1.5rem;gap:2rem}
  section{padding:5rem 1.5rem}
  #music{padding:5rem 1.5rem}
  .about-grid,.impact-grid,.music-grid,.contact-grid{grid-template-columns:1fr;gap:3rem}
  .track-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid,.writings-grid{grid-template-columns:1fr}
  .cv-layout{grid-template-columns:1fr;gap:2rem}
  .cv-sidebar{position:static}
  .cv-tabs{flex-direction:row;flex-wrap:wrap;gap:0.3rem}
  .cv-tab{border-left:none;border-bottom:2px solid transparent;padding:0.6rem 1rem;font-size:0.7rem}
  .cv-tab.active{border-bottom-color:var(--maroon);border-left-color:transparent;background:transparent}
  .research-item{grid-template-columns:1fr;gap:0.5rem}
  .r-num,.r-meta{display:none}
  footer{grid-template-columns:1fr;text-align:center;padding:2rem 1.5rem;gap:1rem}
  .footer-links{justify-content:center}
  .about-photo-label{right:0;bottom:-1rem}
}
