/* ---------- functions ---------- */
/* ---------- mixins ---------- */
/* ---------- tokens ---------- */
:root {
  --rose: #be7882;
  --rose-deep: #8c4e58;
  --rose-soft: #d8a6ad;
  --paper: #f6f0ec;
  --paper-warm: #efe6df;
  --ink: #1c1518;
  --ink-soft: #5a4d50;
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--paper);
  color: var(--ink);
  font-family: "Jost", sans-serif;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

.serif {
  font-family: "Playfair Display", serif;
}

.mincho {
  font-family: "Shippori Mincho", serif;
}

.wrap {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 28px;
}

a {
  color: inherit;
}

.eyebrow {
  font-family: "Jost", sans-serif;
  font-weight: 400;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  font-size: 0.64rem;
  color: var(--rose-deep);
  padding-left: 0.4em;
}

section {
  padding: 92px 0;
}

.sec-head {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 18px;
  margin-bottom: 44px;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
.sec-head h2 {
  font-family: "Playfair Display", serif;
  font-weight: 600;
  font-size: 1.7rem;
  letter-spacing: 0.01em;
}

.rise {
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: opacity 0.8s ease, -webkit-transform 0.8s ease;
  transition: opacity 0.8s ease, -webkit-transform 0.8s ease;
  transition: opacity 0.8s ease, transform 0.8s ease;
  transition: opacity 0.8s ease, transform 0.8s ease, -webkit-transform 0.8s ease;
}
.rise.in {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

:focus-visible {
  outline: 2px solid var(--rose-deep);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .rise {
    opacity: 1;
    -webkit-transform: none;
            transform: none;
    -webkit-transition: none;
    transition: none;
  }
}
@media screen and (max-width: 680px) {
  .skill-grid {
    grid-template-columns: 1fr;
  }
  .work-grid {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 560px) {
  .flow-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 6px;
  }
  .flow-row .k {
    min-width: 0;
  }
}
/* HERO */
.hero {
  background: var(--rose);
  color: var(--ink);
  min-height: 88vh;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  overflow: hidden;
  padding: 80px 28px;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: -webkit-linear-gradient(335deg, rgba(255, 255, 255, 0.1), transparent 42%), -webkit-radial-gradient(50% 115%, 120% 80%, rgba(0, 0, 0, 0.15), transparent 60%);
  background: linear-gradient(115deg, rgba(255, 255, 255, 0.1), transparent 42%), radial-gradient(120% 80% at 50% 115%, rgba(0, 0, 0, 0.15), transparent 60%);
  mix-blend-mode: soft-light;
  pointer-events: none;
}
.hero .mark {
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(3.4rem, 12vw, 6.5rem);
  line-height: 0.92;
}
.hero .lead {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: clamp(1.15rem, 3.4vw, 1.7rem);
  line-height: 1.9;
  margin-top: 28px;
  letter-spacing: 0.04em;
}
.hero .sub {
  margin-top: 22px;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  max-width: 34em;
  color: var(--ink);
  opacity: 0.82;
}
.hero .loc {
  margin-top: 34px;
  letter-spacing: 0.34em;
  font-size: 0.62rem;
  text-transform: uppercase;
  padding-left: 0.34em;
}

.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 980px;
  margin: 0 auto;
  width: 100%;
  padding: 0 28px;
}

/* INTRO */
.intro {
  background: var(--paper);
}
.intro .wrap {
  max-width: 760px;
}
.intro p {
  font-family: "Shippori Mincho", serif;
  font-size: clamp(1.2rem, 3.2vw, 1.6rem);
  line-height: 2.1;
  letter-spacing: 0.03em;
}
.intro p em {
  font-style: normal;
  color: var(--rose-deep);
  border-bottom: 1px solid var(--rose-soft);
  padding-bottom: 0.05em;
}

.intro .note {
  margin-top: 36px;
  font-size: clamp(0.88rem, 2vw, 1rem);
  color: var(--ink-soft);
  line-height: 2;
}

/* SKILLS */
.skills {
  background: var(--paper-warm);
}

.skill-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border: 1px solid rgba(28, 21, 24, 0.12);
}

.skill {
  padding: 30px 28px;
  border: 1px solid rgba(28, 21, 24, 0.12);
  margin: -1px 0 0 -1px;
}
.skill h3 {
  font-family: "Playfair Display", serif;
  font-weight: 600;
  font-size: 1.18rem;
  margin-bottom: 10px;
}
.skill p {
  font-size: 0.92rem;
  color: var(--ink-soft);
  letter-spacing: 0.02em;
}

/* FLOW */
.flow {
  background: var(--paper);
}

.flow-list {
  display: grid;
  gap: 0;
}

.flow-row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 26px;
  padding: 26px 4px;
  border-top: 1px solid rgba(28, 21, 24, 0.13);
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.flow-row:last-child {
  border-bottom: 1px solid rgba(28, 21, 24, 0.13);
}
.flow-row .k {
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--rose-deep);
  min-width: 140px;
}
.flow-row .v {
  font-size: 0.95rem;
  color: var(--ink-soft);
  letter-spacing: 0.02em;
}
.flow-row .v b {
  color: var(--ink);
  font-weight: 500;
}

/* WORKS */
.works {
  background: var(--paper-warm);
}

.works-note {
  margin-bottom: 34px;
  font-size: 0.92rem;
  color: var(--ink-soft);
  letter-spacing: 0.02em;
  max-width: 40em;
}

.work-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.work {
  border: 1px solid rgba(28, 21, 24, 0.14);
  padding: 24px 24px 22px;
  background: var(--paper);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 14px;
  min-height: 150px;
}
.work .cat {
  font-family: "Shippori Mincho", serif;
  font-size: 1.12rem;
  letter-spacing: 0.04em;
}
.work .tags {
  margin-top: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 7px;
}
.work .tag {
  font-size: 0.64rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid var(--rose-soft);
  color: var(--rose-deep);
  padding: 4px 9px;
  border-radius: 2px;
}

/* CONTACT */
.contact {
  background: var(--ink);
  color: var(--paper);
}
.contact .wrap {
  max-width: 720px;
  text-align: center;
}
.contact .mark {
  font-family: "Playfair Display", serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(2.6rem, 9vw, 4.2rem);
  line-height: 1;
}
.contact p {
  margin-top: 24px;
  font-size: 1rem;
  line-height: 1.9;
  letter-spacing: 0.03em;
  opacity: 0.88;
}
.contact .cta {
  display: inline-block;
  margin-top: 34px;
  border: 1px solid var(--rose-soft);
  color: var(--paper);
  padding: 15px 40px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.72rem;
  text-decoration: none;
  -webkit-transition: background 0.25s, color 0.25s;
  transition: background 0.25s, color 0.25s;
}
.contact .cta:hover, .contact .cta:focus-visible {
  background: var(--rose);
  color: var(--ink);
  border-color: var(--rose);
}
.contact .mail {
  margin-top: 22px;
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  opacity: 0.7;
}

/* FOOTER */
footer {
  background: var(--ink);
  color: var(--paper);
  padding: 30px 28px;
  border-top: 1px solid rgba(246, 240, 236, 0.14);
}
footer .wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 18px;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  opacity: 0.62;
}