/*
Theme Name: Гинеколог Плюс (Astra Child)
Theme URI: https://www.kabinetginecologa.ru
Author: Ginekolog Plus
Author URI: https://www.kabinetginecologa.ru
Template: astra
Version: 5.5.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astra-child
Domain Path: /languages
Requires at least: 5.8
Requires PHP: 7.4
Tested up to: 6.4
Description: Дочерняя тема WordPress для медицинской клиники "Гинеколог Плюс" на базе темы Astra. WCAG 2.2 AA compliant.
*/
/* ============================================
CSS VARIABLES (BRAND COLORS + WCAG AA)
============================================ */
:root {
/* Brand Colors - проверены на контраст с белым текстом */
--med-primary: #5568d3;
--med-secondary: #6a4190;
--med-accent: #c2185b;
--med-success: #388e3c;
--med-warning: #f57c00;
--med-danger: #d32f2f;
--med-info: #0277bd;
/* Text Colors - WCAG AA compliant (контраст ≥ 4.5:1 на светлом фоне) */
--med-text: #1a1a1a;
--med-text-light: #4a4a4a;
--med-text-muted: #666666;
/* Background & UI */
--med-bg: #ffffff;
--med-bg-light: #f8f9fa;
--med-bg-gray: #f5f7fa;
--med-border: #cccccc;
/* Focus indicator - высокий контраст для доступности */
--med-focus: #005fcc;
--med-focus-ring: rgba(0, 95, 204, 0.25);
/* Spacing & Radius */
--med-radius: 16px;
--med-radius-sm: 8px;
/* Shadows */
--med-shadow: 0 2px 8px rgba(0,0,0,0.08);
--med-shadow-hover: 0 12px 24px rgba(0,0,0,0.12);
--med-shadow-lg: 0 25px 50px -12px rgba(0,0,0,0.2);
/* Layout */
--med-container: min(100% - 1rem, 1200px);
--med-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
/* Toast Colors */
--toast-success: #2e7d32;
--toast-error: #c62828;
--toast-warning: #ef6c00;
--toast-info: #0288d1;
/* Z-Index System */
--z-base: 1;
--z-header: 100;
--z-dropdown: 500;
--z-toast: 9999;
--z-modal: 10000;
--z-overlay: 9998;
/* WCAG: Системная подсказка браузеру */
color-scheme: light;
/* WCAG: Минимальные тач-таргеты */
--touch-target-min: 44px;
}
/* ============================================
GLOBAL RESET & BOX-SIZING
============================================ */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}

/* Performance: Contain layout for isolated components */
.med-card, .doctor-card, .service-card-mini, .glass-panel {
contain: layout style paint;
}

/* Performance: Content visibility for below-fold sections */
@media (min-width: 769px) {
.med-section:not(:first-child) {
content-visibility: auto;
contain-intrinsic-size: 0 500px;
}
}

/* Font display swap for better LCP */
@font-face {
font-family: 'Inter';
font-display: swap;
src: local('Inter'), local('Inter Regular');
}
/* WCAG: Глобальная плавная прокрутка */
html {
scroll-behavior: smooth;
}

/* Performance: Passive scroll optimization hint */
@media (prefers-reduced-motion: no-preference) {
html {
scroll-behavior: smooth;
}
}

@media (prefers-reduced-motion: reduce) {
html {
scroll-behavior: auto;
}
*, *::before, *::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
}
}
/* ============================================
BASE OVERRIDES (ASTRA COMPATIBLE)
============================================ */
.ast-container {
max-width: var(--med-container);
}
.page-template-template-medical-full .entry-header {
display: none;
}
.page-template-template-medical-full .site-content {
padding-top: 0;
padding-bottom: 0;
}
/* WCAG: Skip link для навигации с клавиатуры */
.skip-link {
position: absolute;
top: -40px;
left: 0;
background: var(--med-primary);
color: #ffffff;
padding: 0.75rem 1.5rem;
text-decoration: none;
font-weight: 600;
z-index: var(--z-header);
transition: top 0.2s;
}
.skip-link:focus {
top: 0;
outline: 3px solid #ffffff;
outline-offset: 2px;
}
/* ============================================
LAYOUT SYSTEM (.med-* classes)
============================================ */
.med-container {
width: 100%;
max-width: var(--med-container);
margin: 0 auto;
padding: 0 1.5rem;
}
.med-section {
padding: 5rem 0;
position: relative;
}
.med-grid {
display: grid;
gap: 1.5rem;
}
.med-flex {
display: flex;
gap: 1rem;
align-items: center;
}
/* Grid Responsive - поддержка 320px (WCAG 1.4.10) */
@media (min-width: 1025px) {
.med-grid-4 { grid-template-columns: repeat(4, 1fr); }
.med-grid-3 { grid-template-columns: repeat(3, 1fr); }
.med-grid-2 { grid-template-columns: repeat(2, 1fr); }
.med-grid-6 { grid-template-columns: repeat(6, 1fr); }
}
@media (min-width: 769px) and (max-width: 1024px) {
.med-grid-6 { grid-template-columns: repeat(3, 1fr); }
.med-grid-4 { grid-template-columns: repeat(2, 1fr); }
.med-grid-3 { grid-template-columns: repeat(2, 1fr); }
.med-grid-2 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
.med-section { padding: 3rem 0; }
.med-grid { grid-template-columns: 1fr !important; }
.med-flex { flex-direction: column; }
.med-hide-mobile { display: none !important; }
.med-full-width-mobile { width: 100% !important; }
}
/* WCAG: Адаптация для очень узких экранов (320px) */
@media (max-width: 375px) {
.med-container { padding: 0 1rem; }
.med-card { padding: 1.5rem; }
}
/* ============================================
TYPOGRAPHY - WCAG AA COMPLIANT
============================================ */
.med-h1,
.med-h2,
h1, h2, h3, h4, h5, h6 {
color: var(--med-text);
line-height: 1.5;
}
.med-h1 {
font-size: clamp(1.8rem, 5vw, 2.8rem);
margin: 0 0 0.5rem;
font-weight: 700;
}
.med-h2 {
font-size: clamp(1.5rem, 4vw, 2rem);
margin: 0 0 1rem;
text-align: center;
font-weight: 700;
}
.med-subtitle {
color: var(--med-text-light);
text-align: center;
margin: 0 0 3rem;
font-size: 1.1rem;
line-height: 1.6;
}
/* ============================================
COMPONENTS - Cards
============================================ */
.med-card {
background: var(--med-bg);
border-radius: var(--med-radius);
padding: 2rem;
box-shadow: var(--med-shadow);
border: 1px solid var(--med-border);
transition: var(--med-transition);
height: 100%;
}
.med-card-icon {
width: 64px;
height: 64px;
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 1rem;
font-size: 1.5rem;
color: var(--med-primary);
background: var(--med-bg-light);
}
/* WCAG: Hover-эффекты только для устройств с курсором */
@media (hover: hover) and (pointer: fine) {
.med-hover-lift:hover {
transform: translateY(-4px);
box-shadow: var(--med-shadow-hover);
}
.med-hover-scale:hover img {
transform: scale(1.05);
}
}
/* WCAG: Визуальный отклик на тач-устройствах вместо hover */
@media (hover: none) and (pointer: coarse) {
.med-hover-lift:active,
.service-item:active {
background: var(--med-bg-light);
transform: translateY(-1px);
}
}
/* Glassmorphism with Fallback */
.glass-panel {
background: rgba(255, 255, 255, 0.95);
border: 1px solid rgba(255, 255, 255, 0.2);
border-radius: var(--med-radius);
}
@supports (backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px)) {
.glass-panel {
background: rgba(255, 255, 255, 0.1);
-webkit-backdrop-filter: blur(10px);
backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.2);
}
}
/* Buttons - WCAG AA Focus & Contrast */
.med-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
min-height: 48px;
padding: 0.875rem 1.5rem;
border-radius: var(--med-radius-sm);
text-decoration: none;
font-weight: 600;
font-size: 1rem;
border: none;
cursor: pointer;
transition: all 0.2s ease;
color: #ffffff;
background: var(--med-primary);
}
.med-btn:hover {
filter: brightness(1.05);
transform: translateY(-1px);
}
.med-btn:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
box-shadow: 0 0 0 6px var(--med-focus-ring);
}
.med-btn:active {
transform: translateY(0);
}
.med-btn:disabled {
opacity: 0.6;
cursor: not-allowed;
}
/* Messengers Scroll Container */
.messengers-scroll {
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
margin: 1.5rem 0;
}
@media (max-width: 480px) {
.messengers-scroll {
justify-content: center;
}
}
/* Messenger Buttons */
.med-messenger-btn {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1.5rem;
border-radius: 50px;
color: #ffffff;
text-decoration: none;
font-weight: 500;
font-size: 0.95rem;
transition: all 0.2s ease;
box-shadow: 0 4px 6px rgba(0,0,0,0.1);
border: none;
cursor: pointer;
min-height: var(--touch-target-min);
min-width: var(--touch-target-min);
}
.med-messenger-btn:hover {
transform: translateY(-2px);
box-shadow: 0 6px 12px rgba(0,0,0,0.2);
color: #ffffff;
text-decoration: none;
}
.med-messenger-btn:focus-visible {
outline: 3px solid #ffffff;
outline-offset: 2px;
box-shadow: 0 0 0 4px var(--med-focus-ring);
}
.med-messenger-btn.max { background: #5a4a78; }
.med-messenger-btn.telegram { background: #0077b5; }
.med-messenger-btn.whatsapp { background: #128c7e; }
.med-messenger-btn.phone { background: var(--med-info); }
@media (max-width: 768px) {
.med-messenger-btn span.text {
display: none;
}
.med-messenger-btn {
padding: 0.75rem;
font-size: 1.2rem;
width: var(--touch-target-min);
height: var(--touch-target-min);
}
}
/* ============================================
ACCORDION (DETAILS/SUMMARY) - Accessible
============================================ */
details {
background: var(--med-bg);
border-radius: 12px;
box-shadow: var(--med-shadow);
overflow: hidden;
margin-bottom: 1rem;
border: 1px solid var(--med-border);
}
summary {
padding: 1.5rem;
display: flex;
align-items: center;
gap: 1rem;
font-weight: 600;
font-size: 1.1rem;
color: var(--med-text);
cursor: pointer;
list-style: none;
position: relative;
user-select: none;
}
summary::-webkit-details-marker {
display: none;
}
summary .acc-icon {
transition: transform 0.3s ease;
margin-left: auto;
font-size: 0.8rem;
color: var(--med-text-muted);
display: block;
}
details[open] summary {
border-bottom: 1px solid var(--med-border);
}
details[open] summary .acc-icon {
transform: rotate(180deg);
}
summary:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: -3px;
}
.acc-content {
padding: 1.5rem;
background: var(--med-bg-light);
color: var(--med-text);
}
/* Service Items in Accordion */
.service-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 1rem;
background: var(--med-bg);
border-radius: var(--med-radius-sm);
margin-bottom: 0.75rem;
box-shadow: 0 1px 3px rgba(0,0,0,0.05);
transition: all 0.2s;
text-decoration: none;
border: 1px solid var(--med-border);
color: var(--med-text);
}
.service-item:hover {
transform: translateX(4px);
box-shadow: 0 2px 8px rgba(0,0,0,0.1);
text-decoration: none;
}
.service-item:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
.service-item-name {
color: var(--med-text);
font-weight: 500;
}
.service-item-meta {
font-size: 0.85rem;
color: var(--med-text-muted);
margin-top: 0.25rem;
}
.service-item-price {
font-weight: 600;
white-space: nowrap;
padding: 0.5rem 1rem;
border-radius: 6px;
background: rgba(0,0,0,0.03);
}
/* ============================================
AJAX SEARCH - Accessible
============================================ */
.astra-child-search-container {
position: relative;
max-width: 600px;
margin: 0 auto;
}
.astra-child-search-input {
width: 100%;
padding: 1rem 1.5rem;
border: 2px solid var(--med-border);
border-radius: var(--med-radius-sm);
font-size: 1rem;
transition: var(--med-transition);
background: var(--med-bg);
color: var(--med-text);
}
.astra-child-search-input::placeholder {
color: var(--med-text-muted);
}
.astra-child-search-input:focus {
outline: none;
border-color: var(--med-focus);
box-shadow: 0 0 0 3px var(--med-focus-ring);
}
.astra-child-search-input:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
.astra-child-search-results {
position: absolute;
top: 100%;
left: 0;
right: 0;
background: var(--med-bg);
border-radius: var(--med-radius-sm);
box-shadow: var(--med-shadow-hover);
margin-top: 0.5rem;
max-height: 400px;
overflow-y: auto;
z-index: var(--z-dropdown);
opacity: 0;
visibility: hidden;
transform: translateY(-10px);
transition: all 0.2s ease;
border: 1px solid var(--med-border);
}
.astra-child-search-results.is-active {
opacity: 1;
visibility: visible;
transform: translateY(0);
}
.astra-child-search-result {
display: flex;
align-items: center;
gap: 1rem;
padding: 1rem 1.5rem;
text-decoration: none;
color: var(--med-text);
border-bottom: 1px solid var(--med-border);
transition: background 0.2s;
}
.astra-child-search-result:hover,
.astra-child-search-result.is-active {
background: var(--med-bg-light);
}
.astra-child-search-result:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: -2px;
}
.astra-child-search-result:last-child {
border-bottom: none;
}
.result-icon {
font-size: 1.5rem;
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
background: var(--med-bg-light);
border-radius: 8px;
flex-shrink: 0;
color: var(--med-primary);
}
.result-content {
flex: 1;
min-width: 0;
}
.result-title {
display: block;
font-weight: 600;
margin-bottom: 0.25rem;
}
.result-meta {
display: block;
font-size: 0.85rem;
color: var(--med-text-muted);
}
.result-type {
font-size: 0.75rem;
padding: 0.25rem 0.5rem;
background: var(--med-primary);
color: #ffffff;
border-radius: 4px;
text-transform: uppercase;
flex-shrink: 0;
}
/* WCAG: Пустое состояние поиска */
.astra-child-search-results:empty::after {
content: "Ничего не найдено. Попробуйте другой запрос.";
display: block;
padding: 1.5rem;
text-align: center;
color: var(--med-text-muted);
font-style: italic;
}
/* Skeleton Loading */
.astra-child-search-skeleton {
padding: 1rem;
}
.skeleton-item {
display: flex;
align-items: center;
gap: 1rem;
padding: 1rem;
margin-bottom: 0.5rem;
}
.skeleton-icon,
.skeleton-text {
background: linear-gradient(90deg, var(--med-bg-light) 25%, var(--med-border) 50%, var(--med-bg-light) 75%);
background-size: 200% 100%;
animation: skeleton-loading 1.5s infinite;
will-change: background-position;
}
.skeleton-icon {
width: 40px;
height: 40px;
border-radius: 8px;
}
.skeleton-text {
flex: 1;
height: 20px;
border-radius: 4px;
}
/* ============================================
TOAST NOTIFICATIONS - Accessible
============================================ */
.astra-child-toast-container {
position: fixed;
top: 20px;
right: 20px;
z-index: var(--z-toast);
display: flex;
flex-direction: column;
gap: 10px;
max-width: 400px;
pointer-events: none;
}
.astra-child-toast {
display: flex;
align-items: center;
gap: 12px;
padding: 16px 20px;
background: var(--med-bg);
border-radius: var(--med-radius-sm);
box-shadow: var(--med-shadow-hover);
border-left: 4px solid;
pointer-events: auto;
color: var(--med-text);
border: 1px solid var(--med-border);
}
.astra-child-toast--success {
border-left-color: var(--toast-success);
background: #f1f8e9;
}
.astra-child-toast--error {
border-left-color: var(--toast-error);
background: #ffebee;
}
.astra-child-toast--warning {
border-left-color: var(--toast-warning);
background: #fff3e0;
}
.astra-child-toast--info {
border-left-color: var(--toast-info);
background: #e3f2fd;
}
.toast-icon {
font-size: 1.25rem;
flex-shrink: 0;
}
.toast-message {
flex: 1;
font-size: 0.95rem;
color: var(--med-text);
}
.toast-close {
background: none;
border: none;
font-size: 1.5rem;
color: var(--med-text-muted);
cursor: pointer;
padding: 0;
width: var(--touch-target-min);
height: var(--touch-target-min);
display: flex;
align-items: center;
justify-content: center;
transition: color 0.2s;
border-radius: 4px;
}
.toast-close:hover {
color: var(--med-text);
background: var(--med-bg-light);
}
.toast-close:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
@media (max-width: 768px) {
.astra-child-toast-container {
left: 20px;
right: 20px;
max-width: none;
}
}
/* ============================================
MOBILE MENU - Accessible
============================================ */
.astra-child-mobile-menu-toggle {
display: none;
background: none;
border: none;
cursor: pointer;
padding: 10px;
z-index: var(--z-header);
min-width: var(--touch-target-min);
min-height: var(--touch-target-min);
}
.astra-child-mobile-menu-toggle .menu-icon {
display: block;
width: 24px;
height: 2px;
background: var(--med-text);
position: relative;
transition: all 0.3s;
}
.astra-child-mobile-menu-toggle .menu-icon::before,
.astra-child-mobile-menu-toggle .menu-icon::after {
content: '';
position: absolute;
width: 24px;
height: 2px;
background: var(--med-text);
transition: all 0.3s;
}
.astra-child-mobile-menu-toggle .menu-icon::before { top: -8px; }
.astra-child-mobile-menu-toggle .menu-icon::after { top: 8px; }
.astra-child-mobile-menu-toggle[aria-expanded="true"] .menu-icon {
background: transparent;
}
.astra-child-mobile-menu-toggle[aria-expanded="true"] .menu-icon::before {
transform: rotate(45deg);
top: 0;
}
.astra-child-mobile-menu-toggle[aria-expanded="true"] .menu-icon::after {
transform: rotate(-45deg);
top: 0;
}
.astra-child-mobile-menu-toggle:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 4px;
}
@media (max-width: 768px) {
.astra-child-mobile-menu-toggle {
display: block;
}
}
/* ============================================
FORM VALIDATION - WCAG AA
============================================ */
input.is-invalid,
textarea.is-invalid {
border-color: var(--med-danger) !important;
background-color: rgba(211, 47, 47, 0.05);
}
input.is-invalid + .field-error::before,
textarea.is-invalid + .field-error::before {
content: "⚠ ";
margin-right: 0.25rem;
}
.field-error {
display: block;
color: var(--med-danger);
font-size: 0.85rem;
margin-top: 0.5rem;
}
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
/* WCAG: Autofill в тёмной теме */
@media (prefers-color-scheme: dark) {
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
-webkit-text-fill-color: #ffffff;
-webkit-box-shadow: 0 0 0 1000px #151525 inset;
box-shadow: 0 0 0 1000px #151525 inset;
transition: background-color 5000s ease-in-out 0s;
}
}

/* Manual dark mode via class */
.dark-mode {
    color-scheme: dark;
}
.dark-mode, .dark-mode body {
    background: var(--med-dark-bg);
    color: var(--med-dark-text);
}
.dark-mode .med-card,
.dark-mode .doctor-card,
.dark-mode .review-card,
.dark-mode .quick-service-card,
.dark-mode details,
.dark-mode .service-item,
.dark-mode .license-image,
.dark-mode .glass-panel {
    background: var(--med-dark-bg-light);
    border-color: var(--med-dark-border);
}
.dark-mode .med-h1,
.dark-mode .med-h2,
.dark-mode h1, .dark-mode h2, .dark-mode h3, .dark-mode h4, .dark-mode h5, .dark-mode h6,
.dark-mode .med-subtitle,
.dark-mode .review-text,
.dark-mode .modal-content,
.dark-mode .acc-content {
    color: var(--med-dark-text);
}
.dark-mode .astra-child-search-input,
.dark-mode input,
.dark-mode textarea,
.dark-mode select {
    background: var(--med-dark-bg);
    color: var(--med-dark-text);
    border-color: var(--med-dark-border);
}
.dark-mode .astra-child-search-results,
.dark-mode .astra-child-toast {
    background: var(--med-dark-bg-light);
    border-color: var(--med-dark-border);
}
.dark-mode .filter-tab,
.dark-mode .pagination .page-numbers {
    color: var(--med-dark-text);
    background: var(--med-dark-bg);
    border-color: var(--med-dark-border);
}
.dark-mode .site-header.is-scrolled {
    background: rgba(10, 10, 20, 0.95);
}
.dark-mode .med-section {
    background: var(--med-dark-bg);
}
.dark-mode .modal-container,
.dark-mode .modal-header,
.dark-mode .modal-footer {
    background: var(--med-dark-bg-light);
    border-color: var(--med-dark-border);
}
.dark-mode .entry-content,
.dark-mode .ast-single-post .entry-content,
.dark-mode .ast-single-page .entry-content {
    color: var(--med-dark-text) !important;
    background: var(--med-dark-bg) !important;
}
.dark-mode .entry-content p,
.dark-mode .entry-content h1,
.dark-mode .entry-content h2,
.dark-mode .entry-content h3,
.dark-mode .entry-content li {
    color: var(--med-dark-text) !important;
}
/* ============================================
SCROLL ANIMATIONS
============================================ */
/* Scroll animations are now controlled via animations.css and animations.js */
/* Use .anim-on-scroll class for scroll-triggered animations */

/* ============================================
STICKY HEADER
============================================ */
.site-header {
transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
z-index: var(--z-header);
}
body .site-header.is-scrolled {
background: rgba(255, 255, 255, 0.95);
-webkit-backdrop-filter: blur(10px);
backdrop-filter: blur(10px);
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}
.site-header.is-hidden {
transform: translateY(-100%);
}

/* Header menu - dark text on white scrolled background */
.main-header-menu a,
.main-header-bar .main-header-menu a {
color: var(--med-text);
}
.main-header-menu a:hover,
.main-header-menu a:focus {
color: var(--med-primary);
}

/* ============================================
HERO SECTION
============================================ */
.medical-hero {
background: linear-gradient(135deg, var(--med-primary) 0%, var(--med-secondary) 100%);
color: #ffffff;
position: relative;
overflow: hidden;
min-height: 90vh;
display: flex;
align-items: center;
}
.medical-hero .glass-panel {
padding: 2rem;
}
.hero-badge {
display: inline-flex;
align-items: center;
gap: 0.5rem;
background: rgba(255,255,255,0.15);
-webkit-backdrop-filter: blur(10px);
backdrop-filter: blur(10px);
padding: 0.5rem 1rem;
border-radius: 30px;
font-size: 0.85rem;
border: 1px solid rgba(255,255,255,0.2);
margin-bottom: 2rem;
}
.hero-badge::before {
content: '';
width: 8px;
height: 8px;
background: #4caf50;
border-radius: 50%;
}
.status-pulse {
animation: pulse-green 2s infinite;
}
/* Сдвинуть вниз на 20px и вправо на 30px */
.hero-badge-inline {
margin-top: 70px;     /* вниз */
margin-right: 00px;    /* вправо */
}
/* ============================================
WHY US SECTION
============================================ */
.why-us-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 1.5rem;
}
/* ============================================
REVIEWS SECTION
============================================ */
.reviews-section {
background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
}
.review-card {
background: var(--med-bg);
padding: 2rem;
border-radius: var(--med-radius);
box-shadow: 0 2px 12px rgba(0,0,0,0.08);
position: relative;
height: 100%;
display: flex;
flex-direction: column;
}
.review-quote {
position: absolute;
top: 1.5rem;
right: 1.5rem;
font-size: 4rem;
opacity: 0.1;
line-height: 1;
font-family: Georgia, serif;
pointer-events: none;
}
.review-text {
color: var(--med-text);
line-height: 1.7;
margin-bottom: 1.5rem;
font-style: italic;
position: relative;
z-index: 1;
flex-grow: 1;
}
.review-author {
font-weight: 700;
color: var(--med-text);
font-size: 1.1rem;
margin-bottom: 0.5rem;
}
.review-stars {
color: #ffc107;
letter-spacing: 2px;
margin-bottom: 1rem;
}
.review-footer {
display: flex;
justify-content: space-between;
align-items: center;
padding-top: 1rem;
border-top: 1px solid var(--med-border);
font-size: 0.9rem;
color: var(--med-text-muted);
}
/* ============================================
DOCTORS CARDS
============================================ */
.doctor-card {
background: var(--med-bg);
border-radius: var(--med-radius);
overflow: hidden;
box-shadow: 0 4px 12px rgba(0,0,0,0.08);
transition: var(--med-transition);
content-visibility: auto;
contain-intrinsic-size: 300px 400px;
}
.doctor-image-wrap {
position: relative;
height: 350px;
overflow: hidden;
}
.doctor-experience-badge {
position: absolute;
top: 15px;
right: 15px;
bottom: auto;
background: linear-gradient(135deg, var(--med-primary) 0%, var(--med-secondary) 100%);
color: #ffffff;
padding: 8px 16px;
border-radius: 20px;
font-size: 14px;
font-weight: 600;
min-width: 0;
width: auto;
height: auto;
display: inline-flex;
align-items: center;
justify-content: center;
box-shadow: 0 4px 15px rgba(102, 126, 234, 0.4);
z-index: 10;
}
@media (max-width: 768px) {
.doctor-experience-badge {
top: 10px;
right: 10px;
padding: 6px 12px;
font-size: 12px;
}
}
.doctor-experience-badge::before,
.doctor-experience-badge::after {
display: none;
}
a.doctor-experience-badge,
button.doctor-experience-badge {
text-decoration: none;
border: none;
background: linear-gradient(135deg, var(--med-primary) 0%, var(--med-secondary) 100%);
}
.doctor-info {
padding: 2rem;
text-align: center;
}
.doctor-name {
margin: 0 0 0.25rem;
color: var(--med-text);
font-size: 1.4rem;
font-weight: 700;
}
.doctor-position {
margin: 0 0 1rem;
color: var(--med-info);
font-weight: 600;
font-size: 1.1rem;
}
.doctor-specialty {
color: var(--med-text-light);
font-size: 0.95rem;
margin-bottom: 1.5rem;
line-height: 1.4;
}
/* ============================================
QUICK SERVICES (6 icons)
============================================ */
.quick-service-card {
background: var(--med-bg);
border-radius: var(--med-radius);
padding: 2rem 1rem;
text-align: center;
text-decoration: none;
color: inherit;
box-shadow: var(--med-shadow);
border-top: 4px solid var(--med-primary);
display: flex;
flex-direction: column;
height: 100%;
transition: var(--med-transition);
}
.quick-service-card:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
.quick-service-icon {
width: 70px;
height: 70px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
margin: 0 auto 1rem;
font-size: 2rem;
background: var(--med-bg-light);
flex-shrink: 0;
color: var(--med-primary);
}
.quick-service-title {
font-size: 1.1rem;
color: var(--med-text);
margin: 0 0 0.5rem;
font-weight: 600;
}
.quick-service-desc {
font-size: 0.9rem;
color: var(--med-text-muted);
margin: 0;
line-height: 1.4;
flex-grow: 1;
}
.quick-service-link {
margin-top: 1rem;
font-weight: 600;
font-size: 0.9rem;
}
/* ============================================
FAQ SECTION
============================================ */
.faq-section details {
margin-bottom: 1rem;
}
.faq-section summary {
border-left: 4px solid var(--med-primary);
}
/* ============================================
LICENSES GALLERY
============================================ */
.license-image {
padding-top: 133.33%;
position: relative;
display: flex;
align-items: center;
justify-content: center;
padding: 1rem;
overflow: hidden;
transition: var(--med-transition);
background: var(--med-bg);
content-visibility: auto;
contain-intrinsic-size: 300px 400px;
}
@supports (aspect-ratio: 3/4) {
.license-image {
padding-top: 0;
aspect-ratio: 3/4;
}
}
.license-image img {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
max-width: 100%;
max-height: 100%;
object-fit: contain;
transition: transform 0.3s;
}
@supports (aspect-ratio: 3/4) {
.license-image img {
position: static;
transform: none;
}
}
.license-image:hover img {
transform: scale(1.05);
}
/* ============================================
DOCTOR MODAL - Accessible
============================================ */
.doctor-modal {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: var(--z-modal);
display: flex;
align-items: center;
justify-content: center;
opacity: 0;
animation: fadeIn 0.2s forwards;
}
.modal-overlay {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.6);
-webkit-backdrop-filter: blur(4px);
backdrop-filter: blur(4px);
z-index: var(--z-overlay);
}
.modal-container {
position: relative;
width: 90%;
max-width: 800px;
max-height: 90vh;
overflow-y: auto;
background: var(--med-bg);
border-radius: 24px;
box-shadow: var(--med-shadow-lg);
z-index: var(--z-modal);
}
.modal-header {
padding: 1.5rem 2rem;
border-bottom: 1px solid var(--med-border);
display: flex;
justify-content: space-between;
align-items: center;
position: sticky;
top: 0;
background: var(--med-bg);
border-radius: 24px 24px 0 0;
z-index: 1;
}
.modal-close {
background: none;
border: none;
font-size: 1.5rem;
color: var(--med-text-muted);
cursor: pointer;
padding: 0;
width: var(--touch-target-min);
height: var(--touch-target-min);
display: flex;
align-items: center;
justify-content: center;
transition: color 0.2s;
border-radius: 4px;
}
.modal-close:hover {
color: var(--med-text);
background: var(--med-bg-light);
}
.modal-close:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
.modal-content {
padding: 2rem;
color: var(--med-text);
}
.modal-footer {
padding: 1.5rem 2rem;
border-top: 1px solid var(--med-border);
display: flex;
justify-content: flex-end;
gap: 1rem;
position: sticky;
bottom: 0;
background: var(--med-bg);
border-radius: 0 0 24px 24px;
}
body.modal-open > *:not(.doctor-modal) {
pointer-events: none;
opacity: 0.5;
user-select: none;
}
.doctor-modal {
pointer-events: auto;
}
/* ============================================
PROFESSIONAL FORMS - WCAG AA
============================================ */
.astra-child-form {
max-width: 600px;
margin: 0 auto;
}
.astra-child-form .form-group {
margin-bottom: 1.5rem;
}
.astra-child-form label {
display: block;
margin-bottom: 0.5rem;
font-weight: 500;
color: var(--med-text);
}
.astra-child-form input,
.astra-child-form textarea,
.astra-child-form select {
width: 100%;
padding: 0.875rem 1rem;
border: 2px solid var(--med-border);
border-radius: var(--med-radius-sm);
font-size: 1rem;
transition: border-color 0.2s, box-shadow 0.2s;
background: var(--med-bg);
color: var(--med-text);
min-height: 48px;
}
.astra-child-form .form-group:focus-within label {
color: var(--med-primary);
}
.astra-child-form input:focus,
.astra-child-form textarea:focus,
.astra-child-form select:focus {
outline: none;
border-color: var(--med-focus);
box-shadow: 0 0 0 3px var(--med-focus-ring);
}
.astra-child-form input:focus-visible,
.astra-child-form textarea:focus-visible,
.astra-child-form select:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
.astra-child-form .form-submit {
padding: 0.875rem 1.5rem;
background: var(--med-primary);
color: #ffffff;
border: none;
border-radius: var(--med-radius-sm);
font-size: 1rem;
font-weight: 600;
cursor: pointer;
transition: all 0.2s;
min-height: 48px;
}
.astra-child-form .form-submit:hover {
filter: brightness(1.05);
transform: translateY(-1px);
}
.astra-child-form .form-submit:focus-visible {
outline: 3px solid #ffffff;
outline-offset: 2px;
box-shadow: 0 0 0 4px var(--med-focus-ring);
}
/* ============================================
BREADCRUMBS
============================================ */
.med-breadcrumbs {
display: flex;
gap: 0.5rem;
list-style: none;
padding: 0;
margin: 0;
flex-wrap: wrap;
}
.med-breadcrumbs li:not(:last-child)::after {
content: '/';
margin-left: 0.5rem;
color: var(--med-text-muted);
}
.med-breadcrumbs a {
color: inherit;
text-decoration: none;
}
.med-breadcrumbs a:hover {
text-decoration: underline;
}
.med-breadcrumbs a:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 4px;
}
/* ============================================
FILTER TABS
============================================ */
.filter-tab {
display: inline-flex;
align-items: center;
padding: 0.75rem 1.5rem;
border-radius: 8px;
text-decoration: none;
font-weight: 600;
transition: all 0.2s;
color: var(--med-text);
background: var(--med-bg);
border: 2px solid var(--med-border);
min-height: 44px;
}
.filter-tab:hover:not(.is-active) {
background: var(--med-bg-light);
}
.filter-tab.is-active {
background: var(--med-primary);
color: #ffffff;
border-color: var(--med-primary);
}
.filter-tab:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
/* ============================================
PAGINATION
============================================ */
.pagination {
margin-top: 3rem;
}
.pagination .page-numbers {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 44px;
height: 44px;
padding: 0 0.75rem;
border-radius: 8px;
text-decoration: none;
font-weight: 500;
transition: all 0.2s;
color: var(--med-text);
background: var(--med-bg);
border: 2px solid var(--med-border);
}
.pagination .page-numbers.current {
background: var(--med-primary);
color: #ffffff;
border-color: var(--med-primary);
}
.pagination .page-numbers:not(.current):hover {
background: var(--med-bg-light);
}
.pagination .page-numbers:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
}
/* ============================================
UTILITY CLASSES
============================================ */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }
.mt-1 { margin-top: 1rem; }
.mt-2 { margin-top: 1.5rem; }
.mt-3 { margin-top: 2rem; }
.mb-1 { margin-bottom: 1rem; }
.mb-2 { margin-bottom: 1.5rem; }
.mb-3 { margin-bottom: 2rem; }
.hidden { display: none !important; }
.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
.sr-only:focus {
position: static;
width: auto;
height: auto;
overflow: visible;
clip: auto;
white-space: normal;
}
/* ============================================
PRINT STYLES
============================================ */
@media print {
.medical-hero { background: #fff !important; color: #000 !important; }
.no-print,
.sticky-review-btn,
.messengers-scroll,
.astra-child-toast-container,
#wpadminbar,
.doctor-actions {
display: none !important;
}
.med-card {
break-inside: avoid;
box-shadow: none;
border: 1px solid #ccc;
}

/* Print styles - header */
.site-header {
position: static !important;
box-shadow: none !important;
background: white !important;
}

a {
text-decoration: none;
color: #000;
}
a[href]::after {
content: " (" attr(href) ")";
font-size: 0.85em;
color: #666;
}
}
/* ============================================
REDUCED MOTION - WCAG 2.3.3
============================================ */
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
scroll-behavior: auto !important;
}
.astra-child-toast,
.modal-container {
animation: none !important;
transition: none !important;
}
}
/* ============================================
HIGH CONTRAST MODE SUPPORT - WCAG 1.4.6
============================================ */
@media (prefers-contrast: high) {
:root {
--med-border: #000000;
--med-text-muted: #333333;
--med-focus: #000000;
}
.med-card,
details,
.service-item,
input,
textarea,
select {
border-width: 2px;
border-color: #000000;
}
.med-btn,
.filter-tab.is-active {
border: 2px solid currentColor;
}
}
/* ============================================
SHORTCODES SUPPORT
============================================ */
.astra-child-doctors-grid.med-grid {
grid-template-columns: repeat(2, 1fr);
}
.astra-child-doctors-grid.med-grid[data-columns="1"] { grid-template-columns: 1fr; }
.astra-child-doctors-grid.med-grid[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.astra-child-doctors-grid.med-grid[data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
.astra-child-doctors-grid.med-grid[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1024px) {
.astra-child-doctors-grid.med-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 768px) {
.astra-child-doctors-grid.med-grid { grid-template-columns: 1fr !important; }
}
.astra-child-hours {
display: flex;
flex-direction: column;
gap: 0.25rem;
font-size: 0.95rem;
}
.astra-child-hours .hours-label {
font-weight: 600;
color: var(--med-text);
}
.astra-child-hours .hours-value {
color: var(--med-text-light);
}
.astra-child-service-item .service-price {
font-size: 1.1rem;
color: var(--med-primary);
font-weight: 600;
margin: 0.5rem 0;
}
/* Phone link styles */
.astra-child-phone-link {
color: var(--med-info);
text-decoration: none;
font-weight: 600;
transition: color 0.2s;
}
.astra-child-phone-link:hover {
color: var(--med-primary);
text-decoration: underline;
}
.astra-child-phone-link:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 4px;
}
/* Address link styles */
.astra-child-address-link {
color: inherit;
text-decoration: none;
}
.astra-child-address-link:hover {
text-decoration: underline;
}
.astra-child-address-link:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 4px;
}
/* ============================================
DARK MODE - WCAG AA COMPLIANT
============================================ */
@media (prefers-color-scheme: dark) {
:root {
color-scheme: dark;
/* Dark theme variables */
--med-bg: var(--med-dark-bg);
--med-bg-light: var(--med-dark-bg-light);
--med-bg-gray: #1a1a2e;
--med-text: var(--med-dark-text);
--med-text-light: #d0d0e0;
--med-text-muted: var(--med-dark-text-muted);
--med-border: var(--med-dark-border);
--med-shadow: 0 2px 12px rgba(0,0,0,0.5);
--med-shadow-hover: 0 12px 24px rgba(0,0,0,0.7);
--med-shadow-lg: 0 25px 50px -12px rgba(0,0,0,0.8);
--toast-success: #81c784;
--toast-error: #e57373;
--toast-warning: #ffb74d;
--toast-info: #64b5f6;
/* Светлее для контраста на тёмном фоне */
--med-primary: #7986cb;
--med-focus: #8ab4f8;
--med-focus-ring: rgba(138, 180, 248, 0.3);
}
body {
background: var(--med-bg);
color: var(--med-text);
}
.med-card,
.doctor-card,
.review-card,
.quick-service-card,
details,
.service-item,
.license-image {
	background: var(--med-bg-light);
	border-color: var(--med-border);
}
.glass-panel {
	background: rgba(21, 21, 37, 0.9);
	border-color: rgba(255, 255, 255, 0.15);
}
.med-h1,
.med-h2,
h1, h2, h3, h4, h5, h6,
.med-subtitle,
.review-text,
.modal-content,
.acc-content {
color: var(--med-text);
}
.doctor-position,
.doctor-specialty,
.quick-service-desc,
.result-meta,
.service-item-meta,
.review-footer,
.med-breadcrumbs li:not(:last-child)::after {
color: var(--med-text-light);
}
.result-type,
.service-item-price {
color: var(--med-text-muted);
}
a {
color: #8ab4f8;
}
a:hover {
color: #aecbfa;
}
.astra-child-search-input {
background: var(--med-bg);
color: var(--med-text);
border-color: var(--med-border);
}
.astra-child-search-input::placeholder {
color: var(--med-text-muted);
}
.astra-child-search-results {
background: var(--med-bg-light);
border-color: var(--med-border);
}
.astra-child-search-result {
color: var(--med-text);
border-bottom-color: var(--med-border);
}
.astra-child-search-result:hover,
.astra-child-search-result.is-active {
background: var(--med-bg);
}
.result-icon {
background: var(--med-bg);
color: var(--med-primary);
}
.astra-child-toast {
background: var(--med-bg-light);
color: var(--med-text);
border-color: var(--med-border);
}
.toast-close {
color: var(--med-text-muted);
}
.toast-close:hover {
color: var(--med-text);
background: var(--med-bg);
}
input,
textarea,
select,
.astra-child-form input,
.astra-child-form textarea,
.astra-child-form select {
background: var(--med-bg);
color: var(--med-text);
border-color: var(--med-border);
}
.filter-tab {
color: var(--med-text);
background: var(--med-bg);
border-color: var(--med-border);
}
.filter-tab.is-active {
background: var(--med-primary);
color: #ffffff;
}
.med-btn:focus-visible,
.filter-tab:focus-visible,
.pagination .page-numbers:focus-visible,
.med-messenger-btn:focus-visible,
input:focus-visible,
textarea:focus-visible {
outline-color: var(--med-focus);
box-shadow: 0 0 0 4px var(--med-focus-ring);
}
.pagination .page-numbers {
color: var(--med-text);
background: var(--med-bg);
border-color: var(--med-border);
}
.site-header.is-scrolled {
background: rgba(10, 10, 20, 0.95);
}
.med-section {
background: var(--med-bg);
}
.reviews-section {
background: linear-gradient(135deg, var(--med-bg-gray) 0%, var(--med-bg) 100%);
}
.faq-section summary {
border-left-color: var(--med-primary);
}
.modal-container,
.modal-header,
.modal-footer {
background: var(--med-bg-light);
border-color: var(--med-border);
}
.modal-close {
color: var(--med-text-muted);
}
.modal-close:hover {
color: var(--med-text);
background: var(--med-bg);
}
.skeleton-icon,
.skeleton-text {
background: linear-gradient(90deg, #1a1a2e 25%, #252540 50%, #1a1a2e 75%);
}
.medical-hero {
background: linear-gradient(135deg, #1a1a2e 0%, #0f0f1a 100%);
}
.medical-hero .hero-badge {
background: rgba(255, 255, 255, 0.1);
border-color: rgba(255, 255, 255, 0.2);
}
.medical-hero .med-btn {
color: #ffffff;
}
@media (max-width: 768px) {
.medical-hero {
min-height: auto;
padding: 4rem 0;
}
.medical-hero h1,
.medical-hero .med-h1 {
color: #ffffff !important;
text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.medical-hero a:not(.med-btn) {
color: #ffffff;
text-decoration: underline;
}
}
/* ✅ ИСПРАВЛЕНО: Текст на страницах и постах в тёмной теме */
.entry-content,
.ast-single-post .entry-content,
.ast-single-page .entry-content,
.single-doctors .entry-content,
.single-services .entry-content {
color: var(--med-text) !important;
background: var(--med-bg) !important;
}
.entry-content *,
.ast-single-post .entry-content *,
.ast-single-page .entry-content * {
color: inherit;
}
/* Заголовки */
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6,
.ast-single-post .entry-content h1,
.ast-single-post .entry-content h2,
.ast-single-post .entry-content h3,
.ast-single-page .entry-content h1,
.ast-single-page .entry-content h2,
.ast-single-page .entry-content h3 {
color: var(--med-text) !important;
}
/* Параграфы */
.entry-content p,
.ast-single-post .entry-content p,
.ast-single-page .entry-content p {
color: var(--med-text) !important;
}
/* Ссылки */
.entry-content a,
.ast-single-post .entry-content a,
.ast-single-page .entry-content a {
color: var(--med-primary) !important;
}
.entry-content a:hover,
.ast-single-post .entry-content a:hover,
.ast-single-page .entry-content a:hover {
color: var(--med-accent) !important;
}
/* Списки */
.entry-content li,
.ast-single-post .entry-content li,
.ast-single-page .entry-content li {
color: var(--med-text) !important;
}
/* Таблицы */
.entry-content table,
.ast-single-post .entry-content table,
.ast-single-page .entry-content table {
background: var(--med-bg-light) !important;
}
.entry-content th,
.entry-content td,
.ast-single-post .entry-content th,
.ast-single-post .entry-content td,
.ast-single-page .entry-content th,
.ast-single-page .entry-content td {
color: var(--med-text) !important;
border-color: var(--med-border) !important;
}
/* Цитаты */
.entry-content blockquote,
.ast-single-post .entry-content blockquote,
.ast-single-page .entry-content blockquote {
background: var(--med-bg-light) !important;
color: var(--med-text-light) !important;
border-left-color: var(--med-primary) !important;
}
/* Код */
.entry-content code,
.entry-content pre,
.ast-single-post .entry-content code,
.ast-single-post .entry-content pre,
.ast-single-page .entry-content code,
.ast-single-page .entry-content pre {
background: var(--med-bg-light) !important;
color: var(--med-text) !important;
}
/* Gutenberg блоки */
.wp-block-group,
.wp-block-columns,
.wp-block-media-text {
background: transparent !important;
}
.wp-block-group *,
.wp-block-columns *,
.wp-block-media-text * {
color: inherit !important;
}
::-webkit-scrollbar {
width: 10px;
height: 10px;
}
::-webkit-scrollbar-track {
background: var(--med-bg);
}
::-webkit-scrollbar-thumb {
background: var(--med-border);
border-radius: 5px;
border: 2px solid var(--med-bg);
}
::-webkit-scrollbar-thumb:hover {
background: #4a4a6a;
}
* {
scrollbar-width: thin;
scrollbar-color: var(--med-border) var(--med-bg);
}
@media (prefers-contrast: high) {
:root {
--med-border: #ffffff;
--med-text-muted: #c0c0d8;
--med-focus: #ffffff;
}
.med-card,
details,
.service-item,
input,
textarea {
border-width: 2px;
}
}
}
/* ============================================
MOBILE DARK MODE FIX
============================================ */
@media (max-width: 768px) and (prefers-color-scheme: dark) {
.entry-content,
.ast-single-post .entry-content,
.ast-single-page .entry-content {
color: var(--med-text) !important;
background: var(--med-bg) !important;
}
.entry-content p,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content li {
color: var(--med-text) !important;
}
}
/* ============================================
SERVICE PAGE IMPROVEMENTS
============================================ */
.service-hero {
min-height: 50vh;
}
@media (max-width: 768px) {
.service-hero {
min-height: auto;
padding: 2rem 0;
}
.service-hero .med-grid {
grid-template-columns: 1fr !important;
}
.service-hero .med-hide-mobile {
display: none !important;
}
}
/* Popular badge - animation in animations.css */
.popular-badge {
/* animation: pulse-badge 2s infinite; - moved to animations.css */
}
/* Service content cards - animations moved to animations.css */
.med-card {
color: var(--med-text);
}
.med-card h2,
.med-card h3,
.med-card h4 {
color: var(--med-text);
}
.med-card p,
.med-card div {
color: var(--med-text-light);
}
/* ============================================
BULK EDIT PAGE STYLES
============================================ */
.astra-child-bulk-edit-table {
background: #fff;
border: 1px solid #ddd;
}
.astra-child-bulk-edit-table th {
background: #f9f9f9;
font-weight: 600;
}
.astra-child-bulk-edit-table tr:hover {
background: #f0f7ff;
}
@media (prefers-color-scheme: dark) {
.astra-child-bulk-edit-table {
background: var(--med-bg-light);
border-color: var(--med-border);
}
.astra-child-bulk-edit-table th {
background: var(--med-bg);
color: var(--med-text);
}
.astra-child-bulk-edit-table td {
color: var(--med-text);
border-color: var(--med-border);
}
.astra-child-bulk-edit-table tr:hover {
background: rgba(102, 126, 234, 0.1);
}
.astra-child-bulk-edit-table input {
background: var(--med-bg);
color: var(--med-text);
border-color: var(--med-border);
}
}
/* ============================================
WCAG: ACCESSIBILITY ENHANCEMENTS
============================================ */
/* ============================================
MOBILE TYPOGRAPHY FIXES - v5.2.0
============================================ */
/* Базовая типографика для контента на мобильных */
.entry-content,
.ast-single-post .entry-content,
.ast-single-page .entry-content {
font-size: clamp(1rem, 2.5vw, 1.125rem);
line-height: 1.8;
color: var(--med-text);
}
/* Мобильная типографика - улучшенная читаемость */
@media (max-width: 768px) {
.entry-content,
.ast-single-post .entry-content,
.ast-single-page .entry-content {
font-size: 1.0625rem;
line-height: 1.75;
padding: 0 0.5rem;
}
}
@media (max-width: 480px) {
.entry-content,
.ast-single-post .entry-content,
.ast-single-page .entry-content {
font-size: 1rem;
line-height: 1.7;
padding: 0;
}
}
/* Заголовки в контенте */
.entry-content h1,
.ast-single-post .entry-content h1,
.ast-single-page .entry-content h1 {
font-size: clamp(1.5rem, 4vw, 2rem);
line-height: 1.3;
margin: 2rem 0 1rem;
color: var(--med-text);
}
.entry-content h2,
.ast-single-post .entry-content h2,
.ast-single-page .entry-content h2 {
font-size: clamp(1.25rem, 3.5vw, 1.75rem);
line-height: 1.35;
margin: 1.75rem 0 0.875rem;
color: var(--med-text);
}
.entry-content h3,
.ast-single-post .entry-content h3,
.ast-single-page .entry-content h3 {
font-size: clamp(1.125rem, 3vw, 1.5rem);
line-height: 1.4;
margin: 1.5rem 0 0.75rem;
color: var(--med-text);
}
.entry-content h4,
.ast-single-post .entry-content h4,
.ast-single-page .entry-content h4 {
font-size: clamp(1rem, 2.5vw, 1.25rem);
line-height: 1.45;
margin: 1.25rem 0 0.625rem;
color: var(--med-text);
}
/* Параграфы */
.entry-content p,
.ast-single-post .entry-content p,
.ast-single-page .entry-content p {
margin-bottom: 1.25rem;
max-width: 70ch;
}
@media (max-width: 768px) {
.entry-content p,
.ast-single-post .entry-content p,
.ast-single-page .entry-content p {
margin-bottom: 1rem;
}
}
/* Списки */
.entry-content ul,
.entry-content ol,
.ast-single-post .entry-content ul,
.ast-single-post .entry-content ol,
.ast-single-page .entry-content ul,
.ast-single-page .entry-content ol {
margin: 1rem 0 1.5rem;
padding-left: 1.75rem;
}
@media (max-width: 768px) {
.entry-content ul,
.entry-content ol,
.ast-single-post .entry-content ul,
.ast-single-post .entry-content ol,
.ast-single-page .entry-content ul,
.ast-single-page .entry-content ol {
padding-left: 1.5rem;
margin: 0.875rem 0 1.25rem;
}
}
.entry-content li,
.ast-single-post .entry-content li,
.ast-single-page .entry-content li {
margin-bottom: 0.5rem;
line-height: 1.7;
}
@media (max-width: 768px) {
.entry-content li,
.ast-single-post .entry-content li,
.ast-single-page .entry-content li {
margin-bottom: 0.375rem;
line-height: 1.65;
}
}
/* Ссылки в контенте */
.entry-content a,
.ast-single-post .entry-content a,
.ast-single-page .entry-content a {
color: var(--med-primary);
text-decoration: underline;
text-underline-offset: 0.2em;
transition: color 0.2s;
}
.entry-content a:hover,
.ast-single-post .entry-content a:hover,
.ast-single-page .entry-content a:hover {
color: var(--med-secondary);
}
.entry-content a:focus-visible,
.ast-single-post .entry-content a:focus-visible,
.ast-single-page .entry-content a:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 2px;
}
/* Цитаты */
.entry-content blockquote,
.ast-single-post .entry-content blockquote,
.ast-single-page .entry-content blockquote {
margin: 1.5rem 0;
padding: 1rem 1.5rem;
border-left: 4px solid var(--med-primary);
background: var(--med-bg-light);
font-style: italic;
color: var(--med-text-light);
}
@media (max-width: 768px) {
.entry-content blockquote,
.ast-single-post .entry-content blockquote,
.ast-single-page .entry-content blockquote {
margin: 1.25rem 0;
padding: 0.875rem 1.25rem;
font-size: 0.95rem;
}
}
/* Код и pre */
.entry-content code,
.ast-single-post .entry-content code,
.ast-single-page .entry-content code {
background: var(--med-bg-light);
padding: 0.2em 0.4em;
border-radius: 4px;
font-family: monospace;
font-size: 0.9em;
}
.entry-content pre,
.ast-single-post .entry-content pre,
.ast-single-page .entry-content pre {
background: var(--med-bg-light);
padding: 1rem;
border-radius: var(--med-radius-sm);
overflow-x: auto;
margin: 1.5rem 0;
font-size: 0.9rem;
line-height: 1.6;
}
@media (max-width: 768px) {
.entry-content pre,
.ast-single-post .entry-content pre,
.ast-single-page .entry-content pre {
padding: 0.875rem;
font-size: 0.85rem;
margin: 1.25rem 0;
}
}
/* Таблицы в контенте */
.entry-content table,
.ast-single-post .entry-content table,
.ast-single-page .entry-content table {
margin: 1.5rem 0;
font-size: 0.95rem;
}
@media (max-width: 768px) {
.entry-content table,
.ast-single-post .entry-content table,
.ast-single-page .entry-content table {
font-size: 0.875rem;
display: block;
overflow-x: auto;
white-space: nowrap;
}
}
/* Изображения в контенте */
.entry-content img,
.ast-single-post .entry-content img,
.ast-single-page .entry-content img {
max-width: 100%;
height: auto;
border-radius: var(--med-radius-sm);
margin: 1rem 0;
}
.entry-content figure,
.ast-single-post .entry-content figure,
.ast-single-page .entry-content figure {
margin: 1.5rem 0;
}
.entry-content figcaption,
.ast-single-post .entry-content figcaption,
.ast-single-page .entry-content figcaption {
font-size: 0.875rem;
color: var(--med-text-muted);
text-align: center;
margin-top: 0.5rem;
}
/* Gutenberg блоки */
.wp-block-group {
padding: 1.5rem;
}
@media (max-width: 768px) {
.wp-block-group {
padding: 1rem;
}
}
.wp-block-columns {
gap: 1.5rem;
}
@media (max-width: 768px) {
.wp-block-columns {
gap: 1rem;
}
.wp-block-column {
flex-basis: 100% !important;
}
}
.wp-block-media-text {
gap: 1.5rem;
}
@media (max-width: 768px) {
.wp-block-media-text {
grid-template-columns: 100% !important;
gap: 1rem;
}
.wp-block-media-text .wp-block-media-text__media {
grid-column: 1;
grid-row: 1;
}
.wp-block-media-text .wp-block-media-text__content {
grid-column: 1;
grid-row: 2;
}
}
.wp-block-button__link {
min-height: 48px;
padding: 0.875rem 1.5rem;
font-size: 1rem;
font-weight: 600;
border-radius: var(--med-radius-sm);
}
@media (max-width: 768px) {
.wp-block-button__link {
min-height: 44px;
padding: 0.75rem 1.25rem;
font-size: 0.95rem;
}
}
.wp-block-separator {
margin: 2rem 0;
border: none;
border-top: 1px solid var(--med-border);
}
.wp-block-cover {
min-height: 300px;
}
@media (max-width: 768px) {
.wp-block-cover {
min-height: 200px;
}
}
/* Контейнер контента на мобильных */
@media (max-width: 768px) {
.ast-container {
padding-left: 1rem;
padding-right: 1rem;
}
.site-content {
padding-top: 1rem;
padding-bottom: 1rem;
}
.ast-single-post .entry-header,
.ast-single-page .entry-header {
margin-bottom: 1.5rem;
}
.ast-single-post .entry-title,
.ast-single-page .entry-title {
font-size: clamp(1.5rem, 5vw, 2rem);
line-height: 1.25;
}
}
@media (max-width: 480px) {
.ast-container {
padding-left: 0.75rem;
padding-right: 0.75rem;
}
.ast-single-post .entry-title,
.ast-single-page .entry-title {
font-size: clamp(1.375rem, 6vw, 1.75rem);
}
}
/* Улучшенная типографика для single-шаблонов */
.single-doctors .entry-content,
.single-services .entry-content {
font-size: clamp(1rem, 2.5vw, 1.125rem);
line-height: 1.8;
}
@media (max-width: 768px) {
.single-doctors .entry-content,
.single-services .entry-content {
font-size: 1.0625rem;
line-height: 1.75;
}
}
/* Улучшенная читаемость для текста в карточках на мобильных */
@media (max-width: 768px) {
.med-card p,
.doctor-card p,
.review-card p {
font-size: 1rem;
line-height: 1.6;
}
.med-card h2,
.med-card h3,
.doctor-card h3,
.review-card h3 {
font-size: 1.125rem;
line-height: 1.35;
}
}
/* Улучшенная типографика для аккордеона на мобильных */
@media (max-width: 768px) {
details summary {
font-size: 1rem;
padding: 1.25rem;
line-height: 1.4;
}
.acc-content {
font-size: 0.95rem;
line-height: 1.65;
padding: 1.25rem;
}
.acc-content p {
margin-bottom: 0.875rem;
}
.acc-content ul,
.acc-content ol {
padding-left: 1.5rem;
}
.acc-content li {
margin-bottom: 0.375rem;
}
}
/* Улучшенная типографика для прайс-листа на мобильных */
@media (max-width: 768px) {
.service-item {
flex-direction: column;
align-items: flex-start;
gap: 0.5rem;
padding: 1rem;
}
.service-item-name {
font-size: 1rem;
line-height: 1.4;
}
.service-item-meta {
font-size: 0.875rem;
}
.service-item-price {
font-size: 1.125rem;
padding: 0.375rem 0.75rem;
}
}
/* Dark Mode для мобильной типографики */
@media (prefers-color-scheme: dark) {
.entry-content,
.ast-single-post .entry-content,
.ast-single-page .entry-content,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.ast-single-post .entry-content h1,
.ast-single-post .entry-content h2,
.ast-single-post .entry-content h3,
.ast-single-post .entry-content h4,
.ast-single-page .entry-content h1,
.ast-single-page .entry-content h2,
.ast-single-page .entry-content h3,
.ast-single-page .entry-content h4 {
color: var(--med-text);
}
.entry-content blockquote,
.ast-single-post .entry-content blockquote,
.ast-single-page .entry-content blockquote {
background: var(--med-bg-light);
border-left-color: var(--med-primary);
}
.entry-content code,
.entry-content pre,
.ast-single-post .entry-content code,
.ast-single-post .entry-content pre,
.ast-single-page .entry-content code,
.ast-single-page .entry-content pre {
background: var(--med-bg-light);
}
}
/* ============================================
WCAG: ДОПОЛНИТЕЛЬНЫЕ УЛУЧШЕНИЯ
============================================ */
/* Иконки должны иметь aria-hidden или альтернативный текст */
.icon,
[class*="icon-"] {
speak: never;
font-style: normal;
font-weight: normal;
font-variant: normal;
text-transform: none;
line-height: 1;
-webkit-font-smoothing: antialiased;
}
/* Предотвращение горизонтальной прокрутки */
img, video, iframe {
max-width: 100%;
height: auto;
}
/* Улучшение доступности таблиц */
table {
border-collapse: collapse;
width: 100%;
}
th, td {
padding: 0.75rem;
text-align: left;
border-bottom: 1px solid var(--med-border);
}
th {
font-weight: 600;
color: var(--med-text);
}
/* ============================================
PRICE INFO BLOCK - WCAG AA + DARK MODE
============================================ */
.price-info-block {
border-radius: 20px;
overflow: hidden;
margin: 2rem 0;
font-size: 1rem;
line-height: 1.6;
}
.price-header {
background: linear-gradient(135deg, var(--med-primary) 0%, var(--med-secondary) 100%);
color: #ffffff;
padding: 20px 15px;
text-align: center;
}
.price-clinic-name {
margin: 0;
font-size: 1.125rem;
opacity: 0.95;
font-weight: 500;
}
.price-divider {
width: 80px;
height: 3px;
background: rgba(255,255,255,0.5);
margin: 15px auto 0;
border-radius: 2px;
}
.price-section {
background: var(--med-bg-light);
padding: 25px 20px;
border-left: 4px solid var(--med-primary);
}
.price-section--bordered {
border-bottom: 1px solid var(--med-border);
}
.price-section--info {
background: #e7f3ff;
border-left-color: #4dabf7;
text-align: center;
}
.price-section-title {
color: var(--med-primary);
margin: 0 0 1rem 0;
font-size: 1.25rem;
display: flex;
align-items: center;
gap: 0.5rem;
font-weight: 600;
}
.price-text {
margin: 0;
color: var(--med-text);
}
.price-text--centered {
text-align: center;
}
.price-link {
color: var(--med-primary);
text-decoration: none;
border-bottom: 1px dotted currentColor;
transition: color 0.2s;
}
.price-link:hover,
.price-link:focus {
color: var(--med-secondary);
text-decoration: none;
}
.price-link:focus-visible {
outline: 2px solid var(--med-focus);
outline-offset: 2px;
border-radius: 2px;
}
.price-badge {
display: inline-block;
background: #fff3cd;
color: #856404;
padding: 2px 8px;
border-radius: 4px;
font-size: 0.95rem;
margin-left: 0.25rem;
}
.price-legal {
background: var(--med-bg);
padding: 20px 15px;
border-bottom: 1px solid var(--med-border);
text-align: center;
}
.price-legal-text {
margin: 0;
font-size: 0.875rem;
color: var(--med-text-muted);
font-style: italic;
}
.price-legal-warning {
color: var(--med-danger);
font-weight: 500;
font-style: normal;
}
.price-stationary {
background: linear-gradient(135deg, #a62a6a 0%, #8a1c3d 100%);
color: #ffffff;
padding: 30px 20px;
text-align: center;
}
.price-stationary-title {
margin: 0 0 1.25rem 0;
font-size: 1.5rem;
text-transform: uppercase;
letter-spacing: 0.5px;
font-weight: 700;
}
.price-stationary-card {
background: rgba(255,255,255,0.15);
border-radius: 15px;
padding: 20px;
backdrop-filter: blur(10px);
border: 1px solid rgba(255,255,255,0.2);
}
.price-stationary-note {
margin: 0 0 1rem 0;
font-size: 1.05rem;
font-weight: 500;
}
.price-underline {
text-decoration: underline;
text-decoration-style: wavy;
text-underline-offset: 2px;
}
.price-features {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 10px;
list-style: none;
padding: 0;
margin: 15px 0 0 0;
}
.price-feature {
background: rgba(255,255,255,0.25);
padding: 8px 16px;
border-radius: 25px;
font-size: 0.9rem;
white-space: nowrap;
}
.price-footnote {
margin: 15px 0 0 0;
font-size: 0.875rem;
opacity: 0.9;
}
.price-footer {
background: #212529;
color: #ffffff;
padding: 25px 20px;
text-align: center;
}
.price-footer-text {
margin: 0;
font-size: 1rem;
}
.price-footer-slogan {
color: #adb5bd;
font-size: 0.9rem;
display: block;
margin-top: 0.5rem;
}
.price-icon {
font-size: 1.25rem;
vertical-align: middle;
}
@media (max-width: 768px) {
.price-info-block {
border-radius: 16px;
margin: 1.5rem 0;
}
.price-header,
.price-section,
.price-legal,
.price-stationary,
.price-footer {
padding-left: 15px;
padding-right: 15px;
}
.price-stationary-title {
font-size: 1.25rem;
}
.price-features {
gap: 8px;
}
.price-feature {
font-size: 0.85rem;
padding: 6px 12px;
}
}
/* Dark Mode Support for Price Block */
@media (prefers-color-scheme: dark) {
.price-section {
background: var(--med-bg-light);
border-left-color: var(--med-primary);
}
.price-section--info {
background: #1a2a4a;
border-left-color: #64b5f6;
}
.price-text,
.price-section-title,
.price-link {
color: var(--med-text);
}
.price-legal-text {
color: var(--med-text-muted);
}
.price-badge {
background: #4a3a04;
color: #ffd54f;
}
.price-stationary {
background: linear-gradient(135deg, #a62a6a 0%, #8a1c3d 100%);
}
.price-stationary-card {
background: rgba(255,255,255,0.1);
border-color: rgba(255,255,255,0.15);
}
.price-feature {
background: rgba(255,255,255,0.2);
}
.price-footer {
background: #1a1a24;
border-top: 1px solid var(--med-border);
}
.price-footer-slogan {
color: #8a8a9a;
}
.price-link:focus-visible {
outline-color: var(--med-focus);
}
}
/* ============================================
WCAG: ACCESSIBILITY ENHANCEMENTS
============================================ */
.price-link:focus-visible,
.price-feature:focus-visible {
outline: 2px solid var(--med-focus);
outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
.price-link {
transition: none;
}
}
@media (prefers-contrast: high) {
.price-section,
.price-section--info,
.price-legal,
.price-stationary-card {
border-width: 2px;
}
.price-badge {
border: 1px solid currentColor;
}
}
/* ============================================
NEW COMPONENTS STYLES v5.3.0
Кнопки отзывов, статус открытости, улучшенные карточки
============================================ */

/* ============================================
HERO SECTION IMPROVEMENTS
============================================ */
.medical-hero-sm {
	min-height: 40vh;
	padding: 3rem 0;
}

.medical-hero-title {
	color: #fff;
	margin-bottom: 1rem;
}

.medical-hero-subtitle {
	font-size: clamp(1rem, 3vw, 1.3rem);
	margin: 0 0 1.5rem;
	opacity: 0.95;
	color: rgba(255,255,255,0.9);
}

.medical-contact-card {
	display: inline-block;
	margin-bottom: 1rem;
}

.medical-contact-link {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: #fff;
	text-decoration: none;
}

.medical-contact-icon {
	width: 44px;
	height: 44px;
	background: rgba(255,255,255,0.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	flex-shrink: 0;
}

.medical-contact-info {
	text-align: left;
}

.medical-contact-label {
	font-size: 0.75rem;
	opacity: 0.85;
}

.medical-contact-value {
	font-size: clamp(1.3rem, 4vw, 1.6rem);
	font-weight: 700;
}

/* ============================================
CARD IMPROVEMENTS
============================================ */
.med-card-border {
	border-top: 4px solid var(--med-border);
}

.med-card-border-primary {
	border-top-color: var(--med-primary);
}

.med-card-border-secondary {
	border-top-color: var(--med-secondary);
}

.med-card-border-success {
	border-top-color: var(--med-success);
}

.med-card-border-info {
	border-top-color: var(--med-info);
}

.med-card-border-warning {
	border-top-color: var(--med-warning);
}

.med-card-border-accent {
	border-top-color: var(--med-accent);
}

.med-card-center {
	text-align: center;
}

.med-card-icon-wrap {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
	font-size: 2rem;
	color: #fff;
}

.med-card-title {
	margin: 0 0 0.5rem;
	color: var(--med-text);
	font-size: 1.25rem;
}

.med-card-title-sm {
	margin: 0 0 0.5rem;
	color: var(--med-text);
	font-size: 1.125rem;
}

.med-card-text {
	color: var(--med-text-light);
	margin: 0 0 1.5rem;
	font-size: 0.95rem;
}

.med-card-header {
	margin: 0 0 1rem;
	color: var(--med-text);
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.125rem;
}

.med-card-content {
	color: var(--med-text-light);
	line-height: 1.8;
}

.med-card-footer {
	padding: 1rem;
	border-radius: var(--med-radius-sm);
	margin-top: 1rem;
}

.med-card-emoji {
	font-size: 3rem;
	margin-bottom: 1rem;
}

/* ============================================
BUTTON VARIANTS
============================================ */
.med-btn-full {
	width: 100%;
}

.med-btn-sm {
	padding: 0.5rem 1rem;
	font-size: 0.85rem;
	min-height: 40px;
}

.med-btn-lg {
	padding: 0.875rem 1.5rem;
	font-size: 1rem;
	min-height: 52px;
}

.med-btn-success {
	background: var(--med-success);
	color: #fff;
}

.med-btn-success:hover {
	background: #388e3c;
}

.med-btn-info {
	background: var(--med-info);
	color: #fff;
}

.med-btn-info:hover {
	background: #1976d2;
}

.med-btn-primary {
	background: var(--med-primary);
	color: #fff;
}

.med-btn-primary:hover {
	background: var(--med-secondary);
}

.med-btn-whatsapp {
	background: #25D366;
	color: #fff;
}

.med-btn-whatsapp:hover {
	background: #128C7E;
}

.med-btn-telegram {
	background: #0088cc;
	color: #fff;
}

.med-btn-telegram:hover {
	background: #006699;
}

.med-btn-vk {
	background: #4a76a8;
	color: #fff;
}

.med-btn-vk:hover {
	background: #3a5a88;
}

.med-btn-max {
	background: #7B68EE;
	color: #fff;
}

.med-btn-max:hover {
	background: #5a4fcf;
}

.med-btn-white {
	background: #fff;
	color: var(--med-primary);
}

.med-btn-white:hover {
	background: #f0f0f0;
}

.med-btn-outline-white {
	background: transparent;
	color: #fff;
	border: 2px solid rgba(255,255,255,0.6);
}

.med-btn-outline-white:hover {
	background: rgba(255,255,255,0.1);
	border-color: #fff;
}

/* ============================================
REVIEWS GRID - 3×3
============================================ */
.med-reviews-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}

@media (max-width: 768px) {
	.med-reviews-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.med-reviews-grid {
		grid-template-columns: 1fr;
	}
}

/* Brand colors for review buttons */
.med-btn-review {
	min-height: 48px;
	padding: 12px 24px;
	border-radius: 8px;
	text-align: center;
	font-weight: 600;
	transition: all 0.3s ease;
}

.med-btn-yandex {
	background: #fc3f1d;
	color: #fff;
}

.med-btn-yandex:hover {
	background: #d93600;
	transform: translateY(-2px);
}

.med-btn-google {
	background: #4285f4;
	color: #fff;
}

.med-btn-google:hover {
	background: #3367d6;
	transform: translateY(-2px);
}

.med-btn-prodoctorov {
	background: #2e7d32;
	color: #fff;
}

.med-btn-prodoctorov:hover {
	background: #1b5e20;
	transform: translateY(-2px);
}

.med-btn-2gis {
	background: #00a8e6;
	color: #fff;
}

.med-btn-2gis:hover {
	background: #0088cc;
	transform: translateY(-2px);
}

.med-btn-napopravku {
	background: #ff6b6b;
	color: #fff;
}

.med-btn-napopravku:hover {
	background: #ee5a5a;
	transform: translateY(-2px);
}

.med-btn-doctortut {
	background: #4ecdc4;
	color: #fff;
}

.med-btn-doctortut:hover {
	background: #3dbbb3;
	transform: translateY(-2px);
}

.med-btn-doctu {
	background: #95e1d3;
	color: #333;
}

.med-btn-doctu:hover {
	background: #7dd4c3;
	transform: translateY(-2px);
}

.med-btn-zoon {
	background: #f38181;
	color: #fff;
}

.med-btn-zoon:hover {
	background: #e06060;
	transform: translateY(-2px);
}

.med-btn-likedoctor {
	background: #aa96da;
	color: #fff;
}

.med-btn-likedoctor:hover {
	background: #9680cc;
	transform: translateY(-2px);
}

/* ============================================
OPEN/CLOSED STATUS BADGE
============================================ */
.med-status-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.25rem 0.75rem;
	border-radius: 9999px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	margin-left: auto;
}

.med-status-open {
	background: #d4edda;
	color: #155724;
}

.med-status-open::before {
	content: '';
	width: 8px;
	height: 8px;
	background: #28a745;
	border-radius: 50%;
	animation: pulse 2s infinite;
}

.med-status-closed {
	background: #f8d7da;
	color: #721c24;
}

.med-status-closed::before {
	content: '';
	width: 8px;
	height: 8px;
	background: #dc3545;
	border-radius: 50%;
}

/* ============================================
HOURS LIST
============================================ */
.med-hours-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.med-hours-item {
	display: flex;
	justify-content: space-between;
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--med-border);
}

.med-hours-item:last-child {
	border-bottom: none;
}

.med-hours-day {
	font-weight: 600;
	color: var(--med-text);
}

.med-hours-time {
	color: var(--med-text-light);
}

.med-hours-closed {
	color: var(--med-danger);
}

/* ============================================
FAQ STYLES
============================================ */
.med-faq-container {
	max-width: 700px;
	margin: 0 auto;
}

.med-faq-item {
	margin-bottom: 0.5rem;
	border-radius: var(--med-radius-sm);
	overflow: hidden;
}

.med-faq-summary {
	font-weight: 600;
	color: var(--med-text);
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1rem;
	background: var(--med-bg-light);
	border-radius: var(--med-radius-sm);
}

.med-faq-summary::-webkit-details-marker {
	display: none;
}

.med-faq-icon {
	transition: transform 0.3s;
}

.med-faq-item[open] .med-faq-icon {
	transform: rotate(180deg);
}

.med-faq-content {
	padding: 1rem;
	color: var(--med-text-light);
	line-height: 1.7;
}

/* ============================================
FORM STYLES
============================================ */
.med-form-input,
.med-form-select,
.med-form-textarea {
	width: 100%;
	padding: 0.875rem 1rem;
	border: 2px solid var(--med-border);
	border-radius: var(--med-radius-sm);
	font-size: 1rem;
	background: var(--med-bg);
	color: var(--med-text);
	min-height: 48px;
	transition: border-color 0.3s, box-shadow 0.3s;
}

.med-form-input:focus,
.med-form-select:focus,
.med-form-textarea:focus {
	outline: none;
	border-color: var(--med-primary);
	box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.med-form-textarea {
	min-height: 120px;
	resize: vertical;
}

.med-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	font-weight: normal;
	cursor: pointer;
}

.med-checkbox {
	width: 20px;
	height: 20px;
	margin-top: 2px;
	flex-shrink: 0;
	cursor: pointer;
}

.med-checkbox-text {
	font-size: 0.9rem;
	color: var(--med-text-light);
}

/* ============================================
UTILITY CLASSES
============================================ */
.med-section-light {
	background: var(--med-bg-light);
}



.med-text-warning {
	color: #856404;
}

.med-text-center {
	text-align: center;
}

.med-text-left {
	text-align: left;
}

.med-text-sm {
	font-size: 0.85rem;
}

.med-text-lg {
	font-size: 1.125rem;
}

.med-text-muted {
	color: var(--med-text-muted);
}

.med-text-light {
	color: var(--med-text-light);
}

.med-opacity-90 {
	opacity: 0.9;
}

.med-font-semibold {
	font-weight: 600;
}

.med-font-bold {
	font-weight: 700;
}

.med-mb-0 {
	margin-bottom: 0;
}

.med-mb-1 {
	margin-bottom: 1rem;
}

.med-mb-2 {
	margin-bottom: 2rem;
}

.med-mt-1 {
	margin-top: 1rem;
}

.med-mt-2 {
	margin-top: 2rem;
}

.med-ml-auto {
	margin-left: auto;
}

.med-flex {
	display: flex;
	gap: 1rem;
	align-items: center;
}

.med-flex-wrap {
	flex-wrap: wrap;
	justify-content: center;
}

.med-justify-center {
	justify-content: center;
}

.med-bg-light {
	background: var(--med-bg-light);
}

.med-bg-success {
	background: var(--med-success);
}

.med-bg-info {
	background: var(--med-info);
}

.med-bg-primary {
	background: var(--med-primary);
}

.med-border-left-warning {
	border-left: 4px solid var(--med-warning);
}

.med-card-warning {
	background: #fff3cd;
	border: 2px solid var(--med-warning);
}

.med-color-primary {
	color: var(--med-primary);
}

.med-color-success {
	color: var(--med-success);
}

.med-color-info {
	color: var(--med-info);
}

.med-color-warning {
	color: var(--med-warning);
}

.med-color-accent {
	color: var(--med-accent);
}

/* ============================================
GRID RESPONSIVE
============================================ */
.med-grid-1-mobile {
	grid-template-columns: 1fr;
}

@media (min-width: 769px) {
	.med-grid-1-mobile {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ============================================
LINK STYLES
============================================ */
.med-link {
	color: var(--med-primary);
	text-decoration: underline;
	text-underline-offset: 0.2em;
	transition: color 0.2s;
}

.med-link:hover {
	color: var(--med-secondary);
}

.med-link-info {
	color: var(--med-info);
}

.med-link-info:hover {
	color: #1976d2;
}

/* ============================================
WCAG FOCUS STYLES
============================================ */
*:focus-visible {
	outline: 2px solid var(--med-primary);
	outline-offset: 2px;
}

.med-btn:focus-visible,
.med-btn-review:focus-visible {
	outline: 3px solid var(--med-focus);
	outline-offset: 2px;
}

/* ============================================
MOBILE FAB (Floating Action Button)
============================================ */
.mobile-fab {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	display: none;
	background: #fff;
	box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
	padding: 0.5rem;
	gap: 0.5rem;
}

.fab-btn {
	flex: 1;
	padding: 0.75rem;
	text-align: center;
	background: var(--med-primary);
	color: #fff;
	border-radius: var(--med-radius-sm);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.875rem;
}

.fab-btn:hover {
	background: var(--med-secondary);
}

@media (max-width: 768px) {
	.mobile-fab {
		display: flex;
	}
}

/* ============================================
DARK MODE SUPPORT
============================================ */
@media (prefers-color-scheme: dark) {
	.med-form-input,
	.med-form-select,
	.med-form-textarea {
		background: var(--med-bg-light);
		border-color: var(--med-border);
		color: var(--med-text);
	}
	
	.med-form-input:focus,
	.med-form-select:focus,
	.med-form-textarea:focus {
		border-color: var(--med-primary);
	}
	
	.med-faq-summary {
		background: var(--med-bg-light);
		color: var(--med-text);
	}
	
	.med-faq-content {
		color: var(--med-text-muted);
	}
	
	.med-card-warning {
		background: #3a3a04;
		border-color: #ffd54f;
	}
	
	.med-text-warning {
		color: #ffd54f;
	}
	
	.mobile-fab {
		background: var(--med-bg-light);
		box-shadow: 0 -2px 10px rgba(0,0,0,0.3);
	}
}/* ============================================
FRONT PAGE OPTIMIZED STYLES - v5.3.0
============================================ */

/* Hero Section */
.hero-container {
position: relative;
z-index: 1;
}

.hero-badge-inline {
display: inline-flex;
align-items: center;
gap: 0.5rem;
margin-bottom: 1rem;
font-size: 0.85rem;
}

.hero-badge-dot {
width: 8px;
height: 8px;
background: #4caf50;
border-radius: 50%;
display: inline-block;
}

.hero-title-white {
color: #fff;
}

.hero-subtitle {
font-size: clamp(1rem, 3vw, 1.3rem);
margin: 0 0 1rem;
opacity: 0.95;
font-weight: 300;
}

.hero-description {
font-size: clamp(0.9rem, 2.5vw, 1.05rem);
line-height: 1.5;
margin-bottom: 1.5rem;
opacity: 0.9;
}

/* Contact Card */
.contact-card {
margin-bottom: 1rem;
}

.contact-phone-link {
display: flex;
align-items: center;
gap: 0.75rem;
color: #fff;
text-decoration: none;
margin-bottom: 0.75rem;
}

.contact-phone-icon {
width: 40px;
height: 40px;
background: rgba(255,255,255,0.2);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-size: 1.1rem;
flex-shrink: 0;
}

.contact-phone-info {
min-width: 0;
flex: 1;
}

.contact-phone-label {
font-size: 0.75rem;
opacity: 0.85;
margin-bottom: 0.15rem;
}

.contact-phone-number {
font-size: clamp(1.3rem, 4vw, 1.8rem);
font-weight: 700;
}

.contact-address,
.contact-hours {
margin-top: 0.5rem;
}

/* Hero Buttons Grid */
.hero-buttons-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.5rem;
margin-top: 1rem;
}

.hero-btn-primary {
background: #fff;
color: #333 !important;
}

.hero-btn-primary:hover {
background: var(--med-accent);
color: #fff !important;
}

.hero-btn-outline {
background: transparent;
color: #fff;
border: 2px solid rgba(255,255,255,0.6);
}

/* Desktop Info Panel */
.hero-info-panel {
text-align: center;
max-width: 400px;
margin: 0 auto;
}

.hero-info-icon {
width: 100%;
aspect-ratio: 1;
background: rgba(255,255,255,0.1);
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
font-size: 4rem;
margin-bottom: 1rem;
}

.hero-ogrn {
font-family: monospace;
font-size: 0.9rem;
opacity: 0.9;
}

/* Feature Cards */
.feature-card {
border-top: 3px solid;
text-align: center;
}

.feature-icon {
width: 48px;
height: 48px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
margin: 0 auto 0.75rem;
font-size: 1.3rem;
}

.feature-title {
margin: 0 0 0.25rem;
font-size: 0.95rem;
}

.feature-desc {
color: var(--med-text-light);
margin: 0;
font-size: 0.8rem;
}

/* Quick Services */
.quick-service-card {
border-top: 3px solid;
}

.quick-service-icon-wrap {
width: 56px;
height: 56px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 0.75rem;
}

.quick-service-icon-wrap .dashicons {
font-size: 1.5rem;
}

.quick-service-title-sm {
font-weight: 600;
margin: 0 0 0.25rem;
font-size: 0.95rem;
}

.quick-service-desc-sm {
color: var(--med-text-light);
margin: 0;
font-size: 0.8rem;
}

/* Doctor Cards */
.doctor-card {
display: flex;
flex-direction: column;
height: 100%;
}

.doctor-image-wrap {
position: relative;
padding-top: 100%;
background: #f0f0f0;
}

.doctor-image-wrap img {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s;
}

.doctor-image-wrap:hover img {
transform: scale(1.05);
}

.doctor-image-placeholder {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg,#667eea20,#764ba220);
}

.doctor-info-sm {
padding: 1rem;
flex: 1;
display: flex;
flex-direction: column;
}

.doctor-name-sm {
font-size: 1rem;
font-weight: 600;
margin: 0 0 0.25rem;
}

.doctor-position-sm {
color: var(--med-primary);
font-weight: 500;
font-size: 0.85rem;
margin: 0 0 0.25rem;
}

.doctor-specialty-sm {
color: var(--med-text-light);
font-size: 0.8rem;
line-height: 1.4;
flex: 1;
margin: 0 0 1rem;
}

.doctor-actions-sm {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0.5rem;
margin-top: auto;
}

.doctor-btn-outline {
background: var(--med-bg);
color: var(--med-text);
border: 1px solid var(--med-border);
font-size: 0.85rem;
padding: 0.6rem;
}

.doctor-btn-primary {
background: var(--med-primary);
color: #fff;
font-size: 0.85rem;
padding: 0.6rem;
}

/* FAQ */
.faq-container {
max-width: 700px;
margin: 0 auto;
}

.faq-item {
margin-bottom: 0.5rem;
}

.faq-summary {
display: flex;
align-items: center;
justify-content: space-between;
cursor: pointer;
font-weight: 500;
font-size: 0.95rem;
list-style: none;
user-select: none;
}

.faq-summary::-webkit-details-marker {
display: none;
}

.faq-icon {
transition: transform 0.2s;
font-size: 0.8rem;
}

.faq-item[open] .faq-icon {
transform: rotate(180deg);
}

.faq-content {
margin-top: 0.75rem;
color: var(--med-text-light);
font-size: 0.9rem;
line-height: 1.5;
}

/* Hospitalization Tests */
.hospitalization-tests details {
margin-bottom: 0.75rem;
border: 1px solid var(--med-border);
border-radius: 8px;
background: var(--med-bg);
}

.hospitalization-tests summary {
padding: 1rem 1.25rem;
cursor: pointer;
font-weight: 600;
color: var(--med-text);
background: var(--med-bg-light);
border-radius: 8px;
list-style: none;
display: flex;
align-items: center;
gap: 0.5rem;
}

.hospitalization-tests summary::-webkit-details-marker {
display: none;
}

.hospitalization-tests details[open] summary {
border-bottom: 1px solid var(--med-border);
border-radius: 8px 8px 0 0;
}

.hospitalization-tests ul {
margin: 0;
padding: 1rem 1.25rem 1rem 2rem;
list-style: disc;
color: var(--med-text-light);
font-size: 0.95rem;
line-height: 1.6;
}

.hospitalization-tests li {
margin-bottom: 0.25rem;
}

.test-notice {
margin-top: 1.5rem;
padding: 1rem;
background: rgba(255, 152, 0, 0.1);
border-left: 4px solid var(--med-warning);
border-radius: 0 8px 8px 0;
font-size: 0.9rem;
color: var(--med-text);
}



/* License Section */
.license-grid {
margin-bottom: 1.5rem;
}

.license-card {
max-width: 500px;
margin: 0 auto;
text-align: center;
}

.license-label {
margin-bottom: 0.5rem;
color: var(--med-text-light);
font-size: 0.9rem;
}

.license-copy-btn {
font-family: monospace;
font-size: 1.1rem;
font-weight: 600;
background: #7d7d7d;
margin-bottom: 1rem;
width: 100%;
position: relative;
}

.license-tooltip {
position: absolute;
top: -35px;
left: 50%;
transform: translateX(-50%);
background: #333;
color: #fff;
padding: 6px 12px;
border-radius: 4px;
font-size: 13px;
opacity: 0;
transition: opacity 0.3s;
pointer-events: none;
white-space: nowrap;
z-index: 10;
}

.license-copy-btn:hover .license-tooltip,
.license-copy-btn:focus .license-tooltip {
opacity: 1;
}

/* Appointment Section */
.appointment-phone-link {
font-size: clamp(1.3rem, 4vw, 1.7rem);
font-weight: 700;
color: var(--med-info);
text-decoration: none;
display: block;
margin-bottom: 0.5rem;
}

.appointment-address-box {
margin: 1rem 0;
padding: 0.75rem;
background: var(--med-bg);
border-radius: 8px;
border-left: 4px solid var(--med-success);
}

.appointment-address-label {
font-size: 0.8rem;
color: var(--med-text-light);
}

.appointment-address-value {
font-weight: 500;
}

.appointment-hours-label {
font-size: 0.8rem;
color: var(--med-text-muted);
margin-bottom: 0.25rem;
}

.appointment-hours-list {
font-size: 0.9rem;
line-height: 1.6;
}

.appointment-hours-closed {
color: var(--med-accent);
}

/* Online Booking Card */
.booking-card {
text-align: center;
border: 2px solid var(--med-info);
background: linear-gradient(to bottom, #f0f9ff, #fff);
}

.booking-icon {
font-size: 2rem;
margin-bottom: 0.5rem;
}

.booking-title {
margin: 0 0 0.75rem;
font-size: 1rem;
}

/* Section backgrounds */
.section-bg-white {
background: var(--med-bg-light);
}

.section-bg-gray {
background: var(--med-bg);
}

/* ARIA enhancements for emoji links */
.emoji-link {
text-decoration: none;
}

.emoji-link:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 4px;
}

/* Smooth scroll offset for fixed header */
html {
scroll-padding-top: 80px;
}

/* Print improvements */
@media print {
.hero-buttons-grid,
.messengers-scroll,
.map-container,
.license-copy-btn {
display: none !important;
}

.medical-hero {
background: #fff !important;
color: #000 !important;
min-height: auto !important;
padding: 2rem 0 !important;
}

.medical-hero .med-h1,
.medical-hero p {
color: #000 !important;
}
}


/* ============================================
ADDITIONAL ENHANCEMENTS - v5.3.1
============================================ */

/* Video Container (responsive embeds) */
.video-container {
position: relative;
padding-bottom: 56.25%; /* 16:9 aspect ratio */
height: 0;
overflow: hidden;
max-width: 100%;
background: #000;
margin: 1.5rem 0;
border-radius: var(--med-radius);
}

.video-container iframe,
.video-container object,
.video-container embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
border: 0;
}

/* Reading Progress Bar */
#reading-progress {
background: linear-gradient(90deg, var(--med-primary), var(--med-secondary));
box-shadow: 0 0 10px rgba(102, 126, 234, 0.5);
}

/* Read More Link */
.read-more {
color: var(--med-primary);
text-decoration: none;
font-weight: 600;
transition: color 0.2s;
}

.read-more:hover {
color: var(--med-secondary);
text-decoration: underline;
}

.read-more::after {
content: ' →';
}

/* Offline indicator */
body.is-offline::before {
content: '⚠ Вы офлайн';
position: fixed;
top: 0;
left: 0;
right: 0;
background: #ff9800;
color: #fff;
text-align: center;
padding: 0.5rem;
z-index: 99999;
font-weight: 600;
font-size: 0.9rem;
}

body.is-offline {
padding-top: 40px;
}

/* Enhanced focus styles */
:focus-visible {
outline: 3px solid var(--med-focus);
outline-offset: 2px;
border-radius: 4px;
}

/* Skip link enhancement */
.skip-link:focus {
z-index: 100000;
}

/* Print improvements */
@media print {
#reading-progress,
.video-container,
.med-messenger-btn,
.messengers-scroll {
display: none !important;
}

.read-more {
text-decoration: none;
color: #000;
}
}

/* High contrast mode fixes */
@media (prefers-contrast: high) {
.video-container {
border: 2px solid #000;
}

.read-more {
text-decoration: underline;
}
}

/* Reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
#reading-progress {
transition: none;
}

.read-more::after {
content: none;
}
}

/* Dark mode adjustments for new elements */
@media (prefers-color-scheme: dark) {
.read-more {
color: var(--med-primary);
}

body.is-offline::before {
background: #e65100;
}
}

/* Reviews external links buttons */
.reviews-external-links {
margin-top: 2rem;
text-align: center;
}

.reviews-external-links .med-btn {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1.5rem;
transition: transform 0.2s, box-shadow 0.2s;
}

.reviews-external-links .med-btn:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.reviews-external-links .med-btn[href*="yandex"] {
background: #fc3f1d;
color: #fff;
}

.reviews-external-links .med-btn[href*="google"] {
background: #4285f4;
color: #fff;
}

/* Responsive adjustments */
@media (max-width: 768px) {
.review-header-sm {
flex-direction: column;
align-items: flex-start;
gap: 0.5rem;
}

.reviews-external-links .med-btn {
width: 100%;
justify-content: center;
margin-bottom: 0.5rem;
}
}

/* Reviews Section with API Integration */

/* Rating Summary */
.reviews-rating-summary {
background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
border: 1px solid #dee2e6;
}

/* Review Card with Avatar */
.review-card-sm {
padding: 1.5rem;
transition: transform 0.2s, box-shadow 0.2s;
}

.review-card-sm:hover {
transform: translateY(-2px);
box-shadow: 0 8px 25px rgba(0,0,0,0.1);
}

.review-header-sm {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1rem;
}

.review-author-avatar {
width: 40px;
height: 40px;
border-radius: 50%;
object-fit: cover;
}

.review-author-initial {
width: 40px;
height: 40px;
border-radius: 50%;
background: linear-gradient(135deg, var(--med-primary), var(--med-secondary));
color: #fff;
display: flex;
align-items: center;
justify-content: center;
font-weight: 600;
font-size: 16px;
}

.review-author-sm {
color: var(--med-text);
font-size: 1rem;
}

.review-stars-sm {
color: #ffc107;
font-size: 1.1rem;
letter-spacing: 2px;
}

.review-text-sm {
margin: 0 0 1rem;
font-style: italic;
color: var(--med-text-light);
line-height: 1.6;
border-left: 3px solid var(--med-primary);
padding-left: 1rem;
}

.review-footer-sm {
display: flex;
justify-content: space-between;
align-items: center;
font-size: 0.875rem;
color: var(--med-text-muted);
}

.review-footer-sm time {
font-size: 0.8rem;
}

.review-source-badge {
display: inline-flex;
align-items: center;
gap: 5px;
padding: 2px 8px;
border-radius: 12px;
font-size: 12px;
font-weight: 500;
}

.review-source-badge.google {
background: #e8f0fe;
color: #4285f4;
}

.review-source-badge.yandex {
background: #ffebee;
color: #fc3f1d;
}

/* Reviews external links buttons */
.reviews-external-links {
margin-top: 2rem;
text-align: center;
}

.reviews-external-links .med-btn {
display: inline-flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1.5rem;
transition: transform 0.2s, box-shadow 0.2s;
}

.reviews-external-links .med-btn:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.reviews-external-links .med-btn[href*="yandex"] {
background: #fc3f1d;
color: #fff;
}

.reviews-external-links .med-btn[href*="google"] {
background: #4285f4;
color: #fff;
}

/* Reviews Loading State */
.reviews-loading {
text-align: center;
padding: 3rem;
}

.reviews-loading-spinner {
width: 40px;
height: 40px;
border: 3px solid var(--med-bg-light);
border-top-color: var(--med-primary);
border-radius: 50%;
animation: spin 1s linear infinite;
margin: 0 auto 1rem;
}

@keyframes spin {
to { transform: rotate(360deg); }
}

/* Responsive adjustments */
@media (max-width: 768px) {
.review-header-sm {
flex-direction: column;
align-items: flex-start;
gap: 0.5rem;
}

.reviews-external-links .med-btn {
width: 100%;
justify-content: center;
margin-bottom: 0.5rem;
}

.reviews-rating-summary > div {
flex-direction: column;
gap: 1rem;
}
}

/* Source Selector in Customizer Preview */
.review-source-indicator {
display: inline-block;
width: 8px;
height: 8px;
border-radius: 50%;
margin-right: 5px;
}

.review-source-indicator.api {
background: #4caf50;
}

.review-source-indicator.manual {
background: #ff9800;
}

.review-source-indicator.mixed {
background: linear-gradient(90deg, #4caf50 50%, #ff9800 50%);
}

/* ============================================================
   Privacy Policy Template Styles
   ============================================================ */

/* Privacy Header */
.privacy-header {
	text-align: center;
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 2px solid var(--med-border);
}

.privacy-meta {
	color: var(--med-text-muted);
	font-size: 0.9rem;
	margin: 0;
}

/* Privacy Sections */
.privacy-section {
	margin-bottom: 2.5rem;
}

.privacy-section:last-of-type,
.privacy-section-last {
	margin-bottom: 0;
}

.privacy-text {
	line-height: 1.8;
	color: var(--med-text);
}

.privacy-text p {
	margin-bottom: 1rem;
}

.privacy-text p:last-child {
	margin-bottom: 0;
}

/* Privacy Content */
.privacy-content h2 {
	margin-bottom: 1rem;
}

.privacy-content h3 {
	margin: 1.5rem 0 0.75rem;
}

.privacy-content ul {
	margin-left: 1.5rem;
	margin-bottom: 1rem;
}

.privacy-content li {
	margin-bottom: 0.5rem;
}

/* ============================================================
   Alert / Notice Components
   ============================================================ */

.med-alert {
	padding: 1.5rem;
	border-radius: var(--med-radius);
	border-left: 4px solid;
}

.med-alert-info {
	background: var(--med-bg-light);
	border-left-color: var(--med-primary);
}

.med-alert-success {
	background: rgba(76, 175, 80, 0.1);
	border-left-color: var(--med-success);
}

.med-alert-warning {
	background: rgba(255, 152, 0, 0.1);
	border-left-color: var(--med-warning);
}

.med-alert-error {
	background: rgba(244, 67, 54, 0.1);
	border-left-color: var(--med-error);
}

/* ============================================================
   Table Component Enhancements
   ============================================================ */

.med-table-responsive {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.med-table {
	width: 100%;
	border-collapse: collapse;
	margin: 1rem 0;
	font-size: 0.95rem;
}

.med-table th,
.med-table td {
	padding: 1rem;
	text-align: left;
	border: 1px solid var(--med-border);
}

.med-table thead th {
	background: var(--med-bg-light);
	font-weight: 600;
	color: var(--med-text-dark);
}

.med-table tbody tr:nth-child(even) {
	background: rgba(0, 0, 0, 0.02);
}

.med-table tbody tr:hover {
	background: rgba(25, 118, 210, 0.05);
}

/* ============================================================
   Text Color Utilities
   ============================================================ */

.med-text-primary {
	color: var(--med-primary);
}

.med-text-secondary {
	color: var(--med-secondary);
}

/* ============================================================
   Link Component
   ============================================================ */

.med-link {
	color: var(--med-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

.med-link:hover {
	color: var(--med-primary-dark);
	text-decoration: underline;
}

/* ============================================================
   Margin Utilities
   ============================================================ */



.med-mt-3 {
	margin-top: 2rem;
}

.med-mb-05 {
	margin-bottom: 0.5rem;
}

.med-gap-1 {
	gap: 1rem;
}

/* ============================================================
   Card Size Variants
   ============================================================ */

.med-card-lg {
	max-width: 900px;
	margin: 0 auto;
}

.med-card-light {
	background: var(--med-bg-light);
}

/* ============================================================
   Print Styles for Privacy Policy
   ============================================================ */

@media print {
	.privacy-header {
		border-bottom: 1px solid #000;
	}
	
	.med-alert {
		border: 1px solid #ccc;
		background: none;
	}
	
	.med-table th,
	.med-table td {
		border: 1px solid #000;
	}
}

/* ============================================================
   Appointment Page Enhanced Styles
   ============================================================ */

/* Status Badge Large */
.med-status-wrapper {
	text-align: center;
	margin: 1rem 0;
}

.med-status-lg {
	font-size: 1rem;
	padding: 0.5rem 1.25rem;
}

.med-status-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: currentColor;
	margin-right: 0.5rem;
	animation: pulse 2s infinite;
}

/* Contact Note */
.medical-contact-note {
	font-size: 0.875rem;
	color: var(--med-text-muted);
	margin-top: 0.25rem;
}

/* Steps Section */
.steps-container {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 0;
	margin-top: 2rem;
	flex-wrap: wrap;
}

.step-item {
	flex: 0 0 200px;
	text-align: center;
	padding: 1.5rem;
	position: relative;
}

.step-number {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 32px;
	height: 32px;
	background: var(--med-primary);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: 0.875rem;
}

.step-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
	display: block;
	margin-top: 0.5rem;
}

.step-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--med-text-dark);
}

.step-desc {
	font-size: 0.9375rem;
	color: var(--med-text-muted);
	line-height: 1.5;
	margin: 0;
}

.step-connector {
	flex: 0 0 60px;
	height: 2px;
	background: linear-gradient(90deg, var(--med-border), var(--med-primary), var(--med-border));
	margin-top: 3rem;
	position: relative;
}

.step-connector::after {
	content: '';
	position: absolute;
	right: 0;
	top: -4px;
	width: 0;
	height: 0;
	border-left: 8px solid var(--med-primary);
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
}

@media (max-width: 992px) {
	.step-connector {
		display: none;
	}
	.step-item {
		flex: 0 0 50%;
		max-width: 250px;
	}
}

@media (max-width: 576px) {
	.step-item {
		flex: 0 0 100%;
	}
}

/* Card Features List */
.med-card-features {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
	text-align: left;
}

.med-card-features li {
	padding: 0.375rem 0;
	padding-left: 1.5rem;
	position: relative;
	font-size: 0.9375rem;
	color: var(--med-text);
}

.med-card-features li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--med-success);
	font-weight: bold;
}

/* Recommended Badge */
.med-card-highlight {
	position: relative;
	overflow: visible;
}

.med-recommended-badge {
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--med-success);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	padding: 0.25rem 1rem;
	border-radius: 0 0 var(--med-radius-sm) var(--med-radius-sm);
	letter-spacing: 0.5px;
	z-index: 100;
	white-space: nowrap;
}

@media (max-width: 768px) {
	.med-recommended-badge {
		font-size: 0.65rem;
		padding: 0.2rem 0.75rem;
		top: -8px;
	}
	.med-card-highlight {
		padding-top: 1.25rem;
	}
}

.med-card {
	position: relative;
	border-color: var(--med-success) !important;
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(76, 175, 80, 0.15);
}

/* Guarantees */
.guarantee-item {
	text-align: center;
	padding: 1.5rem;
}

.guarantee-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
	display: block;
}

.guarantee-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--med-text-dark);
}

.guarantee-desc {
	font-size: 0.9375rem;
	color: var(--med-text-muted);
	line-height: 1.5;
	margin: 0;
}

/* Documents List */
.documents-list {
	list-style: none;
	margin: 1.5rem 0;
	padding: 0;
}

.document-item {
	display: flex;
	align-items: center;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--med-border);
}

.document-item:last-child {
	border-bottom: none;
}

.document-check {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	background: var(--med-success);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.75rem;
	margin-right: 1rem;
}

.document-text {
	font-size: 1rem;
	color: var(--med-text);
}

/* Hours List Large */
.med-hours-list-lg .med-hours-item {
	padding: 1rem 0;
	font-size: 1.0625rem;
}

/* Emergency Phone */
.emergency-phone {
	display: block;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--med-warning);
	text-decoration: none;
	margin-top: 0.75rem;
}

.emergency-phone:hover {
	color: #e68900;
}

/* Service Cards Mini */
.service-card-mini {
	background: #fff;
	border: 1px solid var(--med-border);
	border-radius: var(--med-radius);
	padding: 1.5rem;
	text-align: center;
	transition: all 0.2s ease;
}

.service-card-mini:hover {
	border-color: var(--med-primary);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.service-card-icon {
	font-size: 2rem;
	margin-bottom: 0.75rem;
}

.service-card-title {
	font-size: 1.0625rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.service-card-title a {
	color: var(--med-text-dark);
	text-decoration: none;
}

.service-card-title a:hover {
	color: var(--med-primary);
}

.service-card-price {
	font-size: 0.9375rem;
	color: var(--med-primary);
	font-weight: 600;
	margin-bottom: 0.75rem;
}

/* Location Section */
.location-info > div {
	display: flex;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.location-icon {
	flex-shrink: 0;
	font-size: 1.5rem;
	width: 40px;
	text-align: center;
}

.location-info h3 {
	margin-bottom: 0.25rem;
}

.location-info p {
	margin: 0;
	color: var(--med-text);
	line-height: 1.5;
}

.location-map {
	height: 100%;
	min-height: 300px;
}

.map-placeholder {
	width: 100%;
	height: 100%;
	min-height: 300px;
	background: linear-gradient(135deg, #f5f7fa 0%, #e4e8ec 100%);
	border-radius: var(--med-radius);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px dashed var(--med-border);
}

.map-content {
	text-align: center;
	padding: 2rem;
}

.map-icon {
	font-size: 3rem;
	display: block;
	margin-bottom: 1rem;
}

.map-content p {
	color: var(--med-text-muted);
	margin-bottom: 1rem;
}

/* FAQ Container Large */
.med-faq-container-lg {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

/* Grid Responsive */
@media (max-width: 992px) {
	.med-grid-4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.med-grid-2-tablet {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 576px) {
	.med-grid-2-tablet,
	.med-grid-4 {
		grid-template-columns: 1fr;
	}
}

/* Button Gap Utilities */
.med-gap-05 {
	gap: 0.5rem;
}

/* Button Large */
.med-btn-lg {
	padding: 0.875rem 1.5rem;
	font-size: 1rem;
}

/* ============================================================
   Appointment Page Styles - CSS Classes Only
   ============================================================ */

/* Status Badge */
.med-status-wrapper {
	text-align: center;
	margin: 1rem 0;
}

.med-status-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-size: 0.9rem;
	font-weight: 500;
}

.med-status-open {
	background: rgba(76, 175, 80, 0.9);
	color: #fff;
}

.med-status-closed {
	background: rgba(244, 67, 54, 0.9);
	color: #fff;
}

.med-status-dot {
	width: 8px;
	height: 8px;
	background: #fff;
	border-radius: 50%;
}

/* Contact Card */
.medical-contact-card {
	margin-bottom: 1rem;
}

.medical-contact-link {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: #fff;
	text-decoration: none;
}

.medical-contact-icon {
	width: 44px;
	height: 44px;
	background: rgba(255,255,255,0.2);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	flex-shrink: 0;
}

.medical-contact-label {
	font-size: 0.8rem;
	opacity: 0.8;
}

.medical-contact-value {
	font-size: 1.5rem;
	font-weight: 700;
}

.medical-contact-note {
	font-size: 0.8rem;
	opacity: 0.7;
}

/* Card Variants */
.med-card-highlight {
	position: relative;
	border-left: 4px solid var(--med-success);
	overflow: visible !important;
	padding-top: 1.5rem !important;
}

.med-border-success {
	border-left: 4px solid var(--med-success);
}

.med-border-info {
	border-left: 4px solid var(--med-info);
}

.med-border-primary {
	border-left: 4px solid var(--med-primary);
}

/* Card Icon Wrap */
.med-card-icon-wrap {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
	font-size: 1.75rem;
}

.med-bg-success {
	background: var(--med-success);
	color: #fff;
}

.med-bg-info {
	background: var(--med-info);
	color: #fff;
}

.med-bg-primary {
	background: var(--med-primary);
	color: #fff;
}

/* Card Elements */
.med-card-title {
	font-size: 1.2rem;
	margin-bottom: 0.5rem;
	text-align: center;
}

.med-card-text {
	color: var(--med-text-light);
	font-size: 0.95rem;
	margin-bottom: 1rem;
	line-height: 1.5;
	text-align: center;
}

.med-card-features {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
	text-align: left;
}

.med-card-features li {
	padding: 0.25rem 0;
	padding-left: 1.25rem;
	position: relative;
	font-size: 0.9rem;
}

.med-card-features li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--med-success);
	font-weight: bold;
}

.med-border-info .med-card-features li::before {
	color: var(--med-info);
}

.med-border-primary .med-card-features li::before {
	color: var(--med-primary);
}

/* Button Group */
.med-btn-group {
	display: flex;
	gap: 0.5rem;
	justify-content: center;
	flex-wrap: wrap;
}

.med-btn-group-center {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* List Check */
.med-list-check {
	list-style: none;
	margin: 0;
	padding: 0;
}

.med-list-check li {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--med-border);
}

.med-list-check li:last-child {
	border-bottom: none;
}

.med-list-check li::before {
	content: '✓';
	width: 24px;
	height: 24px;
	background: var(--med-success);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.75rem;
	flex-shrink: 0;
}

/* Card Danger & Warning */
.med-card-danger {
	border-left: 4px solid var(--med-danger);
	margin-bottom: 1.5rem;
}

.med-card-header-danger {
	color: var(--med-danger);
	margin-bottom: 0.75rem;
}

.med-card-warning {
	border-left: 4px solid var(--med-warning);
}

.med-card-header-warning {
	color: var(--med-warning);
	margin-bottom: 0.75rem;
}

.emergency-phone {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--med-danger);
	text-decoration: none;
	display: block;
	margin-top: 0.75rem;
}

.emergency-phone:hover {
	color: #b71c1c;
}

.emergency-note {
	margin-top: 0.5rem;
	font-size: 0.9rem;
	color: var(--med-text-muted);
}

.emergency-note a {
	color: var(--med-danger);
}

/* Location Section */
.location-info {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.location-item {
	display: flex;
	gap: 1rem;
}

.location-icon {
	font-size: 1.5rem;
	width: 40px;
	text-align: center;
	flex-shrink: 0;
}

.location-item h3 {
	margin-bottom: 0.25rem;
	font-size: 1.1rem;
}

.location-item p {
	margin: 0;
	color: var(--med-text-light);
	line-height: 1.5;
}

.location-map {
	width: 100%;
	height: 350px;
	border-radius: var(--med-radius);
	overflow: hidden;
	border: 1px solid var(--med-border);
}

.location-map iframe {
	width: 100%;
	height: 100%;
	border: 0;
}

.map-placeholder {
	width: 100%;
	height: 100%;
	background: var(--med-bg-light);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: var(--med-text-muted);
	text-align: center;
	padding: 2rem;
}

.map-placeholder span {
	font-size: 3rem;
	margin-bottom: 0.5rem;
}

/* Text Utilities */
.med-text-white {
	color: #fff;
}

.med-subtitle-white {
	color: rgba(255,255,255,0.9);
	margin-bottom: 2rem;
	font-size: 1.1rem;
}

/* CTA Section */
.med-section-gradient {
	background: linear-gradient(135deg, var(--med-primary) 0%, var(--med-secondary) 100%);
	padding: 4rem 0;
	color: #fff;
}



/* ============================================================
   APPOINTMENT PAGE STYLES
   ============================================================ */

/* Steps Section */
.steps-container {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 0;
	margin-top: 2rem;
	flex-wrap: wrap;
}

.step-item {
	flex: 0 0 200px;
	text-align: center;
	padding: 1.5rem;
	position: relative;
	background: var(--med-bg);
	border-radius: var(--med-radius);
	border: 1px solid var(--med-border);
	box-shadow: var(--med-shadow);
	margin: 0.5rem;
}

.step-number {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	width: 32px;
	height: 32px;
	background: var(--med-primary);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: 0.875rem;
	box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.step-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
	display: block;
	margin-top: 0.5rem;
}

.step-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--med-text);
}

.step-desc {
	font-size: 0.9375rem;
	color: var(--med-text-muted);
	line-height: 1.5;
	margin: 0;
}

.step-connector {
	flex: 0 0 60px;
	height: 2px;
	background: linear-gradient(90deg, var(--med-border), var(--med-primary), var(--med-border));
	margin-top: 3rem;
	position: relative;
}

.step-connector::after {
	content: '';
	position: absolute;
	right: 0;
	top: -4px;
	width: 0;
	height: 0;
	border-left: 8px solid var(--med-primary);
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
}

@media (max-width: 992px) {
	.step-connector {
		display: none;
	}
	.step-item {
		flex: 0 0 45%;
		max-width: 250px;
	}
}

@media (max-width: 576px) {
	.step-item {
		flex: 0 0 100%;
		max-width: none;
	}
}

/* Guarantees Section */
.guarantee-item {
	text-align: center;
	padding: 2rem 1.5rem;
	background: var(--med-bg);
	border-radius: var(--med-radius);
	border: 1px solid var(--med-border);
	box-shadow: var(--med-shadow);
	height: 100%;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.guarantee-item:hover {
	transform: translateY(-4px);
	box-shadow: var(--med-shadow-hover);
}

.guarantee-icon {
	font-size: 3rem;
	margin-bottom: 1rem;
	display: block;
}

.guarantee-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 0.75rem;
	color: var(--med-text);
}

.guarantee-desc {
	font-size: 0.9375rem;
	color: var(--med-text-light);
	line-height: 1.6;
	margin: 0;
}

/* Service Card Mini */
.service-card-mini {
	text-align: center;
	padding: 1.5rem;
	transition: all 0.3s ease;
}

.service-card-mini:hover {
	border-color: var(--med-primary);
	box-shadow: var(--med-shadow-hover);
}

.service-card-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
}

.service-card-title {
	font-size: 1.0625rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.service-card-title a {
	color: var(--med-text);
	text-decoration: none;
}

.service-card-title a:hover {
	color: var(--med-primary);
}

.service-card-price {
	font-size: 1.125rem;
	color: var(--med-primary);
	font-weight: 700;
	margin-bottom: 1rem;
}

/* Doctor Card Small */
.doctor-card-sm {
	display: flex;
	flex-direction: column;
	padding: 0;
	overflow: hidden;
}

.doctor-card-image {
	width: 100%;
	aspect-ratio: 1;
	overflow: hidden;
	background: var(--med-bg-light);
}

.doctor-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.doctor-card-sm:hover .doctor-card-image img {
	transform: scale(1.05);
}

.doctor-card-body {
	padding: 1.5rem;
	flex: 1;
}

.doctor-card-name {
	font-size: 1.125rem;
	font-weight: 600;
	margin: 0 0 0.5rem;
	color: var(--med-text);
}

.doctor-card-position {
	color: var(--med-primary);
	font-weight: 500;
	font-size: 0.9375rem;
	margin: 0 0 0.25rem;
}

.doctor-card-experience {
	color: var(--med-text-muted);
	font-size: 0.875rem;
	margin: 0;
}

.doctor-card-footer {
	padding: 1rem 1.5rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.5rem;
	border-top: 1px solid var(--med-border);
	background: var(--med-bg-light);
}

/* Button Outline */
.med-btn-outline {
	background: transparent;
	color: var(--med-primary);
	border: 2px solid var(--med-primary);
}

.med-btn-outline:hover {
	background: var(--med-primary);
	color: #fff;
}

/* Unified Card Borders */
.med-card-danger,
.med-card-warning,
.location-item,
.med-faq-item {
	background: var(--med-bg);
	border: 1px solid var(--med-border);
	border-radius: var(--med-radius);
	padding: 1.5rem;
	box-shadow: var(--med-shadow);
}

.med-card-danger {
	border-left: 4px solid var(--med-danger);
}

.med-card-warning {
	border-left: 4px solid var(--med-warning);
}

/* Alert Styles */
.med-alert {
	background: var(--med-bg);
	border: 1px solid var(--med-border);
	border-radius: var(--med-radius);
	padding: 1.5rem;
	box-shadow: var(--med-shadow);
}

.med-alert-info {
	border-left: 4px solid var(--med-primary);
	background: var(--med-bg-light);
}

/* FAQ Styles */
.med-faq-item {
	margin-bottom: 1rem;
	overflow: hidden;
}

.med-faq-summary {
	font-weight: 600;
	color: var(--med-text);
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.25rem;
	background: var(--med-bg-light);
	border-radius: var(--med-radius-sm);
	margin: -1.5rem;
}

.med-faq-summary::-webkit-details-marker {
	display: none;
}

.med-faq-icon {
	transition: transform 0.3s;
	font-size: 0.875rem;
	color: var(--med-text-muted);
}

.med-faq-item[open] .med-faq-icon {
	transform: rotate(180deg);
}

.med-faq-item[open] .med-faq-summary {
	border-bottom: 1px solid var(--med-border);
	border-radius: var(--med-radius-sm) var(--med-radius-sm) 0 0;
}

.med-faq-content {
	padding: 1.5rem 0 0;
	margin-top: 1rem;
	color: var(--med-text-light);
	line-height: 1.7;
}

/* Location Item */
.location-item {
	display: flex;
	gap: 1rem;
	margin-bottom: 1rem;
}

.location-icon {
	flex-shrink: 0;
	font-size: 1.5rem;
	width: 40px;
	text-align: center;
}

.location-item h3 {
	margin-bottom: 0.25rem;
	font-size: 1.1rem;
}

.location-item p {
	margin: 0;
	color: var(--med-text-light);
	line-height: 1.5;
}

/* Review Card Small */
.review-card-sm {
	padding: 1.5rem;
	transition: transform 0.2s, box-shadow 0.2s;
}

.review-card-sm:hover {
	transform: translateY(-2px);
	box-shadow: var(--med-shadow-hover);
}

.review-header-sm {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 1rem;
}

.review-author-sm {
	color: var(--med-text);
	font-size: 1rem;
	font-weight: 600;
}

.review-stars-sm {
	color: #ffc107;
	font-size: 1.1rem;
	letter-spacing: 2px;
}

.review-text-sm {
	margin: 0 0 1rem;
	font-style: italic;
	color: var(--med-text-light);
	line-height: 1.6;
	border-left: 3px solid var(--med-primary);
	padding-left: 1rem;
}

.review-footer-sm {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 0.875rem;
	color: var(--med-text-muted);
}

.review-source-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 2px 8px;
	border-radius: 12px;
	font-size: 12px;
	font-weight: 500;
}

.review-source-badge.yandex {
	background: #ffebee;
	color: #fc3f1d;
}

.review-source-badge.google {
	background: #e8f0fe;
	color: #4285f4;
}

.med-card-highlight {
	position: relative;
	border-color: var(--med-success) !important;
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(76, 175, 80, 0.15);
	overflow: visible;
	padding-top: 1.5rem;
}

/* Card Features */
.med-card-features {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
	text-align: left;
}

.med-card-features li {
	padding: 0.375rem 0;
	padding-left: 1.5rem;
	position: relative;
	font-size: 0.9375rem;
	color: var(--med-text);
}

.med-card-features li::before {
	content: '✓';
	position: absolute;
	left: 0;
	color: var(--med-success);
	font-weight: bold;
}

/* List Check */
.med-list-check {
	list-style: none;
	margin: 0;
	padding: 0;
}

.med-list-check li {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--med-border);
}

.med-list-check li:last-child {
	border-bottom: none;
}

.med-list-check li::before {
	content: '✓';
	width: 24px;
	height: 24px;
	background: var(--med-success);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.75rem;
	flex-shrink: 0;
}

/* Emergency Phone */
.emergency-phone {
	display: block;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--med-danger);
	text-decoration: none;
	margin-top: 0.75rem;
}

.emergency-phone:hover {
	color: #b71c1c;
}

.emergency-note {
	margin-top: 0.5rem;
	font-size: 0.9rem;
	color: var(--med-text-muted);
}

.emergency-note a {
	color: var(--med-danger);
}

/* Card Headers */
.med-card-header-danger {
	color: var(--med-danger);
	margin-bottom: 0.75rem;
	font-size: 1.125rem;
}

.med-card-header-warning {
	color: var(--med-warning);
	margin-bottom: 0.75rem;
	font-size: 1.125rem;
}

/* Button Group */
.med-btn-group {
	display: flex;
	gap: 0.5rem;
	justify-content: center;
	flex-wrap: wrap;
}

.med-btn-group-center {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* Status Badge */
.med-status-wrapper {
	text-align: center;
	margin: 1rem 0;
}

.med-status-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-size: 0.9rem;
	font-weight: 500;
}

.med-status-open {
	background: rgba(76, 175, 80, 0.9);
	color: #fff;
}

.med-status-closed {
	background: rgba(244, 67, 54, 0.9);
	color: #fff;
}

.med-status-dot {
	width: 8px;
	height: 8px;
	background: #fff;
	border-radius: 50%;
}

/* Dark Mode Support for Appointment Page */
@media (prefers-color-scheme: dark) {
	.step-item,
	.guarantee-item,
	.med-card-danger,
	.med-card-warning,
	.location-item,
	.med-faq-item {
		background: var(--med-bg-light);
		border-color: var(--med-border);
	}
	
	.med-faq-summary {
		background: var(--med-bg);
	}
	
	.doctor-card-footer {
		background: var(--med-bg);
		border-color: var(--med-border);
	}
	
	.review-source-badge.yandex {
		background: #4a1a1a;
		color: #ff8a80;
	}
	
	.review-source-badge.google {
		background: #1a3a6a;
		color: #8ab4f8;
	}
}

/* ============================================================
   POPULAR SERVICE BADGE & STYLES
   ============================================================ */

/* Service Card Popular Badge */
.service-popular-badge {
	position: absolute;
	top: -10px;
	right: 15px;
	background: linear-gradient(135deg, #ff6b6b 0%, #ff8e53 100%);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	padding: 0.35rem 0.75rem;
	border-radius: 20px;
	box-shadow: 0 4px 15px rgba(255, 107, 107, 0.4);
	display: flex;
	align-items: center;
	gap: 0.25rem;
	z-index: 2;
	animation: pulse-badge 2s infinite;
}

.badge-icon {
	font-size: 0.875rem;
}

/* Service Card with Popular State */
.service-card-mini {
	position: relative;
	text-align: center;
	padding: 1.5rem;
	transition: all 0.3s ease;
}

.service-card-mini.is-popular {
	border: 2px solid #ff6b6b;
	transform: translateY(-4px);
	box-shadow: 0 12px 30px rgba(255, 107, 107, 0.15);
}

.service-card-mini:hover {
	border-color: var(--med-primary);
	box-shadow: var(--med-shadow-hover);
}

.service-card-mini.is-popular:hover {
	border-color: #ff6b6b;
	transform: translateY(-6px);
	box-shadow: 0 16px 40px rgba(255, 107, 107, 0.25);
}

/* Service Duration */
.service-duration {
	display: inline-block;
	font-size: 0.75rem;
	color: var(--med-text-muted);
	font-weight: 400;
	margin-left: 0.5rem;
	padding-left: 0.5rem;
	border-left: 1px solid var(--med-border);
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
	.service-card-mini.is-popular {
		border-color: #ff8e53;
		box-shadow: 0 12px 30px rgba(255, 107, 107, 0.2);
	}
	
	.service-card-mini.is-popular:hover {
		box-shadow: 0 16px 40px rgba(255, 107, 107, 0.3);
	}
	
	.service-popular-badge {
		box-shadow: 0 4px 15px rgba(255, 107, 107, 0.5);
	}
}

/* ============================================================
   FRONT PAGE ENHANCEMENTS - Contact Info & Contrast Fixes
   ============================================================ */

/* Pulse Dot for Active Status */
.pulse-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	background: #4caf50;
	border-radius: 50%;
	margin-right: 6px;
	animation: pulse-green 2s infinite;
	box-shadow: 0 0 0 0 rgba(76, 175, 80, 0.7);
}



/* Contact Details Block */
.contact-details {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.contact-row {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin-bottom: 8px;
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.95);
}

.contact-icon {
	flex-shrink: 0;
	font-size: 1rem;
	opacity: 0.9;
}

.contact-hours-row {
	align-items: flex-start;
}

.contact-hours-details {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.hours-line {
	display: flex;
	gap: 8px;
}

.hours-label {
	font-weight: 500;
	min-width: 35px;
	color: rgba(255, 255, 255, 0.8);
}

.hours-value {
	color: rgba(255, 255, 255, 0.95);
}

.hours-closed .hours-value {
	color: #ff8a80;
	font-weight: 500;
}

/* Enhanced Contact Phone Label */
.contact-phone-label {
	font-size: 0.8rem;
	opacity: 0.9;
	display: flex;
	align-items: center;
	gap: 4px;
	flex-wrap: wrap;
}

/* Contrast Improvements for Light Theme */
:root {
	/* Enhanced text colors for better contrast */
	--med-text: #1a1a1a;
	--med-text-light: #4a4a4a;
	--med-text-muted: #666666;
	--med-text-subtle: #757575;
	
	/* Stronger primary for better contrast */
	--med-primary: #5568d3;
	--med-primary-dark: #3f4fa3;
	--med-secondary: #5a3a7a;
	
	/* Border with better contrast */
	--med-border: #b0b0b0;
	--med-border-light: #d0d0d0;
}

/* Enhanced Card Contrast */
.med-card {
	background: #ffffff;
	border: 1px solid var(--med-border-light);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.med-card-title,
.feature-title,
.quick-service-title-sm {
	color: var(--med-text);
	font-weight: 600;
}

.med-card-text,
.feature-desc,
.quick-service-desc-sm {
	color: var(--med-text-light);
}

/* Service Card Price - Better Contrast */
.service-card-price {
	color: var(--med-primary-dark);
	font-weight: 700;
}

/* Doctor Card Enhancements */
.doctor-position-sm {
	color: var(--med-primary-dark);
	font-weight: 600;
}

.doctor-specialty-sm {
	color: var(--med-text-light);
}

/* Review Card Contrast */
.review-author-sm {
	color: var(--med-text);
	font-weight: 600;
}

.review-text-sm {
	color: var(--med-text-light);
}

/* FAQ Content */
.faq-content {
	color: var(--med-text-light);
	line-height: 1.7;
}

/* Links with Better Contrast */
.med-link,
.read-more,
.entry-content a {
	color: var(--med-primary-dark);
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.med-link:hover,
.read-more:hover,
.entry-content a:hover {
	color: var(--med-secondary);
}

/* Button Text Contrast */
.med-btn {
	font-weight: 600;
}

.med-btn-primary {
	background: var(--med-primary-dark);
}

/* Dark Mode Contrast Improvements */
@media (prefers-color-scheme: dark) {
	:root {
		/* Dark theme with better contrast */
		--med-text: #ffffff;
		--med-text-light: #e0e0e0;
		--med-text-muted: #b0b0b0;
		--med-text-subtle: #909090;
		
		/* Lighter primary for dark backgrounds */
		--med-primary: #7b8ef5;
		--med-primary-dark: #9aaaf8;
		--med-secondary: #b794d4;
		
		/* Borders with better visibility */
		--med-border: #4a4a6a;
		--med-border-light: #3a3a5a;
		
		/* Backgrounds */
		--med-bg: #0f0f1a;
		--med-bg-light: #1a1a2e;
		--med-bg-gray: #151525;
	}
	
	/* Body background */
	body {
		background-color: var(--med-bg);
		color: var(--med-text);
	}
	
	/* Cards in dark mode */
	.med-card,
	.doctor-card,
	.review-card-sm,
	.quick-service-card {
		background: var(--med-bg-light);
		border-color: var(--med-border);
	}
	
	/* Service card popular badge in dark mode */
	.service-popular-badge {
		box-shadow: 0 4px 15px rgba(255, 107, 107, 0.5);
	}
	
	/* Text colors in dark mode */
	.med-card-title,
	.feature-title,
	.quick-service-title-sm,
	.doctor-name-sm,
	.review-author-sm {
		color: var(--med-text);
	}
	
	.med-card-text,
	.feature-desc,
	.quick-service-desc-sm,
	.doctor-specialty-sm,
	.review-text-sm {
		color: var(--med-text-light);
	}
	
	/* Price in dark mode - brighter for contrast */
	.service-card-price {
		color: var(--med-primary);
	}
	
	/* Position in dark mode */
	.doctor-position-sm {
		color: var(--med-primary);
	}
	
	/* Links in dark mode */
	.med-link,
	.read-more,
	.entry-content a,
	.quick-service-title-sm a {
		color: var(--med-primary);
	}
	
	.med-link:hover,
	.read-more:hover,
	.entry-content a:hover {
		color: var(--med-secondary);
	}
	
	/* FAQ in dark mode */
	.faq-content {
		color: var(--med-text-light);
	}
	
	/* Meta text */
	.med-text-muted,
	.review-footer-sm,
	.hours-label {
		color: var(--med-text-muted);
	}
	
	/* Section backgrounds */
	.section-bg-white {
		background: var(--med-bg);
	}
	
	.section-bg-gray {
		background: var(--med-bg-gray);
	}
	
	/* Glass panel adjustments */
	.glass-panel {
		background: rgba(30, 30, 50, 0.85);
		border-color: rgba(255, 255, 255, 0.1);
	}
	
	/* Form elements */
	input,
	textarea,
	select,
	.astra-child-search-input {
		background: var(--med-bg);
		color: var(--med-text);
		border-color: var(--med-border);
	}
	
	input::placeholder,
	textarea::placeholder {
		color: var(--med-text-muted);
	}
	
	/* Status badges */
	.med-status-open {
		background: rgba(76, 175, 80, 0.2);
		color: #81c784;
		border: 1px solid rgba(76, 175, 80, 0.3);
	}
	
	.med-status-closed {
		background: rgba(244, 67, 54, 0.2);
		color: #e57373;
		border: 1px solid rgba(244, 67, 54, 0.3);
	}
	
	/* Contact hours in dark mode */
	.contact-row {
		color: rgba(255, 255, 255, 0.95);
	}
	
	.hours-label {
		color: rgba(255, 255, 255, 0.7);
	}
	
	.hours-value {
		color: rgba(255, 255, 255, 0.95);
	}
	
	/* Alert backgrounds */
	.med-alert-info {
		background: rgba(33, 150, 243, 0.1);
		border-left-color: var(--med-primary);
	}
	
	/* Service card hover */
	.service-card-mini:hover {
		border-color: var(--med-primary);
	}
	
	/* Step items */
	.step-item {
		background: var(--med-bg-light);
		border-color: var(--med-border);
	}
	
	/* Guarantee items */
	.guarantee-item {
		background: var(--med-bg-light);
		border-color: var(--med-border);
	}
	
	.guarantee-title {
		color: var(--med-text);
	}
	
	.guarantee-desc {
		color: var(--med-text-light);
	}
}

/* Manual Dark Mode Class */
.dark-mode {
	--med-text: #ffffff;
	--med-text-light: #e0e0e0;
	--med-text-muted: #b0b0b0;
	--med-primary: #7b8ef5;
	--med-primary-dark: #9aaaf8;
	--med-secondary: #b794d4;
	--med-border: #4a4a6a;
	--med-border-light: #3a3a5a;
	--med-bg: #0f0f1a;
	--med-bg-light: #1a1a2e;
	--med-bg-gray: #151525;
}

.dark-mode body {
	background-color: var(--med-bg);
	color: var(--med-text);
}

/* Focus styles for accessibility */
*:focus-visible {
	outline: 3px solid var(--med-primary);
	outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
	:root {
		--med-text: #000000;
		--med-text-light: #333333;
		--med-border: #000000;
		--med-primary: #0000ee;
		--med-primary-dark: #0000aa;
	}
	
	.med-card {
		border-width: 2px;
	}
	
	.med-btn {
		border: 2px solid currentColor;
	}
}

@media (prefers-contrast: high) and (prefers-color-scheme: dark) {
	:root {
		--med-text: #ffffff;
		--med-text-light: #ffffff;
		--med-border: #ffffff;
		--med-primary: #ffff00;
		--med-primary-dark: #ffff00;
		--med-bg: #000000;
		--med-bg-light: #000000;
	}
}

/* ============================================================
   CLINIC STATUS BADGE - Hero Section
   ============================================================ */

.clinic-status-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px 8px;
	border-radius: 12px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	margin-left: 4px;
}

.clinic-status-badge.med-status-open {
	background: rgba(76, 175, 80, 0.25);
	color: #81c784;
	border: 1px solid rgba(76, 175, 80, 0.4);
}

.clinic-status-badge.med-status-closed {
	background: rgba(244, 67, 54, 0.25);
	color: #e57373;
	border: 1px solid rgba(244, 67, 54, 0.4);
}

/* Light theme adjustments for status badge */
.medical-hero .clinic-status-badge.med-status-open {
	background: rgba(76, 175, 80, 0.9);
	color: #ffffff;
	border: none;
}

.medical-hero .clinic-status-badge.med-status-closed {
	background: rgba(244, 67, 54, 0.9);
	color: #ffffff;
	border: none;
}

/* Contact phone label enhancements */
.contact-phone-label {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 4px;
}

/* Hero section text contrast improvements */
.medical-hero {
	background: linear-gradient(135deg, var(--med-primary) 0%, var(--med-secondary) 100%);
	color: #ffffff;
}

.medical-hero .hero-title-white,
.medical-hero .hero-subtitle,
.medical-hero .hero-description {
	color: #ffffff;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

.medical-hero .contact-card {
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.medical-hero .contact-phone-number {
	color: #ffffff;
	font-weight: 700;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Enhanced contrast for contact details in hero */
.medical-hero .contact-row {
	color: rgba(255, 255, 255, 0.95);
}

.medical-hero .hours-label {
	color: rgba(255, 255, 255, 0.85);
}

.medical-hero .hours-value {
	color: rgba(255, 255, 255, 0.95);
}

/* Section background improvements */
.section-bg-white {
	background: #ffffff;
}

.section-bg-gray {
	background: #f5f7fa;
}

/* Dark mode adjustments for hero */
@media (prefers-color-scheme: dark) {
	.medical-hero {
		background: linear-gradient(135deg, #1a1a3e 0%, #2d1b4e 100%);
	}
	
	.medical-hero .contact-card {
		background: rgba(30, 30, 50, 0.8);
		border-color: rgba(255, 255, 255, 0.1);
	}
	
	.medical-hero .clinic-status-badge.med-status-open {
		background: rgba(76, 175, 80, 0.9);
		color: #ffffff;
	}
	
	.medical-hero .clinic-status-badge.med-status-closed {
		background: rgba(244, 67, 54, 0.9);
		color: #ffffff;
	}
	
	.section-bg-white {
		background: var(--med-bg);
	}
	
	.section-bg-gray {
		background: var(--med-bg-gray);
	}
}


/* ============================================
PRICE LIST TEMPLATE STYLES
============================================ */
.price-list-container {
	max-width: var(--med-container);
	margin: 0 auto;
	padding: 0 1.5rem;
}

.price-table {
	background: var(--med-bg);
	border-radius: var(--med-radius);
	overflow: hidden;
	box-shadow: var(--med-shadow);
}

.price-row {
	padding: 1rem 1.5rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	border-bottom: 1px solid var(--med-border);
	transition: background 0.2s ease;
}

.price-row:hover {
	background: rgba(85, 104, 211, 0.05);
}

.price-row:last-child {
	border-bottom: none;
}

.price-row__content {
	flex: 1;
	min-width: 0;
}

.price-row__title-wrapper {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-wrap: wrap;
}

.price-row__title {
	margin: 0;
	font-size: 1rem;
	font-weight: 500;
	color: var(--med-text);
}

.price-row__title a {
	color: inherit;
	text-decoration: none;
}

.price-row__title a:hover {
	color: var(--med-primary);
}

.price-row__meta {
	margin: 0.25rem 0 0;
	color: var(--med-text-muted);
	font-size: 0.85rem;
}

.price-row__actions {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex-shrink: 0;
}

.price-row__price {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--med-primary);
	white-space: nowrap;
}

.price-row__price--request {
	color: var(--med-text-muted);
	font-size: 0.9rem;
	font-weight: normal;
}

.price-row__btn {
	white-space: nowrap;
}

/* Popular Badge */
.popular-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	padding: 2px 8px;
	background: var(--med-success);
	color: #fff;
	border-radius: 12px;
	font-size: 0.75rem;
	font-weight: 500;
}

/* Category Header */
.price-category__header {
	margin: 0 0 1.5rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var(--med-primary);
	color: var(--med-text);
	font-size: 1.5rem;
}

.price-category__count {
	font-size: 0.85rem;
	color: var(--med-text-muted);
	font-weight: normal;
	margin-left: 0.5rem;
}

/* Hero Section Price List */
.price-hero {
	min-height: 40vh;
	padding: 3rem 0;
}

.price-hero__content {
	max-width: 700px;
}

.price-hero__title {
	color: #fff;
	margin-bottom: 1rem;
}

.price-hero__subtitle {
	font-size: 1.15rem;
	margin: 0 0 1.5rem;
	opacity: 0.95;
	line-height: 1.6;
}

.price-hero__actions {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

/* Clinic Info Card */
.price-clinic-card {
	margin-bottom: 3rem;
	background: linear-gradient(135deg, var(--med-bg-light), #fff);
	border: 1px solid var(--med-border);
}

.price-clinic-card__content {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	align-items: center;
	justify-content: space-between;
}

.price-clinic-card__info h2 {
	margin: 0 0 0.5rem;
	font-size: 1.25rem;
	color: var(--med-text);
}

.price-clinic-card__license {
	margin: 0;
	color: var(--med-text-muted);
	font-size: 0.9rem;
}

.price-clinic-card__contact {
	text-align: right;
}

.price-clinic-card__phone-label {
	margin: 0 0 0.5rem;
	font-size: 0.9rem;
	color: var(--med-text-light);
}

.price-clinic-card__phone {
	color: var(--med-primary);
	font-weight: 600;
}

/* Popular Services Section */
.price-popular-section {
	margin-bottom: 3rem;
}

.price-popular-section__title {
	margin: 0 0 1.5rem;
	padding-bottom: 0.75rem;
	border-bottom: 3px solid var(--med-success);
	color: var(--med-text);
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

/* Admin Notice */
.price-admin-notice {
	margin-bottom: 2rem;
	padding: 1rem;
	background: #e3f2fd;
	border-left: 4px solid #2196f3;
	border-radius: var(--med-radius-sm);
	font-size: 0.95rem;
}

/* Legal Notice */
.price-legal-notice {
	margin-top: 3rem;
	padding: 1.5rem;
	background: var(--med-bg-light);
	border: 1px solid var(--med-border);
	text-align: center;
}

.price-legal-notice p {
	margin: 0 0 0.5rem;
	font-size: 0.875rem;
	color: var(--med-text-muted);
}

.price-legal-notice p:last-child {
	margin: 0;
}

/* CTA Section */
.price-cta {
	margin-top: 2rem;
	text-align: center;
	background: linear-gradient(135deg, var(--med-primary), var(--med-secondary)) !important;
	color: #fff;
	border: none;
}

.price-cta__title {
	margin: 0 0 1rem;
	color: #fff;
}

.price-cta__text {
	margin: 0 0 1.5rem;
	opacity: 0.95;
}

.price-cta__actions {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* Empty State */
.price-empty {
	text-align: center;
	padding: 3rem;
}

.price-empty__icon {
	font-size: 4rem;
	margin-bottom: 1rem;
}

.price-empty__title {
	margin-bottom: 1rem;
}

.price-empty__text {
	color: var(--med-text-light);
	margin-bottom: 2rem;
}

/* Mobile Responsive for Price List */
@media (max-width: 768px) {
	.price-row {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}
	
	.price-row__actions {
		width: 100%;
		justify-content: space-between;
	}
	
	.price-hero {
		min-height: auto;
		padding: 2rem 0;
	}
	
	.price-clinic-card__content {
		flex-direction: column;
		text-align: center;
	}
	
	.price-clinic-card__contact {
		text-align: center;
	}
	
	.price-category__header {
		font-size: 1.25rem;
	}
	
	.price-row__price {
		font-size: 1.1rem;
	}
}

/* Print Styles for Price List */
@media print {
	.price-hero,
	.price-admin-notice,
	.price-row__btn,
	.price-cta,
	.med-btn {
		display: none !important;
	}
	
	.price-row {
		break-inside: avoid;
		border-bottom: 1px solid #ccc !important;
	}
	
	.price-table {
		box-shadow: none !important;
		border: 1px solid #ccc;
	}
	
	.price-category__header {
		border-bottom-color: #000 !important;
	}
}

/* Dark Mode for Price List */
@media (prefers-color-scheme: dark) {
	.price-row:hover {
		background: rgba(255,255,255,0.05);
	}
	
	.price-clinic-card {
		background: linear-gradient(135deg, var(--med-dark-bg-light), var(--med-dark-bg));
	}
	
	.price-admin-notice {
		background: #1a3a5c;
		border-left-color: #4a9eff;
	}
	
	.price-legal-notice {
		background: var(--med-dark-bg-light);
		border-color: var(--med-dark-border);
	}
}


/* ============================================
LEGAL INFO PAGE - Responsive Grid
============================================ */
.legal-info-list {
margin: 0;
display: grid;
gap: 0.75rem;
}

.legal-info-row {
display: grid;
grid-template-columns: 200px 1fr;
gap: 1rem;
padding: 0.75rem;
background: var(--med-bg-light);
border-radius: var(--med-radius-sm);
}

.legal-info-row dt {
font-weight: 600;
color: var(--med-text);
}

.legal-info-row dd {
margin: 0;
color: var(--med-text-light);
word-break: break-word;
}

@media (max-width: 768px) {
.legal-info-row {
grid-template-columns: 1fr;
gap: 0.5rem;
}
}


/* ============================================
FRONT PAGE - Messengers fix
============================================ */
.messengers-scroll {
display: flex !important;
flex-wrap: wrap !important;
gap: 0.75rem !important;
margin: 1.5rem 0 !important;
}

@media (max-width: 768px) {
.messengers-scroll {
justify-content: center !important;
}
.med-messenger-btn {
flex: 0 0 auto !important;
max-width: calc(50% - 0.375rem) !important;
}
}

@media (max-width: 480px) {
.med-messenger-btn {
max-width: 100% !important;
}
}

/* ============================================
TEXT WRAP FIX - Prevent text overflow
============================================ */
.med-card,
.glass-panel,
.medical-hero .glass-panel {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
word-break: break-word !important;
hyphens: auto !important;
}

.med-card dt,
.med-card dd,
.glass-panel dt,
.glass-panel dd,
.medical-hero .glass-panel dt,
.medical-hero .glass-panel dd {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
word-break: break-word !important;
max-width: 100% !important;
}

/* Hero section specific fixes */
.medical-hero .glass-panel {
max-width: 100% !important;
box-sizing: border-box !important;
}

@media (max-width: 768px) {
.medical-hero .glass-panel {
padding: 1rem !important;
}
.medical-hero h1,
.medical-hero h2,
.medical-hero p {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
word-break: break-word !important;
}
}


/* ============================================
LEGAL & STAFF INFO PAGES - Text wrap fix
============================================ */

/* Fix for definition lists (dl/dt/dd) */
.med-card dl,
.med-card dt,
.med-card dd {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
word-break: break-word !important;
hyphens: auto !important;
max-width: 100% !important;
}

.med-card dt {
font-weight: 600;
color: var(--med-text);
}

.med-card dd {
margin: 0;
color: var(--med-text-light);
}

/* Grid layout for legal info rows - responsive */
.med-card dl > div {
display: grid;
grid-template-columns: minmax(120px, 200px) 1fr;
gap: 1rem;
padding: 0.75rem;
background: var(--med-bg-light);
border-radius: var(--med-radius-sm);
margin-bottom: 0.75rem;
}

/* On mobile - stack elements vertically */
@media (max-width: 768px) {
.med-card dl > div {
display: flex !important;
flex-direction: column !important;
gap: 0.25rem !important;
padding: 0.75rem !important;
}

.med-card dt {
font-size: 0.85rem !important;
opacity: 0.7 !important;
margin-bottom: 0.25rem !important;
}

.med-card dd {
font-size: 1rem !important;
font-weight: 500 !important;
}
}

/* Staff info cards specific */
.staff-info-card,
.doctor-info-card {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
word-break: break-word !important;
}

.staff-info-card p,
.doctor-info-card p,
.staff-info-card li,
.doctor-info-card li {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
word-break: break-word !important;
}

/* Additional fix for all text content */
.med-card h3,
.med-card h4,
.med-card p,
.med-card span,
.med-card a {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
}

/* Ensure cards don't overflow */
.med-card {
max-width: 100% !important;
overflow: hidden !important;
}

/* Exception: highlighted cards need overflow visible for badge */
.med-card.med-card-highlight {
overflow: visible !important;
}


/* ============================================
LICENSE COPY BUTTON - Interactive
============================================ */
.license-copy-btn {
position: relative !important;
transition: all 0.3s ease !important;
cursor: pointer !important;
overflow: hidden !important;
}

.license-copy-btn:hover {
transform: translateY(-2px) !important;
box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}

.license-copy-btn:active {
transform: translateY(0) !important;
}

.license-copy-btn .license-text,
.license-copy-btn .license-copied {
display: inline-block;
transition: opacity 0.2s ease;
}

.license-copy-btn.copied {
background: #4caf50 !important;
}

/* Animation for copied state */
@keyframes licensePulse {
0% { transform: scale(1); }
50% { transform: scale(1.02); }
100% { transform: scale(1); }
}

.license-copy-btn.copied {
animation: licensePulse 0.3s ease;
}


/* ============================================
MOBILE HERO PHONE FIX
============================================ */

/* Phone number should stay on one line on mobile */
@media (max-width: 480px) {
.contact-phone-link {
flex-wrap: nowrap !important;
gap: 0.5rem !important;
}

.contact-phone-icon {
width: 32px !important;
height: 32px !important;
font-size: 1rem !important;
flex-shrink: 0 !important;
background: rgba(255,255,255,0.3) !important;
}

.contact-phone-number {
font-size: 1.1rem !important;
white-space: nowrap !important;
overflow: hidden !important;
text-overflow: ellipsis !important;
}

.contact-phone-label {
font-size: 0.7rem !important;
}

/* Dark mode fix for phone icon */
@media (prefers-color-scheme: dark) {
.contact-phone-icon {
background: rgba(255,255,255,0.25) !important;
}
}
}

/* Dark mode phone icon fix */
.dark-mode .contact-phone-icon,
.dark-mode .medical-hero .contact-phone-icon {
background: rgba(255,255,255,0.25) !important;
}

/* ============================================
LEGAL INFO PAGE - Address Block Fix
============================================ */

/* Better grid for address blocks on mobile */
@media (max-width: 768px) {
.med-card dl > div[itemscope] {
display: flex !important;
flex-direction: column !important;
gap: 0.5rem !important;
}

.med-card dl > div[itemscope] > div {
grid-template-columns: 1fr !important;
gap: 0.25rem !important;
}

.med-card dl > div[itemscope] dt {
font-size: 0.8rem !important;
opacity: 0.7 !important;
}

.med-card dl > div[itemscope] dd {
font-size: 0.95rem !important;
}
}


/* ============================================
ADDRESS LIST STYLES (Legal Info Page)
============================================ */
.address-list .address-item {
display: flex;
flex-direction: column;
gap: 0.75rem;
}

.address-list .address-row {
display: grid;
grid-template-columns: minmax(150px, 200px) 1fr;
gap: 1rem;
padding: 0.75rem;
background: var(--med-bg-light);
border-radius: var(--med-radius-sm);
}

.address-list .address-row dt {
font-weight: 600;
color: var(--med-text);
font-size: 0.9rem;
}

.address-list .address-row dd {
margin: 0;
color: var(--med-text-light);
}

/* Mobile - stack vertically */
@media (max-width: 768px) {
.address-list .address-row {
display: flex;
flex-direction: column;
gap: 0.25rem;
padding: 0.75rem;
}

.address-list .address-row dt {
font-size: 0.8rem;
opacity: 0.7;
margin-bottom: 0.25rem;
}

.address-list .address-row dd {
font-size: 1rem;
font-weight: 500;
}
}

/* Hide empty address fields */
.address-row dd:empty,
.address-row dd:blank {
display: none;
}

.address-row:has(dd:empty) {
display: none;
}


/* ============================================
PWA INSTALL BUTTON
============================================ */
.pwa-install-button {
position: fixed;
bottom: 80px;
right: 20px;
z-index: 9998;
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0.75rem 1rem;
background: linear-gradient(135deg, var(--med-primary), var(--med-secondary));
color: #fff;
border: none;
border-radius: 50px;
box-shadow: 0 4px 12px rgba(0,0,0,0.2);
cursor: pointer;
font-size: 0.9rem;
font-weight: 600;
opacity: 0;
transform: translateY(20px);
transition: all 0.3s ease;
pointer-events: none;
}

.pwa-install-button.is-visible {
opacity: 1;
transform: translateY(0);
pointer-events: auto;
}

.pwa-install-button:hover {
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(0,0,0,0.3);
}

.pwa-install-button .pwa-install-icon {
font-size: 1.2rem;
}

@media (max-width: 768px) {
.pwa-install-button .pwa-install-text {
display: none;
}
.pwa-install-button {
padding: 0.75rem;
border-radius: 50%;
bottom: 80px;
}
}

/* Position adjustments when both buttons present */
.a11y-toggle ~ .pwa-install-button,
.pwa-install-button ~ .a11y-toggle {
bottom: 140px;
}

@media (max-width: 768px) {
.a11y-toggle ~ .pwa-install-button,
.pwa-install-button ~ .a11y-toggle {
bottom: 140px;
}
}


/* ============================================
APPOINTMENT PAGE - Fix overlapping blocks
============================================ */

/* Ensure grid items don't overlap */
.med-grid-2 {
grid-template-columns: repeat(2, 1fr);
align-items: start;
}

.med-grid-2 > div {
height: auto;
min-height: 0;
}

/* Fix card heights and overflow */
.med-card {
height: auto;
overflow: visible;
}

/* Ensure proper spacing between sections */
.med-section + .med-section {
margin-top: 0;
padding-top: 3rem;
}

/* Fix for info section grid */
section[aria-labelledby="info-heading"] .med-grid-2 {
gap: 2rem;
align-items: stretch;
}

section[aria-labelledby="info-heading"] .med-grid-2 > div {
display: flex;
flex-direction: column;
}

section[aria-labelledby="info-heading"] .med-card {
flex: 1 1 auto;
}

/* Mobile fixes */
@media (max-width: 768px) {
.med-grid-2 {
grid-template-columns: 1fr;
}

section[aria-labelledby="info-heading"] .med-grid-2 > div + div {
margin-top: 2rem;
}
}

/* Ensure alerts don't overflow */
.med-alert {
clear: both;
margin-top: 1rem;
}

/* Fix emergency card */
.med-card-danger {
height: auto;
min-height: 0;
}


/* ============================================
PRICE LIST PAGE - Mobile fixes
============================================ */

/* Prevent horizontal overflow on price list page */
.price-list-page {
overflow-x: hidden !important;
}

.price-list-page body {
overflow-x: hidden !important;
}

/* Fix grid on mobile */
@media (max-width: 768px) {
.price-list-page .med-grid-3 {
grid-template-columns: 1fr !important;
}

.price-list-page .med-grid-2 {
grid-template-columns: 1fr !important;
}

/* Fix prices with nowrap */
.price-list-page [style*="white-space: nowrap"] {
white-space: normal !important;
word-break: break-word !important;
}

/* Ensure text wraps properly */
.price-list-page h2,
.price-list-page h3,
.price-list-page p {
overflow-wrap: break-word !important;
word-wrap: break-word !important;
}

/* Popular services section fix */
.price-list-page h2[style*="display: flex"] {
flex-wrap: wrap !important;
}
}

/* Fix for all mobile overflow issues */
@media (max-width: 480px) {
.price-list-page {
width: 100% !important;
max-width: 100% !important;
}

.price-list-page .med-container {
padding-left: 1rem !important;
padding-right: 1rem !important;
}

/* Ensure cards don't overflow */
.price-list-page .med-card {
max-width: 100% !important;
box-sizing: border-box !important;
}

/* Price display fix */
.price-list-page span[itemprop="price"] {
font-size: 1rem !important;
}
}


/* ============================================
PRICE LIST PAGE - Section titles
============================================ */

.price-section-title {
display: flex !important;
align-items: center !important;
gap: 0.5rem !important;
flex-wrap: wrap !important;
}

@media (max-width: 768px) {
.price-section-title {
font-size: 1.25rem !important;
}
}


/* ============================================
GRID SYSTEM FIXES
============================================ */

/* Default grid behavior */
.med-grid {
display: grid;
gap: 1.5rem;
}

/* 3 columns - responsive */
.med-grid-3 {
grid-template-columns: repeat(3, 1fr);
}

/* 2 columns - responsive */
.med-grid-2 {
grid-template-columns: repeat(2, 1fr);
}

/* Mobile: all grids become 1 column */
@media (max-width: 768px) {
.med-grid-3,
.med-grid-2 {
grid-template-columns: 1fr !important;
}
}

/* Small mobile: tighter gaps */
@media (max-width: 480px) {
.med-grid {
gap: 1rem;
}
}


/* ============================================
GLOBAL MOBILE OVERFLOW FIX
============================================ */

/* Prevent horizontal scroll on all pages */
html, body {
overflow-x: hidden;
max-width: 100%;
}

/* Ensure all images are responsive */
img {
max-width: 100%;
height: auto;
}

/* Fix for tables on mobile */
@media (max-width: 768px) {
table {
display: block;
overflow-x: auto;
max-width: 100%;
}
}

/* Fix for long URLs/emails */
a {
word-break: break-word;
overflow-wrap: break-word;
}

/* Container max-width enforcement */
.med-container {
max-width: 100%;
box-sizing: border-box;
}


/* ============================================
HERO SERVICES PANEL ( replaces OGRN block )
============================================ */

.hero-services-panel {
padding: 1.5rem;
max-width: 380px;
}

.hero-services-title {
margin: 0 0 1rem;
font-size: 1rem;
font-weight: 600;
color: #fff;
text-align: center;
opacity: 0.95;
}

.hero-services-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 0.75rem;
}

.hero-service-item {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
padding: 1rem 0.75rem;
background: rgba(255,255,255,0.15);
backdrop-filter: blur(10px);
border: 1px solid rgba(255,255,255,0.2);
border-radius: 12px;
text-decoration: none;
color: #fff;
transition: all 0.3s ease;
}

.hero-service-item:hover {
background: rgba(255,255,255,0.25);
transform: translateY(-3px);
border-color: var(--service-color, rgba(255,255,255,0.4));
box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

.hero-service-icon {
font-size: 2rem;
width: 2rem;
height: 2rem;
color: var(--service-color, #fff);
margin-bottom: 0.5rem;
}

.hero-service-img {
width: 48px;
height: 48px;
object-fit: cover;
border-radius: 8px;
margin-bottom: 0.5rem;
}

.hero-service-content {
display: flex;
flex-direction: column;
gap: 0.25rem;
}

.hero-service-name {
font-size: 0.9rem;
font-weight: 600;
line-height: 1.2;
}

.hero-service-slogan {
font-size: 0.75rem;
opacity: 0.8;
line-height: 1.2;
}

.hero-service-price {
font-size: 0.85rem;
font-weight: 700;
color: var(--service-color, #fff);
margin-top: 0.25rem;
padding: 0.15rem 0.5rem;
background: rgba(255,255,255,0.2);
border-radius: 20px;
}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
.hero-services-title {
color: #fff;
}
}

/* Responsive: stack to 1 column on smaller tablets */
@media (max-width: 1024px) {
.hero-services-grid {
grid-template-columns: 1fr;
}

.hero-services-panel {
max-width: 280px;
}
}

/* Mobile: hide if disabled */
@media (max-width: 768px) {
.hero-services-panel.hide-on-mobile {
display: none !important;
}
}

/* Mobile: adaptive layout */
@media (max-width: 768px) {
.hero-services-panel {
max-width: 100%;
padding: 1rem;
}

.hero-services-grid {
grid-template-columns: repeat(2, 1fr);
gap: 0.5rem;
}

.hero-service-item {
padding: 0.5rem;
}

.hero-service-name {
font-size: 0.85rem;
}

.hero-service-slogan {
font-size: 0.75rem;
}

.hero-service-price {
font-size: 0.8rem;
}
}


/* ============================================
PRICE LIST - Search Styles
============================================ */

.price-search-wrapper {
margin-bottom: 2rem;
}

.price-search-box {
position: relative;
max-width: 600px;
margin: 0 auto;
}

.price-search-icon {
position: absolute;
left: 1rem;
top: 50%;
transform: translateY(-50%);
color: var(--med-text-light);
font-size: 1.25rem;
z-index: 2;
pointer-events: none;
}

.price-search-input {
width: 100%;
padding: 1rem 1rem 1rem 3rem;
border: 2px solid var(--med-border);
border-radius: var(--med-radius);
font-size: 1rem;
background: var(--med-bg);
color: var(--med-text);
transition: all 0.2s ease;
}

.price-search-input:focus {
border-color: var(--med-primary);
outline: none;
box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.price-search-clear {
position: absolute;
right: 1rem;
top: 50%;
transform: translateY(-50%);
background: none;
border: none;
color: var(--med-text-light);
cursor: pointer;
display: none;
padding: 0.25rem;
font-size: 1.25rem;
transition: color 0.2s;
}

.price-search-clear:hover {
color: var(--med-text);
}

.price-search-results {
text-align: center;
margin-top: 0.5rem;
font-size: 0.9rem;
color: var(--med-text-light);
}

/* Mobile adjustments */
@media (max-width: 768px) {
.price-search-input {
font-size: 16px; /* Prevent zoom on iOS */
}
}

/* Fix for recommended badge visibility - ensure parent containers don't clip */
.med-grid:has(.med-card-highlight),
.med-section:has(.med-card-highlight) {
	overflow: visible;
}

/* Alternative: ensure all parent containers of highlighted cards allow overflow */
.med-container .med-grid-3:has(.med-card-highlight),
.med-container .med-grid-2:has(.med-card-highlight),
.med-container .med-grid:has(.med-card-highlight) {
	overflow: visible;
	padding-top: 0.5rem;
}


/* ============================================
FIX: Recommended badge visibility on appointment page
============================================ */

/* Ensure highlighted cards have enough space for badge */
.med-card.med-card-highlight {
	overflow: visible !important;
	padding-top: 1.5rem !important;
	margin-top: 0.75rem !important;
}

/* Ensure badge is always visible */
.med-card-highlight .med-recommended-badge {
	z-index: 9999 !important;
	top: -14px !important;
}

/* Ensure parent containers don't clip the badge */
.med-grid:has(> .med-card-highlight),
.med-container .med-grid-3:has(> .med-card-highlight),
.med-container .med-grid-2:has(> .med-card-highlight) {
	overflow: visible !important;
	padding-top: 1rem !important;
}

/* Fallback for browsers without :has() support */
.med-section .med-grid,
.med-section .med-grid-3,
.med-section .med-grid-2 {
	overflow: visible;
}

/* EMERGENCY FIX: Force badge visibility with maximum specificity */
article.med-card.med-card-highlight {
	overflow: visible !important;
	padding-top: 1.5rem !important;
	margin-top: 0.75rem !important;
}

article.med-card.med-card-highlight .med-recommended-badge {
	position: absolute !important;
	top: -14px !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	z-index: 2147483647 !important;
}

/* Ensure the grid doesn't clip */
.med-section .med-grid,
.med-section .med-grid-3,
.med-section .med-grid-2,
.med-container .med-grid,
.med-container .med-grid-3,
.med-container .med-grid-2 {
	overflow: visible !important;
	padding-top: 0.5rem !important;
}

/* Ensure container doesn't clip */
.med-section {
	overflow: visible !important;
}

/* FIX: Prevent transform from creating clipping context */
.med-card-highlight,
article.med-card.med-card-highlight {
	/* Ensure transform doesn't clip positioned children */
	will-change: auto !important;
}

/* FIX: Transform causes clipping - use alternative approach for cards with badges */
article.med-card.med-card-highlight:has(.med-recommended-badge),
.med-card.med-card-highlight:has(.med-recommended-badge) {
	transform: none !important;
	margin-top: 0.5rem !important;
	margin-bottom: 0.5rem !important;
	padding-top: 2rem !important;
}

/* Alternative: if transform causes clipping, use margin instead */
@supports not (overflow: visible) {
	.med-card-highlight {
		transform: none !important;
		margin-top: -4px !important;
		margin-bottom: 4px !important;
	}
}

/* ============================================
FIX: Appointment page badge visibility
============================================ */

/* Base styles for appointment cards - no !important */
.page-template-template-appointment .med-card-highlight {
	overflow: visible;
}

.page-template-template-appointment .med-recommended-badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
}
/* ============================================
   APPOINTMENT PAGE - LILY BACKGROUND CARD
   ============================================ */

/* Lily card with abstract golden lily silhouettes */
.page-template-template-appointment .med-card-lily {
    position: relative;
    background: #ffffff;
    overflow: hidden;
    border: 1px solid #e8d5b7;
    box-shadow: 
        0 2px 8px rgba(218, 165, 32, 0.08),
        0 4px 16px rgba(218, 165, 32, 0.05);
}

/* Abstract lily silhouettes background */
.page-template-template-appointment .med-card-lily::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: 
        /* Large lily silhouette - top right */
        radial-gradient(ellipse 80px 120px at 88% 12%, rgba(218, 165, 32, 0.12) 0%, transparent 70%),
        /* Lily petals top right */
        radial-gradient(ellipse 30px 60px at 82% 8%, rgba(184, 134, 11, 0.15) 0%, transparent 60%),
        radial-gradient(ellipse 30px 60px at 94% 8%, rgba(184, 134, 11, 0.15) 0%, transparent 60%),
        radial-gradient(ellipse 25px 50px at 85% 20%, rgba(184, 134, 11, 0.12) 0%, transparent 60%),
        
        /* Large lily silhouette - bottom left */
        radial-gradient(ellipse 70px 100px at 12% 88%, rgba(218, 165, 32, 0.1) 0%, transparent 70%),
        /* Lily petals bottom left */
        radial-gradient(ellipse 25px 50px at 6% 82%, rgba(184, 134, 11, 0.12) 0%, transparent 60%),
        radial-gradient(ellipse 25px 50px at 18% 82%, rgba(184, 134, 11, 0.12) 0%, transparent 60%),
        radial-gradient(ellipse 20px 40px at 12% 94%, rgba(184, 134, 11, 0.1) 0%, transparent 60%),
        
        /* Medium lily - center left */
        radial-gradient(ellipse 50px 80px at 5% 45%, rgba(218, 165, 32, 0.08) 0%, transparent 65%),
        radial-gradient(ellipse 20px 40px at 2% 40%, rgba(184, 134, 11, 0.1) 0%, transparent 55%),
        radial-gradient(ellipse 20px 40px at 8% 40%, rgba(184, 134, 11, 0.1) 0%, transparent 55%),
        
        /* Medium lily - center right */
        radial-gradient(ellipse 45px 70px at 95% 55%, rgba(218, 165, 32, 0.08) 0%, transparent 65%),
        radial-gradient(ellipse 18px 35px at 92% 50%, rgba(184, 134, 11, 0.1) 0%, transparent 55%),
        radial-gradient(ellipse 18px 35px at 98% 50%, rgba(184, 134, 11, 0.1) 0%, transparent 55%),
        
        /* Small decorative lilies */
        radial-gradient(ellipse 35px 55px at 25% 15%, rgba(218, 165, 32, 0.06) 0%, transparent 60%),
        radial-gradient(ellipse 30px 50px at 75% 85%, rgba(218, 165, 32, 0.06) 0%, transparent 60%),
        
        /* Lily centers (stamens) - subtle dots */
        radial-gradient(circle 4px at 88% 12%, rgba(218, 165, 32, 0.3) 0%, transparent 100%),
        radial-gradient(circle 4px at 12% 88%, rgba(218, 165, 32, 0.25) 0%, transparent 100%),
        radial-gradient(circle 3px at 5% 45%, rgba(218, 165, 32, 0.2) 0%, transparent 100%),
        radial-gradient(circle 3px at 95% 55%, rgba(218, 165, 32, 0.2) 0%, transparent 100%);
    pointer-events: none;
    z-index: 0;
}

/* Fine lily lines/petals detail layer */
.page-template-template-appointment .med-card-lily::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background:
        /* Subtle stem lines */
        linear-gradient(160deg, transparent 45%, rgba(184, 134, 11, 0.08) 50%, transparent 55%) 85% 15% / 60px 100px no-repeat,
        linear-gradient(200deg, transparent 45%, rgba(184, 134, 11, 0.08) 50%, transparent 55%) 15% 75% / 50px 90px no-repeat,
        /* Petal edges highlight */
        radial-gradient(ellipse 1px 25px at 80% 5%, rgba(255, 215, 0, 0.2) 0%, transparent 100%),
        radial-gradient(ellipse 1px 20px at 96% 5%, rgba(255, 215, 0, 0.2) 0%, transparent 100%),
        radial-gradient(ellipse 1px 22px at 4% 90%, rgba(255, 215, 0, 0.15) 0%, transparent 100%),
        radial-gradient(ellipse 1px 18px at 20% 90%, rgba(255, 215, 0, 0.15) 0%, transparent 100%);
    pointer-events: none;
    z-index: 0;
}

/* Ensure content is above background */
.page-template-template-appointment .med-card-lily > * {
    position: relative;
    z-index: 1;
}

/* Golden icon wrapper for lily card */
.page-template-template-appointment .med-card-lily .med-card-icon-wrap {
    background: linear-gradient(135deg, #daa520 0%, #b8860b 100%);
    box-shadow: 0 4px 12px rgba(184, 134, 11, 0.25);
}

/* Golden button for lily card */
.page-template-template-appointment .med-card-lily .med-btn-success {
    background: linear-gradient(135deg, #daa520 0%, #b8860b 100%);
    border-color: #b8860b;
}

.page-template-template-appointment .med-card-lily .med-btn-success:hover {
    background: linear-gradient(135deg, #e6b535 0%, #c9971c 100%);
    box-shadow: 0 6px 20px rgba(184, 134, 11, 0.35);
}

/* Hover effect - subtle golden glow */
.page-template-template-appointment .med-card-lily:hover {
    box-shadow: 
        0 4px 20px rgba(218, 165, 32, 0.15),
        0 8px 30px rgba(218, 165, 32, 0.1);
    border-color: #daa520;
}

/* Hide any remaining badge elements */
.page-template-template-appointment .med-recommended-badge {
    display: none !important;
}
