/* ===== Визначення змінних кольорів ===== */
:root {
    --color1: #101713; /* deep-dark */
    --color2: #0c4843; /* deep-teal */
    --color3: #a6a762; /* olive */
    --color4: #d8d1a6; /* pale-olive */
    --color5: #ffffee; /* ivory */
}

/* ===== Базові стилі ===== */
body {
    background-color: var(--color5);
    color: var(--color1);
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    overflow-x: hidden; /* Запобігання горизонтальній прокрутці */
}

/* ===== Стилі посилань навігації ===== */
.nav-link {
    position: relative;
    color: var(--color1);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 0;
    height: 2px;
    background-color: var(--color2);
    transition: width 0.3s ease;
}

.nav-link:hover {
    color: var(--color2);
}

.nav-link:hover::after {
    width: 100%;
}

/* ===== Стилі кнопок ===== */
.btn-primary {
    display: inline-block;
    background-color: var(--color3);
    color: var(--color1);
    padding: 12px 32px;
    font-weight: bold;
    text-decoration: none;
    border: 2px solid var(--color3);
    transition: all 0.3s ease;
}

.btn-primary:hover {
    background-color: transparent;
    color: var(--color3);
}

/* Спеціально для .hero */
section:first-of-type .btn-primary:hover {
    background-color: var(--color5);
    color: var(--color1);
    border-color: var(--color5);
}

.btn-secondary {
    display: inline-block;
    background-color: transparent;
    color: var(--color2);
    padding: 12px 32px;
    font-weight: bold;
    text-decoration: none;
    border: 2px solid var(--color2);
    transition: all 0.3s ease;
}

.btn-secondary:hover {
    background-color: var(--color2);
    color: var(--color5);
}

/* ===== Ефект паралаксу ===== */
.parallax-bg {
    /* JS буде керувати transform: translateY() */
    will-change: transform;
    min-height: 120%; /* Запас для прокрутки */
    position: absolute;
}

/* ===== Анімації появи при прокрутці (Scroll Reveal) ===== */
.reveal {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
    will-change: opacity, transform, visibility;
}

.reveal.fade-in {
    transform: translateY(20px);
}

.reveal.slide-left {
    transform: translateX(50px);
}

.reveal.slide-right {
    transform: translateX(-50px);
}

.reveal.slide-up {
    transform: translateY(50px);
}

.reveal.zoom-in {
    transform: scale(0.9);
}

.reveal.is-visible {
    opacity: 1;
    transform: translate(0, 0) scale(1);
    visibility: visible;
}

/* ===== Складні макети та декорації ===== */

/* Sektion 3: Обтікання текстом */
.shape-outside-image {
    /* Створює круглу форму для обтікання текстом */
    shape-outside: circle(45%);
    clip-path: circle(45%);
    width: 33.3333%; /* Tailwind w-1/3 */
    min-width: 250px;
}

@media (max-width: 768px) {
    /* На мобільних вимикаємо обтікання */
    .shape-outside-image {
        shape-outside: none;
        clip-path: none;
        float: none;
        width: 80%;
        margin: 1rem auto;
    }
}

/* Sektion 9: FAQ */
.faq-question {
    display: block;
    padding: 12px 16px;
    font-size: 1.125rem; /* text-lg */
    color: var(--color1);
    font-weight: 500;
    border-left: 4px solid transparent;
    transition: all 0.3s ease;
}

.faq-question:hover {
    background-color: var(--color4);
    border-left-color: var(--color3);
}

.faq-question.active {
    font-weight: 700;
    color: var(--color2);
    border-left-color: var(--color2);
    background-color: var(--color5);
}

#faq-answer-content h3 {
    font-size: 1.5rem; /* text-2xl */
    font-weight: 700;
    color: var(--color2);
    margin-bottom: 1rem;
}

#faq-answer-content p {
    font-size: 1.125rem; /* text-lg */
    color: var(--color1);
    line-height: 1.7;
}


/* Sektion 10: CTA Clip Path */
/* Ця секція не використовує clip-path, оскільки це порушило б фон,
   натомість ми використовуємо нашарування для ефекту */

/* Footer */
.footer-link {
    color: var(--color4);
    opacity: 0.8;
    transition: all 0.3s ease;
}
.footer-link:hover {
    color: var(--color5);
    opacity: 1;
    padding-left: 4px;
}
/* ===== Sektion 3 (About): Clip-Path ===== */
.about-clip-image {
    /* Створює унікальну, асиметричну "галькову" форму */
    clip-path: polygon(0% 15%, 80% 0%, 100% 85%, 20% 100%);
    transition: clip-path 0.4s ease-out;
}

/* Ефект при наведенні (опціонально, але додає динаміки) */
.about-clip-image:hover {
    clip-path: polygon(0% 0%, 100% 15%, 80% 100%, 0% 85%);
}

/* Адаптація clip-path для мобільних пристроїв, щоб уникнути
   надто сильного обрізання на маленьких екранах */
@media (max-width: 768px) {
    .about-clip-image {
        clip-path: polygon(0% 10%, 90% 0%, 100% 90%, 10% 100%);
    }
}
/* ===== Sektion 1 (Service): Hero ===== */
.service-hero-deco {
    /* Створює скошений декоративний елемент */
    clip-path: polygon(25% 0, 100% 0, 100% 100%, 0% 100%);
    z-index: 1;
}

/* На мобільних пристроях змінюємо форму */
@media (max-width: 768px) {
    .service-hero-deco {
        clip-path: polygon(0 0, 100% 0, 100% 30%, 0 50%);
        width: 100%;
        height: 50%;
        opacity: 0.1;
    }
}

/* ===== Sektion 2 (Service): Process Image ===== */
.service-process-image-wrapper {
    position: relative;
    /* Використовуємо clip-path для унікальної форми зображення */
    clip-path: polygon(0 0, 100% 15%, 100% 100%, 0 85%);
    transition: clip-path 0.4s ease-out;
}

.service-process-image-wrapper:hover {
    clip-path: polygon(0 15%, 100% 0, 100% 85%, 0 100%);
}
/* ===== Стилі для полів вводу (Contact Form) ===== */
.contact-input::placeholder {
    color: var(--color1);
    opacity: 0.5;
}

.contact-input:focus {
    background-color: var(--color5); /* ivory */
    border-color: var(--color3); /* olive */
}

/* ===== Стилі для нотифікації (Contact Form) ===== */
#success-notification {
    display: block;
    opacity: 0;
    transform: translateY(-50px);
    visibility: hidden;
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

#success-notification.show {
    opacity: 1;
    transform: translateY(0);
    visibility: visible;
}