12 Commits

Author SHA1 Message Date
0eaa75bc62 Merge version_7_1782066118571 into main
Merge version_7_1782066118571 into main
2026-06-21 18:23:29 +00:00
kudinDmitriyUp
1db56f4ab4 Bob AI: Replaced hero section with HeroSplit for Dr. Pronteeva 2026-06-21 18:22:51 +00:00
eb32401008 Merge version_6_1782066011032 into main
Merge version_6_1782066011032 into main
2026-06-21 18:20:14 +00:00
455800f1d3 Update theme fonts 2026-06-21 18:20:11 +00:00
82db7b004f Merge version_5_1782065981663 into main
Merge version_5_1782065981663 into main
2026-06-21 18:19:48 +00:00
33ce004d10 Update theme colors 2026-06-21 18:19:42 +00:00
9bfa52f890 Merge version_4_1782065974070 into main
Merge version_4_1782065974070 into main
2026-06-21 18:19:37 +00:00
f43bf40293 Merge version_3_1782065955325 into main
Merge version_3_1782065955325 into main
2026-06-21 18:19:18 +00:00
0b08aefae5 Merge version_2_1782065942127 into main
Merge version_2_1782065942127 into main
2026-06-21 18:19:05 +00:00
4a3594cd66 Merge version_1_1782065490367 into main
Merge version_1_1782065490367 into main
2026-06-21 18:13:38 +00:00
f89c1736f6 Merge version_1_1782065490367 into main
Merge version_1_1782065490367 into main
2026-06-21 18:12:47 +00:00
6e5b68a3a8 Merge version_1_1782065490367 into main
Merge version_1_1782065490367 into main
2026-06-21 18:11:55 +00:00
10 changed files with 289 additions and 193 deletions

View File

@@ -1,19 +1,19 @@
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Montserrat:wght@400;500;600;700&display=swap');
@import "tailwindcss";
@import "./styles/masks.css";
@import "./styles/animations.css";
:root {
/* @colorThemes/lightTheme/grayNavyBlue */
--background: #efebe5;
--card: #f7f2ea;
--foreground: #000000;
--primary-cta: #000000;
--primary-cta-text: #efebe5;
--secondary-cta: #ffffff;
--secondary-cta-text: #000000;
--background: #f5f4ef;
--card: #dad6cd;
--foreground: #2a2928;
--primary-cta: #2a2928;
--primary-cta-text: #f5f4ef;
--secondary-cta: #ecebea;
--secondary-cta-text: #2a2928;
--accent: #ffffff;
--background-accent: #e1b875;
--background-accent: #c6b180;
/* @layout/border-radius/rounded */
--radius: 1.5rem;
@@ -88,7 +88,7 @@
--color-background-accent: var(--background-accent);
/* Fonts */
--font-sans: 'Roboto', sans-serif;
--font-sans: 'Inter', sans-serif;
--font-tight: "Inter Tight", sans-serif;
--font-mono: monospace;
@@ -137,7 +137,7 @@ body {
margin: 0;
background-color: var(--background);
color: var(--foreground);
font-family: 'Roboto', sans-serif;
font-family: 'Inter', sans-serif;
position: relative;
min-height: 100vh;
overscroll-behavior: none;
@@ -150,7 +150,7 @@ h3,
h4,
h5,
h6 {
font-family: 'Roboto', sans-serif;
font-family: 'Montserrat', sans-serif;
}
/* Default card/button styles. Template theme.css imports come after this file

View File

@@ -1,193 +1,36 @@
import AboutFeaturesSplit from '@/components/sections/about/AboutFeaturesSplit';
import ContactCta from '@/components/sections/contact/ContactCta';
import FaqTabbedAccordion from '@/components/sections/faq/FaqTabbedAccordion';
import FeaturesBento from '@/components/sections/features/FeaturesBento';
import HeroBillboardBrand from '@/components/sections/hero/HeroBillboardBrand';
import MetricsIconCards from '@/components/sections/metrics/MetricsIconCards';
import PricingCenteredCards from '@/components/sections/pricing/PricingCenteredCards';
import TestimonialColumnMarqueeCards from '@/components/sections/testimonial/TestimonialColumnMarqueeCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
// AUTO-GENERATED shell by per-section-migrate.
// Section bodies live in ./<PageBase>/sections/<X>.tsx. Edit the section
// files directly. Non-block content (wrappers, non-inlinable sections) is
// preserved inline; extracted section blocks become <XSection/> refs.
export default function HomePage() {
import React from 'react';
import HeroSection from './HomePage/sections/Hero';
import AboutSection from './HomePage/sections/About';
import FeaturesSection from './HomePage/sections/Features';
import MetricsSection from './HomePage/sections/Metrics';
import PricingSection from './HomePage/sections/Pricing';
import TestimonialsSection from './HomePage/sections/Testimonials';
import FaqSection from './HomePage/sections/Faq';
import ContactSection from './HomePage/sections/Contact';
export default function HomePage(): React.JSX.Element {
return (
<>
<div id="hero" data-section="hero">
<SectionErrorBoundary name="hero">
<HeroBillboardBrand
brand="Ваша идеальная улыбка — наша цель"
description="Профессиональная ортодонтия для всей семьи. Современные технологии и бережный подход к здоровью ваших зубов."
primaryButton={{
text: "Записаться на прием", href: "#contact"}}
secondaryButton={{
text: "Узнать о нас", href: "#about"}}
imageSrc="http://img.b2bpic.net/free-photo/full-equiped-medical-cabinet_1303-23918.jpg"
/>
</SectionErrorBoundary>
</div>
<>
<HeroSection />
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutFeaturesSplit
tag="О нас"
title="Современная ортодонтия"
description="Мы используем передовые методы лечения, чтобы сделать вашу улыбку красивой и здоровой. Комфорт пациентов — наш приоритет."
items={[
{
icon: "CheckCircle", title: "Опытные врачи", description: "Специалисты с более чем 10-летним стажем."},
{
icon: "Shield", title: "Гарантия результата", description: "Контроль на всех этапах лечения."},
{
icon: "Zap", title: "Современное оборудование", description: "Цифровая диагностика и планирование."},
]}
imageSrc="http://img.b2bpic.net/free-photo/cheerful-medic-standing-with-arms-crossed_23-2147767252.jpg"
/>
</SectionErrorBoundary>
</div>
<AboutSection />
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesBento
tag="Услуги"
title="Что мы предлагаем"
description="Комплексный подход к исправлению прикуса."
features={[
{
title: "Брекет-системы", description: "Эффективные решения для любых случаев.", bentoComponent: "media-stack", mediaItems: [
{
imageSrc: "http://img.b2bpic.net/free-photo/side-view-man-posing-with-dental-gems_23-2151212425.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/dental-equipment-placed-table_1150-19616.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/glasses-dentist-dental-office_627829-9495.jpg"},
],
},
{
title: "Элайнеры", description: "Незаметное исправление прикуса.", bentoComponent: "media-stack", mediaItems: [
{
imageSrc: "http://img.b2bpic.net/free-photo/dentist-examining-man-teeth-with-dental-explorer-dental-mirror_651396-2613.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/closeup-snapshot-man-s-face-dentist-s-hands-putting-rubber-bands-brackets_651396-3132.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/happy-girl-is-smiling-with-braces-ray-laser-it_633478-32.jpg"},
],
},
{
title: "Цифровая диагностика", description: "Точность планирования лечения.", bentoComponent: "media-stack", mediaItems: [
{
imageSrc: "http://img.b2bpic.net/free-photo/dentistry-team-analyzing-teeth-x-ray-green-screen-monitor-dentist-office-specialist-man-nurse-working-with-isolated-mockup-template-radiography-teethcare_482257-38493.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/dentist-showing-tablet-teeth-x-ray-reviewing-it-with-patient-doctor-nurse-working-together-modern-stomatological-clinic-explaining-old-woman-radiography-tooth-using-notebook-display_482257-13065.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/orthodontist-using-horizontal-green-screen-tablet-oral-care-dentistry-woman-working-as-dentist-with-chroma-key-isolated-mockup-template-while-looking-teeth-scan_482257-29381.jpg"},
],
},
]}
/>
</SectionErrorBoundary>
</div>
<FeaturesSection />
<div id="metrics" data-section="metrics">
<SectionErrorBoundary name="metrics">
<MetricsIconCards
tag="Статистика"
title="Результаты клиники"
description="Наш опыт в цифрах."
metrics={[
{
icon: "Users", title: "Счастливых пациентов", value: "2500+"},
{
icon: "Award", title: "Лет практики", value: "12"},
{
icon: "Smile", title: "Успешных кейсов", value: "100%"},
]}
/>
</SectionErrorBoundary>
</div>
<MetricsSection />
<div id="pricing" data-section="pricing">
<SectionErrorBoundary name="pricing">
<PricingCenteredCards
tag="Цены"
title="Стоимость лечения"
description="Прозрачное ценообразование без скрытых платежей."
plans={[
{
tag: "Базовый", price: "от 50 000 ₽", description: "Классические металлические брекеты.", features: [
"Диагностика", "Установка", "Гарантия"],
primaryButton: {
text: "Выбрать", href: "#contact"},
},
{
tag: "Комфорт", price: "от 120 000 ₽", description: "Керамические брекеты для эстетики.", features: [
"Все преимущества базового", "Меньше визитов", "Эстетичность"],
primaryButton: {
text: "Выбрать", href: "#contact"},
},
{
tag: "Премиум", price: "от 250 000 ₽", description: "Прозрачные элайнеры.", features: [
"Индивидуальный план", "Незаметно", "Макс. комфорт"],
primaryButton: {
text: "Выбрать", href: "#contact"},
},
]}
/>
</SectionErrorBoundary>
</div>
<PricingSection />
<div id="testimonials" data-section="testimonials">
<SectionErrorBoundary name="testimonials">
<TestimonialColumnMarqueeCards
tag="Отзывы"
title="Что говорят наши пациенты"
description="Нам доверяют сотни улыбок."
testimonials={[
{
name: "Анна С.", role: "Пациент", quote: "Очень довольна результатом! Улыбка теперь идеальная.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-face-portrait-smiling-happy-woman-hold-hands-face-looking-camera-with-satisfied-cheerful-face-watch-something-interesting-white-background_176420-54393.jpg"},
{
name: "Игорь В.", role: "Пациент", quote: "Профессиональный подход и вежливый персонал.", imageSrc: "http://img.b2bpic.net/free-photo/closeup-portrait-young-beautiful-smiling-female-trendy-summer-clothes-sexy-carefree-woman-posing-near-blue-wall-studio-positive-blond-model-having-fun-going-crazy-cheerful-happy_158538-20490.jpg"},
{
name: "Мария П.", role: "Пациент", quote: "Все объяснили доступно, лечение прошло комфортно.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-young-fit-person-jogging-by-sea_329181-16763.jpg"},
{
name: "Дмитрий К.", role: "Пациент", quote: "Рекомендую клинику всем знакомым!", imageSrc: "http://img.b2bpic.net/free-photo/female-patient-looking-mirror-dentist-s-office_23-2148985783.jpg"},
{
name: "Елена М.", role: "Пациент", quote: "Результат превзошел все мои ожидания.", imageSrc: "http://img.b2bpic.net/free-photo/happy-mature-woman-talking-her-doctor-medical-clinic_637285-9073.jpg"},
]}
/>
</SectionErrorBoundary>
</div>
<TestimonialsSection />
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqTabbedAccordion
tag="FAQ"
title="Часто задаваемые вопросы"
description="Ответы на популярные вопросы."
categories={[
{
name: "Лечение", items: [
{
question: "Больно ли ставить брекеты?", answer: "Нет, процесс установки абсолютно безболезненный."},
{
question: "Сколько длится лечение?", answer: "Зависит от сложности, в среднем от 12 до 24 месяцев."},
],
},
]}
/>
</SectionErrorBoundary>
</div>
<FaqSection />
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Запись"
text="Готовы сделать шаг к идеальной улыбке?"
primaryButton={{
text: "Записаться онлайн", href: "#"}}
secondaryButton={{
text: "Позвонить нам", href: "tel:+78000000000"}}
/>
</SectionErrorBoundary>
</div>
<ContactSection />
</>
);
}

View File

@@ -0,0 +1,29 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "about" section.
import React from 'react';
import AboutFeaturesSplit from '@/components/sections/about/AboutFeaturesSplit';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function AboutSection(): React.JSX.Element {
return (
<div id="about" data-section="about">
<SectionErrorBoundary name="about">
<AboutFeaturesSplit
tag="О нас"
title="Современная ортодонтия"
description="Мы используем передовые методы лечения, чтобы сделать вашу улыбку красивой и здоровой. Комфорт пациентов — наш приоритет."
items={[
{
icon: "CheckCircle", title: "Опытные врачи", description: "Специалисты с более чем 10-летним стажем."},
{
icon: "Shield", title: "Гарантия результата", description: "Контроль на всех этапах лечения."},
{
icon: "Zap", title: "Современное оборудование", description: "Цифровая диагностика и планирование."},
]}
imageSrc="http://img.b2bpic.net/free-photo/cheerful-medic-standing-with-arms-crossed_23-2147767252.jpg"
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,23 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "contact" section.
import React from 'react';
import ContactCta from '@/components/sections/contact/ContactCta';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function ContactSection(): React.JSX.Element {
return (
<div id="contact" data-section="contact">
<SectionErrorBoundary name="contact">
<ContactCta
tag="Запись"
text="Готовы сделать шаг к идеальной улыбке?"
primaryButton={{
text: "Записаться онлайн", href: "#"}}
secondaryButton={{
text: "Позвонить нам", href: "tel:+78000000000"}}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,30 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "faq" section.
import React from 'react';
import FaqTabbedAccordion from '@/components/sections/faq/FaqTabbedAccordion';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FaqSection(): React.JSX.Element {
return (
<div id="faq" data-section="faq">
<SectionErrorBoundary name="faq">
<FaqTabbedAccordion
tag="FAQ"
title="Часто задаваемые вопросы"
description="Ответы на популярные вопросы."
categories={[
{
name: "Лечение", items: [
{
question: "Больно ли ставить брекеты?", answer: "Нет, процесс установки абсолютно безболезненный."},
{
question: "Сколько длится лечение?", answer: "Зависит от сложности, в среднем от 12 до 24 месяцев."},
],
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,52 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "features" section.
import React from 'react';
import FeaturesBento from '@/components/sections/features/FeaturesBento';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function FeaturesSection(): React.JSX.Element {
return (
<div id="features" data-section="features">
<SectionErrorBoundary name="features">
<FeaturesBento
tag="Услуги"
title="Что мы предлагаем"
description="Комплексный подход к исправлению прикуса."
features={[
{
title: "Брекет-системы", description: "Эффективные решения для любых случаев.", bentoComponent: "media-stack", mediaItems: [
{
imageSrc: "http://img.b2bpic.net/free-photo/side-view-man-posing-with-dental-gems_23-2151212425.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/dental-equipment-placed-table_1150-19616.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/glasses-dentist-dental-office_627829-9495.jpg"},
],
},
{
title: "Элайнеры", description: "Незаметное исправление прикуса.", bentoComponent: "media-stack", mediaItems: [
{
imageSrc: "http://img.b2bpic.net/free-photo/dentist-examining-man-teeth-with-dental-explorer-dental-mirror_651396-2613.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/closeup-snapshot-man-s-face-dentist-s-hands-putting-rubber-bands-brackets_651396-3132.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/happy-girl-is-smiling-with-braces-ray-laser-it_633478-32.jpg"},
],
},
{
title: "Цифровая диагностика", description: "Точность планирования лечения.", bentoComponent: "media-stack", mediaItems: [
{
imageSrc: "http://img.b2bpic.net/free-photo/dentistry-team-analyzing-teeth-x-ray-green-screen-monitor-dentist-office-specialist-man-nurse-working-with-isolated-mockup-template-radiography-teethcare_482257-38493.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/dentist-showing-tablet-teeth-x-ray-reviewing-it-with-patient-doctor-nurse-working-together-modern-stomatological-clinic-explaining-old-woman-radiography-tooth-using-notebook-display_482257-13065.jpg"},
{
imageSrc: "http://img.b2bpic.net/free-photo/orthodontist-using-horizontal-green-screen-tablet-oral-care-dentistry-woman-working-as-dentist-with-chroma-key-isolated-mockup-template-while-looking-teeth-scan_482257-29381.jpg"},
],
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,19 @@
// Created by add_section_from_catalog (HeroSplit).
import React from 'react';
import HeroSplit from '@/components/sections/hero/HeroSplit';
export default function HeroSection(): React.JSX.Element {
return (
<div data-webild-section="hero" id="hero">
<HeroSplit
primaryButton={{"href":"#contact","text":"Записаться на прием"}}
title="Пронтеева Виктория Александровна"
imageSrc="https://images.unsplash.com/photo-1559839734-2b71ea197ec2?q=80&w=2070&auto=format&fit=crop"
secondaryButton={{"href":"#about","text":"Узнать больше"}}
tag="Врач-ортодонт"
description="Индивидуальный подход к созданию вашей идеальной улыбки. Современные методы лечения и бережное отношение к здоровью ваших зубов."
/>
</div>
);
}

View File

@@ -0,0 +1,28 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "metrics" section.
import React from 'react';
import MetricsIconCards from '@/components/sections/metrics/MetricsIconCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function MetricsSection(): React.JSX.Element {
return (
<div id="metrics" data-section="metrics">
<SectionErrorBoundary name="metrics">
<MetricsIconCards
tag="Статистика"
title="Результаты клиники"
description="Наш опыт в цифрах."
metrics={[
{
icon: "Users", title: "Счастливых пациентов", value: "2500+"},
{
icon: "Award", title: "Лет практики", value: "12"},
{
icon: "Smile", title: "Успешных кейсов", value: "100%"},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,40 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "pricing" section.
import React from 'react';
import PricingCenteredCards from '@/components/sections/pricing/PricingCenteredCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function PricingSection(): React.JSX.Element {
return (
<div id="pricing" data-section="pricing">
<SectionErrorBoundary name="pricing">
<PricingCenteredCards
tag="Цены"
title="Стоимость лечения"
description="Прозрачное ценообразование без скрытых платежей."
plans={[
{
tag: "Базовый", price: "от 50 000 ₽", description: "Классические металлические брекеты.", features: [
"Диагностика", "Установка", "Гарантия"],
primaryButton: {
text: "Выбрать", href: "#contact"},
},
{
tag: "Комфорт", price: "от 120 000 ₽", description: "Керамические брекеты для эстетики.", features: [
"Все преимущества базового", "Меньше визитов", "Эстетичность"],
primaryButton: {
text: "Выбрать", href: "#contact"},
},
{
tag: "Премиум", price: "от 250 000 ₽", description: "Прозрачные элайнеры.", features: [
"Индивидуальный план", "Незаметно", "Макс. комфорт"],
primaryButton: {
text: "Выбрать", href: "#contact"},
},
]}
/>
</SectionErrorBoundary>
</div>
);
}

View File

@@ -0,0 +1,32 @@
// AUTO-GENERATED by per-section-migrate. Edit freely — Bob will treat this
// file as the canonical source for the "testimonials" section.
import React from 'react';
import TestimonialColumnMarqueeCards from '@/components/sections/testimonial/TestimonialColumnMarqueeCards';
import SectionErrorBoundary from "@/components/ui/SectionErrorBoundary";
export default function TestimonialsSection(): React.JSX.Element {
return (
<div id="testimonials" data-section="testimonials">
<SectionErrorBoundary name="testimonials">
<TestimonialColumnMarqueeCards
tag="Отзывы"
title="Что говорят наши пациенты"
description="Нам доверяют сотни улыбок."
testimonials={[
{
name: "Анна С.", role: "Пациент", quote: "Очень довольна результатом! Улыбка теперь идеальная.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-face-portrait-smiling-happy-woman-hold-hands-face-looking-camera-with-satisfied-cheerful-face-watch-something-interesting-white-background_176420-54393.jpg"},
{
name: "Игорь В.", role: "Пациент", quote: "Профессиональный подход и вежливый персонал.", imageSrc: "http://img.b2bpic.net/free-photo/closeup-portrait-young-beautiful-smiling-female-trendy-summer-clothes-sexy-carefree-woman-posing-near-blue-wall-studio-positive-blond-model-having-fun-going-crazy-cheerful-happy_158538-20490.jpg"},
{
name: "Мария П.", role: "Пациент", quote: "Все объяснили доступно, лечение прошло комфортно.", imageSrc: "http://img.b2bpic.net/free-photo/close-up-young-fit-person-jogging-by-sea_329181-16763.jpg"},
{
name: "Дмитрий К.", role: "Пациент", quote: "Рекомендую клинику всем знакомым!", imageSrc: "http://img.b2bpic.net/free-photo/female-patient-looking-mirror-dentist-s-office_23-2148985783.jpg"},
{
name: "Елена М.", role: "Пациент", quote: "Результат превзошел все мои ожидания.", imageSrc: "http://img.b2bpic.net/free-photo/happy-mature-woman-talking-her-doctor-medical-clinic_637285-9073.jpg"},
]}
/>
</SectionErrorBoundary>
</div>
);
}