:root {
  --max: 1800px;
  --page-bg: #f2eee8;
  --shell: #fffcf9;
  --paper: #ffffff;
  --paper-soft: #faf4ec;
  --ink: #24342c;
  --muted: #66756b;
  --green: #6f866e;
  --green-dark: #3d5647;
  --sand: #e8dccb;
  --clay: #b96b53;
  --line: rgba(61,86,71,.15);
  --shadow: 0 28px 80px rgba(33,45,39,.12);
  --shadow-soft: 0 14px 36px rgba(33,45,39,.10);
  --radius-xl: 36px;
  --radius-lg: 26px;
  --radius-md: 18px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--page-bg); }
body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 10% 5%, rgba(185,107,83,.16), transparent 30rem),
    radial-gradient(circle at 88% 10%, rgba(111,134,110,.18), transparent 34rem),
    linear-gradient(180deg, #fbf7f1 0%, var(--page-bg) 55%, #ebe2d7 100%);
  line-height: 1.65;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--green-dark); }
a:focus-visible, button:focus-visible { outline: 3px solid rgba(185,107,83,.55); outline-offset: 3px; }
img { display: block; max-width: 100%; height: auto; }
.page-frame { width: min(100%, var(--max)); margin: 0 auto; padding: 24px; }
.site-shell {
  min-height: 100vh;
  background: var(--shell);
  border: 1px solid rgba(255,255,255,.9);
  border-radius: 38px;
  box-shadow: 0 36px 110px rgba(35,45,39,.13);
  overflow: clip;
}
.skip-link { position: fixed; left: 18px; top: 14px; z-index: 100; transform: translateY(-150%); background: var(--ink); color: #fff; border-radius: 999px; padding: 10px 14px; font-weight: 700; transition: transform .2s ease; }
.skip-link:focus { transform: translateY(0); }
.site-header { padding: 22px 26px 0; position: sticky; top: 0; z-index: 20; }
.header-grid {
  display: grid;
  grid-template-columns: auto minmax(280px, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,252,249,.88);
  backdrop-filter: blur(18px);
  box-shadow: 0 14px 40px rgba(33,45,39,.08);
}
.brand { display: inline-flex; align-items: center; gap: 12px; padding: 4px 12px 4px 5px; border-radius: 999px; font-weight: 800; letter-spacing: .01em; }
.brand img { width: 112px; height: auto; border-radius: 999px; background: #fff; }
.main-nav { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 6px; }
.main-nav a { padding: 9px 13px; border-radius: 999px; font-size: .96rem; color: var(--muted); transition: background .2s ease, color .2s ease, transform .2s ease; }
.main-nav a:hover, .main-nav a.is-active { background: #edf3ea; color: var(--green-dark); transform: translateY(-1px); }
.lang-switch { display: inline-flex; gap: 4px; padding: 4px; border-radius: 999px; background: #f0e7db; }
.lang-btn { border: 0; border-radius: 999px; padding: 9px 12px; background: transparent; color: var(--muted); cursor: pointer; font-weight: 700; }
.lang-btn.is-active { background: var(--green-dark); color: #fff; box-shadow: 0 8px 20px rgba(61,86,71,.22); }
.hero { padding: clamp(34px, 5vw, 90px); }
.hero-alt { display: grid; grid-template-columns: minmax(280px, .92fr) minmax(320px, 1.08fr); gap: clamp(26px, 4vw, 70px); align-items: center; }
.hero-panel { position: relative; padding: clamp(24px, 4vw, 56px); border-radius: var(--radius-xl); background: linear-gradient(145deg, #fff 0%, #fff9f1 100%); border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.hero-panel:before { content: ""; position: absolute; inset: 20px auto 20px 0; width: 6px; border-radius: 999px; background: linear-gradient(180deg, var(--green), var(--clay)); }
.eyebrow { margin: 0 0 12px; color: var(--clay); font-weight: 800; letter-spacing: .04em; }
h1, h2, h3 { line-height: 1.12; margin: 0; color: var(--ink); }
h1 { font-size: clamp(2.5rem, 5vw, 6.2rem); letter-spacing: -.055em; max-width: 12ch; }
h2 { font-size: clamp(1.8rem, 3vw, 3.2rem); letter-spacing: -.035em; }
h3 { font-size: clamp(1.18rem, 1.7vw, 1.55rem); letter-spacing: -.02em; }
.lead { margin: 22px 0 0; font-size: clamp(1.13rem, 1.8vw, 1.55rem); color: var(--muted); max-width: 58ch; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 12px 18px; border-radius: 999px; border: 1px solid var(--line); font-weight: 800; color: var(--green-dark); background: #fff; box-shadow: 0 8px 20px rgba(33,45,39,.07); transition: transform .2s ease, box-shadow .2s ease; }
.button:hover { transform: translateY(-2px); box-shadow: var(--shadow-soft); }
.button.primary { background: var(--green-dark); color: #fff; border-color: transparent; }
.button.ghost { background: #f6eee5; }
.hero-media { position: relative; min-height: 430px; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.75); isolation: isolate; }
.hero-media img { width: 100%; height: 100%; min-height: 430px; object-fit: cover; transform: scale(1.02); transition: transform .7s ease; }
.hero-media:hover img { transform: scale(1.055); }
.hero-media:after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 45%, rgba(31,42,36,.45)); z-index:1; }
.media-badge { position: absolute; z-index: 2; left: 24px; bottom: 24px; display: grid; gap: 2px; padding: 16px 18px; border-radius: 20px; color: #fff; background: rgba(31,42,36,.72); backdrop-filter: blur(12px); }
.media-badge strong { font-size: 1.25rem; }
.section { padding: clamp(26px, 4vw, 70px); }
.intro-strip { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; padding-top: 0; }
.intro-copy { padding: clamp(22px, 3vw, 38px); border-radius: var(--radius-lg); background: #f7efe5; border: 1px solid var(--line); }
.intro-copy p { color: var(--muted); max-width: 70ch; margin: 16px 0 0; }
.intro-stats { display: grid; grid-template-columns: repeat(3, minmax(120px, 1fr)); gap: 12px; min-width: min(620px, 100%); }
.intro-stats div { padding: 20px; border-radius: 24px; background: #fff; box-shadow: var(--shadow-soft); border: 1px solid var(--line); }
.intro-stats strong { display: block; font-size: 2rem; color: var(--green-dark); line-height: 1; }
.intro-stats span { display: block; margin-top: 6px; color: var(--muted); }
.section-heading { max-width: 900px; margin-bottom: 28px; }
.section-lead { margin: 12px 0 0; color: var(--muted); font-size: 1.08rem; }
.location-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 18px; }
.location-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-soft); transition: transform .25s ease, box-shadow .25s ease; }
.location-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.location-image { display: block; aspect-ratio: 4/3; overflow: hidden; background: #eee; }
.location-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.location-card:hover .location-image img { transform: scale(1.06); }
.location-body { padding: 20px; }
.city { margin: 0 0 8px; color: var(--clay); font-weight: 800; }
.address { color: var(--muted); }
.text-link { display: inline-flex; align-items: center; gap: 7px; margin-top: 8px; font-weight: 850; color: var(--green-dark); }
.text-link:after { content: "›"; font-size: 1.2em; line-height: 1; transition: transform .2s ease; }
.text-link:hover:after { transform: translateX(3px); }
.feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.feature-card { min-height: 100%; display: grid; grid-template-rows: 230px 1fr; overflow: hidden; border-radius: var(--radius-lg); background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.feature-card img { width: 100%; height: 230px; object-fit: cover; }
.feature-card div { padding: 22px; }
.feature-card p { color: var(--muted); }
.subnav { margin: -22px clamp(26px, 4vw, 70px) 0; display: flex; flex-wrap: wrap; gap: 10px; }
.subnav a { padding: 10px 14px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--muted); font-weight: 750; }
.subnav a.is-active { background: var(--green-dark); color: #fff; }
.detail-layout { display: grid; grid-template-columns: minmax(280px, .95fr) minmax(280px, .75fr); gap: 22px; align-items: stretch; }
.detail-image, .contact-panel, .content-card { margin: 0; border-radius: var(--radius-lg); background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-soft); overflow: hidden; }
.detail-image img { width: 100%; height: 100%; min-height: 430px; object-fit: cover; }
.contact-panel, .content-card { padding: clamp(22px, 3vw, 36px); }
.contact-panel p, .content-card p { color: var(--muted); }
.clean-list, .service-list { padding-left: 1.15rem; color: var(--muted); }
.clean-list li, .service-list li { margin: 7px 0; }
.two-column { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.site-footer { margin: clamp(26px, 4vw, 70px); margin-top: 10px; padding: 28px; border-radius: var(--radius-lg); background: #29382f; color: rgba(255,255,255,.82); }
.footer-top { display: flex; justify-content: space-between; gap: 24px; align-items: center; }
.footer-top img { width: 120px; background: #fff; border-radius: 14px; }
.footer-links { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.footer-links a { padding: 8px 11px; border-radius: 999px; background: rgba(255,255,255,.08); }
.source-note { margin: 18px 0 0; color: rgba(255,255,255,.62); font-size: .94rem; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width: 1350px) {
  .header-grid { grid-template-columns: 1fr; border-radius: 28px; justify-items: center; }
  .location-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .intro-strip { grid-template-columns: 1fr; }
}
@media (max-width: 1000px) {
  .page-frame { padding: 12px; }
  .site-shell { border-radius: 28px; }
  .site-header { padding: 14px; }
  .hero-alt, .detail-layout, .two-column { grid-template-columns: 1fr; }
  .hero-media, .hero-media img, .detail-image img { min-height: 330px; }
  .location-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .feature-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .hero, .section { padding: 26px 18px; }
  .location-grid, .intro-stats { grid-template-columns: 1fr; }
  .main-nav { justify-content: flex-start; overflow-x: auto; width: 100%; padding-bottom: 4px; }
  .main-nav a { white-space: nowrap; }
  .brand { width: 100%; justify-content: center; }
  .footer-top { align-items: flex-start; flex-direction: column; }
  .footer-links { justify-content: flex-start; }
}
@media (prefers-reduced-motion: reduce) {
  *, *:before, *:after { scroll-behavior: auto !important; transition: none !important; animation: none !important; }
  .reveal { opacity: 1; transform: none; }
}
