/* Theme Name: Windowserv Theme URI: https://windowserv.demofaino.site/ Author: Vital Author URI: https://github.com/vitaltsud Description: Кастомная тема для проекта Windowserv с автоматическим деплоем Version: 1.0.21 License: GNU General Public License v2 or later License URI: http://www.gnu.org/licenses/gpl-2.0.html Text Domain: windowserv Tags: custom, responsive, modern This theme, like WordPress, is licensed under the GPL. */ /* ═══════════════════════════════════════════════════════════ MAIN STYLES ═══════════════════════════════════════════════════════════ */ :root { --primary-color: #2c3e50; --secondary-color: #3498db; --accent-color: #e74c3c; --text-color: #333; --light-bg: #f8f9fa; --white: #ffffff; --gray: #95a5a6; --dark-gray: #34495e; } * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; font-size: 16px; line-height: 1.6; color: var(--text-color); background: var(--white); } /* Global link styles */ a { color: var(--secondary-color); text-decoration: none; transition: color 0.3s ease; } a:hover { color: var(--accent-color); text-decoration: none; } a:visited { color: var(--secondary-color); } a:active { color: var(--accent-color); } /* Убираем автоматический padding-top от WordPress для admin bar */ body.admin-bar { padding-top: 0 !important; margin-top: 0 !important; } .container { max-width: 1200px; margin: 0 auto; padding: 0 20px; } /* ═══════════════════════════════════════════════════════════ ХЛЕБНЫЕ КРОШКИ ═══════════════════════════════════════════════════════════ */ .breadcrumbs { background: var(--white); padding: 15px 0; border-bottom: 1px solid #e0e0e0; } .breadcrumbs-list { display: flex; flex-wrap: wrap; list-style: none; padding: 0; margin: 0; align-items: center; } .breadcrumb-item { display: flex; align-items: center; font-size: 14px; color: var(--gray); } .breadcrumb-item:not(:last-child)::after { content: '/'; margin: 0 10px; color: var(--gray); } .breadcrumb-item a { color: var(--secondary-color); text-decoration: none; } .breadcrumb-item a:hover { color: var(--primary-color); text-decoration: underline; } .breadcrumb-current { color: var(--primary-color); font-weight: 500; } /* ═══════════════════════════════════════════════════════════ ШАПКА САЙТА ═══════════════════════════════════════════════════════════ */ .site-header { background: var(--white) !important; padding: 15px 0 10px 0; box-shadow: none; border-top: 2px solid var(--secondary-color); } /* Desktop Header - не sticky */ .site-header-desktop { position: relative; z-index: 9999; background: var(--white) !important; } /* Sticky для Mobile Header */ .site-header-mobile { position: sticky; top: 0; z-index: 9999; background: var(--primary-color) !important; } /* WordPress Admin Bar support для Mobile Header */ @media screen and (max-width: 782px) { .admin-bar .site-header-mobile { top: 46px; } } /* Desktop Header - показываем только на десктопе */ .site-header-desktop { display: block; } /* Mobile Header - скрываем на десктопе */ .site-header-mobile { display: none; } /* Стили для Desktop Header - применяются только к desktop версии */ .site-header-desktop .header-content { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px; } .site-header-desktop .logo-section { display: flex !important; align-items: center; gap: 15px; flex: 1; min-width: 0; } .site-header-desktop .logo-link { display: flex; flex-direction: row; align-items: center; gap: 12px; } .site-header-desktop .logo-svg { max-height: 50px; max-width: 150px; height: auto; flex-shrink: 0; } .site-header-desktop .logo-text-container { display: flex; flex-direction: column; justify-content: center; line-height: 1.2; } .site-header-desktop .logo-text { color: #0f5692; font-size: 24px; font-weight: 600; white-space: nowrap; } .site-header-desktop .logo-tagline { color: #000000 !important; } .site-header-mobile .logo-tagline { color: var(--white) !important; } .site-header-desktop .header-phone { display: flex; align-items: center; gap: 5px; } .site-header-desktop .header-phone-label { display: inline !important; font-size: 16px; font-weight: 500; color: var(--text-color); } .site-header-desktop .header-phone a { font-size: 18px; font-weight: 600; color: var(--text-color); text-decoration: none; } .site-header-desktop .header-cta { display: block; } .site-header-desktop .header-cta .btn, .site-header-desktop .btn-primary { display: inline-block; padding: 12px 30px; border: 2px solid var(--secondary-color); border-radius: 5px; font-size: 16px; font-weight: 600; text-decoration: none; cursor: pointer; background: var(--secondary-color); color: var(--white); transition: none; } /* Убеждаемся, что кнопка синяя */ .site-header-desktop .header-cta .btn-primary { background: var(--secondary-color) !important; border-color: var(--secondary-color) !important; color: var(--white) !important; } .site-header-desktop .header-cta .btn:hover, .site-header-desktop .btn-primary:hover { background: var(--accent-color); border-color: var(--accent-color); color: var(--white); } /* Стили для Mobile Header - применяются только к mobile версии */ .site-header-mobile .header-content { display: flex; flex-direction: row; gap: 8px; align-items: center; justify-content: space-between; flex-wrap: nowrap; overflow: hidden; } .site-header-mobile .header-hamburger-wrapper { display: flex; align-items: center; justify-content: center; flex-shrink: 0; order: 1; margin-right: 8px; margin-left: 0; align-self: center; width: 32px; height: 32px; } .site-header-mobile .header-hamburger { display: flex; flex-direction: column; justify-content: center; align-items: center; flex-shrink: 0; width: 100%; height: 100%; padding: 0; margin: 0; border: none; background: transparent; position: relative; gap: 4px; } .site-header-mobile .logo-section { flex-direction: row; align-items: center; gap: 6px; flex: 0 0 auto; min-width: 0; order: 2; margin-right: auto; } /* Скрыть текст и теглайн лого на мобильном — только иконка */ .site-header-mobile .logo-section .logo-link > div, .site-header-mobile .logo-section .logo-text, .site-header-mobile .logo-section .logo-tagline { display: none !important; } .site-header-mobile .logo, .site-header-mobile .company-name { display: none !important; } .site-header-mobile .header-phone { display: flex; flex-direction: row; align-items: center; gap: 0; flex-shrink: 1; min-width: 0; order: 3; margin-left: auto; margin-right: 8px; } .site-header-mobile .header-phone-label { display: none; } .site-header-mobile .header-cta { flex-shrink: 0; order: 4; } /* Цвета для мобильного хедера - темный фон, светлые элементы */ .site-header-mobile { background: var(--primary-color) !important; color: var(--white) !important; } .site-header-mobile .logo-text { color: var(--white) !important; } .site-header-mobile .header-phone a { color: var(--white) !important; } .site-header-mobile .header-phone { color: var(--white) !important; } .site-header-mobile .header-hamburger span { background: var(--white) !important; width: 22px !important; height: 3px !important; margin: 0 !important; display: block !important; } .site-header-mobile .header-cta .btn, .site-header-mobile .btn-primary { background: var(--secondary-color) !important; border-color: var(--secondary-color) !important; color: var(--white) !important; } /* Логотип в мобильном хедере - высота 40px и белый цвет на темном фоне */ .site-header-mobile .logo-link img, .site-header-mobile .custom-logo-link img, .site-header-mobile .custom-logo { filter: brightness(0) invert(1); /* Делает логотип белым на темном фоне */ opacity: 1; max-height: 40px !important; height: 40px !important; width: auto; max-width: none; } @media (max-width: 768px) { .site-header-desktop { display: none !important; } .site-header-mobile { display: block !important; } } /* Убеждаемся, что на десктопе фон белый */ @media (min-width: 769px) { .site-header { background: var(--white) !important; color: var(--text-color) !important; } } /* Общие стили для хедера - базовые, не конфликтующие */ .mobile-header-brand { display: none; } .logo-link { display: flex; flex-direction: row; text-decoration: none; align-items: center; gap: 10px; align-items: center; gap: 12px; cursor: pointer; /* Ensure entire block is clickable */ width: 100%; max-width: fit-content; } .logo-link img, .logo-link .custom-logo, .logo-svg { max-height: 50px; max-width: 150px; height: auto; width: auto; display: block; object-fit: contain; flex-shrink: 0; } .logo-text-container { display: flex; flex-direction: column; line-height: 1.2; justify-content: center; } .logo-text { color: #0f5692; font-size: 24px; font-weight: 600; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; white-space: nowrap; line-height: 1.2; } .logo-icon { font-size: 32px; font-weight: 700; color: var(--text-color); line-height: 1; letter-spacing: -0.5px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; position: relative; } .logo-icon::after { content: '®'; font-size: 10px; position: absolute; top: -3px; right: -12px; font-weight: normal; } .logo-tagline { font-size: 12px; color: #000000 !important; font-weight: 400; margin-top: 2px; letter-spacing: 0.3px; display: block; line-height: 1.2; } .company-name { display: flex; flex-direction: column; } .company-title { font-size: 22px; font-weight: 700; color: var(--text-color); margin: 0; line-height: 1.2; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; } .company-mission { font-size: 12px; color: var(--secondary-color); margin: 4px 0 0 0; font-weight: 500; line-height: 1.3; } .header-info { display: flex; align-items: center; gap: 30px; } .header-phone { display: flex; align-items: center; gap: 5px; } .header-phone-label { font-size: 16px; font-weight: 500; color: var(--text-color); } .header-phone a { font-size: 18px; font-weight: 600; color: var(--secondary-color); text-decoration: none; } /* ═══════════════════════════════════════════════════════════ НАВІГАЦІЯ ═══════════════════════════════════════════════════════════ */ .main-navigation { background: var(--primary-color); isolation: isolate; } /* Sticky для Desktop Navigation - идет после хедера */ .main-navigation-desktop { position: sticky; top: 0; z-index: 9998; background: var(--primary-color); } /* Навигация должна быть ниже хедера при прокрутке */ .site-header-desktop + .main-navigation-desktop { top: 0; } /* Wrapper для навигации с кнопкой */ .main-navigation-desktop .nav-wrapper { display: flex; align-items: center; justify-content: space-between; gap: 20px; } .main-navigation-desktop .nav-menu, .main-navigation-desktop #primary-menu, .main-navigation-desktop .menu { flex: 1; } /* Кнопка в sticky меню - скрыта по умолчанию */ .main-navigation-desktop .nav-cta { display: none; margin-left: auto; padding: 0 0 0 20px; opacity: 0; visibility: hidden; transition: opacity 0.3s ease, visibility 0.3s ease; } /* Показываем кнопку только когда меню sticky и прокрутка вниз */ .main-navigation-desktop.is-sticky.show-button .nav-cta { display: block; opacity: 1; visibility: visible; } .main-navigation-desktop .nav-btn { padding: 8px 20px !important; font-size: 14px !important; line-height: 1.4 !important; height: auto !important; white-space: nowrap; border: 2px solid var(--secondary-color); border-radius: 5px; background: var(--secondary-color) !important; color: var(--white) !important; text-decoration: none; font-weight: 600; } .main-navigation-desktop .nav-btn:hover { background: var(--accent-color) !important; border-color: var(--accent-color) !important; color: var(--white) !important; } /* WordPress Admin Bar support для Desktop Navigation */ .admin-bar .main-navigation-desktop { top: 0; } @media screen and (max-width: 782px) { .admin-bar .main-navigation-desktop { top: 0; } } /* Sticky для Mobile Navigation - идет после хедера */ .main-navigation-mobile { position: sticky; top: 0; z-index: 9998; background: var(--primary-color); } /* Навигация должна быть ниже хедера при прокрутке */ .site-header-mobile + .main-navigation-mobile { top: 0; } /* WordPress Admin Bar support для Mobile Navigation */ .admin-bar .main-navigation-mobile { top: 0; } @media screen and (max-width: 782px) { .admin-bar .main-navigation-mobile { top: 0; } } /* Desktop Navigation - показываем только на десктопе */ .main-navigation-desktop { display: block; } /* Mobile Navigation - скрываем на десктопе */ .main-navigation-mobile { display: none; } /* Стили для Desktop Navigation - применяются только к desktop версии */ .main-navigation-desktop .container { display: flex; align-items: center; justify-content: center; position: relative; } .main-navigation-desktop .nav-menu, .main-navigation-desktop #primary-menu, .main-navigation-desktop .menu { list-style: none; display: flex; gap: 0; justify-content: center; margin: 0; padding: 0; position: relative; z-index: 10001; } .main-navigation-desktop .nav-item, .main-navigation-desktop .menu-item { list-style: none; margin: 0; padding: 0; position: relative; } .main-navigation-desktop .nav-item a, .main-navigation-desktop .menu-item a { display: block; padding: 15px 25px; color: var(--white); text-decoration: none; font-weight: 500; } .main-navigation-desktop .nav-item:hover a, .main-navigation-desktop .menu-item:hover > a { background: var(--secondary-color); } .main-navigation-desktop .nav-item.active a, .main-navigation-desktop .menu-item.current-menu-item > a { background: var(--accent-color); } /* Highlight parent menu item only if it contains the current page */ .main-navigation-desktop .menu-item.current-menu-ancestor > a { background: var(--accent-color); } /* Don't highlight menu items with children unless they are actually current or ancestor */ .main-navigation-desktop .menu-item-has-children:not(.current-menu-item):not(.current-menu-ancestor) > a { background: transparent; } /* Dropdown Menu для Desktop Navigation */ .main-navigation-desktop .nav-item-dropdown, .main-navigation-desktop .menu-item-has-children { position: relative; pointer-events: auto; } .main-navigation-desktop .dropdown-toggle { display: flex; align-items: center; gap: 5px; } .main-navigation-desktop .dropdown-arrow { font-size: 10px; } .main-navigation-desktop .nav-item-dropdown:hover .dropdown-arrow, .main-navigation-desktop .menu-item-has-children:hover .dropdown-arrow { transform: rotate(180deg); } .main-navigation-desktop .dropdown-menu, .main-navigation-desktop .sub-menu { position: absolute; top: 100%; left: 0; background: var(--primary-color) !important; background-color: var(--primary-color) !important; min-width: 250px; max-height: 70vh; overflow-y: auto; list-style: none; padding: 0; margin: 0; opacity: 0; visibility: hidden; z-index: 99999 !important; border: none; pointer-events: none; display: block; } .main-navigation-desktop .nav-item-dropdown:hover .dropdown-menu, .main-navigation-desktop .menu-item-has-children:hover > .sub-menu { opacity: 1 !important; visibility: visible !important; pointer-events: auto !important; } .main-navigation-desktop .dropdown-menu a, .main-navigation-desktop .sub-menu a { padding-left: 20px; background: var(--primary-color) !important; } .main-navigation-desktop .dropdown-menu a:hover, .main-navigation-desktop .sub-menu a:hover { background: var(--secondary-color) !important; } .main-navigation-desktop .dropdown-menu li.active a, .main-navigation-desktop .sub-menu li.current-menu-item > a { background: var(--accent-color) !important; } /* Стили для Mobile Navigation - применяются только к mobile версии */ .main-navigation-mobile .container { display: flex; align-items: center; justify-content: center; position: relative; } .main-navigation-mobile .mobile-menu-header { display: none; position: fixed; top: 0; left: 0; width: 100%; background: var(--primary-color); padding: 15px 20px; z-index: 1002; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(255, 255, 255, 0.1); } .main-navigation-mobile .mobile-menu-header.active { display: flex; } .main-navigation-mobile .nav-menu, .main-navigation-mobile #primary-menu, .main-navigation-mobile .menu { display: none !important; position: fixed; top: 60px; left: 0; width: 100%; height: calc(100vh - 60px); background: var(--primary-color); flex-direction: column; padding: 20px 20px 100px; overflow-y: auto; z-index: 1000; list-style: none; margin: 0; } .main-navigation-mobile .nav-menu.active, .main-navigation-mobile #primary-menu.active, .main-navigation-mobile .menu.active { display: flex !important; } .main-navigation-mobile .mobile-menu-footer { display: none; position: fixed; bottom: 0; left: 0; width: 100%; background: var(--primary-color); padding: 20px; border-top: 2px solid rgba(255, 255, 255, 0.2); z-index: 1001; } .main-navigation-mobile .mobile-menu-footer.active { display: block; } .main-navigation-mobile .mobile-menu-toggle { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); display: flex; background: transparent; border: none; cursor: pointer; padding: 10px; z-index: 10002; width: 32px; height: 32px; flex-direction: column; justify-content: space-around; } @media (max-width: 768px) { .main-navigation-desktop { display: none !important; } .main-navigation-mobile { display: block !important; } } .main-navigation .container { display: flex; align-items: center; justify-content: center; position: relative; } .mobile-menu-toggle { display: none; position: absolute; top: 50%; transform: translateY(-50%); background: transparent; border: none; cursor: pointer; padding: 10px; z-index: 10002; width: 32px; height: 32px; flex-direction: column; justify-content: space-around; } .mobile-menu-toggle span { display: block; width: 22px; height: 3px; background: var(--white); border-radius: 2px; transition: all 0.3s; margin: 0; } .mobile-menu-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(8px, 8px); } .mobile-menu-toggle.active span:nth-child(2) { opacity: 0; } .mobile-menu-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(7px, -7px); } /* Общие стили для навигации удалены - используются только специфичные для desktop/mobile */ /* Dropdown Menu */ .nav-item-dropdown, .menu-item-has-children, .main-navigation .nav-item-dropdown, .main-navigation .menu-item-has-children { position: relative; pointer-events: auto; } .dropdown-toggle { display: flex; align-items: center; gap: 5px; } .dropdown-arrow { font-size: 10px; } .nav-item-dropdown:hover .dropdown-arrow { transform: rotate(180deg); } /* Базовые стили для выпадающих меню - как в статике */ .dropdown-menu, .sub-menu, .main-navigation .dropdown-menu, .main-navigation .sub-menu { position: absolute; top: 100%; left: 0; background: var(--primary-color) !important; background-color: var(--primary-color) !important; min-width: 250px; max-height: 70vh; overflow-y: auto; /* No box-shadow - project rule */ list-style: none; padding: 0; margin: 0; opacity: 0; visibility: hidden; /* No transform - only border change on hover */ z-index: 99999 !important; border: none; pointer-events: none; } /* DEBUG styles removed - menu debugging complete */ /* Убеждаемся, что выпадашка всегда темная, независимо от состояния родителя */ /* Выпадашка показывается только при hover - как в статике */ /* Универсальные селекторы для всех страниц - максимальная специфичность */ .main-navigation .nav-item-dropdown:hover .dropdown-menu, .main-navigation .menu-item-has-children:hover > .sub-menu, .main-navigation .nav-menu .menu-item-has-children:hover > .sub-menu, .main-navigation #primary-menu .menu-item-has-children:hover > .sub-menu, .main-navigation .menu .menu-item-has-children:hover > .sub-menu, body .main-navigation .menu-item-has-children:hover > .sub-menu, body .main-navigation .nav-item-dropdown:hover .dropdown-menu, body .main-navigation .nav-menu .menu-item-has-children:hover > .sub-menu, body .main-navigation #primary-menu .menu-item-has-children:hover > .sub-menu, body .main-navigation .menu .menu-item-has-children:hover > .sub-menu, .site .main-navigation .menu-item-has-children:hover > .sub-menu, .site .main-navigation .nav-item-dropdown:hover .dropdown-menu, #page .main-navigation .menu-item-has-children:hover > .sub-menu, #page .main-navigation .nav-item-dropdown:hover .dropdown-menu { opacity: 1 !important; visibility: visible !important; pointer-events: auto !important; background: var(--primary-color) !important; background-color: var(--primary-color) !important; display: block !important; z-index: 99999 !important; } .dropdown-menu li, .sub-menu li { margin: 0; border-bottom: 1px solid rgba(255, 255, 255, 0.1); list-style: none; } .dropdown-menu li:last-child, .sub-menu li:last-child { border-bottom: none; } .dropdown-menu a, .sub-menu a { display: block; padding: 12px 20px; color: var(--white); text-decoration: none; font-weight: 400; background: var(--primary-color) !important; background-color: var(--primary-color) !important; } .dropdown-menu a:hover, .sub-menu a:hover { background: var(--secondary-color) !important; background-color: var(--secondary-color) !important; color: var(--white); } .dropdown-menu li.active a, .sub-menu li.current-menu-item > a { background: var(--accent-color) !important; background-color: var(--accent-color) !important; color: var(--white); } .dropdown-menu li.active a:hover, .sub-menu li.current-menu-item > a:hover { background: var(--secondary-color) !important; background-color: var(--secondary-color) !important; color: var(--white); } /* Scrollbar для выпадающего меню */ .dropdown-menu::-webkit-scrollbar { width: 6px; } .dropdown-menu::-webkit-scrollbar-track { background: rgba(255, 255, 255, 0.1); } .dropdown-menu::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.3); border-radius: 3px; } .dropdown-menu::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.5); } .mobile-menu-toggle { display: none; background: transparent; border: none; cursor: pointer; padding: 10px; flex-direction: column; justify-content: space-around; width: 40px; height: 40px; z-index: 1001; position: relative; } .header-hamburger { display: none; } .mobile-menu-toggle span { display: block; width: 100%; height: 3px; background: var(--white); border-radius: 2px; position: absolute; left: 0; } .mobile-menu-toggle span:nth-child(1) { top: 10px; } .mobile-menu-toggle span:nth-child(2) { top: 18px; } .mobile-menu-toggle span:nth-child(3) { top: 26px; } .mobile-menu-toggle.active span:nth-child(1) { top: 18px; transform: rotate(45deg); } .mobile-menu-toggle.active span:nth-child(2) { opacity: 0; } .mobile-menu-toggle.active span:nth-child(3) { top: 18px; transform: rotate(-45deg); } /* ═══════════════════════════════════════════════════════════ HERO СЕКЦІЯ ═══════════════════════════════════════════════════════════ */ .hero { background-image: url('img/male-worker-factory.webp'); background-size: cover; background-position: center; background-repeat: no-repeat; color: var(--white); padding: 0; margin-bottom: 0; position: relative; overflow: hidden; height: 600px; display: flex; align-items: center; } .hero::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(44, 62, 80, 0.75); z-index: 1; } .hero-background { display: none; } .hero .container { position: relative; z-index: 2; height: 100%; display: flex; align-items: center; } .hero-content-wrapper { max-width: 1200px; margin: 0 auto; width: 100%; } .hero-title { font-size: 42px; font-weight: 900; line-height: 1.2; color: var(--white); text-transform: uppercase; text-align: center; width: 100%; margin-bottom: 25px; position: relative; z-index: 3; } .hero-content { max-width: 600px; position: relative; z-index: 2; padding: 10px 0; margin: 0 auto; color: var(--white); } .hero-content * { color: var(--white) !important; } /* Override for buttons in hero - ensure text is visible */ .hero-content .btn-primary { color: var(--white) !important; } .hero-content .btn-secondary { color: var(--secondary-color) !important; } .hero-content-wrapper { color: var(--white); } .hero-content-wrapper * { color: var(--white) !important; } /* Override for buttons in hero wrapper - ensure text is visible */ .hero-content-wrapper .btn-primary { color: var(--white) !important; } .hero-content-wrapper .btn-secondary { color: var(--secondary-color) !important; } /* Additional rules for hero buttons container */ .hero-buttons .btn-primary { color: var(--white) !important; } .hero-buttons .btn-secondary { color: var(--secondary-color) !important; } /* Global hero button rules */ .hero .btn-primary { color: var(--white) !important; } .hero .btn-secondary { color: var(--secondary-color) !important; } .hero-lists-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; align-items: stretch; } /* Ensure columns have same height */ .hero-lists-grid .pain-column, .hero-lists-grid .benefits-column { display: flex; flex-direction: column; } .pain-column, .benefits-column { display: flex; flex-direction: column; } .pain-title, .benefits-title { font-size: 18px; font-weight: 700; color: var(--white); margin-bottom: 12px; line-height: 1.3; } .pain-list, .benefits-list { list-style: none; padding: 0; margin: 0; } .pain-list li, .benefits-list li { padding: 0; margin: 0; font-size: 15px; line-height: 1.8; border-bottom: none !important; margin-bottom: 0; } .pain-list li { color: var(--white); margin-bottom: 0; } .hero .benefits-list li { color: var(--white); border-bottom: none !important; padding: 0 !important; margin-bottom: 0 !important; font-size: 15px; line-height: 1.8; } .hero-buttons { display: flex; gap: 15px; margin: 15px auto; flex-wrap: wrap; justify-content: center; } .benefits-list { margin-top: 0; } .hero-rating { font-size: 13px; font-weight: 600; color: var(--white); margin: 10px auto; text-align: center; } .hero-badges { display: none !important; gap: 15px; margin: 10px auto 0; flex-wrap: wrap; align-items: center; justify-content: center; } .hero-badges .badge { max-width: 100px; height: auto; object-fit: contain; filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1)); } .hero-badges .badge:hover { /* No transform - only border change on hover */ } /* ═══════════════════════════════════════════════════════════ КНОПКИ ═══════════════════════════════════════════════════════════ */ .btn { display: inline-block; padding: 12px 30px; border: none; border-radius: 5px; font-size: 16px; font-weight: 600; text-decoration: none; cursor: pointer; } .btn-primary { background: var(--secondary-color); color: var(--white) !important; border: 2px solid var(--secondary-color); } .btn-primary:hover { background: var(--accent-color); border-color: var(--accent-color); color: var(--white) !important; } /* Глобальное правило: все кнопки с синим фоном должны иметь белый текст */ .btn[style*="background: var(--secondary-color)"], .btn[style*="background-color: var(--secondary-color)"], .btn[style*="background: var(--primary-color)"], .btn[style*="background-color: var(--primary-color)"], .btn-primary, a.btn-primary, button.btn-primary, input[type="submit"].btn-primary, input[type="button"].btn-primary { color: var(--white) !important; } /* Кнопки с синим фоном в hover состоянии */ .btn-primary:hover, .btn[style*="background: var(--secondary-color)"]:hover, .btn[style*="background-color: var(--secondary-color)"]:hover, .btn[style*="background: var(--primary-color)"]:hover, .btn[style*="background-color: var(--primary-color)"]:hover { color: var(--white) !important; } .btn-secondary { background: var(--white); color: var(--secondary-color); border: 2px solid var(--secondary-color); } .btn-secondary:hover { background: var(--accent-color); color: var(--white); border-color: var(--accent-color); } .btn-large { padding: 15px 40px; font-size: 18px; } /* ═══════════════════════════════════════════════════════════ ОСНОВНИЙ КОНТЕНТ ═══════════════════════════════════════════════════════════ */ .site-main { position: relative; z-index: 0; padding: 0 0 60px 0; } /* ═══════════════════════════════════════════════════════════ УНИФИЦИРОВАННЫЙ БЛОК ЗАГОЛОВКА СЕКЦИИ ═══════════════════════════════════════════════════════════ */ .section-header { text-align: center; margin-bottom: 50px; padding: 0 20px; } .section-title { font-size: 36px; text-align: center; margin-bottom: 15px; color: var(--primary-color); font-weight: 700; } .section-subtitle { text-align: center; font-size: 18px; color: var(--gray); margin-top: 0; margin-bottom: 0; line-height: 1.6; } /* ═══════════════════════════════════════════════════════════ ПРАВИЛО ФОНОВ ДЛЯ СЕКЦИЙ (после hero): Секции чередуются: белый → серый → белый → серый и т.д. Порядок секций: 1. Services - белый 2. Guarantee - серый 3. About Us - белый 4. Our Works - серый 5. Why Us - белый 6. How It Works - серый 7. Membership Plans - белый 8. Testimonials - серый 9. Blog - белый 10. Contact - серый 11. Locations - белый При добавлении новых секций - продолжать чередование! ═══════════════════════════════════════════════════════════ */ /* Послуги */ .services { padding: 60px 0; background: var(--white); } .services-intro { width: 100%; max-width: 100%; margin: 30px 0 40px; padding: 0; } .services-intro-text { font-size: 18px; line-height: 1.7; color: var(--text-color); text-align: center; max-width: 900px; margin: 0 auto; padding: 0 20px; } .services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 40px; } .service-card { background: var(--white); padding: 0; border-radius: 0; text-align: center; box-shadow: none; overflow: hidden; display: flex; flex-direction: column; border: 2px solid transparent; cursor: pointer; } .service-card:hover { border-color: var(--accent-color); } .service-image { width: 100%; height: 200px; overflow: hidden; background: #f0f0f0; position: relative; } .service-img { width: 100%; height: 100%; object-fit: cover; } .service-image .service-title { position: absolute; bottom: 0; left: 0; right: 0; margin: 0; padding: 15px 20px; background: var(--primary-color); color: var(--white); font-size: 22px; text-align: center; } .service-card:hover .service-image .service-title { background: var(--accent-color); color: var(--white); } .service-card { text-decoration: none; color: inherit; } .service-card:hover { text-decoration: none; color: inherit; } .service-card .service-description { padding: 20px 25px 25px; } .service-description { padding-bottom: 25px; font-size: 15px; line-height: 1.6; color: var(--text-color); } /* Our Guarantee Section */ .guarantee-section { padding: 60px 0; background: var(--light-bg); } .guarantee-content { display: grid; grid-template-columns: 1fr 3fr; gap: 50px; align-items: center; } .guarantee-text { padding-left: 20px; } .guarantee-text .section-header { text-align: left; margin-bottom: 20px; } .guarantee-text .section-title { text-align: left; margin-bottom: 15px; } .guarantee-description { font-size: 16px; line-height: 1.8; color: var(--text-color); margin-bottom: 20px; } .guarantee-description:last-of-type { margin-bottom: 0; } .guarantee-badge { display: flex; align-items: center; justify-content: center; width: 100%; } .guarantee-img { max-width: 100%; height: auto; object-fit: contain; } /* Про нас */ .about { padding: 60px 0; } .about-us { padding: 60px 0; background: var(--white); } .about-content { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: stretch; } .about-text { padding-right: 20px; display: flex; flex-direction: column; } .about-text .section-header { text-align: left; margin-bottom: 20px; flex-shrink: 0; } .about-text .section-title { text-align: left; margin-bottom: 15px; } .about-text .section-title { text-align: left; margin-bottom: 20px; flex-shrink: 0; } .about-text-scroll { height: 300px; overflow-y: auto; padding-right: 15px; margin-bottom: 0; } .about-cta { text-align: center; margin-top: 20px; } .about-text-scroll::-webkit-scrollbar { width: 8px; } .about-text-scroll::-webkit-scrollbar-track { background: var(--light-bg); border-radius: 4px; } .about-text-scroll::-webkit-scrollbar-thumb { background: var(--secondary-color); border-radius: 4px; } .about-text-scroll::-webkit-scrollbar-thumb:hover { background: var(--accent-color); } .about-description { font-size: 16px; line-height: 1.8; color: var(--text-color); margin-bottom: 20px; } .about-description:last-of-type { margin-bottom: 0; } /* Formatting for About Us content text */ .about-text-scroll .about-content-text { font-size: 16px; line-height: 1.8; color: var(--text-color); } .about-text-scroll .about-content-text p { margin-bottom: 1.2em; } .about-text-scroll .about-content-text p:last-child { margin-bottom: 0; } .about-text-scroll .about-content-text ul, .about-text-scroll .about-content-text ol { margin: 1em 0; padding-left: 2em; } .about-text-scroll .about-content-text li { margin-bottom: 0.5em; } .about-text-scroll .about-content-text strong, .about-text-scroll .about-content-text b { font-weight: 600; } .about-text-scroll .about-content-text em, .about-text-scroll .about-content-text i { font-style: italic; } .about-text-scroll .about-content-text h1, .about-text-scroll .about-content-text h2, .about-text-scroll .about-content-text h3, .about-text-scroll .about-content-text h4, .about-text-scroll .about-content-text h5, .about-text-scroll .about-content-text h6 { margin: 1.5em 0 1em; font-weight: 600; line-height: 1.3; } .about-text-scroll .about-content-text h1:first-child, .about-text-scroll .about-content-text h2:first-child, .about-text-scroll .about-content-text h3:first-child, .about-text-scroll .about-content-text h4:first-child, .about-text-scroll .about-content-text h5:first-child, .about-text-scroll .about-content-text h6:first-child { margin-top: 0; } .about-video { width: 100%; display: flex; flex-direction: column; } .about-video-iframe { width: 100%; aspect-ratio: 16 / 9; border-radius: 8px; } .about-video-image { width: 100%; aspect-ratio: 16 / 9; border-radius: 8px; object-fit: cover; } .about-features { list-style: none; margin-top: 20px; } .about-features li { padding: 10px 0; font-size: 18px; } /* Контакти */ /* ═══════════════════════════════════════════════════════════ LOCATIONS СЕКЦІЯ ═══════════════════════════════════════════════════════════ */ .locations { padding: 60px 0; background: var(--white); } .locations-content { display: flex; flex-direction: row; gap: 40px; align-items: stretch; } .locations-map { flex: 1 1 50%; width: 100%; height: 100%; align-self: stretch; border-radius: 12px; overflow: hidden; box-shadow: none; } .locations-content > .locations-map, .locations-content > .locations-contact { height: 100%; } .map-container { width: 100%; height: 100%; } .map-container iframe { width: 100%; height: 100%; border: none; } .locations-contact { flex: 1 1 50%; background: var(--light-bg); padding: 25px; border-radius: 12px; height: 100%; box-shadow: none; } .locations-contact h3 { font-size: 20px; font-weight: 700; color: var(--primary-color); margin-bottom: 18px; } .contact-details { margin-bottom: 20px; } .contact-item { margin-bottom: 15px; padding-bottom: 15px; border-bottom: 1px solid #e0e0e0; } .contact-item:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; } .contact-item strong { display: block; font-size: 12px; color: var(--gray); margin-bottom: 5px; text-transform: uppercase; letter-spacing: 0.5px; } .contact-inline { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; } .contact-inline strong { display: inline; margin-bottom: 0; margin-right: 5px; } .contact-item-inline { display: inline-flex !important; flex-direction: row; flex-wrap: nowrap; align-items: center; gap: 8px; width: 100%; } .contact-item-inline strong { display: inline-block !important; min-width: 150px; flex: 0 0 150px; margin-bottom: 0; margin-right: 0; white-space: nowrap; } .contact-item-inline span { display: inline-block !important; flex: 1 1 auto; font-size: 14px; line-height: 1.5; color: var(--text-color); margin: 0; } .contact-separator { color: var(--gray); margin: 0 10px; } .contact-item a { color: var(--primary-color); text-decoration: none; font-size: 16px; font-weight: 600; } .contact-item a:hover { color: var(--secondary-color); } .contact-item p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--text-color); } .locations-cta { display: flex; gap: 12px; flex-wrap: wrap; } .cities-section { width: 100%; margin-top: 50px; background: var(--light-bg); padding: 40px 0; box-shadow: none; } .cities-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; } .cities-title { font-size: 28px; font-weight: 700; color: var(--primary-color); text-align: center; margin-bottom: 40px; } .cities-content { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; width: 100%; background: var(--white); padding: 25px; border-radius: 12px; box-shadow: none; } .city-column { background: transparent; padding: 0; border-radius: 0; box-shadow: none; } .city-image-column { background: transparent; padding: 0; border-radius: 0; box-shadow: none; display: flex; align-items: center; justify-content: center; } .city-image { width: 100%; height: auto; border-radius: 8px; object-fit: cover; } .cities-cta { text-align: center; margin-top: 40px; } .cities-list { list-style: none; padding: 0; margin: 0; } .cities-list li { padding: 10px 0; font-size: 16px; color: var(--text-color); border-bottom: 1px solid #e0e0e0; } .cities-list li:last-child { border-bottom: none; } .cities-list a { color: var(--text-color); text-decoration: none; display: block; } .cities-list a:hover { color: var(--primary-color); } .city-state { font-size: 18px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; padding-bottom: 10px; border-bottom: 2px solid var(--secondary-color); } .locations-page { padding: 60px 0; } .contact { padding: 60px 0; background: var(--white); } .contact-content { max-width: 800px; margin: 0 auto; } .contact-form { background: #f8f9fa; padding: 30px; border-radius: 8px; } .contact-bottom-map { padding: 0 0 60px; } .contact-bottom-map-frame { width: 100%; height: 360px; border-radius: 12px; overflow: hidden; box-shadow: none; } .contact-bottom-map-frame iframe { width: 100%; height: 100%; border: 0; } .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; } .form-group { margin-bottom: 20px; } .form-group label { display: block; margin-bottom: 5px; font-weight: 600; } .form-group input, .form-group textarea, .form-group select { width: 100%; padding: 12px; border: 1px solid #ddd; border-radius: 5px; font-size: 16px; } .contact-list { list-style: none; } .contact-list li { margin-bottom: 15px; font-size: 16px; } .contact-list .contact-inline { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; } .contact-list .contact-inline strong { display: inline; margin-bottom: 0; margin-right: 5px; } /* ═══════════════════════════════════════════════════════════ ФУТЕР ═══════════════════════════════════════════════════════════ */ .site-footer { background: var(--primary-color); color: var(--white); padding: 40px 0 20px; } .footer-content { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 30px; margin-bottom: 30px; } .footer-column h4 { margin-bottom: 15px; } .footer-menu, .footer-contacts { list-style: none; padding: 0; margin: 0; } .footer-menu li, .footer-contacts li { margin-bottom: 10px; } /* Стили для футер-меню - переопределяем стили главного меню */ .site-footer .footer-menu a, .site-footer .footer-contacts a, .site-footer .footer-column .menu-item a, .site-footer .footer-column .menu-item > a, .site-footer .footer-column #menu-footer-navigation a, .site-footer .footer-column #menu-footer-services a, .site-footer .footer-column #menu-footer-contact a { color: var(--white) !important; text-decoration: none !important; opacity: 0.8 !important; display: inline !important; width: auto !important; height: auto !important; padding: 0 !important; background: transparent !important; font-size: 14px !important; font-weight: normal !important; margin: 0 !important; } .site-footer .footer-menu a:hover, .site-footer .footer-contacts a:hover, .site-footer .footer-column .menu-item a:hover, .site-footer .footer-column .menu-item > a:hover, .site-footer .footer-column #menu-footer-navigation a:hover, .site-footer .footer-column #menu-footer-services a:hover, .site-footer .footer-column #menu-footer-contact a:hover { opacity: 1 !important; background: transparent !important; color: var(--white) !important; } /* Social Media Icons */ .social-links { display: flex; gap: 12px; flex-wrap: wrap; } .social-icon { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background: rgba(255, 255, 255, 0.1); color: var(--white); text-decoration: none; border: 2px solid transparent; } .social-icon svg { width: 20px; height: 20px; } .social-icon:hover { background: var(--white); /* No transform - only border change on hover */ border-color: var(--white); } .social-icon.facebook:hover { background: #1877f2; border-color: #1877f2; color: var(--white); } .social-icon.instagram:hover { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); border-color: transparent; color: var(--white); } .social-icon.twitter:hover { background: #1da1f2; border-color: #1da1f2; color: var(--white); } .social-icon.linkedin:hover { background: #0077b5; border-color: #0077b5; color: var(--white); } .social-icon.youtube:hover { background: #ff0000; border-color: #ff0000; color: var(--white); } /* Payment Methods */ .footer-locations { background: transparent; padding: 30px 0; border-top: 1px solid rgba(255,255,255,0.1); } .footer-locations-wrapper { display: inline-flex; flex-direction: row; gap: 15px; align-items: center; flex-wrap: nowrap; white-space: nowrap; width: 100%; } .locations-label { color: var(--white); font-size: 16px; font-weight: 500; white-space: nowrap; flex-shrink: 0; display: inline-block; } .footer-locations-wrapper a { color: var(--white) !important; text-decoration: none; font-size: 14px; white-space: nowrap; display: inline-block; transition: color 0.2s; } .footer-locations-wrapper a:hover { color: var(--secondary-color) !important; text-decoration: underline; } .payment-methods { background: transparent; padding: 30px 0; border-top: 1px solid rgba(255,255,255,0.1); } .payment-methods-content { display: flex; align-items: center; justify-content: center; gap: 30px; flex-wrap: wrap; } .payment-label { color: var(--white); font-size: 16px; font-weight: 500; } .payment-logos { display: flex; align-items: center; gap: 25px; flex-wrap: wrap; } .payment-logo { color: var(--white); font-weight: 600; font-size: 14px; display: flex; align-items: center; gap: 8px; } /* VISA */ .payment-logo.visa { font-size: 24px; font-weight: 700; letter-spacing: 2px; } /* Mastercard */ .payment-logo.mastercard { display: flex; align-items: center; gap: 8px; } .mc-circles { position: relative; width: 40px; height: 25px; display: inline-block; } .mc-circles .circle { position: absolute; width: 25px; height: 25px; border-radius: 50%; border: 2px solid var(--white); } .mc-circles .circle-1 { left: 0; background: rgba(255,255,255,0.1); } .mc-circles .circle-2 { right: 0; background: rgba(255,255,255,0.1); } .mc-text { font-size: 12px; font-weight: 500; text-transform: lowercase; letter-spacing: 1px; } /* American Express */ .payment-logo.amex { font-size: 10px; line-height: 1.2; text-align: center; border: 1px solid var(--white); padding: 4px 8px; font-weight: 700; letter-spacing: 0.5px; } /* Zelle */ .payment-logo.zelle { font-size: 20px; font-weight: 600; position: relative; padding-left: 5px; } .payment-logo.zelle::before { content: ''; position: absolute; left: -3px; top: -2px; width: 1px; height: 12px; background: var(--white); } /* Square */ .payment-logo.square { display: flex; align-items: center; gap: 8px; } .square-icon { position: relative; width: 20px; height: 20px; display: inline-block; } .square-outline { position: absolute; width: 20px; height: 20px; border: 2px solid var(--white); top: 0; left: 0; } .square-inner { position: absolute; width: 10px; height: 10px; background: var(--white); top: 5px; left: 5px; } .square-text { font-size: 14px; font-weight: 500; } .footer-bottom { text-align: center; padding-top: 20px; border-top: 1px solid rgba(255,255,255,0.1); opacity: 0.7; display: flex; justify-content: center; align-items: center; gap: 15px; flex-wrap: wrap; } .footer-bottom p { margin: 0; } .footer-legal { margin: 0; display: flex; justify-content: center; align-items: center; gap: 10px; flex-wrap: wrap; } .footer-legal a { color: var(--white); text-decoration: none; opacity: 0.8; font-size: 14px; } .footer-legal a:hover { opacity: 1; text-decoration: underline; } .footer-legal .separator { opacity: 0.5; } /* ═══════════════════════════════════════════════════════════ СТРАНИЦЫ ═══════════════════════════════════════════════════════════ */ .page-header { background: var(--light-bg); color: var(--text-color); padding: 40px 0; text-align: center; position: relative; z-index: 0; width: 100%; } .page-header h1 { font-size: 42px; margin-bottom: 10px; color: var(--primary-color); } .page-subtitle { font-size: 18px; color: var(--gray); } .page-content { padding: 60px 0; } /* Contact Info Block */ .contact-info-block { padding: 30px 0; background: var(--light-bg); } .contact-info-content { display: flex; flex-wrap: wrap; gap: 20px 40px; justify-content: center; align-items: center; } .contact-info-item { display: flex; align-items: center; gap: 8px; font-size: 16px; } .contact-info-item strong { color: var(--primary-color); font-weight: 600; } .contact-info-item a { color: var(--secondary-color); text-decoration: none; } .contact-info-item a:hover { text-decoration: underline; } .contact-info-item span { color: var(--text-color); } @media (max-width: 768px) { .contact-info-content { flex-direction: column; align-items: flex-start; gap: 15px; } } .content-text { max-width: 800px; margin: 0 auto; } /* About Us Page Styles */ .about-who-we-are { padding: 60px 0; background: var(--white); } .about-who-content { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; } .about-who-text { padding-right: 20px; } .about-who-description { font-size: 16px; line-height: 1.8; color: var(--text-color); } .about-who-description p { margin-bottom: 20px; } .about-who-description p:last-child { margin-bottom: 0; } .about-who-image { width: 100%; } .about-who-img { width: 100%; height: auto; border-radius: 8px; object-fit: cover; } .about-video-section { padding: 60px 0; background: var(--light-bg); } .about-video-wrapper { max-width: 900px; margin: 0 auto; } .about-video-full { width: 100%; aspect-ratio: 16 / 9; border-radius: 8px; } .about-video-wrapper .about-video-image { width: 100%; aspect-ratio: 16 / 9; border-radius: 8px; object-fit: cover; } .about-services-section { padding: 60px 0; background: var(--white); } .about-services-list { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 30px; max-width: 1000px; margin: 0 auto 40px; } .about-services-cta { text-align: center; margin-top: 40px; } .services-column-list { list-style: none; padding: 0; margin: 0; } .services-column-list li { margin-bottom: 0; } .services-column-list li:last-child { margin-bottom: 0; } .services-column-list a { font-size: 18px; color: var(--text-color); text-decoration: none; display: block; padding: 12px 15px; border: 2px solid transparent; border-radius: 4px; margin-bottom: 0; } .services-column-list a:hover { border-color: var(--accent-color); } .about-locations-section { padding: 60px 0; background: var(--light-bg); } .about-locations-list { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 30px; max-width: 1000px; margin: 0 auto 40px; } .locations-column-list { list-style: none; padding: 0; margin: 0; } .locations-column-list li { margin-bottom: 0; font-size: 18px; color: var(--text-color); padding: 12px 15px; border: 2px solid transparent; border-radius: 4px; } .locations-column-list li:last-child { margin-bottom: 0; } .about-locations-cta { text-align: center; margin-top: 40px; } @media (max-width: 768px) { .about-who-content { grid-template-columns: 1fr; gap: 30px; } .about-who-text { padding-right: 0; } .about-services-list, .about-locations-list { grid-template-columns: 1fr; gap: 30px; } } margin: 0 auto; } .content-text h2 { font-size: 32px; margin-bottom: 20px; color: var(--primary-color); } .content-text p { font-size: 18px; line-height: 1.8; margin-bottom: 20px; } .content-text .last-updated { font-size: 14px; color: var(--gray); font-style: italic; margin-bottom: 30px; } .content-text ul { margin: 15px 0 20px 30px; line-height: 1.8; } .content-text ul li { margin-bottom: 10px; } /* Services List */ .services-list { padding: 60px 0; } .services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; } .service-item { background: var(--white); padding: 30px; border-radius: 10px; box-shadow: none; } .service-item h3 a { color: var(--primary-color); text-decoration: none; font-size: 24px; } .service-item h3 a:hover { color: var(--secondary-color); } /* Portfolio */ .portfolio-intro { padding: 60px 0; background: var(--light-bg); } .portfolio-intro-content { max-width: 900px; margin: 0 auto; } .portfolio-intro-content p { font-size: 18px; line-height: 1.8; color: var(--text-color); margin-bottom: 20px; } .portfolio-intro-content p:last-child { margin-bottom: 0; } .portfolio-grid-section { padding: 60px 0; background: var(--white); } .portfolio-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 0; } /* Ensure CTA card appears first */ .portfolio-grid .portfolio-cta-card { order: -1; } /* When both classes are applied, works-grid takes precedence */ .works-grid.portfolio-grid { grid-template-columns: repeat(3, 1fr); margin-top: 0; } .portfolio-item { cursor: pointer; } /* Our Works Section */ .our-works { padding: 60px 0; background: var(--light-bg); } .works-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 40px; } /* When both classes are applied, works-grid takes precedence */ .works-grid.portfolio-grid { grid-template-columns: repeat(3, 1fr); margin-top: 0; } .work-card { background: var(--white); border-radius: 0; overflow: hidden; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); height: 100%; display: flex; flex-direction: column; border: 2px solid transparent; transition: all 0.3s ease; } .work-card:hover { border-color: var(--accent-color); box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2); transform: translateY(-2px); } .work-image { position: relative; width: 100%; height: 250px; overflow: hidden; background: #f0f0f0; } .work-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; } .work-card:hover .work-img { transform: scale(1.05); } .work-content { padding: 20px; flex: 1; display: flex; flex-direction: column; justify-content: center; text-align: center; } .work-content h3, .work-content h1, .work-content h2, .work-content h4, .work-content h5, .work-content h6, .work-title { text-align: center; } .work-content p { text-align: center; } /* Portfolio CTA Card */ .portfolio-cta-card { display: flex !important; align-items: center; justify-content: center; min-height: 300px; background: var(--light-bg); border: 2px solid var(--secondary-color); cursor: default; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); order: -1; /* Place first in grid */ } .portfolio-cta-card:hover { border-color: var(--accent-color); box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2); transform: translateY(-2px); } .portfolio-cta-content { text-align: center; padding: 40px 20px; } .portfolio-cta-title { font-size: 28px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .portfolio-cta-text { font-size: 16px; line-height: 1.6; color: var(--text-color); margin-bottom: 25px; max-width: 400px; margin-left: auto; margin-right: auto; } .portfolio-cta-content .btn { margin-top: 10px; color: var(--white) !important; } /* Thank You Page */ .thank-you-content { padding: 60px 0; background: var(--light-bg); } .thank-you-wrapper { max-width: 700px; margin: 0 auto; text-align: center; padding: 40px 20px; } .thank-you-icon { margin-bottom: 30px; display: flex; justify-content: center; align-items: center; } .thank-you-icon svg { animation: checkmark 0.6s ease-in-out; } @keyframes checkmark { 0% { transform: scale(0); opacity: 0; } 50% { transform: scale(1.1); } 100% { transform: scale(1); opacity: 1; } } .thank-you-title { font-size: 36px; font-weight: 700; color: var(--primary-color); margin-bottom: 25px; line-height: 1.3; } .thank-you-message { margin-bottom: 40px; } .thank-you-text { font-size: 18px; line-height: 1.8; color: var(--text-color); margin-bottom: 20px; } .thank-you-contact { background: var(--white); padding: 30px; border-radius: 8px; margin-bottom: 40px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); } .thank-you-contact .contact-item { margin-bottom: 15px; font-size: 16px; } .thank-you-contact .contact-item:last-child { margin-bottom: 0; } .thank-you-contact strong { color: var(--primary-color); margin-right: 10px; } .thank-you-contact a { color: var(--secondary-color); text-decoration: none; transition: color 0.3s ease; } .thank-you-contact a:hover { color: var(--accent-color); } .thank-you-actions { display: flex; gap: 15px; justify-content: center; flex-wrap: wrap; } .thank-you-actions .btn { min-width: 180px; } .thank-you-actions .btn-primary { color: var(--white) !important; } @media (max-width: 768px) { .thank-you-title { font-size: 28px; } .thank-you-text { font-size: 16px; } .thank-you-actions { flex-direction: column; } .thank-you-actions .btn { width: 100%; } } /* Portfolio Gallery Modal */ .portfolio-gallery-modal { display: none; position: fixed; z-index: 10000; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.9); overflow: auto; } .portfolio-gallery-content { position: relative; margin: auto; padding: 20px; width: 90%; max-width: 1200px; top: 50%; transform: translateY(-50%); } .portfolio-gallery-content img { width: 100%; height: auto; max-height: 80vh; object-fit: contain; display: block; margin: 0 auto; } .portfolio-gallery-caption { text-align: center; color: var(--white); padding: 20px 0; } .portfolio-gallery-caption h3 { font-size: 24px; margin: 0; color: var(--white); } .portfolio-gallery-close { position: absolute; top: 20px; right: 35px; color: var(--white); font-size: 40px; font-weight: bold; cursor: pointer; z-index: 10001; } .portfolio-gallery-close:hover { color: var(--accent-color); } .portfolio-gallery-prev, .portfolio-gallery-next { position: absolute; top: 50%; transform: translateY(-50%); color: var(--white); font-size: 50px; font-weight: bold; cursor: pointer; padding: 16px; user-select: none; z-index: 10001; } .portfolio-gallery-prev { left: 20px; } .portfolio-gallery-next { right: 20px; } .portfolio-gallery-prev:hover, .portfolio-gallery-next:hover { color: var(--accent-color); } @media (max-width: 768px) { .portfolio-gallery-content { width: 95%; padding: 10px; } .portfolio-gallery-close { top: 10px; right: 15px; font-size: 30px; } .portfolio-gallery-prev, .portfolio-gallery-next { font-size: 30px; padding: 10px; } .portfolio-gallery-prev { left: 10px; } .portfolio-gallery-next { right: 10px; } } display: flex; flex-direction: column; background: var(--white); } .work-title { font-size: 22px; font-weight: 700; color: var(--primary-color); margin: 0; padding: 0; line-height: 1.3; } .work-card:hover .work-title { color: var(--secondary-color); } .works-cta { text-align: center; margin-top: 40px; } /* Blog */ .blog-list { padding: 60px 0; } .blog-posts { max-width: 800px; margin: 0 auto; } .blog-post { background: var(--white); padding: 40px; margin-bottom: 30px; border-radius: 10px; box-shadow: none; } .blog-post h2 a { color: var(--primary-color); text-decoration: none; } .blog-post h2 a:hover { color: var(--secondary-color); } .post-date { color: var(--gray); font-size: 14px; margin-bottom: 15px; } /* Steps */ .steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; padding: 40px 0; } .step { text-align: center; padding: 30px; background: var(--light-bg); border-radius: 10px; } .step h3 { color: var(--primary-color); margin-bottom: 15px; } /* Locations */ .locations-list { padding: 40px 0; } .location-item { background: var(--white); padding: 30px; margin-bottom: 20px; border-radius: 10px; box-shadow: none; } /* ═══════════════════════════════════════════════════════════ WHY US SECTION ═══════════════════════════════════════════════════════════ */ .why-us { padding: 60px 0; background: var(--white); } .why-icons-row { display: flex; justify-content: center; align-items: center; gap: 40px; margin-bottom: 50px; flex-wrap: wrap; } .why-icon-item { display: flex; flex-direction: column; align-items: center; text-align: center; } .why-icon-circle { width: 100px; height: 100px; border-radius: 50%; background: var(--secondary-color); display: flex; align-items: center; justify-content: center; margin-bottom: 15px; } .why-icon-circle svg { width: 40px; height: 40px; } .why-icon-label { font-size: 14px; font-weight: 600; color: var(--text-color); margin: 0; } .trust-badges { display: flex; justify-content: center; align-items: center; gap: 40px; margin-top: 50px; flex-wrap: wrap; } .trust-badges .trust-badge { max-width: 150px; height: auto; object-fit: contain; filter: drop-shadow(0 3px 6px rgba(0,0,0,0.15)); } .trust-badges .trust-badge:hover { /* No transform - only border change on hover */ } /* Service Badges Section */ .service-badges-section { display: none !important; } .service-badges-section .trust-badges { margin-top: 0; } /* ═══════════════════════════════════════════════════════════ HOW IT WORKS SECTION ═══════════════════════════════════════════════════════════ */ .how-it-works { padding: 60px 0; background: var(--light-bg); } .steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 40px; margin-bottom: 40px; max-width: 1000px; margin: 0 auto 40px; } .how-it-works-cta { text-align: center; margin-top: 40px; } /* How It Works button - white text on blue background */ .how-it-works-cta .btn-primary { color: var(--white) !important; } .how-it-works-cta .btn-secondary { color: var(--secondary-color) !important; } .step-item { text-align: center; position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; } .step-number { width: 60px; height: 60px; background: var(--secondary-color); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; font-weight: bold; margin: 0 auto 20px; } .step-item h3, .step-item h1, .step-item h2, .step-item h4, .step-item h5, .step-item h6 { font-size: 24px; margin-bottom: 15px; color: var(--primary-color); text-align: center; } .step-item p { text-align: center; } /* ═══════════════════════════════════════════════════════════ MEMBERSHIP PLANS ═══════════════════════════════════════════════════════════ */ .membership-plans { padding: 60px 0; background: var(--white); } .plans-intro { text-align: center; max-width: 800px; margin: 0 auto 50px; } .plans-intro h2 { font-size: 36px; margin-bottom: 20px; color: var(--primary-color); } .plans-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-bottom: 60px; } .plan-card { background: var(--white); border: 2px solid #e0e0e0; border-radius: 15px; padding: 40px; position: relative; } .plan-card:hover { box-shadow: none; } .plan-card.plan-featured { border-color: var(--secondary-color); border-width: 3px; } .plan-badge { position: absolute; top: -15px; right: 20px; background: var(--secondary-color); color: var(--white); padding: 8px 20px; border-radius: 20px; font-size: 14px; font-weight: 600; } .plan-header { text-align: center; margin-bottom: 30px; padding-bottom: 20px; border-bottom: 2px solid var(--light-bg); } .plan-header h3 { font-size: 28px; margin-bottom: 15px; color: var(--primary-color); } .plan-price { display: flex; align-items: baseline; justify-content: center; gap: 5px; } .price-amount { font-size: 42px; font-weight: bold; color: var(--secondary-color); } .price-period { font-size: 18px; color: var(--gray); } .plan-features ul { list-style: none; margin-bottom: 30px; } .plan-features li { padding: 12px 0; font-size: 16px; border-bottom: 1px solid var(--light-bg); } .plan-features li:last-child { border-bottom: none; } .plan-cta { text-align: center; } .plans-benefits { margin-top: 60px; padding-top: 60px; border-top: 2px solid var(--light-bg); } .plans-benefits h2 { text-align: center; font-size: 32px; margin-bottom: 40px; color: var(--primary-color); } .benefits-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; } .benefit-item { text-align: center; padding: 20px; } .benefit-item h4 { font-size: 20px; margin-bottom: 10px; color: var(--primary-color); } /* Service Cards Links */ .service-title a { color: var(--primary-color); text-decoration: none; } .service-title a:hover { color: var(--secondary-color); } /* ═══════════════════════════════════════════════════════════ TESTIMONIALS SECTION ═══════════════════════════════════════════════════════════ */ .testimonials { padding: 60px 0; background: color-mix(in srgb, var(--primary-color) 85%, white 15%); color: var(--white); } .testimonials .section-title, .testimonials .section-subtitle { color: var(--white); } .testimonials-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-bottom: 40px; } .testimonial-card { background: var(--white); padding: 30px; border-radius: 10px; box-shadow: none; } .testimonial-card:hover { } .testimonial-rating { margin-bottom: 15px; } .testimonial-rating .star { color: #ffc107; font-size: 20px; margin-right: 3px; } .testimonial-text { font-size: 16px; line-height: 1.7; margin-bottom: 20px; font-style: italic; color: var(--text-color); } .testimonial-author { display: flex; align-items: center; padding-top: 15px; border-top: 1px solid #e0e0e0; } .author-info { display: flex; flex-direction: column; } .author-info strong { color: var(--primary-color); font-size: 16px; } .author-location { font-size: 14px; color: var(--gray); margin-top: 5px; } .service-badge { background: var(--secondary-color); color: var(--white); padding: 5px 12px; border-radius: 15px; font-size: 12px; font-weight: 600; } .testimonials-cta { text-align: center; margin-top: 30px; } /* ═══════════════════════════════════════════════════════════ BLOG СЕКЦІЯ ═══════════════════════════════════════════════════════════ */ .blog-section { padding: 80px 0; background: var(--light-bg); } .blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 30px; margin-bottom: 40px; } .blog-card { background: var(--white); border-radius: 0; overflow: hidden; box-shadow: none; height: 100%; display: flex; flex-direction: column; border: 2px solid transparent; } .blog-card:hover { border-color: var(--accent-color); } .blog-card-link { text-decoration: none; color: inherit; display: flex; flex-direction: column; height: 100%; } .blog-image { position: relative; width: 100%; height: 250px; overflow: hidden; background: #f0f0f0; } .blog-image-img { width: 100%; height: 100%; object-fit: cover; } .blog-category { position: absolute; top: 15px; right: 15px; background: rgba(255,255,255,0.95); color: var(--primary-color); padding: 8px 16px; border-radius: 25px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; z-index: 2; box-shadow: none; } .blog-content { padding: 20px; flex: 1; display: flex; flex-direction: column; background: var(--white); } .blog-title { font-size: 22px; font-weight: 700; color: var(--primary-color); margin: 0; padding: 0; line-height: 1.3; } .blog-excerpt { font-size: 15px; line-height: 1.6; color: var(--text-color); margin: 0; padding: 0; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; } .blog-meta { display: flex; justify-content: space-between; align-items: center; padding-top: 18px; border-top: 1px solid #f0f0f0; font-size: 13px; color: var(--gray); margin-top: auto; } .blog-date { font-weight: 500; color: var(--text-color); } .blog-read-time { opacity: 0.7; font-size: 12px; } .blog-date { font-weight: 500; } .blog-read-time { opacity: 0.7; } .blog-cta { text-align: center; margin-top: 40px; } /* Blog Post Page */ .blog-post-content { padding: 60px 0; } .post-header-meta { display: flex; gap: 15px; justify-content: center; margin-bottom: 15px; flex-wrap: wrap; } .post-category-badge { background: var(--white); color: var(--primary-color); padding: 8px 16px; border-radius: 20px; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; } .post-read-time { background: transparent; color: var(--gray) !important; padding: 0; border-radius: 0; font-size: 16px; } .post-content { max-width: 800px; margin: 0 auto; } .post-image { width: 100%; height: 400px; margin-bottom: 40px; border-radius: 10px; overflow: hidden; background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%); } .post-image-img { width: 100%; height: 100%; object-fit: cover; } .post-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--white); font-size: 24px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; } .post-text { font-size: 18px; line-height: 1.8; color: var(--text-color); } .post-text h2 { font-size: 28px; color: var(--primary-color); margin: 40px 0 20px 0; font-weight: 700; } .post-text p { margin-bottom: 20px; } .post-lead { font-size: 20px; font-weight: 500; color: var(--primary-color); line-height: 1.7; margin-bottom: 30px; padding: 20px; background: var(--light-bg); border-left: 4px solid var(--secondary-color); border-radius: 5px; } .post-cta { display: flex; gap: 20px; margin-top: 50px; padding-top: 40px; border-top: 2px solid #e0e0e0; justify-content: center; flex-wrap: wrap; } /* Post Meta Header */ .post-meta-header { display: flex; align-items: baseline; justify-content: center; gap: 10px; margin-top: 15px; font-size: 16px; color: var(--gray) !important; flex-wrap: nowrap; white-space: nowrap; line-height: 1.5; } .post-meta-header .post-date, .post-meta-header .post-author, .post-meta-header .post-read-time, .post-meta-header .post-separator { color: var(--gray) !important; display: inline-block; vertical-align: baseline; line-height: 1.5; font-size: 16px; } .post-separator { color: var(--gray); opacity: 0.5; display: inline-block; vertical-align: baseline; line-height: 1.5; } .post-category-badge { display: inline-block; background: var(--secondary-color); color: var(--white); padding: 6px 15px; border-radius: 20px; font-size: 14px; font-weight: 600; margin-bottom: 15px; text-transform: uppercase; letter-spacing: 0.5px; } /* Post Tags */ .post-tags { margin-top: 40px; padding-top: 30px; border-top: 1px solid #e0e0e0; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; } .post-tags strong { color: var(--primary-color); font-weight: 700; } .tag-link { display: inline-block; padding: 5px 12px; background: var(--light-bg); color: var(--text-color); text-decoration: none; border-radius: 15px; font-size: 14px; transition: all 0.3s ease; } .tag-link:hover { background: var(--secondary-color); color: var(--white); } /* Post Navigation */ .post-navigation { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; margin-top: 50px; padding-top: 40px; border-top: 2px solid #e0e0e0; } .nav-previous, .nav-next { display: flex; flex-direction: column; } .nav-previous a, .nav-next a { text-decoration: none; color: inherit; display: flex; flex-direction: column; padding: 20px; background: var(--light-bg); border-radius: 10px; transition: all 0.3s ease; } .nav-previous a:hover, .nav-next a:hover { background: var(--secondary-color); color: var(--white); transform: translateY(-2px); } .nav-subtitle { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--gray); margin-bottom: 8px; font-weight: 600; } .nav-previous a:hover .nav-subtitle, .nav-next a:hover .nav-subtitle { color: rgba(255, 255, 255, 0.8); } .nav-title { font-size: 18px; font-weight: 700; color: var(--primary-color); line-height: 1.4; } .nav-previous a:hover .nav-title, .nav-next a:hover .nav-title { color: var(--white); } .nav-next { text-align: right; } .nav-next a { align-items: flex-end; } @media (max-width: 768px) { .post-navigation { grid-template-columns: 1fr; gap: 20px; } .nav-next { text-align: left; } .nav-next a { align-items: flex-start; } .post-meta-header { font-size: 14px; } } /* Blog List Page */ .blog-list { padding: 60px 0; } .blog-posts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 40px; } .blog-post-card { background: var(--white); border-radius: 12px; overflow: hidden; box-shadow: none; border: 1px solid rgba(0,0,0,0.05); } .blog-post-card:hover { border-color: var(--accent-color); } .blog-post-link { text-decoration: none; color: inherit; display: block; } .blog-post-image { position: relative; width: 100%; height: 280px; overflow: hidden; background: #f0f0f0; } .blog-post-image-img { width: 100%; height: 100%; object-fit: cover; } .blog-post-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%); color: var(--white); font-size: 24px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; } /* No transform on hover - only border change */ /* No overlay animation on hover - only border change */ .blog-post-category { position: absolute; top: 15px; right: 15px; background: rgba(255,255,255,0.95); color: var(--primary-color); padding: 8px 16px; border-radius: 25px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; z-index: 2; box-shadow: none; } .blog-post-content { padding: 30px; } .blog-post-content h2 { font-size: 24px; font-weight: 700; color: var(--primary-color); margin: 0 0 10px 0; line-height: 1.3; } .blog-post-card:hover .blog-post-content h2 { color: var(--secondary-color); } .post-date { font-size: 14px; color: var(--gray); margin-bottom: 15px; } .post-excerpt { font-size: 16px; line-height: 1.7; color: var(--text-color); margin-bottom: 20px; } .post-meta { display: flex; justify-content: space-between; align-items: center; padding-top: 15px; border-top: 1px solid #e0e0e0; font-size: 13px; color: var(--gray); } .post-author { font-weight: 500; } /* Testimonials Page */ .testimonials-page { padding: 60px 0; } .testimonials-filters, .blog-filters { display: flex; flex-wrap: wrap; gap: 15px; justify-content: center; margin-bottom: 40px; } .filter-btn { padding: 10px 20px; border: 2px solid var(--primary-color); background: var(--white); color: var(--primary-color); border-radius: 25px; cursor: pointer; font-size: 14px; font-weight: 600; } .filter-btn:hover, .filter-btn.active { background: var(--primary-color); color: var(--white); } .testimonials-grid-full { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 30px; margin-bottom: 60px; } .testimonials-stats-section { background: var(--primary-color); padding: 60px 0; width: 100%; } .testimonials-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; padding: 0; } .stats-item { text-align: center; padding: 20px; border: 2px solid rgba(255, 255, 255, 0.2); background: rgba(255, 255, 255, 0.05); } .stats-item:hover { border-color: var(--accent-color); } .stats-icon { font-size: 48px; margin-bottom: 15px; display: block; line-height: 1; } .stats-number { font-size: 56px; font-weight: 700; color: var(--white); margin-bottom: 10px; line-height: 1; } .stats-label { font-size: 18px; color: var(--white); font-weight: 500; text-transform: uppercase; letter-spacing: 0.5px; } /* Leave Review Section */ .leave-review-section { padding: 80px 0; background: var(--light-bg); } .review-form-wrapper { max-width: 800px; margin: 0 auto; background: var(--white); padding: 50px; border-radius: 0; } .review-form { width: 100%; } .rating-input { display: flex; gap: 8px; align-items: center; margin-top: 10px; } .rating-input input[type="radio"] { display: none; } .rating-input .star-label { font-size: 36px; color: #ddd; cursor: pointer; line-height: 1; user-select: none; } .rating-input input[type="radio"]:checked + .star-label, .rating-input input[type="radio"]:checked ~ .star-label { color: #ffc107; } .rating-input .star-label:hover, .rating-input .star-label:hover ~ .star-label { color: #ffc107; } /* Make stars interactive - highlight on hover */ .rating-input:hover .star-label { color: #ffc107; } /* Mobile styles for testimonials stats and review form */ @media (max-width: 768px) { .testimonials-stats-section { padding: 40px 0; } .testimonials-stats { grid-template-columns: 1fr; gap: 30px; } .stats-item { padding: 30px 20px; } .stats-icon { font-size: 40px; } .stats-number { font-size: 48px; } .stats-label { font-size: 16px; } .review-form-wrapper { padding: 30px 20px; } .leave-review-section { padding: 60px 0; } } /* ═══════════════════════════════════════════════════════════ АДАПТИВНІСТЬ ═══════════════════════════════════════════════════════════ */ /* Скрыть мобильный footer и header на ПК */ .mobile-menu-footer { display: none; } .mobile-menu-header { display: none !important; } @media (max-width: 768px) { .hero .container, .about-content, .contact-content { grid-template-columns: 1fr; } .about-text { padding-right: 0; margin-bottom: 30px; } .about-text .section-title { text-align: center; } .about-text-scroll { height: 200px; } .about-video { padding-bottom: 56.25%; height: 0; } .about-video-iframe { position: absolute; } .hero { height: auto; min-height: 500px; padding: 40px 0; } .hero::before { background: rgba(44, 62, 80, 0.8); } .hero-title { font-size: 32px; margin-bottom: 30px; } .hero-content { max-width: 100%; } .hero-lists-grid { grid-template-columns: 1fr; gap: 20px; } .pain-title, .benefits-title { font-size: 16px; margin-bottom: 10px; } .hero-title { font-size: 32px; } .hero-buttons { flex-direction: column; } .hero-buttons .btn { width: 100%; text-align: center; } .hero-badges { justify-content: center; } .hero-badges .badge { max-width: 100px; } .why-icons-row { gap: 20px; margin-bottom: 30px; } .why-icon-circle { width: 80px; height: 80px; } .why-icon-circle svg { width: 32px; height: 32px; } .why-icon-label { font-size: 12px; } .trust-badges { gap: 20px; margin-top: 30px; } .trust-badges .trust-badge { max-width: 120px; } .services-intro { margin: 20px 0 30px; } .services-intro-text { font-size: 16px; padding: 0 15px; line-height: 1.6; } .guarantee-content { grid-template-columns: 1fr; gap: 30px; } .works-grid { grid-template-columns: 1fr; gap: 20px; } .works-grid.portfolio-grid { grid-template-columns: 1fr; } .guarantee-text { padding-right: 0; } .guarantee-text .section-header { text-align: center; } .guarantee-text .section-title { text-align: center; } .guarantee-badge { order: -1; } .blog-grid { grid-template-columns: 1fr; } .blog-posts-grid { grid-template-columns: 1fr; } .post-cta { flex-direction: column; } .post-cta .btn { width: 100%; } .locations-content { flex-direction: column; } .locations-map { height: 300px; margin-bottom: 30px; } .locations-cta { flex-direction: column; } .locations-cta .btn { width: 100%; } .cities-section { padding: 30px 0; } .cities-container { padding: 0 15px; } .cities-title { font-size: 24px; margin-bottom: 30px; } .cities-content { grid-template-columns: 1fr; gap: 20px; padding: 20px; } .city-column { padding: 0; } .city-image-column { padding: 0; min-height: 250px; } .cities-section { padding: 30px 20px; } /* Mobile Header Styles - скрыты по умолчанию */ .mobile-menu-header { display: none; } /* Mobile Header - только для мобильных */ @media (max-width: 768px) { .logo-section { flex: 1; } .logo, .company-name { display: none !important; } .mobile-menu-toggle { display: flex !important; } /* Hide phone and CTA only in desktop header on mobile */ .site-header-desktop .header-phone { display: none !important; } .site-header-desktop .header-cta { display: none !important; } /* Keep phone and CTA visible in mobile header */ .site-header-mobile .header-phone { display: flex !important; } .site-header-mobile .header-cta { display: block !important; } /* Скрыть текст и теглайн лого на мобильном — только иконка */ .site-header-mobile .logo-section .logo-link > div, .site-header-mobile .logo-section .logo-text, .site-header-mobile .logo-section .logo-tagline { display: none !important; } .mobile-menu-header { display: none; position: fixed; top: 0; left: 0; width: 100%; background: var(--primary-color); padding: 15px 20px; z-index: 1002; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(255, 255, 255, 0.1); } .mobile-menu-header.active { display: flex; } .mobile-menu-close { background: transparent; border: none; color: var(--white); font-size: 24px; cursor: pointer; padding: 5px; line-height: 1; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; } .mobile-menu-close:hover { color: var(--accent-color); } .mobile-menu-logo { display: flex; flex-direction: column; align-items: flex-start; text-decoration: none; color: var(--white); } .mobile-menu-logo img, .mobile-menu-logo .custom-logo { max-height: 40px; max-width: 150px; height: auto; width: auto; display: block; } .mobile-menu-logo-icon { font-size: 24px; font-weight: 700; color: var(--white); line-height: 1; } .mobile-menu-logo-tagline { font-size: 9px; color: var(--white); margin-top: 2px; line-height: 1; } } .main-navigation .nav-menu, .main-navigation #primary-menu, .main-navigation .menu { display: none !important; position: fixed; top: 60px; left: 0; width: 100%; height: calc(100vh - 60px); background: var(--primary-color); flex-direction: column; padding: 20px 20px 100px; overflow-y: auto; z-index: 1000; list-style: none; margin: 0; } /* WordPress Admin Bar support for mobile menu */ .main-navigation .nav-menu.active, .main-navigation #primary-menu.active, .main-navigation .menu.active { display: flex !important; } .mobile-menu-footer { display: none; position: fixed; bottom: 0; left: 0; width: 100%; background: var(--primary-color); padding: 20px; border-top: 2px solid rgba(255, 255, 255, 0.2); z-index: 1001; } .mobile-menu-footer.active { display: block; } .mobile-menu-phone { text-align: center; margin-bottom: 15px; } .mobile-menu-phone-label { display: block; font-size: 12px; color: rgba(255, 255, 255, 0.8); margin-bottom: 8px; } .mobile-menu-phone-link { display: block; font-size: 20px; font-weight: 700; color: var(--white); text-decoration: none; } .mobile-menu-phone-link:hover { color: var(--secondary-color); } .mobile-menu-cta { text-align: center; } .mobile-menu-cta .btn { width: 100%; padding: 15px 30px; font-size: 16px; } /* Desktop Navigation - всегда видимо на десктопе */ @media (min-width: 769px) { .main-navigation .mobile-menu-toggle { display: none !important; } .nav-item, .menu-item { width: auto; border-bottom: none; } .nav-item a, .menu-item a { padding: 15px 25px; display: block; width: auto; } .dropdown-toggle, .menu-item-has-children > a { display: flex; align-items: center; gap: 5px; } .dropdown-arrow { font-size: 10px; margin-left: 5px; display: inline-block; } .nav-item-dropdown.active .dropdown-arrow, .menu-item-has-children.active .dropdown-arrow { transform: none; } .dropdown-menu, .sub-menu { position: absolute; top: 100%; left: 0; background: var(--primary-color); min-width: 250px; display: none; width: auto; padding: 0; margin-left: 0; list-style: none; opacity: 0; visibility: hidden; } .nav-item-dropdown:hover .dropdown-menu, .menu-item-has-children:hover > .sub-menu { display: block; opacity: 1; visibility: visible; } } /* Mobile Navigation - только для мобильных */ @media (max-width: 768px) { .main-navigation .mobile-menu-toggle { display: none; } .mobile-menu-toggle { position: relative; z-index: 1001; } /* Main menu items */ .main-navigation-mobile .menu-item, .main-navigation-mobile .nav-item { width: 100%; margin: 0; padding: 0; border-bottom: 1px solid rgba(255, 255, 255, 0.1); } .main-navigation-mobile .menu-item:last-child, .main-navigation-mobile .nav-item:last-child { border-bottom: none; } /* Main menu links */ .main-navigation-mobile .menu-item > a, .main-navigation-mobile .nav-item > a { display: block; padding: 18px 20px; color: var(--white); text-decoration: none; font-size: 16px; font-weight: 500; transition: background 0.2s, color 0.2s; width: 100%; background: transparent; } .main-navigation-mobile .menu-item > a:hover, .main-navigation-mobile .nav-item > a:hover { background: rgba(255, 255, 255, 0.1); color: var(--white); } /* Active menu items - only current, not all with children */ .main-navigation-mobile .menu-item.current-menu-item > a, .main-navigation-mobile .nav-item.active > a { background: var(--accent-color); color: var(--white); } /* Highlight parent menu item only if it contains the current page */ .main-navigation-mobile .menu-item.current-menu-ancestor > a { background: var(--accent-color); color: var(--white); } /* Don't highlight menu items with children unless they are actually current or ancestor */ .main-navigation-mobile .menu-item-has-children:not(.current-menu-item):not(.current-menu-ancestor) > a { background: transparent; } /* Items with children */ .main-navigation-mobile .menu-item-has-children > a, .main-navigation-mobile .nav-item-dropdown > a { display: flex; justify-content: space-between; align-items: center; } /* Dropdown arrow - hide it since all are expanded */ .main-navigation-mobile .dropdown-arrow { display: none; } /* Submenus - always visible */ .main-navigation-mobile .sub-menu, .main-navigation-mobile .dropdown-menu { display: block !important; position: static; opacity: 1; visibility: visible; width: 100%; margin: 0; padding: 0; background: rgba(0, 0, 0, 0.15); list-style: none; border: none; box-shadow: none; } /* First level submenu items */ .main-navigation-mobile .menu-item-has-children > .sub-menu > .menu-item, .main-navigation-mobile .nav-item-dropdown > .dropdown-menu > li { border-bottom: 1px solid rgba(255, 255, 255, 0.05); } .main-navigation-mobile .menu-item-has-children > .sub-menu > .menu-item > a, .main-navigation-mobile .nav-item-dropdown > .dropdown-menu > li > a { display: block; padding: 14px 20px 14px 40px; color: rgba(255, 255, 255, 0.9); text-decoration: none; font-size: 15px; font-weight: 400; transition: background 0.2s, padding-left 0.2s; } .main-navigation-mobile .menu-item-has-children > .sub-menu > .menu-item > a:hover, .main-navigation-mobile .nav-item-dropdown > .dropdown-menu > li > a:hover { background: rgba(255, 255, 255, 0.08); padding-left: 45px; } /* Second level submenu (nested) */ .main-navigation-mobile .sub-menu .sub-menu, .main-navigation-mobile .dropdown-menu .dropdown-menu { background: rgba(0, 0, 0, 0.25); margin: 0; padding: 0; } .main-navigation-mobile .sub-menu .sub-menu > .menu-item > a, .main-navigation-mobile .dropdown-menu .dropdown-menu > li > a { padding-left: 60px; font-size: 14px; color: rgba(255, 255, 255, 0.85); } .main-navigation-mobile .sub-menu .sub-menu > .menu-item > a:hover, .main-navigation-mobile .dropdown-menu .dropdown-menu > li > a:hover { padding-left: 65px; } /* Third level submenu (deeply nested) */ .main-navigation-mobile .sub-menu .sub-menu .sub-menu, .main-navigation-mobile .dropdown-menu .dropdown-menu .dropdown-menu { background: rgba(0, 0, 0, 0.35); } .main-navigation-mobile .sub-menu .sub-menu .sub-menu > .menu-item > a, .main-navigation-mobile .dropdown-menu .dropdown-menu .dropdown-menu > li > a { padding-left: 80px; font-size: 14px; color: rgba(255, 255, 255, 0.8); } .main-navigation-mobile .sub-menu .sub-menu .sub-menu > .menu-item > a:hover, .main-navigation-mobile .dropdown-menu .dropdown-menu .dropdown-menu > li > a:hover { padding-left: 85px; } } /* Comments widget in mobile menu - white background */ .main-navigation .widget, .main-navigation .widget-area, .main-navigation #secondary, .main-navigation .widget_recent_comments, .main-navigation .widget_comments { background: var(--white) !important; color: var(--text-color) !important; padding: 20px; margin: 20px 0; border-radius: 5px; } .main-navigation .widget h2, .main-navigation .widget h3, .main-navigation .widget .widget-title { color: var(--primary-color) !important; } .main-navigation .widget a { color: var(--secondary-color) !important; } .main-navigation .widget a:hover { color: var(--accent-color) !important; } .main-navigation .widget ul, .main-navigation .widget ol { color: var(--text-color) !important; } .main-navigation .widget li { color: var(--text-color) !important; } color: var(--white); background: transparent; } .dropdown-menu a:hover { background: var(--secondary-color); color: var(--white); } .dropdown-menu li.active a { background: var(--accent-color); color: var(--white); } .dropdown-menu li.active a:hover { background: var(--secondary-color); color: var(--white); } .company-name { display: none; } .site-header { padding: 10px 0; background: var(--primary-color); color: var(--white); } .site-header .logo-icon { color: #000000 !important; } .site-header-desktop .logo-tagline { color: #000000 !important; } .site-header-mobile .logo-tagline { color: var(--white) !important; } .site-header .header-phone a { color: var(--secondary-color); font-weight: 700; } .site-header .header-cta .btn { background: var(--accent-color); border-color: var(--accent-color); color: var(--white); } .site-header .header-cta .btn:hover { background: var(--secondary-color); border-color: var(--secondary-color); } .header-hamburger span { background: var(--white); } /* Мобильный хедер - темный фон, светлые элементы */ .site-header-mobile { background: var(--primary-color) !important; color: var(--white) !important; } .site-header-mobile .logo-text { color: var(--white) !important; } .site-header-mobile .header-phone a { color: var(--white) !important; } .site-header-mobile .header-hamburger span { background: var(--white) !important; } .site-header-mobile .header-cta .btn, .site-header-mobile .btn-primary { background: var(--secondary-color) !important; border-color: var(--secondary-color) !important; color: var(--white) !important; } .header-content { display: flex; flex-direction: row; gap: 8px; align-items: center; justify-content: space-between; flex-wrap: nowrap; overflow: hidden; } .logo-section { flex-direction: row; align-items: center; gap: 6px; flex: 0 0 auto; min-width: 0; order: 2; } .logo-link { flex-shrink: 0; display: flex; flex-direction: row; align-items: center; gap: 8px; } .site-header-mobile .logo-link img, .site-header-mobile .logo-link .custom-logo, .site-header-mobile .logo-svg { max-height: 40px !important; height: 40px !important; width: auto; max-width: none; } .site-header-mobile .logo-text { font-size: 18px !important; } .header-info { display: none; } .header-phone { display: flex; flex-direction: row; align-items: center; gap: 0; flex-shrink: 1; min-width: 0; order: 3; margin-left: auto; } .header-phone-label { display: none; } .header-phone a { font-size: 14px; white-space: nowrap; line-height: 1.2; } .header-cta { flex-shrink: 0; order: 4; } .header-cta .btn { padding: 6px 12px; font-size: 12px; white-space: nowrap; line-height: 1.2; } .main-navigation { position: relative; } .main-navigation .container { display: flex; align-items: center; justify-content: center; } .logo-icon { font-size: 28px; } .logo-tagline { font-size: 11px; } .logo-link img, .logo-link .custom-logo { max-height: 40px; max-width: 180px; height: auto; } .company-title { font-size: 18px; } .company-mission { font-size: 11px; } .header-info { flex-direction: column; gap: 15px; width: 100%; } .footer-locations-wrapper { display: inline-flex; flex-direction: row; flex-wrap: nowrap; white-space: nowrap; gap: 15px; overflow-x: auto; width: 100%; } .locations-label { flex-shrink: 0; } .footer-locations-wrapper a { flex-shrink: 0; } .quote-form-section { grid-template-columns: 1fr; } .form-row { grid-template-columns: 1fr; gap: 0; } } /* Quote Form Page */ .quote-form-section { display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px; padding: 40px 0; } .quote-form-wrapper { background: var(--white); padding: 30px; } .quote-form { max-width: 100%; } .quote-info { background: var(--light-bg); padding: 30px; } .quote-benefits { list-style: none; padding: 0; margin: 0 0 30px 0; } .quote-benefits li { padding: 8px 0; font-size: 15px; color: var(--text-color); } .quote-contact h4 { color: var(--primary-color); margin-bottom: 10px; font-size: 18px; } .quote-phone { font-size: 20px; font-weight: 700; color: var(--secondary-color); text-decoration: none; } .quote-phone:hover { color: var(--accent-color); text-decoration: underline; } .quote-hours { margin-top: 10px; font-size: 14px; color: var(--gray); line-height: 1.6; } .form-group select { width: 100%; padding: 12px; border: 1px solid #ddd; border-radius: 5px; font-size: 16px; background: var(--white); color: var(--text-color); cursor: pointer; } .form-group select:focus { outline: none; border-color: var(--secondary-color); } .form-submit { text-align: center; margin-top: 30px; display: flex; gap: 15px; justify-content: center; flex-wrap: wrap; } /* ═══════════════════════════════════════════════════════════ SERVICE PAGE STYLES (Landing Page for Services) ═══════════════════════════════════════════════════════════ */ /* Service Hero */ .service-hero { background: var(--primary-color); color: var(--white); padding: 80px 0; } .service-hero-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; } .service-hero-content { text-align: left; } .service-hero-title { font-size: 42px; font-weight: 700; margin-bottom: 20px; color: var(--white); line-height: 1.2; } .service-hero-subtitle { font-size: 20px; margin-bottom: 40px; color: rgba(255, 255, 255, 0.9); line-height: 1.6; } .service-hero-cta { display: flex; gap: 20px; justify-content: flex-start; flex-wrap: wrap; } /* Service hero buttons - first button white text */ .service-hero-cta .btn-primary { color: var(--white) !important; } .service-hero-cta .btn-secondary { color: var(--secondary-color) !important; } .service-hero-image { text-align: center; } .service-hero-image .hero-img { max-width: 70%; width: 70%; height: auto; border-radius: 8px; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3); } /* Service hero – reduced height (compact, ~30% of standard) */ .service-hero.service-hero--compact { padding: 24px 0 !important; } .service-hero.service-hero--compact .service-hero-wrapper { gap: 20px !important; align-items: center !important; } .service-hero.service-hero--compact .service-hero-title { font-size: 24px !important; margin-bottom: 8px !important; } .service-hero.service-hero--compact .service-hero-subtitle { font-size: 14px !important; margin-bottom: 16px !important; } .service-hero.service-hero--compact .service-hero-cta { margin-bottom: 0 !important; } .service-hero.service-hero--compact .service-hero-cta .btn { padding: 8px 16px !important; font-size: 14px !important; } .service-hero.service-hero--compact .service-hero-image .hero-img { max-width: 35% !important; width: 35% !important; } /* Service Intro Section */ /* Intro: сверху 40px, снизу меньше */ .service-intro { padding: 40px 0 20px !important; background: var(--white); } .service-intro-content { max-width: 800px; margin: 0 auto; font-size: 18px; line-height: 1.6; color: var(--text-color); } .service-intro-content p { margin-bottom: 1em; } .service-intro-content h2, .service-intro-content h3, .service-intro-content h4 { color: var(--primary-color); margin-top: 1.25em; margin-bottom: 0.5em; } .service-intro-content h2:first-child, .service-intro-content h3:first-child, .service-intro-content h4:first-child { margin-top: 0; } .service-intro-content ul, .service-intro-content ol { margin: 0.75em 0 0.75em 1.5em; } /* Visual Root Causes Section */ .service-visual-root-causes { padding: 80px 0; background: var(--light-bg); } .service-visual-root-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 24px; } @media (max-width: 992px) { .service-visual-root-cards { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } } @media (max-width: 576px) { .service-visual-root-cards { grid-template-columns: 1fr; } } .service-visual-root-card { display: block; background: var(--white); padding: 24px; border: 2px solid transparent; border-radius: 8px; min-height: 120px; box-sizing: border-box; transition: border-color 0.2s ease; } .service-visual-root-card:hover { border-color: var(--accent-color); } .service-visual-root-card-title { font-size: 18px; font-weight: 700; color: var(--primary-color); margin-bottom: 12px; line-height: 1.3; } .service-visual-root-card-text { font-size: 15px; line-height: 1.5; color: var(--text-color); margin: 0; } /* Deep Dive Section */ .service-deep-dive { padding: 80px 0; background: var(--white); } .service-deep-dive-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; overflow: hidden; } .service-deep-dive-cards { min-width: 0; display: flex; flex-direction: column; gap: 28px; } .service-deep-dive-card { margin: 0; } .service-deep-dive-card-title { font-size: 22px; font-weight: 700; color: var(--primary-color); margin: 0 0 10px 0; line-height: 1.3; } .service-deep-dive-card-text { font-size: 16px; line-height: 1.6; color: var(--text-color); margin: 0; } .service-deep-dive-image { position: sticky; top: 24px; min-width: 0; overflow: hidden; border-radius: 8px; display: flex; align-items: center; max-height: min(70vh, 600px); } .service-deep-dive-image .deep-dive-img { width: 100%; max-width: 100%; max-height: 100%; height: auto; display: block; object-fit: contain; object-position: center; border-radius: 8px; } .service-deep-dive-wrapper--no-image { grid-template-columns: 1fr; } @media (max-width: 992px) { .service-deep-dive-wrapper { grid-template-columns: 1fr; } .service-deep-dive-image { position: static; order: -1; } } /* Comparison Table Section */ .service-comparison-table { padding: 80px 0; background: var(--light-bg); } .service-comparison-table-wrapper { overflow-x: auto; } .comparison-table { width: 100%; border-collapse: collapse; background: var(--white); border: 1px solid rgba(0, 0, 0, 0.08); } .comparison-table th, .comparison-table td { padding: 14px 18px; text-align: left; border: 1px solid rgba(0, 0, 0, 0.08); vertical-align: middle; } .comparison-table thead th { font-weight: 700; color: var(--primary-color); background: var(--light-bg); } .comparison-table .comparison-col-feature { font-weight: 600; color: var(--primary-color); } .comparison-table .comparison-col-value { color: var(--text-color); } .comparison-table .comparison-col-best { background: rgba(0, 128, 0, 0.08); border-color: rgba(0, 128, 0, 0.2); } .comparison-table thead .comparison-col-best { background: rgba(0, 128, 0, 0.12); } .comparison-check { display: inline-block; color: #0a7c0a; font-weight: 700; margin-right: 6px; font-size: 1.1em; } @media (max-width: 576px) { .comparison-table th, .comparison-table td { padding: 10px 12px; font-size: 14px; } } /* Specifics Section (no header, solution-item style cards) */ .service-specifics { padding: 80px 0; background: var(--white); } .service-specifics .solutions-content { margin-top: 0; } /* Process Section: steps-grid, step-item; centered content, even distribution */ .service-process { padding: 80px 0; background: var(--light-bg); } .service-process .section-header { margin-bottom: 48px; } .service-process .steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 280px)); gap: 32px; margin: 0 auto; justify-content: center; width: fit-content; max-width: 100%; } /* 4 cards in one row — equal columns, no narrowing */ .service-process .steps-grid.steps-count-4, .service-process .steps-grid:has(.step-item:nth-child(4):last-child) { grid-template-columns: repeat(4, 1fr) !important; } .service-process .step-item { text-align: center; display: flex; flex-direction: column; align-items: center; padding: 36px 28px; background: var(--white); border: 2px solid transparent; border-radius: 10px; transition: border-color 0.2s ease; } .service-process .step-item:hover { border-color: var(--accent-color); } .service-process .step-number { width: 56px; height: 56px; background: var(--secondary-color); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 26px; font-weight: 700; margin-bottom: 16px; } .service-process .step-item h3, .service-process .step-item h1, .service-process .step-item h2, .service-process .step-item h4, .service-process .step-item h5, .service-process .step-item h6 { font-size: 22px; font-weight: 700; color: var(--primary-color); margin: 0 0 12px 0; text-align: center; } .service-process .step-item p { font-size: 15px; line-height: 1.6; color: var(--text-color); margin: 0; text-align: center; } @media (max-width: 768px) { .service-process .steps-grid.steps-count-4, .service-process .steps-grid:has(.step-item:nth-child(4):last-child) { grid-template-columns: repeat(2, 1fr) !important; } } @media (max-width: 576px) { .service-process { padding: 56px 0; } .service-process .section-header { margin-bottom: 32px; } .service-process .steps-grid, .service-process .steps-grid.steps-count-4, .service-process .steps-grid:has(.step-item:nth-child(4):last-child) { grid-template-columns: 1fr !important; gap: 24px; } .service-process .step-item { padding: 28px 20px; } } /* Consequences Section (title H2, list of cards: title + text) */ .service-consequences { padding: 80px 0; background: var(--white); } .consequences-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; } .consequences-card { background: var(--white); padding: 24px; border: 2px solid transparent; border-radius: 8px; transition: border-color 0.2s ease; } .consequences-card:hover { border-color: var(--accent-color); } .consequences-card-title { font-size: 20px; font-weight: 700; color: var(--primary-color); margin: 0 0 12px 0; line-height: 1.3; } .consequences-card-text { font-size: 16px; line-height: 1.6; color: var(--text-color); margin: 0; } @media (max-width: 576px) { .consequences-cards { grid-template-columns: 1fr; } } /* Symptoms Section (title H2, subtitle, bullet list + warning icon right) */ .service-symptoms { padding: 80px 0; background: var(--white); } .symptoms-content { display: grid; grid-template-columns: 1fr auto; gap: 40px; align-items: stretch; max-width: 1000px; margin: 0 auto; } .service-symptoms .symptoms-list { padding-left: 24px; font-size: 17px; line-height: 1.7; color: var(--text-color); margin: 0; } .service-symptoms .symptoms-list li { margin-bottom: 10px; } .service-symptoms .symptoms-list li:last-child { margin-bottom: 0; } .symptoms-warning-icon { display: flex; align-items: center; justify-content: center; align-self: stretch; padding-left: 20px; } .symptoms-warning-icon svg { width: auto; height: 100%; max-width: 200px; object-fit: contain; color: #c00; opacity: 0.1; } @media (max-width: 768px) { .symptoms-content { grid-template-columns: 1fr; } .symptoms-warning-icon { padding-left: 0; padding-top: 24px; min-height: 140px; } .symptoms-warning-icon svg { max-height: 140px; } } /* FAQ Section (accordion + Schema.org) */ .service-faq { padding: 80px 0; background: var(--light-bg); } .faq-accordion { max-width: 800px; margin: 0 auto; } .faq-item { border: 1px solid rgba(0, 0, 0, 0.08); border-bottom: none; background: var(--white); } .faq-item:last-child { border-bottom: 1px solid rgba(0, 0, 0, 0.08); } .faq-question-wrap { margin: 0; } .faq-question { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 18px 24px; text-align: left; font-size: 18px; font-weight: 600; color: var(--primary-color); background: none; border: none; cursor: pointer; position: relative; padding-right: 48px; } .faq-question:hover { color: var(--accent-color); } .faq-question::after { content: '+'; position: absolute; right: 24px; top: 50%; transform: translateY(-50%); font-size: 24px; font-weight: 400; line-height: 1; } .faq-item.faq-item--open .faq-question::after { content: '−'; } .faq-answer-wrap { overflow: hidden; } .faq-answer-wrap[hidden] { display: none; } .faq-answer { padding: 0 24px 20px; font-size: 16px; line-height: 1.7; color: var(--text-color); } .faq-answer p:first-child { margin-top: 0; } .faq-answer p:last-child { margin-bottom: 0; } /* Service Content Section */ .service-content { padding: 80px 0; background: var(--white); } .service-content-wrapper { display: grid; grid-template-columns: 2fr 1fr; gap: 60px; align-items: start; } .service-content-text { text-align: left; } .service-content-text .entry-content { font-size: 18px; line-height: 1.5; color: var(--text-color); } .service-content-collapsible { max-height: 400px; overflow: hidden; position: relative; transition: max-height 0.5s ease-in-out; } .service-content-collapsible.expanded { max-height: none; } .service-content-collapsible::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 60px; background: linear-gradient(to bottom, transparent, var(--light-bg)); pointer-events: none; opacity: 1; transition: opacity 0.3s ease; } .service-content-collapsible.expanded::after { opacity: 0; } .service-content-toggle { text-align: center; margin-top: 20px; } .service-content-toggle .btn { padding: 12px 30px; font-size: 16px; border: 2px solid var(--secondary-color); background: transparent; color: var(--secondary-color); cursor: pointer; transition: all 0.3s ease; } .service-content-toggle .btn:hover { background: var(--secondary-color); color: var(--white); } .service-content-text .entry-content h2, .service-content-text .entry-content h3, .service-content-text .entry-content h4 { color: var(--primary-color); margin-top: 25px; margin-bottom: 12px; } .service-content-text .entry-content h2:first-child, .service-content-text .entry-content h3:first-child, .service-content-text .entry-content h4:first-child { margin-top: 0; } .service-content-text .entry-content p { margin-bottom: 12px; line-height: 1.5; } .service-content-text .entry-content ul, .service-content-text .entry-content ol { margin: 12px 0 12px 30px; padding: 0; list-style-position: outside; } .service-content-text .entry-content li { margin-bottom: 4px; line-height: 1.5; } .service-content-image { text-align: center; max-height: 600px; overflow: hidden; display: flex; align-items: center; justify-content: center; } .service-content-image .content-img { max-width: 100%; max-height: 600px; width: auto; height: auto; object-fit: contain; border-radius: 8px; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1); } @media (max-width: 992px) { .service-hero-wrapper { grid-template-columns: 1fr; gap: 40px; text-align: center; } .service-hero-content { text-align: center; } .service-hero-cta { justify-content: center; } .service-content-wrapper { grid-template-columns: 1fr; gap: 40px; } .service-content-image { order: -1; } } /* Service Problems Section */ .service-problems { padding: 80px 0; background: var(--white); } .problems-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 40px; margin-top: 50px; } .problem-item { text-align: center; padding: 30px 20px; border: 2px solid transparent; } .problem-item:hover { border-color: var(--accent-color); } .problem-icon { width: 80px; height: 80px; background: var(--accent-color); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; position: relative; } .problem-icon span { font-size: 40px; font-weight: 700; color: var(--primary-color); filter: grayscale(100%) brightness(0); display: flex; align-items: center; justify-content: center; line-height: 1; width: 100%; height: 100%; text-align: center; } .problem-item h3, .problem-item h1, .problem-item h2, .problem-item h4, .problem-item h5, .problem-item h6 { font-size: 22px; color: var(--primary-color); margin-bottom: 15px; font-weight: 700; text-align: center; } .problem-item p { font-size: 16px; line-height: 1.7; color: var(--text-color); text-align: center; } /* Service Solutions Section */ .service-solutions, .service-subservices { padding: 80px 0; background: var(--light-bg); } .service-calculator { padding: 40px 0 80px; background: var(--light-bg); } .solutions-content { max-width: 1000px; margin: 50px auto 0; } /* Ensure subservices section uses standard spacing */ .service-subservices .section-header { margin-bottom: 50px; } .service-subservices .solutions-content { margin-top: 50px; } .solution-item { display: grid; grid-template-columns: 1fr 200px; gap: 30px; align-items: center; margin-bottom: 40px; padding-bottom: 40px; border-bottom: 1px solid #e0e0e0; } .solution-item:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; } .solution-image { width: 200px; height: 150px; overflow: hidden; background: #f0f0f0; border: 2px solid transparent; } .solution-item:hover .solution-image { border-color: var(--accent-color); } .solution-img { width: 100%; height: 100%; object-fit: cover; } .solution-text { flex: 1; } .solution-item h3, .service-specifics .solution-item h2 { font-size: 26px; color: var(--primary-color); margin-bottom: 15px; font-weight: 700; } .solution-item p { font-size: 18px; line-height: 1.8; color: var(--text-color); } /* Service Why Us Section */ .service-why-us { padding: 80px 0; background: var(--white); } .why-us-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 40px; margin-top: 50px; } .why-us-item { text-align: center; padding: 30px 20px; } .why-us-icon { width: 60px; height: 60px; background: #27ae60; color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; font-weight: 700; margin: 0 auto 20px; } .why-us-item h3, .why-us-item h1, .why-us-item h2, .why-us-item h4, .why-us-item h5, .why-us-item h6 { font-size: 22px; color: var(--primary-color); margin-bottom: 15px; font-weight: 700; text-align: center; } .why-us-item p { font-size: 16px; line-height: 1.7; color: var(--text-color); text-align: center; } /* Service How It Works */ .service-how-it-works { padding: 80px 0; background: var(--light-bg); } /* Service Portfolio */ .service-portfolio { padding: 80px 0; background: var(--white); } /* Service Testimonials Section */ .service-testimonials { padding: 80px 0; background: var(--light-bg); } /* Service Order Section */ .service-order { padding: 80px 0; background: var(--white); text-align: center; } .service-order-content { max-width: 800px; margin: 0 auto; } .service-order-content h2, .service-order-content h1, .service-order-content h3, .service-order-content h4, .service-order-content h5, .service-order-content h6 { font-size: 36px; color: var(--primary-color); margin-bottom: 20px; font-weight: 700; } .service-order-content p { font-size: 20px; color: var(--text-color); margin-bottom: 40px; line-height: 1.6; } .service-order-buttons { display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; } /* Service CTA Section */ .service-cta { padding: 80px 0; background: var(--primary-color); color: var(--white); text-align: center; } .service-cta-content { max-width: 800px; margin: 0 auto; } .service-cta-content h2 { font-size: 36px; color: var(--white); margin-bottom: 20px; font-weight: 700; } .service-cta-content p { font-size: 20px; color: rgba(255, 255, 255, 0.9); margin-bottom: 40px; line-height: 1.6; } .service-cta-buttons { display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; } /* Mobile styles for service pages */ @media (max-width: 768px) { .service-hero-title { font-size: 32px; } .service-hero-subtitle { font-size: 18px; } .service-hero-cta { flex-direction: column; } .service-hero-cta .btn { width: 100%; } .problems-grid, .why-us-grid { grid-template-columns: 1fr; gap: 30px; } .solution-item { grid-template-columns: 1fr; gap: 20px; } .solution-image { width: 100%; height: 200px; margin: 0 auto; } .solution-item h3, .service-specifics .solution-item h2 { font-size: 22px; } .solution-item p { font-size: 16px; } .service-cta-content h2 { font-size: 28px; } .service-cta-content p { font-size: 18px; } .service-cta-buttons { flex-direction: column; } .service-cta-buttons .btn { width: 100%; } .service-order-content h2, .service-order-content h1, .service-order-content h3, .service-order-content h4, .service-order-content h5, .service-order-content h6 { font-size: 28px; } .service-order-content p { font-size: 18px; } .service-order-buttons { flex-direction: column; } .service-order-buttons .btn { width: 100%; } } /* ═══════════════════════════════════════════════════════════ CONTACT FORM 7 STYLES ═══════════════════════════════════════════════════════════ */ /* Contact Form 7 wrapper styles */ .wpcf7-form { width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; } /* Two-column layout for Contact Form 7 - matching static prototype */ .wpcf7-form p { margin-bottom: 5px; } /* First Name, Last Name, Email, Phone - two columns */ .wpcf7-form p:has([name="first-name"]), .wpcf7-form p:has([name="last-name"]), .wpcf7-form p:has([name="email"]), .wpcf7-form p:has([name="phone"]) { grid-column: span 1; } /* Full-width fields (address, textarea, submit, location, service) */ .wpcf7-form p:has([name="address"]), .wpcf7-form p:has([name="project"]), .wpcf7-form p:has([name="message"]), .wpcf7-form p:has([name="review-text"]), .wpcf7-form p:has([name="review-location"]), .wpcf7-form p:has([name="membership-notes"]), .wpcf7-form p:has([type="submit"]), .wpcf7-form p:has([name="location"]), .wpcf7-form p:has([name="service"]), .wpcf7-form p:has([name="review-service"]), .wpcf7-form p:has([name="zip-code"]), .wpcf7-form p:has(textarea) { grid-column: 1 / -1; } .wpcf7-form-control-wrap { display: block; width: 100%; } .wpcf7-form label { display: block; margin-bottom: 2px; font-weight: 600; color: var(--text-color); } .wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"], .wpcf7-form textarea, .wpcf7-form select { width: 100%; padding: 8px; border: 1px solid #ddd; border-radius: 5px; font-size: 16px; font-family: inherit; background: var(--white); color: var(--text-color); box-sizing: border-box; } .wpcf7-form input[type="text"]:focus, .wpcf7-form input[type="email"]:focus, .wpcf7-form input[type="tel"]:focus, .wpcf7-form textarea:focus, .wpcf7-form select:focus { outline: none; border-color: var(--accent-color); } .wpcf7-form textarea { resize: vertical; min-height: 30px; } .wpcf7-form .wpcf7-submit { padding: 12px 30px; background: var(--accent-color); color: var(--white); border: 2px solid var(--accent-color); border-radius: 5px; font-size: 16px; font-weight: 600; cursor: pointer; font-family: inherit; width: auto; } .wpcf7-form .wpcf7-submit:hover { background: var(--primary-color); border-color: var(--primary-color); } .wpcf7-form .wpcf7-submit.btn-secondary { background: transparent; color: var(--primary-color); border-color: var(--primary-color); } .wpcf7-form .wpcf7-submit.btn-secondary:hover { background: var(--primary-color); color: var(--white); } .wpcf7-form .wpcf7-radio { display: flex; gap: 10px; flex-wrap: wrap; } .wpcf7-form .wpcf7-radio .wpcf7-list-item { margin: 0; } .wpcf7-form .wpcf7-radio label { display: flex; align-items: center; cursor: pointer; font-size: 24px; color: #ddd; transition: color 0.2s; } .wpcf7-form .wpcf7-radio input[type="radio"] { display: none; } .wpcf7-form .wpcf7-radio input[type="radio"]:checked + label, .wpcf7-form .wpcf7-radio label:hover { color: #ffc107; } .wpcf7-response-output { margin: 20px 0; padding: 15px; border-radius: 4px; } .wpcf7-mail-sent-ok { display: none !important; } .wpcf7-mail-sent-ng, .wpcf7-aborted, .wpcf7-spam, .wpcf7-validation-errors { background: #f8d7da; border: 1px solid #f5c6cb; color: #721c24; } .wpcf7-not-valid-tip { color: #dc3545; font-size: 14px; margin-top: 5px; display: block; } .wpcf7-not-valid { border-color: #dc3545 !important; } /* Review form specific styles */ .review-form-wrapper .wpcf7-form .rating-input { display: flex; gap: 5px; align-items: center; } .review-form-wrapper .wpcf7-form .rating-input .wpcf7-radio { display: flex; gap: 5px; } .review-form-wrapper .wpcf7-form .rating-input label.star-label { font-size: 28px; color: #ddd; cursor: pointer; transition: color 0.2s; } .review-form-wrapper .wpcf7-form .rating-input input[type="radio"]:checked ~ label.star-label, .review-form-wrapper .wpcf7-form .rating-input label.star-label:hover, .review-form-wrapper .wpcf7-form .rating-input label.star-label:hover ~ label.star-label { color: #ffc107; } /* ═══════════════════════════════════════════════════════════ FOR CONTRACTORS PAGE ═══════════════════════════════════════════════════════════ */ .contractors-content { padding: 60px 0; } .contractors-content .content-text { max-width: 900px; margin: 0 auto; } .contractors-content h2 { font-size: 36px; font-weight: 700; color: var(--primary-color); margin-bottom: 20px; text-align: center; } .contractors-content h3 { font-size: 28px; font-weight: 700; color: var(--primary-color); margin-top: 40px; margin-bottom: 20px; } .contractors-content p { font-size: 18px; line-height: 1.8; color: var(--text-color); margin-bottom: 20px; } .contractor-benefits, .contractor-requirements { background: var(--light-bg); padding: 30px; border-radius: 10px; margin: 30px 0; } .contractor-benefits h3, .contractor-requirements h3 { margin-top: 0; margin-bottom: 20px; } .benefits-list, .requirements-list { list-style: none; padding: 0; margin: 0; } .benefits-list li, .requirements-list li { padding: 10px 0; font-size: 16px; line-height: 1.6; color: var(--text-color); border-bottom: 1px solid #e0e0e0; } .benefits-list li:last-child, .requirements-list li:last-child { border-bottom: none; } .contractor-how-it-works { margin: 40px 0; } .contractor-how-it-works h3 { text-align: center; margin-bottom: 40px; } .how-it-works-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; margin-top: 30px; } .step-item { display: flex; gap: 20px; align-items: flex-start; padding: 20px; background: var(--white); border: 2px solid #e0e0e0; border-radius: 10px; transition: all 0.3s ease; } .step-item:hover { border-color: var(--secondary-color); box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1); } .step-number { flex-shrink: 0; width: 50px; height: 50px; background: var(--secondary-color); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 24px; font-weight: 700; } .step-content h4 { font-size: 20px; font-weight: 700; color: var(--primary-color); margin-bottom: 10px; } .step-content p { font-size: 16px; line-height: 1.6; color: var(--text-color); margin: 0; } .contractor-form-section { padding: 80px 0; background: var(--light-bg); } .form-section-header { text-align: center; max-width: 700px; margin: 0 auto 50px; } .form-section-header h2 { font-size: 36px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .form-section-header p { font-size: 18px; line-height: 1.8; color: var(--text-color); margin: 0; } .contractor-form-wrapper { max-width: 800px; margin: 0 auto; background: var(--white); padding: 40px; border-radius: 10px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); } .contractor-form-wrapper .wpcf7-form { display: grid; grid-template-columns: 1fr; gap: 20px; } .contractor-form-wrapper .wpcf7-form p { margin: 0; } .contractor-form-wrapper .wpcf7-form label { display: block; font-weight: 600; color: var(--primary-color); margin-bottom: 8px; font-size: 16px; } .contractor-form-wrapper .wpcf7-form input[type="text"], .contractor-form-wrapper .wpcf7-form input[type="email"], .contractor-form-wrapper .wpcf7-form input[type="tel"], .contractor-form-wrapper .wpcf7-form input[type="number"], .contractor-form-wrapper .wpcf7-form select, .contractor-form-wrapper .wpcf7-form textarea { width: 100%; padding: 12px 15px; border: 2px solid #e0e0e0; border-radius: 5px; font-size: 16px; font-family: inherit; transition: border-color 0.3s ease; } .contractor-form-wrapper .wpcf7-form input[type="text"]:focus, .contractor-form-wrapper .wpcf7-form input[type="email"]:focus, .contractor-form-wrapper .wpcf7-form input[type="tel"]:focus, .contractor-form-wrapper .wpcf7-form input[type="number"]:focus, .contractor-form-wrapper .wpcf7-form select:focus, .contractor-form-wrapper .wpcf7-form textarea:focus { outline: none; border-color: var(--secondary-color); } .contractor-form-wrapper .wpcf7-form textarea { min-height: 120px; resize: vertical; } .contractor-form-wrapper .wpcf7-submit { background: var(--secondary-color); color: var(--white); padding: 15px 40px; border: none; border-radius: 5px; font-size: 18px; font-weight: 700; cursor: pointer; transition: background 0.3s ease; width: 100%; margin-top: 10px; } .contractor-form-wrapper .wpcf7-submit:hover { background: var(--accent-color); } .form-not-found { text-align: center; padding: 40px; background: #fff3cd; border: 2px solid #ffc107; border-radius: 10px; color: #856404; } .form-not-found a { color: var(--secondary-color); text-decoration: underline; } /* ═══════════════════════════════════════════════════════════ HOW IT WORKS PAGE ═══════════════════════════════════════════════════════════ */ .how-it-works-hero { padding: 80px 0 60px; background: var(--white); text-align: center; } .how-it-works-hero h1 { font-size: 42px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .how-it-works-hero .hero-subtitle { font-size: 24px; color: var(--secondary-color); margin-bottom: 20px; font-weight: 600; } .how-it-works-hero .hero-description { font-size: 18px; line-height: 1.8; color: var(--text-color); max-width: 800px; margin: 0 auto; } .how-it-works-steps-section { padding: 80px 0; background: var(--light-bg); } .how-it-works-steps-section .section-header { text-align: center; margin-bottom: 50px; } .how-it-works-steps-section .section-title { font-size: 36px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .how-it-works-steps-section .section-subtitle { font-size: 20px; color: var(--text-color); } .how-it-works-steps-section .steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 40px; max-width: 1200px; margin: 0 auto; } .how-it-works-steps-section .step-item { text-align: center; background: var(--white); padding: 40px 30px; border-radius: 10px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); transition: transform 0.3s ease, box-shadow 0.3s ease; } .how-it-works-steps-section .step-item:hover { transform: translateY(-5px); box-shadow: 0 5px 20px rgba(0, 0, 0, 0.15); } .how-it-works-steps-section .step-number { width: 70px; height: 70px; background: var(--secondary-color); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; font-weight: 700; margin: 0 auto 20px; } .how-it-works-steps-section .step-item h3, .how-it-works-steps-section .step-item h1, .how-it-works-steps-section .step-item h2, .how-it-works-steps-section .step-item h4, .how-it-works-steps-section .step-item h5, .how-it-works-steps-section .step-item h6 { font-size: 24px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; text-align: center; } .how-it-works-steps-section .step-item p { font-size: 16px; line-height: 1.6; color: var(--text-color); margin: 0; text-align: center; } .how-it-works-benefits-section { padding: 80px 0; background: var(--white); } .how-it-works-benefits-section .section-header { text-align: center; margin-bottom: 50px; } .how-it-works-benefits-section .section-title { font-size: 36px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .how-it-works-benefits-section .section-subtitle { font-size: 20px; color: var(--text-color); } .benefits-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 30px; max-width: 1200px; margin: 0 auto; } .benefit-item { background: var(--light-bg); padding: 30px; border-radius: 10px; border-left: 4px solid var(--secondary-color); } .benefit-item h3 { font-size: 22px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .benefit-item p { font-size: 16px; line-height: 1.6; color: var(--text-color); margin: 0; } .how-it-works-faq-section { padding: 80px 0; background: var(--light-bg); } .how-it-works-faq-section .section-header { text-align: center; margin-bottom: 50px; } .how-it-works-faq-section .section-title { font-size: 36px; font-weight: 700; color: var(--primary-color); } .faq-list { max-width: 900px; margin: 0 auto; } .faq-item { background: var(--white); padding: 30px; margin-bottom: 20px; border-radius: 10px; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); } .faq-question { font-size: 22px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .faq-answer { font-size: 16px; line-height: 1.8; color: var(--text-color); } .faq-answer p { margin: 0; } .how-it-works-cta-section { padding: 80px 0; background: var(--secondary-color); color: var(--white); text-align: center; } .how-it-works-cta-section .cta-content h2 { font-size: 36px; font-weight: 700; margin-bottom: 20px; color: var(--white); } .how-it-works-cta-section .cta-content p { font-size: 20px; margin-bottom: 30px; max-width: 700px; margin-left: auto; margin-right: auto; } .how-it-works-cta-section .btn { background: var(--white); color: var(--secondary-color); padding: 15px 40px; font-size: 18px; font-weight: 700; } .how-it-works-cta-section .btn:hover { background: var(--accent-color); color: var(--white) !important; } /* Кнопки с синим фоном в секции how-it-works-cta-section */ .how-it-works-cta-section .btn-primary, .how-it-works-cta-section .btn[style*="background: var(--secondary-color)"], .how-it-works-cta-section .btn[style*="background-color: var(--secondary-color)"], .how-it-works-cta-section .btn[style*="background: var(--primary-color)"], .how-it-works-cta-section .btn[style*="background-color: var(--primary-color)"] { color: var(--white) !important; } .how-it-works-quote-form-section { padding: 80px 0; background: var(--white); } .how-it-works-quote-form-section .form-section-header { text-align: center; max-width: 700px; margin: 0 auto 50px; } .how-it-works-quote-form-section .form-section-header h2 { font-size: 36px; font-weight: 700; color: var(--primary-color); margin-bottom: 15px; } .how-it-works-quote-form-section .form-section-header p { font-size: 18px; line-height: 1.8; color: var(--text-color); margin: 0; } .quote-form-wrapper { max-width: 800px; margin: 0 auto; background: var(--light-bg); padding: 40px; border-radius: 10px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); } .quote-form-wrapper .wpcf7-form { display: grid; grid-template-columns: 1fr; gap: 20px; } .quote-form-wrapper .wpcf7-form p { margin: 0; } .quote-form-wrapper .wpcf7-form label { display: block; font-weight: 600; color: var(--primary-color); margin-bottom: 8px; font-size: 16px; } .quote-form-wrapper .wpcf7-form input[type="text"], .quote-form-wrapper .wpcf7-form input[type="email"], .quote-form-wrapper .wpcf7-form input[type="tel"], .quote-form-wrapper .wpcf7-form select, .quote-form-wrapper .wpcf7-form textarea { width: 100%; padding: 12px 15px; border: 2px solid #e0e0e0; border-radius: 5px; font-size: 16px; font-family: inherit; transition: border-color 0.3s ease; } .quote-form-wrapper .wpcf7-form input[type="text"]:focus, .quote-form-wrapper .wpcf7-form input[type="email"]:focus, .quote-form-wrapper .wpcf7-form input[type="tel"]:focus, .quote-form-wrapper .wpcf7-form select:focus, .quote-form-wrapper .wpcf7-form textarea:focus { outline: none; border-color: var(--secondary-color); } .quote-form-wrapper .wpcf7-form textarea { min-height: 120px; resize: vertical; } .quote-form-wrapper .wpcf7-submit { background: var(--secondary-color); color: var(--white); padding: 15px 40px; border: none; border-radius: 5px; font-size: 18px; font-weight: 700; cursor: pointer; transition: background 0.3s ease; width: 100%; margin-top: 10px; } .quote-form-wrapper .wpcf7-submit:hover { background: var(--accent-color); } /* Mobile responsive for How It Works page */ @media (max-width: 768px) { .how-it-works-hero h1 { font-size: 32px; } .how-it-works-hero .hero-subtitle { font-size: 20px; } .how-it-works-hero .hero-description { font-size: 16px; } .how-it-works-steps-section .section-title, .how-it-works-benefits-section .section-title, .how-it-works-faq-section .section-title, .how-it-works-quote-form-section .form-section-header h2 { font-size: 28px; } .how-it-works-steps-section .steps-grid { grid-template-columns: 1fr; gap: 30px; } .benefits-grid { grid-template-columns: 1fr; } .how-it-works-cta-section .cta-content h2 { font-size: 28px; } .quote-form-wrapper { padding: 25px; } } /* Mobile responsive for For Contractors page */ @media (max-width: 768px) { .contractors-content h2 { font-size: 28px; } .contractors-content h3 { font-size: 24px; } .how-it-works-steps { grid-template-columns: 1fr; } .step-item { flex-direction: column; text-align: center; } .step-number { margin: 0 auto; } .contractor-form-wrapper { padding: 25px; } .form-section-header h2 { font-size: 28px; } } /* Mobile responsive for Contact Form 7 */ @media (max-width: 768px) { .wpcf7-form { grid-template-columns: 1fr !important; } .wpcf7-form p { grid-column: 1 / -1 !important; } }