.ios-webcam-player {
    --player-control-size: 42px;
    --player-control-slot: 44px;
    --player-control-icon: 24px;
    --player-live-font: 11px;
    container-type: inline-size;
    overflow: hidden;
    background: #000;
    color: #fff;
    touch-action: manipulation;
    -webkit-user-select: none;
    user-select: none;
}

.video > .ios-webcam-player {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
}

.ios-webcam-player__poster,
.ios-webcam-player__video {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: #000;
}

.ios-webcam-player__poster {
    position: absolute;
    z-index: 0;
    inset: 0;
}

.ios-webcam-player__video {
    position: relative;
    z-index: 1;
    opacity: 0;
}

.ios-webcam-player.has-video .ios-webcam-player__video {
    opacity: 1;
}

.ios-webcam-player__controls {
    position: absolute;
    z-index: 3;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    min-height: calc(var(--player-control-size) + env(safe-area-inset-bottom));
    height: calc(var(--player-control-size) + env(safe-area-inset-bottom));
    padding: 0 max(8px, env(safe-area-inset-right)) env(safe-area-inset-bottom) max(8px, env(safe-area-inset-left));
    background: linear-gradient(to top, rgba(0, 0, 0, 0.82), rgba(0, 0, 0, 0));
    opacity: 1;
    transition: opacity 180ms ease;
}

.ios-webcam-player.is-controls-hidden .ios-webcam-player__controls {
    pointer-events: none;
    opacity: 0;
}

.ios-webcam-player.is-controls-hidden:focus-within .ios-webcam-player__controls {
    pointer-events: auto;
    opacity: 1;
}

.ios-webcam-player__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 var(--player-control-slot);
    width: var(--player-control-slot);
    height: var(--player-control-size);
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: transparent;
    color: #fff;
    -webkit-appearance: none;
    appearance: none;
}

.ios-webcam-player__button[hidden] {
    display: none;
}

.ios-webcam-player__button:active {
    background: rgba(255, 255, 255, 0.2);
}

.ios-webcam-player__button--pip[aria-pressed="true"],
.ios-webcam-player__button--airplay[aria-pressed="true"] {
    background: rgba(54, 150, 233, 0.9);
}

.ios-webcam-player__button:focus-visible {
    outline: 2px solid #fff;
    outline-offset: -2px;
}

.ios-webcam-player__button--play {
    position: absolute;
    z-index: 4;
    top: 50%;
    left: 50%;
    width: 54px;
    width: clamp(54px, 10cqi, 82px);
    height: 54px;
    height: clamp(54px, 10cqi, 82px);
    padding: 0;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.58);
    transform: translate(-50%, -50%);
    transition: opacity 180ms ease, background-color 180ms ease;
}

.ios-webcam-player .ios-webcam-player__button--play svg {
    width: 28px;
    width: clamp(28px, 5cqi, 42px);
    height: 28px;
    height: clamp(28px, 5cqi, 42px);
}

.ios-webcam-player.is-playing.is-controls-hidden .ios-webcam-player__button--play,
.ios-webcam-player.is-playing.is-controls-hidden .ios-webcam-player__button--sound {
    pointer-events: none;
    opacity: 0;
}

.ios-webcam-player__button--sound {
    position: absolute;
    z-index: 4;
    top: 8px;
    top: max(clamp(8px, 1.5cqi, 14px), env(safe-area-inset-top));
    right: 8px;
    right: max(clamp(8px, 1.5cqi, 14px), env(safe-area-inset-right));
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.48);
    transition: opacity 180ms ease, background-color 180ms ease;
}

.ios-webcam-player__button svg {
    display: block;
    width: var(--player-control-icon);
    height: var(--player-control-icon);
    fill: currentColor;
}

.ios-webcam-player__pause-icon,
.ios-webcam-player__sound-muted,
.ios-webcam-player.is-muted .ios-webcam-player__sound-waves,
.ios-webcam-player__fullscreen-exit,
.ios-webcam-player.is-fullscreen .ios-webcam-player__fullscreen-enter {
    display: none;
}

.ios-webcam-player.is-playing .ios-webcam-player__pause-icon,
.ios-webcam-player.is-muted .ios-webcam-player__sound-muted,
.ios-webcam-player.is-fullscreen .ios-webcam-player__fullscreen-exit {
    display: block;
}

.ios-webcam-player.is-playing .ios-webcam-player__play-icon {
    display: none;
}

.ios-webcam-player__live {
    position: absolute;
    z-index: 3;
    top: 8px;
    top: max(clamp(8px, 1.5cqi, 14px), env(safe-area-inset-top));
    left: 8px;
    left: max(clamp(8px, 1.5cqi, 14px), env(safe-area-inset-left));
    display: inline-flex;
    align-items: center;
    gap: 7px;
    gap: clamp(7px, 1cqi, 9px);
    font-size: var(--player-live-font);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.08em;
    pointer-events: none;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.75);
}

.ios-webcam-player__live > span {
    width: 7px;
    width: clamp(7px, 1.1cqi, 9px);
    height: 7px;
    height: clamp(7px, 1.1cqi, 9px);
    border-radius: 50%;
    background: #f44336;
    box-shadow: 0 0 0 3px rgba(244, 67, 54, 0.22);
}

.ios-webcam-player__controls-end {
    display: flex;
    align-items: center;
    height: var(--player-control-size);
    margin-left: auto;
}

.ios-webcam-player__controls-end .ios-webcam-player__button {
    align-self: stretch;
    height: 100%;
    min-height: 0;
    line-height: 0;
}

.ios-webcam-player__controls-end .ios-webcam-player__button svg {
    flex: 0 0 var(--player-control-icon);
}

.ios-webcam-player__button--pip svg {
    transform: translateY(2px);
}

.ios-webcam-player__loading {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 50%;
    width: 38px;
    height: 38px;
    margin: -19px 0 0 -19px;
    border: 3px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    opacity: 0;
    animation: ios-webcam-player-spin 800ms linear infinite;
    transition: opacity 120ms ease;
}

.ios-webcam-player.is-loading .ios-webcam-player__loading {
    opacity: 1;
}

.ios-webcam-player__error {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 50%;
    width: min(80%, 360px);
    padding: 12px 16px;
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.72);
    font-size: 13px;
    line-height: 1.4;
    text-align: center;
    transform: translate(-50%, -50%);
}

.ios-webcam-player:fullscreen,
.ios-webcam-player:-webkit-full-screen {
    width: 100vw !important;
    height: 100vh !important;
    background: #000;
}

@keyframes ios-webcam-player-spin {
    to {
        transform: rotate(360deg);
    }
}

@media (prefers-reduced-motion: reduce) {
    .ios-webcam-player__controls,
    .ios-webcam-player__loading {
        transition: none;
    }
}

@supports (width: 1cqi) {
    .ios-webcam-player {
        --player-control-size: clamp(42px, 6cqi, 58px);
        --player-control-slot: clamp(44px, 7cqi, 62px);
        --player-control-icon: clamp(24px, 3.5cqi, 32px);
        --player-live-font: clamp(11px, 1.6cqi, 13px);
    }
}
