/* =========================================================
   ARTIN ABIRI — PORTFOLIO
   ========================================================= */

:root{
  --bg:           #0E0B0B;
  --bg-1:         #131010;
  --bg-2:         #1A1414;
  --burgundy:     #3A0A12;
  --burgundy-deep:#2D0A0E;
  --bone:         #F5F2ED;
  --bone-dim:     #D9D3C8;
  --red:          #D63838;
  --orange:       #E85025;
  --pink:         #DC85B5;
  --periwinkle:   #B6C5E8;
  --muted:        #8A7A78;
  --line:         #2A1F20;

  --serif:  'Playfair Display', Georgia, serif;
  --sans:   'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --mono:   'Space Mono', ui-monospace, monospace;

  --margin: clamp(20px, 4vw, 64px);
  --section: clamp(80px, 11vw, 160px);

  --t-fast: 200ms cubic-bezier(.2,.7,.2,1);
  --t-med:  500ms cubic-bezier(.2,.7,.2,1);
  --t-slow: 900ms cubic-bezier(.2,.7,.2,1);
}

/* ===== RESET ===== */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html,body{ background:var(--bg); color:var(--bone); }
body{
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none;
}
@media (pointer:coarse){ body{ cursor:auto; } .cursor,.cursor-dot{ display:none; } }
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; background:none; border:0; color:inherit; cursor:none; }
ul,ol{ list-style:none; }
em{ font-style:italic; }

/* ===== HELPERS ===== */
.mono{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; }
.section-tag{ display:inline-block; color:var(--red); margin-bottom:24px; }
.lede{ font-size:clamp(16px,1.4vw,20px); color:var(--bone-dim); max-width:60ch; line-height:1.6; }
.big-italic{ font-family:var(--serif); font-style:italic; font-weight:900; color:var(--red); }

/* ===== CUSTOM CURSOR ===== */
.cursor{
  position:fixed; top:0; left:0; width:38px; height:38px;
  border:1.5px solid var(--bone); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width var(--t-fast), height var(--t-fast), background var(--t-fast), border-color var(--t-fast);
}
.cursor-dot{
  position:fixed; top:0; left:0; width:5px; height:5px; border-radius:50%;
  background:var(--bone); pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
}
.cursor.is-hover{ width:80px; height:80px; background:var(--red); border-color:var(--red); }
.cursor.is-hover.has-label::after{
  content:attr(data-label);
  position:absolute; inset:0; display:grid; place-items:center;
  font-family:var(--mono); font-size:10px; text-transform:uppercase; color:var(--bone);
}

/* ===== TOP MARQUEE BANNER ===== */
.top-banner{
  background:var(--red);
  color:var(--bone);
  border-bottom:2px solid var(--bg);
  overflow:hidden;
  padding:8px 0;
  position:relative;
  z-index:60;
}
.marquee-track{
  display:flex; white-space:nowrap;
  font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.18em;
  animation: marquee 38s linear infinite;
}
.marquee-track span{ padding:0 32px; }
@keyframes marquee{ from{ transform:translate3d(0,0,0) } to{ transform:translate3d(-50%,0,0) } }

/* ===== NAV ===== */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--margin);
  background:rgba(14,11,11,.78);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-brand{
  font-family:var(--serif); font-weight:900; font-size:22px; letter-spacing:-.02em;
  color:var(--bone);
}
.brand-dot{ color:var(--red); }
.nav-links{ display:flex; gap:28px; }
.nav-links a{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  position:relative; padding:6px 2px; color:var(--bone-dim);
}
.nav-links a::after{
  content:''; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform var(--t-fast);
}
.nav-links a:hover{ color:var(--bone); }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-cta{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  background:var(--red); color:var(--bone);
  padding:12px 18px;
  transition:background var(--t-fast), transform var(--t-fast);
}
.nav-cta:hover{ background:var(--orange); transform:translate(-2px,-2px); box-shadow:4px 4px 0 var(--bone); }
.nav-cta .material-symbols-outlined{ font-size:16px; }
.nav-burger{ display:none; }
@media (max-width: 900px){
  .nav-links, .nav-cta{ display:none; }
  .nav-burger{ display:flex; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
  .nav-burger span{ width:24px; height:2px; background:var(--bone); display:block; transition: transform var(--t-fast), opacity var(--t-fast); }
  .nav.is-open .nav-burger span:nth-child(1){ transform: translate3d(0,7px,0) rotate(45deg); }
  .nav.is-open .nav-burger span:nth-child(2){ opacity: 0; }
  .nav.is-open .nav-burger span:nth-child(3){ transform: translate3d(0,-7px,0) rotate(-45deg); }
  .nav.is-open .nav-links{
    display:flex;
    flex-direction:column; gap:8px;
    position:absolute; top:100%; left:0; right:0;
    padding: 20px var(--margin);
    background:rgba(14,11,11,.96);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
  }
  .nav.is-open .nav-links a{ padding: 10px 0; font-size: 14px; letter-spacing: .14em; }
}

/* ===== HERO ===== */
.hero{
  position:relative;
  padding: clamp(40px, 6vw, 80px) 0 0;
  overflow:hidden;
  background: var(--burgundy);
}
.tile-bg{
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  pointer-events:none;
  z-index:0;
}
.tile-row{
  flex: 1 0 0;
  display:flex; align-items:stretch;
  overflow:hidden;
  width:100%;
}
.tile-row-track{
  display:flex; flex: 0 0 auto;
  animation: tileScroll 32s linear infinite;
  will-change: transform;
}
.tile-row.reverse .tile-row-track{ animation-direction: reverse; }
.tile-row .tile{ flex: 0 0 auto; width: clamp(110px, 11vw, 180px); }
.tile.a{ background: var(--pink); }
.tile.b{ background: var(--orange); }
@keyframes tileScroll{
  from{ transform:translate3d(0,0,0); }
  to  { transform:translate3d(-50%,0,0); }
}
@media (prefers-reduced-motion: reduce){ .tile-row-track{ animation: none; } }

.hero-content{
  position:relative; z-index:2;
  display:grid;
  grid-template-columns: 56px 1fr;
  min-height: clamp(560px, 88vh, 920px);
}
.vertical-label{
  position:relative;
  display:flex; align-items:flex-start; justify-content:center;
  padding-top: 32px;
}
.vertical-label span{
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  color: var(--periwinkle);
  white-space: nowrap;
}
.hero-stage{
  position:relative;
  display:flex; flex-direction:column; justify-content:center;
  padding: 24px var(--margin) 0 0;
}
.hero-title{
  font-family:var(--serif);
  font-weight:900;
  color: var(--burgundy-deep);
  font-size: clamp(72px, 16vw, 240px);
  line-height: .85;
  letter-spacing: -.045em;
  text-transform: uppercase;
}
.hero-title .line{ display:block; overflow:hidden; }
.hero-title .word{
  display:inline-block;
  transform: translateY(105%);
  animation: reveal 1.1s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero-title .line:nth-child(2) .word{ animation-delay:.10s; }
.hero-title .italic{ font-style: italic; }
@keyframes reveal{ to{ transform:translateY(0); } }

.hero-foot{
  position:relative; z-index:3;
  display:grid;
  grid-template-columns: 56px 1fr 1fr;
  gap: clamp(24px, 4vw, 64px);
  padding: clamp(40px, 5vw, 64px) var(--margin) clamp(48px, 6vw, 80px) 0;
  background: var(--burgundy);
  color: var(--periwinkle);
}
.hero-foot .lede-a{
  font-family: var(--serif);
  font-style: italic;
  font-weight: 700;
  font-size: clamp(22px, 2.2vw, 36px);
  line-height: 1.15;
  color: var(--periwinkle);
  max-width: 22ch;
}
.hero-foot .lede-b{
  font-family: var(--sans);
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.6;
  color: rgba(182,197,232,.78);
  max-width: 50ch;
}
.hero-foot .lede-b p + p{ margin-top: 12px; }
.hero-foot .lede-b strong{ color: var(--periwinkle); font-weight:700; }

@media (max-width: 800px){
  .hero-content{ grid-template-columns: 36px 1fr; min-height: 70vh; }
  .vertical-label span{ font-size: 10px; letter-spacing: .35em; }
  .hero-foot{ grid-template-columns: 36px 1fr; }
  .hero-foot .lede-b{ grid-column: 2; }
}

/* ===== TICKER ===== */
.ticker{
  background: var(--red);
  color: var(--burgundy-deep);
  overflow: hidden;
  padding: 14px 0;
  position: relative;
  z-index: 4;
}
.ticker-track{
  display:flex; white-space:nowrap;
  font-family: var(--serif);
  font-weight: 900;
  text-transform: uppercase;
  font-size: clamp(28px, 4.2vw, 56px);
  line-height: 1;
  letter-spacing: -.01em;
  width: max-content;
  animation: marquee-25 26s linear infinite;
}
.ticker-track span{ padding: 0 8px; flex: 0 0 auto; }
.ticker-track span em{ font-style: normal; color: var(--burgundy-deep); opacity: .55; padding: 0 14px; }
@keyframes marquee-25{
  from{ transform: translate3d(0,0,0); }
  to  { transform: translate3d(-25%,0,0); }
}

/* ===== EXPERTISE / "MAGNIFICENT AT" ===== */
.magnificent{ padding: var(--section) var(--margin); }
.magnificent-head{
  display:grid; grid-template-columns: 1fr 1fr; gap:48px;
  align-items:end; margin-bottom: 80px;
}
.magnificent-head h2{
  grid-column:1 / -1;
  font-family:var(--serif); font-weight:900;
  font-size:clamp(40px, 6.2vw, 88px); line-height:.95; letter-spacing:-.03em;
  color:var(--bone);
}
@media (max-width:800px){ .magnificent-head{ grid-template-columns:1fr; } }

.capabilities{
  display:grid; grid-template-columns: repeat(2, 1fr);
  border-top:1px solid var(--line);
}
.capabilities li{
  position:relative;
  border-bottom:1px solid var(--line);
  padding: 40px 32px 40px 0;
  display:grid; grid-template-columns: 80px 1fr; gap:24px; align-items:start;
  transition: background var(--t-med), padding var(--t-med);
}
.capabilities li:nth-child(odd){ border-right:1px solid var(--line); padding-right:32px; }
.capabilities li:hover{ background:var(--burgundy); padding-left:24px; }
.capabilities .num{ font-family:var(--mono); font-size:12px; letter-spacing:.18em; color:var(--red); padding-top:6px; }
.capabilities .cap-body{ min-width: 0; }
.capabilities h3{ font-family:var(--serif); font-weight:700; font-size:clamp(22px,2.2vw,32px); color:var(--bone); margin-bottom:10px; line-height:1.1; }
.capabilities p{ color:var(--bone-dim); max-width:48ch; }
.capabilities li.muted{ background:transparent; }
.capabilities li.muted h3, .capabilities li.muted p{ color:var(--muted); font-style:italic; }
.capabilities li.muted:hover{ background:transparent; }
@media (max-width:800px){
  .capabilities{ grid-template-columns:1fr; }
  .capabilities li:nth-child(odd){ border-right:0; }
}

/* ===== EXPERIENCE TIMELINE ===== */
.experience{
  padding: var(--section) var(--margin);
  background: var(--bg);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.experience-head{ max-width: 900px; margin-bottom: 80px; }
.experience-head h2{
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(40px, 6.2vw, 88px);
  line-height: .95;
  color: var(--bone);
  margin: 16px 0 24px;
}
.experience-list{
  display: grid;
  border-top: 1px solid var(--line);
}
.exp-item{
  position: relative;
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 48px;
  padding: 56px 0;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  transition: padding-left var(--t-med);
  cursor: pointer;
}
.exp-item::before{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(214,56,56,.08) 0%, transparent 60%);
  transform: translate3d(-100%,0,0);
  transition: transform 600ms cubic-bezier(.2,.7,.2,1);
  z-index: 0;
  pointer-events: none;
}
.exp-item:hover::before{ transform: translate3d(0,0,0); }
.exp-item:hover{ padding-left: 32px; }
.exp-bg-idx{
  position: absolute;
  right: -10px; top: 50%;
  transform: translate3d(0,-50%,0);
  font-family: var(--serif);
  font-style: italic;
  font-weight: 900;
  font-size: clamp(120px, 18vw, 260px);
  line-height: 1;
  color: var(--bone);
  opacity: 0;
  transition: opacity 600ms ease, transform 600ms cubic-bezier(.2,.7,.2,1), color 400ms;
  pointer-events: none;
  z-index: 0;
  user-select: none;
}
.exp-item:hover .exp-bg-idx{
  opacity: .06;
  transform: translate3d(-20px,-50%,0);
  color: var(--red);
}
.exp-meta{
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 12px;
}
.exp-meta .idx{ color: var(--red); }
.exp-meta .loc{ color: var(--muted); }
.exp-body{ position: relative; z-index: 1; min-width: 0; }
.exp-company{
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(36px, 4.6vw, 72px);
  line-height: 1;
  color: var(--bone);
  margin-bottom: 12px;
  display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap;
  transition: color var(--t-med);
}
.exp-item:hover .exp-company{ color: var(--red); }
.exp-company-text{ position: relative; display: inline-block; }
.exp-company-text::after{
  content: "";
  position: absolute;
  left: 0; bottom: -6px;
  width: 100%; height: 3px;
  background: var(--red);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 500ms cubic-bezier(.2,.7,.2,1);
}
.exp-item:hover .exp-company-text::after{ transform: scaleX(1); }
.exp-arrow{
  font-family: var(--sans);
  font-size: clamp(20px, 2.2vw, 32px);
  font-weight: 300;
  color: var(--red);
  opacity: 0;
  transform: translate(-12px, 6px);
  transition: opacity 400ms, transform 500ms cubic-bezier(.2,.7,.2,1);
}
.exp-item:hover .exp-arrow{ opacity: 1; transform: translate(0, 0); }
.exp-role{ display: block; color: var(--bone-dim); margin-bottom: 28px; }
.exp-bullets{ display: flex; flex-direction: column; gap: 14px; max-width: 70ch; }
.exp-bullets li{
  font-family: var(--sans);
  font-size: clamp(15px, 1.15vw, 17px);
  line-height: 1.55;
  color: var(--bone-dim);
  padding-left: 28px;
  position: relative;
}
.exp-bullets li::before{
  content: "";
  position: absolute;
  left: 0; top: .7em;
  width: 14px; height: 1px;
  background: var(--red);
  transition: width 400ms cubic-bezier(.2,.7,.2,1);
}
.exp-item:hover .exp-bullets li::before{ width: 22px; }
@media (max-width: 800px){
  .exp-item{ grid-template-columns: 1fr; gap: 16px; padding: 36px 0; }
  .exp-meta{ flex-direction: row; gap: 16px; padding-top: 0; }
  .exp-bg-idx{ font-size: 140px; right: -20px; }
  .exp-item:hover{ padding-left: 0; }
}

/* ===== SECTION MARQUEE ===== */
.section-marquee{
  background: var(--bg);
  padding: clamp(18px, 2vw, 28px) 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.section-marquee .row{
  display:flex; white-space:nowrap; overflow:hidden;
  font-family: var(--serif); font-weight: 900; text-transform: uppercase;
  font-size: clamp(22px, 3vw, 44px); line-height: 1.1; letter-spacing: -.01em;
  color: var(--bone);
}
.section-marquee .row + .row{ margin-top: 4px; }
.section-marquee .row .track{
  display:flex; flex: 0 0 auto; width: max-content;
  animation: marquee-25 36s linear infinite;
}
.section-marquee .row.reverse .track{ animation-direction: reverse; animation-duration: 42s; color: var(--red); }
.section-marquee .row .track span{ padding: 0 22px; }
.section-marquee .row .track em{ font-style: italic; color: var(--red); font-weight: 900; padding: 0 14px; }
.section-marquee .row.reverse .track em{ color: var(--bone); }

/* ===== PRINCIPLES (how I work) ===== */
.principles{
  padding: var(--section) var(--margin);
  background: var(--burgundy);
  position: relative;
  overflow: hidden;
}
.principles::before{
  content:'';
  position:absolute; inset:0;
  background-image: repeating-linear-gradient(45deg, transparent 0 28px, rgba(245,242,237,.025) 28px 29px);
  pointer-events:none;
}
.principles-head{ max-width: 1100px; margin-bottom: clamp(48px, 6vw, 80px); position:relative; }
.principles-head h2{
  font-family: var(--serif); font-weight: 900;
  font-size: clamp(36px, 5.4vw, 80px);
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--bone);
  margin-top: 16px;
}
.principles-lede{ color: rgba(245,242,237,.7); margin-top: 24px; max-width: 60ch; }
.principles-list{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  position: relative;
  border-top: 1px solid rgba(245,242,237,.12);
}
.principles-list li{
  padding: clamp(28px, 3.4vw, 48px) clamp(20px, 2.4vw, 36px);
  border-bottom: 1px solid rgba(245,242,237,.12);
  display:grid; grid-template-columns: 56px 1fr auto; gap: 24px;
  align-items: start;
  position: relative;
  transition: background var(--t-fast);
}
.principles-list li:hover{ background: rgba(245,242,237,.04); }
.principles-list li:nth-child(odd){ border-right: 1px solid rgba(245,242,237,.12); }
.principles-list .num{
  grid-column: 1;
  grid-row: 1 / span 2;
  font-family: var(--mono); font-size: 11px; letter-spacing: .2em;
  color: var(--bone-dim); padding-top: 10px;
}
.principles-list h3{
  grid-column: 2;
  font-family: var(--serif); font-weight: 700;
  font-size: clamp(20px, 2.1vw, 30px); line-height: 1.2;
  color: var(--bone);
  margin-bottom: 12px;
}
.principles-list h3 em{ font-style: italic; color: var(--periwinkle); font-weight: 700; }
.principles-list p{
  grid-column: 2;
  color: rgba(245,242,237,.6);
  font-size: 15px; line-height: 1.55;
  max-width: 42ch;
}
.principles-arrow{
  grid-column: 3;
  grid-row: 1 / span 2;
  align-self: start;
  padding-top: 8px;
  font-family: var(--sans); font-weight: 300;
  font-size: 22px;
  color: var(--periwinkle);
  opacity: .5;
  transform: translate(-6px, 4px);
  transition: opacity var(--t-fast), transform var(--t-fast), color var(--t-fast);
}
.principles-list li:hover .principles-arrow{
  opacity: 1;
  transform: translate(0, 0);
  color: var(--red);
}
@media (max-width: 800px){
  .principles-list{ grid-template-columns: 1fr; }
  .principles-list li:nth-child(odd){ border-right: 0; }
}

/* ===== PRINCIPLE MODAL ===== */
/* The native dialog top layer sits above z-indexed elements,
   so swap the custom cursor for the system one while it's open. */
body:has(dialog[open]){ cursor: auto; }
body:has(dialog[open]) .cursor,
body:has(dialog[open]) .cursor-dot{ display: none; }
.principle-modal,
.principle-modal *{ cursor: auto; }
.principle-modal a,
.principle-modal button,
.principle-modal [role="button"]{ cursor: pointer; }

.principle-modal{
  padding: 0;
  border: 0;
  background: var(--burgundy-deep);
  color: var(--bone);
  width: min(640px, 92vw);
  max-height: 88vh;
  position: fixed;
  inset: 0;
  margin: auto;
}
.principle-modal::backdrop{
  background: rgba(14,11,11,.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.principle-modal[open]{
  animation: principleIn 280ms cubic-bezier(.2,.7,.2,1);
}
@keyframes principleIn{
  from{ opacity: 0; transform: translateY(8px); }
  to  { opacity: 1; transform: translateY(0); }
}
.principle-modal-body{
  padding: clamp(28px, 4vw, 48px);
}
.principle-modal-num{
  color: var(--red);
  display: block;
  margin-bottom: 18px;
}
.principle-modal-title{
  font-family: var(--serif);
  font-weight: 900;
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.1;
  color: var(--bone);
  margin-bottom: 24px;
}
.principle-modal-title em{
  font-style: italic;
  color: var(--periwinkle);
}
.exp-modal-role{
  display: block;
  color: var(--red);
  margin: -16px 0 24px;
  font-size: 13px;
  letter-spacing: 0.04em;
}
.principle-modal-text p{
  color: var(--bone-dim);
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.7;
  margin-bottom: 16px;
}
.principle-modal-text p:last-child{ margin-bottom: 0; }
.principle-modal-close{
  position: absolute;
  top: 10px; right: 14px;
  width: 36px; height: 36px;
  font-size: 26px;
  line-height: 1;
  color: var(--bone-dim);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: color var(--t-fast);
  z-index: 2;
}
.principle-modal-close:hover{ color: var(--red); }

/* ===== FLY-BY (CD on colour-swap band) ===== */
.flyby{
  position: relative;
  background: transparent;
  overflow: visible;
  z-index: 3;
}
.flyby-sticky{
  position: relative;
  display: flex; align-items: center; justify-content: center;
  overflow: visible;
}
.flyby-band{
  position: relative;
  width: calc(100% + 20vw);
  margin-left: -10vw;
  display: flex; align-items: center;
  white-space: nowrap;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 900;
  font-size: clamp(96px, 16vw, 220px);
  line-height: .9;
  letter-spacing: -.02em;
  background: var(--red);
  border-top: 6px solid var(--burgundy-deep);
  border-bottom: 6px solid var(--burgundy-deep);
  transition: background 600ms ease;
  overflow: hidden;
}
.flyby-band span{
  display: inline-block;
  padding: .04em .25em;
  color: var(--burgundy-deep);
}
.flyby-band span:nth-child(even){ color: var(--bone); }
.flyby.is-past .flyby-band{ background: var(--periwinkle); }
.flyby.is-past .flyby-band span{ color: var(--burgundy-deep); }
.flyby.is-past .flyby-band span:nth-child(even){ color: var(--red); }
.flyby-prop{
  position: absolute;
  left: 50%; top: 50%;
  z-index: 2;
  height: clamp(280px, 40vh, 520px);
  width: auto;
  --p: 0;
  transform: translate3d(calc(-50% + (var(--p) - .5) * 60vw), -50%, 0) rotate(calc((var(--p) - .5) * 30deg));
  filter: drop-shadow(0 30px 50px rgba(0,0,0,.6));
  pointer-events: none;
  user-select: none;
  transition: transform 80ms linear;
  will-change: transform;
}
@media (prefers-reduced-motion: reduce){
  .flyby-prop{ transform: translate3d(-50%,-50%,0); }
}

/* ===== MANIFESTO ===== */
.manifesto{
  padding: var(--section) var(--margin);
  display:grid; grid-template-columns: 1fr 1.2fr; gap: clamp(40px, 6vw, 100px);
  align-items:center;
  position:relative; overflow:hidden;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.manifesto-bg{
  position:absolute; left:-2vw; top:50%;
  transform:translateY(-50%) rotate(-90deg); transform-origin:left center;
  font-family:var(--serif); font-weight:900; font-style:italic;
  font-size:18vw; color:var(--bone); opacity:.04;
  pointer-events:none; white-space:nowrap;
}
.manifesto-image{
  position:relative;
  border:3px solid var(--red);
  padding:10px;
  background:var(--bg-1);
}
.manifesto-image img{
  filter:grayscale(.7) contrast(1.1);
  transition: filter var(--t-slow);
  aspect-ratio: 4/5;
  object-fit:cover;
}
.manifesto-image:hover img{ filter:grayscale(0); }
.manifesto-image .caption{
  position:absolute; left:-14px; bottom:24px;
  writing-mode:vertical-rl; transform:rotate(180deg);
  color:var(--red); background:var(--bg); padding:8px 4px;
}
.manifesto-body h2{
  font-family:var(--serif); font-weight:900;
  font-size:clamp(40px, 5.6vw, 80px); line-height:.95; letter-spacing:-.03em;
  color:var(--bone); margin:20px 0 32px;
}
.manifesto-body p{ font-size:clamp(16px, 1.3vw, 20px); margin-bottom:18px; color:var(--bone-dim); }
.manifesto-body strong{ color:var(--bone); font-weight:700; }
@media (max-width: 900px){ .manifesto{ grid-template-columns:1fr; } }

/* ===== BUTTONS ===== */
.cta-row{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 14px 22px;
  font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  border:2px solid transparent;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast), border-color var(--t-fast);
}
.btn.primary{ background:var(--red); color:var(--bone); }
.btn.primary:hover{ background:var(--orange); transform: translate(-3px,-3px); box-shadow: 6px 6px 0 var(--bone); }
.btn.ghost{ border-color:var(--bone); color:var(--bone); }
.btn.ghost:hover{ background:var(--bone); color:var(--bg); transform: translate(-3px,-3px); box-shadow:6px 6px 0 var(--red); }
.btn .material-symbols-outlined{ font-size:18px; }
.btn.big{ padding:20px 30px; font-size:13px; }

/* ===== PROPS STRIP ===== */
.props-strip{
  background: var(--bg);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  padding: 28px 0;
  margin-top: calc(var(--section) * -.55);
  margin-bottom: calc(var(--section) * -.55);
  position: relative;
  z-index: 1;
}
.props-track{
  display: flex; align-items: center;
  gap: clamp(20px, 3vw, 48px);
  width: max-content;
  animation: propsScroll 90s linear infinite;
  will-change: transform;
}
.props-track img{
  height: clamp(110px, 13vw, 180px);
  width: auto;
  flex: 0 0 auto;
  user-select: none;
  pointer-events: none;
  filter: drop-shadow(0 14px 20px rgba(0,0,0,.5));
  transition: transform 400ms cubic-bezier(.2,.7,.2,1);
}
.props-track img:nth-child(7n+1){ transform: rotate(-7deg); }
.props-track img:nth-child(7n+2){ transform: rotate(4deg); }
.props-track img:nth-child(7n+3){ transform: rotate(-3deg); }
.props-track img:nth-child(7n+4){ transform: rotate(8deg); }
.props-track img:nth-child(7n+5){ transform: rotate(-5deg); }
.props-track img:nth-child(7n+6){ transform: rotate(2deg); }
.props-track img:nth-child(7n+7){ transform: rotate(-9deg); }
.props-track img:hover{ transform: rotate(0deg) scale(1.05); }
@keyframes propsScroll{
  from{ transform: translate3d(0,0,0); }
  to{   transform: translate3d(-50%,0,0); }
}
.props-strip:hover .props-track{ animation-play-state: paused; }
@media (prefers-reduced-motion: reduce){ .props-track{ animation: none; } }

/* ===== ANTICS ===== */
.antics{
  padding: var(--section) 0 var(--section) var(--margin);
  border-top:1px solid var(--line);
  background:var(--bg);
  overflow:hidden;
}
.antics-head{ max-width:900px; padding-right:var(--margin); margin-bottom:56px; }
.antics-head h2{
  font-family:var(--serif); font-weight:900;
  font-size:clamp(40px, 6.2vw, 88px); line-height:.95;
  color:var(--bone); margin:16px 0 24px;
}
.antics-rail{
  display:flex; gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-right:var(--margin); padding-bottom:24px;
  scrollbar-width:thin; scrollbar-color: var(--red) var(--bg-1);
}
.antics-rail::-webkit-scrollbar{ height:6px; }
.antics-rail::-webkit-scrollbar-track{ background:var(--bg-1); }
.antics-rail::-webkit-scrollbar-thumb{ background:var(--red); }
.antic-card{
  flex: 0 0 clamp(280px, 28vw, 420px);
  scroll-snap-align:start;
  border:1px solid var(--line);
  background:var(--bg-1);
  transition: transform var(--t-fast), border-color var(--t-fast);
}
.antic-card:hover{ transform:translateY(-6px); border-color:var(--red); }
.antic-img{ aspect-ratio: 5/6; overflow:hidden; position:relative; }
.antic-img img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(.6) contrast(1.1);
  transition: filter var(--t-med), transform var(--t-med);
}
.antic-card:hover .antic-img img{ filter:grayscale(0); transform:scale(1.04); }
.antic-card h3{
  font-family:var(--serif); font-weight:700;
  font-size:22px; line-height:1.2;
  padding: 18px 22px 6px;
  color:var(--bone);
}
.antic-card .mono{ color:var(--red); display:block; padding: 0 22px 22px; }

/* ===== CTA ===== */
.cta{
  padding: var(--section) var(--margin);
  background:var(--bone); color:var(--bg);
  text-align:center;
  border-top: 8px solid var(--red);
  position:relative; overflow:hidden;
}
.cta::before{
  content:'';
  position:absolute; inset:0;
  background-image: repeating-linear-gradient(45deg, transparent 0 28px, rgba(204,51,51,.05) 28px 30px);
  pointer-events:none;
}
.cta-inner{ position:relative; max-width: 1100px; margin:0 auto; }
.cta .section-tag{ color:var(--red); }
.cta-title{
  font-family:var(--serif); font-weight:900;
  font-size:clamp(48px, 8vw, 128px); line-height:.9; letter-spacing:-.04em;
  margin: 20px 0 28px;
}
.cta .lede{ color:#3a2a2a; margin:0 auto 40px; }
.cta-actions{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; }
.cta .btn.primary{ background:var(--bg); color:var(--bone); border-color:var(--bg); }
.cta .btn.primary:hover{ background:var(--red); border-color:var(--red); box-shadow:6px 6px 0 var(--bg); }
.cta .btn.ghost{ border-color:var(--bg); color:var(--bg); }
.cta .btn.ghost:hover{ background:var(--bg); color:var(--bone); box-shadow:6px 6px 0 var(--red); }

/* ===== FOOTER ===== */
.footer{
  background:var(--bg);
  padding: clamp(80px,10vw,140px) var(--margin) 40px;
  border-top:1px solid var(--line);
}
.footer-mark{
  font-family:var(--serif); font-weight:900; font-style:italic;
  font-size:clamp(56px, 13vw, 200px); line-height:.85; letter-spacing:-.04em;
  color:var(--bone); text-align:center; margin-bottom: 80px;
}
.footer-mark span{ color:var(--red); }
.footer-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:40px;
  padding: 40px 0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.footer-grid .mono{ color:var(--red); display:block; margin-bottom:10px; }
.footer-grid p{ color:var(--bone-dim); line-height:1.6; }
.footer-grid a{ color:var(--bone-dim); transition:color var(--t-fast); }
.footer-grid a:hover{ color:var(--bone); }
.footer-bottom{
  display:flex; justify-content:space-between; gap:20px;
  padding-top:32px; flex-wrap:wrap;
}
.footer-bottom .mono{ color:var(--muted); }
@media (max-width:800px){ .footer-grid{ grid-template-columns: repeat(2, 1fr); } }

/* ===== SCROLL REVEAL ===== */
.reveal{
  opacity:0;
  transform: translate3d(0, 40px, 0);
  transition: opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{ opacity:1; transform: translate3d(0,0,0); }

/* ===== PERF: skip offscreen rendering ===== */
.experience, .principles, .manifesto, .antics, .cta, .footer{
  content-visibility: auto;
  contain-intrinsic-size: 800px;
}
