.page-hero {
  min-height: 300px;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  padding: 40px 0 48px;
  overflow: hidden;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  background:
    radial-gradient(ellipse 75% 65% at 12% 42%, color-mix(in srgb, var(--amber) 10%, transparent) 0%, transparent 58%),
    radial-gradient(ellipse 60% 55% at 88% 25%, color-mix(in srgb, var(--sage) 8%, transparent) 0%, transparent 52%),
    linear-gradient(
      168deg,
      var(--bg-page) 0%,
      color-mix(in srgb, var(--bg-white) 88%, transparent) 48%,
      var(--bg-page) 100%
    );
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.45;
  background:
    repeating-linear-gradient(0deg, transparent 0, transparent 39px, rgba(44, 41, 36, 0.03) 39px, rgba(44, 41, 36, 0.03) 40px),
    repeating-linear-gradient(90deg, transparent 0, transparent 39px, rgba(44, 41, 36, 0.03) 39px, rgba(44, 41, 36, 0.03) 40px);
}
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.038;
  background-image: var(--noise-fine);
  mix-blend-mode: multiply;
}
.page-hero-content {
  position: relative;
  z-index: 2;
  max-width: var(--C);
  width: 100%;
  margin: 0 auto;
  padding: 0 40px;
}
.page-hero-eye {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: color-mix(in srgb, var(--amber) 88%, var(--graphite));
  font-weight: 700;
  margin-bottom: 10px;
}
.page-hero-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--graphite);
  line-height: 1.0;
  margin-bottom: 14px;
}
.page-hero-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
  max-width: 520px;
  font-style: italic;
}
.page-hero-line {
  width: 48px;
  height: 3px;
  background: var(--amber-line);
  border-radius: 2px;
  margin-bottom: 16px;
}
.breadcrumb {
  background: linear-gradient(180deg, color-mix(in srgb, var(--bg-page) 88%, var(--bg-white)) 0%, color-mix(in srgb, var(--bg-page) 96%, var(--bg-white)) 100%);
  border-bottom: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
  padding: 10px 0;
}
.breadcrumb .inner { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; row-gap: 4px; }
.breadcrumb a { font-size: 12px; color: var(--muted); text-decoration: none; transition: color .2s; }
.breadcrumb a:hover { color: var(--amber); }
.breadcrumb span { font-size: 12px; color: var(--muted-2); }
.breadcrumb .current { font-size: 12px; color: var(--graphite); font-weight: 600; word-break: break-word; }
.service-main {
  background: linear-gradient(180deg, var(--bg-white) 0%, color-mix(in srgb, var(--bg-white) 92%, var(--bg-page)) 100%);
  border-bottom: 1px solid var(--border);
  padding: 56px 0;
}
.service-main .inner {
  display: grid;
  grid-template-columns: 260px 1fr 260px;
  gap: 28px;
  align-items: start;
}

.col-title {
  font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 2px; color: var(--graphite2);
  margin-bottom: 16px; padding-bottom: 10px;
  border-bottom: 2px solid var(--amber-line);
  display: flex; align-items: center; gap: 8px;
}
.benefit-list { display: flex; flex-direction: column; gap: 12px; }
.benefit-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 14px; background: color-mix(in srgb, var(--bg-page) 78%, var(--bg-white));
  border: 1px solid color-mix(in srgb, var(--border) 88%, transparent); border-radius: 8px;
  transition: border-color .2s, box-shadow .2s;
}
.benefit-item:hover { border-color: var(--sage-border); box-shadow: 0 2px 12px rgba(45, 42, 36, .07); }
.merit-icon {
  width: 32px; height: 32px; border-radius: 7px;
  background: color-mix(in srgb, var(--amber-line) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--amber-line) 35%, transparent);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.merit-icon svg { width: 16px; height: 16px; }
.merit-title { font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .4px; color: var(--graphite); margin-bottom: 3px; }
.merit-desc { font-size: 11px; color: var(--muted); line-height: 1.5; font-style: italic; }

.photo-main {
  width: 100%; aspect-ratio: 16/10;
  background: linear-gradient(135deg, var(--placeholder-1), var(--placeholder-2));
  border-radius: 10px; border: 1px solid var(--border);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; color: var(--muted-2); font-size: 13px; font-style: italic;
  cursor: pointer; position: relative; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  transition: box-shadow .25s;
}
.photo-main:hover { box-shadow: 0 8px 32px rgba(0,0,0,.14); }
.photo-main svg { width: 36px; height: 36px; opacity: .25; }
.photo-zoom {
  position: absolute; top: 12px; right: 12px;
  width: 30px; height: 30px; border-radius: 6px;
  background: rgba(0,0,0,.45); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .2s;
}
.photo-main:hover .photo-zoom { opacity: 1; }
.photo-zoom svg { width: 14px; height: 14px; }
.photo-hint { font-size: 11px; color: var(--muted-2); font-style: italic; margin-top: 4px; }

.photo-thumbs {
  display: flex; gap: 8px; margin-top: 10px;
}
.photo-thumb {
  flex: 1; aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--placeholder-1), var(--placeholder-2));
  border-radius: 6px; border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 10px; color: var(--muted-2); font-style: italic;
  transition: border-color .2s, transform .2s;
}
.photo-thumb:hover { border-color: color-mix(in srgb, var(--amber) 45%, var(--border)); transform: translateY(-2px); }

.photo-caption {
  margin-top: 12px; padding: 14px;
  background: color-mix(in srgb, var(--bg-white) 82%, transparent);
  border-radius: 8px; border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
}
.photo-caption-title { font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--graphite); margin-bottom: 5px; }
.photo-caption-text { font-size: 12px; color: var(--muted); line-height: 1.6; font-style: italic; }

.steps-list { display: flex; flex-direction: column; gap: 0; }
.step-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.step-item:last-child { border-bottom: none; }
.step-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--dark); color: color-mix(in srgb, var(--amber) 92%, white);
  font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 1px;
}
.step-name { font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .4px; color: var(--graphite); margin-bottom: 3px; }
.step-desc { font-size: 11px; color: var(--muted); line-height: 1.5; font-style: italic; }

.btn-cta {
  display: block; width: 100%; margin-top: 20px;
  background: var(--amber); color: var(--dark);
  border: none; border-radius: 8px;
  padding: 13px; text-align: center;
  font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer; text-decoration: none;
  box-shadow: 0 4px 16px color-mix(in srgb, var(--amber) 26%, transparent);
  transition: background .2s, transform .2s, box-shadow .2s;
}
.btn-cta:hover { background: var(--amber-soft); transform: translateY(-2px); box-shadow: 0 8px 24px color-mix(in srgb, var(--amber) 22%, transparent); }
.portfolio {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--bg-page) 75%, var(--bg-white)) 0%, var(--bg-page) 100%);
  padding: 56px 0;
  border-top: 1px solid color-mix(in srgb, var(--border) 85%, transparent); border-bottom: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
}
.section-head { margin-bottom: 32px; }
.section-eye {
  font-size: 10px; text-transform: uppercase; letter-spacing: 3px;
  color: color-mix(in srgb, var(--amber) 85%, var(--graphite)); font-weight: 700; margin-bottom: 6px;
}
.section-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(24px, 3vw, 34px); font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px; color: var(--graphite);
}
.section-title::after {
  content: ''; display: block; width: 36px; height: 3px;
  background: var(--amber-line); margin-top: 8px; border-radius: 2px;
}
.portfolio-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.portfolio-card {
  background: var(--bg-card); border-radius: 10px;
  border: 1px solid var(--border); overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  transition: transform .25s, box-shadow .25s, border-color .25s;
  cursor: pointer;
}
.portfolio-card:hover { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(45, 42, 36, .1); border-color: color-mix(in srgb, var(--amber-line) 45%, var(--border)); }
.pf-photo {
  height: 180px;
  background: linear-gradient(135deg, var(--placeholder-1), var(--placeholder-2));
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px; color: var(--muted-2); font-size: 11px; font-style: italic; position: relative;
}
.pf-photo svg { width: 28px; height: 28px; opacity: .22; }
.pf-tag {
  position: absolute; top: 10px; left: 10px;
  background: var(--amber-soft); color: var(--dark);
  font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
  padding: 3px 8px; border-radius: 3px;
}
.pf-body { padding: 14px; }
.pf-name { font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--graphite); margin-bottom: 5px; }
.pf-meta { font-size: 11px; color: var(--muted); font-style: italic; }
.about {
  background: linear-gradient(180deg, var(--bg-white) 0%, color-mix(in srgb, var(--bg-white) 92%, var(--bg-page)) 100%);
  padding: 56px 0;
  border-bottom: 1px solid var(--border);
}
.about .inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center;
}
.about-scope {
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: color-mix(in srgb, var(--amber) 88%, var(--graphite));
  margin-bottom: 6px;
}
.about-body {
  font-size: 14px; color: var(--muted); line-height: 1.85;
  margin-top: 16px;
}
.about-body p + p { margin-top: 12px; }
.about-body em { color: var(--muted-2); }

.about-page-section {
  padding: 52px 0;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--bg-white) 0%, color-mix(in srgb, var(--bg-white) 94%, var(--bg-page)) 100%);
}
.about-page-section--tone {
  background: linear-gradient(180deg, color-mix(in srgb, var(--bg-page) 86%, var(--bg-white)) 0%, color-mix(in srgb, var(--bg-page) 76%, var(--bg-white)) 100%);
}

.about-page-note {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.75;
  font-style: italic;
  max-width: 720px;
  margin-bottom: 20px;
}
.about-page-prose p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.85;
  margin-bottom: 12px;
  max-width: 720px;
}
.about-page-prose p:last-child { margin-bottom: 0; }

.about-page-values { max-width: 720px; }

.about-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 8px;
}
.about-team-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px 18px;
  text-align: center;
  box-shadow: 0 2px 12px rgba(0,0,0,.05);
}
.about-team-ph {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  margin: 0 auto 14px;
  background: linear-gradient(135deg, var(--placeholder-1), var(--placeholder-2));
  border: 1px solid var(--border);
}
.about-team-name {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--graphite);
  margin-bottom: 8px;
}
.about-team-role {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.55;
  font-style: italic;
}

.about-facts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 8px;
}
.about-fact-card {
  padding: 18px 16px;
  background: color-mix(in srgb, var(--bg-white) 75%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 88%, transparent);
  border-radius: 10px;
}
.about-fact-label {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: color-mix(in srgb, var(--amber) 82%, var(--graphite));
  margin-bottom: 10px;
}
.about-fact-text {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
  font-style: italic;
}

.about-page-cta {
  background: var(--bg-white);
  border-bottom: 1px solid var(--border);
  padding: 40px 0 64px;
}
.about-page-cta-inner {
  text-align: center;
  max-width: 520px;
  margin: 0 auto;
}
.about-page-cta-text {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 20px;
}
.about-page-cta .btn-cta { max-width: 280px; margin-left: auto; margin-right: auto; }

h2.section-title { margin: 0; }

.about-visual {
  background: linear-gradient(135deg, var(--placeholder-1), var(--placeholder-2));
  border-radius: 12px; border: 1px solid var(--border);
  min-height: 260px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; color: var(--muted-2); font-size: 12px; font-style: italic;
  box-shadow: 0 4px 20px rgba(0,0,0,.06);
}
.about-visual svg { width: 36px; height: 36px; opacity: .20; }

.lightbox {
  display: none; position: fixed; inset: 0; z-index: 999;
  background: rgba(0,0,0,.88); backdrop-filter: blur(6px);
  align-items: center; justify-content: center;
}
.lightbox.open { display: flex; }
.lightbox-inner { position: relative; max-width: 900px; width: 90%; }
.lightbox-img {
  width: 100%; aspect-ratio: 16/10;
  background: linear-gradient(135deg, var(--graphite2), var(--graphite));
  border-radius: 10px; border: 1px solid rgba(201,145,46,.25);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.30); font-size: 14px; font-style: italic;
}
.lightbox-close {
  position: absolute; top: -14px; right: -14px;
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--amber); color: var(--dark);
  border: none; cursor: pointer; font-size: 18px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,.40);
}
@media (max-width: 1024px) {
  .service-main .inner { grid-template-columns: 220px 1fr 220px; gap: 20px; }
  .portfolio-grid { grid-template-columns: repeat(2,1fr); }
  .page-hero-content { padding: 0 24px; }
  .about-team-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .page-hero { min-height: 240px; padding: 32px 0 36px; }
  .page-hero-content { padding: 0 20px; }
  .page-hero-desc { font-size: 14px; }
  .service-main { padding: 40px 0; }
  .portfolio-grid { grid-template-columns: 1fr 1fr; }
  .about .inner { grid-template-columns: 1fr; gap: 28px; }
  .about-visual { min-height: 180px; }
  .about-team-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }
  .about-facts-grid { grid-template-columns: 1fr; }
  .about-page-section { padding: 40px 0; }
}

.contacts-page {
  background: linear-gradient(180deg, var(--bg-white) 0%, color-mix(in srgb, var(--bg-white) 88%, var(--bg-page)) 100%);
  border-bottom: 1px solid var(--border);
  padding: 48px 0 72px;
}
.contacts-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(0, 1.15fr);
  gap: 44px;
  align-items: start;
}
.contacts-info {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.contacts-block {
  padding: 18px 0 20px;
  border-bottom: 1px solid var(--border);
}
.contacts-block:first-child { padding-top: 0; }
.contacts-block:last-child { border-bottom: none; padding-bottom: 0; }
.contacts-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--muted);
  margin-bottom: 8px;
}
.contacts-value {
  font-size: 16px;
  color: var(--graphite);
  line-height: 1.55;
}
.contacts-map-wrap { min-width: 0; }
.contacts-map {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 8px 28px rgba(0,0,0,.07);
  background: var(--bg);
}
.contacts-map-canvas {
  width: 100%;
  height: min(420px, 52vh);
  min-height: 280px;
  z-index: 0;
}
.contacts-map .leaflet-control-attribution {
  display: none !important;
}

@media (max-width: 900px) {
  .service-main { padding: 44px 0; }
  .service-main .inner { grid-template-columns: 1fr; }
  .col-photo { order: 1; }
  .col-benefits { order: 2; }
  .col-steps { order: 3; }
  .photo-thumbs { display: none; }
  .contacts-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .contacts-map-canvas {
    height: 360px;
    min-height: 260px;
  }
}

@media (max-width: 480px) {
  .page-hero { min-height: 0; padding: 28px 0 32px; }
  .page-hero-content { padding: 0 16px; }
  .page-hero-title { letter-spacing: 0.06em; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .lightbox-inner { width: min(100%, 92vw); margin: 0 auto; }
  .lightbox-close {
    top: 10px;
    right: 10px;
  }
  .contacts-page { padding: 36px 0 48px; }
  .contacts-value { font-size: 15px; word-break: break-word; }
}
