.ts,
.dock,
.dock-sheet,
.yb-cb {
    display: none;
}

@media (max-width: 900px) {

    .nav {
        display: none !important;
    }

    .nav-drawer {
        display: none !important;
    }

    body {
        padding-top: 48px;
        padding-bottom: calc(76px + env(safe-area-inset-bottom));
    }

    .ts {
        display: flex;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        z-index: var(--z-header);
        height: 48px;
        padding: 0 12px 0 16px;
        align-items: center;
        justify-content: space-between;
        pointer-events: auto;
        isolation: isolate;
    }

    .ts__glass {
        position: absolute;
        inset: 0;
        z-index: -1;
        background: rgba(255, 255, 255, 0.72);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        backdrop-filter: blur(24px) saturate(180%);
        border-bottom: 1px solid rgba(0, 0, 0, 0.06);
        transition: opacity .28s var(--ease);
    }

    .ts--hero .ts__glass {
        background: rgba(18, 20, 26, 0.28);
        border-bottom-color: rgba(255, 255, 255, 0.08);
        opacity: 0;
    }

    body.ts-solid .ts--hero .ts__glass {
        opacity: 1;
        background: rgba(18, 20, 26, 0.72);
    }

    .ts__brand {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        text-decoration: none;
        color: var(--c-black);
        height: 44px;
        padding: 0 6px;
        margin-left: -4px;
        border-radius: 10px;
        -webkit-tap-highlight-color: transparent;
        transition: background-color .15s var(--ease);
    }

    .ts__brand:active {
        background: rgba(0, 0, 0, 0.05);
    }

    .ts--hero .ts__brand:active {
        background: rgba(255, 255, 255, 0.12);
    }

    .ts--hero .ts__brand {
        color: #fff;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.35));
    }

    .ts__home {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 18px;
        height: 18px;
        flex-shrink: 0;
    }

    .ts__home svg {
        width: 17px;
        height: 17px;
        display: block;
    }

    .ts__logo {
        height: 12px;
        width: auto;
        display: block;
    }

    .ts__sep {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin: 0 2px 0 4px;
        color: var(--c-black);
        opacity: 0.38;
        pointer-events: none;
    }

    .ts--hero .ts__sep {
        color: #fff;
        opacity: 0.55;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.3));
    }

    .ts__sep svg {
        width: 13px;
        height: 13px;
        display: block;
    }

    .ts__section {
        font-size: 14px;
        font-weight: 700;
        letter-spacing: -0.01em;
        color: var(--c-black);
        white-space: nowrap;
    }

    .ts--hero .ts__section {
        color: #fff;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.35));
    }

    .ts__hint {
        position: fixed;
        top: 52px;
        left: 16px;
        z-index: calc(var(--z-header) + 5);
        padding: 9px 13px 10px;
        background: #1D1D1F;
        color: #fff;
        border-radius: 10px;
        font-family: var(--font);
        font-size: 12.5px;
        font-weight: 600;
        letter-spacing: -0.005em;
        white-space: nowrap;
        pointer-events: none;
        opacity: 0;
        transform: translateY(-8px) scale(0.95);
        transform-origin: 30px 0;
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.3), 0 2px 6px rgba(0, 0, 0, 0.15);
        will-change: transform, opacity;
        transition:
            opacity .28s cubic-bezier(0.22, 1, 0.36, 1),
            transform .38s cubic-bezier(0.34, 1.4, 0.64, 1);
    }

    .ts__hint::before {
        content: '';
        position: absolute;
        top: -5px;
        left: 26px;
        width: 10px;
        height: 10px;
        background: #1D1D1F;
        transform: rotate(45deg);
        border-radius: 2px 0 0 0;
    }

    .ts__hint.is-on {
        opacity: 1;
        transform: translateY(0) scale(1);
    }

    .ts__hint-arrow {
        display: inline-block;
        margin-right: 6px;
        animation: ts-hint-arrow 1s ease-in-out infinite alternate;
    }

    @keyframes ts-hint-arrow {
        from { transform: translateY(0); }
        to   { transform: translateY(3px); }
    }

    .ts__actions {
        display: flex;
        align-items: center;
        gap: 2px;
    }

    .ts__ic {
        position: relative;
        width: 40px;
        height: 40px;
        border-radius: 50%;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: none;
        border: none;
        cursor: pointer;
        color: var(--c-black);
        text-decoration: none;
        font-family: inherit;
        -webkit-tap-highlight-color: transparent;
        touch-action: manipulation;
        transition: background-color .18s var(--ease), transform .18s var(--ease);
    }

    .ts--hero .ts__ic {
        color: #fff;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.3));
    }

    .ts__ic:active {
        transform: scale(0.92);
        background: rgba(0, 0, 0, 0.06);
    }

    .ts--hero .ts__ic:active {
        background: rgba(255, 255, 255, 0.12);
    }

    .ts__ic svg {
        width: 21px;
        height: 21px;
        pointer-events: none;
    }

    .ts__badge {
        position: absolute;
        top: 4px;
        right: 4px;
        min-width: 16px;
        height: 16px;
        padding: 0 4px;
        border-radius: 100px;
        background: #FCE116;
        color: #1D1D1F;
        border: 1.5px solid #fff;
        font: 700 9.5px/1 inherit;
        letter-spacing: -0.02em;
        font-variant-numeric: tabular-nums;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        pointer-events: none;
        box-sizing: content-box;
    }

    .ts--hero .ts__badge {
        border-color: rgba(18, 20, 26, 0.9);
    }

    .dock {
        display: flex;
        position: fixed;
        left: 50%;
        bottom: calc(14px + env(safe-area-inset-bottom));
        z-index: var(--z-header);
        transform: translate3d(-50%, 0, 0);
        align-items: stretch;
        justify-content: space-between;
        padding: 6px;
        gap: 2px;
        width: calc(100vw - 24px);
        max-width: 420px;
        height: 62px;
        border-radius: 31px;
        isolation: isolate;
        pointer-events: auto;
        will-change: transform;
        animation: dockIn .55s cubic-bezier(0.22, 1, 0.36, 1) .15s both;
    }

    @keyframes dockIn {
        from { opacity: 0; transform: translate3d(-50%, 20px, 0); }
        to   { opacity: 1; transform: translate3d(-50%, 0, 0); }
    }

    .dock__glass {
        position: absolute;
        inset: 0;
        z-index: -3;
        border-radius: inherit;
        background: rgba(255, 255, 255, 0.72);
        -webkit-backdrop-filter: blur(32px) saturate(180%) brightness(1.04);
        backdrop-filter: blur(32px) saturate(180%) brightness(1.04);
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.6) inset,
            0 -1px 0 rgba(0, 0, 0, 0.04) inset,
            0 0 0 1px rgba(0, 0, 0, 0.05),
            0 12px 40px rgba(15, 18, 30, 0.12),
            0 4px 12px rgba(15, 18, 30, 0.06);
    }

    .dock--hero .dock__glass {
        background: rgba(22, 24, 30, 0.55);
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.18) inset,
            0 -1px 0 rgba(0, 0, 0, 0.18) inset,
            0 0 0 1px rgba(255, 255, 255, 0.08),
            0 12px 40px rgba(0, 0, 0, 0.35),
            0 4px 12px rgba(0, 0, 0, 0.18);
    }

    .dock__noise {
        position: absolute;
        inset: 0;
        z-index: -2;
        border-radius: inherit;
        pointer-events: none;
        opacity: 0.035;
        mix-blend-mode: overlay;
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
    }

    .dock__highlight {
        position: absolute;
        top: 0;
        left: 12%;
        right: 12%;
        height: 1px;
        z-index: -1;
        border-radius: inherit;
        background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.75) 50%, transparent 100%);
        pointer-events: none;
    }

    .dock--hero .dock__highlight {
        background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.3) 50%, transparent 100%);
    }

    .dock__indicator {
        position: absolute;
        bottom: 6px;
        left: 6px;
        width: calc((100% - 12px) / 5);
        height: 3px;
        border-radius: 2px;
        background: var(--c-accent);
        box-shadow: 0 0 14px rgba(252, 225, 22, 0.55), 0 0 2px rgba(252, 225, 22, 0.9);
        opacity: 0;
        pointer-events: none;
        transform: translate3d(0, 0, 0) scaleX(0.55);
        transform-origin: center;
        transition:
            transform .42s cubic-bezier(0.32, 0.72, 0, 1),
            opacity .22s var(--ease);
        will-change: transform;
    }

    .dock.is-spring .dock__indicator {
        transition: none;
    }

    .dock[data-active="gazon"]  .dock__indicator,
    .dock[data-active="sneg"]   .dock__indicator,
    .dock[data-active="vozduh"] .dock__indicator,
    .dock[data-active="shop"]   .dock__indicator {
        opacity: 1;
        transform: translate3d(var(--dock-ind-x, 0), 0, 0) scaleX(0.55);
    }

    .dock[data-active="gazon"]  { --dock-ind-x: 0%; }
    .dock[data-active="sneg"]   { --dock-ind-x: 100%; }
    .dock[data-active="vozduh"] { --dock-ind-x: 200%; }
    .dock[data-active="shop"]   { --dock-ind-x: 300%; }

    .dock__glow {
        display: none;
    }

    .dock__slot-glow {
        position: absolute;
        top: 50%;
        left: 50%;
        width: 58px;
        height: 58px;
        margin-left: -29px;
        margin-top: -29px;
        border-radius: 50%;
        background: radial-gradient(circle, rgba(252, 225, 22, 0.6) 0%, rgba(252, 225, 22, 0.18) 40%, transparent 70%);
        pointer-events: none;
        z-index: -1;
        opacity: 0;
    }

    .dock--hero .dock__slot-glow {
        background: radial-gradient(circle, rgba(252, 225, 22, 0.75) 0%, rgba(252, 225, 22, 0.22) 40%, transparent 70%);
    }

    .dock {
        transition:
            opacity .3s cubic-bezier(0.4, 0, 0.2, 1),
            transform .42s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .dock--hidden {
        opacity: 0 !important;
        transform: translate3d(-50%, 18px, 0) scale(0.86) !important;
        pointer-events: none !important;
    }

    .dock-mini {
        position: fixed;
        right: 14px;
        bottom: calc(14px + env(safe-area-inset-bottom));
        z-index: var(--z-header);
        width: 52px;
        height: 52px;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.78);
        -webkit-backdrop-filter: blur(28px) saturate(180%);
        backdrop-filter: blur(28px) saturate(180%);
        border: none;
        display: flex;
        align-items: center;
        justify-content: center;
        color: var(--c-black);
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.65) inset,
            0 0 0 1px rgba(0, 0, 0, 0.05),
            0 12px 32px rgba(15, 18, 30, 0.18),
            0 4px 10px rgba(15, 18, 30, 0.08);
        cursor: pointer;
        opacity: 0;
        visibility: hidden;
        transform: scale(0.55) translateY(20px);
        will-change: transform, opacity;
        -webkit-tap-highlight-color: transparent;
        touch-action: manipulation;
        transition:
            opacity .32s cubic-bezier(0.22, 1, 0.36, 1),
            transform .5s cubic-bezier(0.34, 1.45, 0.64, 1),
            visibility 0s linear .5s;
    }

    .dock-mini--hero {
        background: rgba(22, 24, 30, 0.58);
        color: #fff;
        box-shadow:
            0 1px 0 rgba(255, 255, 255, 0.2) inset,
            0 0 0 1px rgba(255, 255, 255, 0.1),
            0 12px 32px rgba(0, 0, 0, 0.38),
            0 4px 10px rgba(0, 0, 0, 0.18);
    }

    .dock-mini.is-on {
        opacity: 1;
        visibility: visible;
        transform: scale(1) translateY(0);
        transition:
            opacity .32s cubic-bezier(0.22, 1, 0.36, 1),
            transform .5s cubic-bezier(0.34, 1.45, 0.64, 1),
            visibility 0s linear 0s;
    }

    .dock-mini:active {
        transform: scale(0.9) translateY(0);
        transition-duration: .14s;
    }

    .dock-mini svg {
        width: 22px;
        height: 22px;
        display: block;
        pointer-events: none;
    }

    .dock__slot {
        position: relative;
        flex: 1 1 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 3px;
        padding: 6px 2px 9px;
        border-radius: 22px;
        background: none;
        border: none;
        cursor: pointer;
        text-decoration: none;
        font-family: inherit;
        color: var(--c-black);
        -webkit-tap-highlight-color: transparent;
        touch-action: manipulation;
        transition: transform .18s var(--ease);
    }

    .dock--hero .dock__slot {
        color: rgba(255, 255, 255, 0.88);
    }

    .dock__slot:active {
        transform: scale(0.93);
    }

    .dock--hero .dock__slot[aria-current="page"] {
        color: #fff;
    }

    .dock__ic {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 24px;
        height: 24px;
    }

    .dock__ic svg {
        width: 22px;
        height: 22px;
        display: block;
        pointer-events: none;
        transition: transform .22s var(--ease);
    }

    .dock__slot[aria-current="page"] .dock__ic svg {
        transform: scale(1.08);
    }

    .dock__slot--trigger[aria-expanded="true"] .dock__ic svg {
        transform: scale(1.12) rotate(-8deg);
    }

    .dock__label {
        font-size: 9.5px;
        font-weight: 700;
        letter-spacing: 0.01em;
        line-height: 1;
        opacity: 0.66;
        white-space: nowrap;
    }

    .dock--hero .dock__label {
        opacity: 0.72;
    }

    .dock__slot[aria-current="page"] .dock__label {
        opacity: 1;
    }

    .dock-sheet {
        display: block;
        position: fixed;
        inset: 0;
        z-index: calc(var(--z-header) + 20);
        pointer-events: none;
        visibility: hidden;
        transition: visibility 0s linear .42s;
    }

    .dock-sheet[aria-hidden="false"] {
        pointer-events: auto;
        visibility: visible;
        transition: visibility 0s linear 0s;
    }

    .dock-sheet__backdrop {
        position: absolute;
        inset: 0;
        background: rgba(10, 12, 18, 0.48);
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
        opacity: 0;
        transition: opacity .32s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .dock-sheet[aria-hidden="false"] .dock-sheet__backdrop {
        opacity: 1;
    }

    .dock-sheet__panel {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        padding: calc(14px + env(safe-area-inset-top, 0px)) 12px calc(22px + env(safe-area-inset-bottom));
        border-radius: 24px 24px 0 0;
        background: #fff;
        box-shadow:
            0 -10px 32px rgba(15, 18, 30, 0.18),
            0 -2px 8px rgba(15, 18, 30, 0.06);
        transform: translate3d(0, 100%, 0);
        transition: transform .42s cubic-bezier(0.22, 1, 0.36, 1);
        will-change: transform;
        touch-action: pan-y;
        max-height: calc(100dvh - 40px);
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }

    .dock-sheet[aria-hidden="false"] .dock-sheet__panel {
        transform: translate3d(0, 0, 0);
    }

    .dock-sheet__panel.is-dragging {
        transition: none;
    }

    .dock-sheet__handle {
        display: block;
        width: 40px;
        height: 4px;
        margin: 0 auto 14px;
        border-radius: 2px;
        background: rgba(0, 0, 0, 0.16);
    }

    .dock-sheet__title {
        margin: 0 12px 2px;
        font-size: 19px;
        font-weight: 900;
        letter-spacing: -0.02em;
        color: var(--c-black);
    }

    .dock-sheet__subtitle {
        margin: 0 12px 12px;
        font-size: 13px;
        font-weight: 500;
        color: var(--c-muted);
    }

    .dock-sheet__row {
        display: flex;
        align-items: center;
        gap: 12px;
        width: 100%;
        padding: 12px;
        min-height: 56px;
        border-radius: 16px;
        background: none;
        border: none;
        font-family: inherit;
        text-align: left;
        text-decoration: none;
        color: var(--c-black);
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
        transition: background-color .16s var(--ease);
    }

    .dock-sheet__row:active {
        background: rgba(0, 0, 0, 0.05);
    }

    .dock-sheet__row--accent {
        background: rgba(252, 225, 22, 0.16);
    }

    .dock-sheet__row--accent:active {
        background: rgba(252, 225, 22, 0.28);
    }

    .dock-sheet__ic {
        width: 40px;
        height: 40px;
        flex-shrink: 0;
        border-radius: 50%;
        background: rgba(0, 0, 0, 0.05);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--c-black);
    }

    .dock-sheet__row--accent .dock-sheet__ic {
        background: var(--c-accent);
    }

    .dock-sheet__ic svg {
        width: 20px;
        height: 20px;
        display: block;
    }

    .dock-sheet__txt {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 2px;
    }

    .dock-sheet__row-title {
        font-size: 15px;
        font-weight: 700;
        letter-spacing: -0.01em;
        color: var(--c-black);
    }

    .dock-sheet__row-hint {
        font-size: 12.5px;
        font-style: normal;
        font-weight: 500;
        color: var(--c-muted);
    }

    .dock-sheet__chev {
        flex-shrink: 0;
        width: 16px;
        height: 16px;
        color: var(--c-subtle);
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .dock-sheet__chev svg {
        width: 14px;
        height: 14px;
    }

    .dock-sheet__close {
        display: none;
    }

    .yb-cb__success {
        position: fixed;
        inset: 0;
        background: rgba(255, 255, 255, 0.98);
        -webkit-backdrop-filter: blur(8px);
        backdrop-filter: blur(8px);
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 24px;
        z-index: calc(var(--z-header) + 60);
        opacity: 0;
        transition: opacity .32s cubic-bezier(0.22, 1, 0.36, 1);
        pointer-events: none;
    }

    .yb-cb__success.is-on {
        opacity: 1;
        pointer-events: auto;
    }

    .yb-cb__success-inner {
        text-align: center;
        max-width: 280px;
        position: relative;
    }

    .yb-cb__success-icon {
        width: 84px;
        height: 84px;
        margin: 0 auto 20px;
        color: var(--c-green);
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .yb-cb__success-icon svg {
        position: relative;
        z-index: 1;
        transform: scale(0.3);
        opacity: 0;
    }

    .yb-cb__success-glow {
        position: absolute;
        inset: -8px;
        border-radius: 50%;
        background: radial-gradient(circle, rgba(45, 127, 58, 0.25) 0%, transparent 65%);
        opacity: 0;
        pointer-events: none;
    }

    .yb-cb__success-ring {
        fill: none;
        stroke: currentColor;
    }

    .yb-cb__success-check {
        fill: none;
        stroke: currentColor;
    }

    .yb-cb__success-title {
        margin: 0 0 6px;
        font-size: 22px;
        font-weight: 900;
        letter-spacing: -0.02em;
        color: var(--c-black);
        opacity: 0;
        transform: translateY(8px);
    }

    .yb-cb__success-sub {
        margin: 0;
        font-size: 14px;
        font-weight: 500;
        color: var(--c-muted);
        opacity: 0;
        transform: translateY(8px);
    }

    .yb-cb__success-bar {
        margin: 22px auto 0;
        width: 72px;
        height: 3px;
        background: rgba(0, 0, 0, 0.08);
        border-radius: 2px;
        overflow: hidden;
        opacity: 0;
        transform: translateY(8px);
    }

    .yb-cb__success-bar span {
        display: block;
        height: 100%;
        width: 0;
        background: var(--c-accent);
        border-radius: 2px;
    }

    .yb-cb__success-burst {
        position: absolute;
        top: 42px;
        left: 50%;
        width: 0;
        height: 0;
        pointer-events: none;
    }

    .yb-cb__success-burst span {
        position: absolute;
        top: 0;
        left: 0;
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--c-accent);
        opacity: 0;
        transform: translate(-50%, -50%);
    }

    .yb-cb__success-burst span:nth-child(1) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(2) { background: #2D7F3A; }
    .yb-cb__success-burst span:nth-child(3) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(4) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(5) { background: #2D7F3A; }
    .yb-cb__success-burst span:nth-child(6) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(7) { background: #2D7F3A; width: 5px; height: 5px; }
    .yb-cb__success-burst span:nth-child(8) { background: #FCE116; width: 5px; height: 5px; }

    @keyframes yb-cb-bar { to { width: 100%; } }
    @keyframes yb-cb-fade-up { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes yb-cb-icon-pop { 0% { transform: scale(0.3); opacity: 0; } 60% { transform: scale(1.08); opacity: 1; } 100% { transform: scale(1); opacity: 1; } }
    @keyframes yb-cb-ring { to { stroke-dashoffset: 0; } }
    @keyframes yb-cb-check { to { stroke-dashoffset: 0; } }
    @keyframes yb-cb-glow { 0%, 100% { opacity: 0.4; transform: scale(1); } 50% { opacity: 0.95; transform: scale(1.15); } }
    @keyframes yb-cb-burst { 0% { opacity: 0; transform: translate(-50%, -50%) scale(0.2); } 30% { opacity: 1; } 100% { opacity: 0; transform: translate(calc(-50% + var(--bx)), calc(-50% + var(--by))) scale(0.6); } }

    .yb-cb__success-burst {
        position: absolute;
        top: 42px;
        left: 50%;
        width: 0;
        height: 0;
        pointer-events: none;
    }

    .yb-cb__success-burst span:nth-child(1) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(2) { background: #2D7F3A; }
    .yb-cb__success-burst span:nth-child(3) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(4) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(5) { background: #2D7F3A; }
    .yb-cb__success-burst span:nth-child(6) { background: #FCE116; }
    .yb-cb__success-burst span:nth-child(7) { background: #2D7F3A; width: 5px; height: 5px; }
    .yb-cb__success-burst span:nth-child(8) { background: #FCE116; width: 5px; height: 5px; }

    body.dock-sheet-open,
    body.yb-cb-open {
        overflow: hidden;
        overscroll-behavior: contain;
    }

    .yb-cb {
        display: block;
        position: fixed;
        inset: 0;
        z-index: calc(var(--z-header) + 40);
        pointer-events: none;
        visibility: hidden;
        transition: visibility 0s linear .4s;
    }

    .yb-cb[aria-hidden="false"] {
        pointer-events: auto;
        visibility: visible;
        transition: visibility 0s linear 0s;
    }

    .yb-cb__backdrop {
        position: absolute;
        inset: 0;
        background: rgba(10, 12, 18, 0.55);
        -webkit-backdrop-filter: blur(12px);
        backdrop-filter: blur(12px);
        opacity: 0;
        transition: opacity .32s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .yb-cb[aria-hidden="false"] .yb-cb__backdrop {
        opacity: 1;
    }

    .yb-cb__box {
        position: absolute;
        left: 50%;
        top: 50%;
        width: calc(100vw - 32px);
        max-width: 420px;
        max-height: min(640px, calc(100vh - 64px));
        background: #fff;
        border-radius: 26px;
        box-shadow:
            0 32px 80px rgba(10, 12, 18, 0.4),
            0 10px 28px rgba(10, 12, 18, 0.2);
        transform: translate(-50%, -48%) scale(0.92);
        opacity: 0;
        overflow: hidden;
        transition:
            transform .42s cubic-bezier(0.34, 1.4, 0.64, 1),
            opacity .28s cubic-bezier(0.22, 1, 0.36, 1);
        display: flex;
        flex-direction: column;
    }

    .yb-cb[aria-hidden="false"] .yb-cb__box {
        transform: translate(-50%, -50%) scale(1);
        opacity: 1;
    }

    .yb-cb__close {
        position: absolute;
        top: 14px;
        right: 14px;
        width: 36px;
        height: 36px;
        border: none;
        background: rgba(0, 0, 0, 0.06);
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        color: var(--c-black);
        cursor: pointer;
        z-index: 2;
        -webkit-tap-highlight-color: transparent;
        transition: background .15s, transform .15s;
    }

    .yb-cb__close:active {
        background: rgba(0, 0, 0, 0.12);
        transform: scale(0.92);
    }

    .yb-cb__view {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-height: 0;
        padding: 28px 22px 22px;
    }

    .yb-cb__view[hidden] {
        display: none;
    }

    .yb-cb__view--priv {
        padding: 18px 14px 18px;
    }

    .yb-cb__head {
        margin-bottom: 18px;
        padding-right: 40px;
    }

    .yb-cb__title {
        margin: 0 0 4px;
        font-size: 22px;
        font-weight: 900;
        letter-spacing: -0.02em;
        color: var(--c-black);
    }

    .yb-cb__sub {
        margin: 0;
        font-size: 13.5px;
        font-weight: 500;
        color: var(--c-muted);
    }

    .yb-cb__form {
        display: flex;
        flex-direction: column;
    }

    .yb-cb__field {
        position: relative;
        display: block;
        height: 52px;
        margin-bottom: 0;
    }

    .yb-cb__ghost {
        position: absolute;
        left: 18px;
        top: 0;
        height: 52px;
        display: flex;
        align-items: center;
        pointer-events: none;
        font-family: var(--font);
        font-size: 16px;
        font-weight: 500;
        color: var(--c-black);
        opacity: 0.42;
        white-space: nowrap;
        overflow: hidden;
        max-width: calc(100% - 36px);
        z-index: 2;
        transition: opacity .18s ease;
    }

    .yb-cb__inp:focus ~ .yb-cb__ghost,
    .yb-cb__inp:not(:placeholder-shown) ~ .yb-cb__ghost,
    .yb-cb__inp[data-egg-active="1"] ~ .yb-cb__ghost {
        opacity: 0;
        visibility: hidden;
    }

    .yb-cb__ghost-c {
        display: inline-block;
        width: 2px;
        height: 18px;
        background: var(--c-black);
        margin-left: 2px;
        vertical-align: middle;
        animation: yb-cb-blink 1.05s steps(2, end) infinite;
    }

    @keyframes yb-cb-blink {
        0%, 50% { opacity: 1; }
        51%, 100% { opacity: 0; }
    }

    .yb-cb__inp {
        display: block;
        width: 100%;
        height: 52px;
        padding: 0 16px;
        background: rgba(0, 0, 0, 0.04);
        border: 1.5px solid rgba(0, 0, 0, 0.06);
        border-radius: 14px;
        font-size: 16px;
        font-weight: 500;
        font-family: var(--font);
        color: var(--c-black);
        outline: none;
        transition: background .15s, border-color .15s;
        -webkit-appearance: none;
        appearance: none;
    }

    .yb-cb__inp:focus {
        background: #fff;
        border-color: var(--c-accent);
    }

    .yb-cb__inp::placeholder {
        color: var(--c-muted);
        opacity: 0.7;
    }

    .yb-cb__hint {
        display: block;
        min-height: 18px;
        padding: 4px 4px 4px;
        font-size: 11.5px;
        font-weight: 600;
        color: var(--c-muted);
        transition: color .15s;
    }

    .yb-cb__hint--center {
        text-align: center;
    }

    .yb-cb__hint--ok { color: var(--c-green); }
    .yb-cb__hint--err { color: var(--c-red); }

    .yb-cb__field--shake .yb-cb__inp {
        animation: yb-cb-shake .42s cubic-bezier(.36, .07, .19, .97);
        border-color: var(--c-red);
    }

    @keyframes yb-cb-shake {
        10%, 90% { transform: translateX(-2px); }
        20%, 80% { transform: translateX(3px); }
        30%, 50%, 70% { transform: translateX(-5px); }
        40%, 60% { transform: translateX(5px); }
    }

    .yb-cb__consent {
        display: flex;
        align-items: flex-start;
        gap: 10px;
        margin: 10px 2px 6px;
        cursor: pointer;
        user-select: none;
        position: relative;
    }

    .yb-cb__consent input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
        width: 20px;
        height: 20px;
        top: 0;
        left: 0;
    }

    .yb-cb__consent-box {
        flex-shrink: 0;
        width: 20px;
        height: 20px;
        margin-top: 1px;
        border: 1.5px solid rgba(0, 0, 0, 0.22);
        border-radius: 6px;
        background: #fff;
        transition: background .15s, border-color .15s, transform .15s;
        position: relative;
    }

    .yb-cb__consent input:checked + .yb-cb__consent-box {
        background: var(--c-accent);
        border-color: var(--c-accent);
    }

    .yb-cb__consent input:checked + .yb-cb__consent-box::after {
        content: '';
        position: absolute;
        top: 2px;
        left: 6px;
        width: 5px;
        height: 10px;
        border: solid #1D1D1F;
        border-width: 0 2.2px 2.2px 0;
        transform: rotate(45deg);
    }

    .yb-cb__consent:active .yb-cb__consent-box {
        transform: scale(0.9);
    }

    .yb-cb__consent-txt {
        flex: 1;
        font-size: 12px;
        line-height: 1.45;
        color: var(--c-black);
        opacity: 0.78;
    }

    .yb-cb__priv-trig {
        border: none;
        background: none;
        padding: 0;
        font: inherit;
        color: var(--c-black);
        text-decoration: underline;
        cursor: pointer;
    }

    .yb-cb__btn {
        display: block;
        width: 100%;
        height: 52px;
        flex-shrink: 0;
        padding: 0 16px;
        margin-top: 14px;
        background: var(--c-accent);
        border: none;
        border-radius: 14px;
        font-family: var(--font);
        font-size: 15px;
        font-weight: 900;
        letter-spacing: -0.01em;
        color: var(--c-black);
        cursor: pointer;
        transition: background .15s, transform .12s;
        -webkit-tap-highlight-color: transparent;
    }

    .yb-cb__btn:active {
        background: var(--c-accent-h);
        transform: scale(0.985);
    }

    .yb-cb__btn:disabled {
        opacity: 0.5;
        pointer-events: none;
    }

    .yb-cb__status {
        margin-top: 12px;
        padding: 12px 14px;
        border-radius: 12px;
        font-size: 13px;
        font-weight: 600;
        text-align: center;
        animation: yb-cb-fade-in .24s ease both;
    }

    @keyframes yb-cb-fade-in {
        from { opacity: 0; transform: translateY(-6px); }
        to { opacity: 1; transform: translateY(0); }
    }

    .yb-cb__status--ok {
        background: rgba(45, 127, 58, 0.12);
        color: var(--c-green);
    }

    .yb-cb__status--err {
        background: rgba(224, 49, 49, 0.12);
        color: var(--c-red);
    }

    .yb-cb__priv-back {
        display: flex;
        align-items: center;
        gap: 6px;
        padding: 8px 10px;
        margin: 0 -4px 12px;
        border: none;
        background: none;
        font-family: var(--font);
        font-size: 14px;
        font-weight: 700;
        color: var(--c-black);
        opacity: 0.7;
        cursor: pointer;
        border-radius: 8px;
        -webkit-tap-highlight-color: transparent;
        transition: opacity .15s, background .15s;
        align-self: flex-start;
    }

    .yb-cb__priv-back:active {
        opacity: 1;
        background: rgba(0, 0, 0, 0.04);
    }

    .yb-cb__priv-body {
        flex: 1;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        padding: 0 8px 12px;
        font-size: 13.5px;
        line-height: 1.55;
        color: var(--c-black);
        scrollbar-width: thin;
        scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
    }

    .yb-cb__priv-body::-webkit-scrollbar {
        width: 5px;
    }

    .yb-cb__priv-body::-webkit-scrollbar-thumb {
        background: rgba(0, 0, 0, 0.18);
        border-radius: 3px;
    }

    .yb-cb__priv-body h1,
    .yb-cb__priv-body h2 {
        font-size: 15px;
        font-weight: 900;
        margin: 14px 0 6px;
        letter-spacing: -0.01em;
    }

    .yb-cb__priv-body h1:first-child,
    .yb-cb__priv-body h2:first-child {
        margin-top: 0;
    }

    .yb-cb__priv-body p {
        margin: 0 0 8px;
        opacity: 0.85;
    }

    .yb-cb__priv-body ul,
    .yb-cb__priv-body ol {
        margin: 0 0 10px 18px;
    }

    .yb-cb__priv-body li {
        margin-bottom: 4px;
        opacity: 0.85;
    }

    .yb-cb__priv-body a {
        color: var(--c-black);
        text-decoration: underline;
    }

    @media (max-width: 380px) {
        .dock {
            width: calc(100vw - 16px);
            height: 58px;
            padding: 5px;
        }
        .dock__ic svg {
            width: 20px;
            height: 20px;
        }
        .dock__label {
            font-size: 9px;
        }
        .ts {
            padding: 0 8px 0 12px;
        }
        .yb-cb__view {
            padding: 24px 18px 18px;
        }
        .yb-cb__title {
            font-size: 20px;
        }
    }
}

@media (prefers-reduced-motion: reduce) {
    .dock,
    .dock__indicator,
    .dock__ic svg,
    .dock-sheet__panel,
    .dock-sheet__backdrop,
    .dock-sheet__row,
    .yb-cb__box,
    .yb-cb__backdrop {
        animation: none !important;
        transition: none !important;
    }
}

@media (prefers-reduced-transparency: reduce) {
    .ts__glass,
    .dock__glass,
    .dock-sheet__backdrop,
    .yb-cb__backdrop {
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
    }
    .ts__glass { background: rgba(255, 255, 255, 0.98); }
    .ts--hero .ts__glass { background: rgba(18, 20, 26, 0.92); }
    .dock__glass { background: rgba(255, 255, 255, 0.96); }
    .dock--hero .dock__glass { background: rgba(22, 24, 30, 0.92); }
    .dock-sheet__backdrop { background: rgba(10, 12, 18, 0.75); }
    .yb-cb__backdrop { background: rgba(10, 12, 18, 0.82); }
}
