:root, [data-theme="light"] {
      --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
      --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
      --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
      --text-lg: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
      --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
      --text-2xl: clamp(2.2rem, 1.4rem + 3vw, 4.5rem);
      --space-1: 0.25rem;
      --space-2: 0.5rem;
      --space-3: 0.75rem;
      --space-4: 1rem;
      --space-5: 1.25rem;
      --space-6: 1.5rem;
      --space-8: 2rem;
      --space-10: 2.5rem;
      --space-12: 3rem;
      --space-16: 4rem;
      --space-20: 5rem;
      --space-24: 6rem;
      --radius-sm: 0.5rem;
      --radius-md: 1rem;
      --radius-lg: 1.5rem;
      --radius-xl: 2rem;
      --radius-full: 999px;
      --color-bg: #f6f2ec;
      --color-surface: rgba(255,255,255,0.68);
      --color-surface-2: rgba(255,255,255,0.82);
      --color-surface-offset: #ebe4da;
      --color-border: rgba(53,43,33,0.12);
      --color-divider: rgba(53,43,33,0.08);
      --color-text: #241d17;
      --color-text-muted: #6f655b;
      --color-text-faint: #998f85;
      --color-primary: #1C3489;
      --color-primary-hover: #324eb3;
      --color-primary-highlight: rgba(58,106,99,0.12);
      --color-accent: #b98655;
      --shadow-sm: 0 10px 30px rgba(40, 28, 17, 0.06);
      --shadow-lg: 0 30px 80px rgba(40, 28, 17, 0.12);
      --font-body: 'CoFoSans';
      --font-display: 'CoFoSans';
      --content-wide: 1180px;
      --transition: 220ms cubic-bezier(0.16, 1, 0.3, 1);
    }

    [data-theme="dark"] {
      --color-bg: #171411;
      --color-surface: rgba(33, 29, 25, 0.7);
      --color-surface-2: rgba(39, 35, 31, 0.86);
      --color-surface-offset: #221d19;
      --color-border: rgba(231,224,214,0.12);
      --color-divider: rgba(231,224,214,0.08);
      --color-text: #f1e9df;
      --color-text-muted: #c2b8ab;
      --color-text-faint: #91867a;
      --color-primary: #7eb3aa;
      --color-primary-hover: #93c4bc;
      --color-primary-highlight: rgba(126,179,170,0.12);
      --color-accent: #d2a06d;
      --shadow-sm: 0 10px 30px rgba(0, 0, 0, 0.2);
      --shadow-lg: 0 30px 80px rgba(0, 0, 0, 0.35);
    }

    @font-face {
  font-family: CoFoSans;
  src: url(/fonts/CoFoSans-Regular.5fs8RDZZ.woff2);
  font-weight: normal;
  font-style: normal;
}

    @font-face {
  font-family: Aristov;
  src: local('Aristov'), url('/fonts/aristov.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}


    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      min-height: 100vh;
      font-family: CoFoSans; /* set name */
  src: url(/fonts/CoFoSans-Regular.5fs8RDZZ.woff2); /* url of the font */;
      font-size: var(--text-base);
      line-height: 1.65;
      color: var(--color-text);
      background:
        radial-gradient(circle at top left, rgba(185,134,85,0.10), transparent 28%),
        radial-gradient(circle at 85% 15%, rgba(58,106,99,0.10), transparent 24%),
        var(--color-bg);
      overflow-x: hidden;
    }
    img, svg, iframe { display: block; max-width: 100%; }
    a { color: inherit; text-decoration: none; }
    button { font: inherit; border: 0; background: none; cursor: pointer; }
    :focus-visible { outline: 2px solid var(--color-primary); outline-offset: 3px; }

    .skip-link {
      position: absolute; left: 1rem; top: -3rem; z-index: 100;
      background: var(--color-primary); color: #fff; padding: 0.75rem 1rem; border-radius: var(--radius-sm);
    }
    .skip-link:focus { top: 1rem; }

    .label-carousel{--gap:16px;position:relative;width:100%;overflow:hidden}
    .label-carousel__viewport{overflow:hidden;width:100%;height:100%;}
    .label-carousel__track{display:flex;gap:var(--gap);will-change:transform;align-items:center}
    .label-carousel__slide{flex:0 0 clamp(220px,28vw,1360px);aspect-ratio:4/3;border-radius:16px;overflow:hidden;display:block;box-shadow:0 10px 30px rgba(0,0,0,.12);transform:translateZ(0)}
    .label-carousel__slide img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
    .label-carousel__slide:hover img{transform:scale(1.03)}


    .banner_img{
      width:100%;
      height:250px;
      object-fit:cover;
      display:block;
      margin-bottom: 1rem;
      border-radius: 15px;
      background-image: url(/img/07.jpg);
      background-repeat: no-repeat;
      background-position: center bottom;
    }

    .grid_image {
      border-radius: 15px;
    }

    .img_icon {
      width:75px;
      height:75px;
      object-fit:cover;
      justify-content: center;
      align-items: center;
      padding-bottom: 2rem;
    }

    .container { width: min(calc(100% - 2rem), var(--content-wide)); margin: 0 auto; }
    .site-header {
      position: sticky; top: 0; z-index: 20;
      backdrop-filter: blur(18px);
      background: color-mix(in srgb, var(--color-bg) 72%, transparent);
      border-bottom: 1px solid var(--color-divider);
    }
    .header-inner {
      display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
      min-height: 82px;
    }
    .logo { display: inline-flex; align-items: center; gap: 0.875rem; }
    .logo-mark {
      width: 46px; height: 46px; border-radius: 50%;
      display: grid; place-items: center; color: var(--color-primary);
      border: 1px solid var(--color-border);
      background: var(--color-surface-2);
      box-shadow: var(--shadow-sm);
      flex-shrink: 0;
    }
    .logo-copy span {
      display: block; font-size: var(--text-xs); letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-text-muted);
    }
    .logo-copy strong {
      display: block; font-family: var(--font-display); font-size: 1.7rem; font-weight: 600; letter-spacing: 0.03em;
    }
    .header-actions { display: flex; align-items: center; gap: 0.75rem; }
    .theme-toggle, .phone-chip {
      min-height: 44px; border: 1px solid var(--color-border); border-radius: var(--radius-full);
      background: var(--color-surface-2); display: inline-flex; align-items: center; justify-content: center;
      transition: transform var(--transition), background var(--transition), border-color var(--transition);
    }
    .theme-toggle { width: 44px; color: var(--color-text); }
    .phone-chip { padding: 0 1rem; font-size: var(--text-sm); font-weight: 600; }
    .theme-toggle:hover, .phone-chip:hover { transform: translateY(-1px); }

    main section { padding-block: clamp(4rem, 8vw, 7rem); }
    .hero { padding-top: clamp(3rem, 5vw, 5rem); 
    background-image: url("/img/hero_bg_01.png");
    }
    .hero-grid {
      display: grid; grid-template-columns: 1.2fr 0.9fr; gap: clamp(1.5rem, 4vw, 4rem); align-items: end;
    }
    .eyebrow {
      display: inline-flex; align-items: center; gap: 0.6rem; padding: 0.55rem 0.9rem;
      border-radius: var(--radius-full); background: var(--color-primary-highlight); color: var(--color-primary);
      font-size: var(--text-xs); letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700;
      margin-bottom: var(--space-5);
    }

    .hero_header {
      font-family: 'Aristov', sans-serif;
  font-size: 2.2rem;
  color: #222;
  padding: 1.2rem 1rem;

    }

    .hero h1, h2 {
      font-family: Aristov;  line-height: 0.95; letter-spacing: 0.01em; padding-bottom: 2rem;
    }
    .hero h1 { font-size: var(--text-2xl); max-width: 10ch; }
    .hero-lead {
      margin-top: var(--space-6); max-width: 58ch; color: var(--color-text-muted);
    }
    .hero-actions {
      display: flex; flex-wrap: wrap; gap: 0.9rem; margin-top: var(--space-8);
    }
    .btn {
      min-height: 50px; padding: 0 1.3rem; border-radius: var(--radius-full); display: inline-flex; align-items: center; justify-content: center;
      font-size: var(--text-sm); font-weight: 700; transition: transform var(--transition), background var(--transition), color var(--transition), border-color var(--transition);
    }
    .btn-primary { background: var(--color-primary); color: #fff; }
    .btn-primary:hover { background: var(--color-primary-hover); transform: translateY(-2px); }
    .btn-secondary { border: 1px solid var(--color-border); background: var(--color-surface-2); }
    .btn-secondary:hover { background: var(--color-surface); transform: translateY(-2px); }

    .hero-card {
      position: relative; padding: clamp(1.5rem, 3vw, 2rem); border-radius: var(--radius-xl);
      background: linear-gradient(180deg, var(--color-surface-2), var(--color-surface));
      border: 1px solid var(--color-border); box-shadow: var(--shadow-lg); overflow: hidden;
      min-height: 460px;
    }
    .hero-card::after {
      content: ""; position: absolute; inset: auto -10% -20% auto; width: 220px; height: 220px; border-radius: 50%;
      background: radial-gradient(circle, rgba(185,134,85,0.18), transparent 70%);
      pointer-events: none;
    }
    .hero-stats {
      display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.8rem; margin-top: auto;
    }
    .stat {
      padding: 1rem; border-radius: var(--radius-md); background: rgba(255,255,255,0.48); border: 1px solid var(--color-border);
      backdrop-filter: blur(8px);
    }
    .stat strong { display: block; font-size: 1.5rem; font-weight: 800; }
    .stat span { color: var(--color-text-muted); font-size: var(--text-sm); }
    .hero-note {
      display: inline-flex; margin-bottom: 1.25rem; color: var(--color-accent); font-size: var(--text-sm); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
    }
    .hero-card p { max-width: 28ch; color: var(--color-text-muted); }

    .section-head { display: grid; grid-template-columns: 0.85fr 1fr; gap: 2rem; align-items: end; margin-bottom: 2rem; }
    .section-head p { color: var(--color-text-muted); max-width: 52ch; }
    h2 { font-size: clamp(2rem, 1.3rem + 2vw, 3.5rem); }

    .features-grid {
      display: flex;
      column-gap: 15px;
    }
    .feature-card {
      padding: 1.4rem; border: 1px solid var(--color-border); border-radius: var(--radius-lg);
      background: var(--color-surface); box-shadow: var(--shadow-sm); min-height: 220px;
    }
    .feature-card.large { min-height: 320px; }
    .feature-kicker {
      color: var(--color-accent); font-size: var(--text-xs); letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; margin-bottom: 0.8rem;
    }
    .feature-card h3 {
      font-size: clamp(1.3rem, 1rem + 1vw, 2rem); line-height: 1.1; margin-bottom: 0.8rem; font-family: var(--font-display); font-weight: 600;
    }
    .feature-card p { color: var(--color-text-muted); max-width: 34ch; }

    .lifestyle-grid {
      display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem;
    }
    .lifestyle-item {
      padding: 1.35rem; border-radius: var(--radius-lg); background: var(--color-surface-2); border: 1px solid var(--color-border);
    }
    .lifestyle-item strong { display: block; margin-bottom: 0.6rem; font-size: 1.05rem; }
    .lifestyle-item p { color: var(--color-text-muted); }

    .timeline {
      display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1rem;
    }
    .timeline-step {
      padding-top: 1rem;
      padding: 1.3rem; border-top: 1px solid var(--color-border); background: #ffffff;
    }
    .timeline-step span {
      display: inline-block; margin-bottom: 0.8rem; color: var(--color-accent); font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700;
    }
    .timeline-step h3 { margin-bottom: 0.55rem; font-size: 1.15rem; }
    .timeline-step p { color: var(--color-text-muted); }

    .contacts-wrap {
      display: grid; grid-template-columns: 0.8fr 1.2fr; gap: 1rem; align-items: stretch;
    }
    .contacts-panel, .map-card {
      border: 1px solid var(--color-border); border-radius: var(--radius-xl); background: var(--color-surface); box-shadow: var(--shadow-sm);
    }
    .contacts-panel { padding: clamp(1.4rem, 3vw, 2rem); }
    .contact-list { display: grid; gap: 1rem; margin-top: 1.5rem; }
    .contact-item small {
      display: block; font-size: var(--text-xs); letter-spacing: 0.15em; text-transform: uppercase; color: var(--color-text-faint); margin-bottom: 0.35rem;
    }
    .contact-item a, .contact-item p { color: var(--color-text); font-weight: 600; }
    .contact-item p.subtext { color: var(--color-text-muted); font-weight: 500; margin-top: 0.25rem; }
    .map-card { overflow: hidden; min-height: 420px; }
    .map-card iframe { width: 100%; height: 100%; min-height: 420px; border: 0; }

    .footer {
      padding: 1.5rem 0 2.5rem; color: var(--color-text-muted); font-size: var(--text-sm);
    }
    .footer-inner {
      display: flex; align-items: center; justify-content: space-between; gap: 1rem; border-top: 1px solid var(--color-divider); padding-top: 1.5rem;
    }

    .reveal {
      opacity: 0; transform: translateY(24px); transition: opacity 700ms ease, transform 700ms ease;
    }
    .reveal.is-visible { opacity: 1; transform: translateY(0); }

    @media (max-width: 768px){.label-carousel__slide{flex-basis:78vw}}

    @media (max-width: 980px) {
      .hero-grid, .section-head, .features-grid, .lifestyle-grid, .timeline, .contacts-wrap {
        grid-template-columns: 1fr;
      }
      .hero h1 { max-width: 12ch; }
      .hero-card { min-height: auto; }
      .footer-inner { flex-direction: column; align-items: flex-start; }
    }

    @media (max-width: 640px) {
      .header-inner { min-height: 74px; }
      .phone-chip { display: none; }
      .hero-actions { flex-direction: column; align-items: stretch; }
      .btn { width: 100%; }
      .hero-stats { grid-template-columns: 1fr; }
    }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
      .reveal { opacity: 1; transform: none; }
    }