:root {
  --page: #f6f1eb;
  --paper: #fbf7f1;
  --ink: #1b1713;
  --muted: #75675a;
  --line: rgba(91, 65, 43, 0.18);
  --gold: #9a6d3c;
  --brown: #4a351c;
  --red: #a8443a;
  --shadow: 0 22px 60px rgba(64, 41, 24, 0.14);
  --serif: "Songti SC", "STSong", "Noto Serif SC", "SimSun", serif;
  --sans: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--ink);
  background: var(--page);
  font-family: var(--sans);
  letter-spacing: 0;
}

button,
input,
select,
textarea {
  font: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

.site-shell {
  width: 100%;
  min-width: 0;
  margin: 0;
  overflow: hidden;
  background: var(--page);
}

.hero {
  position: relative;
  height: clamp(760px, 49vw, 940px);
  min-height: 640px;
  overflow: hidden;
  background: #f7f1ea;
}

.hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.hero-left {
  display: none;
}

.nav {
  position: absolute;
  z-index: 4;
  top: clamp(24px, 3.2vw, 52px);
  left: clamp(46px, 4.8vw, 77px);
  right: clamp(38px, 5.1vw, 82px);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.brand {
  position: relative;
  display: grid;
  gap: 9px;
  isolation: isolate;
}

.brand strong {
  font-family: var(--serif);
  font-size: clamp(18px, 2.1vw, 34px);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.22em;
}

.brand span {
  font-family: var(--serif);
  font-size: clamp(9px, 0.95vw, 15px);
  letter-spacing: 0.28em;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: clamp(32px, 5vw, 80px);
  color: #fff4e8;
  font-family: var(--serif);
  font-size: clamp(13px, 0.98vw, 16px);
  font-weight: 700;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.78), 0 0 10px rgba(0, 0, 0, 0.28);
}

.nav-links a {
  white-space: nowrap;
}

.nav-cta {
  margin-left: 4px;
  padding: clamp(7px, 0.9vw, 14px) clamp(17px, 1.8vw, 29px);
  border: 1px solid rgba(255, 247, 235, 0.92);
  border-radius: 999px;
}

.hero-copy {
  position: absolute;
  z-index: 4;
  top: clamp(108px, 7.6vw, 138px);
  left: clamp(46px, 4.8vw, 77px);
  width: clamp(300px, 31.5vw, 506px);
  isolation: isolate;
}

.eyebrow {
  margin: 0 0 clamp(12px, 1.8vw, 29px);
  font-size: clamp(8px, 0.95vw, 15px);
  letter-spacing: 0.32em;
}

.hero h1 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(36px, 4.9vw, 79px);
  font-weight: 700;
  line-height: 1.16;
}

.lead {
  margin: clamp(17px, 2.1vw, 34px) 0 clamp(18px, 2.4vw, 38px);
  color: #64594d;
  font-family: var(--serif);
  font-size: clamp(11px, 1.25vw, 20px);
  line-height: 1.85;
}

.hero-actions {
  display: flex;
  gap: clamp(10px, 1.7vw, 27px);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-height: clamp(30px, 3.85vw, 62px);
  padding: 0 clamp(18px, 2.1vw, 34px);
  border-radius: 999px;
  border: 1px solid var(--brown);
  font-family: var(--serif);
  font-size: clamp(12px, 1.18vw, 19px);
  white-space: nowrap;
  cursor: pointer;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease;
}

.btn:hover,
.case-card:hover,
.step-card:hover,
.article-row:hover {
  transform: translateY(-2px);
}

.btn span {
  margin-left: 20px;
}

.primary {
  color: #fff7ee;
  background: var(--brown);
}

.primary:hover {
  background: #6b4a23;
}

.ghost {
  min-width: 150px;
  background: rgba(250, 247, 241, 0.55);
}

.material-card {
  position: absolute;
  z-index: 2;
  left: clamp(46px, 4.8vw, 77px);
  bottom: clamp(20px, 3vw, 48px);
  width: min(28vw, 450px);
  height: min(11.65vw, 187px);
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow);
}

.material-card img,
.step-card img,
.case-card img,
.article-row img,
.ai-flow img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.case-info i,
.text-link span {
  font-style: normal;
}

.service-strip {
  height: 114px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: center;
  border-bottom: 1px solid var(--line);
  background: rgba(255, 251, 245, 0.72);
}

.service-strip article {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  min-height: 58px;
  border-right: 1px solid var(--line);
}

.service-strip article:last-child {
  border-right: 0;
}

.service-strip h2 {
  margin: 0 0 5px;
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.1;
}

.service-strip p {
  margin: 0;
  color: var(--muted);
  font-family: var(--serif);
  font-size: 14px;
  line-height: 1.35;
}

.line-icon {
  position: relative;
  width: 44px;
  height: 44px;
  flex: 0 0 auto;
  border: 1.5px solid var(--gold);
  border-radius: 9px;
}

.line-icon::before,
.line-icon::after {
  content: "";
  position: absolute;
  border-color: var(--gold);
}

.icon-plan::before {
  inset: 9px 12px;
  border-left: 2px solid var(--gold);
  border-right: 2px solid var(--gold);
}

.icon-plan::after {
  width: 20px;
  height: 16px;
  left: 12px;
  top: 15px;
  border-top: 2px solid var(--gold);
  border-bottom: 2px solid var(--gold);
  transform: rotate(-18deg);
}

.icon-box {
  transform: rotate(30deg);
  border-radius: 6px;
}

.icon-box::before {
  width: 18px;
  left: 12px;
  top: 21px;
  border-top: 2px solid var(--gold);
}

.icon-build {
  border-radius: 50% 50% 8px 8px;
}

.icon-build::before {
  width: 24px;
  height: 18px;
  left: 9px;
  top: 16px;
  border: 2px solid var(--gold);
  border-top: 0;
  border-radius: 0 0 12px 12px;
}

.icon-heart {
  border: 0;
}

.icon-heart::before,
.icon-heart::after {
  width: 24px;
  height: 34px;
  left: 9px;
  top: 4px;
  border: 2px solid var(--gold);
  border-bottom: 0;
  border-radius: 24px 24px 0 0;
  transform: rotate(-45deg);
  transform-origin: 50% 100%;
}

.icon-heart::after {
  left: 10px;
  transform: rotate(45deg);
}

.section-pad {
  padding: 46px 64px 58px;
}

.section-head {
  margin-bottom: 22px;
}

.section-head.split {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
}

.section-head h2,
.ai-copy h2,
.consult-copy h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.35;
}

.section-head p {
  margin: 8px 0 0;
  color: var(--muted);
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.8;
}

.process {
  padding-top: 18px;
}

.process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 27px;
}

.step-card {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: rgba(255, 251, 245, 0.62);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.step-card:hover {
  box-shadow: 0 18px 34px rgba(67, 44, 28, 0.12);
}

.step-card img {
  height: 146px;
}

.step-body {
  position: relative;
  min-height: 110px;
  padding: 14px 18px 18px;
  font-family: var(--serif);
}

.step-body h3 {
  margin: 0 52px 8px 0;
  font-size: 18px;
}

.step-body span {
  position: absolute;
  right: 17px;
  top: 16px;
  color: #7f4c25;
  font-size: 17px;
}

.step-body p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.cases {
  padding-top: 32px;
}

.text-link {
  margin-top: 14px;
  color: #765331;
  font-family: var(--serif);
  font-size: 16px;
}

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

.case-card {
  position: relative;
  height: 414px;
  overflow: hidden;
  border-radius: 8px;
  background: #211a13;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.case-card:hover {
  box-shadow: 0 22px 40px rgba(63, 40, 24, 0.16);
}

.case-card img {
  height: 100%;
  transition: transform 500ms ease;
}

.case-card:hover img {
  transform: scale(1.03);
}

.case-info {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  min-height: 124px;
  padding: 18px 20px;
  color: #fff8ef;
  background: linear-gradient(180deg, rgba(25, 25, 19, 0.9), rgba(16, 17, 13, 0.97));
  font-family: var(--serif);
}

.case-info h3 {
  margin: 0 0 8px;
  font-size: 20px;
}

.case-info p {
  margin: 0 0 13px;
  font-size: 14px;
}

.case-info div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.case-info span {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 8px;
  border: 1px solid rgba(219, 181, 122, 0.44);
  border-radius: 5px;
  color: #d5bc96;
  font-size: 13px;
}

.case-info i {
  margin-left: auto;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(219, 181, 122, 0.75);
  border-radius: 50%;
}

.case-card b {
  position: absolute;
  left: 18px;
  top: 18px;
  display: grid;
  place-items: center;
  width: 44px;
  height: 32px;
  color: #fff2df;
  border: 1px solid rgba(219, 181, 122, 0.85);
  border-radius: 999px;
  font-family: Georgia, serif;
  font-size: 18px;
}

.journal {
  padding-top: 0;
}

.article-panel {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 251, 246, 0.58);
}

.article-tools {
  display: flex;
  align-items: center;
  gap: 40px;
  min-height: 60px;
  padding: 13px 18px;
  border-bottom: 1px solid var(--line);
}

.search {
  position: relative;
  width: 216px;
}

.search input {
  width: 100%;
  height: 34px;
  padding: 0 38px 0 13px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--ink);
  background: rgba(255, 252, 247, 0.75);
  outline: 0;
  font-size: 13px;
}

.search span {
  position: absolute;
  right: 12px;
  top: 5px;
  color: #8d7a66;
}

.tabs {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.tabs button {
  height: 30px;
  min-width: 66px;
  padding: 0 18px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: #695a4b;
  background: rgba(255, 252, 247, 0.56);
  cursor: pointer;
}

.tabs button.active {
  color: #fff7ef;
  border-color: transparent;
  background: #a58a70;
}

.article-list {
  display: grid;
}

.article-row {
  display: grid;
  grid-template-columns: 248px 1fr 180px;
  align-items: center;
  gap: 28px;
  min-height: 153px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  transition: transform 180ms ease, background 180ms ease;
}

.article-row:last-child {
  border-bottom: 0;
}

.article-row.hidden {
  display: none !important;
}

[data-tags].hidden {
  display: none !important;
}

.article-row img {
  height: 88px;
  border-radius: 5px;
}

.article-row h3 {
  margin: 0 0 14px;
  font-family: var(--serif);
  font-size: 22px;
}

.article-row p {
  margin: 0;
  color: var(--muted);
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.65;
}

.article-row > span {
  color: #786a5d;
  font-family: var(--serif);
  font-size: 14px;
  text-align: right;
}

.ai {
  min-height: 462px;
  display: grid;
  grid-template-columns: 345px 1fr;
  align-items: center;
  gap: 40px;
  padding-top: 62px;
  padding-bottom: 76px;
  background: linear-gradient(180deg, rgba(255, 251, 246, 0.44), rgba(246, 241, 235, 0.9));
}

.ai-copy p {
  margin: 20px 0 36px;
  color: var(--muted);
  font-family: var(--serif);
  line-height: 1.8;
}

.ai-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: center;
  gap: 18px;
}

.ai-flow > i {
  display: none;
}

.ai-flow article {
  overflow: hidden;
  border-radius: 7px;
  background: rgba(255, 251, 246, 0.72);
  box-shadow: 0 14px 28px rgba(74, 50, 31, 0.08);
}

.ai-flow img {
  height: 158px;
}

.ai-flow h3,
.ai-flow p {
  margin-left: 18px;
  margin-right: 18px;
  font-family: var(--serif);
}

.ai-flow h3 {
  margin-top: 17px;
  margin-bottom: 10px;
  font-size: 18px;
}

.ai-flow h3 span {
  color: #8a5b31;
  margin-right: 10px;
}

.ai-flow p {
  min-height: 62px;
  margin-top: 0;
  margin-bottom: 18px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.consult {
  position: relative;
  min-height: 584px;
  overflow: hidden;
}

.consult-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.consult-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(35, 20, 10, 0.72) 0%, rgba(64, 37, 16, 0.36) 46%, rgba(40, 20, 8, 0.08) 100%),
    linear-gradient(180deg, rgba(42, 24, 12, 0.05), rgba(42, 24, 12, 0.28));
}

.consult-content {
  position: relative;
  z-index: 1;
  min-height: 584px;
  display: grid;
  grid-template-columns: 1fr 454px;
  gap: 80px;
  align-items: center;
  padding: 64px 110px 64px 108px;
}

.consult-copy {
  color: #fff7ef;
  font-family: var(--serif);
}

.consult-copy h2 {
  font-size: 42px;
  line-height: 1.38;
}

.consult-copy p {
  margin: 22px 0 34px;
  font-size: 17px;
}

.trust-line {
  display: flex;
  align-items: center;
  gap: 36px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 247, 235, 0.48);
}

.trust-line span {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  line-height: 1.35;
}

.trust-line small {
  color: rgba(255, 247, 235, 0.82);
  font-size: 13px;
}

.mini-icon {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 36px;
  border: 1.5px solid currentColor;
  border-radius: 50%;
}

.mini-icon::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  top: 10px;
  bottom: 10px;
  border: 1.5px solid currentColor;
  border-radius: 50%;
}

.consult-form {
  padding: 36px 30px 34px;
  border-radius: 14px;
  background: rgba(255, 251, 246, 0.94);
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.18);
}

.consult-form label {
  position: relative;
  display: block;
  padding: 0 0 17px;
  margin-bottom: 18px;
  border-bottom: 1px solid rgba(93, 68, 47, 0.28);
}

.consult-form span {
  display: block;
  margin-bottom: 10px;
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 700;
}

.consult-form input,
.consult-form select,
.consult-form textarea {
  width: 100%;
  border: 0;
  outline: 0;
  resize: vertical;
  color: var(--ink);
  background: transparent;
  font-size: 15px;
}

.consult-form em {
  position: absolute;
  right: 0;
  top: 38px;
  color: #6c6156;
  font-style: normal;
}

.form-contact-note {
  margin: -2px 0 14px;
  color: rgba(80, 54, 29, 0.72);
  font-size: 14px;
  line-height: 1.7;
}

.submit-btn {
  width: 100%;
  height: 58px;
  margin-top: 8px;
  border: 0;
  border-radius: 999px;
  color: #fff7ef;
  background: var(--red);
  font-family: var(--serif);
  font-size: 18px;
  cursor: pointer;
  transition: transform 180ms ease, background 180ms ease;
}

.submit-btn:hover {
  transform: translateY(-2px);
  background: #b74d42;
}

.submit-btn span {
  margin-left: 82px;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 28px;
  z-index: 20;
  transform: translate(-50%, 20px);
  max-width: min(88vw, 420px);
  padding: 13px 20px;
  border-radius: 999px;
  color: #fff8ef;
  background: rgba(42, 31, 23, 0.92);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

.case-dialog {
  width: min(420px, calc(100vw - 40px));
  border: 0;
  border-radius: 12px;
  padding: 34px;
  color: var(--ink);
  background: var(--paper);
  box-shadow: 0 24px 80px rgba(34, 22, 12, 0.28);
}

.case-dialog::backdrop {
  background: rgba(33, 24, 16, 0.42);
}

.case-dialog h2 {
  margin: 0 0 14px;
  font-family: var(--serif);
}

.case-dialog p {
  margin: 0 0 24px;
  color: var(--muted);
  line-height: 1.8;
}

.dialog-close {
  position: absolute;
  right: 14px;
  top: 10px;
  width: 34px;
  height: 34px;
  border: 0;
  background: transparent;
  font-size: 30px;
  cursor: pointer;
}

.service-page {
  background:
    radial-gradient(circle at 50% 0, rgba(255, 255, 255, 0.72), transparent 44%),
    var(--page);
}

.service-hero {
  position: relative;
  height: clamp(640px, 55.2vw, 820px);
  min-height: 620px;
  overflow: hidden;
  background: #eadfd1;
}

.service-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.service-hero-wash {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(250, 244, 236, 0.92) 0%, rgba(250, 244, 236, 0.76) 28%, rgba(250, 244, 236, 0.16) 50%, rgba(64, 43, 24, 0.16) 100%),
    linear-gradient(180deg, rgba(31, 21, 12, 0.05), rgba(31, 21, 12, 0.08));
}

.service-nav .brand {
  color: #201812;
}

.service-nav .nav-links a.active {
  position: relative;
}

.service-nav .nav-links a.active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -22px;
  width: 52px;
  height: 1px;
  background: rgba(255, 247, 235, 0.9);
  transform: translateX(-50%);
  box-shadow: 22px 0 0 rgba(255, 247, 235, 0.35);
}

.service-hero-copy {
  position: absolute;
  z-index: 4;
  left: clamp(46px, 4.8vw, 77px);
  top: clamp(210px, 18.8vw, 290px);
  width: min(760px, 49vw);
  color: #261c13;
}

.service-hero-copy h1 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(48px, 5vw, 80px);
  font-weight: 700;
  line-height: 1.23;
}

.service-hero-copy p:not(.eyebrow) {
  margin: clamp(24px, 3vw, 46px) 0 clamp(26px, 3.1vw, 48px);
  color: #65594b;
  font-family: var(--serif);
  font-size: clamp(17px, 1.42vw, 23px);
  line-height: 1.8;
}

.service-section {
  padding: clamp(58px, 5.8vw, 94px) clamp(48px, 4.7vw, 80px);
}

.service-title {
  display: grid;
  place-items: center;
  gap: 14px;
  margin-bottom: clamp(28px, 3.1vw, 50px);
  text-align: center;
}

.service-title h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(28px, 2.6vw, 42px);
  line-height: 1.2;
}

.service-title span {
  display: block;
  width: 34px;
  height: 1px;
  background: rgba(143, 111, 80, 0.66);
}

.service-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(28px, 2.4vw, 38px);
}

.service-detail-card {
  min-height: 292px;
  display: grid;
  grid-template-columns: minmax(240px, 42%) 1fr;
  overflow: hidden;
  border: 1px solid rgba(122, 91, 63, 0.16);
  border-radius: 8px;
  background: rgba(255, 252, 247, 0.68);
  box-shadow: 0 20px 52px rgba(80, 54, 34, 0.08);
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.service-detail-card.reverse {
  grid-template-columns: 1fr minmax(240px, 42%);
}

.service-detail-card.reverse img {
  order: 2;
}

.service-detail-card:hover,
.deliver-grid article:hover,
.fit-list article:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 58px rgba(76, 50, 30, 0.14);
}

.service-detail-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.service-detail-card div {
  padding: clamp(34px, 3.1vw, 50px) clamp(32px, 3vw, 48px);
  font-family: var(--serif);
}

.service-detail-card span {
  margin-right: 22px;
  color: #9b7c5d;
  font-size: clamp(24px, 2.1vw, 34px);
}

.service-detail-card h3 {
  display: inline;
  margin: 0;
  font-size: clamp(21px, 1.7vw, 28px);
}

.service-detail-card p {
  margin: 36px 0 50px;
  max-width: 370px;
  color: #67594c;
  font-size: clamp(15px, 1.1vw, 18px);
  line-height: 1.9;
}

.service-detail-card button {
  height: 42px;
  padding: 0;
  border: 0;
  color: #755332;
  background: transparent;
  font-family: var(--serif);
  font-size: 17px;
  cursor: pointer;
}

.service-detail-card button i {
  margin-left: 18px;
  font-style: normal;
}

.service-flow {
  background: linear-gradient(180deg, rgba(255, 252, 247, 0.38), rgba(246, 241, 235, 0.96));
}

.flow-line {
  position: relative;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 24px;
  margin: 0 auto clamp(52px, 5.7vw, 92px);
  max-width: 1360px;
}

.flow-line::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 38px;
  border-top: 1px dashed rgba(155, 126, 96, 0.55);
}

.flow-line article {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  text-align: center;
  font-family: var(--serif);
}

.flow-line b {
  order: 2;
  margin-top: 24px;
  color: #201812;
  font-size: 24px;
}

.flow-line h3 {
  order: 3;
  margin: 8px 0 12px;
  font-size: 22px;
}

.flow-line p {
  order: 4;
  max-width: 164px;
  margin: 0;
  color: #6e6258;
  font-size: 15px;
  line-height: 1.75;
}

.flow-icon {
  position: relative;
  display: block;
  width: 64px;
  height: 64px;
  border: 1.5px solid rgba(139, 104, 72, 0.62);
  border-radius: 50%;
  background: rgba(255, 252, 247, 0.86);
}

.flow-icon::before,
.flow-icon::after {
  content: "";
  position: absolute;
  border-color: #9b7350;
}

.icon-chat::before {
  width: 24px;
  height: 18px;
  left: 18px;
  top: 19px;
  border: 2px solid #9b7350;
  border-radius: 14px;
}

.icon-chat::after {
  width: 10px;
  height: 8px;
  left: 24px;
  top: 37px;
  border-left: 2px solid #9b7350;
  border-bottom: 2px solid #9b7350;
  transform: skew(-24deg);
}

.icon-cube::before {
  width: 25px;
  height: 25px;
  left: 19px;
  top: 19px;
  border: 2px solid #9b7350;
  transform: rotate(45deg);
}

.icon-budget::before {
  width: 24px;
  height: 24px;
  left: 18px;
  top: 18px;
  border: 2px solid #9b7350;
  border-radius: 4px;
}

.icon-budget::after {
  width: 18px;
  left: 23px;
  top: 32px;
  border-top: 2px solid #9b7350;
}

.icon-sample::before {
  width: 27px;
  height: 20px;
  left: 18px;
  top: 21px;
  border: 2px solid #9b7350;
  border-radius: 5px;
}

.icon-site::before {
  width: 24px;
  height: 24px;
  left: 19px;
  top: 18px;
  border: 2px solid #9b7350;
  border-radius: 50% 50% 8px 8px;
}

.icon-home::before {
  width: 25px;
  height: 18px;
  left: 18px;
  top: 25px;
  border: 2px solid #9b7350;
  border-top: 0;
}

.icon-home::after {
  width: 20px;
  height: 20px;
  left: 21px;
  top: 17px;
  border-left: 2px solid #9b7350;
  border-top: 2px solid #9b7350;
  transform: rotate(45deg);
}

.deliver-panel {
  max-width: 1380px;
  margin: 0 auto;
  padding: clamp(42px, 4.2vw, 70px) clamp(28px, 3vw, 48px);
  border-radius: 8px;
  background: rgba(255, 252, 247, 0.56);
  box-shadow: 0 18px 55px rgba(91, 66, 43, 0.08);
}

.deliver-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(18px, 1.7vw, 28px);
}

.deliver-grid article {
  overflow: hidden;
  border: 1px solid rgba(122, 91, 63, 0.1);
  border-radius: 8px;
  background: rgba(251, 247, 241, 0.9);
  text-align: center;
  font-family: var(--serif);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.deliver-grid img {
  width: 100%;
  aspect-ratio: 1 / 0.88;
  object-fit: cover;
  display: block;
}

.deliver-grid h3 {
  margin: 22px 10px 10px;
  font-size: 21px;
}

.deliver-grid p {
  min-height: 64px;
  margin: 0 18px 22px;
  color: #6e6258;
  font-size: 15px;
  line-height: 1.65;
}

.fit-layout {
  position: relative;
  display: grid;
  grid-template-columns: minmax(360px, 42%) 1fr minmax(150px, 16%);
  gap: 28px;
  align-items: start;
}

.fit-photo {
  width: 100%;
  height: 352px;
  object-fit: cover;
  border-radius: 8px;
}

.fit-still {
  width: 100%;
  max-height: 352px;
  object-fit: contain;
  align-self: end;
}

.fit-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid rgba(122, 91, 63, 0.18);
  border-left: 1px solid rgba(122, 91, 63, 0.18);
}

.fit-list article {
  position: relative;
  min-height: 126px;
  padding: 28px 30px 24px 86px;
  border-right: 1px solid rgba(122, 91, 63, 0.18);
  border-bottom: 1px solid rgba(122, 91, 63, 0.18);
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.fit-list article:last-child {
  grid-column: span 1;
}

.fit-list i {
  position: absolute;
  width: 34px;
  height: 34px;
  margin-left: -56px;
  display: inline-grid;
  place-items: center;
  border: 1.4px solid #6f5134;
  border-radius: 50%;
  color: #5c3d22;
  font-style: normal;
}

.fit-list h3 {
  margin: 0 0 12px;
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.4;
}

.fit-list p {
  margin: 0;
  color: #6e6258;
  font-family: var(--serif);
  font-size: 15px;
}

.service-consult {
  position: relative;
  min-height: 286px;
  display: grid;
  grid-template-columns: minmax(360px, 1fr) auto 270px;
  align-items: center;
  gap: 36px;
  margin: 0 clamp(48px, 4.7vw, 80px) clamp(58px, 5.8vw, 94px);
  padding: 44px clamp(38px, 4vw, 62px);
  overflow: hidden;
  border-radius: 8px;
  background: linear-gradient(90deg, rgba(221, 204, 184, 0.95), rgba(234, 220, 202, 0.78));
}

.service-consult-copy {
  position: relative;
  z-index: 1;
  font-family: var(--serif);
}

.service-consult h2 {
  margin: 0 0 28px;
  font-size: clamp(27px, 2.4vw, 38px);
  line-height: 1.55;
}

.consult-badges {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 24px;
  font-family: var(--serif);
}

.consult-badges span {
  min-width: 138px;
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 10px;
  color: #2b2118;
  font-size: 17px;
}

.consult-badges small {
  display: block;
  grid-column: 2;
  color: #6e6258;
  font-size: 14px;
}

.service-consult > img {
  position: absolute;
  right: 0;
  top: 0;
  width: 320px;
  height: 100%;
  object-fit: cover;
  object-position: right center;
  opacity: 0.92;
}

.service-dialog h2 {
  font-size: 26px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.service-pixel-page {
  background: #f7f1eb;
}

.pixel-page {
  background: #f7f1eb;
}

.pixel-shot,
.service-shot {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #f7f1eb;
}

.pixel-shot img,
.service-shot img {
  width: 100%;
  height: auto;
  display: block;
  user-select: none;
}

.shot-hotspot {
  position: absolute;
  z-index: 2;
  display: block;
  border: 0;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
}

.shot-hotspot:focus-visible {
  outline: 2px solid rgba(94, 61, 28, 0.62);
  outline-offset: 3px;
}

.logo-hotspot {
  left: 3.5%;
  top: 5%;
  width: 12%;
  height: 7%;
}

.nav-service-hotspot {
  left: 54.8%;
  top: 6.2%;
  width: 7.8%;
  height: 5.8%;
}

.nav-case-hotspot {
  left: 64.4%;
  top: 6.2%;
  width: 5.7%;
  height: 5.8%;
}

.nav-journal-hotspot {
  left: 71.4%;
  top: 6.2%;
  width: 8.7%;
  height: 5.8%;
}

.nav-ai-hotspot {
  left: 80.6%;
  top: 6.2%;
  width: 8.9%;
  height: 5.8%;
}

.nav-consult-hotspot {
  left: 88.4%;
  top: 4.5%;
  width: 9.1%;
  height: 7.3%;
}

.hero-consult-hotspot {
  left: 3.7%;
  top: 69.5%;
  width: 17.1%;
  height: 7.3%;
}

.service-card-hotspot {
  border-radius: 8px;
}

.service-card-one {
  left: 4.6%;
  top: 16%;
  width: 39.8%;
  height: 40%;
}

.service-card-two {
  left: 47.3%;
  top: 16%;
  width: 47.9%;
  height: 40%;
}

.service-card-three {
  left: 4.6%;
  top: 60%;
  width: 46.4%;
  height: 36.8%;
}

.service-card-four {
  left: 52.2%;
  top: 60%;
  width: 42.9%;
  height: 36.8%;
}

.fit-consult-hotspot {
  left: 7%;
  top: 83%;
  width: 15.8%;
  height: 6.8%;
}

.service-ai-correction {
  position: absolute;
  z-index: 3;
  left: 80.5%;
  top: 6.25%;
  display: grid;
  place-items: center;
  width: 8.9%;
  height: 5.2%;
  color: #fff7ed;
  background: rgba(103, 76, 52, 0.72);
  backdrop-filter: blur(5px);
  font-family: var(--serif);
  font-size: clamp(8px, 1.05vw, 18px);
  font-weight: 700;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.38);
  pointer-events: none;
}

.pixel-crop {
  position: relative;
  width: 100%;
  height: var(--crop-height);
  overflow: hidden;
  background: #f7f1eb;
}

.pixel-crop img {
  position: absolute;
  left: 0;
  top: calc(-1 * var(--crop-top));
  width: 100%;
  height: auto;
  display: block;
  user-select: none;
}

.case-more-crop {
  --crop-top: 26.8vw;
  --crop-height: 19.4vw;
}

.about-mid-crop {
  --crop-top: 6.3vw;
  --crop-height: 70.9vw;
}

.about-hero-crop {
  --crop-top: 0vw;
  --crop-height: 69.5vw;
}

.px-nav-service {
  left: 49.8%;
  top: 4.3%;
  width: 8.5%;
  height: 5.8%;
}

.px-nav-case {
  left: 59.6%;
  top: 4.3%;
  width: 6.5%;
  height: 5.8%;
}

.px-nav-journal {
  left: 67.2%;
  top: 4.3%;
  width: 8.9%;
  height: 5.8%;
}

.px-nav-ai {
  left: 76.6%;
  top: 4.3%;
  width: 8.2%;
  height: 5.8%;
}

.px-nav-consult {
  left: 86.2%;
  top: 3.1%;
  width: 10.7%;
  height: 7.5%;
}

.info-hotspot {
  border-radius: 8px;
}

.case-hit-one {
  left: 6.2%;
  top: 66.3%;
  width: 28%;
  height: 31.5%;
}

.case-hit-two {
  left: 35.8%;
  top: 66.3%;
  width: 28%;
  height: 31.5%;
}

.case-hit-three {
  left: 65.5%;
  top: 66.3%;
  width: 28%;
  height: 31.5%;
}

.case-hit-four {
  left: 8%;
  top: 4%;
  width: 26.5%;
  height: 87%;
}

.case-hit-five {
  left: 35.6%;
  top: 4%;
  width: 29%;
  height: 87%;
}

.case-hit-six {
  left: 65.5%;
  top: 4%;
  width: 28%;
  height: 87%;
}

.case-feature-hit {
  left: 50%;
  top: 0;
  width: 44%;
  height: 55%;
}

.case-consult-hit {
  left: 7%;
  top: 85%;
  width: 15%;
  height: 8%;
}

.journal-feature-hit {
  left: 5%;
  top: 15%;
  width: 42%;
  height: 78%;
}

.journal-budget-hit {
  left: 48%;
  top: 15%;
  width: 42%;
  height: 36%;
}

.journal-designer-hit {
  left: 48%;
  top: 54%;
  width: 42%;
  height: 39%;
}

.journal-consult-hit {
  left: 7%;
  top: 58%;
  width: 25%;
  height: 11%;
}

.ai-submit-hit {
  left: 3.8%;
  top: 40%;
  width: 15%;
  height: 6%;
}

.ai-case-hit {
  left: 20%;
  top: 40%;
  width: 13%;
  height: 6%;
}

.ai-faq-one {
  left: 4.5%;
  top: 10%;
  width: 91%;
  height: 9%;
}

.ai-faq-two {
  left: 4.5%;
  top: 19.5%;
  width: 91%;
  height: 9%;
}

.ai-faq-three {
  left: 4.5%;
  top: 29%;
  width: 91%;
  height: 9%;
}

.ai-form-submit-hit {
  left: 55%;
  top: 77%;
  width: 32%;
  height: 9%;
}

.about-consult-hit {
  left: 48%;
  top: 52%;
  width: 45%;
  height: 15%;
}

.about-service-hit {
  left: 28%;
  top: 68%;
  width: 10%;
  height: 26%;
}

.about-case-hit {
  left: 41%;
  top: 68%;
  width: 10%;
  height: 26%;
}

.about-journal-hit {
  left: 53%;
  top: 68%;
  width: 11%;
  height: 26%;
}

@media (max-width: 760px) {
  .site-shell {
    width: 100%;
  }

  .nav {
    top: 16px;
    left: 35px;
    right: 31px;
  }

  .brand {
    pointer-events: auto;
  }

  .nav-links {
    gap: 22px;
    font-size: 9px;
  }

  .nav-links {
    display: flex;
  }

  .hero-copy {
    top: 142px;
    left: 35px;
    width: 300px;
  }

  .btn {
    min-height: 28px;
    padding: 0 12px;
    font-size: 11px;
  }

  .hero-actions {
    gap: 8px;
  }

  .ghost {
    min-width: 124px;
  }

  .material-card {
    left: 35px;
    bottom: 18px;
    width: 196px;
    height: 82px;
    border-radius: 7px;
  }

  .service-hero {
    height: 720px;
  }

  .service-nav .nav-links {
    gap: 16px;
  }

  .service-nav .nav-cta {
    display: none;
  }

  .service-hero-copy {
    top: 142px;
    left: 35px;
    width: min(330px, calc(100vw - 70px));
  }

  .service-hero-copy h1 {
    font-size: 42px;
  }

  .service-hero-copy p:not(.eyebrow) {
    font-size: 16px;
  }

  .service-section {
    padding: 46px 24px;
  }

  .service-card-grid,
  .flow-line,
  .deliver-grid,
  .fit-layout,
  .fit-list,
  .service-consult {
    grid-template-columns: 1fr;
  }

  .service-detail-card,
  .service-detail-card.reverse {
    grid-template-columns: 1fr;
  }

  .service-detail-card.reverse img {
    order: 0;
  }

  .service-detail-card img {
    height: 220px;
  }

  .flow-line::before,
  .fit-still {
    display: none;
  }

  .flow-line {
    gap: 34px;
  }

  .deliver-grid {
    gap: 18px;
  }

  .fit-photo {
    height: 280px;
  }

  .service-consult {
    margin: 0 24px 48px;
    padding: 34px 26px;
  }

  .consult-badges {
    display: grid;
  }

  .service-consult > img {
    display: none;
  }

}

@media (max-width: 520px) {
  .service-strip,
  .process-grid,
  .case-grid,
  .ai,
  .consult-content {
    grid-template-columns: 1fr;
  }

  .service-strip {
    height: auto;
    padding: 18px 0;
  }

  .service-strip article {
    justify-content: flex-start;
    padding: 16px 24px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .section-pad {
    padding: 36px 22px;
  }

  .section-head.split,
  .article-tools {
    display: block;
  }

  .search {
    width: 100%;
    margin-bottom: 14px;
  }

  .article-row {
    grid-template-columns: 112px 1fr;
    gap: 14px;
  }

  .article-row > span {
    grid-column: 2;
    text-align: left;
  }

  .ai {
    gap: 26px;
  }

  .ai-flow {
    grid-template-columns: 1fr;
  }

  .consult-content {
    gap: 28px;
    padding: 44px 22px;
  }

  .trust-line {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

/* Real prototype pages: typed content + high-resolution assets */
.real-page {
  --real-bg: #f5efe7;
  --real-paper: #fffaf3;
  --real-ink: #211b16;
  --real-muted: #74665a;
  --real-line: rgba(87, 63, 40, 0.18);
  background: var(--real-bg);
}

.real-page img {
  display: block;
  width: 100%;
}

.mobile-only {
  display: none;
}

.real-nav {
  position: absolute;
  z-index: 20;
  top: clamp(24px, 3vw, 48px);
  left: clamp(34px, 4.8vw, 76px);
  right: clamp(34px, 4.8vw, 76px);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 28px;
}

.real-brand {
  display: grid;
  gap: 8px;
  flex: 0 0 auto;
}

.real-brand strong {
  font-family: var(--serif);
  font-size: clamp(22px, 2.2vw, 36px);
  letter-spacing: 0.2em;
  line-height: 1;
}

.real-brand span {
  font-family: var(--serif);
  font-size: clamp(11px, 0.95vw, 15px);
  letter-spacing: 0.28em;
}

.real-links {
  display: flex;
  align-items: center;
  gap: clamp(24px, 4.5vw, 72px);
  font-family: var(--serif);
  font-size: clamp(13px, 1vw, 17px);
  font-weight: 700;
}

.real-links a {
  white-space: nowrap;
}

.real-links a:not(.real-nav-cta).active {
  border-bottom: 1px solid currentColor;
  padding-bottom: 5px;
}

.real-nav-cta {
  border: 1px solid currentColor;
  border-radius: 999px;
  padding: 12px 26px;
}

.nav-light {
  color: #fff7eb;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.42);
}

.nav-dark {
  color: #211b16;
}

.real-hero {
  position: relative;
  min-height: 760px;
  overflow: hidden;
}

.real-hero-copy {
  position: relative;
  z-index: 4;
  width: min(520px, calc(100vw - 56px));
}

.real-kicker {
  margin: 0 0 18px;
  color: var(--gold);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.34em;
}

.real-hero-copy h1,
.real-section h2,
.case-feature-real h2,
.real-cta-photo h2,
.real-consult h2 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.14;
  overflow-wrap: anywhere;
}

.real-hero-copy h1 {
  font-size: clamp(46px, 5.5vw, 88px);
}

.real-hero-copy p:not(.real-kicker),
.real-section-head > p,
.case-feature-real p,
.real-cta-photo p,
.real-consult p {
  color: var(--real-muted);
  font-family: var(--serif);
  font-size: clamp(17px, 1.35vw, 23px);
  line-height: 1.95;
}

.real-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 34px;
}

.real-btn {
  display: inline-flex;
  min-height: 58px;
  align-items: center;
  justify-content: center;
  gap: 22px;
  border-radius: 999px;
  padding: 0 34px;
  border: 1px solid var(--brown);
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 700;
  white-space: nowrap;
  transition: transform 180ms ease, background-color 180ms ease, color 180ms ease;
}

.real-btn:hover,
.real-card:hover {
  transform: translateY(-3px);
}

.real-btn.primary {
  background: var(--brown);
  color: #fff8ef;
}

.real-btn.outline {
  background: rgba(255, 250, 243, 0.68);
  color: var(--brown);
}

.light-outline {
  border-color: rgba(255, 248, 238, 0.86);
  color: #fff8ef;
  background: rgba(255, 255, 255, 0.1);
}

.real-section {
  padding: clamp(70px, 8vw, 128px) clamp(32px, 5.6vw, 90px);
}

.real-alt {
  background: #fbf6ef;
  border-top: 1px solid var(--real-line);
  border-bottom: 1px solid var(--real-line);
}

.real-section-head {
  max-width: 840px;
  margin-bottom: clamp(34px, 4.8vw, 70px);
}

.real-section-head h2,
.case-feature-real h2,
.real-cta-photo h2,
.real-consult h2 {
  font-size: clamp(34px, 3.8vw, 58px);
}

.split-head {
  display: flex;
  max-width: none;
  align-items: end;
  justify-content: space-between;
  gap: 40px;
}

.split-head > p {
  max-width: 520px;
  margin: 0;
}

.service-real-hero {
  display: grid;
  grid-template-columns: minmax(420px, 42%) 1fr;
  align-items: stretch;
  background: #f6f0e8;
}

.service-real-hero .real-hero-copy,
.cases-hero .real-hero-copy {
  padding: clamp(170px, 13vw, 230px) 0 70px clamp(42px, 5.7vw, 92px);
}

.service-real-hero .real-hero-copy p:not(.real-kicker),
.cases-hero .real-hero-copy p:not(.real-kicker) {
  max-width: 500px;
}

.service-hero-image {
  position: relative;
  min-height: 760px;
  margin: 0;
  overflow: hidden;
  border-bottom-left-radius: 70px;
}

.service-hero-image img {
  height: 100%;
  object-fit: cover;
}

.service-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
}

.service-detail-card,
.real-card {
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.service-detail-card {
  display: grid;
  grid-template-columns: 48% 1fr;
  min-height: 310px;
  overflow: hidden;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  box-shadow: 0 18px 42px rgba(60, 40, 22, 0.08);
}

.service-detail-card img {
  height: 100%;
  object-fit: cover;
}

.service-detail-card div {
  display: grid;
  align-content: center;
  gap: 14px;
  padding: 30px;
}

.service-detail-card span,
.real-process span,
.philosophy-grid span {
  color: var(--gold);
  font-family: Georgia, serif;
  font-size: 18px;
}

.service-detail-card h3,
.real-process h3,
.deliver-grid-real h3,
.real-case-card h3,
.journal-card h3,
.article-row h3,
.ai-reason-grid h3,
.team-grid h3,
.philosophy-grid h3 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(22px, 1.8vw, 30px);
}

.service-detail-card p,
.real-process p,
.deliver-grid-real p,
.real-case-card p,
.journal-card p,
.article-row p,
.ai-reason-grid p,
.team-grid p,
.philosophy-grid p {
  margin: 0;
  color: var(--real-muted);
  font-size: 15px;
  line-height: 1.9;
}

.real-process {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-line);
}

.real-process article {
  min-height: 230px;
  padding: 30px;
  background: var(--real-paper);
}

.real-process span {
  display: block;
  margin-bottom: 42px;
}

.deliver-grid-real,
.ai-reason-grid,
.team-grid,
.philosophy-grid,
.featured-article-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px;
}

.deliver-grid-real {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.deliver-grid-real article,
.ai-reason-grid article,
.team-grid article,
.philosophy-grid article,
.journal-card,
.real-case-card {
  overflow: hidden;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  box-shadow: 0 18px 42px rgba(60, 40, 22, 0.08);
}

.deliver-grid-real img,
.ai-reason-grid img,
.team-grid img,
.philosophy-grid img,
.journal-card img,
.real-case-card img {
  aspect-ratio: 1.1 / 1;
  object-fit: cover;
}

.deliver-grid-real article > *:not(img),
.ai-reason-grid article > *:not(img),
.team-grid article > *:not(img),
.philosophy-grid article > *:not(img),
.journal-card div,
.real-case-card div {
  padding: 0 24px 24px;
}

.deliver-grid-real h3,
.ai-reason-grid h3,
.team-grid h3,
.philosophy-grid h3,
.journal-card h3,
.real-case-card h3 {
  padding-top: 22px;
}

.fit-section {
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  gap: clamp(40px, 6vw, 88px);
  align-items: center;
}

.real-check-list {
  display: grid;
  gap: 18px;
  margin: 32px 0;
  padding: 0;
  list-style: none;
  color: var(--real-muted);
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.7;
}

.real-check-list li {
  position: relative;
  padding-left: 28px;
}

.real-check-list li::before {
  position: absolute;
  left: 0;
  color: var(--gold);
  content: "□";
}

.fit-collage {
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  gap: 22px;
  align-items: end;
}

.fit-collage img {
  height: 520px;
  object-fit: cover;
  border-radius: 8px;
}

.fit-collage img:first-child {
  height: 390px;
}

.cases-hero {
  display: grid;
  grid-template-columns: minmax(420px, 38%) 1fr;
  gap: 52px;
  align-items: center;
  background: #f6f0e8;
}

.case-hero-collage {
  display: grid;
  grid-template-columns: 1fr 0.78fr;
  grid-template-rows: 1fr 1fr;
  gap: 18px;
  height: min(680px, 52vw);
  min-height: 560px;
  padding: clamp(138px, 11vw, 190px) clamp(38px, 4.8vw, 78px) 58px 0;
}

.case-hero-collage img {
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

.case-hero-collage .wide {
  grid-row: span 2;
}

.real-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.real-tabs button {
  min-height: 44px;
  border: 1px solid var(--real-line);
  border-radius: 999px;
  background: rgba(255, 250, 243, 0.78);
  color: var(--real-muted);
  padding: 0 22px;
  cursor: pointer;
}

.real-tabs button.active {
  background: var(--brown);
  color: #fff8ef;
  border-color: var(--brown);
}

.real-case-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}

.case-principle-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: rgba(91, 64, 37, 0.18);
  border-top: 1px solid rgba(91, 64, 37, 0.16);
  border-bottom: 1px solid rgba(91, 64, 37, 0.16);
}

.case-principle-strip article {
  min-height: 210px;
  padding: clamp(32px, 4vw, 54px);
  background: #fbf6ee;
}

.case-principle-strip span {
  color: var(--gold);
  font-family: Georgia, serif;
  font-size: 18px;
}

.case-principle-strip h2 {
  margin: 18px 0 14px;
  font-size: clamp(24px, 2.2vw, 34px);
}

.case-principle-strip p {
  max-width: 360px;
  color: var(--real-muted);
  line-height: 1.9;
}

.comparison-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(24px, 3vw, 42px);
}

.comparison-card {
  display: grid;
  overflow: hidden;
  background: #fffaf3;
  border: 1px solid rgba(91, 64, 37, 0.14);
  cursor: pointer;
}

.comparison-card img {
  width: 100%;
  aspect-ratio: 1672 / 941;
  object-fit: cover;
  border-radius: 0;
}

.comparison-card div {
  padding: 24px 26px 28px;
}

.comparison-card h3 {
  margin: 10px 0 10px;
  font-size: clamp(24px, 2vw, 32px);
}

.comparison-card p {
  margin: 0;
  color: var(--real-muted);
  line-height: 1.8;
}

.case-ethics {
  background: #efe5d9;
}

.real-case-card span,
.journal-card span,
.article-row span {
  color: var(--gold);
  font-size: 13px;
  letter-spacing: 0.14em;
}

.article-row.hidden {
  display: none;
}

.case-feature-real {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: clamp(36px, 5vw, 76px);
  align-items: center;
  padding: clamp(56px, 6vw, 92px) clamp(32px, 5.6vw, 90px);
  background: #efe5d9;
}

.case-feature-real img {
  height: 560px;
  object-fit: cover;
  border-radius: 8px;
}

.case-feature-real p:not(.real-kicker) {
  margin: 24px 0 34px;
}

.real-cta-photo {
  position: relative;
  min-height: 430px;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: #fff8ef;
  text-align: center;
}

.real-cta-photo img {
  position: absolute;
  inset: 0;
  height: 100%;
  object-fit: cover;
}

.real-cta-photo::after {
  position: absolute;
  inset: 0;
  background: rgba(26, 18, 11, 0.46);
  content: "";
}

.real-cta-photo > div {
  position: relative;
  z-index: 2;
  width: min(760px, calc(100vw - 60px));
}

.image-hero {
  min-height: 800px;
  color: #fff8ef;
}

.image-hero > img {
  position: absolute;
  inset: 0;
  height: 100%;
  object-fit: cover;
}

.image-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(22, 15, 9, 0.78), rgba(22, 15, 9, 0.28) 48%, rgba(22, 15, 9, 0.08));
}

.image-hero .real-hero-copy {
  padding: clamp(185px, 16vw, 260px) 0 80px clamp(42px, 5.7vw, 92px);
}

.image-hero .real-hero-copy p:not(.real-kicker) {
  max-width: 600px;
  color: rgba(255, 249, 239, 0.86);
}

.journal-hero .real-hero-copy h1,
.about-hero .real-hero-copy h1 {
  font-size: clamp(58px, 6.2vw, 96px);
}

.real-search {
  display: flex;
  width: min(620px, calc(100vw - 70px));
  margin-top: 42px;
  border: 1px solid rgba(255, 250, 242, 0.58);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(12px);
}

.real-search input {
  width: 100%;
  min-height: 58px;
  border: 0;
  outline: 0;
  background: transparent;
  color: #fff8ef;
  padding: 0 26px;
}

.real-search input::placeholder {
  color: rgba(255, 248, 238, 0.68);
}

.journal-tools-section {
  padding-top: 34px;
  padding-bottom: 34px;
  background: #fbf6ef;
}

.featured-article-grid .journal-card:first-child {
  grid-column: span 1;
}

.article-list-real {
  display: grid;
  gap: 18px;
}

.article-list-real .article-row {
  display: grid;
  grid-template-columns: 190px 1fr auto;
  gap: 28px;
  align-items: center;
  min-height: 166px;
  overflow: hidden;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  padding-right: 28px;
}

.article-list-real img {
  height: 166px;
  object-fit: cover;
}

.article-list-real .article-row div {
  padding: 0;
}

.article-list-real b {
  color: var(--gold);
  font-family: Georgia, serif;
  font-weight: 400;
}

.content-system-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: -28px 0 34px;
}

.content-system-grid article {
  min-height: 168px;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  padding: 24px;
}

.content-system-grid span {
  color: var(--gold);
  font-family: Georgia, serif;
  font-size: 14px;
  letter-spacing: 0.12em;
}

.content-system-grid h3 {
  margin: 18px 0 10px;
  font-family: var(--serif);
  font-size: 24px;
}

.content-system-grid p {
  margin: 0;
  color: var(--real-muted);
  line-height: 1.8;
}

.article-page {
  background: #f5efe7;
}

.article-nav {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  padding: clamp(24px, 3vw, 48px) clamp(34px, 4.8vw, 76px) 0;
}

.geo-article {
  padding: 0 clamp(32px, 5.6vw, 90px) clamp(64px, 7vw, 110px);
}

.article-hero {
  padding-top: clamp(56px, 7vw, 108px);
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  color: var(--real-muted);
  font-size: 14px;
}

.breadcrumb a {
  color: var(--gold);
}

.article-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.78fr);
  gap: clamp(36px, 6vw, 92px);
  align-items: center;
  margin-top: 42px;
}

.article-hero-grid > * {
  min-width: 0;
}

.article-hero h1 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(44px, 5vw, 78px);
  line-height: 1.12;
}

.article-description {
  max-width: 780px;
  color: var(--real-muted);
  font-family: var(--serif);
  font-size: clamp(18px, 1.5vw, 24px);
  line-height: 1.9;
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.article-meta span,
.article-meta time {
  border: 1px solid var(--real-line);
  border-radius: 999px;
  color: var(--real-muted);
  padding: 8px 14px;
}

.article-hero figure {
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 22px 60px rgba(64, 41, 24, 0.14);
}

.article-hero figure img {
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.article-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 860px);
  gap: clamp(32px, 5vw, 78px);
  align-items: start;
  margin-top: clamp(58px, 7vw, 100px);
}

.article-toc {
  position: sticky;
  top: 24px;
  display: grid;
  gap: 14px;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: rgba(255, 250, 243, 0.82);
  padding: 20px;
}

.article-toc strong {
  font-family: var(--serif);
  font-size: 20px;
}

.article-toc a {
  color: var(--real-muted);
  font-size: 14px;
}

.article-content {
  color: #2a211a;
}

.article-content p,
.article-content li {
  color: var(--real-muted);
  font-size: 17px;
  line-height: 2;
}

.article-content strong {
  color: var(--real-ink);
}

.answer-box {
  border: 1px solid rgba(154, 109, 60, 0.35);
  border-radius: 8px;
  background: #fff8ef;
  padding: clamp(24px, 3vw, 38px);
  margin-bottom: 34px;
}

.answer-box h2,
.article-section h2 {
  margin: 0 0 18px;
  font-family: var(--serif);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.25;
}

.article-section {
  margin-top: clamp(42px, 5vw, 72px);
}

.article-section h3 {
  margin: 30px 0 12px;
  font-family: var(--serif);
  font-size: 24px;
}

.table-scroll {
  overflow-x: auto;
  margin: 24px 0;
  border: 1px solid var(--real-line);
  border-radius: 8px;
}

.article-content table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  background: var(--real-paper);
}

.article-content th,
.article-content td {
  border-bottom: 1px solid var(--real-line);
  padding: 15px 16px;
  color: var(--real-muted);
  line-height: 1.75;
  text-align: left;
  vertical-align: top;
}

.article-content th {
  color: var(--real-ink);
  font-family: var(--serif);
  background: #f2e8dc;
}

.document-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 24px 0;
}

.document-grid span {
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  padding: 16px 18px;
  color: var(--real-ink);
  font-family: var(--serif);
}

.article-content details {
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  padding: 20px 24px;
  margin: 14px 0;
}

.article-content summary {
  cursor: pointer;
  color: var(--real-ink);
  font-family: var(--serif);
  font-size: 21px;
  font-weight: 700;
}

.source-section a {
  color: var(--gold);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.article-next {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 40px;
  align-items: start;
}

.next-article-grid {
  display: grid;
  gap: 14px;
}

.next-article-grid a {
  display: flex;
  gap: 16px;
  align-items: center;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  padding: 18px 22px;
  font-family: var(--serif);
  font-size: 20px;
}

.next-article-grid span {
  color: var(--gold);
  font-family: Georgia, serif;
}

.ai-hero {
  min-height: 860px;
}

.ai-hero .real-hero-copy {
  width: min(720px, calc(100vw - 56px));
}

.ai-problem-panel {
  position: absolute;
  z-index: 5;
  right: clamp(34px, 5.6vw, 90px);
  bottom: clamp(42px, 5vw, 80px);
  width: min(360px, calc(100vw - 68px));
  padding: 30px;
  border: 1px solid rgba(255, 248, 238, 0.36);
  border-radius: 8px;
  background: rgba(34, 24, 15, 0.5);
  color: #fff8ef;
  backdrop-filter: blur(12px);
}

.ai-problem-panel h2 {
  margin: 0 0 18px;
  font-family: var(--serif);
  font-size: 28px;
}

.ai-problem-panel p {
  margin: 0;
  padding: 13px 0;
  border-top: 1px solid rgba(255, 248, 238, 0.22);
}

.ai-problem-panel a {
  display: inline-flex;
  margin-top: 20px;
  color: #ead2ad;
}

.ai-reason-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ai-method-section {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 70px;
  align-items: start;
}

.ai-method-section > div:first-child p:not(.real-kicker) {
  color: var(--real-muted);
  font-family: var(--serif);
  font-size: 21px;
  line-height: 1.9;
}

.ai-step-list {
  display: grid;
  gap: 18px;
}

.ai-step-list article {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 18px;
  padding: 26px;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
}

.ai-step-list span {
  grid-row: 1 / span 2;
  color: var(--gold);
  font-family: Georgia, serif;
  font-size: 28px;
}

.ai-step-list h3 {
  grid-column: 2;
  margin: 0 0 8px;
  font-family: var(--serif);
  font-size: 24px;
}

.ai-step-list p {
  grid-column: 2;
  margin: 0;
  color: var(--real-muted);
  line-height: 1.8;
}

.output-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.faq-list {
  display: grid;
  gap: 14px;
}

.faq-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  width: 100%;
  border: 1px solid var(--real-line);
  border-radius: 8px;
  background: var(--real-paper);
  padding: 24px 28px;
  color: var(--real-ink);
  text-align: left;
  cursor: pointer;
}

.faq-item span {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 700;
}

.faq-item em {
  display: none;
  grid-column: 1 / -1;
  color: var(--real-muted);
  font-style: normal;
  line-height: 1.85;
}

.faq-item.open em {
  display: block;
}

.faq-item.open b {
  transform: rotate(45deg);
}

.real-consult {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: clamp(36px, 6vw, 86px);
  padding: clamp(64px, 7vw, 108px) clamp(32px, 5.6vw, 90px);
  background: #312414;
  color: #fff8ef;
}

.real-consult p {
  color: rgba(255, 248, 238, 0.72);
}

.real-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.real-form input,
.real-form select,
.real-form textarea {
  width: 100%;
  min-height: 56px;
  border: 1px solid rgba(255, 248, 238, 0.2);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff8ef;
  padding: 0 18px;
  outline: 0;
}

.real-form textarea {
  grid-column: 1 / -1;
  min-height: 128px;
  padding-top: 16px;
  resize: vertical;
}

.real-form .form-contact-note {
  grid-column: 1 / -1;
  margin: 0;
  color: rgba(255, 248, 238, 0.72);
}

.real-form .real-btn {
  grid-column: 1 / -1;
  border-color: #fff8ef;
}

.about-hero {
  min-height: 850px;
}

.about-stats {
  position: absolute;
  z-index: 5;
  left: clamp(34px, 5.6vw, 90px);
  right: clamp(34px, 5.6vw, 90px);
  bottom: clamp(34px, 4.5vw, 70px);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid rgba(255, 248, 238, 0.28);
  border-radius: 8px;
  background: rgba(31, 22, 14, 0.42);
  backdrop-filter: blur(12px);
}

.about-stats article {
  padding: 26px;
  color: #fff8ef;
  border-right: 1px solid rgba(255, 248, 238, 0.18);
}

.about-stats article:last-child {
  border-right: 0;
}

.about-stats strong {
  display: block;
  font-family: Georgia, serif;
  font-size: clamp(34px, 3.5vw, 54px);
  font-weight: 400;
}

.about-stats span {
  color: rgba(255, 248, 238, 0.76);
}

.team-grid img {
  aspect-ratio: 0.9 / 1.12;
}

.philosophy-grid article {
  position: relative;
}

.philosophy-grid span {
  display: block;
  padding: 24px 24px 0;
}

.about-process {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.about-output img {
  object-position: center;
}

.toast {
  position: fixed;
  z-index: 100;
  left: 50%;
  bottom: 28px;
  transform: translate(-50%, 22px);
  opacity: 0;
  pointer-events: none;
  border-radius: 999px;
  background: rgba(35, 26, 17, 0.92);
  color: #fff8ef;
  padding: 12px 22px;
  transition: opacity 180ms ease, transform 180ms ease;
}

.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

@media (max-width: 1120px) {
  .real-links {
    gap: 22px;
  }

  .service-real-hero,
  .cases-hero,
  .fit-section,
  .case-feature-real,
  .ai-method-section,
  .real-consult {
    grid-template-columns: 1fr;
  }

  .service-hero-image,
  .case-hero-collage {
    min-height: 480px;
    height: 520px;
    padding: 0 32px 54px;
  }

  .service-real-hero .real-hero-copy,
  .cases-hero .real-hero-copy {
    padding-right: 42px;
  }

  .service-detail-grid,
  .real-case-grid,
  .comparison-grid,
  .ai-reason-grid,
  .deliver-grid-real,
  .real-process,
  .output-grid,
  .about-process {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .split-head {
    display: grid;
  }

  .case-principle-strip {
    grid-template-columns: 1fr;
  }

  .about-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .mobile-only {
    display: block;
  }

  .real-nav {
    position: absolute;
    top: 20px;
    left: 22px;
    right: 22px;
    display: grid;
    gap: 18px;
  }

  .real-brand strong {
    font-size: 24px;
  }

  .real-links {
    gap: 13px;
    overflow-x: auto;
    padding-bottom: 6px;
    font-size: 13px;
  }

  .real-nav-cta {
    padding: 8px 16px;
  }

  .real-hero,
  .image-hero,
  .ai-hero,
  .about-hero {
    min-height: 720px;
  }

  .real-hero-copy,
  .service-real-hero .real-hero-copy,
  .cases-hero .real-hero-copy,
  .image-hero .real-hero-copy {
    width: 100%;
    max-width: 100%;
    padding: 150px 22px 48px;
  }

  .real-hero-copy h1 {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-all;
    line-break: loose;
    font-size: 36px;
  }

  .real-section h2,
  .case-feature-real h2,
  .real-cta-photo h2,
  .real-consult h2 {
    word-break: break-all;
  }

  .real-actions {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: start;
  }

  .real-section,
  .case-feature-real,
  .real-consult {
    padding-left: 22px;
    padding-right: 22px;
  }

  .service-detail-grid,
  .service-detail-card,
  .deliver-grid-real,
  .real-case-grid,
  .comparison-grid,
  .featured-article-grid,
  .article-list-real .article-row,
  .content-system-grid,
  .ai-reason-grid,
  .team-grid,
  .philosophy-grid,
  .real-process,
  .output-grid,
  .about-process,
  .real-form,
  .about-stats {
    grid-template-columns: 1fr;
  }

  .service-detail-card img {
    height: 230px;
  }

  .case-hero-collage,
  .fit-collage {
    grid-template-columns: 1fr;
    height: auto;
    min-height: 0;
  }

  .case-hero-collage img,
  .fit-collage img,
  .fit-collage img:first-child,
  .case-feature-real img {
    height: 280px;
  }

  .case-principle-strip article {
    min-height: 0;
    padding: 30px 22px;
  }

  .comparison-card div {
    padding: 20px 20px 24px;
  }

  .article-list-real .article-row {
    padding: 0 0 22px;
  }

  .article-list-real img {
    width: 100%;
    height: 240px;
  }

  .article-list-real .article-row div,
  .article-list-real b {
    padding: 0 22px;
  }

  .geo-article {
    padding-left: 22px;
    padding-right: 22px;
  }

  .article-hero-grid,
  .article-layout,
  .article-next {
    grid-template-columns: 1fr;
  }

  .article-toc {
    position: static;
  }

  .article-hero h1 {
    max-width: calc(100vw - 44px);
    overflow-wrap: anywhere;
    word-break: break-all;
    font-size: 32px;
  }

  .article-description,
  .article-meta {
    max-width: calc(100vw - 44px);
    overflow-wrap: anywhere;
  }

  .article-meta {
    display: grid;
    grid-template-columns: repeat(2, max-content);
    width: 100%;
    gap: 10px 8px;
  }

  .article-meta span,
  .article-meta time {
    max-width: 100%;
    white-space: normal;
    font-size: 14px;
    padding: 7px 12px;
  }

  .document-grid {
    grid-template-columns: 1fr;
  }

  .article-nav {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    padding: 20px 22px 0;
  }

  .article-nav .real-links {
    display: flex;
    max-width: 100%;
  }

  .article-hero {
    padding-top: 34px;
  }

  .breadcrumb {
    font-size: 13px;
  }

  .ai-problem-panel {
    position: relative;
    right: auto;
    bottom: auto;
    margin: -20px 22px 42px;
  }

  .about-stats {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    margin: -120px 22px 42px;
  }

.about-stats article {
    border-right: 0;
    border-bottom: 1px solid rgba(255, 248, 238, 0.18);
  }
}

.admin-page {
  background: #f7f2ea;
  color: #211c17;
}

.site-footer {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  padding: 22px 24px;
  border-top: 1px solid rgba(87, 65, 39, 0.12);
  background: #f7f2ea;
  color: rgba(33, 28, 23, 0.58);
  font-size: 14px;
}

.site-footer p {
  margin: 0;
}

.site-footer a {
  color: rgba(33, 28, 23, 0.68);
  text-decoration: none;
}

.site-footer a:hover {
  color: #4f3820;
}

.admin-shell {
  width: min(1180px, calc(100% - 56px));
  margin: 0 auto;
  padding: 54px 0 80px;
}

.admin-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 40px;
  align-items: end;
  padding: 42px 0 34px;
  border-bottom: 1px solid rgba(87, 65, 39, 0.2);
}

.admin-hero h1 {
  margin: 10px 0 14px;
  font-size: 52px;
  line-height: 1;
  font-weight: 500;
}

.admin-hero p {
  margin: 0;
  max-width: 580px;
  color: rgba(33, 28, 23, 0.68);
  line-height: 1.9;
}

.admin-login {
  display: grid;
  gap: 14px;
  padding: 22px;
  border: 1px solid rgba(87, 65, 39, 0.18);
  background: rgba(255, 252, 246, 0.72);
}

.admin-login label {
  display: grid;
  gap: 8px;
}

.admin-login span,
.admin-metrics span,
.admin-panel small {
  color: rgba(33, 28, 23, 0.56);
}

.admin-login input {
  width: 100%;
  border: 1px solid rgba(87, 65, 39, 0.22);
  background: #fffaf2;
  padding: 14px 16px;
  font: inherit;
}

.admin-dashboard {
  padding-top: 36px;
}

.admin-dashboard.hidden {
  display: none;
}

.admin-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin-bottom: 22px;
}

.admin-toolbar h2 {
  margin: 0;
  font-size: 30px;
  font-weight: 500;
}

.admin-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 18px;
}

.admin-metrics article,
.admin-panel {
  border: 1px solid rgba(87, 65, 39, 0.16);
  background: rgba(255, 252, 246, 0.76);
}

.admin-metrics article {
  display: grid;
  gap: 10px;
  padding: 24px;
}

.admin-metrics strong {
  font-size: 38px;
  line-height: 1;
  font-weight: 500;
}

.admin-grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 18px;
}

.admin-panel {
  min-width: 0;
  padding: 22px;
}

.admin-panel h3 {
  margin: 0 0 16px;
  font-size: 22px;
  font-weight: 500;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-panel table {
  width: 100%;
  min-width: 520px;
  border-collapse: collapse;
}

.admin-panel th,
.admin-panel td {
  padding: 13px 10px;
  border-bottom: 1px solid rgba(87, 65, 39, 0.12);
  text-align: left;
  vertical-align: top;
}

.admin-panel th {
  color: rgba(33, 28, 23, 0.55);
  font-size: 13px;
  font-weight: 500;
}

.admin-panel td {
  font-size: 14px;
  line-height: 1.5;
}

.admin-panel a {
  color: #4f3820;
  text-decoration: none;
}

.admin-panel small {
  display: block;
  margin-top: 5px;
  font-size: 12px;
}

@media (max-width: 820px) {
  .admin-shell {
    width: min(100% - 32px, 1180px);
    padding-top: 28px;
  }

  .admin-hero,
  .admin-grid,
  .admin-metrics {
    grid-template-columns: 1fr;
  }

  .admin-hero h1 {
    font-size: 38px;
  }
}
