:root { --paper: #f3efe6; --ink: #24231f; --muted: #736f66; --rust: #9a5438; --line: rgba(36, 35, 31, 0.22); }
html { scroll-behavior: smooth; }
body { background: var(--paper); color: var(--ink); font-family: "DM Sans", sans-serif; line-height: 1.6; }
.wrap { width: min(1180px, calc(100% - 2.5rem)); margin-inline: auto; }
h1, h2, p { margin-top: 0; }
figure { margin: 0; }
h1, h2 { font-family: "Newsreader", serif; font-weight: 400; line-height: 0.98; }
h1 { max-width: 15ch; font-size: clamp(3rem, 5.6vw, 5.7rem); letter-spacing: 0; margin-bottom: 2rem; }
h2 { font-size: clamp(2.4rem, 5vw, 5.4rem); letter-spacing: 0; }
.eyebrow, .section-no { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.16em; color: var(--rust); }
.lede { max-width: 45rem; font-family: "Newsreader", serif; font-size: clamp(1.25rem, 2vw, 1.65rem); line-height: 1.45; }
.hero { position: relative; min-height: 94vh; padding: clamp(3.5rem, 8vw, 8rem) 0; overflow: hidden; }
.hero::before {
  content: "STUDIO JOURNAL / ISSUE 01";
  position: absolute;
  right: 1.2rem;
  top: 50%;
  writing-mode: vertical-rl;
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  color: var(--muted);
}
.hero-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; align-items: center; gap: clamp(2rem, 5vw, 5rem); }
.hero-copy { position: relative; z-index: 2; }
.hero-copy h1 { margin-right: clamp(-3rem, -4vw, -1rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 2rem; }
.btn { display: inline-flex; justify-content: center; align-items: center; min-height: 3.25rem; padding: 0.8rem 1.15rem; border: 1px solid var(--ink); color: var(--ink); text-decoration: none; font-weight: 600; background: transparent; }
.btn-dark { background: var(--ink); color: var(--paper); }
.btn:hover { background: var(--rust); border-color: var(--rust); color: #fff; }
.hero-media {
  position: relative;
  min-height: min(72vh, 48rem);
  display: grid;
  align-items: center;
}
.hero-portrait {
  width: min(78%, 34rem);
  justify-self: end;
  position: relative;
  z-index: 1;
}
.hero-portrait img {
  width: 100%;
  height: clamp(29rem, 64vh, 42rem);
  aspect-ratio: 4 / 5;
  object-fit: cover;
  object-position: center 35%;
  background: #e7e0d3;
}
.hero-work {
  position: absolute;
  z-index: 2;
  width: min(38%, 16rem);
  left: 0;
  bottom: 3%;
  transform: rotate(-2.5deg);
  background: var(--paper);
  padding: 0.55rem;
  box-shadow: 0 1rem 2.4rem rgba(36, 35, 31, 0.18);
}
.hero-work img, .work img, .gallery img { width: 100%; height: 100%; object-fit: cover; background: #e7e0d3; }
figcaption { display: flex; justify-content: space-between; gap: 1rem; padding-top: 0.65rem; font-size: 0.76rem; color: var(--muted); }
figcaption i { color: var(--ink); font-family: "Newsreader", serif; font-size: 1rem; }
.about, .works, .available, .notes, .gallery, .commission { border-top: 1px solid var(--line); padding: clamp(4rem, 9vw, 8rem) 0; }
.about-grid, .notes-grid { display: grid; grid-template-columns: 0.42fr 1.4fr; gap: clamp(2rem, 7vw, 8rem); }
.about-grid h2 { max-width: 13ch; }
.about-grid div > p { max-width: 48rem; font-size: 1.05rem; }
.section-head { display: flex; justify-content: space-between; align-items: end; gap: 2rem; margin-bottom: 3rem; }
.section-head h2 { margin-bottom: 0; }
.section-head > p { max-width: 24rem; color: var(--muted); }
.work-grid { display: grid; grid-template-columns: 1.45fr 0.55fr; gap: 1rem 2rem; }
.work { margin-bottom: 2.5rem; }
.work-wide { grid-row: span 2; }
.work-wide img { aspect-ratio: 4 / 3; }
.work:not(.work-wide) img { aspect-ratio: 1 / 1; }
.available { background: #282722; color: var(--paper); }
.available .section-no { color: #d79a78; }
.available-grid { display: grid; grid-template-columns: 0.5fr 1.25fr; gap: 1.5rem 5rem; }
.available-grid h2 { max-width: 10ch; }
.available-grid p { max-width: 38rem; color: #c9c2b5; }
.price-list { list-style: none; padding: 0; margin: 0; }
.price-list li { display: flex; justify-content: space-between; gap: 2rem; padding: 1rem 0; border-top: 1px solid rgba(243, 239, 230, 0.22); }
.price-list b { font-weight: 500; }
.text-link { color: inherit; text-underline-offset: 5px; }
.available .text-link { grid-column: 2; }
.notes-list { list-style: none; padding: 0; margin: 0; }
.notes-list li { display: grid; grid-template-columns: 5rem 1fr; gap: 1rem; padding: 1.25rem 0; border-top: 1px solid var(--line); }
.notes-list b { font-family: "Newsreader", serif; font-size: 1.25rem; font-weight: 500; }
.gallery { background: #e9e1d4; }
.gallery-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.15fr 0.85fr;
  gap: 1rem;
  align-items: end;
}
.gallery-grid figure:nth-child(1) { grid-row: span 2; }
.gallery-grid figure:nth-child(2) { transform: translateY(2.2rem); }
.gallery-grid figure:nth-child(4) { grid-column: 2 / -1; }
.gallery-grid figure:nth-child(1) img { aspect-ratio: 3 / 4; }
.gallery-grid figure:nth-child(2) img,
.gallery-grid figure:nth-child(3) img { aspect-ratio: 1 / 1; }
.gallery-grid figure:nth-child(4) img { aspect-ratio: 16 / 9; object-position: center 42%; }
.commission-grid { display: grid; grid-template-columns: 0.75fr 1.25fr; gap: clamp(3rem, 8vw, 8rem); }
.commission-copy h2 { max-width: 10ch; }
.commission-copy > p:not(.section-no) { max-width: 32rem; color: var(--muted); }
.commission-form { background: #e8e1d5; padding: clamp(1.3rem, 4vw, 2.5rem); }
.f-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
label { display: grid; gap: 0.4rem; margin-bottom: 1rem; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; }
input, select, textarea { width: 100%; border: 0; border-bottom: 1px solid var(--ink); border-radius: 0; background: transparent; color: var(--ink); padding: 0.8rem 0.2rem; font-size: 1rem; text-transform: none; letter-spacing: 0; }
textarea { resize: vertical; }
.form-note { margin: 0.8rem 0 0; color: var(--muted); font-size: 0.8rem; }
.biz-foot { background: var(--paper); border-top: 1px solid var(--line); padding: 2.5rem 0; }
.biz-foot .wrap { display: flex; justify-content: space-between; gap: 2rem; }
.biz-foot p { margin: 0; color: var(--muted); }
.biz-foot .biz-name { color: var(--ink); font-family: "Newsreader", serif; font-size: 1.25rem; }
@media (max-width: 800px) {
  .hero { min-height: auto; padding-top: 4rem; }
  .hero-grid, .about-grid, .notes-grid, .commission-grid, .available-grid { grid-template-columns: 1fr; }
  .hero-copy h1 { margin-right: 0; }
  .hero-media { min-height: auto; gap: 1rem; }
  .hero-portrait { width: min(100%, 30rem); justify-self: stretch; }
  .hero-portrait img { height: auto; max-height: 72vh; }
  .hero-work { position: relative; width: min(70%, 18rem); left: auto; bottom: auto; transform: rotate(-1deg); }
  .hero-work img { max-height: 70vh; object-fit: cover; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .work-wide { grid-column: 1 / -1; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid figure:nth-child(1),
  .gallery-grid figure:nth-child(4) { grid-column: auto; grid-row: auto; }
  .gallery-grid figure:nth-child(2) { transform: none; }
  .available .text-link { grid-column: 1; }
}
@media (max-width: 560px) {
  .wrap { width: min(100% - 1.4rem, 1180px); }
  h1 { font-size: clamp(2.4rem, 11vw, 3.4rem); }
  .lede { font-size: 1.08rem; line-height: 1.36; }
  .section-head { align-items: start; flex-direction: column; }
  .work-grid, .gallery-grid, .f-row { grid-template-columns: 1fr; }
  .work-wide { grid-column: auto; }
  .hero-work { width: 82%; }
  .hero-actions .btn { width: 100%; }
  figcaption, .biz-foot .wrap { flex-direction: column; }
  .biz-foot .wrap { gap: 0.35rem; }
}
