/* ==========================================================================
   London Theme — Style: SVC — INNER PAGES
   Services (Our Food) · About · Blog · Contact
   Loaded with the svc style library; all rules scoped under .london-style-svc.
   Reuses tokens, buttons, labels, sections, stats and footer from svc.css.
   ========================================================================== */

/* --------------------------------------------------------------------------
   WORDMARK (replaces the logo image in header + footer)
   -------------------------------------------------------------------------- */
.london-style-svc .svc-wordmark {
  display: inline-flex;
  align-items: baseline;
  gap: 7px;
  font-family: var(--svc-font-serif);
  line-height: 1;
  text-decoration: none;
}
.london-style-svc .svc-wordmark__main { font-size: 27px; font-weight: 700; color: var(--svc-brown-deep); }
.london-style-svc .svc-wordmark__accent { font-style: italic; font-size: 27px; font-weight: 600; color: var(--svc-rust); }
.london-style-svc .svc-footer .svc-wordmark { display: flex; }
.london-style-svc .svc-footer .svc-wordmark__main { color: var(--svc-cream); }
.london-style-svc .svc-footer .svc-wordmark__accent { color: var(--svc-gold); }

/* Brand logo image (replaces the text wordmark) */
.london-style-svc .svc-logo { display: inline-flex; align-items: center; text-decoration: none; }
.london-style-svc .svc-logo img { height: 78px; width: auto; display: block; }
.london-style-svc .svc-logo-text {
  display: inline-flex;
  align-items: baseline;
  gap: 7px;
  margin-left: 24px;
  font-family: var(--svc-font-serif);
  line-height: 1;
}
@media (max-width: 600px) {
  .london-style-svc .svc-logo-text {
    display: none;
  }
}
.london-style-svc .svc-footer .svc-logo--footer img {
  height: 104px;
  margin-bottom: 20px;
  filter: none;
  opacity: 1;
}

/* --------------------------------------------------------------------------
   PAGE HEAD (warm brown banner)
   -------------------------------------------------------------------------- */
.london-style-svc .svc-pagehead {
  background: var(--svc-brown-deep);
  color: var(--svc-cream);
  position: relative;
  overflow: hidden;
}
.london-style-svc .svc-pagehead::before {
  content: "";
  position: absolute;
  right: -140px;
  top: -120px;
  width: 460px;
  height: 460px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(185, 93, 38, 0.45), transparent 70%);
  pointer-events: none;
}
.london-style-svc .svc-pagehead__inner {
  position: relative;
  max-width: var(--svc-maxw);
  margin: 0 auto;
  padding: 80px 48px 92px;
}
.london-style-svc .svc-crumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--svc-gold);
  margin-bottom: 22px;
}
.london-style-svc .svc-crumbs a { color: var(--svc-cream-2); opacity: 0.7; text-decoration: none; transition: opacity var(--svc-dur-fast); }
.london-style-svc .svc-crumbs a:hover { opacity: 1; }
.london-style-svc .svc-crumbs__sep { color: var(--svc-gold); }
.london-style-svc .svc-pagehead__title {
  font-family: var(--svc-font-serif);
  font-weight: 600;
  font-size: clamp(42px, 5.4vw, 76px);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--svc-cream);
  margin: 0;
}
.london-style-svc .svc-pagehead__title em { font-style: italic; color: var(--svc-gold); }
.london-style-svc .svc-pagehead__sub {
  margin-top: 20px;
  max-width: 560px;
  font-size: 17px;
  line-height: 1.7;
  color: var(--svc-cream-2);
  opacity: 0.82;
}

/* --------------------------------------------------------------------------
   SECTION BACKGROUND HELPERS (reuses .svc-sec / .svc-sec-head from svc.css)
   -------------------------------------------------------------------------- */
.london-style-svc .svc-sec--alt { background: var(--svc-cream-2); }
.london-style-svc .svc-sec--tight { padding: 84px 0; }
.london-style-svc .svc-inner-messages { padding: 24px 0 0; }

/* --------------------------------------------------------------------------
   CARD GRID (services / values)
   -------------------------------------------------------------------------- */
.london-style-svc .svc-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.london-style-svc .svc-cards--4 { grid-template-columns: repeat(4, 1fr); }

.london-style-svc .svc-card {
  background: var(--svc-cream);
  border: 1px solid rgba(85, 44, 22, 0.07);
  border-radius: 20px;
  padding: 38px 32px;
  transition: transform var(--svc-dur-base) var(--svc-ease-out), box-shadow var(--svc-dur-base) var(--svc-ease-out);
}
.london-style-svc .svc-sec--alt .svc-card { background: #fff; }
.london-style-svc .svc-card:hover { transform: translateY(-6px); box-shadow: 0 24px 50px -24px rgba(85, 44, 22, 0.3); }
.london-style-svc .svc-card__icon {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--svc-brown-deep);
  color: var(--svc-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
.london-style-svc .svc-card h3 {
  font-family: var(--svc-font-serif);
  font-size: 23px;
  font-weight: 600;
  color: var(--svc-brown-deep);
  margin-bottom: 10px;
}
.london-style-svc .svc-card p {
  font-size: 14.5px;
  line-height: 1.72;
  color: var(--svc-brown-dark);
  opacity: 0.72;
}

/* --------------------------------------------------------------------------
   ALTERNATING ROWS (services detail / about story)
   -------------------------------------------------------------------------- */
.london-style-svc .svc-rows { display: flex; flex-direction: column; gap: 64px; }
.london-style-svc .svc-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.london-style-svc .svc-row--reverse .svc-row__media { order: 2; }
.london-style-svc .svc-row__media {
  border-radius: 180px 180px 20px 20px;
  overflow: hidden;
  border: 1px solid rgba(85, 44, 22, 0.08);
  box-shadow: 0 30px 64px -28px rgba(85, 44, 22, 0.4);
  min-height: 420px;
}
.london-style-svc .svc-row__media .svc-img-placeholder { min-height: 420px; }
.london-style-svc .svc-row__media img { width: 100%; height: 100%; object-fit: cover; }
.london-style-svc .svc-row__title {
  font-family: var(--svc-font-serif);
  font-weight: 600;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.12;
  color: var(--svc-brown-deep);
  margin: 14px 0 0;
}
.london-style-svc .svc-row__title em { font-style: italic; color: var(--svc-rust); }
.london-style-svc .svc-row__body { margin-top: 18px; font-size: 16px; line-height: 1.75; color: var(--svc-brown-dark); opacity: 0.78; }
.london-style-svc .svc-rowticks { margin-top: 24px; display: flex; flex-direction: column; gap: 14px; }
.london-style-svc .svc-rowtick { display: flex; align-items: flex-start; gap: 14px; font-size: 15px; color: var(--svc-brown-dark); }
.london-style-svc .svc-rowtick__mark {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(52, 80, 54, 0.12);
  color: var(--svc-green-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

/* --------------------------------------------------------------------------
   TEAM
   -------------------------------------------------------------------------- */
.london-style-svc .svc-team {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.london-style-svc .svc-team-card { text-align: center; }
.london-style-svc .svc-team-card__photo {
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(85, 44, 22, 0.08);
}
.london-style-svc .svc-team-card__photo .svc-img-placeholder { height: 100%; }
.london-style-svc .svc-team-card h3 {
  font-family: var(--svc-font-serif);
  font-size: 19px;
  font-weight: 600;
  color: var(--svc-brown-deep);
  margin-top: 16px;
}
.london-style-svc .svc-team-card span { font-size: 13px; color: var(--svc-rust); font-weight: 600; letter-spacing: 0.02em; }

/* --------------------------------------------------------------------------
   BLOG
   -------------------------------------------------------------------------- */
.london-style-svc .svc-blog-featured {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  border-radius: 24px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(85, 44, 22, 0.08);
  box-shadow: 0 24px 54px -28px rgba(85, 44, 22, 0.32);
  margin-bottom: 56px;
}
.london-style-svc .svc-blog-featured__media { min-height: 360px; }
.london-style-svc .svc-blog-featured__media .svc-img-placeholder { height: 100%; min-height: 360px; }
.london-style-svc .svc-blog-featured__media img { width: 100%; height: 100%; object-fit: cover; }
.london-style-svc .svc-blog-featured__body { padding: 48px; display: flex; flex-direction: column; justify-content: center; }
.london-style-svc .svc-blog-featured__title {
  font-family: var(--svc-font-serif);
  font-weight: 600;
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.14;
  color: var(--svc-brown-deep);
  margin: 16px 0 0;
}
.london-style-svc .svc-blog-featured__excerpt { margin-top: 14px; font-size: 16px; line-height: 1.7; color: var(--svc-brown-dark); opacity: 0.75; }

.london-style-svc .svc-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.london-style-svc .svc-post-card {
  background: #fff;
  border: 1px solid rgba(85, 44, 22, 0.08);
  border-radius: 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--svc-dur-base) var(--svc-ease-out), box-shadow var(--svc-dur-base) var(--svc-ease-out);
}
.london-style-svc .svc-post-card:hover { transform: translateY(-6px); box-shadow: 0 24px 50px -24px rgba(85, 44, 22, 0.3); }
.london-style-svc .svc-post-card__media { aspect-ratio: 16 / 10; overflow: hidden; }
.london-style-svc .svc-post-card__media .svc-img-placeholder { height: 100%; }
.london-style-svc .svc-post-card__media img { width: 100%; height: 100%; object-fit: cover; }
.london-style-svc .svc-post-card__body { padding: 26px; display: flex; flex-direction: column; flex: 1; }
.london-style-svc .svc-post-card__title {
  font-family: var(--svc-font-serif);
  font-weight: 600;
  font-size: 21px;
  line-height: 1.22;
  color: var(--svc-brown-deep);
  margin: 12px 0 0;
}
.london-style-svc .svc-post-card__title a { color: inherit; text-decoration: none; }
.london-style-svc .svc-post-card__excerpt { margin-top: 10px; font-size: 14.5px; line-height: 1.7; color: var(--svc-brown-dark); opacity: 0.72; flex: 1; }

.london-style-svc .svc-chip {
  display: inline-flex;
  align-self: flex-start;
  background: rgba(185, 93, 38, 0.1);
  color: var(--svc-rust);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 100px;
}
.london-style-svc .svc-post-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(85, 44, 22, 0.1);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--svc-brown-dark);
  opacity: 0.6;
}

.london-style-svc .svc-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 56px;
}
.london-style-svc .svc-pagination a,
.london-style-svc .svc-pagination span {
  min-width: 44px;
  height: 44px;
  padding: 0 14px;
  border-radius: 100px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--svc-font-serif);
  font-size: 16px;
  border: 1px solid rgba(85, 44, 22, 0.18);
  background: var(--svc-cream);
  color: var(--svc-brown-deep);
  text-decoration: none;
  transition: background var(--svc-dur-fast), color var(--svc-dur-fast), border-color var(--svc-dur-fast);
}
.london-style-svc .svc-pagination a:hover { border-color: var(--svc-rust); color: var(--svc-rust); }
.london-style-svc .svc-pagination .is-current { background: var(--svc-rust); border-color: var(--svc-rust); color: var(--svc-cream); }

/* --------------------------------------------------------------------------
   CONTACT
   -------------------------------------------------------------------------- */
.london-style-svc .svc-contact-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 48px;
  align-items: start;
}
.london-style-svc .svc-contact-form {
  background: #fff;
  border: 1px solid rgba(85, 44, 22, 0.08);
  border-radius: 24px;
  padding: 44px;
  box-shadow: 0 24px 54px -30px rgba(85, 44, 22, 0.3);
}
.london-style-svc .svc-contact-form h2 {
  font-family: var(--svc-font-serif);
  font-weight: 600;
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.1;
  color: var(--svc-brown-deep);
  margin: 12px 0 0;
}
.london-style-svc .svc-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 26px; }
.london-style-svc .svc-field { display: flex; flex-direction: column; }
.london-style-svc .svc-field--full { grid-column: 1 / -1; }
.london-style-svc .svc-field label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--svc-rust);
  margin-bottom: 9px;
}
.london-style-svc .svc-input,
.london-style-svc .svc-textarea,
.london-style-svc .svc-select {
  width: 100%;
  padding: 14px 18px;
  border-radius: 12px;
  background: var(--svc-cream);
  border: 1px solid rgba(85, 44, 22, 0.16);
  color: var(--svc-ink);
  font-family: var(--svc-font-sans);
  font-size: 15px;
  outline: none;
  transition: border-color var(--svc-dur-fast), box-shadow var(--svc-dur-fast), background var(--svc-dur-fast);
}
.london-style-svc .svc-textarea { resize: vertical; min-height: 130px; }
.london-style-svc .svc-input::placeholder,
.london-style-svc .svc-textarea::placeholder { color: rgba(42, 32, 24, 0.4); }
.london-style-svc .svc-input:focus,
.london-style-svc .svc-textarea:focus,
.london-style-svc .svc-select:focus {
  border-color: var(--svc-rust);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(185, 93, 38, 0.13);
}
.london-style-svc .svc-form-note { margin-top: 18px; font-size: 12.5px; color: var(--svc-brown-dark); opacity: 0.55; }

.london-style-svc .svc-info-stack { display: flex; flex-direction: column; gap: 16px; }
.london-style-svc .svc-info-card {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  background: var(--svc-cream);
  border: 1px solid rgba(85, 44, 22, 0.08);
  border-radius: 18px;
  padding: 24px;
}
.london-style-svc .svc-info-card__icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--svc-brown-deep);
  color: var(--svc-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.london-style-svc .svc-info-card__label { font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--svc-rust); }
.london-style-svc .svc-info-card__value {
  font-family: var(--svc-font-serif);
  font-size: 18px;
  color: var(--svc-brown-deep);
  margin-top: 5px;
  word-break: break-word;
}
.london-style-svc a.svc-info-card__value:hover { color: var(--svc-rust); }

.london-style-svc .svc-map {
  margin-top: 16px;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(85, 44, 22, 0.1);
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    repeating-linear-gradient(45deg, rgba(85,44,22,0.05) 0 14px, transparent 14px 28px),
    var(--svc-cream-2);
}
.london-style-svc .svc-map__pin {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  font-family: var(--svc-font-serif);
  font-size: 17px;
  color: var(--svc-brown-deep);
}
.london-style-svc .svc-map__pin-badge {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--svc-rust);
  color: var(--svc-cream);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 16px 30px -12px rgba(185, 93, 38, 0.6);
}

/* --------------------------------------------------------------------------
   RESPONSIVE
   -------------------------------------------------------------------------- */
@media (max-width: 980px) {
  .london-style-svc .svc-cards,
  .london-style-svc .svc-cards--4 { grid-template-columns: repeat(2, 1fr); }
  .london-style-svc .svc-team { grid-template-columns: repeat(2, 1fr); }
  .london-style-svc .svc-blog-grid { grid-template-columns: repeat(2, 1fr); }
  .london-style-svc .svc-row,
  .london-style-svc .svc-row--reverse,
  .london-style-svc .svc-blog-featured,
  .london-style-svc .svc-contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .london-style-svc .svc-row--reverse .svc-row__media { order: 0; }
  .london-style-svc .svc-blog-featured__body { padding: 34px; }
}

@media (max-width: 600px) {
  .london-style-svc .svc-pagehead__inner { padding: 60px 24px 72px; }
  .london-style-svc .svc-cards,
  .london-style-svc .svc-cards--4,
  .london-style-svc .svc-blog-grid,
  .london-style-svc .svc-team { grid-template-columns: 1fr; }
  .london-style-svc .svc-form-grid { grid-template-columns: 1fr; }
  .london-style-svc .svc-contact-form { padding: 28px 22px; }
  .london-style-svc .svc-row__media,
  .london-style-svc .svc-row__media .svc-img-placeholder { min-height: 300px; border-radius: 120px 120px 18px 18px; }
}

/* --------------------------------------------------------------------------
   CONTACT FORM — style Drupal / Webform elements inside the contact card
   -------------------------------------------------------------------------- */
.london-style-svc .svc-form-content .js-form-item,
.london-style-svc .svc-form-content .form-item { margin: 0 0 16px; }
.london-style-svc .svc-form-content label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--svc-rust);
  margin-bottom: 8px;
}
.london-style-svc .svc-form-content input[type="text"],
.london-style-svc .svc-form-content input[type="email"],
.london-style-svc .svc-form-content input[type="tel"],
.london-style-svc .svc-form-content input[type="number"],
.london-style-svc .svc-form-content input[type="url"],
.london-style-svc .svc-form-content input[type="search"],
.london-style-svc .svc-form-content input[type="date"],
.london-style-svc .svc-form-content textarea,
.london-style-svc .svc-form-content select {
  width: 100%;
  padding: 14px 18px;
  font-family: var(--svc-font-sans);
  font-size: 15px;
  color: var(--svc-ink);
  background: var(--svc-cream);
  border: 1px solid rgba(85, 44, 22, 0.16);
  border-radius: 12px;
  box-sizing: border-box;
}
.london-style-svc .svc-form-content textarea { min-height: 130px; resize: vertical; }
.london-style-svc .svc-form-content input:focus,
.london-style-svc .svc-form-content textarea:focus,
.london-style-svc .svc-form-content select:focus {
  outline: none;
  border-color: var(--svc-rust);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(185, 93, 38, 0.13);
}
.london-style-svc .svc-form-content .description { font-size: 12.5px; color: var(--svc-brown-dark); opacity: 0.6; margin-top: 5px; }
.london-style-svc .svc-form-content .form-required::after { color: #b3401e; }
.london-style-svc .svc-form-content .form-actions { margin-top: 8px; }
.london-style-svc .svc-form-content .button,
.london-style-svc .svc-form-content .form-submit,
.london-style-svc .svc-form-content button[type="submit"],
.london-style-svc .svc-form-content input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 38px;
  font-family: var(--svc-font-sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--svc-cream);
  background: var(--svc-rust);
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: background var(--svc-dur-fast), transform var(--svc-dur-fast);
}
.london-style-svc .svc-form-content .button:hover,
.london-style-svc .svc-form-content .form-submit:hover,
.london-style-svc .svc-form-content button[type="submit"]:hover,
.london-style-svc .svc-form-content input[type="submit"]:hover { background: var(--svc-rust-hover); transform: translateY(-2px); }
