/* ============================================
   ОСНОВНОЙ КОНТЕЙНЕР КНОПКИ "НАВЕРХ"
   ============================================ */
.to-top {
    position: fixed;           /* фиксируем кнопку в углу экрана */
    bottom: 25px;
    right: 25px;

    width: 54px;
    height: 54px;

    display: flex;             /* выравнивание стрелки и SVG-кольца */
    align-items: center;
    justify-content: center;

    background: #000;          /* фон кнопки */
    color: #fff;               /* цвет стрелки */
    border-radius: 50%;        /* делаем кнопку круглой */
    border: none;
    cursor: pointer;

    opacity: 0;                /* скрыта по умолчанию */
    visibility: hidden;
    z-index: 1000;

    /* стартовая позиция — чуть ниже и уменьшена */
    transform: translateY(40px) scale(0.82);

    /* плавные переходы для iOS-like эффекта */
    transition:
        opacity 0.3s ease,
        visibility 0.3s ease,
        transform 0.4s cubic-bezier(.22,1.26,.57,1.01);
}

/* ============================================
   SVG ПРОГРЕСС-КОЛЬЦО ВОКРУГ КНОПКИ
   ============================================ */
.progress-ring {
    position: absolute;    /* кладём кольцо поверх кнопки */
    top: 0;
    left: 0;
    transform: rotate(-90deg); /* поворачиваем, чтобы прогресс начинался сверху */
}

/* Фоновый круг — всегда виден */
.progress-ring__bg {
    stroke: rgba(255, 255, 255, 0.15); /* светлый полупрозрачный контур */
    stroke-width: 4;
    fill: none;                         /* без заливки */
}

/* Круг прогресса — рисуется динамически JS */
.progress-ring__progress {
    stroke: #ffffff;       /* цвет линии прогресса */
    stroke-width: 4;
    fill: none;
    stroke-linecap: round; /* закругленный конец линии — красивее */
    transition: stroke-dashoffset 0.2s linear; /* плавный прогресс */
}

/* Стрелка наверх — поверх SVG-кольца */
.to-top .arrow {
    position: relative;
    z-index: 2;
    pointer-events: none; /* клики не идут по стрелке, а по всей кнопке */
}

/* ============================================
   ПОЯВЛЕНИЕ / ИСЧЕЗНОВЕНИЕ КНОПКИ
   ============================================ */

/* Кнопка показана */
.to-top.show-ios {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1); /* обычное положение */
}

/* Кнопка скрыта */
.to-top.hide-ios {
    opacity: 0;
    visibility: hidden;
    transform: translateY(40px) scale(0.75); /* уезжает вниз iOS-style */
}

/* ============================================
   ХАПТИК-ЭФФЕКТ ПРИ НАЖАТИИ
   ============================================ */
.to-top.tap-ios {
    transform: scale(0.92); /* кнопка как бы "вжимается" */
    transition: transform 0.15s cubic-bezier(.17,.89,.32,1.27);
}

/* ============================================
   HOVER-ЭФФЕКТ (как у иконок macOS/iOS)
   ============================================ */
.to-top:hover {
    transform: translateY(0) scale(1.06); /* небольшая инерция */
    transition: transform 0.25s cubic-bezier(.22,1.5,.36,1);
}
