
:root{
  --bone:#f7f2e9; --ink:#141414; --hair:#e5dfd4;
  --ghostUI:rgba(0,0,0,.22); --label:rgba(0,0,0,.34);
  --uiPad:48px; --colMax:1180px; --imgW:72vw; --imgWMax:1000px;
  --radius:10px; --shadow:0 10px 18px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.05);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bone);color:var(--ink);
  font-family:Inter, ui-sans-serif, -apple-system, Segoe UI, Roboto, Helvetica, Arial; line-height:1.6;}
a{color:inherit;text-decoration:none}

.grain{position:fixed;inset:0;z-index:0;pointer-events:none;background-image:url('/assets/grain.png');background-size:240px 240px;opacity:.22;mix-blend-mode:multiply}
.grain-v{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(70% 60% at 50% 30%, rgba(0,0,0,.05), rgba(0,0,0,0) 60%),radial-gradient(70% 70% at 50% 100%, rgba(0,0,0,.10), rgba(0,0,0,0) 65%);mix-blend-mode:multiply}

.topbar{position:sticky; top:0; left:0; right:0; z-index:20; display:flex; align-items:center; justify-content:space-between;
  padding:16px var(--uiPad); background:linear-gradient(to bottom, rgba(239,231,216,.94), rgba(239,231,216,.66)); border-bottom:1px solid var(--hair);
  text-transform:uppercase; letter-spacing:.12em}
.brand,.burger{font-weight:900;font-size:22px;color:var(--ghostUI)}
.center-dot{opacity:.5;font-weight:900;font-size:16px}
.burger-btn{background:transparent;border:0;padding:4px 6px;cursor:pointer;outline:none;-webkit-appearance:none}
.burger{background:transparent}

.menu{position:fixed;inset:0;display:none;z-index:30;background:linear-gradient(to bottom, rgba(239,231,216,.92), rgba(239,231,216,.66));backdrop-filter:saturate(110%) blur(1px)}
.menu.open{display:block}
.menu-inner{max-width:var(--colMax);margin:0 auto;padding:90px 48px}
.menu ul{list-style:none;margin:0;padding:0}
.menu li{margin:12px 0}
.menu a{font-weight:900;font-size:22px;letter-spacing:.04em;color:#111;text-decoration:none;opacity:.85}
.menu .close{ -webkit-appearance:none; appearance:none; text-decoration:none; color: var(--ink, #141414);position:absolute;top:18px;right:48px;background:none;border:0;cursor:pointer;letter-spacing:.12em;text-transform:uppercase}

.hero{position:relative;margin-top:0}
.hero img{width:100%;height:auto;display:block}
.hero .stance-overlay{position:absolute;left:0;right:0;bottom:2.5vh;text-align:center;z-index:2}
.hero .stance-overlay .line{
  font-family:'Work Sans', Inter, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  font-weight:200; letter-spacing:.06em; text-transform:uppercase;
  color:rgba(255,255,255,.72); font-size:min(4.2vw, 34px);
}

.hero-caption{max-width:1180px;margin:10px auto 0;padding:0 24px;font-weight:900;font-size:14px;letter-spacing:.12em;color:var(--label);text-transform:uppercase}

.figure{max-width:var(--imgWMax);width:var(--imgW);margin:10vh auto;position:relative;padding:0 8px}
.figure .print{background:#fff;padding:12px;border-radius:12px;box-shadow:var(--shadow)}
.figure img{display:block;width:100%;height:auto;border-radius:8px}
.figure .label{position:absolute;left:18px;bottom:-28px;font-weight:900;font-size:14px;letter-spacing:.12em;color:var(--label);text-transform:uppercase}
.figure.heavy{margin-top:14vh}
.figure.light{margin-top:9vh}

/* Watermark fixed on the far right; we animate it with JS so the whole word is revealed over scroll */
\1
  position:absolute; top:0; right:0; transform-origin: top right;
  transform-origin: top right;
  position:fixed; top:0; right:-2vw; z-index:0; pointer-events:none;
  writing-mode:vertical-rl; text-orientation:upright;
  font-weight:900; font-size:120vh; letter-spacing:.06em;
  color:rgba(0,0,0,.14); text-transform:lowercase; margin:0;
  transform:translateY(0); will-change:transform;
}

main, footer { position:relative; z-index:1 }

footer{margin:10vh 0 0;padding:18px 0;border-top:1px solid var(--hair);text-align:center;letter-spacing:.12em;font-size:13px;background:linear-gradient(to top, rgba(239,231,216,.92), rgba(239,231,216,.66));color:rgba(0,0,0,.7)}

@media (max-width:1100px){
  :root{--imgW:84vw;--imgWMax:1000px}
  .brand,.burger{font-size:20px}
  .hero .stance-overlay .line{font-size:min(6.2vw, 32px)}
}

@media (max-width: 640px){
  }


@supports (-webkit-touch-callout: none) {
  }



/* === About page additions === */
.page-hero{padding: calc(var(--uiPad, 48px)) 0 24px;}
.page-title{font-size: clamp(28px, 5vw, 60px); line-height: 1; margin: 0 0 8px; font-weight: 900; letter-spacing: .02em;}
.kicker{opacity:.8; font-weight: 400; letter-spacing:.08em}

.about-body{padding: 24px 0 72px;}
.container{max-width: var(--colMax,1180px); margin: 0 auto; padding: 0 20px;}
.prose{font-size: 1.05rem}
.about-grid{display:grid; grid-template-columns: repeat(12, 1fr); gap: 16px; margin: 28px 0 20px;}
.card{grid-column: span 6; background: rgba(255,255,255,.55); backdrop-filter: blur(2px); border-radius: var(--radius,10px); box-shadow: var(--shadow, 0 10px 18px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.05)); padding: 16px}
.card h3{margin:0 0 8px; font-size: 1.1rem; letter-spacing:.06em}
.card ul{margin: 6px 0 0 18px}

@media (max-width: 900px){
  .card{grid-column: span 12}
}



/* Wrapper to stabilise right-edge anchoring on iOS Safari */
/* About hero image */
.about-hero{
  min-height: 46vh;
  background: url('/images/01_hero.jpg') center / cover no-repeat;
  color: var(--ink, #141414);
  position: relative;
}
.about-hero .container{ padding-top: 14vh; padding-bottom: 10vh; }
.about-hero::after{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(247,242,233,0.2), rgba(247,242,233,0.85) 70%);
  pointer-events: none;
}
