/* ============================================================
   THE SWEIS ATELIER — inner page styles
   ============================================================ */

/* ---------- Page header (inner pages) ---------- */
.page-header {
  padding: clamp(120px, 16vw, 220px) var(--pad-x) clamp(60px, 8vw, 110px);
  background: var(--ivory);
  position: relative;
  z-index: 2;
}
.page-header__inner { max-width: var(--max); margin: 0 auto; }
.page-header__plate {
  display: flex;
  justify-content: space-between;
  margin-bottom: 36px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--rule);
}
.page-header h1 {
  font-size: clamp(54px, 8vw, 132px);
  line-height: 0.96;
  letter-spacing: -0.025em;
  font-variation-settings: "SOFT" 30, "opsz" 144;
  max-width: 14ch;
}
.page-header h1 em {
  font-style: italic;
  font-variation-settings: "SOFT" 100, "opsz" 144;
  color: var(--champagne-deep);
}
.page-header__sub {
  margin-top: 40px;
  max-width: 56ch;
  font-size: clamp(17px, 1.4vw, 21px);
  color: var(--ink-soft);
}

/* ---------- Story page ---------- */
.timeline {
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  margin-top: 60px;
}
.timeline__row {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: clamp(30px, 5vw, 80px);
  padding: 50px 0;
  border-bottom: 1px solid var(--rule);
  align-items: start;
}
.timeline__row:last-child { border-bottom: none; }
.timeline__year {
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 64px);
  font-variation-settings: "SOFT" 50;
  color: var(--champagne-deep);
  letter-spacing: -0.01em;
  line-height: 1;
}
.timeline__year em {
  display: block;
  font-style: italic;
  font-size: 14px;
  color: var(--taupe);
  margin-top: 8px;
  font-variation-settings: "SOFT" 100;
  letter-spacing: 0.04em;
}
.timeline__body h3 {
  font-family: var(--serif);
  font-size: clamp(24px, 2.4vw, 32px);
  font-variation-settings: "SOFT" 40;
  margin-bottom: 16px;
}
.timeline__body p { color: var(--ink-soft); line-height: 1.7; max-width: 64ch; }
.timeline__body p + p { margin-top: 14px; }
@media (max-width: 720px) {
  .timeline__row { grid-template-columns: 1fr; gap: 16px; }
}

/* ---------- Pull-quote ---------- */
.pullquote {
  padding: 80px var(--pad-x);
  background: var(--ivory-deep);
  text-align: center;
  position: relative;
  z-index: 2;
}
.pullquote__mark {
  font-family: var(--serif);
  font-size: 100px;
  color: var(--champagne);
  line-height: 0.5;
  font-style: italic;
  font-variation-settings: "SOFT" 100;
}
.pullquote__text {
  font-family: var(--serif);
  font-size: clamp(28px, 3.8vw, 50px);
  line-height: 1.2;
  letter-spacing: -0.018em;
  max-width: 24ch;
  margin: 30px auto 22px;
  font-variation-settings: "SOFT" 40;
  font-style: italic;
}
.pullquote__attr {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--taupe);
}

/* ---------- Designers page (full roster) ---------- */
.designers-full {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.designer-row {
  background: var(--ivory);
  padding: 44px 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  align-items: start;
  transition: background 240ms ease;
}
.designer-row:hover { background: var(--blush-soft); }
.designer-row__head { display: flex; flex-direction: column; gap: 12px; }
.designer-row__name { font-family: var(--serif); font-size: 36px; font-variation-settings: "SOFT" 50; line-height: 1.0; letter-spacing: -0.015em; }
.designer-row__house { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--taupe); }
.designer-row__sig { font-family: var(--serif); font-style: italic; font-variation-settings: "SOFT" 100; color: var(--ink-soft); line-height: 1.5; font-size: 16px; }
.designer-row__price {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--champagne-deep);
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
}
@media (max-width: 880px) { .designers-full { grid-template-columns: 1fr; } .designer-row { grid-template-columns: 1fr; } }

.designers-also {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  margin-top: 60px;
}
.designers-also__cell {
  background: var(--ivory);
  padding: 24px 18px;
  font-family: var(--serif);
  font-size: 18px;
  font-variation-settings: "SOFT" 50;
  text-align: center;
  letter-spacing: -0.01em;
}
@media (max-width: 880px) { .designers-also { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .designers-also { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Collection page ---------- */
.collection-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
.col-card {
  background: var(--ivory);
  border: 1px solid var(--rule);
  overflow: hidden;
  transition: all 240ms ease;
  display: flex;
  flex-direction: column;
}
.col-card:hover { transform: translateY(-3px); border-color: var(--ink); }
.col-card__image {
  aspect-ratio: 3/4;
  background: var(--ivory-deep);
  position: relative;
  overflow: hidden;
}
.col-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms ease; }
.col-card:hover .col-card__image img { transform: scale(1.04); }
.col-card__image::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 70%, rgba(43,29,36,0.15));
}
.col-card__body { padding: 26px 24px 28px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.col-card__num { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--taupe); }
.col-card__name { font-family: var(--serif); font-size: 26px; font-variation-settings: "SOFT" 50; line-height: 1.05; letter-spacing: -0.015em; }
.col-card__sub { font-family: var(--serif); font-style: italic; font-variation-settings: "SOFT" 100; color: var(--champagne-deep); font-size: 14px; }
.col-card__desc { font-size: 14px; line-height: 1.6; color: var(--ink-soft); }
.col-card__foot {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--champagne-deep);
}
@media (max-width: 980px) { .collection-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .collection-grid { grid-template-columns: 1fr; } }

/* ---------- Swatch wall (macro detail) ---------- */
.swatch-wall {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 18px;
  margin-top: 50px;
}
.swatch {
  aspect-ratio: 1/1;
  position: relative;
  overflow: hidden;
}
.swatch__inner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  padding: 16px;
  color: var(--ivory);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.swatch--ivory { background: linear-gradient(135deg, #FAF6EC, #E8DECB); }
.swatch--ivory .swatch__inner { color: var(--ink); }
.swatch--blush { background: linear-gradient(135deg, #F2E0DA, #D6B3A8); }
.swatch--blush .swatch__inner { color: var(--ink); }
.swatch--champagne { background: linear-gradient(135deg, #E0C68C, #A88858); }
.swatch--gold { background: linear-gradient(135deg, #D4B26A, #8E6F3A); }
.swatch--mocha { background: linear-gradient(135deg, #8D7C6E, #5C4F44); }
.swatch--ink { background: linear-gradient(135deg, #2A2622, #14110F); }
.swatch--lace {
  background:
    radial-gradient(circle at 30% 30%, transparent 6px, rgba(43,29,36,0.06) 7px, transparent 8px),
    radial-gradient(circle at 70% 70%, transparent 6px, rgba(43,29,36,0.06) 7px, transparent 8px),
    radial-gradient(circle at 50% 50%, transparent 4px, rgba(43,29,36,0.04) 5px, transparent 6px),
    linear-gradient(135deg, #FAF6EC, #E8DECB);
  background-size: 24px 24px, 24px 24px, 18px 18px, 100% 100%;
}
.swatch--lace .swatch__inner { color: var(--ink); }
.swatch--beading {
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,0.6) 2px, transparent 3px),
    radial-gradient(circle at 25% 25%, rgba(255,255,255,0.4) 1.5px, transparent 2.5px),
    radial-gradient(circle at 75% 75%, rgba(255,255,255,0.4) 1.5px, transparent 2.5px),
    linear-gradient(135deg, #E0C68C, #A88858);
  background-size: 16px 16px, 16px 16px, 16px 16px, 100% 100%;
}
.swatch--silk {
  background: linear-gradient(45deg, #FAF6EC 0%, #EDE4D3 50%, #FAF6EC 100%);
  background-size: 200% 200%;
}
.swatch--tulle {
  background:
    repeating-linear-gradient(45deg, transparent, transparent 2px, rgba(43,29,36,0.04) 2px, rgba(43,29,36,0.04) 3px),
    repeating-linear-gradient(-45deg, transparent, transparent 2px, rgba(43,29,36,0.04) 2px, rgba(43,29,36,0.04) 3px),
    linear-gradient(135deg, #F2E0DA, #E8DECB);
}
.swatch--tulle .swatch__inner { color: var(--ink); }
.swatch--crepe { background: linear-gradient(135deg, #EDE4D3, #C8B89E); }
.swatch--crepe .swatch__inner { color: var(--ink); }
.swatch--mikado { background: linear-gradient(135deg, #FAF6EC, #D6C8AE); }
.swatch--mikado .swatch__inner { color: var(--ink); }
@media (max-width: 880px) { .swatch-wall { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 540px) { .swatch-wall { grid-template-columns: repeat(3, 1fr); gap: 10px; } }

/* ---------- Appointment page ---------- */
.appt-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--rule);
  margin-top: 50px;
}
.appt-form {
  padding: 60px 50px;
  background: var(--ivory);
}
.appt-form h3 {
  font-family: var(--serif);
  font-size: 30px;
  font-variation-settings: "SOFT" 40;
  margin-bottom: 30px;
}
.appt-form__row { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.appt-form__row.split { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.appt-form__row.split > div { display: flex; flex-direction: column; gap: 8px; }
.appt-form label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--taupe);
}
.appt-form input,
.appt-form select,
.appt-form textarea {
  font-family: var(--sans);
  font-size: 16px;
  padding: 12px 14px;
  border: 1px solid var(--rule-strong);
  background: var(--ivory);
  color: var(--ink);
  border-radius: 0;
}
.appt-form input:focus,
.appt-form select:focus,
.appt-form textarea:focus {
  outline: 2px solid var(--champagne);
  outline-offset: -1px;
}
.appt-form textarea { resize: vertical; min-height: 110px; }
.appt-form button[type="submit"] {
  margin-top: 14px;
  background: var(--ink);
  color: var(--ivory);
  padding: 16px 28px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  transition: background 240ms ease;
}
.appt-form button[type="submit"]:hover { background: var(--champagne-deep); }
.appt-form__note {
  margin-top: 16px;
  font-size: 12px;
  color: var(--taupe);
  line-height: 1.6;
  font-style: italic;
  font-family: var(--serif);
  font-variation-settings: "SOFT" 100;
}

.appt-card {
  background: var(--ink);
  color: var(--ivory);
  padding: 60px 50px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.appt-card h3 {
  font-family: var(--serif);
  font-size: 30px;
  font-variation-settings: "SOFT" 40;
  color: var(--ivory);
}
.appt-card__row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 20px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(251,246,239,0.18);
  align-items: baseline;
}
.appt-card__row:last-child { border-bottom: none; }
.appt-card__row .k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--champagne); }
.appt-card__row .v { font-family: var(--serif); font-size: 19px; font-variation-settings: "SOFT" 50; color: var(--ivory); }

@media (max-width: 880px) {
  .appt-split { grid-template-columns: 1fr; }
  .appt-form, .appt-card { padding: 40px 28px; }
  .appt-form__row.split { grid-template-columns: 1fr; }
}

/* ---------- Visit page (full) ---------- */
.visit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--rule);
}
.visit-grid__info {
  padding: 60px 50px;
  background: var(--ivory);
}
.visit-grid__map {
  min-height: 560px;
  background: var(--ivory-deep);
}
.visit-grid__map iframe { width: 100%; height: 100%; min-height: 560px; border: 0; filter: grayscale(40%) contrast(0.95); }
.hours-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 30px;
}
.hours-table tr { border-bottom: 1px solid var(--rule); }
.hours-table tr:last-child { border-bottom: none; }
.hours-table td {
  padding: 14px 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.hours-table td:first-child { color: var(--taupe); width: 70px; }
.hours-table td:last-child { text-align: right; color: var(--ink); }
.hours-table tr.closed td:last-child { color: var(--champagne-deep); font-style: italic; }
@media (max-width: 880px) {
  .visit-grid { grid-template-columns: 1fr; }
  .visit-grid__info { padding: 40px 28px; }
}

/* ---------- 404 ---------- */
.four-oh-four {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 120px var(--pad-x);
  background: var(--ivory);
}
.four-oh-four__inner { max-width: 600px; }
.four-oh-four h1 {
  font-size: clamp(80px, 14vw, 200px);
  line-height: 0.85;
  letter-spacing: -0.03em;
  font-variation-settings: "SOFT" 30;
  margin-bottom: 24px;
}
.four-oh-four h1 em { color: var(--champagne-deep); font-style: italic; font-variation-settings: "SOFT" 100; }
.four-oh-four p { color: var(--ink-soft); margin-bottom: 30px; font-size: 17px; }
