:root {
  --bg: #000;
  --text: #f6f6f3;
  --muted: rgba(246,246,243,.70);
  --soft: rgba(255,255,255,.11);
  --panel: rgba(7,7,7,.74);
  --accent: #f3c089;
  --max: 1180px;
}
* { box-sizing: border-box; }
html { background:#000; scroll-behavior:smooth; }
html, body { margin:0; min-height:100%; }
body {
  min-height:100vh;
  color:var(--text);
  background:#000;
  font-family:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  scrollbar-color:#2a2a2a #070707;
  scrollbar-width:thin;
}
body::-webkit-scrollbar { width:12px; height:12px; }
body::-webkit-scrollbar-track { background:#070707; }
body::-webkit-scrollbar-thumb { background:#282828; border:2px solid #070707; border-radius:999px; }
body::-webkit-scrollbar-thumb:hover { background:#3a3a3a; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
body::before {
  content:"";
  position:fixed;
  inset:-4%;
  z-index:-4;
  background:#000 url("assets/smoke-bg.webp") center/cover no-repeat;
  opacity:.90;
  transform:scale(1.08);
}
body::after {
  content:"";
  position:fixed;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background:
    radial-gradient(ellipse at center, transparent 0 30%, rgba(0,0,0,.34) 66%, rgba(0,0,0,.94) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.36), transparent 22%, transparent 78%, rgba(0,0,0,.96));
}
.topbar {
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  width:min(100% - 40px, 1380px);
  margin:0 auto;
  padding:30px 0 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.logo,.main-menu a,.social-menu a,.kicker,.scroll-mark b,.page-action,.gallery-caption {
  font-family:"Montserrat", "Inter", sans-serif;
  font-weight:600;
  letter-spacing:.34em;
}
.logo { font-size:16px; letter-spacing:.42em; margin-right:-.42em; white-space:nowrap; text-shadow:0 0 18px #000; }
.nav-panel { display:flex; align-items:center; gap:30px; margin-left:auto; }
.main-menu { display:flex; align-items:center; gap:clamp(18px,2.4vw,42px); white-space:nowrap; }
.main-menu a,.social-menu a { font-size:12px; color:rgba(255,255,255,.96); text-shadow:0 0 18px #000; transition:opacity .18s ease, transform .18s ease, color .18s ease; }
.main-menu a:hover,.main-menu a.active,.social-menu a:hover,.logo:hover { transform:translateY(-1px); }
.main-menu a.active { color:var(--accent); }
.social-menu { display:flex; align-items:center; gap:18px; }
.social-menu a { display:inline-flex; align-items:center; justify-content:center; width:18px; height:18px; letter-spacing:0; font-size:18px; }
.menu-toggle {
  display:none;
  align-items:center;
  justify-content:center;
  width:46px; height:46px;
  border:1px solid var(--soft);
  border-radius:999px;
  background:rgba(0,0,0,.72);
  color:var(--text);
  cursor:pointer;
  backdrop-filter:blur(12px);
}
.menu-toggle .icon-close { display:none; }
.menu-toggle[aria-expanded="true"] .icon-open { display:none; }
.menu-toggle[aria-expanded="true"] .icon-close { display:inline-block; }
.stage { min-height:100svh; position:relative; display:grid; place-items:center; overflow:hidden; }
.hero { min-height:100svh; width:100%; display:grid; place-items:center; }
.portrait {
  position:relative;
  z-index:2;
  width:min(72vw, 880px, 86vh);
  transform-origin:center center;
  animation:slowPortraitZoom 16s ease-in-out infinite;
}
.portrait img {
  width:100%;
  height:auto;
  background:transparent;
  filter:drop-shadow(0 24px 60px rgba(0,0,0,.22));
}
.scroll-mark { position:absolute; left:50%; bottom:28px; z-index:3; display:grid; justify-items:center; gap:14px; transform:translateX(-50%); opacity:.92; }
.scroll-mark span { width:1px; height:42px; background:linear-gradient(to bottom, transparent, rgba(255,255,255,.96), transparent); }
.scroll-mark b { font-size:11px; margin-right:-.34em; }
@keyframes slowPortraitZoom { 0%,100% { transform:scale(1) translateY(0); } 50% { transform:scale(1.045) translateY(-.35%); } }
.page-main { min-height:100svh; padding:124px 0 80px; }
.page-shell { width:min(var(--max), calc(100% - 28px)); margin:0 auto; }
.page-content {
  position:relative;
  overflow:hidden;
  padding:clamp(24px,4vw,46px);
  border:1px solid var(--soft);
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  backdrop-filter:blur(14px);
  box-shadow:0 30px 90px rgba(0,0,0,.42);
}
.page-content::before { content:""; position:absolute; inset:0; background:url("assets/smoke-bg.webp") center/cover no-repeat; opacity:.07; mix-blend-mode:screen; pointer-events:none; }
.page-content > * { position:relative; z-index:1; }
.kicker { margin:0 0 12px; font-size:11px; color:rgba(255,255,255,.84); }
h1,h2,h3 { font-family:"Montserrat", "Inter", sans-serif; letter-spacing:-.04em; margin:0 0 12px; }
h1 { font-size:clamp(2.2rem,6vw,4.4rem); line-height:.95; }
h2 { font-size:clamp(1.4rem,4vw,2.2rem); }
p,li { color:var(--muted); line-height:1.75; }
.intro { max-width:840px; }
.page-action { display:inline-flex; margin-top:24px; min-height:48px; align-items:center; justify-content:center; padding:0 18px; border:1px solid var(--soft); border-radius:999px; background:rgba(255,255,255,.06); font-size:12px; text-transform:uppercase; }
.list-grid { display:grid; gap:18px; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); margin-top:24px; }
.info-block { padding:22px; border:1px solid var(--soft); border-radius:22px; background:rgba(0,0,0,.38); }
.info-block h3 { font-size:1.05rem; }
.gallery-toolbar { display:flex; flex-wrap:wrap; gap:12px; margin:24px 0 18px; }
.gallery-toolbar span { padding:12px 14px; border:1px solid var(--soft); border-radius:999px; background:rgba(0,0,0,.34); color:var(--muted); font-size:.92rem; }
.image-gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:16px; margin-top:14px; }
.gallery-item { position:relative; overflow:hidden; border:1px solid var(--soft); border-radius:24px; background:rgba(0,0,0,.38); aspect-ratio:4/5; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.gallery-item:hover img { transform:scale(1.04); }
.gallery-caption { position:absolute; left:0; right:0; bottom:0; padding:16px; background:linear-gradient(180deg, transparent, rgba(0,0,0,.88)); color:#fff; font-size:.95rem; letter-spacing:.08em; }
.gallery-loading { color:var(--muted); }
code { color:#f3d9b6; }
@media (max-width:920px) {
  .topbar { width:calc(100% - 28px); padding-top:18px; }
  .menu-toggle { display:inline-flex; }
  .nav-panel { position:absolute; top:calc(100% + 10px); right:0; width:min(330px, calc(100vw - 28px)); display:grid; gap:16px; padding:20px; border:1px solid var(--soft); border-radius:24px; background:rgba(8,8,8,.95); backdrop-filter:blur(18px); opacity:0; visibility:hidden; transform:translateY(-6px); transition:opacity .2s ease, transform .2s ease, visibility .2s ease; }
  .nav-panel.open { opacity:1; visibility:visible; transform:translateY(0); }
  .main-menu { display:grid; gap:12px; }
  .social-menu { justify-content:flex-start; }
  .portrait { width:min(112vw, 760px); }
}
@media (max-width:560px) {
  .topbar { width:calc(100% - 32px); padding-top:16px; }
  .logo { font-size:14px; }
  .portrait { width:min(118vw, 670px); }
  .page-main { padding-top:96px; }
  .image-gallery { grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce) { *,*::before,*::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; } }


/* final smoke and mobile centering patch */
body::before {
  inset: -7% !important;
  opacity: .92 !important;
  transform: scale(1.10) !important;
  animation: none !important;
  background: #000 url("assets/smoke-bg.webp") center center / cover no-repeat !important;
}
body::after {
  background:
    radial-gradient(ellipse at center, transparent 0 26%, rgba(0,0,0,.24) 58%, rgba(0,0,0,.82) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.22), transparent 22%, transparent 76%, rgba(0,0,0,.94)) !important;
}
.hero {
  position: relative;
  overflow: hidden;
}
.hero::before,
.hero::after {
  content: "";
  position: absolute;
  inset: -18%;
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: screen;
  filter: blur(30px);
}
.hero::before {
  opacity: .28;
  background:
    radial-gradient(ellipse at 18% 42%, rgba(255,255,255,.28), transparent 20%),
    radial-gradient(ellipse at 42% 28%, rgba(255,255,255,.14), transparent 24%),
    radial-gradient(ellipse at 68% 56%, rgba(255,255,255,.18), transparent 26%),
    radial-gradient(ellipse at 86% 36%, rgba(255,255,255,.15), transparent 20%);
}
.hero::after {
  opacity: .22;
  background: url("assets/smoke-bg.webp") center / cover no-repeat;
  transform: scaleX(-1) scale(1.08);
}
.portrait {
  --portrait-x: 0vw;
  z-index: 2 !important;
  width: min(72vw, 880px, 86vh) !important;
  margin-left: 0 !important;
  animation: slowPortraitZoom 16s ease-in-out infinite !important;
}
.portrait::before,
.portrait::after {
  content: "" !important;
  display: block !important;
  position: absolute;
  pointer-events: none;
  border-radius: 50%;
  z-index: 1;
  mix-blend-mode: screen;
}
.portrait::before {
  inset: 4% -16% 12% -16%;
  background:
    radial-gradient(ellipse at 48% 34%, rgba(255,255,255,.16), transparent 32%),
    radial-gradient(ellipse at 42% 58%, rgba(255,255,255,.20), transparent 34%),
    radial-gradient(ellipse at 64% 47%, rgba(255,255,255,.11), transparent 28%);
  filter: blur(26px);
  opacity: .44;
}
.portrait::after {
  inset: -3% -10% 22% -10%;
  background:
    radial-gradient(ellipse at 38% 38%, rgba(255,255,255,.12), transparent 26%),
    radial-gradient(ellipse at 53% 50%, rgba(255,255,255,.10), transparent 30%);
  filter: blur(18px);
  opacity: .32;
}
.portrait img {
  position: relative;
  z-index: 2;
  background: transparent !important;
  filter: drop-shadow(0 24px 60px rgba(0,0,0,.20));
}
@keyframes slowPortraitZoom {
  0%, 100% { transform: translateX(var(--portrait-x)) scale(1) translateY(0); }
  50% { transform: translateX(var(--portrait-x)) scale(1.045) translateY(-.35%); }
}
@media (max-width: 920px) {
  .portrait {
    --portrait-x: -4vw;
    width: min(112vw, 760px) !important;
  }
}
@media (max-width: 560px) {
  .topbar {
    width: calc(100% - 32px) !important;
    padding-left: 4px;
    padding-right: 4px;
  }
  .portrait {
    --portrait-x: -7.5vw;
    width: min(118vw, 670px) !important;
  }
}
@media (max-width: 390px) {
  .portrait {
    --portrait-x: -8.5vw;
  }
}


/* responsive portfolio lightbox */
.gallery-trigger {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  color: inherit;
  background: transparent;
  cursor: pointer;
  font: inherit;
  text-align: left;
}
.gallery-trigger img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease, filter .35s ease;
}
.gallery-trigger::after {
  content: "VIEW";
  position: absolute;
  right: 12px;
  top: 12px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  background: rgba(0,0,0,.58);
  color: rgba(255,255,255,.86);
  font-family: "Montserrat", "Inter", sans-serif;
  font-size: .66rem;
  letter-spacing: .18em;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity .2s ease, transform .2s ease;
  backdrop-filter: blur(8px);
}
.gallery-trigger:hover img,
.gallery-trigger:focus-visible img {
  transform: scale(1.04);
  filter: brightness(1.08);
}
.gallery-trigger:hover::after,
.gallery-trigger:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}
.gallery-trigger:focus-visible {
  outline: 2px solid rgba(255,255,255,.78);
  outline-offset: -6px;
  border-radius: 24px;
}
.gallery-lightbox-open {
  overflow: hidden;
}
.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: grid;
  place-items: center;
  padding: clamp(14px, 4vw, 38px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .22s ease, visibility .22s ease;
}
.gallery-lightbox.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.gallery-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at center, rgba(255,255,255,.08), transparent 42%),
    rgba(0,0,0,.86);
  backdrop-filter: blur(12px);
}
.gallery-lightbox__box {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  max-height: min(86svh, 860px);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-rows: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: clamp(14px, 2.5vw, 22px);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: clamp(18px, 3vw, 30px);
  background: linear-gradient(180deg, rgba(18,18,18,.94), rgba(2,2,2,.92));
  box-shadow: 0 34px 120px rgba(0,0,0,.74);
}
.gallery-lightbox__image-wrap {
  grid-column: 2;
  grid-row: 1;
  position: relative;
  display: grid;
  place-items: center;
  min-height: 180px;
}
.gallery-lightbox__image-wrap.is-loading::before {
  content: "Loading full image…";
  position: absolute;
  color: rgba(255,255,255,.68);
  font-family: "Montserrat", "Inter", sans-serif;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.gallery-lightbox__image {
  justify-self: center;
  align-self: center;
  width: auto;
  max-width: 100%;
  max-height: calc(86svh - 118px);
  object-fit: contain;
  border-radius: clamp(14px, 2vw, 22px);
  box-shadow: 0 18px 60px rgba(0,0,0,.48);
}
.gallery-lightbox__caption {
  grid-column: 1 / -1;
  grid-row: 2;
  color: rgba(255,255,255,.82);
  font-family: "Montserrat", "Inter", sans-serif;
  font-size: .92rem;
  letter-spacing: .08em;
  text-align: center;
}
.gallery-lightbox__close,
.gallery-lightbox__nav {
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.55);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(8px);
  transition: background .18s ease, transform .18s ease;
}
.gallery-lightbox__close:hover,
.gallery-lightbox__nav:hover,
.gallery-lightbox__close:focus-visible,
.gallery-lightbox__nav:focus-visible {
  background: rgba(255,255,255,.14);
  transform: translateY(-1px);
}
.gallery-lightbox__close {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  width: 42px;
  height: 42px;
  border-radius: 999px;
}
.gallery-lightbox__nav {
  grid-row: 1;
  width: 46px;
  height: 72px;
  border-radius: 999px;
}
.gallery-lightbox__nav--prev { grid-column: 1; }
.gallery-lightbox__nav--next { grid-column: 3; }

@media (max-width: 680px) {
  .gallery-lightbox {
    padding: 10px;
    align-items: end;
  }
  .gallery-lightbox__box {
    width: 100%;
    max-height: 88svh;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: minmax(0, 1fr) auto auto;
    gap: 10px;
    padding: 12px;
    border-radius: 24px 24px 18px 18px;
  }
  .gallery-lightbox__image-wrap {
    grid-column: 1 / -1;
    grid-row: 1;
  }
  .gallery-lightbox__image {
    max-height: calc(88svh - 136px);
    width: 100%;
  }
  .gallery-lightbox__caption {
    grid-column: 1 / -1;
    grid-row: 2;
    padding: 0 44px;
    font-size: .84rem;
  }
  .gallery-lightbox__nav {
    grid-row: 3;
    width: 100%;
    height: 46px;
    border-radius: 999px;
  }
  .gallery-lightbox__nav--prev { grid-column: 1; }
  .gallery-lightbox__nav--next { grid-column: 2; }
  .gallery-lightbox__close {
    top: 10px;
    right: 10px;
  }
}


/* contact form */
.contact-shell {
  
}
.contact-form {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 18px;
  margin-top: 26px;
}
.contact-form__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.contact-form label {
  display: grid;
  gap: 8px;
}
.contact-form label span {
  font-family: "Montserrat", "Inter", sans-serif;
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
}
.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  background: rgba(0,0,0,.42);
  color: #fff;
  padding: 14px 16px;
  font: inherit;
  outline: none;
  transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.contact-form textarea {
  resize: vertical;
  min-height: 180px;
}
.contact-form input:focus,
.contact-form textarea:focus {
  border-color: rgba(255,255,255,.42);
  background: rgba(0,0,0,.58);
  box-shadow: 0 0 0 4px rgba(255,255,255,.06);
}
.contact-form__honey {
  position: absolute !important;
  left: -9999px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.contact-form__notice {
  margin: 0;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  font-size: .88rem;
  color: rgba(255,255,255,.62);
}
.contact-form__submit {
  width: fit-content;
  cursor: pointer;
  color: #f6f6f3;
}
.contact-form__status {
  min-height: 1.4em;
  margin: 0;
  color: rgba(255,255,255,.72);
}
.contact-form__status.is-success { color: #9df0b6; }
.contact-form__status.is-warning { color: #ffd08a; }
.contact-form__status.is-working { color: rgba(255,255,255,.88); }

@media (max-width: 680px) {
  .contact-form__row {
    grid-template-columns: 1fr;
  }
  .contact-form__submit {
    width: 100%;
  }
}


/* global dark scrollbars */
html {
  scrollbar-color: #2a2a2a #050505;
  scrollbar-width: thin;
}
body,
.page-main,
.gallery-lightbox__box,
.gallery-lightbox__image-wrap,
.contact-form textarea {
  scrollbar-color: #2a2a2a #050505;
  scrollbar-width: thin;
}
*::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}
*::-webkit-scrollbar-track {
  background: #050505;
}
*::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #343434, #171717);
  border: 2px solid #050505;
  border-radius: 999px;
}
*::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #4a4a4a, #252525);
}
*::-webkit-scrollbar-corner {
  background: #050505;
}


/* about page profile */
.about-page-content {
  overflow: visible;
}
.about-profile {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(190px, 300px) minmax(0, 1fr);
  align-items: center;
  gap: clamp(22px, 4vw, 48px);
}
.about-portrait {
  position: relative;
  margin: 0;
  min-height: 340px;
  display: grid;
  place-items: center;
  overflow: visible;
  padding: 18px 0;
}
.about-portrait::before {
  content: "";
  position: absolute;
  inset: 2% -14% 0;
  background:
    radial-gradient(ellipse at center, rgba(255,255,255,.13), transparent 58%),
    url("../assets/smoke-bg.webp") center / cover no-repeat;
  opacity: .28;
  filter: blur(20px);
  mix-blend-mode: screen;
  pointer-events: none;
}
.about-portrait img {
  position: relative;
  width: min(100%, 300px);
  height: auto;
  filter: drop-shadow(0 22px 52px rgba(0,0,0,.52));
}
.about-copy .intro {
  max-width: 760px;
  font-size: clamp(1rem, 1.65vw, 1.2rem);
}
.about-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 22px 0 24px;
}
.about-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 13px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(0,0,0,.34);
  color: rgba(255,255,255,.76);
  font-family: "Montserrat", "Inter", sans-serif;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.about-mini-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 860px) {
  .about-profile {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .about-portrait {
    min-height: 285px;
    order: -1;
    padding: 12px 0 4px;
  }
  .about-portrait img {
    width: min(68vw, 270px);
  }
  .about-mini-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 480px) {
  .about-portrait {
    min-height: 255px;
  }
  .about-portrait img {
    width: min(66vw, 255px);
  }
}
