/* =========================================================================
   ADI GOLAN — Interior Design Portfolio
   A close study of Norm Architects (normcph.com): warm cream, light serif
   display + sans, full-screen image hero, uniform minimal project grid.
   ========================================================================= */

:root {
  --paper:    #F1ECE2;
  --paper-2:  #E4DDCE;
  --ink:      #2B2822;
  --ink-2:    #6E695D;
  --ink-3:    #A39C8C;
  --line:     rgba(43, 40, 34, .15);
  --line-2:   rgba(43, 40, 34, .07);

  --foot-bg:  #211E18;
  --foot-fg:  #ECE7DC;
  --foot-fg2: #918B7C;
  --foot-line: rgba(236, 231, 220, .16);

  --serif: "Cormorant", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", "Helvetica Neue", Helvetica, Arial, sans-serif;

  --fs-label: clamp(.68rem, .65rem + .12vw, .76rem);
  --fs-body:  clamp(.92rem, .89rem + .16vw, 1.02rem);
  --fs-lead:  clamp(1.05rem, .95rem + .5vw, 1.38rem);
  --fs-title: clamp(1.45rem, 1.15rem + 1.1vw, 2.2rem);
  --fs-h2:    clamp(1.5rem, 1.1rem + 1.6vw, 2.4rem);

  --pad:     clamp(1.25rem, .4rem + 3.6vw, 4.75rem);
  --section: clamp(5rem, 3.5rem + 9vw, 12rem);
  --maxw:    1680px;

  --ease:   cubic-bezier(.22, .61, .15, 1);
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: 1.62;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
::selection { background: var(--ink); color: var(--paper); }

/* ---------------------------------------------------------------- helpers */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad); }
.label { font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-2); }
.serif { font-family: var(--serif); }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }

.reveal { opacity: 0; transform: translateY(18px); transition: opacity 1.2s var(--ease), transform 1.2s var(--ease); transition-delay: var(--d, 0ms); }
.reveal.in { opacity: 1; transform: none; }

.frame { overflow: hidden; background: var(--paper-2); }
.frame img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.6s var(--ease); }
.bleed { width: 100%; }

/* ===================================================================== nav */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 9000;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(1.2rem, .85rem + 1vw, 2rem) var(--pad);
  color: var(--ink);
  transition: background .55s var(--ease), color .55s var(--ease), border-color .55s, padding .55s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.on-image { color: #fff; }
.nav.solid { background: color-mix(in srgb, var(--paper) 92%, transparent); backdrop-filter: blur(12px) saturate(1.05); border-bottom-color: var(--line); color: var(--ink); padding-block: clamp(.95rem, .7rem + .6vw, 1.25rem); }
.brand { font-family: var(--serif); font-weight: 500; font-size: 1.32rem; letter-spacing: .24em; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: clamp(1.3rem, 2.6vw, 3rem); }
.nav-links a { font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .14em; text-transform: uppercase; position: relative; padding: .35rem 0; }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1px; background: currentColor; transition: width .45s var(--ease); }
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
@media (max-width: 560px) {
  .nav { padding-inline: 1.15rem; }
  .brand { font-size: 1.05rem; letter-spacing: .16em; }
  .nav-links { gap: 1.05rem; }
  .nav-links a { letter-spacing: .06em; }
}

/* =============================================================== hero (full) */
.hero-full { position: relative; height: 100svh; min-height: 560px; }
.hero-full .frame { position: absolute; inset: 0; background: var(--paper-2); }
.hero-full .frame img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.06); opacity: 0; will-change: transform, opacity; }
body.loaded .hero-full .frame img { transform: scale(1); opacity: 1; transition: transform 2.6s var(--ease), opacity 1.5s ease; }
.hero-full::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(20,18,14,.22) 0%, rgba(20,18,14,0) 32%, rgba(20,18,14,0) 55%, rgba(20,18,14,.5) 100%); z-index: 1; }
.hero-overlay { position: absolute; inset: auto 0 clamp(3.5rem, 11vh, 8rem) 0; z-index: 2; text-align: center; color: #fff; padding-inline: var(--pad); }
.hero-eyebrow { font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .26em; text-transform: uppercase; opacity: .92; }
.hero-name { font-family: var(--serif); font-weight: 400; font-size: clamp(2.6rem, 1.6rem + 4vw, 6rem); letter-spacing: .12em; text-transform: uppercase; line-height: 1; margin: clamp(1rem, 2.5vh, 1.6rem) 0 clamp(1.2rem, 3vh, 2rem); }
.hero-bio { font-family: var(--sans); font-weight: 300; font-size: clamp(1rem, .92rem + .5vw, 1.3rem); line-height: 1.55; max-width: 50ch; margin-inline: auto; opacity: .96; text-transform: uppercase; letter-spacing: .04em; }
.hero-scroll { position: absolute; bottom: clamp(1.2rem, 3vh, 2rem); left: 50%; transform: translateX(-50%); z-index: 2; color: #fff; font-family: var(--sans); font-size: var(--fs-label); letter-spacing: .2em; text-transform: uppercase; opacity: 0; animation: bob 2.6s var(--ease) infinite; }
body.loaded .hero-scroll { opacity: .82; transition: opacity 1s ease 1.15s; }
@keyframes bob { 0%,100% { transform: translate(-50%, 0); } 50% { transform: translate(-50%, 6px); } }

/* hero load choreography */
.hero-overlay .load { opacity: 0; transform: translateY(16px); }
body.loaded .hero-overlay .load { opacity: 1; transform: none; transition: opacity 1.1s var(--ease), transform 1.1s var(--ease); transition-delay: var(--d, 0s); }
.hero-name .clip { display: inline-block; overflow: hidden; vertical-align: top; padding: .04em 0; }
.hero-name .clip-i { display: inline-block; transform: translateY(112%); }
body.loaded .hero-name .clip-i { transform: translateY(0); transition: transform 1.25s var(--ease); transition-delay: var(--d, 0s); }

/* =============================================================== projects */
.projects { padding-block: var(--section); position: relative; }
.vlabel { position: absolute; left: clamp(.5rem, 1.4vw, 1.4rem); top: var(--section); writing-mode: vertical-rl; transform: rotate(180deg); font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .5em; text-transform: uppercase; color: var(--ink-3); }
@media (max-width: 1100px) { .vlabel { display: none; } }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding-bottom: clamp(2.6rem, 6vh, 4.5rem); }
.section-head h2 { font-family: var(--serif); font-weight: 400; font-size: var(--fs-h2); letter-spacing: .01em; line-height: 1; }

.project-grid { --col-gap: clamp(1.4rem, .8rem + 2vw, 2.6rem); display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(2.2rem, 1.2rem + 3vw, 4.5rem) var(--col-gap); }
.project-grid .project-link { width: calc((100% - 2 * var(--col-gap)) / 3); }
.project-link { display: block; }
.project-link .frame { aspect-ratio: 4 / 3; }
.project-link:hover .frame img { transform: scale(1.04); }
.project-cap { margin-top: clamp(.9rem, 2vh, 1.3rem); text-align: center; display: grid; gap: .55rem; justify-items: center; }
.project-cap .pt { position: relative; font-family: var(--serif); font-weight: 500; font-size: var(--fs-title); letter-spacing: .06em; text-transform: uppercase; line-height: 1.1; }
.project-cap .pt::after { content: ""; position: absolute; left: 50%; right: 50%; bottom: -.16em; height: 1px; background: currentColor; transition: left .55s var(--ease), right .55s var(--ease); }
.project-link:hover .pt::after { left: 0; right: 0; }
/* staggered grid reveal */
.project-grid .project-link:nth-child(1) { --d: 0ms; }
.project-grid .project-link:nth-child(2) { --d: 70ms; }
.project-grid .project-link:nth-child(3) { --d: 140ms; }
.project-grid .project-link:nth-child(4) { --d: 90ms; }
.project-grid .project-link:nth-child(5) { --d: 160ms; }
/* image settles in as it reveals */
.project-link .frame img, .bigfig .frame img, .shot .frame img { transform: scale(1.045); }
.project-link.in .frame img, .bigfig.in .frame img, .shot.in .frame img { transform: scale(1); transition: transform 1.8s var(--ease); }
.project-meta { font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-3); }
@media (max-width: 860px) { .project-grid .project-link { width: calc((100% - var(--col-gap)) / 2); } }
@media (max-width: 540px) { .project-grid { gap: 2.6rem; } .project-grid .project-link { width: 100%; } }

/* ======================================================= contact + footer */
.foot { background: var(--foot-bg); color: var(--foot-fg); padding: clamp(4.5rem, 11vh, 9.5rem) 0 clamp(1.8rem, 4vh, 2.6rem); text-align: center; }
.foot .label { color: var(--foot-fg2); }
.foot-lead { font-family: var(--serif); font-weight: 300; font-size: clamp(1.9rem, 1.2rem + 3.2vw, 4.4rem); line-height: 1.12; letter-spacing: .01em; max-width: 16ch; margin: 1.4rem auto clamp(2.4rem, 6vh, 3.6rem); }
.foot-mail { font-family: var(--sans); font-weight: 400; font-size: clamp(1rem, .9rem + .8vw, 1.5rem); position: relative; display: inline-block; letter-spacing: .01em; }
.foot-mail::after { content: ""; position: absolute; left: 0; bottom: -.05em; height: 1px; width: 100%; background: currentColor; transform: scaleX(0); transform-origin: center; transition: transform .5s var(--ease); }
.foot-mail:hover::after { transform: scaleX(1); }
.foot-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; align-items: start; text-align: left; margin-top: clamp(3.5rem, 9vh, 6rem); padding-top: clamp(2.5rem, 6vh, 4rem); border-top: 1px solid var(--foot-line); }
.foot-brand { font-family: var(--serif); font-weight: 500; letter-spacing: .22em; text-transform: uppercase; font-size: 1.2rem; color: var(--foot-fg); }
.foot-brand span { display: block; font-family: var(--sans); font-weight: 400; letter-spacing: .04em; text-transform: none; color: var(--foot-fg2); margin-top: 1rem; font-size: .92rem; line-height: 1.5; }
.foot-col h4 { margin-bottom: 1.1rem; }
.foot-col a, .foot-col p { display: block; font-size: .94rem; color: var(--foot-fg2); padding: .3rem 0; transition: color .3s; }
.foot-col a:hover { color: var(--foot-fg); }
.foot-bottom { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-top: clamp(3rem, 7vh, 5rem); }
.foot-bottom span, .foot-bottom a { font-family: var(--sans); font-size: var(--fs-label); letter-spacing: .1em; text-transform: uppercase; color: var(--foot-fg2); }
.foot-bottom a:hover { color: var(--foot-fg); }
@media (max-width: 820px) { .foot-top { grid-template-columns: 1fr 1fr; gap: 2.4rem 1.5rem; } .foot-brand { grid-column: 1 / -1; } }

/* ========================================================= project page */
.proj-hero { padding-top: clamp(8rem, 16vh, 12rem); }
.proj-back { font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-2); display: inline-flex; gap: .55rem; align-items: center; margin-bottom: clamp(2.4rem, 6vh, 3.8rem); }
.proj-back .arw { transition: transform .4s var(--ease); }
.proj-back:hover { color: var(--ink); }
.proj-back:hover .arw { transform: translateX(-5px); }
.proj-titleblock { text-align: center; padding-bottom: clamp(2.5rem, 6vh, 4rem); }
.badge { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 1.4rem; }
.badge .pulse { width: 6px; height: 6px; border-radius: 50%; background: var(--ink-2); animation: pulse 2.6s var(--ease) infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .25; } }
.proj-num { margin-bottom: 1.3rem; }
.proj-title { font-family: var(--serif); font-weight: 400; font-size: clamp(2.4rem, 1.5rem + 3.6vw, 5rem); line-height: 1.02; letter-spacing: .06em; text-transform: uppercase; }
.proj-sub { font-family: var(--sans); font-weight: 400; font-size: clamp(1rem, .9rem + .6vw, 1.3rem); color: var(--ink-2); margin-top: 1rem; letter-spacing: .01em; }
.meta-list { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: .3rem .8rem; margin-top: 1.9rem; font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .12em; text-transform: uppercase; }
.meta-list .v { color: var(--ink); }
.meta-list .sep { color: var(--ink-3); }

.proj-lead { max-width: 62ch; margin: 0 auto; padding-block: clamp(3rem, 8vh, 6rem); text-align: center; }
.proj-lead .label { display: block; margin-bottom: 1.4rem; }
.proj-lead .lead-txt { font-family: var(--serif); font-weight: 300; font-size: clamp(1.3rem, 1rem + 1.4vw, 2.1rem); line-height: 1.32; letter-spacing: .005em; }
.proj-lead .lead-txt em { font-style: italic; }

.proj-section { padding-bottom: clamp(2.5rem, 7vh, 6rem); }
.proj-section .seclabel { display: flex; justify-content: center; gap: 1rem; padding-bottom: clamp(1.6rem, 4vh, 2.6rem); }
.proj-section .seclabel .label { text-align: center; }
.bigfig .frame img { transition: transform 1.8s var(--ease); }
.bigfig:hover .frame img { transform: scale(1.02); }
/* project hero image: contained + a bit smaller (not full-screen) */
.hero-fig .frame { max-width: 66rem; margin-inline: auto; }
/* a "full" image shown small + centered (e.g. dense presentation boards) */
.bigfig--narrow .frame { max-width: 30rem; margin-inline: auto; }
.figcap { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; padding-top: 1rem; text-align: center; }

.gal { display: flex; flex-wrap: wrap; justify-content: center; gap: 1rem; }
.gal-2 .shot { width: calc((100% - 1rem) / 2); }
.gal-3 .shot { width: calc((100% - 2rem) / 3); }
.gal-4 .shot { width: calc((100% - 3rem) / 4); }
.shot { cursor: zoom-in; }
.shot:hover img { transform: scale(1.04); }
.gal-caps .shot-cap { display: block; margin-top: .7rem; font-family: var(--sans); font-size: .82rem; font-weight: 400; letter-spacing: .03em; line-height: 1.45; color: var(--ink-2); text-align: center; }
.gal.contain .frame { background: #fff; }
.gal.contain .frame img { object-fit: contain; }
@media (max-width: 860px) { .gal-3 .shot, .gal-4 .shot { width: calc((100% - 1rem) / 2); } }
@media (max-width: 520px) { .gal-2 .shot, .gal-3 .shot, .gal-4 .shot { width: 100%; } }

/* flipbook (Auraglow booklet) */
.flipbook { --pageW: min(40vw, 27rem); display: flex; justify-content: center; perspective: 2600px; }
@media (max-width: 719px) { .flipbook { --pageW: min(90vw, 28rem); } }
.book { position: relative; display: flex; transform-style: preserve-3d; box-shadow: 0 34px 70px -28px rgba(35,32,26,.5); }
.book.two { width: calc(var(--pageW) * 2); }
.book.one { width: var(--pageW); }
.pg { width: var(--pageW); aspect-ratio: 1 / 1.414; background: #fff; overflow: hidden; position: relative; }
.pg img { width: 100%; height: 100%; object-fit: contain; display: block; }
.book.two .pg-left { box-shadow: inset -20px 0 34px -22px rgba(0,0,0,.32); }
.book.two .pg-right { box-shadow: inset 20px 0 34px -22px rgba(0,0,0,.32); }
.book.two .pg-left, .book.two .pg-right, .pg-solo { cursor: pointer; }
.leaf { position: absolute; top: 0; width: var(--pageW); height: 100%; transform-style: preserve-3d; transition: transform .85s var(--ease); z-index: 6; }
.leaf.right { right: 0; transform-origin: left center; }
.leaf.left { left: 0; transform-origin: right center; }
.leaf.right.turn { transform: rotateY(-178deg); }
.leaf.left.turn { transform: rotateY(178deg); }
.leaf-face { position: absolute; inset: 0; backface-visibility: hidden; background: #fff; overflow: hidden; box-shadow: 0 0 40px -10px rgba(0,0,0,.25); }
.leaf-face img { width: 100%; height: 100%; object-fit: contain; display: block; }
.leaf-back { transform: rotateY(180deg); }

.flip-nav { display: flex; align-items: center; justify-content: center; gap: clamp(1.2rem, 3vw, 2rem); margin-top: clamp(1.4rem, 4vh, 2.2rem); }
.flip-btn { width: 48px; height: 48px; border: 1px solid var(--line); border-radius: 50%; display: grid; place-items: center; font-size: 1.3rem; line-height: 1; color: var(--ink); transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), transform .15s ease, opacity .3s; }
.flip-btn:hover:not(:disabled) { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.flip-btn:active:not(:disabled) { transform: scale(.93); }
.flip-btn:disabled { opacity: .28; cursor: default; }
.flip-counter { font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-2); min-width: 10ch; text-align: center; font-variant-numeric: tabular-nums; }

.figtext { color: var(--ink-2); max-width: 64ch; margin: 2rem auto 0; }
.figtext h4 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.3rem, 1rem + .9vw, 1.8rem); color: var(--ink); margin: 2rem 0 .5rem; letter-spacing: .02em; }
.figtext h4:first-child { margin-top: 0; }
.figtext em { font-style: italic; color: var(--ink); }

.videowrap { position: relative; background: #161510; overflow: hidden; max-width: 30rem; margin-inline: auto; aspect-ratio: 1700 / 2412; }
.videowrap video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.videowrap .vposter { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity .6s; }
.videowrap .playbtn { position: absolute; inset: 0; display: grid; place-items: center; z-index: 3; transition: opacity .4s; cursor: pointer; }
.videowrap .playbtn .circle { width: clamp(64px, 8vw, 96px); height: clamp(64px, 8vw, 96px); border-radius: 50%; border: 1px solid rgba(255,255,255,.9); background: rgba(0,0,0,.2); backdrop-filter: blur(2px); display: grid; place-items: center; transition: transform .5s var(--ease), background .4s; }
.videowrap .playbtn .circle svg { width: 34%; height: 34%; fill: #fff; margin-left: 8%; }
.videowrap:hover .playbtn .circle { transform: scale(1.08); background: rgba(255,255,255,.18); }
.videowrap.playing .playbtn, .videowrap.playing .vposter { opacity: 0; pointer-events: none; }

.dl { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .1em; text-transform: uppercase; border: 1px solid var(--line); padding: .85rem 1.4rem; border-radius: 100px; transition: background .35s, color .35s, border-color .35s; }
.dl:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.dlwrap { text-align: center; margin-top: 2.2rem; }

.nextproj { border-top: 1px solid var(--line); padding-block: clamp(3.5rem, 9vh, 7rem); text-align: center; }
.nextproj .label { display: block; margin-bottom: 1rem; }
.nextproj .npt { font-family: var(--serif); font-weight: 400; font-size: clamp(2rem, 1.3rem + 3vw, 4rem); letter-spacing: .05em; text-transform: uppercase; transition: color .35s; }
.nextproj a:hover .npt { color: var(--ink-2); }

/* =============================================================== lightbox */
.lightbox { position: fixed; inset: 0; z-index: 9999; background: color-mix(in srgb, var(--foot-bg) 96%, black); display: grid; place-items: center; opacity: 0; visibility: hidden; transition: opacity .45s var(--ease), visibility .45s; }
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox img { max-width: 92vw; max-height: 86vh; object-fit: contain; transform: scale(.98); transition: transform .45s var(--ease); }
.lightbox.open img { transform: scale(1); }
.lb-btn { position: absolute; font-family: var(--sans); font-size: var(--fs-label); font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--foot-fg); padding: 1rem; }
.lb-close { top: clamp(1rem,3vh,2rem); right: var(--pad); }
.lb-counter { position: absolute; top: clamp(1rem,3vh,2rem); left: var(--pad); font-family: var(--sans); font-size: var(--fs-label); letter-spacing: .1em; color: var(--foot-fg2); }
.lb-nav { top: 50%; transform: translateY(-50%); font-size: 1.5rem; width: 60px; height: 60px; display: grid; place-items: center; color: var(--foot-fg); }
.lb-prev { left: clamp(.2rem,2vw,1.5rem); } .lb-next { right: clamp(.2rem,2vw,1.5rem); }
.lb-nav:hover { color: #fff; }
.lb-cap { position: absolute; bottom: clamp(1rem,3vh,2rem); left: 50%; transform: translateX(-50%); font-family: var(--sans); font-size: var(--fs-label); letter-spacing: .1em; text-transform: uppercase; color: var(--foot-fg2); text-align: center; }
@media (max-width: 640px) { .lb-nav { width: 42px; height: 42px; } }

/* =========================================================== motion & polish */
/* seamless page transitions (fade out on nav, fade in on load) */
body { opacity: 0; }
body.loaded { opacity: 1; transition: opacity .55s var(--ease); }
body.leaving { opacity: 0; transition: opacity .34s var(--ease); }

/* typography polish */
.hero-name, .section-head h2, .project-cap .pt, .proj-title, .foot-lead, .nextproj .npt, .figtext h4 { text-wrap: balance; }
.hero-bio, .lead-txt, .proj-sub, .figtext p, .foot-brand span { text-wrap: pretty; }
.lb-counter { font-variant-numeric: tabular-nums; }

/* subtle image edge so covers don't blur into the cream */
.frame img { outline: 1px solid rgba(43, 40, 34, .06); outline-offset: -1px; }

/* tactile buttons + accessible focus */
.dl { transition: background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .15s ease; }
.dl:active, .lb-btn:active { transform: scale(.97); }
:focus-visible { outline: 2px solid currentColor; outline-offset: 4px; border-radius: 2px; }
.nav.on-image :focus-visible, .foot :focus-visible, .lightbox :focus-visible { outline-color: #fff; }

/* no-JS fallback: present everything */
@media (scripting: none) {
  .reveal, .hero-overlay .load { opacity: 1 !important; transform: none !important; }
  .hero-name .clip-i { transform: none !important; }
  .hero-full .frame img, .project-link .frame img, .bigfig .frame img, .shot .frame img { opacity: 1 !important; transform: none !important; }
  .hero-scroll { opacity: .82 !important; }
  body { opacity: 1 !important; }
}

/* reduced motion: present everything statically */
@media (prefers-reduced-motion: reduce) {
  body, .reveal, .hero-overlay .load { opacity: 1 !important; transform: none !important; }
  .hero-name .clip-i, .hero-full .frame img, .project-link .frame img, .bigfig .frame img, .shot .frame img { transform: none !important; opacity: 1 !important; }
  .hero-scroll { opacity: .82 !important; animation: none !important; }
  body.leaving { opacity: 1 !important; }
}
