/* --- Base ------------------------------------------------------- */

html, body {
    overflow-x: hidden;  /* запобігаємо горизонтальному скролу від декоративного SVG */
    max-width: 100vw;
}

html { scroll-behavior: smooth; }

body {
    font-feature-settings: "ss01", "cv02", "cv11";
    -webkit-text-size-adjust: 100%;
    text-rendering: optimizeLegibility;
}

/* iOS safe-area + sticky CTA на мобільному */
:root {
    --safe-bottom: env(safe-area-inset-bottom, 0px);
    --safe-top: env(safe-area-inset-top, 0px);
}

/* Плавний type scale через clamp — без різких ламань на breakpoints */
.t-display {
    font-size: clamp(1.4rem, 5vw, 3.5rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
    word-wrap: break-word;
    overflow-wrap: break-word;
}
.t-h2 {
    font-size: clamp(1.1rem, 3vw + 0.3rem, 1.75rem);
    line-height: 1.2;
    letter-spacing: -0.01em;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

/* Кнопки опцій — на mobile менше padding, щоб довгі тексти вмістились */
.option-card {
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: normal;
}
.t-body {
    font-size: clamp(1rem, 1vw + 0.7rem, 1.125rem);
    line-height: 1.55;
}

/* --- Анімації --------------------------------------------------- */

.slide-enter {
    animation: slideIn 360ms cubic-bezier(0.2, 0, 0.2, 1) both;
}
@keyframes slideIn {
    from { opacity: 0; transform: translateX(16px); }
    to   { opacity: 1; transform: translateX(0); }
}

.fade-in {
    animation: fadeIn 460ms cubic-bezier(0.2, 0, 0.2, 1) both;
}
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.feedback-in {
    animation: feedbackIn 540ms cubic-bezier(0.2, 0, 0.2, 1) both;
}
@keyframes feedbackIn {
    0%   { opacity: 0; transform: translateY(20px) scale(0.97); }
    60%  { opacity: 1; }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}

.progress-bar {
    transition: width 420ms cubic-bezier(0.2, 0, 0.2, 1);
}

/* --- Touch targets ----------------------------------------------- */

button, .btn, input, textarea {
    font-family: inherit;
    -webkit-tap-highlight-color: transparent;
}

button:focus-visible, input:focus-visible, textarea:focus-visible {
    outline: 2px solid #E07A5F;
    outline-offset: 2px;
}

/* На дотик — щоб не було активної підсвітки після тапа */
@media (hover: none) {
    button:hover {
        background-color: inherit;
    }
}

/* Мінімальний touch-target 48px */
.tap-target {
    min-height: 56px;
}

/* Sticky CTA bar для мобільного — щоб «Далі» завжди було в полі зору */
.sticky-cta {
    position: sticky;
    bottom: 0;
    margin-left: -1.5rem;
    margin-right: -1.5rem;
    padding: 1rem 1.5rem calc(1rem + var(--safe-bottom));
    background: linear-gradient(to top, #F5F1EA 70%, rgba(245, 241, 234, 0));
    z-index: 10;
}
@media (min-width: 768px) {
    .sticky-cta {
        position: static;
        margin: 0;
        padding: 1.5rem 0 0;
        background: none;
    }
}

/* --- Прогрес-бар з safe-area ------------------------------------ */

.progress-track {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(26, 26, 26, 0.06);
    z-index: 50;
    padding-top: var(--safe-top);
    box-sizing: content-box;
}

/* --- Нормалізація форм ------------------------------------------- */

textarea {
    -webkit-appearance: none;
    appearance: none;
}

input[type="email"], input[type="text"] {
    -webkit-appearance: none;
    appearance: none;
}

/* На iOS формуляри 16px+ щоб не зумити */
input, textarea {
    font-size: 16px;
}
@media (min-width: 768px) {
    input, textarea {
        font-size: inherit;
    }
}
