/* ---------------------------------
   ГЛОБАЛЬНЫЕ НАСТРОЙКИ (v10)
   --------------------------------- */

:root {
    --color-bg: #FFFFFF;
    --color-bg-contrast: #F9F9F9;
    --color-text-primary: #1D1D1F; 
    --color-text-muted: #6E6E73;
    --color-accent: #007AFF; 
    --color-accent-darker: #0056B3;
    --color-border: #EAEAEA;
    --color-footer-bg: #1D1D1F;
    --color-whatsapp: #25D366; /* НОВЫЙ ЦВЕТ */
    
    --font-family: 'Manrope', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    
    --transition-fast: 0.3s ease-out;
    --transition-medium: 0.4s ease-out;
    --transition-slow: 0.6s cubic-bezier(0.165, 0.84, 0.44, 1); 
    
    --shadow-card: 0 4px 12px rgba(0, 0, 0, 0.04), 0 10px 30px rgba(0, 0, 0, 0.06);
    --shadow-card-hover: 0 10px 20px rgba(0, 0, 0, 0.07), 0 20px 60px rgba(0, 0, 0, 0.1);
    --shadow-nav: 0 4px 12px rgba(0, 0, 0, 0.05); 
    
    --border-radius-main: 16px;
    --border-radius-small: 10px;
    --navbar-height: 70px; 
}

/* ---------------------------------
   БАЗОВЫЕ СТИЛИ
   --------------------------------- */

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    font-family: var(--font-family);
    background-color: var(--color-bg);
    color: var(--color-text-primary);
    line-height: 1.7; 
    -webkit-font-smoothing: antialiased;
}
body.no-scroll {
    overflow: hidden;
}

.container {
    width: 100%;
    max-width: 1440px; 
    margin: 0 auto;
    padding: 0 3rem; 
}

h1, h2, h3, h4 {
    font-weight: 700; 
    line-height: 1.2;
    letter-spacing: -0.04em; 
}

h2 {
    font-size: 3.5rem; 
    margin-bottom: 1rem;
    text-align: center;
}

h3 { font-size: 1.75rem; }
h4 { font-size: 1.25rem; margin-bottom: 0.75rem; }

.section-header {
    text-align: center;
    margin-bottom: 4rem;
}

.section-subtitle {
    font-size: 1.25rem;
    font-weight: 300;
    color: var(--color-text-muted);
    max-width: 600px;
    margin: 0 auto;
}

/* ---------------------------------
   1. NAVBAR (v10 - с лого QPRINT.kz)
   --------------------------------- */
.navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: var(--navbar-height);
    display: flex;
    align-items: center;
    z-index: 1000;
    background-color: transparent;
    transition: background-color var(--transition-fast), 
                box-shadow var(--transition-fast);
}

.navbar-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.navbar-brand {
    font-size: 1.8rem;
    font-weight: 800;
    text-decoration: none;
    color: var(--color-bg); 
    transition: color var(--transition-fast);
    z-index: 101; 
}
.navbar-brand .logo-print {
    font-weight: 400;
    margin-left: -4px; 
}
.navbar-brand .logo-kz {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-accent);
    opacity: 0.8;
}

.navbar-links {
    display: flex;
    gap: 2rem;
}
.navbar-links a {
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--color-bg); 
    transition: color var(--transition-fast), border-bottom-color var(--transition-fast);
    padding-bottom: 5px;
    border-bottom: 2px solid transparent;
}
.navbar-links a:hover {
    color: var(--color-bg);
    border-bottom-color: var(--color-bg);
}

.navbar-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    z-index: 101;
    padding: 0;
}
.navbar-toggle span {
    display: block;
    width: 25px;
    height: 3px;
    background-color: var(--color-bg); 
    margin: 5px 0;
    transition: background-color var(--transition-fast), 
                transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Состояние при скролле (класс .scrolled) */
.navbar.scrolled {
    background-color: var(--color-bg);
    box-shadow: var(--shadow-nav);
}
.navbar.scrolled .navbar-brand {
    color: var(--color-text-primary);
}
.navbar.scrolled .navbar-brand .logo-kz {
    color: var(--color-text-muted);
}
.navbar.scrolled .navbar-links a {
    color: var(--color-text-muted);
}
.navbar.scrolled .navbar-links a:hover {
    color: var(--color-text-primary);
    border-bottom-color: var(--color-accent);
}
.navbar.scrolled .navbar-toggle span {
    background-color: var(--color-text-primary); 
}
.navbar.scrolled .navbar-toggle.active span {
     background-color: var(--color-text-primary);
}

/* ---------------------------------
   1. HERO-СЛАЙДЕР (v10 - Ken Burns)
   --------------------------------- */
@keyframes kenBurns {
    0% { transform: scale(1.1); }
    100% { transform: scale(1); }
}

.hero {
    height: 100vh; 
    min-height: 700px;
    position: relative;
    overflow: hidden;
    background-color: #1D1D1F; 
}
.slider-track {
    display: flex;
    height: 100%;
    transition: transform 0.8s cubic-bezier(0.65, 0, 0.35, 1);
}
.slide {
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
}
.slide::before { /* Оверлей */
    content: '';
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(rgba(0,0,0,0.4), rgba(0,0,0,0.4));
    z-index: 2;
}
.slide-background { /* ! DIV ДЛЯ ФОНА ! */
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background-size: cover;
    background-position: center;
    z-index: 1;
    opacity: 0;
    transform: scale(1.1);
    transition: opacity 1s ease-in-out;
}
.slide.is-active .slide-background {
    opacity: 1;
    animation: kenBurns 15s linear infinite alternate-reverse;
}
.slide-2.is-active .slide-background,
.slide-4.is-active .slide-background {
    animation-direction: alternate;
}

.hero-container {
    position: relative;
    z-index: 3; 
    color: var(--color-bg);
    max-width: 900px;
}
.hero h1 {
    font-size: 5.5rem; 
    font-weight: 700;
    margin-bottom: 1.5rem;
    color: var(--color-bg);
}
.hero .subtitle {
    font-size: 1.5rem;
    font-weight: 300; 
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 3rem;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}
.hero .cta-button {
    background-color: var(--color-bg);
    color: var(--color-text-primary);
}
.hero .cta-button:hover {
    background-color: #f0f0f0;
    color: #000;
    box-shadow: none;
    transform: translateY(0);
}

.slider-dots {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 12px;
    z-index: 5;
}
.dot {
    width: 12px;
    height: 12px;
    background-color: rgba(255, 255, 255, 0.4);
    border-radius: 50%;
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-fast);
}
.dot:hover { background-color: rgba(255, 255, 255, 0.7); }
.dot.active { background-color: var(--color-bg); }

/* ---------------------------------
   Кнопки CTA (Общее)
   --------------------------------- */
.cta-button {
    display: inline-block;
    font-size: 1rem;
    font-weight: 600; 
    text-decoration: none;
    color: var(--color-bg);
    background-color: var(--color-accent);
    padding: 1rem 2.5rem;
    border-radius: var(--border-radius-small);
    transition: background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
    border: none;
    cursor: pointer;
}
.cta-arrow {
    display: inline-block;
    transition: transform var(--transition-fast);
}
.cta-button:hover {
    transform: translateY(-3px);
    background-color: var(--color-accent-darker);
    box-shadow: 0 10px 20px rgba(0, 122, 255, 0.2); 
}
.cta-button:hover .cta-arrow {
    transform: translateX(4px);
}

/* ---------------------------------
   2. СЕКЦИЯ "УСЛУГИ" (v10 - "Воздушный" Редизайн)
   --------------------------------- */
.services-section {
    padding: 7rem 0;
    background-color: var(--color-bg);
}
.services-section h2 { margin-bottom: 4rem; }
.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 2.5rem;
}
.service-item {
    padding: 2.5rem;
    background-color: var(--color-bg-contrast); 
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-main);
    transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}
.service-item:hover { 
    transform: translateY(-5px);
    box-shadow: var(--shadow-card); 
}
.service-item svg {
    width: 2.5rem;
    height: 2.5rem;
    color: var(--color-accent); 
    margin-bottom: 1.5rem;
}
.service-item h4 {
    color: var(--color-text-primary); 
}
.service-item p { 
    font-size: 1rem; 
    color: var(--color-text-muted); 
}

/* ---------------------------------
   3. ГАЛЕРЕЯ КНИГ (12 книг)
   --------------------------------- */
.gallery-section {
    padding: 8rem 0; 
    background-color: var(--color-bg-contrast);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}
.book-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4rem; 
}
.book-card{background:var(--color-bg);border-radius:var(--border-radius-main);box-shadow:var(--shadow-card);overflow:hidden;transition:box-shadow var(--transition-medium)}
.book-card:hover{box-shadow:var(--shadow-card-hover)}
.book-cover{overflow:hidden;border-radius:var(--border-radius-main) var(--border-radius-main) 0 0;background-color:#f9f9f9}
.book-cover img{width:100%;height:auto;display:block;aspect-ratio:10/14;object-fit:cover;transition:transform var(--transition-slow)}
.book-card:hover .book-cover img{transform:scale(1.03)}
.book-info{padding:2rem}
.book-info .author{font-size:1rem;color:var(--color-text-muted);margin-bottom:1.25rem}
.book-info .specs{font-size:.95rem;font-weight:500;color:var(--color-text-primary);margin-bottom:1.75rem}

/* Новые стили для кнопки "Читать описание" (открывает модал) */
.open-modal-button {
    font-family: var(--font-family);
    font-size: .95rem;
    font-weight: 600;
    color: var(--color-accent);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: color var(--transition-fast);
}
.open-modal-button .arrow {
    display: inline-block;
    transition: transform var(--transition-fast);
}
.open-modal-button:hover {
    color: var(--color-accent-darker);
}
.open-modal-button:hover .arrow {
    transform: translateX(3px);
}

/* Скрываем .description-content, он теперь используется только как источник данных */
.description-content {
    display: none;
}

/* ---------------------------------
   4. НОВЫЕ ИЗДАНИЯ (Marquee v10)
   --------------------------------- */
   
/* ! ИЗМЕНЕНИЕ: число -12 заменено на -9 ! */
@keyframes scrollLeft {
    0% { transform: translateX(0); }
    100% { transform: translateX(calc( (350px + 2.5rem) * -9 )); } 
}
.new-editions {
    padding: 8rem 0;
    background-color: var(--color-bg);
}
.new-editions-scroll-container {
    overflow: hidden; 
    padding: 0;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
    mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.new-editions-track {
    display: flex;
    gap: 2.5rem;
    width: max-content; 
    /* ! ИЗМЕНЕНИЕ: 90s заменено на 70s для плавной прокрутки 9 книг ! */
    animation: scrollLeft 70s linear infinite;
}
.new-editions-track:hover {
    animation-play-state: paused;
}
.new-edition-card {
    width: 350px; 
    flex-shrink: 0; 
    background: var(--color-bg);
    border-radius: var(--border-radius-main);
    box-shadow: var(--shadow-card);
    overflow: hidden;
    transition: box-shadow var(--transition-medium);
}
.new-edition-card:hover { box-shadow: var(--shadow-card-hover); }
.new-edition-cover {
    overflow: hidden;
    border-radius: var(--border-radius-main) var(--border-radius-main) 0 0;
    background-color: #F9F9F9;
}
.new-edition-cover img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 10 / 12; 
    object-fit: cover;
    transition: transform var(--transition-slow);
}
.new-edition-card:hover .new-edition-cover img { transform: scale(1.03); }
.new-edition-info { padding: 1.5rem; }
.new-edition-info h3 { 
    font-size: 1.4rem; 
    margin-bottom: 0.25rem;
    /* Добавлено, чтобы длинные заголовки не ломали верстку */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.new-edition-info p { 
    font-size: 0.9rem; 
    color: var(--color-text-muted);
    /* Добавлено, чтобы длинные заголовки не ломали верстку */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ---------------------------------
   5. СЕКЦИЯ "ПРОЦЕСС" (v10 - с hover)
   --------------------------------- */
.process-section {
    padding: 8rem 0;
    background-color: var(--color-bg-contrast);
    border-top: 1px solid var(--color-border);
}
.process-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 3rem;
    position: relative;
}
.process-step {
    padding: 2.5rem;
    padding-top: 3rem;
    position: relative;
    border-radius: var(--border-radius-main);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.process-step:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-card);
    background-color: var(--color-bg);
}
.process-step .step-number {
    position: absolute;
    top: -1rem;
    left: 0;
    font-size: 6rem;
    font-weight: 800;
    line-height: 1;
    color: var(--color-border);
    z-index: 1;
    transition: color var(--transition-fast);
}
.process-step:hover .step-number {
    color: var(--color-accent);
    opacity: 0.2;
}
.process-step h4 {
    position: relative;
    z-index: 2;
    font-size: 1.5rem;
}
.process-step p {
    position: relative;
    z-index: 2;
    color: var(--color-text-muted);
    font-size: 1rem;
}

/* ---------------------------------
   6. О ТИПОГРАФИИ
   --------------------------------- */
.about-us {
    padding: 8rem 0;
    background-color: var(--color-bg);
}
.about-layout {
    display: grid;
    grid-template-columns: 1.2fr 1fr; 
    gap: 5rem;
    align-items: center;
}
.about-text h2{text-align:left;margin-bottom:2rem}
.about-text p{font-size:1.1rem;line-height:1.8;color:var(--color-text-muted);margin-bottom:1.5rem}
.about-text p:last-child{margin-bottom:0}
.about-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem}
.about-item{text-align:left}
.about-item svg{width:2.5rem;height:2.5rem;color:var(--color-accent);margin-bottom:1rem;stroke-width:1.5}
.about-item p{font-size:.95rem;color:var(--color-text-muted)}

/* ---------------------------------
   7. СЕКЦИЯ "ОТЗЫВЫ" (v10 - с hover)
   --------------------------------- */
.testimonials-section {
    padding: 8rem 0;
    background-color: var(--color-bg-contrast);
    border-top: 1px solid var(--color-border);
}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.5rem}
.testimonial-card{
    background:var(--color-bg);
    border:1px solid var(--color-border);
    border-radius:var(--border-radius-main);
    padding:2.5rem;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.testimonial-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-card-hover);
}
.testimonial-card blockquote{border:none;padding:0;margin:0 0 1.5rem 0;font-size:1.1rem;font-weight:400;line-height:1.7;font-style:italic;color:var(--color-text-primary)}
.testimonial-card cite{font-style:normal;font-weight:600}
.testimonial-author{display:block;color:var(--color-text-primary);font-size:1rem}
.testimonial-company{display:block;color:var(--color-text-muted);font-size:.9rem;font-weight:400}

/* ---------------------------------
   8. ! НОВАЯ СЕКЦИЯ "WHATSAPP CTA" !
   --------------------------------- */
.cta-whatsapp-section {
    padding: 6rem 0; /* ! ОТСТУП УМЕНЬШЕН ! */
    background-color: var(--color-footer-bg); /* ! ТЕМНЫЙ ФОН ! */
    border-top: 1px solid var(--color-border);
}
.cta-whatsapp-content {
    max-width: 700px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    color: var(--color-bg); /* ! ВЕСЬ ТЕКСТ БЕЛЫЙ ! */
}
.whatsapp-icon {
    width: 60px;
    height: 60px;
    color: var(--color-whatsapp);
    margin-bottom: 1.5rem;
}
.cta-whatsapp-content h2 {
    margin-bottom: 1rem;
}
.cta-whatsapp-content .section-subtitle {
    margin-bottom: 2.5rem;
    color: rgba(255, 255, 255, 0.8); /* Чуть приглушенный белый */
}
/* Стилизация кнопки WhatsApp */
.cta-whatsapp-content .whatsapp-button {
    font-size: 1.15rem;
    padding: 1.25rem 3rem;
    background-color: var(--color-whatsapp);
    color: var(--color-bg);
}
.cta-whatsapp-content .whatsapp-button:hover {
    background-color: #1DAE53; /* Темнее WhatsApp */
    box-shadow: 0 10px 20px rgba(37, 211, 102, 0.2);
    transform: translateY(-3px);
}

/* ---------------------------------
   9. КОНТАКТЫ И ФУТЕР (v10)
   --------------------------------- */
.footer-contact {
    padding-top: 8rem;
    background-color: var(--color-footer-bg);
    color: var(--color-bg);
    /* border-top убран, т.к. секция CTA уже темная */
}
.footer-layout {
    display: grid;
    grid-template-columns: 1fr 1.2fr; 
    gap: 4rem;
    padding-bottom: 7rem;
}
.footer-info h4 { font-size: 2.5rem; color: var(--color-bg); margin-bottom: 1rem; }
.footer-info > p {
    font-size: 1.1rem;
    font-weight: 300;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 2rem;
}
.footer-contacts p {
    font-size: 1.1rem;
    font-weight: 300;
    margin-bottom: 1rem;
    line-height: 1.6;
}
.footer-contacts p strong {
    font-weight: 600;
    color: rgba(255, 255, 255, 0.9);
}
.footer-phone-list {
    list-style: none;
    padding-left: 0;
    margin: 0.5rem 0 1rem 0;
}
.footer-phone-list li {
    margin-bottom: 0.25rem;
}
.footer-contacts a {
    color: var(--color-bg);
    text-decoration: none;
    transition: var(--transition-fast);
    font-weight: 400;
}
.footer-contacts a:hover { color: var(--color-accent); }
.footer-info .main-cta {
    background-color: var(--color-bg);
    color: var(--color-text-primary);
    padding: 1.25rem 3rem; 
    font-size: 1.1rem;
    margin-top: 1.5rem;
}
.footer-info .main-cta:hover {
    background-color: #F0F0F0;
    color: #000;
    box-shadow: none; 
    transform: translateY(0);
}
.footer-map {
    width: 100%;
    height: 100%;
    min-height: 400px;
    border-radius: var(--border-radius-main);
    overflow: hidden;
}
.footer-map iframe { width: 100%; height: 100%; border: 0; }
.footer-bottom {
    padding: 2.5rem 0;
    border-top: 1px solid #3E4C59; 
    text-align: center;
}
.footer-bottom p { font-size: 0.95rem; color: #9CA3AF; }

/* ---------------------------------
   АНИМАЦИИ
   --------------------------------- */
   
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}
.slide .animate-on-load { opacity: 0; }
.slide.is-active .animate-on-load {
    animation: fadeInUp 0.9s 0.4s both cubic-bezier(0.25, 0.8, 0.25, 1);
}
.slide.is-active .animate-on-load:nth-child(2) { animation-delay: 0.6s; }
.slide.is-active .animate-on-load:nth-child(3) { animation-delay: 0.8s; }
.fade-in {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.7s var(--transition-slow), transform 0.7s var(--transition-slow);
}
.fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ---------------------------------
   10. МОДАЛЬНОЕ ОКНО КНИГИ (НОВОЕ)
   --------------------------------- */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    
    /* Скрыто по умолчанию */
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-fast), visibility var(--transition-fast);
}
.modal.is-visible {
    opacity: 1;
    visibility: visible;
}
.modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(29, 29, 31, 0.85); /* Темный фон, как в моб. меню */
    backdrop-filter: blur(8px);
    cursor: pointer;
}
.modal-content {
    position: relative;
    z-index: 2001;
    background-color: var(--color-bg);
    border-radius: var(--border-radius-main);
    padding: 2.5rem;
    width: 100%;
    max-width: 900px; /* Ширина окна */
    max-height: 90vh; /* Макс. высота */
    overflow-y: auto; /* Прокрутка, если не влезает */
    box-shadow: var(--shadow-card-hover);
    
    /* Анимация появления */
    transform: scale(0.95);
    transition: transform var(--transition-fast);
}
.modal.is-visible .modal-content {
    transform: scale(1);
}
.modal-close {
    position: absolute;
    top: 1rem;
    right: 1.25rem;
    background: none;
    border: none;
    font-size: 2.5rem;
    font-weight: 300;
    line-height: 1;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0;
    transition: color var(--transition-fast);
}
.modal-close:hover {
    color: var(--color-text-primary);
}
.modal-layout {
    display: grid;
    grid-template-columns: 1fr 2fr; /* 1 часть для картинки, 2 для текста */
    gap: 2.5rem;
    align-items: flex-start;
}
.modal-image img {
    width: 100%;
    height: auto;
    border-radius: var(--border-radius-small);
    border: 1px solid var(--color-border);
}
.modal-text h3 {
    font-size: 2.2rem;
    letter-spacing: -0.04em;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}
.modal-text .modal-author {
    font-size: 1.1rem;
    color: var(--color-text-muted);
    margin-bottom: 1rem;
}
.modal-text .modal-specs {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: 1.5rem;
}
.modal-text .modal-description {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-text-muted);
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}
.modal-text .modal-description p {
    margin-bottom: 1rem;
}
.modal-text .modal-description p:last-child {
    margin-bottom: 0;
}


/* ---------------------------------
   МОБИЛЬНАЯ АДАПТАЦИЯ (v10)
   --------------------------------- */

@media (max-width: 992px) {
    .container { padding: 0 2rem; }
    .book-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 2.5rem;
    }
    h2 { font-size: 2.8rem; }
    .about-layout { grid-template-columns: 1fr; gap: 3rem; }
    .about-text h2 { text-align: center; }
    .footer-layout { grid-template-columns: 1fr; gap: 3rem; padding-bottom: 4rem; }
    .new-editions-track { padding-left: 2rem; }
    .navbar-links { gap: 1rem; } 
    .form-grid { grid-template-columns: 1fr; gap: 0; }
}

@media (max-width: 768px) {
    html { font-size: 15px; }
    .container { padding: 0 1.5rem; }
    h2 { font-size: 2.2rem; }
    .section-header { margin-bottom: 2.5rem; }
    .section-subtitle { font-size: 1.1rem; }

    /* Мобильное меню v10 */
    .navbar-toggle { display: block; }
    .navbar-toggle.active span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
    .navbar-toggle.active span:nth-child(2) { opacity: 0; }
    .navbar-toggle.active span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
    .navbar-toggle.active span { background-color: var(--color-bg); }
    .navbar.scrolled .navbar-toggle.active span { background-color: var(--color-text-primary); }
    .navbar-links {
        position: fixed;
        top: 0; left: 0; width: 100%; height: 100vh;
        background-color: rgba(29, 29, 31, 0.98); 
        backdrop-filter: blur(10px);
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 2.5rem;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-20px);
        transition: opacity var(--transition-fast), visibility var(--transition-fast), transform var(--transition-fast);
    }
    .navbar-links.active { opacity: 1; visibility: visible; transform: translateY(0); }
    .navbar-links a { color: var(--color-bg); font-size: 1.5rem; font-weight: 700; }
    .navbar-links a:hover { color: var(--color-accent); border-bottom-color: transparent; }
    .navbar.scrolled .navbar-links a { color: var(--color-bg); }

    /* Hero */
    .hero { min-height: 90vh; }
    .hero h1 { font-size: 2.5rem; }
    .hero .subtitle { font-size: 1.1rem; }
    
    /* Секции */
    .services-section, .gallery-section, .new-editions, .about-us, .testimonials-section, .process-section, .cta-whatsapp-section {
        padding: 4.5rem 0;
    }
    .book-gallery-grid { 
        grid-template-columns: 1fr;
        gap: 2rem; 
    }
    .book-info { padding: 1.5rem; }
    
    /* Marquee */
    .new-editions-track { padding-left: 1.5rem; }
    .new-edition-card { width: 280px; }
    
    /* ! ИЗМЕНЕНИЕ: число -12 заменено на -9 ! */
    @keyframes scrollLeft {
        100% { transform: translateX(calc( (280px + 2.5rem) * -9 )); }
    }
    
    .about-grid { grid-template-columns: 1fr; }
    .about-item { text-align: center; }
    .about-item svg { margin-left: auto; margin-right: auto; }
    .process-step { padding-left: 1rem; padding-right: 1rem; }
    .footer-layout { text-align: center; }
    .footer-info .main-cta { width: 100%; text-align: center; }
    
    /* Адаптация модального окна */
    @media (max-width: 768px) {
        .modal-content {
            padding: 2rem 1.5rem;
            padding-top: 3.5rem; /* Больше места для кнопки "Х" */
            max-height: 85vh;
        }
        .modal-layout {
            grid-template-columns: 1fr; /* Картинка и текст друг под другом */
            gap: 1.5rem;
        }
        .modal-image {
            max-width: 250px; /* Картинка не будет слишком большой */
            margin: 0 auto;
        }
        .modal-text h3 {
            font-size: 1.8rem;
        }
        .modal-close {
            top: 0.75rem;
            right: 0.75rem;
        }
    }
}