/*
  Standard page styling.
  Used for Privacy Policy and future static/editorial pages.
  Calmer than the home page, but still aligned with the Elemental Kin/Messy Middle system.
*/

.standard-page {
  background: var(--ek-colour-light, #fffdfa);
  color: var(--ek-colour-primary, #172239);
  overflow: hidden;
}

.standard-page .container {
  width: min(88vw, 1680px);
  margin-inline: auto;
  padding-inline: clamp(22px, 4vw, 54px);
}

/* Header/title area */
.standard-page__hero {
  position: relative;
  isolation: isolate;
  padding: clamp(72px, 7vw, 112px) 0 clamp(28px, 3.5vw, 46px);
  background:
    radial-gradient(circle at 82% 18%, rgba(234, 217, 200, 0.22) 0 14%, transparent 42%),
    radial-gradient(circle at 14% 86%, rgba(212, 223, 201, 0.16) 0 12%, transparent 36%),
    var(--ek-colour-light, #fffdfa);
}

.standard-page__hero::after {
  content: "";
  position: absolute;
  right: clamp(-90px, -5vw, -42px);
  top: clamp(70px, 7vw, 110px);
  width: clamp(160px, 18vw, 280px);
  height: clamp(160px, 18vw, 280px);
  opacity: 0.11;
  pointer-events: none;
  background:
    linear-gradient(90deg, var(--ek-colour-accent, #c56535) 0 48%, transparent 48% 100%) 0 12% / 100% 2px no-repeat,
    linear-gradient(90deg, transparent 0 18%, var(--ek-colour-accent, #c56535) 18% 76%, transparent 76% 100%) 0 34% / 100% 2px no-repeat,
    linear-gradient(90deg, var(--ek-colour-accent, #c56535) 0 36%, transparent 36% 100%) 0 58% / 100% 2px no-repeat,
    linear-gradient(90deg, transparent 0 38%, var(--ek-colour-accent, #c56535) 38% 92%, transparent 92% 100%) 0 82% / 100% 2px no-repeat,
    linear-gradient(180deg, var(--ek-colour-accent, #c56535) 0 44%, transparent 44% 100%) 16% 0 / 2px 100% no-repeat,
    linear-gradient(180deg, transparent 0 16%, var(--ek-colour-accent, #c56535) 16% 78%, transparent 78% 100%) 50% 0 / 2px 100% no-repeat,
    linear-gradient(180deg, var(--ek-colour-accent, #c56535) 0 66%, transparent 66% 100%) 82% 0 / 2px 100% no-repeat;
}

.standard-page__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 14px;
  color: var(--ek-colour-accent, #c56535);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.standard-page__eyebrow::before {
  content: "";
  width: 28px;
  height: 2px;
  background: currentColor;
}

.standard-page h1 {
  position: relative;
  z-index: 2;
  max-width: 960px;
  margin: 0;
  font-family: var(--ff-serif);
  color: var(--ek-colour-primary, #172239);
  font-size: clamp(2.8rem, 5.2vw, 5.6rem);
  line-height: 0.96;
  letter-spacing: -0.058em;
}

/* Content area */
.standard-page__content {
  padding: clamp(32px, 4vw, 56px) 0 clamp(84px, 8vw, 130px);
}

.standard-page__content-inner {
  max-width: min(88vw, 1320px);
}

/* Remove duplicate visual title from text content when the page hero already has h1 */
.standard-page__content .ce-header:first-child,
.standard-page__content .frame:first-child > header:first-child {
  display: none;
}

.standard-page__content .frame {
  margin: 0;
}

.standard-page__content .frame > *:first-child,
.standard-page__content .ce-bodytext > *:first-child {
  margin-top: 0;
}

.standard-page__content h1,
.standard-page__content h2,
.standard-page__content h3 {
  font-family: var(--ff-serif);
  color: var(--ek-colour-primary, #172239);
  line-height: 1.02;
  letter-spacing: -0.042em;
}

.standard-page__content h1 {
  font-size: clamp(2rem, 3.2vw, 3.4rem);
}

.standard-page__content h2 {
  margin: clamp(34px, 4.2vw, 54px) 0 12px;
  font-size: clamp(1.65rem, 2.6vw, 2.55rem);
}

.standard-page__content h3 {
  margin: 30px 0 10px;
  font-size: clamp(1.35rem, 2vw, 1.95rem);
}

.standard-page__content p,
.standard-page__content li {
  color: rgba(23, 34, 57, 0.82);
  font-size: clamp(0.98rem, 1vw, 1.06rem);
  line-height: 1.68;
}

.standard-page__content p {
  margin: 0 0 1em;
}

.standard-page__content ul,
.standard-page__content ol {
  margin: 1em 0 1.25em;
  padding-left: 1.25em;
}

.standard-page__content li + li {
  margin-top: 0.45em;
}

.standard-page__content a {
  color: var(--ek-colour-accent, #c56535);
  font-weight: 850;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

.standard-page__content a:hover {
  color: var(--ek-colour-primary, #172239);
}

/* Editorial/legal content panel */
.standard-page__content-inner > .frame-default,
.standard-page__content-inner > .frame-type-text,
.standard-page__content-inner > .frame {
  padding: clamp(32px, 4vw, 58px);
  background: rgba(255, 253, 250, 0.78);
  border: 1px solid rgba(23, 34, 57, 0.07);
  box-shadow: 0 18px 58px rgba(23, 34, 57, 0.045);
}

.standard-page__content-inner .ce-bodytext {
  max-width: 1040px;
}

/* Cookie banner: less intrusive on content pages */
.cookie-consent {
  max-width: 780px;
  padding: 15px;
}

.cookie-consent p {
  font-size: 0.84rem;
}

.cookie-consent__button {
  padding: 8px 12px;
  font-size: 0.78rem;
}

@media (max-width: 760px) {
  .standard-page__hero {
    padding-top: 70px;
    padding-bottom: 30px;
  }

  .standard-page h1 {
    font-size: clamp(2.65rem, 13vw, 4.4rem);
  }

  .standard-page__content {
    padding-top: 28px;
  }

  .standard-page__content-inner > .frame-default,
  .standard-page__content-inner > .frame-type-text,
  .standard-page__content-inner > .frame {
    padding: 24px;
  }

  .standard-page__hero::after {
    right: -130px;
    opacity: 0.08;
  }
}
