:root {
    --bg: #ffb300;
    --fg: #0b0b0b;
    --muted: rgba(0, 0, 0, 0.12);
    --accent: #ff6b6b;
    --transition: 300ms;
}

body {
    margin: 0;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg);
    color: var(--fg);
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
    transition: background var(--transition), color var(--transition);
    user-select: none;
    /* Prevent text selection */
    -webkit-user-select: none;
    /* Safari */
    -moz-user-select: none;
    /* Firefox */
    -ms-user-select: none;
    /* IE10+ */
}

body.dark {
    --bg: #070707;
    --fg: #ffb300;
    --muted: rgba(255, 255, 255, 0.06)
}

.stage {
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: center;
    width: 100%;
    padding: 28px;
    box-sizing: border-box
}

.clock-wrap {
    display: grid;
    place-items: center
}

svg.clock-svg {
    display: block;
    transition: transform var(--transition);
}

svg.clock-svg .rim,
svg.clock-svg .tick,
svg.clock-svg .hand-hour,
svg.clock-svg .hand-minute {
    stroke: currentColor;
    transition: stroke var(--transition), opacity var(--transition)
}

svg.clock-svg .second {
    stroke: var(--accent);
    transition: stroke var(--transition), opacity var(--transition)
}

svg.clock-svg .hub {
    fill: currentColor;
    transition: fill var(--transition)
}

.digital {
    padding: 10px 16px;
    border-radius: 10px;
    background: rgba(0, 0, 0, 0.06);
    min-width: 220px;
    text-align: center;
    font-weight: 600;
    transition: background var(--transition), color var(--transition)
}

.ip-info {
    margin-top: 20px;
    font-size: 0.8rem;
    opacity: 0.6;
    font-family: monospace;
    letter-spacing: 0.5px;
}

.isp-info {
    margin-top: 8px;
    font-size: 0.8rem;
    opacity: 0.6;
    font-family: monospace;
    letter-spacing: 0.5px;
    text-align: center;
}

.visitor-details {
    margin-top: 8px;
    font-size: 0.75rem;
    line-height: 1.4;
    opacity: 0.5;
    font-family: monospace;
    text-align: center;
}

body.dark .digital {
    background: rgba(255, 255, 255, 0.03)
}

.controls {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    width: 100%;
    max-width: 520px
}

.mode-row,
.zoom-row {
    display: flex;
    gap: 12px;
    align-items: center
}

.mode-row {
    justify-content: center
}

.zoom-row {
    justify-content: center
}

.btn {
    padding: 10px 14px;
    border-radius: 10px;
    border: 0;
    cursor: pointer;
    font-weight: 700;
    background: var(--muted);
    color: var(--fg);
    transition: background var(--transition), color var(--transition)
}

body.dark .btn {
    background: rgba(255, 255, 255, 0.04)
}

.sensitive-info {
    transition: filter var(--transition), opacity var(--transition);
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.sensitive-info.hidden {
    filter: blur(8px);
    pointer-events: none;
    user-select: none;
}

.accent-btn {
    background: var(--accent) !important;
    color: white !important;
    opacity: 0.8;
}

.accent-btn:hover {
    opacity: 1;
}

@media (max-width: 600px) {
    .stage {
        padding: 16px;
        gap: 20px;
    }

    .btn {
        padding: 12px 20px;
        /* Larger touch targets */
        font-size: 0.9rem;
    }

    .digital {
        min-width: 180px;
        font-size: 1.2rem;
    }

    .ip-info {
        font-size: 0.75rem;
    }

    .isp-info {
        font-size: 0.75rem;
    }

    .visitor-details {
        font-size: 0.7rem;
        max-width: 90vw;
    }
}

/* Landscape mode or very short screens */
@media (max-height: 500px) {
    .stage {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        gap: 30px;
    }

    .controls {
        width: auto;
    }
}