/* ============================================================
   Julia Kastin — Portfolio  |  styles.css
   (core stylesheet + about-editorial module)
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:      #080808;
  --ivory:   #f5f0eb;
  --white:   #fdfaf8;
  --silver:  #b8b4ae;
  --chrome:  #d4d0ca;
  --rose:    #c4a49c;
  --dim:     rgba(245,240,235,0.42);
  --faint:   rgba(245,240,235,0.08);
  --rule:    rgba(245,240,235,0.1);
  --rulemd:  rgba(245,240,235,0.18);
  /* Type system */
  --disp:   'DM Serif Display',Georgia,serif; /* Headlines — high contrast, Vogue energy */
  --play:   'Italiana',Georgia,serif;          /* Italic editorial moments */
  --corm:   'Cormorant Garamond',serif;        /* Body, captions */
  --brush:  'Caveat',cursive;                  /* Signature */
  --label:  'Inter',system-ui,sans-serif;      /* Micro labels only */
  --e:      cubic-bezier(0.25,0,0,1);
}
html{scroll-behavior:auto}
body{
  background:var(--bg);color:var(--ivory);
  font-family:var(--label);font-weight:300;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
::selection{background:var(--ivory);color:var(--bg)}
::-webkit-scrollbar{width:1px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--rose)}

#prog{
  position:fixed;top:0;left:0;height:2px;z-index:9999;width:0%;pointer-events:none;
  background:linear-gradient(to right,var(--silver),var(--rose),var(--chrome),var(--rose),var(--silver));
}
#curtain{position:fixed;inset:0;z-index:9998;background:var(--bg);pointer-events:none;animation:curtain 1.4s var(--e) both}
@keyframes curtain{from{transform:scaleY(1);transform-origin:top}to{transform:scaleY(0);transform-origin:top}}

body::before{
  content:'';position:fixed;inset:0;z-index:0;
  background-image:url('images/texture.jpg');
  background-size:cover;background-position:center;background-attachment:fixed;
}
body::after{
  content:'';position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%,  rgba(8,8,8,.94) 0%,transparent 70%),
    radial-gradient(ellipse 70%  55% at 0%  50%,  rgba(6,6,6,.9)  0%,transparent 60%),
    radial-gradient(ellipse 70%  55% at 100% 50%, rgba(6,6,6,.9)  0%,transparent 60%),
    radial-gradient(ellipse 100% 65% at 50% 110%, rgba(8,8,8,.97) 0%,transparent 65%),
    linear-gradient(to bottom,rgba(8,8,8,.9) 0%,rgba(6,6,6,.3) 28%,rgba(6,6,6,.26) 72%,rgba(8,8,8,.94) 100%);
  mix-blend-mode:multiply;
}
.grain{position:fixed;inset:0;z-index:2;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.11'/%3E%3C/svg%3E");opacity:.28;mix-blend-mode:overlay}
nav,section,footer,.sm,#hero,.statement{position:relative;z-index:3}

/* ═══════ NAV ═══════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:54px;display:flex;align-items:center;justify-content:space-between;
  padding:0 52px;
  background:rgba(8,8,8,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--rule);transition:all .5s ease;
}
nav.at-top{background:rgba(8,8,8,.4);border-bottom-color:transparent}

/* Logo — Caveat signature */
.nav-logo{
  font-family:var(--brush);font-size:19px;font-weight:700;
  color:var(--ivory);text-decoration:none;opacity:.92;
  transition:opacity .3s;letter-spacing:.01em;
}
.nav-logo:hover{opacity:.45}

/* Nav links — tiny Inter caps */
.nav-links{position:absolute;left:50%;transform:translateX(-50%);display:flex;gap:30px;list-style:none}
.nav-link{
  font-family:var(--label);font-size:9px;font-weight:300;
  letter-spacing:.24em;text-transform:uppercase;
  color:rgba(245,240,235,.36);text-decoration:none;
  position:relative;transition:color .3s;
}
.nav-link::after{
  content:'';position:absolute;bottom:-5px;left:0;right:0;height:1px;
  background:linear-gradient(to right,var(--rose),var(--chrome),var(--rose));
  transform:scaleX(0);transform-origin:left;transition:transform .45s var(--e);
}
.nav-link:hover{color:var(--ivory)}
.nav-link:hover::after{transform:scaleX(1)}
.nav-right{font-family:var(--label);font-size:9px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:rgba(245,240,235,.2)}

/* ═══════════════════════════════
   HERO — TYPOGRAPHIC ARCHITECTURE
═══════════════════════════════ */
#hero{
  height:100vh;min-height:700px;
  position:relative;overflow:hidden;
  background:#060606;
  display:flex;flex-direction:column;
  justify-content:flex-end;
}
.h-bg{position:absolute;inset:0;background:#060606;overflow:hidden}
.h-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:brightness(1.18) contrast(1.06) saturate(1.22)}
.h-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,6,6,.32) 0%,rgba(6,6,6,.16) 40%,rgba(6,6,6,.52) 100%);z-index:1}
.h-halo{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 45% at 50% 35%,rgba(210,190,182,.07) 0%,transparent 58%),
    radial-gradient(ellipse 25% 20% at 30% 18%,rgba(200,180,168,.03) 0%,transparent 50%),
    radial-gradient(ellipse 25% 20% at 70% 18%,rgba(200,180,168,.03) 0%,transparent 50%);
  mix-blend-mode:screen;
}
.h-vign{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(to right,rgba(4,4,4,.42) 0%,transparent 18%,transparent 82%,rgba(4,4,4,.42) 100%),
    linear-gradient(to bottom,rgba(4,4,4,.55) 0%,transparent 26%,transparent 66%,rgba(4,4,4,.5) 100%);
}
.h-grain{position:absolute;inset:0;z-index:3;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.11'/%3E%3C/svg%3E");opacity:.22;mix-blend-mode:overlay}

/* Ghost — huge italic DM Serif Display JK watermark */
.h-ghost{
  position:absolute;z-index:2;
  font-family:var(--disp);font-style:italic;
  font-size:clamp(380px,62vw,980px);
  font-weight:700;line-height:.9;letter-spacing:-.04em;
  color:rgba(245,240,235,.028);
  top:50%;left:50%;
  transform:translate(-48%,-46%);
  user-select:none;pointer-events:none;
  white-space:nowrap;
}

/* ── NAME — Tenor Sans display ── */
.h-content{position:relative;z-index:10;padding:0 52px 0;width:100%}

/* JULIA — Tenor Sans, massive, bottom-anchored */
.h-julia{
  display:block;
  font-family:var(--disp);
  font-size:clamp(130px,25.5vw,400px);
  line-height:.70;
  letter-spacing:-.01em;
  text-transform:uppercase;
  color:var(--white);
  text-shadow:
    0 0 80px rgba(196,164,156,.16),
    0 0 200px rgba(196,164,156,.06),
    0 4px 18px rgba(4,4,4,.65),
    0 28px 90px rgba(4,4,4,.4);
  opacity:0;
  animation:sweepUp 1.5s var(--e) .25s forwards;
}

/* KASTIN — Playfair italic, outlined — the tension ──
   Tenor vs Playfair = editorial contrast, fashion-house typography */
.h-kastin{
  display:block;
  font-family:var(--disp);
  font-size:clamp(114px,22.5vw,348px);
  font-weight:400;
  font-style:italic;
  line-height:.80;
  letter-spacing:-.01em;
  text-transform:uppercase;
  color:transparent;
  -webkit-text-stroke:clamp(1.8px,0.22vw,3px) rgba(216,196,188,.68);
  opacity:0;
  animation:sweepUp 1.5s var(--e) .65s forwards;
}

/* Divider row */
.h-portfolio-line{
  display:flex;align-items:center;justify-content:flex-start;
  padding:18px 0 0;
  border-top:1px solid rgba(216,196,188,.18);
  margin-top:14px;
  opacity:0;animation:aFade 1.4s ease 1.55s forwards;
}
.h-port-word{
  font-family:var(--play);
  font-size:clamp(22px,3vw,48px);
  font-weight:400;
  letter-spacing:.18em;
  color:rgba(216,196,188,.78);
  font-style:normal;
  text-transform:uppercase;
}

/* Bottom strip */
.h-strip{display:none}
.h-strip-item{display:none}
.h-strip-center{display:none}

.h-spine{
  position:absolute;left:40px;top:20%;bottom:56px;z-index:5;
  width:1px;background:linear-gradient(to bottom,transparent,rgba(196,164,156,.18) 18%,rgba(196,164,156,.18) 82%,transparent);
  opacity:0;animation:aFade 1.5s ease 1.9s forwards;
}
.h-top-rule{
  position:absolute;top:0;left:0;right:0;height:2px;z-index:11;
  background:linear-gradient(to right,transparent,rgba(196,164,156,.35) 22%,rgba(210,196,188,.55) 50%,rgba(196,164,156,.35) 78%,transparent);
}
.h-scroll{
  position:absolute;bottom:58px;right:52px;z-index:10;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:aFade 1s ease 2.5s forwards;
}
.h-scroll span{font-family:var(--label);font-size:7px;letter-spacing:.5em;text-transform:uppercase;color:rgba(196,164,156,.32)}
.h-scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,rgba(196,164,156,.42),transparent);animation:pulse 2.8s ease-in-out infinite 3s}

@keyframes sweepUp{
  0%{opacity:0;transform:translateY(52px);filter:blur(12px)}
  22%{opacity:1;filter:blur(2px)}
  100%{opacity:1;transform:translateY(0);filter:blur(0)}
}

/* ═══════ SM ═══════ */
.sm{
  display:flex;align-items:center;height:42px;padding:0 52px;
  background:rgba(8,8,8,.86);backdrop-filter:blur(18px);
  border-top:1px solid var(--rulemd);border-bottom:1px solid var(--rule);
}
.sm-lbl{
  font-family:var(--disp);font-size:11px;
  letter-spacing:.35em;text-transform:uppercase;color:var(--ivory);flex-shrink:0;
}
.sm-line{flex:1;height:1px;background:var(--rule);margin:0 22px}
.sm-num{
  font-family:var(--play);font-size:15px;font-style:italic;
  color:rgba(196,164,156,.58);letter-spacing:.04em;flex-shrink:0;
}

/* ═══════ ABOUT ═══════ */

.about-video-section{position:relative;overflow:hidden;min-height:auto;background:#0c0c0c}
.about-video-wrap{position:relative;width:100%;background:#0c0c0c;display:flex;align-items:center;justify-content:center}
.about-video-wrap video{position:relative;width:100%;height:auto;display:block;object-fit:contain}
@media(max-width:700px){
  .about-video-wrap{height:auto;min-height:auto;max-height:none}
}
.about-visual{position:relative;overflow:hidden;border-right:1px solid var(--rule)}
.about-photo{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 44% 26%,rgba(210,185,177,.06) 0%,transparent 55%),
  linear-gradient(152deg,#1a1a1a 0%,#0c0c0c 42%,#141414 100%);
  transform:scale(1.04);transition:transform 18s ease;
}

.about-photo::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.11'/%3E%3C/svg%3E");opacity:.42;mix-blend-mode:overlay}
.about-cap{position:absolute;bottom:22px;left:26px;z-index:2;font-family:var(--label);font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,240,235,.18)}

.about-content{padding:84px 64px;display:flex;flex-direction:column;justify-content:center}

/* Eyebrow — tiny Inter rose */
.about-overline{
  font-family:var(--disp);
  font-size:clamp(52px,7vw,100px);
  font-weight:400;line-height:.78;letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(245,240,235,.048);
  user-select:none;pointer-events:none;
  margin-bottom:-8px;
  display:block;
}

.about-eyebrow{
  font-family:var(--label);font-size:8px;letter-spacing:.45em;text-transform:uppercase;
  color:rgba(196,164,156,.65);margin-bottom:28px;padding-bottom:12px;
  border-bottom:1px solid rgba(196,164,156,.15);
}

/* Heading — Tenor Sans display */
.about-hed{
  font-family:var(--disp);
  font-size:clamp(38px,5vw,72px);
  font-weight:400;line-height:.84;
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-bottom:34px;color:var(--ivory);
}
/* Italic em — Playfair contrast */
.about-hed em{
  display:block;
  font-family:var(--play);
  font-weight:400;font-style:italic;
  font-size:.75em;
  letter-spacing:.01em;
  text-transform:none;
  color:rgba(245,240,235,.5);
  margin-top:4px;
}

/* Pull quote — Playfair italic large */
.about-pull{
  font-family:var(--disp);
  font-size:clamp(19px,2.1vw,27px);
  font-weight:400;font-style:italic;
  line-height:1.5;color:rgba(245,240,235,.88);
  margin-bottom:26px;
  padding-left:18px;border-left:1px solid rgba(196,164,156,.3);
}

/* Body — Cormorant Garamond */
.about-body{
  font-family:var(--corm);
  font-size:clamp(14px,1.4vw,16px);
  font-weight:300;color:rgba(245,240,235,.38);
  line-height:1.95;margin-bottom:36px;
}

.about-tags{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--rule);padding-top:20px}
.atag{
  font-family:var(--label);font-size:8px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(245,240,235,.28);padding:6px 14px;border-right:1px solid var(--rule);
  transition:all .25s ease;cursor:default;
}
.atag:first-child{padding-left:0}
.atag:hover{color:var(--ivory)}

/* STATEMENT — Playfair italic, editorial */
.statement{
  padding:clamp(120px,16vh,220px) 52px;text-align:center;
  background:rgba(10,10,10,.88);backdrop-filter:blur(8px);
  border-top:1px solid var(--rulemd);border-bottom:1px solid var(--rulemd);
  position:relative;overflow:hidden;
}
.stmt-glow{position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:580px;height:380px;border-radius:50%;pointer-events:none;background:radial-gradient(ellipse,rgba(196,164,156,.05) 0%,transparent 65%);z-index:1}
.stmt-inner{position:relative;z-index:2;max-width:960px;margin:0 auto}
.stmt-q{
  font-family:var(--disp);
  font-size:clamp(22px,2.6vw,33px);
  font-weight:400;font-style:italic;line-height:1.44;
  color:var(--ivory);margin-bottom:20px;letter-spacing:-.01em;
}
.stmt-attr{font-family:var(--label);font-size:8px;letter-spacing:.42em;text-transform:uppercase;color:rgba(196,164,156,.55)}

/* ═══════ MB ═══════ */
#moodboard{background:rgba(8,8,8,.86);backdrop-filter:blur(5px);position:relative;overflow:hidden}
.mb-head{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--rule)}
.mb-title-col{padding:clamp(88px,11vh,168px) 52px clamp(52px,6.5vh,92px);border-right:1px solid var(--rule)}
/* Mood Board heading — Tenor Sans + Playfair em */
.mb-hed{
  font-family:var(--disp);
  font-size:clamp(44px,6.5vw,92px);
  font-weight:400;line-height:.86;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ivory);
}
.mb-hed em{
  display:block;font-family:var(--play);font-weight:400;font-style:italic;
  font-size:.7em;letter-spacing:.02em;text-transform:none;
  color:rgba(245,240,235,.44);margin-top:4px;
}
.mb-text-col{padding:clamp(88px,11vh,168px) 52px clamp(52px,6.5vh,92px);display:flex;flex-direction:column;justify-content:flex-end}
.mb-label{font-family:var(--label);font-size:8px;letter-spacing:.44em;text-transform:uppercase;color:rgba(196,164,156,.52);margin-bottom:14px}
.mb-desc{font-family:var(--disp);font-size:clamp(17px,1.9vw,24px);font-weight:400;font-style:italic;color:rgba(245,240,235,.44);line-height:1.58}
.mb-img-wrap{position:relative;z-index:2;padding:clamp(48px,6.5vh,84px) 52px;border-bottom:1px solid var(--rule)}
.mb-img-inner{width:100%;overflow:hidden;border:1px solid rgba(196,164,156,.12);line-height:0;box-shadow:0 0 80px rgba(196,164,156,.04)}
.mb-img{display:block;width:100%;height:auto;transition:transform 16s ease}
#moodboard:hover .mb-img{transform:scale(1.005)}
.mb-caption{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:13px 52px;font-family:var(--label);font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,240,235,.2)}

/* ═══════ PROJECTS ═══════ */
#projects{background:rgba(8,8,8,.86);backdrop-filter:blur(5px);position:relative;overflow:hidden}
.proj-header{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;padding:clamp(88px,11vh,168px) 52px clamp(52px,6.5vh,92px);gap:56px;align-items:end;border-bottom:1px solid var(--rule)}
/* "Selected" — Playfair italic ghost */
.proj-hed{
  font-family:var(--disp);
  font-size:clamp(40px,5.5vw,76px);
  font-weight:400;line-height:.88;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ivory);
}
.proj-hed .gh{
  display:block;
  font-family:var(--play);font-style:italic;font-weight:300;
  font-size:.7em;letter-spacing:.01em;text-transform:none;
  -webkit-text-stroke:1px rgba(245,240,235,.18);color:transparent;
}
.proj-meta-tag{font-family:var(--label);font-size:8px;letter-spacing:.44em;text-transform:uppercase;color:rgba(196,164,156,.52);margin-bottom:9px}
.proj-meta-desc{font-family:var(--corm);font-size:clamp(13px,1.5vw,18px);font-weight:300;font-style:italic;color:rgba(245,240,235,.38);line-height:1.6}

.proj-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:560px;gap:1px;background:rgba(245,240,235,.07)}
.proj{position:relative;overflow:hidden;background:#0a0a0a;cursor:pointer}
.proj-fill{position:absolute;inset:0;transition:transform 1.3s var(--e)}
.proj:hover .proj-fill{transform:scale(1.042)}
.pf1{background:linear-gradient(152deg,#1a1a1a 0%,#0c0c0c 45%,#141414 100%)}
.pf2{background:linear-gradient(132deg,#161616 0%,#0a0a0a 100%)}
.pf3{background:linear-gradient(198deg,#181818 0%,#0e0e0e 100%)}
.proj-fill::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 42% 24%,rgba(196,164,156,.04) 0%,transparent 55%)}
.proj-ph{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.proj-ph-ring{width:34px;height:34px;border-radius:50%;border:1px solid rgba(245,240,235,.1);display:flex;align-items:center;justify-content:center}
.proj-ph-ring svg{width:12px;height:12px;stroke:rgba(245,240,235,.18);fill:none;stroke-width:1.5}
.proj-ph-txt{font-family:var(--label);font-size:7px;letter-spacing:.44em;text-transform:uppercase;color:rgba(245,240,235,.14)}
.proj::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--rose),var(--chrome),var(--rose),transparent);transform:scaleX(0);transform-origin:left;transition:transform .7s var(--e);z-index:10}
.proj:hover::before{transform:scaleX(1)}
.proj-label{position:absolute;bottom:0;left:0;right:0;z-index:5;padding:26px 22px 12px;background:linear-gradient(to top,rgba(4,4,4,.92) 0%,rgba(4,4,4,.55) 55%,transparent 100%);transform:translateY(4px);opacity:.88;transition:all .5s var(--e)}
.proj:hover .proj-label{transform:translateY(0);opacity:1}
.proj-cat{font-family:var(--label);font-size:7px;letter-spacing:.35em;text-transform:uppercase;color:rgba(196,164,156,.48);margin-bottom:3px}
.proj-name{font-family:var(--disp);font-size:clamp(12px,1.1vw,15px);font-weight:400;font-style:italic;color:rgba(245,240,235,.92);line-height:1.18}
.proj-video{position:absolute;inset:3%;width:94%;height:94%;object-fit:contain;display:block;background:#0a0a0a}
.proj-video-mute{position:absolute;top:16px;right:16px;z-index:6;width:26px;height:26px;border-radius:50%;background:rgba(8,8,8,.55);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .4s var(--e)}
.proj-video-mute svg{width:11px;height:11px;fill:rgba(245,240,235,.85);stroke:none}
.proj:hover .proj-video-mute{opacity:.95}
.proj-video-card .proj-fill::before{background:radial-gradient(ellipse at 50% 30%,rgba(8,8,8,0) 0%,rgba(8,8,8,.18) 100%)}


/* ═══════ CAPABILITIES ═══════ */
#capabilities{background:rgba(8,8,8,.86);backdrop-filter:blur(5px);position:relative;overflow:hidden}
.cap-head{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;padding:clamp(88px,11vh,168px) 52px clamp(52px,6.5vh,92px);gap:56px;align-items:end;border-bottom:1px solid var(--rule)}
.cap-hed{
  font-family:var(--disp);
  font-size:clamp(44px,6.5vw,92px);
  font-weight:400;line-height:.86;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ivory);
}
.cap-hed em{
  display:block;font-family:var(--play);font-weight:400;font-style:italic;
  font-size:.7em;letter-spacing:.02em;text-transform:none;
  color:rgba(245,240,235,.42);margin-top:4px;
}
.cap-sub{font-family:var(--label);font-size:8px;letter-spacing:.44em;text-transform:uppercase;color:rgba(196,164,156,.52);margin-bottom:11px}
.cap-desc-txt{font-family:var(--play);font-size:clamp(17px,1.8vw,23px);font-weight:300;font-style:italic;color:rgba(245,240,235,.4);line-height:1.62;padding-left:15px;border-left:1px solid rgba(196,164,156,.22)}
.cap-cards{position:relative;z-index:2;display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(245,240,235,.06)}
.cap-card{position:relative;overflow:hidden;background:rgba(8,8,8,.9);padding:clamp(52px,6vh,64px) 26px clamp(46px,5.5vh,58px);cursor:default;min-height:230px;transition:background .38s ease}
.cap-card:hover{background:rgba(18,18,18,.96)}
.cap-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--rose),var(--chrome),var(--rose),transparent);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--e);z-index:2}
.cap-card:hover::before{transform:scaleX(1)}
/* Big ghost number — Tenor Sans display */
.cap-num{
  font-family:var(--disp);font-size:76px;font-weight:400;letter-spacing:.04em;
  color:rgba(245,240,235,.03);line-height:1;margin-bottom:-14px;user-select:none;transition:color .38s ease;
}
.cap-card:hover .cap-num{color:rgba(196,164,156,.07)}
.cap-name{
  font-family:var(--label);font-size:clamp(9px,.85vw,11px);font-weight:400;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(245,240,235,.52);line-height:1.4;position:relative;z-index:1;transition:color .38s ease;
}
.cap-card:hover .cap-name{color:var(--ivory)}
.cap-body{
  font-family:var(--corm);font-size:clamp(12px,1.2vw,14px);font-weight:300;font-style:italic;
  color:rgba(245,240,235,.36);line-height:1.7;margin-top:15px;position:relative;z-index:1;
  max-height:0;overflow:hidden;opacity:0;transition:max-height .5s var(--e),opacity .4s ease;
}
.cap-card:hover .cap-body{max-height:140px;opacity:1}
.cap-arrow{position:absolute;bottom:19px;right:19px;font-size:12px;color:rgba(245,240,235,.1);transition:all .38s ease}
.cap-card:hover .cap-arrow{color:rgba(196,164,156,.62);transform:translate(2px,-2px)}
.cap-footer{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(245,240,235,.06);border-top:1px solid var(--rule)}
.cap-foot-item{padding:11px 18px;text-align:center;background:rgba(8,8,8,.9);font-family:var(--label);font-size:8px;letter-spacing:.26em;text-transform:uppercase;color:rgba(245,240,235,.24)}

/* ═══════ PURSUITS ═══════ */
#pursuits{background:rgba(8,8,8,.86);backdrop-filter:blur(5px);overflow:hidden;position:relative}
.pursuits-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.pursuits-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.pursuits-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,6,6,.68) 0%,rgba(6,6,6,.58) 50%,rgba(6,6,6,.72) 100%)}

/* Shared cohesive background — reused across Selected Work, Mood Board, Statement, Core Focus, Contact */
.shared-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.shared-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.shared-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,6,6,.82) 0%,rgba(6,6,6,.74) 50%,rgba(6,6,6,.86) 100%)}
.pursuits-head{position:relative;z-index:2;display:flex;align-items:baseline;gap:22px;padding:clamp(88px,11vh,168px) 52px clamp(46px,5.5vh,80px);border-bottom:1px solid var(--rule)}
/* "What Moves Me" — Playfair italic, gorgeous */
.pursuits-hed{
  font-family:var(--disp);
  font-size:clamp(32px,4.5vw,68px);
  font-weight:400;font-style:italic;letter-spacing:-.01em;color:var(--ivory);
}
.pursuits-sub{font-family:var(--corm);font-size:16px;font-weight:300;font-style:italic;color:rgba(245,240,235,.5)}
.mq-band{position:relative;z-index:2;overflow:hidden;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin-top:2px;background:rgba(8,8,8,.35)}
.mq-band+.mq-band{margin-top:1px}
.mq-track{display:flex;width:max-content;animation:mq 36s linear infinite}
.mq-band:last-child .mq-track{animation-direction:reverse;animation-duration:28s}
.mq-item{display:inline-flex;align-items:center;padding:17px 40px;gap:16px;border-right:1px solid var(--rule);white-space:nowrap}
/* Marquee words — Cormorant italic */
.mq-word{font-family:var(--corm);font-size:clamp(18px,2.2vw,32px);font-weight:300;font-style:italic;letter-spacing:.04em;color:rgba(245,240,235,.55);transition:color .3s ease}
.mq-item:hover .mq-word{color:var(--ivory)}
.mq-dot{font-size:4px;color:rgba(196,164,156,.42)}

/* ═══════ GALLERY ═══════ */
#gallery{background:rgba(8,8,8,.86);backdrop-filter:blur(5px)}
.gal-head{display:flex;align-items:flex-end;justify-content:space-between;padding:clamp(88px,11vh,168px) 52px clamp(52px,6.5vh,92px);gap:38px;border-bottom:1px solid var(--rule)}
.gal-hed{
  font-family:var(--disp);
  font-size:clamp(44px,6.5vw,92px);
  font-weight:400;line-height:.86;letter-spacing:.04em;text-transform:uppercase;color:var(--ivory);
}
.gal-hed em{
  display:block;font-family:var(--play);font-weight:400;font-style:italic;
  font-size:.68em;letter-spacing:.02em;text-transform:none;
  color:rgba(245,240,235,.36);margin-top:4px;
}
.gal-note{font-family:var(--label);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,240,235,.28);line-height:1.9;text-align:right;max-width:152px}
.gal-grid{display:grid;grid-template-columns:1.7fr 1fr 1.2fr;grid-template-rows:390px 225px;gap:1px;background:rgba(245,240,235,.06)}
.gi{position:relative;overflow:hidden;background:#080808}
.gi:nth-child(1){grid-row:span 2}.gi:nth-child(3){grid-column:3;grid-row:span 2}
.gi-inner{position:absolute;inset:0;transition:transform 1.3s var(--e)}
.gi:hover .gi-inner{transform:scale(1.04)}
.gi:nth-child(1) .gi-inner{background:linear-gradient(155deg,#1e1e1e 0%,#0c0c0c 35%,#181818 100%)}
.gi:nth-child(2) .gi-inner{background:linear-gradient(122deg,#161616 0%,#0a0a0a 100%)}
.gi:nth-child(3) .gi-inner{background:linear-gradient(192deg,#1a1a1a 0%,#060606 55%,#121212 100%)}
.gi:nth-child(4) .gi-inner{background:linear-gradient(106deg,#0e0e0e 0%,#181818 100%)}
.gi-inner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 42% 22%,rgba(196,164,156,.04) 0%,transparent 55%)}
.gi::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--rose),var(--chrome),var(--rose),transparent);transform:scaleX(0);transform-origin:left;transition:transform .7s var(--e);z-index:5}
.gi:hover::before{transform:scaleX(1)}
.gi-lbl{position:absolute;bottom:16px;left:20px;z-index:3;font-family:var(--label);font-size:8px;letter-spacing:.35em;text-transform:uppercase;color:rgba(245,240,235,.16)}

/* ═══════ DIARY ═══════ */
#diary{background:#0a0a0a;position:relative;overflow:hidden;width:100%;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
.diary-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.diary-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.diary-head{position:absolute;z-index:2;top:36px;left:36px;text-align:left;pointer-events:none}
.diary-hed-corner{font-family:var(--label);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:rgba(245,240,235,.85);text-shadow:0 1px 8px rgba(0,0,0,.6)}
.diary-hed{
  font-family:var(--disp);
  font-size:clamp(44px,6.5vw,92px);
  font-weight:400;line-height:.86;letter-spacing:.04em;text-transform:uppercase;color:var(--ivory);
}
.diary-hed em{
  display:block;font-family:var(--play);font-weight:400;font-style:italic;
  font-size:.68em;letter-spacing:.02em;text-transform:none;
  color:rgba(245,240,235,.34);margin-top:4px;
}
.diary-intro{font-family:var(--disp);font-size:clamp(16px,1.7vw,22px);font-weight:400;font-style:italic;color:rgba(245,240,235,.55);line-height:1.62;max-width:560px}
.diary-canvas{padding:50px 52px;position:relative;z-index:2;min-height:730px;background:rgba(6,6,6,.5)}
/* Ghost — Playfair italic "Vision" */
.diary-ghost{
  position:absolute;top:0;right:-18px;
  font-family:var(--disp);font-style:italic;
  font-size:clamp(150px,22vw,300px);
  font-weight:400;color:var(--ivory);opacity:.016;
  letter-spacing:-.02em;user-select:none;pointer-events:none;
}
.pin{position:absolute;cursor:pointer;transition:transform .6s var(--e),box-shadow .6s ease;z-index:1}
.pin:hover{z-index:40}
.pin-img{width:100%;height:100%;position:relative;overflow:hidden}
.pin-photo{position:absolute;inset:0;transition:transform .8s var(--e)}
.pin-photo video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.pin:hover .pin-photo{transform:scale(1.05)}
.pin-photo::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 42% 22%,rgba(196,164,156,.04) 0%,transparent 55%)}
.pin-photo::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.68' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.11'/%3E%3C/svg%3E");opacity:.4;mix-blend-mode:overlay}
.pin.fr{border:5px solid rgba(245,240,235,.055);box-shadow:0 4px 22px rgba(4,4,4,.7)}
.pin.fr:hover{box-shadow:0 16px 48px rgba(4,4,4,.88)}
.pin.dk{border:3px solid #1a1a1a;box-shadow:0 4px 16px rgba(4,4,4,.65)}
.pin.dk:hover{box-shadow:0 16px 42px rgba(4,4,4,.85)}
.pin-cap{padding:6px 10px;border-top:1px solid rgba(245,240,235,.06);background:#0c0c0c;font-family:var(--label);font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,240,235,.24);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pin.tp::before{content:'';position:absolute;top:-7px;left:50%;transform:translateX(-50%);width:28px;height:12px;background:rgba(245,240,235,.055);border:1px solid rgba(245,240,235,.09);z-index:10}
.qc{position:absolute;background:rgba(10,10,10,.94);border:1px solid rgba(196,164,156,.1);padding:15px 17px;z-index:5;cursor:default;transition:transform .5s var(--e),box-shadow .5s ease}
.qc:hover{z-index:40;box-shadow:0 14px 44px rgba(4,4,4,.88);transform:rotate(0deg) scale(1.03)!important}
.qc-l{font-family:var(--label);font-size:7px;letter-spacing:.42em;text-transform:uppercase;color:rgba(196,164,156,.45);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(245,240,235,.06)}
.qc-t{font-family:var(--disp);font-size:clamp(12px,1.3vw,15px);font-weight:400;font-style:italic;line-height:1.42;color:var(--ivory)}
.qc-a{margin-top:8px;font-family:var(--label);font-size:7px;letter-spacing:.3em;text-transform:uppercase;color:rgba(245,240,235,.24)}
.d1{background:linear-gradient(155deg,#1e1e1e 0%,#0e0e0e 40%,#181818 100%)}
.d2{background:linear-gradient(200deg,#161616 0%,#222222 55%,#0a0a0a 100%)}
.d3{background:linear-gradient(125deg,#181818 0%,#242424 100%)}
.d4{background:linear-gradient(165deg,#1c1c1c 0%,#101010 45%,#282828 100%)}
.d5{background:linear-gradient(240deg,#141414 0%,#1e1e1e 100%)}
.d6{background:linear-gradient(100deg,#1a1a1a 0%,#101010 55%,#242424 100%)}
.d7{background:linear-gradient(175deg,#222222 0%,#0c0c0c 50%,#181818 100%)}
.d8{background:linear-gradient(135deg,#161616 0%,#242424 100%)}
.d9{background:linear-gradient(195deg,#141414 0%,#0e0e0e 100%)}
.d10{background:linear-gradient(115deg,#1e1e1e 0%,#0c0c0c 100%)}
.tstrip{position:relative;z-index:2;display:grid;grid-template-columns:repeat(8,1fr);gap:1px;background:rgba(245,240,235,.06);border-top:1px solid var(--rule)}
.ts{height:150px;position:relative;overflow:hidden;background:#0a0a0a;cursor:pointer}
.ts-photo{position:absolute;inset:0;transition:transform .8s var(--e)}
.ts-photo video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.ts:hover .ts-photo{transform:scale(1.07)}
.ts::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--rose),var(--chrome),var(--rose),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--e);z-index:5}
.ts:hover::before{transform:scaleX(1)}
.ts-lbl{position:absolute;bottom:11px;left:12px;z-index:3;font-family:var(--label);font-size:7px;letter-spacing:.38em;text-transform:uppercase;color:rgba(245,240,235,.18)}

/* ═══════ CONTACT ═══════ */
#contact{min-height:74vh;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(64px,8.5vh,120px) 52px clamp(84px,11vh,140px);position:relative;overflow:hidden;background:rgba(8,8,8,.94);backdrop-filter:blur(10px)}
#contact::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(196,164,156,.04) 0%,transparent 60%);pointer-events:none}
.contact-ghost{
  position:absolute;bottom:-45px;left:-16px;z-index:1;
  font-family:var(--disp);font-style:italic;
  font-size:clamp(110px,17vw,240px);
  font-weight:400;line-height:1;color:rgba(245,240,235,.013);
  letter-spacing:-.03em;user-select:none;pointer-events:none;
}
.contact-inner{position:relative;z-index:2}
.contact-eye{position:relative;z-index:2;font-family:var(--label);font-size:8px;letter-spacing:.5em;text-transform:uppercase;color:rgba(196,164,156,.45);margin-bottom:36px;padding-top:16px;border-top:1px solid rgba(245,240,235,.07)}
/* Contact heading — Tenor Sans */
.contact-hed{
  font-family:var(--disp);
  font-size:clamp(48px,9.5vw,138px);
  font-weight:400;line-height:.82;letter-spacing:-.01em;text-transform:uppercase;
  margin-bottom:52px;max-width:960px;color:var(--ivory);
}
.contact-hed.one-line{font-size:clamp(26px,3.6vw,58px);max-width:1400px;white-space:nowrap;line-height:1.1}
.contact-hed em{
  display:block;font-family:var(--play);font-weight:400;font-style:italic;
  font-size:.7em;letter-spacing:.02em;text-transform:none;
  color:rgba(210,188,180,.44);margin-top:6px;
}
.contact-row{display:flex;gap:0;border:1px solid rgba(245,240,235,.08)}
.cl{flex:1;display:flex;flex-direction:column;gap:7px;text-decoration:none;padding:20px 30px;border-right:1px solid rgba(245,240,235,.08);transition:background .28s ease}
.cl:last-child{border-right:none}
.cl:hover{background:rgba(245,240,235,.04)}
.cl-tag{font-family:var(--label);font-size:8px;letter-spacing:.4em;text-transform:uppercase;color:rgba(245,240,235,.18)}
.cl-val{font-family:var(--corm);font-size:clamp(14px,1.7vw,20px);font-weight:400;font-style:italic;color:rgba(245,240,235,.42);display:flex;align-items:center;gap:5px;transition:color .28s ease}
.cl-val::after{content:'↗';font-size:11px;opacity:0;transform:translate(-4px,4px);transition:all .28s ease}
.cl:hover .cl-val{color:var(--ivory)}
.cl:hover .cl-val::after{opacity:1;transform:translate(0,0)}
footer{background:rgba(4,4,4,.98);border-top:1px solid rgba(245,240,235,.05);padding:20px 52px;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:3}
.foot-sig{font-family:var(--brush);font-size:17px;font-weight:600;letter-spacing:.02em;color:rgba(245,240,235,.22)}
.foot-line{font-family:var(--corm);font-size:11px;color:rgba(245,240,235,.1);font-style:italic}
.foot-yr{font-family:var(--label);font-size:9px;color:rgba(245,240,235,.1);letter-spacing:.15em}

/* ═══════ ANIMATIONS ═══════ */
.cw{display:inline-block;overflow:hidden;vertical-align:bottom}
.cword{display:inline;white-space:nowrap}
.cs{display:inline-block;opacity:0;transform:translateY(100%);transition:opacity .75s var(--e),transform .75s var(--e)}
.cw.in .cs{opacity:1;transform:translateY(0)}
.au{opacity:0;transform:translateY(16px);transition:opacity .95s var(--e),transform .95s var(--e)}
.au.in{opacity:1;transform:translateY(0)}
.ac{position:relative;overflow:hidden}
.ac::after{content:'';position:absolute;inset:0;z-index:20;background:#0c0c0c;transform:scaleX(1);transform-origin:left;transition:transform 1.3s var(--e)}
.ac.in::after{transform:scaleX(0);transform-origin:right}
.as{position:relative}
.as::before{content:'';position:absolute;top:0;left:0;width:0;height:1px;background:linear-gradient(to right,rgba(196,164,156,.3),var(--chrome));transition:width 2s var(--e);z-index:10}
.as.in::before{width:100%}
.stg>*{opacity:0;transform:translateY(13px);transition:opacity .75s var(--e),transform .75s var(--e)}
.stg.in>*:nth-child(1){opacity:1;transform:none;transition-delay:0s}
.stg.in>*:nth-child(2){opacity:1;transform:none;transition-delay:.1s}
.stg.in>*:nth-child(3){opacity:1;transform:none;transition-delay:.2s}
.stg.in>*:nth-child(4){opacity:1;transform:none;transition-delay:.3s}
.stg.in>*:nth-child(5){opacity:1;transform:none;transition-delay:.4s}
.stg.in>*:nth-child(6){opacity:1;transform:none;transition-delay:.5s}
.stg.in>*:nth-child(7){opacity:1;transform:none;transition-delay:.6s}
.stg.in>*:nth-child(8){opacity:1;transform:none;transition-delay:.7s}
.d1x{transition-delay:.1s!important}.d2x{transition-delay:.2s!important}
.d3x{transition-delay:.3s!important}.d4x{transition-delay:.4s!important}
@keyframes aFade{from{opacity:0}to{opacity:1}}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes pulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}

@media(max-width:1100px) and (min-width:901px){
  .proj-grid{grid-template-columns:1fr 1fr;grid-template-rows:480px 480px}
}
@media(max-width:900px){
  nav{padding:0 22px;flex-wrap:wrap;height:auto;padding-top:11px;padding-bottom:11px}
  .nav-links{position:static;transform:none;gap:14px;flex-wrap:wrap;margin-top:8px;justify-content:center}
  .nav-right{display:none}
  .h-strip,.h-spine{display:none}
  .h-content{padding:0 22px 0}
  .h-julia{font-size:clamp(72px,18vw,140px)}
  .h-kastin{font-size:clamp(64px,16vw,120px)}
  .h-portfolio-line{flex-direction:column;gap:8px}
  .h-port-right{display:none}
  .h-scroll{right:22px}
  .sm{padding:0 22px}
  
  .about-visual{min-height:280px;border-right:none}
  .about-content{padding:48px 22px}
  .statement{padding:clamp(80px,12vh,120px) 22px}
  .stmt-q{font-size:clamp(18px,5.6vw,26px)}
  .stmt-q br{display:none}
  .mb-head{grid-template-columns:1fr}
  .mb-title-col{border-right:none;padding:clamp(64px,9vh,96px) 22px 34px}
  .mb-text-col{padding:0 22px 44px}
  .mb-img-wrap{padding:clamp(30px,5vh,48px) 22px}
  .mb-caption{padding:12px 22px;flex-direction:column;gap:5px}
  .proj-header,.cap-head,.gal-head,.pursuits-head{padding-left:22px;padding-right:22px;grid-template-columns:1fr}
  .diary-head{top:20px;left:20px}
  .proj-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .proj{height:250px}
  .cap-cards{grid-template-columns:repeat(2,1fr)!important}
  .cap-body{max-height:none;opacity:1;margin-top:11px}
  .gal-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gi:nth-child(1),.gi:nth-child(3){grid-column:span 2;grid-row:auto;height:210px}
  .gi{height:175px}
  .gal-head{flex-direction:column;gap:11px}
  .gal-note{text-align:left;max-width:100%}
  .diary-canvas{padding:22px 14px;min-height:1180px}
  .tstrip{grid-template-columns:repeat(4,1fr)}
  #contact{padding:clamp(48px,7vh,80px) 22px clamp(60px,9vh,96px)}
  .contact-hed{font-size:clamp(36px,11vw,60px);white-space:normal}
  .contact-hed.one-line{font-size:clamp(26px,7.5vw,40px);white-space:normal}
  .contact-hed em{white-space:normal}
  .contact-row{flex-direction:column}
  .cl{border-right:none;border-bottom:1px solid rgba(245,240,235,.08)}
  .cl:last-child{border-bottom:none}
  footer{padding:18px 22px;flex-direction:column;gap:9px;text-align:center}
}
@media(prefers-reduced-motion:reduce){
  .h-julia,.h-kastin{animation:none!important;opacity:1!important;transform:none!important;filter:none!important}
  .h-portfolio-line,.h-strip,.h-spine,.h-scroll{animation:none!important;opacity:1!important}
  .au,.ac,.as,.stg>*,.cs{opacity:1;transform:none;transition:none}
  .ac::after,.as::before{display:none}
  .mq-track{animation:none}
}

/* ═══════ COVER · full-bleed title-film ═══════ */
#hero{ height:100vh; min-height:560px; position:relative; overflow:hidden; background:#070706; }
.h-film{ position:absolute; inset:0; width:100%; height:100%; overflow:hidden; }
.h-film video{ position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center 52%; display:block; }
.h-film::after{ content:''; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to bottom, rgba(6,6,6,0) 70%, rgba(6,6,6,.42) 100%); }
.h-scroll{ position:absolute; right:auto; bottom:30px; left:50%; transform:translateX(-50%);
  z-index:6; display:flex; flex-direction:column; align-items:center; gap:9px;
  text-decoration:none; opacity:0; animation:aFade 1s ease 1.2s forwards; }
.h-scroll span{ font-family:var(--label); font-size:8px; letter-spacing:.5em;
  text-transform:uppercase; color:rgba(245,240,235,.72); }
.h-scroll .h-scroll-line{ width:1px; height:40px;
  background:linear-gradient(to bottom,rgba(245,240,235,.6),transparent);
  animation:pulse 2.8s ease-in-out infinite 2s; }
@media(max-width:760px){ .h-scroll{ bottom:24px; } }

/* ============================================================
   About — editorial module
   ============================================================ */

/* ═══════════ ABOUT · EDITORIAL FEATURE  (dark · cinematic · Vogue × SKIMS × Rhode) ═══════════ */
#about.about-editorial{
  --ink:#f4efe8; --body:rgba(243,238,231,.6); --muted:rgba(243,238,231,.34);
  --rose:#c4a49c; --line:rgba(243,238,231,.12); --line-faint:rgba(243,238,231,.055);
  position:relative; z-index:3; isolation:isolate; color:var(--body);
  background:
    radial-gradient(135% 80% at 50% -12%, rgba(196,164,156,.12) 0%, rgba(196,164,156,0) 46%),
    radial-gradient(120% 130% at 50% 46%, rgba(0,0,0,0) 52%, rgba(0,0,0,.6) 100%),
    linear-gradient(180deg, #0c0b0a 0%, #080807 58%, #0b0a09 100%);
  padding:clamp(120px,17vh,228px) 0 clamp(104px,14vh,196px);
  overflow:hidden;
}
/* faint hairlines framing the spread */
#about.about-editorial::before,
#about.about-editorial::after{
  content:''; position:absolute; left:0; right:0; height:1px; z-index:2;
  pointer-events:none; background:var(--line-faint);
}
#about.about-editorial::before{ top:0; }
#about.about-editorial::after{ bottom:0; }

#about.about-editorial .ae-wrap{
  position:relative; z-index:3; width:min(1200px,88vw); margin:0 auto;
}

/* ── folio / masthead kicker ── */
#about.about-editorial .ae-top{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding-bottom:clamp(26px,3.2vw,44px);
  border-bottom:1px solid var(--line);
  font-family:var(--label); font-weight:300; font-size:10px;
  letter-spacing:.42em; text-transform:uppercase; color:var(--muted);
}
#about.about-editorial .ae-folio{
  display:inline-flex; align-items:center; gap:15px; color:var(--ink); flex-shrink:0;
}
#about.about-editorial .ae-folio-rule{
  width:36px; height:1px; background:var(--rose); opacity:.9;
  box-shadow:0 0 12px rgba(196,164,156,.5);
}
#about.about-editorial .ae-year{ color:var(--muted); flex-shrink:0; }

/* ── masthead title ── */
#about.about-editorial .ae-masthead{
  padding-top:clamp(40px,5.6vw,84px); padding-bottom:clamp(48px,6.8vw,110px);
  position:relative;
}
/* cinematic spotlight behind the title */
#about.about-editorial .ae-masthead::before{
  content:''; position:absolute; left:-6%; top:8%; width:64%; height:120%;
  background:radial-gradient(60% 60% at 30% 50%, rgba(196,164,156,.16), rgba(196,164,156,0) 70%);
  filter:blur(8px); z-index:-1; pointer-events:none;
}
#about.about-editorial .ae-title{
  margin:0; font-family:var(--disp); font-weight:400;
  font-size:clamp(60px,10.6vw,172px); line-height:.9;
  letter-spacing:-.022em; text-indent:-.02em;
  color:#f5f0eb; /* solid fallback — heading always visible */
  filter:drop-shadow(0 2px 30px rgba(0,0,0,.55));
}
/* gradient sheen only where text-clip is supported (otherwise stays solid ivory) */
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  #about.about-editorial .ae-title{
    background:linear-gradient(176deg, #faf6f0 0%, #efe7dd 42%, #c8beb3 100%);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent;
  }
}

/* ── body : asymmetric editorial grid ── */
#about.about-editorial .ae-body{
  display:grid; align-items:start;
  grid-template-columns:minmax(0,1fr) minmax(0,2.55fr);
  gap:clamp(34px,5vw,94px);
}
#about.about-editorial .ae-rail{
  display:flex; flex-direction:column; align-items:flex-start;
  gap:20px; padding-top:16px; align-self:stretch;
}
#about.about-editorial .ae-rail-dot{
  width:7px; height:7px; border-radius:50%; background:var(--rose);
  box-shadow:0 0 14px rgba(196,164,156,.6);
}
#about.about-editorial .ae-rail-line{
  width:1px; flex:1; min-height:140px;
  background:linear-gradient(var(--line), transparent);
}

#about.about-editorial .ae-main{ max-width:65ch; }

/* lead / standfirst */
#about.about-editorial .ae-lead{
  margin:0; max-width:40ch; font-family:var(--corm); font-style:italic;
  font-weight:400; color:var(--ink); font-size:clamp(23px,2.65vw,37px);
  line-height:1.4; letter-spacing:.002em; text-wrap:balance;
}
#about.about-editorial .ae-divider{
  width:100%; height:1px; background:var(--line);
  margin:clamp(40px,4.6vw,68px) 0;
}
#about.about-editorial .ae-cols p{
  margin:0 0 1.5em; font-family:var(--corm); font-weight:400; color:var(--body);
  font-size:clamp(17px,1.32vw,20px); line-height:1.88; letter-spacing:.004em;
}
#about.about-editorial .ae-cols p:last-child{ margin-bottom:0; }
/* drop cap — magazine signature, rose-lit */
#about.about-editorial .ae-cols p:first-child::first-letter{
  float:left; font-family:var(--disp); font-weight:400; color:var(--ink);
  font-size:3.5em; line-height:.74; padding:.05em .12em 0 0;
  text-shadow:0 0 24px rgba(196,164,156,.25);
}

/* ── reveal motion (uses existing IntersectionObserver: .in) ── */
#about.about-editorial .ae-reveal{
  opacity:0; transform:translateY(22px);
  transition:opacity 1.1s cubic-bezier(.25,0,0,1), transform 1.1s cubic-bezier(.25,0,0,1);
}
#about.about-editorial .ae-reveal.in{ opacity:1; transform:none; }
/* title : refined clip-up reveal */
#about.about-editorial .ae-title.ae-reveal{
  clip-path:inset(-14% -14% 110% -14%); transform:translateY(34px);
  transition:clip-path 1.3s cubic-bezier(.22,1,.36,1),
             transform 1.3s cubic-bezier(.22,1,.36,1),
             opacity 1.3s cubic-bezier(.22,1,.36,1);
}
#about.about-editorial .ae-title.ae-reveal.in{
  clip-path:inset(-14% -14% -14% -14%); transform:none;
}
/* stagger */
#about.about-editorial .ae-top.ae-reveal{ transition-delay:.04s; }
#about.about-editorial .ae-title.ae-reveal{ transition-delay:.12s; }
#about.about-editorial .ae-lead.ae-reveal{ transition-delay:.30s; }
#about.about-editorial .ae-rail.ae-reveal{ transition-delay:.40s; }
#about.about-editorial .ae-divider.ae-reveal{ transition-delay:.40s; }
#about.about-editorial .ae-cols.ae-reveal{ transition-delay:.48s; }

@media (max-width:860px){
  #about.about-editorial .ae-body{ grid-template-columns:1fr; gap:0; }
  #about.about-editorial .ae-rail{
    flex-direction:row; align-items:center; gap:14px;
    padding-top:0; margin-bottom:30px;
  }
  #about.about-editorial .ae-rail-line{
    width:auto; flex:1; min-height:0; height:1px;
    background:linear-gradient(90deg, var(--line), transparent);
  }
  #about.about-editorial .ae-main,
  #about.about-editorial .ae-lead{ max-width:none; }
}
@media (max-width:560px){
  #about.about-editorial .ae-top{ font-size:9px; letter-spacing:.34em; gap:14px; }
  #about.about-editorial .ae-title{ font-size:clamp(52px,16vw,94px); letter-spacing:-.018em; }
  #about.about-editorial .ae-lead{ font-size:clamp(21px,5.8vw,28px); }
  #about.about-editorial .ae-cols p:first-child::first-letter{ font-size:3em; }
  /* What Moves Me — phone layout: stack heading + caption, scale proportionally */
  .pursuits-head{ flex-direction:column; align-items:flex-start; gap:7px; }
  .pursuits-hed{ font-size:clamp(30px,8.4vw,46px); line-height:1.04; }
  .pursuits-sub{ font-size:15px; }
}
@media (prefers-reduced-motion:reduce){
  #about.about-editorial .ae-reveal,
  #about.about-editorial .ae-title.ae-reveal{
    opacity:1; transform:none; clip-path:none; transition:none;
  }
}
