/* fonts.css - Подключение и настройка шрифтов для сайта "В гостях у отца Владимира" */

/* Подключение шрифтов через Google Fonts API */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500&display=swap');

/* Подключение локальных шрифтов (резервный вариант) */
@font-face {
    font-family: 'Playfair Display';
    font-style: normal;
    font-weight: 400;
    src: local('Playfair Display Regular'), local('PlayfairDisplay-Regular'),
         url('../fonts/playfair-display/playfair-display-regular.woff2') format('woff2'),
         url('../fonts/playfair-display/playfair-display-regular.woff') format('woff');
    font-display: swap;
}

@font-face {
    font-family: 'Playfair Display';
    font-style: normal;
    font-weight: 600;
    src: local('Playfair Display SemiBold'), local('PlayfairDisplay-SemiBold'),
         url('../fonts/playfair-display/playfair-display-600.woff2') format('woff2'),
         url('../fonts/playfair-display/playfair-display-600.woff') format('woff');
    font-display: swap;
}

@font-face {
    font-family: 'Playfair Display';
    font-style: normal;
    font-weight: 700;
    src: local('Playfair Display Bold'), local('PlayfairDisplay-Bold'),
         url('../fonts/playfair-display/playfair-display-700.woff2') format('woff2'),
         url('../fonts/playfair-display/playfair-display-700.woff') format('woff');
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 300;
    src: local('Open Sans Light'), local('OpenSans-Light'),
         url('../fonts/open-sans/open-sans-300.woff2') format('woff2'),
         url('../fonts/open-sans/open-sans-300.woff') format('woff');
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 400;
    src: local('Open Sans Regular'), local('OpenSans-Regular'),
         url('../fonts/open-sans/open-sans-regular.woff2') format('woff2'),
         url('../fonts/open-sans/open-sans-regular.woff') format('woff');
    font-display: swap;
}

@font-face {
    font-family: 'Open Sans';
    font-style: normal;
    font-weight: 600;
    src: local('Open Sans SemiBold'), local('OpenSans-SemiBold'),
         url('../fonts/open-sans/open-sans-600.woff2') format('woff2'),
         url('../fonts/open-sans/open-sans-600.woff') format('woff');
    font-display: swap;
}

/* Определение переменных CSS для шрифтов */
:root {
    /* Семейства шрифтов */
    --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
    --font-body: 'Open Sans', Arial, Helvetica, sans-serif;
    --font-accent: 'Playfair Display', Georgia, serif;
    
    /* Размеры шрифтов для десктопа */
    --font-size-xs: 0.75rem;    /* 12px */
    --font-size-sm: 0.875rem;   /* 14px */
    --font-size-base: 1rem;     /* 16px */
    --font-size-lg: 1.125rem;   /* 18px */
    --font-size-xl: 1.25rem;    /* 20px */
    --font-size-2xl: 1.5rem;    /* 24px */
    --font-size-3xl: 1.875rem;  /* 30px */
    --font-size-4xl: 2.25rem;   /* 36px */
    --font-size-5xl: 3rem;      /* 48px */
    
    /* Высота строки */
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;
    
    /* Межбуквенное расстояние */
    --letter-spacing-tight: -0.025em;
    --letter-spacing-normal: 0;
    --letter-spacing-wide: 0.025em;
    --letter-spacing-wider: 0.05em;
}

/* Базовые настройки типографики */
body {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    letter-spacing: var(--letter-spacing-normal);
    font-weight: 400;
    color: var(--black);
}

/* Заголовки */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 600;
    line-height: var(--line-height-tight);
    margin-bottom: 0.75em;
    color: var(--black);
}

h1 {
    font-size: var(--font-size-4xl);
    letter-spacing: var(--letter-spacing-tight);
    font-weight: 700;
}

h2 {
    font-size: var(--font-size-3xl);
    letter-spacing: var(--letter-spacing-tight);
}

h3 {
    font-size: var(--font-size-2xl);
}

h4 {
    font-size: var(--font-size-xl);
}

h5 {
    font-size: var(--font-size-lg);
}

h6 {
    font-size: var(--font-size-base);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
}

/* Абзацы */
p {
    margin-bottom: 1.25em;
    line-height: var(--line-height-relaxed);
}

.lead {
    font-size: var(--font-size-lg);
    font-weight: 300;
    line-height: var(--line-height-relaxed);
}

/* Ссылки */
a {
    color: var(--accent);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover {
    color: var(--accent-light);
    text-decoration: underline;
}

/* Списки */
ul, ol {
    margin-bottom: 1.25em;
    padding-left: 1.5em;
}

li {
    margin-bottom: 0.5em;
    line-height: var(--line-height-relaxed);
}

/* Цитаты */
blockquote {
    font-family: var(--font-heading);
    font-size: var(--font-size-lg);
    font-style: italic;
    border-left: 4px solid var(--accent-light);
    padding-left: 1.5rem;
    margin: 2rem 0;
    color: var(--gray-dark);
    line-height: var(--line-height-relaxed);
}

cite {
    display: block;
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    font-style: normal;
    margin-top: 0.5rem;
    color: var(--gray-dark);
}

/* Специальные классы для текста */
.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

.text-left {
    text-align: left;
}

.text-uppercase {
    text-transform: uppercase;
}

.text-lowercase {
    text-transform: lowercase;
}

.text-capitalize {
    text-transform: capitalize;
}

.text-bold {
    font-weight: 700;
}

.text-semibold {
    font-weight: 600;
}

.text-light {
    font-weight: 300;
}

.text-italic {
    font-style: italic;
}

.text-small {
    font-size: var(--font-size-sm);
}

.text-large {
    font-size: var(--font-size-lg);
}

.text-xlarge {
    font-size: var(--font-size-xl);
}

/* Адаптивная типографика для мобильных устройств */
@media (max-width: 768px) {
    :root {
        --font-size-xs: 0.7rem;     /* 11.2px */
        --font-size-sm: 0.8rem;     /* 12.8px */
        --font-size-base: 0.9rem;   /* 14.4px */
        --font-size-lg: 1rem;       /* 16px */
        --font-size-xl: 1.125rem;   /* 18px */
        --font-size-2xl: 1.25rem;   /* 20px */
        --font-size-3xl: 1.5rem;    /* 24px */
        --font-size-4xl: 1.75rem;   /* 28px */
        --font-size-5xl: 2rem;      /* 32px */
    }
    
    h1 {
        font-size: var(--font-size-3xl);
    }
    
    h2 {
        font-size: var(--font-size-2xl);
    }
    
    h3 {
        font-size: var(--font-size-xl);
    }
    
    blockquote {
        font-size: var(--font-size-base);
        padding-left: 1rem;
        margin: 1.5rem 0;
    }
}

/* Дополнительные стили для специальных элементов */
.script-font {
    font-family: 'Playfair Display', cursive;
    font-style: italic;
}

.article-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-4xl);
    font-weight: 700;
    line-height: var(--line-height-tight);
    margin-bottom: 0.5em;
}

.section-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-3xl);
    font-weight: 600;
    position: relative;
    padding-bottom: 0.5em;
    margin-bottom: 1em;
}

.section-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 60px;
    height: 3px;
    background-color: var(--accent);
}

.meta-text {
    font-size: var(--font-size-sm);
    color: var(--gray-dark);
    font-style: italic;
}

/* Стили для навигации */
nav ul {
    list-style: none;
    padding-left: 0;
}

nav a {
    font-family: var(--font-body);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    font-size: var(--font-size-sm);
}

/* Стили для кнопок */
button, .btn {
    font-family: var(--font-body);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    font-size: var(--font-size-sm);
}

/* Стили для форм */
label {
    font-family: var(--font-body);
    font-weight: 600;
    font-size: var(--font-size-sm);
    margin-bottom: 0.5rem;
    display: block;
}

input, textarea, select {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
}

/* Стили для футера */
footer {
    font-size: var(--font-size-sm);
}

footer a {
    font-weight: 600;
}

/* Специальные стили для религиозного контента */
.bible-verse {
    font-family: var(--font-heading);
    font-style: italic;
    padding: 1.5rem;
    background-color: var(--gray-light);
    border-radius: 8px;
    margin: 1.5rem 0;
    position: relative;
}

.bible-verse::before {
    content: '"';
    font-family: var(--font-heading);
    font-size: var(--font-size-5xl);
    position: absolute;
    top: 0.5rem;
    left: 0.5rem;
    color: var(--accent-light);
    opacity: 0.3;
}

.prayer-text {
    font-family: var(--font-heading);
    line-height: var(--line-height-relaxed);
    padding: 1rem;
    background-color: var(--gray-light);
    border-left: 3px solid var(--accent);
}

/* Анимации для текста */
.fade-in {
    animation: fadeIn 0.8s ease-in;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Оптимизация рендеринга шрифтов */
* {
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Поддержка высококонтрастного режима */
@media (prefers-contrast: high) {
    body {
        font-weight: 600;
    }
    
    a {
        text-decoration: underline;
    }
}

/* Поддержка reduced motion */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}