:root {
  --ink: #0b0d0c;
  --paper: #f0efe9;
  --white: #fff;
  --muted: #a5a8a4;
  --acid: #d8ff00;
  --orange: #ff4d00;
  --line: rgba(255,255,255,.17);
  --max: 1240px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "Arial Narrow", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  line-height: 1.7;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.noise {
  position: fixed; inset: 0; z-index: 999; pointer-events: none; opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.95' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.9'/%3E%3C/svg%3E");
}

.site-header {
  position: absolute; inset: 0 0 auto; z-index: 20; height: 96px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 clamp(24px, 5vw, 72px); color: #fff; border-bottom: 1px solid rgba(255,255,255,.18);
  background: rgba(6,8,7,.86); backdrop-filter: blur(5px);
}
.brand { display: flex; align-items: center; gap: 18px; line-height: 1; }
.brand-mark { font: 900 clamp(26px, 3vw, 38px)/1 Impact, sans-serif; letter-spacing: -.04em; }
.brand-mark span { color: var(--acid); }
.brand-sub { color: rgba(255,255,255,.65); font: 700 9px/1.4 Arial, sans-serif; letter-spacing: .2em; }
.desktop-nav { display: flex; gap: 34px; margin-left: auto; margin-right: 42px; }
.desktop-nav a { position: relative; font: 700 11px/1 Arial, sans-serif; letter-spacing: .16em; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -8px; height: 2px; background: var(--acid); transition: right .25s; }
.desktop-nav a:hover::after { right: 0; }
.header-cta { border: 1px solid rgba(255,255,255,.45); padding: 14px 18px; font: 700 11px/1 Arial, sans-serif; letter-spacing: .12em; transition: .25s; }
.header-cta:hover { color: var(--ink); background: var(--acid); border-color: var(--acid); }
.header-cta span { margin-left: 16px; }

.hero { min-height: 780px; height: 100svh; position: relative; color: #fff; background: #080b09; isolation: isolate; }
.hero-photo { position: absolute; inset: 0; z-index: -3; background: url("assets/catch-06.jpg") center 60% / cover no-repeat; filter: saturate(.72) contrast(1.1); transform: scale(1.01); }
.hero-shade { position: absolute; inset: 0; z-index: -2; background: linear-gradient(90deg, rgba(4,7,5,.95) 0%, rgba(4,7,5,.8) 38%, rgba(4,7,5,.15) 72%), linear-gradient(0deg, rgba(4,7,5,.85) 0, transparent 42%); }
.hero-grid { position: absolute; inset: 96px 0 0; z-index: -1; opacity: .16; background-image: linear-gradient(90deg, transparent calc(25% - 1px), #fff 25%, transparent calc(25% + 1px)), linear-gradient(90deg, transparent calc(50% - 1px), #fff 50%, transparent calc(50% + 1px)), linear-gradient(90deg, transparent calc(75% - 1px), #fff 75%, transparent calc(75% + 1px)); }
.hero-content { position: absolute; left: clamp(24px, 7vw, 110px); top: 50%; transform: translateY(-48%); max-width: 820px; }
.eyebrow, .section-index, .record-note, .contact-kicker { margin: 0 0 22px; color: var(--acid); font: 800 11px/1 Arial, sans-serif; letter-spacing: .24em; }
.eyebrow::before { content: ""; display: inline-block; width: 36px; height: 2px; margin: 0 12px 3px 0; background: var(--acid); }
.hero h1 { margin: 0; font-size: clamp(54px, 8vw, 122px); font-weight: 900; line-height: .91; letter-spacing: -.08em; }
.hero h1 span, .hero h1 strong { display: block; }
.hero h1 span { font-size: .57em; letter-spacing: -.06em; margin-bottom: .13em; }
.hero h1 strong { color: transparent; -webkit-text-stroke: 2px #fff; text-shadow: 6px 6px 0 rgba(216,255,0,.18); }
.hero-copy { max-width: 620px; margin: 30px 0 0; padding-left: 18px; border-left: 3px solid var(--acid); font-weight: 700; font-size: clamp(14px, 1.5vw, 18px); letter-spacing: .04em; }
.hero-actions { display: flex; gap: 10px; margin-top: 34px; }
.button { min-width: 180px; padding: 17px 20px; font: 800 12px/1 Arial, sans-serif; letter-spacing: .12em; transition: .25s; }
.button span { float: right; }
.button-primary { color: var(--ink); background: var(--acid); }
.button-primary:hover { background: #fff; transform: translateY(-2px); }
.button-ghost { border: 1px solid rgba(255,255,255,.45); }
.button-ghost:hover { border-color: #fff; background: rgba(255,255,255,.1); }
.hero-badge { position: absolute; right: clamp(24px, 5vw, 80px); bottom: 70px; width: 210px; height: 210px; display: grid; grid-template: auto 1fr auto / 1fr 1fr; align-items: center; padding: 22px; color: var(--ink); background: var(--acid); clip-path: polygon(12% 0,100% 0,100% 88%,88% 100%,0 100%,0 12%); }
.badge-number { font: 900 75px/.75 Impact, sans-serif; letter-spacing: -.05em; }
.badge-text { font: 900 12px/1.1 Arial, sans-serif; text-align: right; }
.badge-years { grid-column: 1 / -1; padding-top: 14px; border-top: 1px solid rgba(0,0,0,.5); font: 800 11px/1 Arial, sans-serif; letter-spacing: .2em; }
.scroll-cue { position: absolute; left: 32px; bottom: 68px; margin: 0; transform: rotate(-90deg); transform-origin: left bottom; color: rgba(255,255,255,.6); font: 700 9px/1 Arial,sans-serif; letter-spacing: .2em; }
.scroll-cue span { display: inline-block; width: 48px; height: 1px; margin: 0 12px 3px 0; background: rgba(255,255,255,.5); }

.stats { max-width: var(--max); margin: -1px auto 0; display: grid; grid-template-columns: .8fr .8fr 1.6fr 1fr; background: #fff; position: relative; z-index: 3; }
.stat { min-height: 145px; display: flex; flex-direction: column; justify-content: center; padding: 28px; border-right: 1px solid #ddd; }
.stat strong { font: 900 clamp(28px, 3vw, 45px)/1 Impact, sans-serif; letter-spacing: -.02em; }
.stat span { margin-top: 10px; color: #777; font: 700 9px/1 Arial, sans-serif; letter-spacing: .18em; }
.stat-accent { color: var(--ink); background: var(--acid); border: 0; }
.stat-accent span { color: var(--ink); }

.section { padding: 140px max(24px, calc((100vw - var(--max)) / 2)); }
.section-head { display: grid; grid-template-columns: 200px 1fr; align-items: start; margin-bottom: 75px; }
.section-head .section-index { color: #777; padding-top: 12px; }
.section-head h2 { margin: 0; font-size: clamp(46px, 6vw, 88px); line-height: .98; letter-spacing: -.07em; }
.section-head h2 em { color: var(--orange); font-style: normal; }
.about-layout { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(40px, 8vw, 120px); align-items: start; margin-left: 200px; }
.profile-card { display: grid; grid-template-columns: 100px 1fr; gap: 20px; align-items: center; position: relative; padding: 24px; background: #fff; box-shadow: 12px 12px 0 #d8d7d1; }
.profile-card img { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; filter: grayscale(1) contrast(1.1); }
.profile-name { margin: 0; font-size: 24px; font-weight: 900; }
.profile-handle { margin: 4px 0 0; color: #777; font: 700 12px/1 Arial, sans-serif; }
.profile-tag { position: absolute; right: -30px; bottom: -12px; padding: 8px 12px; background: var(--ink); color: var(--acid); font: 800 9px/1 Arial,sans-serif; letter-spacing: .15em; transform: rotate(-3deg); }
.about-copy .lead { margin: 0 0 28px; font-size: clamp(22px, 2.3vw, 32px); font-weight: 900; line-height: 1.6; letter-spacing: -.03em; }
.about-copy > p:not(.lead) { max-width: 640px; color: #5d605d; font-size: 15px; }
.tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 30px; }
.tags span { padding: 8px 13px; border: 1px solid #b9bbb7; border-radius: 20px; font-size: 11px; font-weight: 700; }

.record { color: #fff; background: var(--ink); overflow: hidden; }
.record-intro { display: flex; align-items: end; justify-content: space-between; }
.section-head-light { display: block; }
.section-head-light .section-index { color: var(--acid); }
.section-head-light h2 em { color: var(--acid); }
.record-note { margin-bottom: 84px; color: #6f736f; line-height: 1.7; text-align: right; }
.record-feature { display: grid; grid-template-columns: .42fr 1.35fr .5fr; align-items: stretch; min-height: 330px; margin-bottom: 60px; border: 1px solid var(--line); background: linear-gradient(125deg,#141714 0%,#070907 100%); }
.record-year { display: flex; flex-direction: column; align-items: center; justify-content: center; color: #b4b7b2; border-right: 1px solid var(--line); font: 900 34px/.85 Impact,sans-serif; letter-spacing: .06em; }
.record-year span { color: var(--acid); }
.record-title { display: flex; flex-direction: column; justify-content: center; padding: 50px; }
.record-title p { margin: 0 0 18px; color: var(--acid); font: 800 10px/1 Arial,sans-serif; letter-spacing: .2em; }
.record-title h3 { margin: 0; font-size: clamp(38px,5vw,72px); line-height: 1.1; letter-spacing: -.06em; }
.record-title h3 strong { color: var(--acid); }
.trophy { display: flex; flex-direction: column; justify-content: center; align-items: center; color: var(--ink); background: var(--acid); font: 900 55px/.8 Impact,sans-serif; transform: skewX(-5deg) scale(1.02); }
.trophy span { margin-top: 16px; font-size: 25px; }
.record-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--line); }
.record-list li { display: grid; grid-template-columns: 130px 1fr 100px; align-items: center; min-height: 120px; border-bottom: 1px solid var(--line); transition: .25s; }
.record-list li:hover { padding-left: 16px; background: rgba(255,255,255,.04); }
.record-list time { color: var(--acid); font: 900 30px/1 Impact,sans-serif; }
.record-list p { margin: 0; color: #858985; font-size: 13px; line-height: 1.5; }
.record-list p strong { color: #fff; font-size: 21px; }
.record-list li > span { color: #555955; font: 900 28px/1 Impact,sans-serif; text-align: right; }

.style { background: #e5e3dc; }
.style-grid { display: grid; grid-template-columns: 1.2fr .8fr; grid-template-rows: 310px 310px; gap: 16px; margin-left: 200px; }
.style-card { position: relative; overflow: hidden; background: #111; }
.style-card-large { grid-row: 1 / span 2; }
.style-card img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.65) contrast(1.08); transition: transform .6s, filter .6s; }
.style-card:hover img { transform: scale(1.035); filter: saturate(1); }
.style-overlay { position: absolute; inset: auto 0 0; padding: 60px 28px 26px; color: #fff; background: linear-gradient(transparent,rgba(0,0,0,.9)); }
.style-overlay p { margin: 0 0 8px; color: var(--acid); font: 800 9px/1 Arial,sans-serif; letter-spacing: .18em; }
.style-overlay h3 { margin: 0; font-size: clamp(22px,2.4vw,38px); line-height: 1.15; }
.style-overlay span { display: block; margin-top: 10px; color: rgba(255,255,255,.7); font-size: 12px; }

.gallery { display: grid; grid-template-columns: .72fr 1.28fr; min-height: 720px; background: var(--paper); }
.gallery-copy { display: flex; flex-direction: column; justify-content: center; padding: 70px clamp(30px,6vw,100px); }
.gallery-copy .section-index { color: #777; }
.gallery-copy h2 { margin: 0; font: 900 clamp(55px,7vw,100px)/.82 Impact, sans-serif; letter-spacing: -.03em; }
.gallery-copy h2 em { color: var(--orange); font-style: normal; }
.gallery-copy > p:not(.section-index) { margin: 32px 0 18px; color: #666; font-size: 13px; }
.text-link { width: fit-content; padding-bottom: 5px; border-bottom: 2px solid var(--ink); font: 800 11px/1 Arial,sans-serif; letter-spacing: .13em; }
.text-link span { margin-left: 25px; }
.gallery-grid { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 2px; background: #111; }
.gallery-item { position: relative; overflow: hidden; min-height: 300px; }
.gallery-item:first-child { grid-row: 1 / span 2; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.75); transition: .5s; }
.gallery-item:hover img { transform: scale(1.04); filter: saturate(1); }
.gallery-item span { position: absolute; left: 18px; bottom: 18px; padding: 8px 10px; color: var(--ink); background: var(--acid); font: 800 9px/1 Arial,sans-serif; letter-spacing: .12em; }

.contact { position: relative; overflow: hidden; padding: 150px 24px; color: #fff; background: var(--orange); text-align: center; isolation: isolate; }
.contact-kicker { color: var(--ink); }
.contact h2 { margin: 0; font-size: clamp(50px,8vw,118px); line-height: .92; letter-spacing: -.08em; }
.contact h2 em { color: transparent; -webkit-text-stroke: 2px #fff; font-style: normal; }
.contact-copy { margin: 34px 0; font-size: 14px; font-weight: 700; }
.contact-button { width: min(580px, 100%); min-height: 86px; display: flex; align-items: center; justify-content: space-between; margin: 0 auto; padding: 0 30px; color: var(--ink); background: var(--acid); box-shadow: 10px 10px 0 var(--ink); font: 900 13px/1 Arial,sans-serif; letter-spacing: .14em; transition: .25s; }
.contact-button:hover { transform: translate(-3px,-3px); box-shadow: 16px 16px 0 var(--ink); }
.contact-button strong { font-size: 27px; }
.contact-rings { position: absolute; z-index: -1; width: 520px; height: 520px; left: -220px; bottom: -250px; border: 1px solid rgba(0,0,0,.25); border-radius: 50%; box-shadow: 0 0 0 70px rgba(0,0,0,.06), 0 0 0 140px rgba(0,0,0,.04); }

footer { min-height: 200px; display: grid; grid-template-columns: 1fr auto auto; align-items: end; gap: 50px; padding: 70px clamp(24px,5vw,72px) 40px; color: #777; background: var(--ink); font: 700 9px/1.5 Arial,sans-serif; letter-spacing: .12em; }
.footer-brand { color: #fff; font: 900 clamp(38px,5vw,70px)/.8 Impact,sans-serif; letter-spacing: -.03em; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s ease, transform .75s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .desktop-nav { display: none; }
  .hero-badge { width: 165px; height: 165px; right: 18px; bottom: 28px; padding: 17px; }
  .badge-number { font-size: 58px; }
  .stats { grid-template-columns: 1fr 1fr; }
  .stat-wide, .stat-accent { border-top: 1px solid #ddd; }
  .section { padding-top: 100px; padding-bottom: 100px; }
  .section-head { grid-template-columns: 1fr; gap: 22px; }
  .about-layout, .style-grid { margin-left: 0; }
  .about-layout { grid-template-columns: 1fr; }
  .profile-card { max-width: 480px; }
  .record-feature { grid-template-columns: .3fr 1.3fr; }
  .trophy { grid-column: 1 / -1; min-height: 120px; transform: none; flex-direction: row; gap: 15px; }
  .trophy span { margin: 0; }
  .gallery { grid-template-columns: 1fr; }
  .gallery-copy { min-height: 470px; }
  footer { grid-template-columns: 1fr; gap: 16px; align-items: start; }
}

@media (max-width: 620px) {
  .site-header { height: 74px; padding: 0 18px; }
  .brand-sub { display: none; }
  .header-cta { padding: 11px 12px; font-size: 9px; }
  .header-cta span { margin-left: 8px; }
  .hero { min-height: 720px; }
  .hero-grid { top: 74px; }
  .hero-photo { background-size: auto 150%; background-position: 58% 63%; transform: none; }
  .hero-shade { background: linear-gradient(90deg,rgba(4,7,5,.93),rgba(4,7,5,.38)), linear-gradient(0deg,rgba(4,7,5,.95),transparent 55%); }
  .hero-content { left: 20px; right: 20px; top: 47%; }
  .hero h1 { font-size: clamp(52px,17vw,76px); }
  .hero h1 strong { -webkit-text-stroke-width: 1px; }
  .hero-copy { max-width: 92%; font-size: 13px; }
  .hero-actions { flex-direction: column; width: 210px; }
  .button { min-width: 0; }
  .hero-badge { width: 136px; height: 136px; right: 15px; bottom: 22px; padding: 13px; }
  .badge-number { font-size: 45px; }
  .badge-text { font-size: 9px; }
  .badge-years { padding-top: 8px; font-size: 8px; }
  .scroll-cue { display: none; }
  .stat { min-height: 105px; padding: 20px; }
  .stat strong { font-size: 27px; }
  .section { padding-left: 20px; padding-right: 20px; }
  .section-head { margin-bottom: 48px; }
  .section-head h2 { font-size: 49px; }
  .profile-card { grid-template-columns: 78px 1fr; padding: 17px; }
  .profile-card img { width: 78px; height: 78px; }
  .record-intro { display: block; }
  .record-note { display: none; }
  .record-feature { grid-template-columns: 66px 1fr; min-height: 250px; }
  .record-year { font-size: 23px; }
  .record-title { padding: 25px 20px; }
  .record-title h3 { font-size: 38px; }
  .record-list li { grid-template-columns: 74px 1fr; min-height: 100px; }
  .record-list li > span { display: none; }
  .record-list time { font-size: 24px; }
  .record-list p strong { font-size: 17px; }
  .style-grid { display: block; }
  .style-card { height: 420px; margin-bottom: 12px; }
  .style-card:not(.style-card-large) { height: 300px; }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 360px 230px; }
  .gallery-item { min-height: 0; }
  .gallery-item:first-child { grid-column: 1 / -1; grid-row: auto; }
  .contact { padding: 110px 20px; }
  .contact h2 { font-size: 55px; }
  .contact-button { min-height: 74px; padding: 0 18px; font-size: 10px; box-shadow: 7px 7px 0 var(--ink); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}
