:root {
  --ink: #243246;
  --muted: #6d7b8d;
  --line: rgba(36, 50, 70, 0.12);
  --paper: #fffaf7;
  --white: #ffffff;
  --mint: #7de2cf;
  --aqua: #9ee9f2;
  --pink: #ff93bd;
  --peach: #ffd3a6;
  --butter: #ffe48e;
  --lavender: #d8c8ff;
  --shadow: 0 24px 70px rgba(36, 50, 70, 0.14);
  --soft-shadow: 0 14px 38px rgba(36, 50, 70, 0.10);
  --radius-xl: 34px;
  --radius-lg: 24px;
  --radius-md: 16px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.55;
  background:
    radial-gradient(circle at 8% 0%, rgba(125, 226, 207, 0.28), transparent 28rem),
    radial-gradient(circle at 93% 6%, rgba(255, 147, 189, 0.26), transparent 24rem),
    linear-gradient(180deg, #fffaf7 0%, #f9fffb 42%, #fff8fb 100%);
}

body.modal-open { overflow: hidden; }

img { max-width: 100%; display: block; }

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

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

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.4rem;
  padding: 1rem clamp(1rem, 4vw, 3.2rem);
  background: rgba(255, 250, 247, 0.82);
  border-bottom: 1px solid rgba(36, 50, 70, 0.08);
  backdrop-filter: blur(20px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 220px;
}

.brand img { width: 68px; height: auto; }
.brand strong { display: block; font-family: Georgia, "Times New Roman", serif; font-size: 1.15rem; letter-spacing: 0.04em; }
.brand small { color: var(--muted); font-size: 0.77rem; }

.main-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.4rem;
}

.main-nav a, .nav-message {
  border: 0;
  border-radius: 999px;
  padding: 0.72rem 1rem;
  color: #34445a;
  background: transparent;
  cursor: pointer;
  transition: 0.2s ease;
}

.main-nav a:hover, .nav-message:hover {
  background: rgba(125, 226, 207, 0.20);
  transform: translateY(-1px);
}

.nav-message {
  color: var(--ink);
  background: linear-gradient(135deg, rgba(125, 226, 207, 0.6), rgba(255, 147, 189, 0.5));
  box-shadow: 0 10px 24px rgba(255, 147, 189, 0.18);
}

.hero {
  width: min(1220px, calc(100% - 2rem));
  margin: 2rem auto 1.4rem;
  min-height: 650px;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(340px, 0.98fr);
  align-items: center;
  gap: clamp(1.4rem, 4vw, 4rem);
  padding: clamp(1.4rem, 4vw, 3.8rem);
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 48px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.83), rgba(255, 255, 255, 0.48)),
    radial-gradient(circle at top right, rgba(255, 147, 189, 0.30), transparent 20rem),
    radial-gradient(circle at bottom left, rgba(125, 226, 207, 0.36), transparent 24rem);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.hero-copy { max-width: 650px; }

.eyebrow {
  margin: 0 0 0.8rem;
  color: #168a7f;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.hero h1, .section-heading h2, .story-strip h2, .edit h2, .product-detail h1, .related-products h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.03;
  letter-spacing: -0.045em;
}

.hero h1 { font-size: clamp(3rem, 7.4vw, 6.8rem); }
.hero-lede { margin: 1.4rem 0 0; max-width: 590px; color: #526176; font-size: clamp(1rem, 1.5vw, 1.24rem); }

.hero-actions, .detail-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.8rem;
  margin: 2rem 0;
}

.primary-button, .secondary-button, .mini-button, .text-button, .reset-link {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border-radius: 999px;
  border: 0;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.primary-button {
  min-height: 48px;
  padding: 0.9rem 1.28rem;
  color: #182434;
  font-weight: 800;
  background: linear-gradient(135deg, var(--mint), var(--pink) 58%, var(--butter));
  box-shadow: 0 14px 34px rgba(255, 147, 189, 0.25);
}

.secondary-button {
  min-height: 48px;
  padding: 0.86rem 1.22rem;
  color: #30425a;
  font-weight: 750;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid var(--line);
}

.primary-button:hover, .secondary-button:hover, .mini-button:hover, .text-button:hover, .reset-link:hover {
  transform: translateY(-2px);
}

.hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.hero-stats span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.7rem 0.86rem;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.70);
  color: var(--muted);
}

.hero-stats strong { color: var(--ink); }

.hero-showcase {
  position: relative;
  min-height: 560px;
}

.showcase-card {
  position: absolute;
  display: block;
  width: min(360px, 74vw);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 36px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: var(--soft-shadow);
  backdrop-filter: blur(12px);
  transition: 0.25s ease;
}

.showcase-card:hover { transform: translateY(-7px) rotate(0deg) scale(1.01); }
.showcase-card img { aspect-ratio: 1.32 / 1; object-fit: cover; width: 100%; }
.showcase-card span, .showcase-card strong { display: block; padding-inline: 1rem; }
.showcase-card span { padding-top: 0.9rem; color: #43536a; font-weight: 750; }
.showcase-card strong { padding-bottom: 1rem; font-size: 1.28rem; }
.showcase-card-1 { top: 0; left: 10%; transform: rotate(-5deg); }
.showcase-card-2 { top: 180px; right: -1%; transform: rotate(5deg); }
.showcase-card-3 { bottom: 8px; left: 0; transform: rotate(-2deg); }

.flash {
  width: min(1120px, calc(100% - 2rem));
  margin: 1rem auto 0;
  padding: 1rem 1.2rem;
  border-radius: 20px;
  box-shadow: var(--soft-shadow);
}
.flash.success { background: rgba(155, 231, 198, 0.42); border: 1px solid rgba(34, 148, 116, 0.18); }
.flash.error { background: rgba(255, 147, 189, 0.25); border: 1px solid rgba(204, 62, 106, 0.18); }

.story-strip, .edit, .collection, .related-products {
  width: min(1220px, calc(100% - 2rem));
  margin: 1.4rem auto;
}

.story-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.story-strip article, .edit, .collection, .related-products, .empty-state {
  border: 1px solid rgba(255, 255, 255, 0.80);
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.64);
  box-shadow: var(--soft-shadow);
  backdrop-filter: blur(14px);
}

.story-strip article {
  padding: clamp(1.2rem, 3vw, 2rem);
  opacity: 0;
  transform: translateY(12px);
  transition: 0.5s ease;
}
.story-strip article.is-visible { opacity: 1; transform: none; }
.story-strip h2 { font-size: clamp(1.8rem, 3vw, 2.8rem); }
.story-strip p:last-child { color: var(--muted); margin-bottom: 0; }

.edit { padding: clamp(1.2rem, 3vw, 2.4rem); }
.edit h2, .section-heading h2, .related-products h2 { font-size: clamp(2rem, 4vw, 3.7rem); }
.edit-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.4rem;
}
.edit-grid article {
  padding: 1.25rem;
  border: 1px solid var(--line);
  border-radius: 26px;
  background: linear-gradient(135deg, rgba(255,255,255,0.86), rgba(255,255,255,0.46));
  opacity: 0;
  transform: translateY(12px);
  transition: 0.5s ease;
}
.edit-grid article.is-visible { opacity: 1; transform: none; }
.edit-grid span { display: inline-flex; color: #168a7f; font-weight: 900; margin-bottom: 0.7rem; }
.edit-grid h3 { margin: 0 0 0.45rem; font-size: 1.25rem; }
.edit-grid p { margin: 0; color: var(--muted); }

.collection, .related-products { padding: clamp(1.2rem, 3vw, 2.3rem); }
.section-heading { display: flex; flex-wrap: wrap; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 1.2rem; }
.section-heading p:not(.eyebrow) { margin: 0; color: var(--muted); max-width: 520px; }

.filters {
  display: grid;
  grid-template-columns: minmax(180px, 1.5fr) minmax(150px, 1fr) minmax(150px, 1fr) auto auto;
  align-items: end;
  gap: 0.8rem;
  margin: 1.2rem 0 1rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.58);
}

.filters label, .message-form label {
  display: grid;
  gap: 0.38rem;
  color: #4a5a70;
  font-size: 0.84rem;
  font-weight: 800;
}

input, select, textarea {
  width: 100%;
  border: 1px solid rgba(36, 50, 70, 0.14);
  border-radius: 16px;
  padding: 0.86rem 0.92rem;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.86);
  outline: none;
  transition: 0.2s ease;
}

input:focus, select:focus, textarea:focus {
  border-color: rgba(22, 138, 127, 0.42);
  box-shadow: 0 0 0 4px rgba(125, 226, 207, 0.22);
}

.reset-link {
  min-height: 48px;
  padding: 0.75rem 0.9rem;
  color: var(--muted);
  background: rgba(255,255,255,0.5);
}

.category-pills {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 1rem;
}
.category-pills a {
  flex: 0 0 auto;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0.62rem 0.9rem;
  color: #46576e;
  background: rgba(255, 255, 255, 0.62);
  transition: 0.2s ease;
}
.category-pills a:hover, .category-pills a.active {
  color: #1e2a3a;
  background: linear-gradient(135deg, rgba(125, 226, 207, 0.48), rgba(255, 147, 189, 0.36));
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.compact-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.product-card {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.80);
  box-shadow: 0 12px 30px rgba(36, 50, 70, 0.08);
  transition: 0.25s ease;
  opacity: 0;
  transform: translateY(12px);
}
.product-card.is-visible { opacity: 1; transform: none; }
.product-card:hover { transform: translateY(-7px); box-shadow: 0 20px 42px rgba(36, 50, 70, 0.13); }
.product-image { display: block; overflow: hidden; background: #f7fbff; }
.product-image img { width: 100%; aspect-ratio: 1.18 / 1; object-fit: cover; transition: 0.35s ease; }
.product-card:hover .product-image img { transform: scale(1.035); }
.product-info { display: grid; gap: 0.7rem; padding: 1rem; }
.product-meta { display: flex; justify-content: space-between; gap: 0.5rem; color: #6c788a; font-size: 0.78rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.07em; }
.product-info h3 { margin: 0; font-family: Georgia, "Times New Roman", serif; font-size: 1.32rem; letter-spacing: -0.02em; line-height: 1.16; }
.product-info h3 a:hover { color: #168a7f; }
.product-info p { min-height: 4.6em; margin: 0; color: var(--muted); font-size: 0.94rem; }
.product-bottom { display: flex; justify-content: space-between; align-items: center; gap: 0.8rem; padding-top: 0.25rem; }
.product-bottom strong { font-size: 1.14rem; }
.mini-button { padding: 0.55rem 0.78rem; color: #263548; font-weight: 800; background: rgba(125, 226, 207, 0.28); }

.empty-state {
  padding: 2rem;
  text-align: center;
}
.page-empty { width: min(720px, calc(100% - 2rem)); margin: 3rem auto; }

.product-detail {
  width: min(1180px, calc(100% - 2rem));
  margin: 2rem auto;
  display: grid;
  grid-template-columns: minmax(320px, 0.98fr) minmax(320px, 1.02fr);
  gap: clamp(1rem, 4vw, 3rem);
  align-items: center;
  padding: clamp(1.1rem, 3vw, 2rem);
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 42px;
  background: rgba(255, 255, 255, 0.65);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
}
.detail-image-wrap {
  overflow: hidden;
  border-radius: 34px;
  box-shadow: var(--soft-shadow);
}
.detail-image { width: 100%; aspect-ratio: 1.06 / 1; object-fit: cover; }
.breadcrumb { display: inline-flex; margin-bottom: 1rem; color: #168a7f; font-weight: 800; }
.product-detail h1 { font-size: clamp(2.6rem, 5vw, 5.2rem); }
.detail-summary { color: var(--muted); font-size: 1.1rem; }
.detail-price { display: block; margin: 1rem 0 0; font-size: 2rem; }
.detail-text { color: #526176; }
.spec-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
  margin: 1.2rem 0;
}
.spec-list div {
  padding: 0.86rem;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,0.64);
}
.spec-list dt { color: var(--muted); font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 900; }
.spec-list dd { margin: 0.2rem 0 0; font-weight: 760; }
.feature-list { display: flex; flex-wrap: wrap; gap: 0.55rem; }
.feature-list span {
  border-radius: 999px;
  padding: 0.55rem 0.72rem;
  background: rgba(255, 147, 189, 0.18);
  color: #5a3851;
  font-weight: 800;
  font-size: 0.85rem;
}


.page-hero, .page-section, .lookbook-grid, .faq-list, .contact-grid, .notice-bar {
  width: min(1120px, calc(100% - 2rem));
  margin: 1.4rem auto;
}

.page-hero {
  padding: clamp(1.6rem, 4vw, 4rem);
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 44px;
  background:
    radial-gradient(circle at 0 0, rgba(125, 226, 207, 0.32), transparent 24rem),
    radial-gradient(circle at 100% 10%, rgba(255, 147, 189, 0.24), transparent 22rem),
    rgba(255, 255, 255, 0.68);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
}
.page-hero h1, .page-section h2, .lookbook-card h2, .contact-card h2, .policy-card h2, .faq-item h2, .text-page h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.06;
  letter-spacing: -0.035em;
}
.page-hero h1 { max-width: 930px; font-size: clamp(2.7rem, 6vw, 5.8rem); }
.page-hero p:last-child { max-width: 760px; color: #526176; font-size: 1.12rem; }
.compact-page-hero h1 { max-width: 780px; font-size: clamp(2.4rem, 4.8vw, 4.6rem); }

.page-section {
  padding: clamp(1.2rem, 3vw, 2.3rem);
  border: 1px solid rgba(255, 255, 255, 0.80);
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.64);
  box-shadow: var(--soft-shadow);
  backdrop-filter: blur(14px);
}
.split-panel, .two-column-section {
  display: grid;
  grid-template-columns: minmax(240px, 0.88fr) minmax(280px, 1.12fr);
  gap: clamp(1rem, 4vw, 3rem);
  align-items: start;
}
.page-section h2 { font-size: clamp(2rem, 4vw, 3.8rem); }
.page-section p { color: var(--muted); }
.feature-cards, .policy-grid, .timeline, .note-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.policy-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.timeline { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.note-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.reveal-card, .policy-card, .timeline div, .faq-item, .contact-card, .contact-form {
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(255,255,255,0.72);
  box-shadow: 0 12px 30px rgba(36, 50, 70, 0.07);
}
.reveal-card, .policy-card, .timeline div { padding: 1.2rem; opacity: 0; transform: translateY(12px); transition: 0.5s ease; }
.reveal-card.is-visible, .policy-card.is-visible, .timeline div.is-visible { opacity: 1; transform: none; }
.reveal-card span, .timeline strong { color: #168a7f; font-weight: 900; letter-spacing: 0.08em; }
.reveal-card h3, .timeline h3 { margin: 0.65rem 0 0.35rem; }
.reveal-card p, .policy-card p, .timeline p { margin-bottom: 0; color: var(--muted); }

.lookbook-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.lookbook-card {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 34px;
  background: rgba(255,255,255,0.72);
  box-shadow: var(--soft-shadow);
  opacity: 0;
  transform: translateY(12px);
  transition: 0.5s ease;
}
.lookbook-card.is-visible { opacity: 1; transform: none; }
.lookbook-card img { width: 100%; aspect-ratio: 1.35 / 1; object-fit: cover; }
.lookbook-card div { padding: 1.2rem; }
.lookbook-card h2 { font-size: clamp(1.7rem, 3vw, 2.6rem); }
.lookbook-card p:not(.eyebrow) { color: var(--muted); }

.faq-list { display: grid; gap: 0.8rem; }
.faq-item { padding: 1.25rem; opacity: 0; transform: translateY(12px); transition: 0.5s ease; }
.faq-item.is-visible { opacity: 1; transform: none; }
.faq-item h2 { font-size: clamp(1.35rem, 2.2vw, 2rem); }
.faq-item p { margin-bottom: 0; color: var(--muted); }
.faq-item code, .text-page code { background: rgba(125,226,207,0.18); border-radius: 7px; padding: 0.1rem 0.35rem; }

.contact-grid {
  display: grid;
  grid-template-columns: minmax(260px, 0.85fr) minmax(320px, 1.15fr);
  gap: 1rem;
  align-items: start;
}
.contact-card, .contact-form { padding: clamp(1.2rem, 3vw, 2rem); }
.contact-card p { color: var(--muted); }
.contact-form { display: grid; gap: 0.8rem; }
.contact-form label { display: grid; gap: 0.38rem; color: #4a5a70; font-size: 0.84rem; font-weight: 800; }

.notice-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
  padding: 1rem 1.2rem;
  border: 1px solid rgba(255,255,255,0.82);
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(125,226,207,0.32), rgba(255,147,189,0.18), rgba(255,228,142,0.22));
  box-shadow: var(--soft-shadow);
}
.notice-bar span { color: #526176; }

.text-page { max-width: 880px; }
.text-page h2 { margin-top: 1.6rem; font-size: clamp(1.5rem, 3vw, 2.4rem); }
.text-page h2:first-child { margin-top: 0; }
.text-page p { color: var(--muted); }

.site-footer {
  width: min(1220px, calc(100% - 2rem));
  margin: 1.4rem auto 2rem;
}
.footer-card {
  display: grid;
  grid-template-columns: 1.35fr repeat(3, minmax(150px, 0.8fr));
  gap: 1rem;
  padding: clamp(1.2rem, 3vw, 2rem);
  border-radius: 34px;
  border: 1px solid rgba(255, 255, 255, 0.80);
  background: linear-gradient(135deg, rgba(255,255,255,0.76), rgba(255,255,255,0.48));
  box-shadow: var(--soft-shadow);
}
.footer-logo { width: 180px; margin-bottom: 0.8rem; }
.footer-card h3 { margin: 0 0 0.6rem; }
.footer-card p { margin-top: 0; color: var(--muted); }
.footer-links { display: grid; align-content: start; gap: 0.45rem; }
.footer-links a { color: #526176; font-weight: 750; }
.footer-links a:hover, .copyright a:hover { color: #168a7f; }
.text-button {
  padding: 0.75rem 1rem;
  color: #263548;
  font-weight: 850;
  background: rgba(125, 226, 207, 0.32);
}
.copyright { color: var(--muted); text-align: center; }

.floating-message {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 50;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 52px;
  border: 0;
  border-radius: 999px;
  padding: 0.85rem 1.1rem;
  color: #172536;
  font-weight: 900;
  background: linear-gradient(135deg, var(--mint), var(--pink) 60%, var(--butter));
  box-shadow: 0 18px 36px rgba(36, 50, 70, 0.22);
  cursor: pointer;
}
.floating-message span { display: grid; place-items: center; width: 24px; height: 24px; border-radius: 999px; background: rgba(255,255,255,0.65); }

.message-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
}
.message-modal[aria-hidden="false"] { display: block; }
.message-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(23, 31, 45, 0.46);
  backdrop-filter: blur(7px);
}
.message-panel {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(560px, calc(100% - 1.6rem));
  max-height: min(88vh, 780px);
  overflow: auto;
  padding: clamp(1.2rem, 4vw, 2rem);
  border: 1px solid rgba(255,255,255,0.8);
  border-radius: 34px;
  background:
    radial-gradient(circle at 0 0, rgba(125,226,207,0.34), transparent 18rem),
    radial-gradient(circle at 100% 0, rgba(255,147,189,0.26), transparent 18rem),
    #fffaf7;
  box-shadow: 0 30px 90px rgba(20, 28, 40, 0.32);
}
.modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,0.8);
  color: #263548;
  font-size: 1.6rem;
  cursor: pointer;
}
.message-panel h2 { margin: 0; font-family: Georgia, "Times New Roman", serif; font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; }
.message-panel p { color: var(--muted); }
.message-form { display: grid; gap: 0.78rem; }
.message-form textarea { resize: vertical; }

@media (max-width: 1100px) {
  .product-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .hero { grid-template-columns: 1fr; }
  .hero-showcase { min-height: 430px; }
  .showcase-card { width: min(320px, 58vw); }
  .showcase-card-1 { left: 0; }
  .showcase-card-2 { top: 88px; right: 0; }
  .showcase-card-3 { left: 22%; }
}

@media (max-width: 840px) {
  .site-header { align-items: flex-start; flex-direction: column; }
  .main-nav { justify-content: flex-start; }
  .hero { border-radius: 34px; min-height: unset; }
  .hero-showcase { display: grid; grid-template-columns: 1fr; gap: 1rem; min-height: unset; }
  .showcase-card { position: static; width: 100%; transform: none; }
  .story-strip, .edit-grid, .product-detail, .footer-card, .split-panel, .two-column-section, .policy-grid, .timeline, .contact-grid { grid-template-columns: 1fr; }
  .filters { grid-template-columns: 1fr; }
  .product-grid, .compact-grid, .lookbook-grid, .feature-cards, .note-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .spec-list { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .brand img { width: 58px; }
  .main-nav a, .nav-message { padding: 0.58rem 0.78rem; }
  .hero h1 { font-size: 2.65rem; }
  .product-grid, .compact-grid, .lookbook-grid, .feature-cards, .note-grid { grid-template-columns: 1fr; }
  .floating-message { left: 1rem; justify-content: center; }
  .product-info p { min-height: auto; }
}
