/* Psico — stylesheet
   Reads CSS vars (--bg, --surface, --ink, --mute, --line, --accent, --accent-ink, --soft,
   --f-display, --f-body, --f-mono) set by ThemeStyle in app.jsx.
*/

*, *::before, *::after { box-sizing: border-box; }
html, body {
  margin: 0;
  padding: 0;
  max-width: 100%;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }

html {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { background: var(--bg); color: var(--ink); }

::selection { background: var(--accent); color: var(--accent-ink); }

.ps-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ── Typography ─────────────────────────────────────────────────────────── */

.ps-h1 {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(44px, 7vw, 96px);
  line-height: 1.02;
  letter-spacing: -0.018em;
  margin: 0 0 28px;
  text-wrap: balance;
  color: var(--ink);
}

.ps-h2 {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(36px, 5.4vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.012em;
  margin: 0;
  text-wrap: balance;
  color: var(--ink);
}

.ps-h3 {
  font-family: var(--f-body);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.3;
  letter-spacing: -0.005em;
  margin: 0 0 8px;
  color: var(--ink);
}

.ps-p {
  font-size: 17px;
  line-height: 1.55;
  color: var(--mute);
  margin: 0 0 12px;
  text-wrap: pretty;
}
.ps-p:last-child { margin-bottom: 0; }

.ps-lede {
  font-size: 19px;
  line-height: 1.5;
  color: var(--mute);
  max-width: 56ch;
  margin: 0 0 32px;
  text-wrap: pretty;
}

.ps-eyebrow {
  font-family: var(--f-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 18px;
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */

.ps-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--f-body);
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  padding: 14px 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s;
  white-space: nowrap;
}
.ps-btn:active { transform: translateY(1px); }

.ps-btn-primary {
  background: var(--accent);
  color: var(--accent-ink);
}
.ps-btn-primary:hover { background: color-mix(in oklab, var(--accent) 88%, black); }

.ps-btn-ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--line);
}
.ps-btn-ghost:hover { border-color: var(--ink); }

.ps-btn-sm { font-size: 14px; padding: 10px 16px; }
.ps-btn-wide { width: 100%; padding: 16px 22px; }

/* CTA variant for use on the accent block in the header. Inverts: light fill,
   accent text. */
.ps-btn-onaccent {
  background: var(--accent-ink);
  color: var(--accent);
}
.ps-btn-onaccent:hover {
  background: color-mix(in oklab, var(--accent-ink) 92%, white);
}

/* ── Header ──────────────────────────────────────────────────────────────
   Two-tone band across the top. Cream zone holds the logo on the left,
   brick accent block holds nav + lang + CTA on the right. Hard edge meets
   at the logo wordmark. Header is solid (not transparent) so ambient blobs
   underneath never bleed through. */

.ps-header {
  padding: 0;
  margin: 0 -32px;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
}

.ps-header-classic {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: stretch;
  min-height: 88px;
}
.ps-header-cream {
  display: flex;
  align-items: center;
  padding: 0 28px 0 32px;
  background: var(--bg);
}
.ps-header-block {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 0 28px;
  background: var(--accent);
  color: var(--accent-ink);
}
/* Divider between nav group and utils group inside the brick block. */
.ps-header-divider {
  display: inline-block;
  width: 1px;
  align-self: stretch;
  margin: 18px 0;
  background: color-mix(in oklab, var(--accent-ink) 35%, transparent);
}
.ps-header-block .ps-nav a {
  color: var(--accent-ink);
}
.ps-header-block .ps-nav a::after {
  background: var(--accent-ink);
}
.ps-header-block .ps-nav a:hover {
  color: var(--accent-ink);
}
.ps-header-block .ps-lang {
  color: var(--accent-ink);
}
.ps-header-block .ps-lang-sep,
.ps-header-block .ps-lang-alt {
  color: color-mix(in oklab, var(--accent-ink) 60%, var(--accent));
}
.ps-header-block .ps-lang:hover {
  background: color-mix(in oklab, var(--accent-ink) 12%, transparent);
}

.ps-header-centered {
  padding: 22px 32px;
  margin: 0 -32px;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 18px;
}
.ps-header-row-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

.ps-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--ink);
}
.ps-logo-mark {
  width: 36px;
  height: 36px;
  background: url("logo-mark.png") center / contain no-repeat;
  flex-shrink: 0;
}
.ps-logo-mark-sm { width: 22px; height: 22px; }
.ps-logo-name {
  font-family: var(--f-display);
  font-size: 22px;
  letter-spacing: -0.01em;
  line-height: 1;
}
.ps-logo-role {
  display: inline-block;
  margin-left: 8px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  border-left: 1px solid var(--line);
  padding-left: 12px;
}
.ps-header-centered .ps-logo-role { display: none; }

.ps-nav {
  display: flex;
  justify-content: center;
  gap: 24px;
}
.ps-nav a { white-space: nowrap; }
.ps-nav-centered { gap: 36px; }
.ps-nav a {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: 0.005em;
}
.ps-nav a:hover { color: var(--accent); }

/* Subtle hairline separators between nav items. Sit at the midpoint of the
   flex gap so the spacing rhythm is preserved. Use currentColor-ish tint so
   the divider tone adapts to both the cream and the brick header blocks. */
.ps-nav a + a::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  width: 1px;
  height: 12px;
  transform: translateY(-50%);
  background: color-mix(in oklab, var(--ink) 22%, transparent);
  pointer-events: none;
}
.ps-nav-centered a + a::before { left: -18px; }
.ps-header-block .ps-nav a + a::before {
  background: color-mix(in oklab, var(--accent-ink) 32%, transparent);
}

.ps-header-utils {
  display: flex;
  align-items: center;
  gap: 14px;
  justify-content: flex-end;
}

.ps-lang {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: transparent;
  border: none;
  font-family: var(--f-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--ink);
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
}
.ps-lang:hover { background: var(--soft); }
.ps-lang-sep { color: var(--mute); }
.ps-lang-alt { color: var(--mute); }

/* ── Hero ────────────────────────────────────────────────────────────────── */

.ps-hero {
  position: relative;
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 64px;
  padding: 64px 0 144px;
  align-items: center;
}
.ps-hero-text { min-width: 0; }
.ps-hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}
.ps-hero-media {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ps-hero-media image-slot {
  border-radius: 2px;
  overflow: hidden;
  background: var(--soft);
}
.ps-hero-media-caption {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mute);
}
.ps-hero-photo {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: var(--soft);
}

/* Hero abstract shape — visible accent circle behind the photo column,
   positioned away from the (now opaque) header so it never bleeds upward.
   Parallaxes downward as you scroll. */
.ps-hero-shape {
  position: absolute;
  top: -4vh;
  right: -14vw;
  width: 46vmin;
  height: 46vmin;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.2;
  filter: blur(24px);
  pointer-events: none;
  transform: translate3d(0, calc(var(--scroll-y, 0px) * 0.45), 0);
  will-change: transform;
  z-index: 0;
}

/* image-slot empty state matches surface tone */
image-slot {
  --is-bg: var(--soft);
  --is-fg: var(--mute);
}

/* ── Sections ────────────────────────────────────────────────────────────── */

.ps-section {
  padding: 128px 0;
  border-top: 1px solid var(--line);
}
.ps-section-soft {
  background: var(--surface);
  margin: 0 -32px;
  padding-left: 32px;
  padding-right: 32px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.ps-section-head {
  max-width: 760px;
  margin: 0 0 80px;
}
.ps-section-note {
  font-size: 15px;
  color: var(--mute);
  margin-top: 16px;
  max-width: 60ch;
}

/* ── About ───────────────────────────────────────────────────────────────── */

.ps-about-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 64px;
  align-items: start;
}
.ps-about-body .ps-p {
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  margin-bottom: 18px;
}

.ps-credentials {
  margin: 0;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
}
.ps-cred-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.ps-cred-row:last-child { border-bottom: none; }
.ps-cred-row:first-child { padding-top: 0; }
.ps-cred-row dt {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  align-self: center;
}
.ps-cred-row dd {
  margin: 0;
  font-size: 15px;
  color: var(--ink);
}

/* ── Approach ────────────────────────────────────────────────────────────── */

.ps-approach-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
}
.ps-approach-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  padding: 36px 32px;
  background: var(--surface);
}
.ps-approach-num {
  font-family: var(--f-display);
  font-size: 28px;
  color: var(--accent);
  line-height: 1;
}
.ps-approach-body .ps-p { color: var(--mute); }

/* ── Services ────────────────────────────────────────────────────────────── */

.ps-services-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.ps-service {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 28px;
  transition: border-color 0.15s, transform 0.15s;
}
.ps-service:hover { border-color: var(--accent); }
.ps-service-head { margin-bottom: 12px; }
.ps-service-dur {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
}
.ps-service-desc { flex: 1; margin-bottom: 20px; font-size: 15px; }
.ps-service-foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.ps-price { display: flex; flex-direction: column; gap: 4px; }
.ps-price-num {
  font-family: var(--f-display);
  font-size: 32px;
  line-height: 1;
  color: var(--ink);
}
.ps-price-unit {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
}

/* ── Booking ─────────────────────────────────────────────────────────────── */

.ps-booking-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 32px;
  align-items: start;
}
.ps-booking-main {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 32px;
}
.ps-booking-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.ps-booking-col { min-width: 0; }

.ps-step-label {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.ps-step-divider {
  margin: 32px 0 24px;
  border-top: 1px solid var(--line);
}

/* Service picker */
.ps-service-picker { margin-bottom: 32px; }
.ps-field-label {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 10px;
}
.ps-service-chips {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
}
.ps-service-chip {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  text-align: left;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 12px 14px;
  font: inherit;
  color: var(--ink);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}
.ps-service-chip:hover { border-color: var(--ink); }
.ps-service-chip-active {
  border-color: var(--accent);
  background: var(--soft);
}
.ps-service-chip-name { font-size: 14px; font-weight: 500; }
.ps-service-chip-price {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--mute);
}

/* Calendar */
.ps-cal { user-select: none; }
.ps-cal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.ps-cal-title {
  font-family: var(--f-display);
  font-size: 22px;
  letter-spacing: -0.01em;
}
.ps-cal-nav {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: #ffffff;
  color: var(--ink);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ps-cal-nav:hover:not(:disabled) { border-color: var(--ink); }
.ps-cal-nav:disabled { opacity: 0.3; cursor: not-allowed; }

.ps-cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 8px;
}
.ps-cal-weekdays div {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  text-align: center;
  padding: 4px 0;
}

.ps-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.ps-cal-cell {
  position: relative;
  aspect-ratio: 1 / 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  /* White cells so the calendar reads as a distinct UI surface on cream. */
  background: #ffffff;
  border: 1px solid transparent;
  border-radius: 4px;
  cursor: pointer;
  font: inherit;
  color: var(--ink);
  padding: 0;
}
.ps-cal-cell-num { font-size: 15px; font-variant-numeric: tabular-nums; }
.ps-cal-cell-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
  margin-top: 4px;
}
.ps-cal-cell:hover:not(:disabled) {
  background: var(--soft);
}
.ps-cal-cell-today { border-color: var(--line); }
.ps-cal-cell-sel {
  background: var(--accent);
  color: var(--accent-ink);
}
.ps-cal-cell-sel .ps-cal-cell-dot { background: var(--accent-ink); }
.ps-cal-cell-sel:hover { background: var(--accent); }
.ps-cal-cell-out { opacity: 0; pointer-events: none; }
.ps-cal-cell-dis {
  color: color-mix(in oklab, var(--ink) 30%, #ffffff);
  cursor: not-allowed;
}
.ps-cal-cell-dis .ps-cal-cell-dot { display: none; }

/* Slot picker */
.ps-slots {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.ps-slots-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 240px;
  background: var(--surface);
  border: 1px dashed var(--line);
  border-radius: 4px;
  padding: 24px;
}
.ps-slots-empty-msg {
  max-width: 30ch;
  text-align: center;
  font-size: 14px;
  color: var(--mute);
}

.ps-slot-group-label {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 8px;
}
.ps-slot-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));
  gap: 6px;
}
.ps-slot {
  padding: 10px 8px;
  border: 1px solid var(--line);
  background: var(--bg);
  border-radius: 4px;
  font: inherit;
  font-family: var(--f-mono);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}
.ps-slot:hover:not(:disabled) { border-color: var(--ink); }
.ps-slot-active {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}
.ps-slot-booked {
  color: color-mix(in oklab, var(--ink) 25%, var(--bg));
  background: var(--surface);
  text-decoration: line-through;
  cursor: not-allowed;
}

/* Summary */
.ps-summary {
  position: sticky;
  top: 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 24px;
}
.ps-summary-title {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 16px;
}
.ps-summary-list { margin: 0 0 16px; }
.ps-summary-list > div {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.ps-summary-list > div:last-child { border-bottom: none; }
.ps-summary-list dt {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mute);
  align-self: center;
}
.ps-summary-list dd {
  margin: 0;
  font-size: 14px;
  color: var(--ink);
}
.ps-summary-total dd {
  font-family: var(--f-display);
  font-size: 22px !important;
  line-height: 1;
}

/* Forms */
.ps-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.ps-field > span {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mute);
}
.ps-field input,
.ps-field textarea {
  font: inherit;
  font-size: 15px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 4px;
  /* Pure white fields so they read as distinct UI against the cream page. */
  background: #ffffff;
  color: var(--ink);
  width: 100%;
  resize: vertical;
}
.ps-field input::placeholder,
.ps-field textarea::placeholder {
  color: color-mix(in oklab, var(--ink) 38%, #ffffff);
}
.ps-field input:focus,
.ps-field textarea:focus {
  outline: none;
  border-color: var(--accent);
}

.ps-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.ps-field-full { grid-column: 1 / -1; }
.ps-field-half { grid-column: span 1; }
.ps-details .ps-field { margin-bottom: 0; }

/* Flow chooser */
.ps-flow-choose { margin-bottom: 24px; }
.ps-flow-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.ps-flow-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 16px 18px;
  text-align: left;
  font: inherit;
  color: var(--ink);
  cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
}
.ps-flow-card:hover { border-color: var(--ink); }
.ps-flow-card-active {
  border-color: var(--accent);
  background: var(--soft);
}
.ps-flow-card-radio {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: var(--bg);
  flex-shrink: 0;
  margin-top: 3px;
  position: relative;
}
.ps-flow-card-active .ps-flow-card-radio {
  border-color: var(--accent);
}
.ps-flow-card-active .ps-flow-card-radio::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: var(--accent);
}
.ps-flow-card-label {
  display: block;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 4px;
}
.ps-flow-card-sub {
  display: block;
  font-size: 13px;
  color: var(--mute);
  line-height: 1.4;
}

/* Pay panel */
.ps-pay {
  margin-top: 24px;
  padding: 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
}
.ps-pay-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.ps-pay-tab {
  background: transparent;
  border: none;
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--mute);
  padding: 10px 14px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.ps-pay-tab:hover { color: var(--ink); }
.ps-pay-tab-active {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.ps-pay-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.ps-pay-form .ps-btn-wide { grid-column: 1 / -1; margin-top: 4px; }
.ps-pay-sub {
  grid-column: 1 / -1;
  font-size: 14px;
  color: var(--mute);
  margin: 0;
  line-height: 1.5;
}

.ps-bank {
  grid-column: 1 / -1;
  margin: 0;
  padding: 14px 16px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 4px;
  font-family: var(--f-mono);
  font-size: 13px;
}
.ps-bank > div {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 12px;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
}
.ps-bank > div:last-child { border-bottom: none; }
.ps-bank dt { color: var(--mute); letter-spacing: 0.06em; text-transform: uppercase; font-size: 10px; align-self: center; }
.ps-bank dd { margin: 0; color: var(--ink); font-variant-numeric: tabular-nums; }

/* Code input */
.ps-code-input {
  font-family: var(--f-mono);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  font-size: 18px !important;
  text-align: center;
}
.ps-code-err {
  grid-column: 1 / -1;
  font-size: 13px;
  color: #b04030;
  padding: 8px 0;
}

/* Confirmed */
.ps-confirmed {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  padding: 48px 24px;
}
.ps-confirmed-check {
  width: 64px;
  height: 64px;
  margin: 0 auto 24px;
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
}
.ps-confirmed-check svg { width: 48px; height: 48px; }
.ps-confirmed .ps-p { margin-bottom: 32px; }
.ps-confirmed-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 4px;
  text-align: left;
  margin-bottom: 32px;
  overflow: hidden;
}
.ps-confirmed-grid > div {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 16px;
  padding: 16px 20px;
  background: var(--surface);
}
.ps-confirmed-grid dt {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  align-self: center;
}
.ps-confirmed-grid dd { margin: 0; color: var(--ink); font-size: 15px; }

/* ── Contact ─────────────────────────────────────────────────────────────── */

.ps-contact-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 56px;
  align-items: start;
}
.ps-contact-form { display: flex; flex-direction: column; gap: 4px; }
.ps-contact-form .ps-btn { align-self: flex-start; margin-top: 8px; }
.ps-contact-aside {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 4px;
}
.ps-contact-label {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute);
  margin-bottom: 8px;
}
.ps-contact-aside .ps-p { color: var(--ink); font-size: 15px; margin-bottom: 4px; }
.ps-contact-sent {
  padding: 32px;
  background: var(--soft);
  border-radius: 4px;
}

/* ── Footer ──────────────────────────────────────────────────────────────── */

.ps-footer {
  border-top: 1px solid var(--line);
  padding: 48px 0 32px;
  margin-top: 0;
}
.ps-footer-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: center;
  margin-bottom: 32px;
}
.ps-footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-display);
  font-size: 18px;
}
.ps-footer-tag {
  font-size: 14px;
  color: var(--mute);
  text-align: center;
}
.ps-footer-links { display: flex; gap: 20px; }
.ps-footer-links a {
  font-size: 13px;
  color: var(--mute);
  text-decoration: none;
}
.ps-footer-links a:hover { color: var(--ink); }

.ps-footer-meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--mute);
}
.ps-footer-notice { font-style: italic; }

/* ── Motion / dynamism ──────────────────────────────────────────────────── */

/* No native smooth-scroll — Lenis handles it. Leaving it on causes a
   double-smooth where the browser tries to ease what Lenis already eased. */
html { scroll-behavior: auto; }

/* Marker emphasis: italic + accent color. No fake hand-drawn stroke. */
.ps-mk {
  font-style: italic;
  color: var(--accent);
  font-weight: inherit;
}

/* Reveal on scroll. Wrapper fades up when its IO trigger fires. */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 700ms cubic-bezier(.2,.65,.2,1),
              transform 700ms cubic-bezier(.2,.65,.2,1);
  will-change: opacity, transform;
}
.reveal.is-revealed {
  opacity: 1;
  transform: none;
}

/* Stagger: children of a .stagger inside a revealed wrapper come in one
   after another. nth-child delays keep the JSX clean (no per-item inline
   styles needed). */
.stagger > * {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 600ms cubic-bezier(.2,.65,.2,1),
              transform 600ms cubic-bezier(.2,.65,.2,1);
}
.reveal.is-revealed .stagger > *,
.stagger.is-revealed > * {
  opacity: 1;
  transform: none;
}
.stagger > *:nth-child(1) { transition-delay: 60ms; }
.stagger > *:nth-child(2) { transition-delay: 140ms; }
.stagger > *:nth-child(3) { transition-delay: 220ms; }
.stagger > *:nth-child(4) { transition-delay: 300ms; }
.stagger > *:nth-child(5) { transition-delay: 380ms; }
.stagger > *:nth-child(6) { transition-delay: 460ms; }

/* Scroll progress bar — pinned to top edge, filled with accent. Bound to
   --scroll-progress (0..1) which the App useEffect updates each frame. */
.ps-scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  z-index: 100;
  pointer-events: none;
}
.ps-scroll-progress::after {
  content: "";
  display: block;
  height: 100%;
  width: 100%;
  background: var(--accent);
  transform: scaleX(var(--scroll-progress, 0));
  transform-origin: left center;
}

/* Ambient parallax layer. Five soft blobs at different positions, colors,
   sizes, and scroll-rates. Real divs (not pseudo-elements) so we can have
   more than two. */
.ps-ambient {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.ps-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(28px);
  will-change: transform;
}
/* Distribution: spread initial `top` positions so only 2-3 blobs are in
   any one viewport at a time. Lower blobs scroll up into view as you
   move down the page; higher blobs drift out. */
.ps-blob-1 {
  width: 26vmin;
  height: 26vmin;
  top: 65vh;
  left: -6vw;
  background: var(--soft);
  opacity: 0.55;
  transform: translate3d(0, calc(var(--scroll-y, 0px) * -0.3), 0);
  animation: blob-drift-a 32s ease-in-out infinite alternate;
}
.ps-blob-2 {
  width: 32vmin;
  height: 32vmin;
  top: 130vh;
  right: -10vw;
  background: var(--accent);
  opacity: 0.28;
  transform: translate3d(0, calc(var(--scroll-y, 0px) * -0.5), 0);
  animation: blob-drift-b 40s ease-in-out infinite alternate;
}
.ps-blob-3 {
  width: 22vmin;
  height: 22vmin;
  top: 195vh;
  left: 25vw;
  background: var(--soft);
  opacity: 0.5;
  transform: translate3d(0, calc(var(--scroll-y, 0px) * -0.7), 0);
  animation: blob-drift-c 28s ease-in-out infinite alternate;
}
.ps-blob-4 {
  width: 38vmin;
  height: 38vmin;
  top: 275vh;
  right: 15vw;
  background: var(--accent);
  opacity: 0.24;
  transform: translate3d(0, calc(var(--scroll-y, 0px) * -0.95), 0);
}
.ps-blob-5 {
  width: 42vmin;
  height: 42vmin;
  top: 105vh;
  left: 60vw;
  background: var(--soft);
  opacity: 0.26;
  filter: blur(40px);
  transform: translate3d(0, calc(var(--scroll-y, 0px) * 0.4), 0);
}
@keyframes blob-drift-a {
  from { translate: 0 0; }
  to   { translate: 6vw 4vh; }
}
@keyframes blob-drift-b {
  from { translate: 0 0; }
  to   { translate: -5vw -6vh; }
}
@keyframes blob-drift-c {
  from { translate: 0 0; }
  to   { translate: 4vw -3vh; }
}

/* Sticky condensing header. Sticky everywhere; condensed style kicks in
   once useScrolled fires past the threshold. */
.ps-header {
  position: sticky;
  top: 0;
  z-index: 40;
  transition: min-height 0.35s cubic-bezier(.2,.65,.2,1),
              box-shadow 0.35s;
}
.ps-header-scrolled.ps-header-classic {
  min-height: 64px;
}
.ps-header-scrolled {
  box-shadow: 0 8px 24px -18px rgba(0,0,0,0.25);
}
.ps-logo-role {
  transition: opacity 0.3s, max-width 0.3s, margin-left 0.3s, padding-left 0.3s;
  overflow: hidden;
  white-space: nowrap;
  max-width: 240px;
}
.ps-header-scrolled .ps-logo-role {
  opacity: 0;
  max-width: 0;
  margin-left: 0;
  padding-left: 0;
}
/* The mark stays the same size in scrolled state but the logo name tightens. */
.ps-header-scrolled .ps-logo-mark {
  width: 30px;
  height: 30px;
  transition: width 0.35s cubic-bezier(.2,.65,.2,1), height 0.35s;
}
.ps-logo-mark {
  transition: width 0.35s cubic-bezier(.2,.65,.2,1), height 0.35s;
}

/* Primary CTA gets a real hover, not the browser default. */
.ps-btn {
  transition: background 0.18s, color 0.18s, border-color 0.18s,
              transform 0.18s cubic-bezier(.2,.65,.2,1),
              box-shadow 0.25s;
}
.ps-btn-primary:hover {
  transform: translateY(-1.5px);
  box-shadow: 0 10px 24px -14px color-mix(in oklab, var(--accent) 65%, black);
}
.ps-btn-ghost:hover {
  transform: translateY(-1px);
}

/* Service card hover lift. */
.ps-service {
  transition: border-color 0.2s,
              transform 0.28s cubic-bezier(.2,.65,.2,1),
              box-shadow 0.28s cubic-bezier(.2,.65,.2,1);
}
.ps-service:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px -28px rgba(0,0,0,0.35);
}

/* Nav links: marker-style underline that scales in from left on hover. */
.ps-nav a {
  position: relative;
  padding: 4px 0;
  transition: color 0.18s;
}
.ps-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.28s cubic-bezier(.2,.65,.2,1);
}
.ps-nav a:hover::after { transform: scaleX(1); }
.ps-nav a:hover { color: var(--ink); }

/* Booking step transitions: the details/flow/payment block slides in when
   date and slot are picked. Same for the conditional pay/code panels. */
.ps-booking-revealed {
  animation: slideUp 0.5s cubic-bezier(.2,.65,.2,1);
}
@keyframes slideUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: none; }
}

/* Calendar / slot picker micro-feedback. */
.ps-cal-cell {
  transition: background 0.16s, color 0.16s, transform 0.18s cubic-bezier(.2,.65,.2,1);
}
.ps-cal-cell:hover:not(:disabled) {
  transform: scale(1.04);
}
.ps-cal-cell-sel { transform: none; }
.ps-cal-cell-sel:hover { transform: none; }

.ps-slot {
  transition: border-color 0.16s, background 0.16s, color 0.16s,
              transform 0.18s cubic-bezier(.2,.65,.2,1);
}
.ps-slot:hover:not(:disabled) {
  transform: translateY(-1px);
}

/* Stacking: shell above ambient layer. */
.ps-shell { position: relative; z-index: 1; }

/* Honor reduced-motion. Turn everything off cleanly. */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal,
  .reveal.is-revealed,
  .stagger > *,
  .reveal.is-revealed .stagger > * {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .ps-blob,
  .ps-blob-1, .ps-blob-2, .ps-blob-3, .ps-blob-4, .ps-blob-5 { animation: none; }
  .ps-booking-revealed { animation: none; }
}

/* ── Responsive ─────────────────────────────────────────────────────────── */

@media (max-width: 960px) {
  .ps-shell { padding: 0 24px; }
  .ps-header { margin-left: -24px; margin-right: -24px; }
  .ps-section-soft { margin-left: -24px; margin-right: -24px; padding-left: 24px; padding-right: 24px; }
  .ps-hero { grid-template-columns: 1fr; gap: 48px; padding: 40px 0 72px; overflow: hidden; }
  .ps-about-grid { grid-template-columns: 1fr; gap: 32px; }
  .ps-approach-list { grid-template-columns: 1fr; }
  .ps-services-grid { grid-template-columns: 1fr; }
  .ps-booking-grid { grid-template-columns: 1fr; }
  .ps-booking-cols { grid-template-columns: 1fr; gap: 28px; }
  .ps-summary { position: static; }
  .ps-contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .ps-flow-cards { grid-template-columns: 1fr; }
  .ps-header-classic { grid-template-columns: auto 1fr; min-height: 68px; }
  .ps-header-classic .ps-nav { display: none; }
  .ps-header-block { padding: 0 18px; }
  .ps-header-cream { padding: 0 18px; }
  .ps-logo-role { display: none; }
  .ps-footer-row { grid-template-columns: 1fr; text-align: left; }
  .ps-footer-tag { text-align: left; }
  .ps-section { padding-top: 64px; padding-bottom: 64px; }
}

@media (max-width: 560px) {
  .ps-shell { padding: 0 18px; }
  .ps-header { margin-left: -18px; margin-right: -18px; }
  .ps-header-divider,
  .ps-header-utils .ps-btn-onaccent { display: none; }
  .ps-header-block { justify-content: flex-end; }
  .ps-header-utils { gap: 0; }
  .ps-section-soft { margin-left: -18px; margin-right: -18px; padding-left: 18px; padding-right: 18px; }
  .ps-pay-form { grid-template-columns: 1fr; }
  .ps-details { grid-template-columns: 1fr; }
  .ps-field-half { grid-column: 1 / -1; }
  .ps-booking-main { padding: 20px; }
  .ps-pay { padding: 16px; }
}
