/* ═══════════════════════════════════════════════════════════════════════
   DIDO+ PREMIUM — Capa de UX premium (carga DESPUÉS de dido-pro.css)
   Sidebar reimaginado, mobile-first, animaciones globales, efectos wow.
   ═══════════════════════════════════════════════════════════════════════

   📐 JERARQUÍA Z-INDEX (referencia maestra — respetar al añadir nuevos)
   ─────────────────────────────────────────────────────────────────────
   9999  ─ Toasts / Alerts globales (player.css, dp-progress, dp-cursor)
   9997  ─ Confetti
   9998  ─ Loading bar superior
   210   ─ Topbar cuando hay sidebar drawer abierto (mobile)
   200   ─ Sidebar mobile drawer + bottom-sheets
   195   ─ Sidebar backdrop (mobile)
   120   ─ Player controls (player.css, !important)
   110   ─ Dropdowns / popovers
   105   ─ Backdrops generales
   100   ─ Topbar (default)
   95    ─ Bottom-nav móvil
   94    ─ FAB móvil
   90    ─ Sidebar desktop (default)
   30    ─ Cards portrait al hover
   20    ─ Cards landscape al hover
   3     ─ Hero content
   2     ─ Hero overlay
   1     ─ Hero bg-slot active
   0     ─ Background layers
   ───────────────────────────────────────────────────────────────────── */

:root{
    /* Spring easings */
    --spring:        cubic-bezier(.34, 1.56, .64, 1);
    --spring-soft:   cubic-bezier(.5, 1.25, .75, 1.25);
    --spring-snappy: cubic-bezier(.65, 0, .35, 1);

    /* Shadows premium */
    --shadow-glow-magenta: 0 0 40px rgba(217, 40, 229, .35);
    --shadow-glow-purple:  0 0 30px rgba(107, 43, 226, .28);
    --shadow-soft:         0 14px 40px rgba(0, 0, 0, .35);
    --shadow-deep:         0 24px 80px rgba(0, 0, 0, .55);
}

/* ═══════════════════════════════════════════════════════════════════════
   FASE α — SIDEBAR ESTÁTICO (no se expande con hover)
   ═══════════════════════════════════════════════════════════════════════ */

/* DESKTOP — 64px colapsado, se expande con HOVER o CLICK ☰ */
@media (min-width: 769px){
    .dido-sidebar{
        width: 64px !important;
        background: #0a0a0a !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        border-right: 1px solid rgba(255,255,255,.06) !important;
        box-shadow: none !important;
        overflow: hidden !important;
        transition: width .3s cubic-bezier(.65, 0, .35, 1), box-shadow .3s ease !important;
    }
    /* Hover en sidebar O click ☰ → expande (mismo comportamiento) */
    .dido-sidebar:hover,
    .dido-sidebar.open{
        width: 280px !important;
        box-shadow: 8px 0 40px rgba(0,0,0,.5) !important;
        z-index: 110 !important;
    }

    .dido-sidebar-inner{
        position: relative;
        padding: .85rem .5rem 1rem !important;
        width: 64px !important;
        overflow-x: hidden !important;
        transition: width .3s cubic-bezier(.65, 0, .35, 1), padding .3s ease !important;
    }
    .dido-sidebar:hover .dido-sidebar-inner,
    .dido-sidebar.open .dido-sidebar-inner{
        width: 280px !important;
        padding: 1rem .85rem 2rem !important;
    }

    /* Colapsado (sin hover y sin .open): ocultar contenido extra */
    .dido-sidebar:not(:hover):not(.open) .ds-header,
    .dido-sidebar:not(:hover):not(.open) .ds-header-guest,
    .dido-sidebar:not(:hover):not(.open) .ds-trending,
    .dido-sidebar:not(:hover):not(.open) .ds-footer,
    .dido-sidebar:not(:hover):not(.open) .ds-group-label,
    .dido-sidebar:not(:hover):not(.open) .ds-item-badge,
    .dido-sidebar:not(:hover):not(.open) .ds-active-indicator,
    .dido-sidebar:not(:hover):not(.open) .ds-item .dido-side-label,
    .dido-sidebar:not(:hover):not(.open) .dido-side-label{
        display: none !important;
    }
    /* Expandido (hover o .open): TODO visible */
    .dido-sidebar:hover .ds-header,
    .dido-sidebar:hover .ds-header-guest,
    .dido-sidebar.open .ds-header,
    .dido-sidebar.open .ds-header-guest{
        display: flex !important;
        align-items: center;
        gap: .7rem;
        padding: .75rem .65rem !important;
        min-height: 60px;
        margin-bottom: 1rem;
        border-radius: 12px;
    }
    .dido-sidebar:hover .ds-header-text,
    .dido-sidebar:hover .ds-header-name,
    .dido-sidebar:hover .ds-header-balance,
    .dido-sidebar.open .ds-header-text,
    .dido-sidebar.open .ds-header-name,
    .dido-sidebar.open .ds-header-balance{
        display: block !important;
        opacity: 1 !important;
    }
    .dido-sidebar:hover .ds-header-arrow,
    .dido-sidebar.open .ds-header-arrow{
        opacity: 1 !important;
    }
    .dido-sidebar:hover .ds-trending,
    .dido-sidebar:hover .ds-footer,
    .dido-sidebar.open .ds-trending,
    .dido-sidebar.open .ds-footer{
        display: block !important;
    }
    .dido-sidebar:hover .ds-trending-chips,
    .dido-sidebar.open .ds-trending-chips{
        display: flex !important;
        opacity: 1 !important;
    }
    .dido-sidebar:hover .ds-group-label,
    .dido-sidebar.open .ds-group-label{
        display: block !important;
        opacity: 1 !important;
    }
    .dido-sidebar:hover .ds-item-badge,
    .dido-sidebar.open .ds-item-badge{
        display: inline-flex !important;
        opacity: 1 !important;
        margin-left: auto;
    }
    .dido-sidebar:hover .ds-item .dido-side-label,
    .dido-sidebar:hover .dido-side-label,
    .dido-sidebar.open .ds-item .dido-side-label,
    .dido-sidebar.open .dido-side-label{
        display: inline-block !important;
        opacity: 1 !important;
    }
    .dido-sidebar:hover .ds-item,
    .dido-sidebar.open .ds-item{
        justify-content: flex-start !important;
        padding: .65rem .65rem !important;
        gap: .85rem !important;
    }
    /* Cuando expandido, ocultar el tooltip (ya hay label visible) */
    .dido-sidebar:hover .ds-item::after,
    .dido-sidebar.open .ds-item::after{
        display: none !important;
    }

    /* Item desktop: solo ícono centrado */
    .dido-sidebar .ds-item{
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: .65rem 0 !important;
        margin: .15rem 0 !important;
        gap: 0 !important;
        width: 100% !important;
        height: 44px !important;
        border-radius: 10px !important;
        color: rgba(255,255,255,.55) !important;
        background: transparent !important;
        border: 0 !important;
        transition: background .18s, color .18s !important;
        position: relative;
    }
    .dido-sidebar .ds-item:hover{
        background: rgba(255,255,255,.06) !important;
        color: #fff !important;
    }
    .dido-sidebar .ds-item.active{
        background: rgba(217,40,229,.12) !important;
        color: var(--pro-magenta) !important;
    }
    .dido-sidebar .ds-item.active::before{
        content: '';
        position: absolute;
        left: -.5rem;
        top: 50%;
        transform: translateY(-50%);
        width: 3px;
        height: 22px;
        border-radius: 0 3px 3px 0;
        background: linear-gradient(180deg, var(--pro-magenta), var(--pro-purple));
    }
    .dido-sidebar .ds-item .dido-side-icon{
        width: 22px;
        height: 22px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .dido-sidebar .ds-item .dido-side-icon svg{
        width: 22px;
        height: 22px;
    }
    .dido-sidebar .ds-group{
        padding: 0 !important;
        margin: .55rem 0 !important;
        border: 0 !important;
        border-bottom: 1px solid rgba(255,255,255,.04) !important;
        padding-bottom: .55rem !important;
    }
    .dido-sidebar .ds-group:last-child{
        border-bottom: 0 !important;
    }

    /* Tooltip al hover en desktop */
    .dido-sidebar .ds-item::after{
        content: attr(data-label);
        position: absolute;
        left: calc(100% + 12px);
        top: 50%;
        transform: translateY(-50%);
        background: #1a1a1a;
        color: #fff;
        padding: .4rem .7rem;
        border-radius: 6px;
        font-size: .78rem;
        font-weight: 600;
        white-space: nowrap;
        border: 1px solid rgba(255,255,255,.08);
        box-shadow: 0 8px 24px rgba(0,0,0,.5);
        opacity: 0;
        pointer-events: none;
        transition: opacity .15s ease, transform .15s ease;
        transform: translateY(-50%) translateX(-4px);
        z-index: 200;
    }
    .dido-sidebar .ds-item:hover::after{
        opacity: 1;
        transform: translateY(-50%) translateX(0);
    }

    /* Layout: sidebar fijo 64px — body se desplaza a la derecha */
    body{
        padding-left: 0 !important;
        margin-left: 64px !important;
        box-sizing: border-box;
    }
    /* Topbar también desplazada (es position:fixed) */
    .dido-topbar{
        left: 64px !important;
    }
}

/* ─── Header de perfil ──────────────────────────────────────────────── */
.ds-header{
    display: flex;
    align-items: center;
    gap: .7rem;
    padding: .55rem .5rem;
    height: 52px;
    border-radius: 10px;
    text-decoration: none;
    color: var(--pro-text);
    margin-bottom: .85rem;
    background: linear-gradient(135deg, rgba(107,43,226,.12), rgba(217,40,229,.05));
    border: 1px solid rgba(217,40,229,.14);
    overflow: hidden;
    position: relative;
    transition: all .25s var(--pro-ease);
}
/* (consolidado en bloque anterior — desktop colapsado oculta todo extra) */
.ds-header::before{
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 0%, rgba(255,255,255,.06) 50%, transparent 100%);
    transform: translateX(-100%);
    transition: transform .8s var(--pro-ease);
}
.ds-header:hover{
    border-color: rgba(217,40,229,.4);
    transform: translateY(-1px);
    box-shadow: var(--shadow-glow-magenta);
}
.ds-header:hover::before{ transform: translateX(100%); }

.ds-avatar{
    position: relative;
    width: 38px; height: 38px;
    flex-shrink: 0;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta));
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: 1rem;
    color: #fff;
    box-shadow: 0 6px 18px rgba(217,40,229,.35);
}
.ds-avatar-initial{ position: relative; z-index: 2; }
.ds-avatar-ring{
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    border: 2px solid transparent;
    background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta)) border-box;
    -webkit-mask: linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: .5;
    animation: dsAvatarRing 3s linear infinite;
}
@keyframes dsAvatarRing{
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}
.ds-header-text{
    min-width: 0;
    flex: 1;
    opacity: 0;
    transition: opacity .2s var(--pro-ease) .1s;
}
.dido-sidebar:hover .ds-header-text,
.dido-sidebar.open .ds-header-text{ opacity: 1; }
.ds-header-name{
    font-size: .83rem;
    font-weight: 700;
    letter-spacing: -.01em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #fff;
}
.ds-header-balance{
    font-size: .68rem;
    color: var(--pro-magenta);
    font-weight: 600;
    margin-top: .15rem;
    display: flex;
    align-items: center;
    gap: .25rem;
    font-variant-numeric: tabular-nums;
}
.ds-header-balance svg{ flex-shrink: 0; }
.ds-header-balance span{ color: #fff; font-weight: 800; }

.ds-header-guest{
    background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta));
    border: 0;
    color: #fff;
}
.ds-header-guest .ds-header-name{ color: #fff; font-weight: 800; }
.ds-header-guest .ds-header-balance{ color: rgba(255,255,255,.85); font-weight: 600; }
.ds-header-arrow{ flex-shrink: 0; opacity: 0; transition: opacity .2s; }
.dido-sidebar:hover .ds-header-arrow{ opacity: 1; }

/* ─── Active indicator deslizante (estilo Discord) ──────────────────── */
.dido-sidebar-inner{
    position: relative !important;
}
.ds-active-indicator{
    position: absolute !important;
    left: -2px !important;
    width: 3px !important;
    max-width: 3px !important;
    height: 0 !important;
    border-radius: 0 4px 4px 0 !important;
    background: linear-gradient(180deg, var(--pro-magenta), var(--pro-purple)) !important;
    box-shadow: 0 0 8px rgba(217,40,229,.55) !important;
    transition: top .35s var(--spring), height .25s var(--pro-ease), opacity .2s ease !important;
    z-index: 5;
    pointer-events: none;
    opacity: 0;
    top: -100px !important;
}
/* Solo visible cuando sidebar está expandido (hover/open) */
.dido-sidebar:hover .ds-active-indicator.ready,
.dido-sidebar.open .ds-active-indicator.ready{
    opacity: 1;
    left: 0 !important;
}
@media (max-width: 768px){
    /* En mobile sidebar siempre se ve expandido cuando open */
    .dido-sidebar.open .ds-active-indicator.ready{
        opacity: 1 !important;
        left: 0 !important;
    }
}

/* ─── Group label ───────────────────────────────────────────────────── */
.ds-group-label{
    font-size: .58rem;
    font-weight: 800;
    letter-spacing: .14em;
    color: rgba(255,255,255,.32);
    padding: .55rem .65rem .35rem;
    text-transform: uppercase;
    opacity: 0;
    transition: opacity .2s var(--pro-ease) .15s;
    white-space: nowrap;
    overflow: hidden;
}
.dido-sidebar:hover .ds-group-label,
.dido-sidebar.open .ds-group-label{ opacity: 1; }

.ds-group{
    border-bottom: 0 !important;
    padding: .15rem 0 !important;
    margin-bottom: .25rem;
}

/* ─── Items (cuando active, sin border-left propio porque va el indicator) ─── */
.dido-sidebar .ds-item{
    position: relative;
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .58rem .6rem !important;
    margin: .12rem 0 !important;
    border-radius: 8px;
    color: rgba(255,255,255,.7) !important;
    transition: background .18s var(--pro-ease), color .18s var(--pro-ease), transform .18s var(--pro-ease);
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    text-decoration: none;
}
.dido-sidebar .ds-item .dido-side-icon{
    width: 22px; height: 22px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.dido-sidebar .ds-item .dido-side-icon svg{ width: 19px; height: 19px; }
.dido-sidebar .ds-item .dido-side-label{
    font-size: .82rem;
    font-weight: 500;
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    opacity: 0;
    transition: opacity .2s var(--pro-ease) .1s;
}
.dido-sidebar:hover .ds-item .dido-side-label,
.dido-sidebar.open .ds-item .dido-side-label{ opacity: 1; }

.dido-sidebar .ds-item:hover{
    background: rgba(255,255,255,.06) !important;
    color: #fff !important;
    transform: translateX(2px);
}
.dido-sidebar .ds-item.active{
    background: linear-gradient(90deg, rgba(217,40,229,.16), rgba(217,40,229,.02)) !important;
    color: #fff !important;
}
.dido-sidebar .ds-item.active .dido-side-icon{
    color: var(--pro-magenta);
}
.dido-sidebar .ds-item.active .dido-side-label{
    font-weight: 700;
}

/* ─── Item badges ───────────────────────────────────────────────────── */
.ds-item-badge{
    margin-left: auto;
    flex-shrink: 0;
    opacity: 0;
    transition: opacity .2s var(--pro-ease) .1s;
}
.dido-sidebar:hover .ds-item-badge,
.dido-sidebar.open .ds-item-badge{ opacity: 1; }
.ds-badge{
    display: inline-flex;
    align-items: center;
    gap: .25em;
    padding: .15em .42em;
    border-radius: 4px;
    font-size: .58rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    line-height: 1;
}
.ds-badge.live{
    background: rgba(229,9,20,.16);
    color: var(--pro-live);
    border: 1px solid rgba(229,9,20,.35);
}
.ds-badge.live .live-pulse{
    width: 6px; height: 6px;
    background: var(--pro-live);
    box-shadow: 0 0 0 0 rgba(229,9,20,.6);
    animation: live-pulse-anim 1.6s var(--pro-ease) infinite;
    margin: 0;
}
.ds-badge.gain{
    background: rgba(0,200,83,.14);
    color: var(--pro-success);
    border: 1px solid rgba(0,200,83,.3);
}
.ds-badge.new{
    background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta));
    color: #fff;
    border: 0;
    box-shadow: 0 0 14px rgba(217,40,229,.4);
}

/* ─── Sección Tendencias ────────────────────────────────────────────── */
.ds-trending{
    margin-top: 1rem;
    padding: 0 0 .5rem;
    border-top: 1px solid rgba(255,255,255,.05);
    padding-top: .85rem;
}
.ds-trending-chips{
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    padding: 0 .35rem;
    opacity: 0;
    transition: opacity .25s var(--pro-ease) .15s;
}
.dido-sidebar:hover .ds-trending-chips,
.dido-sidebar.open .ds-trending-chips{ opacity: 1; }
.ds-chip{
    display: inline-block;
    padding: .28rem .55rem;
    border-radius: 999px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    color: rgba(255,255,255,.75);
    font-size: .68rem;
    font-weight: 600;
    text-decoration: none;
    transition: all .18s var(--pro-ease);
    white-space: nowrap;
}
.ds-chip:hover{
    background: rgba(217,40,229,.18);
    border-color: rgba(217,40,229,.4);
    color: #fff;
    transform: translateY(-1px);
}

/* ─── Footer del sidebar ────────────────────────────────────────────── */
.ds-footer{
    margin-top: auto;
    padding: 1.5rem .65rem .35rem;
    font-size: .65rem;
    color: rgba(255,255,255,.3);
    display: flex;
    gap: .35rem;
    align-items: center;
    opacity: 0;
    transition: opacity .25s var(--pro-ease) .2s;
}
.dido-sidebar:hover .ds-footer,
.dido-sidebar.open .ds-footer{ opacity: 1; }
.ds-footer a{
    color: rgba(255,255,255,.5);
    text-decoration: none;
    transition: color .15s;
}
.ds-footer a:hover{ color: #fff; }
.ds-footer span{ color: rgba(255,255,255,.2); }

/* ─── Mobile sidebar drawer (limpio, todo visible) ──────────────────── */
@media (max-width: 768px){
    .dido-sidebar{
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        width: 86vw !important;
        max-width: 320px !important;
        min-width: 280px !important;
        background: #0a0a0a !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        border-right: 1px solid rgba(255,255,255,.06) !important;
        box-shadow: 12px 0 40px rgba(0,0,0,.6) !important;
        transform: translateX(-105%) !important;
        transition: transform .3s cubic-bezier(.65, 0, .35, 1) !important;
        z-index: 200 !important;
        padding-top: 0 !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
    }
    .dido-sidebar.open{
        transform: translateX(0) !important;
    }
    .dido-sidebar-inner{
        padding: calc(68px + 1rem) .85rem 2rem !important;
        width: 100% !important;
        height: auto !important;
        min-height: 100% !important;
    }

    /* Mobile: todo el contenido del sidebar se ve completo */
    .dido-sidebar .ds-header{
        display: flex !important;
        align-items: center;
        gap: .7rem;
        padding: 1rem .85rem !important;
        height: auto !important;
        min-height: 64px !important;
        margin: 0 0 1.2rem 0 !important;
        border-radius: 12px !important;
        text-decoration: none;
        flex-shrink: 0 !important;
        width: 100% !important;
        overflow: visible !important;
    }
    .dido-sidebar .ds-header.ds-header-guest{
        background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta)) !important;
        color: #fff !important;
    }
    .dido-sidebar .ds-header-arrow{
        opacity: 1 !important;
        flex-shrink: 0;
    }
    .dido-sidebar .ds-header-text{
        opacity: 1 !important;
        flex: 1;
        min-width: 0;
    }
    .dido-sidebar .ds-header-name{
        font-size: .9rem;
        font-weight: 700;
        color: #fff;
        margin-bottom: .15rem;
    }
    .dido-sidebar .ds-header-balance{
        font-size: .72rem;
        opacity: .85;
    }
    .dido-sidebar .ds-group-label{
        display: block !important;
        opacity: 1 !important;
        padding: .65rem .65rem .35rem !important;
        font-size: .62rem;
        font-weight: 800;
        letter-spacing: .14em;
        color: rgba(255,255,255,.32);
        text-transform: uppercase;
    }
    .dido-sidebar .ds-trending,
    .dido-sidebar .ds-footer{
        display: block !important;
    }
    .dido-sidebar .ds-trending-chips{
        opacity: 1 !important;
        display: flex !important;
        flex-wrap: wrap;
        gap: .35rem;
        padding: 0 .65rem;
    }
    .dido-sidebar .ds-footer{
        opacity: 1 !important;
        margin-top: 1rem;
        padding: 1rem .65rem 0;
        border-top: 1px solid rgba(255,255,255,.06);
    }
    .dido-sidebar .ds-item{
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        padding: .75rem .65rem !important;
        gap: .85rem !important;
        height: auto !important;
        margin: .1rem 0 !important;
        border-radius: 10px !important;
        color: rgba(255,255,255,.75) !important;
    }
    .dido-sidebar .ds-item .dido-side-label{
        display: inline-block !important;
        opacity: 1 !important;
        font-size: .9rem;
        font-weight: 500;
    }
    .dido-sidebar .ds-item.active{
        background: linear-gradient(90deg, rgba(217,40,229,.18), rgba(217,40,229,.04)) !important;
        color: #fff !important;
    }
    .dido-sidebar .ds-item.active .dido-side-icon{
        color: var(--pro-magenta);
    }
    .dido-sidebar .ds-item.active::before{
        display: none !important;
    }
    .dido-sidebar .ds-item-badge{
        display: inline-flex !important;
        margin-left: auto;
        opacity: 1 !important;
    }
    /* No tooltips en mobile */
    .dido-sidebar .ds-item::after{
        display: none !important;
    }

    /* Backdrop SIN blur — solo dim oscuro sutil */
    .ds-backdrop{
        z-index: 195 !important;
        background: rgba(0,0,0,.55) !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
    body.sidebar-open{
        overflow: hidden;
        position: fixed;
        width: 100%;
    }
    body.sidebar-open .home-cinema,
    body.sidebar-open main{
        filter: none !important;
        transform: none !important;
        pointer-events: none;
    }
    body.sidebar-open .dido-topbar{
        z-index: 210 !important;
        pointer-events: auto !important;
    }
    /* Cuando drawer abierto: ocultar bottom-nav y FAB */
    body.sidebar-open .dp-bottom-nav,
    body.sidebar-open .dp-fab{
        opacity: 0 !important;
        pointer-events: none !important;
        transition: opacity .2s ease !important;
    }
    .dido-sidebar .ds-item .dido-side-label,
    .dido-sidebar .ds-header-text,
    .dido-sidebar .ds-group-label,
    .dido-sidebar .ds-item-badge,
    .dido-sidebar .ds-trending-chips,
    .dido-sidebar .ds-footer{
        opacity: 1 !important;
    }
    /* Active indicator: en mobile el sidebar siempre tiene labels visibles, ajustar */
    .ds-active-indicator{
        opacity: 1 !important;
    }
    /* Backdrop overlay cuando sidebar está open */
    .dido-sidebar.open + .ds-backdrop{
        opacity: 1;
        pointer-events: auto;
    }
    /* Topbar mobile: más compacta */
    .dido-topbar{
        padding: 0 .75rem !important;
    }
    /* Esconder search trigger en mobile (existe el botón Buscar en bottom nav) */
    .dido-search-trigger{
        display: none !important;
    }
}
.ds-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.6);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 89;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s var(--pro-ease);
}

/* ─── Logo glitch hover (sutil RGB split) ───────────────────────────── */
.dido-brand{
    transition: transform .2s var(--pro-ease);
}
.dido-brand:hover{
    transform: scale(1.02);
}
.dido-brand-text{
    position: relative;
    transition: text-shadow .25s var(--pro-ease);
}
.dido-brand:hover .dido-brand-text{
    text-shadow:
        -1px 0 0 var(--pro-magenta),
         1px 0 0 var(--pro-purple),
         0 0 12px rgba(217,40,229,.4);
    animation: dsGlitch .35s var(--pro-ease);
}
@keyframes dsGlitch{
    0%   { transform: translate(0); }
    20%  { transform: translate(-1px, 0); }
    40%  { transform: translate(1px, 0); }
    60%  { transform: translate(-1px, 0); }
    80%  { transform: translate(0, 1px); }
    100% { transform: translate(0); }
}
.dido-brand-plus{
    transition: filter .25s, transform .25s;
}
.dido-brand:hover .dido-brand-plus{
    filter: drop-shadow(0 0 8px rgba(217,40,229,.7));
    transform: rotate(-8deg) scale(1.1);
}
/* Idle glitch automático cada cierto tiempo */
.dido-brand.idle-glitch .dido-brand-text{
    animation: dsGlitch .35s var(--pro-ease);
    text-shadow:
        -1px 0 0 var(--pro-magenta),
         1px 0 0 var(--pro-purple);
}

/* ═══════════════════════════════════════════════════════════════════════
   FASE β — MOBILE-FIRST PREMIUM
   ═══════════════════════════════════════════════════════════════════════ */

/* Mobile: sin sidebar fijo, sin bottom-nav */
@media (max-width: 768px){
    body{
        padding-bottom: env(safe-area-inset-bottom) !important;
        padding-left: 0 !important;
    }
    .dido-topbar{
        left: 0 !important;
    }
}

/* ─── BOTTOM NAV — minimal, solo iconos + labels ───────────────────── */
.dp-bottom-nav{
    display: none !important;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 95;
    background: #0a0a0a;
    border-top: 1px solid rgba(255,255,255,.08);
    padding: .25rem .25rem calc(.35rem + env(safe-area-inset-bottom));
    height: calc(58px + env(safe-area-inset-bottom));
}
@media (max-width: 768px){
    .dp-bottom-nav{
        display: flex !important;
        align-items: stretch;
        gap: 0;
    }
}

/* Pill OCULTA — el active state se muestra solo con color del ícono */
.dp-nav-pill{
    display: none !important;
}

.dp-nav-item{
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: rgba(255,255,255,.5);
    padding: .25rem .15rem;
    transition: color .15s ease;
    position: relative;
    -webkit-tap-highlight-color: transparent;
    overflow: hidden;
}
.dp-nav-item:active{
    transform: scale(.92);
}
.dp-nav-icon{
    width: 22px;
    height: 22px;
    display: grid;
    place-items: center;
    transition: transform .15s ease;
}
.dp-nav-icon svg{ width: 22px; height: 22px; }
.dp-nav-label{
    font-size: .62rem !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    word-spacing: 0 !important;
    margin-top: .25rem !important;
    text-transform: none !important;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.1;
}
.dp-nav-item.active{
    color: var(--pro-magenta);
}
.dp-nav-item.active .dp-nav-icon{
    color: var(--pro-magenta);
}
.dp-nav-item.active .dp-nav-label{
    color: var(--pro-magenta);
    font-weight: 700;
}

/* Dot indicator (live) */
.dp-nav-dot{
    position: absolute;
    top: .35rem;
    right: 32%;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--pro-live);
    box-shadow: 0 0 0 2px rgba(8,8,12,.85);
    animation: live-pulse-anim 1.6s var(--pro-ease) infinite;
}

/* Badge numeric (D-Credits ganados hoy) */
.dp-nav-badge{
    position: absolute;
    top: .25rem;
    right: 18%;
    background: var(--pro-success);
    color: #000;
    font-size: .55rem;
    font-weight: 900;
    padding: .1rem .3rem;
    border-radius: 6px;
    line-height: 1;
    box-shadow: 0 2px 8px rgba(0,200,83,.4);
}

/* ─── FAB (Floating Action Button) ─────────────────────────────────── */
.dp-fab{
    position: fixed;
    right: 1rem;
    bottom: calc(80px + env(safe-area-inset-bottom));
    z-index: 94;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    border: 0;
    background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta));
    color: #fff;
    cursor: pointer;
    display: grid;
    place-items: center;
    box-shadow:
        0 14px 36px rgba(217,40,229,.45),
        0 0 0 0 rgba(217,40,229,.6);
    transition: transform .25s var(--spring), box-shadow .25s var(--pro-ease);
    -webkit-tap-highlight-color: transparent;
}
.dp-fab:active{ transform: scale(.92); }
.dp-fab:hover{
    transform: scale(1.08);
    box-shadow: 0 18px 44px rgba(217,40,229,.55);
}
@media (max-width: 768px){
    .dp-fab{ display: grid; }
}
@media (min-width: 769px){
    .dp-fab{ display: none; }
}
/* Pulso decorativo del FAB */
.dp-fab-pulse{
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    border: 2px solid rgba(217,40,229,.6);
    pointer-events: none;
    animation: dpFabPulse 2.2s var(--pro-ease) infinite;
}
@keyframes dpFabPulse{
    0%   { transform: scale(.96); opacity: .9; }
    70%  { transform: scale(1.35); opacity: 0; }
    100% { transform: scale(1.45); opacity: 0; }
}

/* ─── BOTTOM SHEET (componente reutilizable) ───────────────────────── */
.dp-sheet-backdrop{
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s var(--pro-ease);
}
.dp-sheet-backdrop.open{
    opacity: 1;
    pointer-events: auto;
}
.dp-sheet{
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 201;
    background: linear-gradient(180deg, var(--pro-surface-2), var(--pro-black));
    border-top-left-radius: 22px;
    border-top-right-radius: 22px;
    border-top: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 -24px 80px rgba(0,0,0,.7);
    transform: translateY(100%);
    transition: transform .45s var(--spring-snappy);
    max-height: 88vh;
    overflow-y: auto;
    padding-bottom: env(safe-area-inset-bottom);
    overscroll-behavior: contain;
}
.dp-sheet.open{
    transform: translateY(0);
}
.dp-sheet-handle{
    width: 38px;
    height: 4px;
    border-radius: 4px;
    background: rgba(255,255,255,.18);
    margin: .65rem auto;
}
.dp-sheet-header{
    padding: .35rem 1.25rem 0;
}
.dp-sheet-header h3{
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: -.015em;
    margin: 0;
    color: #fff;
}
.dp-sheet-body{
    padding: 1rem 1.25rem 1.5rem;
}

/* ─── SWIPE NATIVO en carruseles (scroll-snap mejorado) ────────────── */
@media (max-width: 768px){
    .dh-rail-track,
    [class*="-rail-track"],
    [class*="rail-track"]{
        scroll-snap-type: x mandatory !important;
        -webkit-overflow-scrolling: touch !important;
        overscroll-behavior-x: contain;
        scroll-padding-left: 4vw;
        scroll-padding-right: 4vw;
    }
    .dh-rail-track > *,
    [class*="-rail-track"] > *{
        scroll-snap-align: start;
        scroll-snap-stop: always;
    }
}

/* ─── PULL TO REFRESH indicator ────────────────────────────────────── */
.dp-ptr{
    position: fixed;
    top: 0;
    left: 50%;
    transform: translate(-50%, -100%);
    z-index: 110;
    width: 44px;
    height: 44px;
    background: rgba(15,15,20,.92);
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(20px);
    box-shadow: 0 12px 30px rgba(0,0,0,.5);
    display: grid;
    place-items: center;
    color: var(--pro-magenta);
    transition: transform .2s var(--pro-ease);
    pointer-events: none;
}
.dp-ptr.visible{
    transform: translate(-50%, calc(var(--ptr-y, 60px) - 50px));
}
.dp-ptr.refreshing{
    transform: translate(-50%, 14px);
}
.dp-ptr svg{
    width: 22px;
    height: 22px;
    transform: rotate(var(--ptr-rotate, 0deg));
    transition: transform .15s linear;
}
.dp-ptr.refreshing svg{
    animation: dpPtrSpin 1s linear infinite;
}
@keyframes dpPtrSpin{
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* ─── Esconder sidebar desktop en mobile (drawer ya cubre eso) ──────── */
@media (max-width: 768px){
    .dp-bottom-nav,
    .dp-fab{ display: flex; }
}

/* ═══════════════════════════════════════════════════════════════════════
   FASE γ — ANIMACIONES GLOBALES (utilities aplicadas por JS)
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── γ.1 TILT 3D en cards (clase data-tilt) ───────────────────────── */
[data-tilt]{
    transform-style: preserve-3d;
    transition: transform .25s var(--pro-ease);
    will-change: transform;
}
[data-tilt]:hover{
    transform: perspective(1000px) rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg)) translateZ(8px);
}
[data-tilt] > *{ transform: translateZ(0); }

/* Glare effect opcional */
[data-tilt][data-tilt-glare]::after{
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(125deg,
        rgba(255,255,255,0) 30%,
        rgba(255,255,255,.18) 50%,
        rgba(255,255,255,0) 70%);
    opacity: 0;
    transition: opacity .25s var(--pro-ease);
    pointer-events: none;
    transform: translateX(var(--tilt-glare-x, -30%));
}
[data-tilt][data-tilt-glare]:hover::after{
    opacity: 1;
}

/* ─── γ.1 FILTER PILLS con morph activo ────────────────────────────── */
.dp-filter-bar{
    display: flex;
    gap: .5rem;
    overflow-x: auto;
    padding: .25rem 0 .75rem;
    scrollbar-width: none;
}
.dp-filter-bar::-webkit-scrollbar{ display: none; }
.dp-filter-pill{
    flex: 0 0 auto;
    padding: .5rem 1rem;
    border-radius: 999px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    color: var(--pro-text-muted);
    font-size: .8rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all .25s var(--spring);
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    white-space: nowrap;
}
.dp-filter-pill:hover{
    background: rgba(255,255,255,.1);
    color: #fff;
    transform: translateY(-1px);
}
.dp-filter-pill.active{
    background: linear-gradient(135deg, var(--pro-purple), var(--pro-magenta));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 8px 24px rgba(217,40,229,.3);
    transform: scale(1.05);
}

/* ─── γ.2 GLOW CARDS (planes de suscripción, etc.) ─────────────────── */
[data-glow-card]{
    position: relative;
    transition: transform .35s var(--pro-ease-out);
}
[data-glow-card]::before{
    content: '';
    position: absolute;
    inset: -2px;
    border-radius: inherit;
    padding: 2px;
    background: conic-gradient(
        from var(--glow-angle, 0deg),
        var(--pro-magenta),
        var(--pro-purple),
        transparent 60%,
        var(--pro-magenta));
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: 0;
    transition: opacity .35s var(--pro-ease);
    pointer-events: none;
    animation: dpGlowRotate 6s linear infinite paused;
}
[data-glow-card]:hover::before{
    opacity: 1;
    animation-play-state: running;
}
@property --glow-angle{
    syntax: '<angle>';
    initial-value: 0deg;
    inherits: false;
}
@keyframes dpGlowRotate{
    from { --glow-angle: 0deg; }
    to   { --glow-angle: 360deg; }
}
[data-glow-card]:hover{
    transform: translateY(-4px);
}

/* ─── γ.3 COUNT-UP / TABULAR-NUMS (data-count) ──────────────────────── */
[data-count]{
    font-variant-numeric: tabular-nums;
    font-feature-settings: 'tnum' 1;
}

/* ─── γ.3 PROGRESS RING SVG ────────────────────────────────────────── */
.dp-ring{
    position: relative;
    width: 88px;
    height: 88px;
    display: inline-grid;
    place-items: center;
}
.dp-ring svg{
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}
.dp-ring-track{
    fill: none;
    stroke: rgba(255,255,255,.08);
    stroke-width: 4;
}
.dp-ring-fill{
    fill: none;
    stroke: url(#dpRingGradient);
    stroke-width: 4;
    stroke-linecap: round;
    stroke-dasharray: var(--ring-circ, 270);
    stroke-dashoffset: var(--ring-circ, 270);
    transition: stroke-dashoffset 1.4s var(--pro-ease-out);
}
.dp-ring.animated .dp-ring-fill{
    stroke-dashoffset: calc(var(--ring-circ, 270) * (1 - var(--ring-pct, 0)));
}
.dp-ring-text{
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    font-weight: 800;
    font-size: 1.15rem;
    letter-spacing: -.02em;
    color: #fff;
}

/* ─── γ.4 EQUALIZER REAL (CSS animado) ──────────────────────────────── */
.dp-equalizer{
    display: inline-flex;
    align-items: flex-end;
    gap: 2px;
    width: 16px;
    height: 14px;
}
.dp-equalizer span{
    flex: 1;
    background: linear-gradient(180deg, var(--pro-magenta), var(--pro-purple));
    border-radius: 1px;
    animation: dpEqBar 1s var(--pro-ease) infinite;
}
.dp-equalizer span:nth-child(1){ animation-delay: -.6s; }
.dp-equalizer span:nth-child(2){ animation-delay: -.3s; }
.dp-equalizer span:nth-child(3){ animation-delay: -.9s; }
.dp-equalizer span:nth-child(4){ animation-delay: -.45s; }
@keyframes dpEqBar{
    0%, 100% { height: 25%; }
    50%      { height: 100%; }
}

/* ─── γ.5 AUTH gradient mesh background ─────────────────────────────── */
.dp-mesh-bg{
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    overflow: hidden;
    background: var(--pro-black);
}
.dp-mesh-bg::before,
.dp-mesh-bg::after{
    content: '';
    position: absolute;
    width: 60vw;
    height: 60vw;
    border-radius: 50%;
    filter: blur(120px);
    opacity: .4;
    animation: dpMeshFloat 20s var(--pro-ease) infinite alternate;
}
.dp-mesh-bg::before{
    background: radial-gradient(circle, var(--pro-purple), transparent 70%);
    top: -10vw;
    left: -10vw;
}
.dp-mesh-bg::after{
    background: radial-gradient(circle, var(--pro-magenta), transparent 70%);
    bottom: -15vw;
    right: -10vw;
    animation-delay: -10s;
}
@keyframes dpMeshFloat{
    0%   { transform: translate(0, 0) scale(1); }
    50%  { transform: translate(5%, -8%) scale(1.15); }
    100% { transform: translate(-5%, 8%) scale(.9); }
}

/* ─── γ.5 INPUT GLOW al focus ──────────────────────────────────────── */
input.dp-premium,
textarea.dp-premium,
.dp-form-field{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 10px;
    color: #fff;
    padding: .7rem .9rem;
    font: inherit;
    transition: all .25s var(--pro-ease);
    width: 100%;
}
input.dp-premium:focus,
textarea.dp-premium:focus,
.dp-form-field:focus,
input:focus.dp-premium-target,
textarea:focus.dp-premium-target{
    background: rgba(255,255,255,.07);
    border-color: var(--pro-magenta);
    box-shadow:
        0 0 0 4px rgba(217,40,229,.12),
        0 0 28px rgba(217,40,229,.18);
    outline: none;
}
input.dp-premium::placeholder,
textarea.dp-premium::placeholder{ color: rgba(255,255,255,.35); }

/* ─── γ.6 EMPTY STATES con line-draw SVG ───────────────────────────── */
.dp-empty{
    display: grid;
    place-items: center;
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--pro-text-muted);
}
.dp-empty-illu{
    width: 120px;
    height: 120px;
    margin-bottom: 1.2rem;
    color: rgba(217,40,229,.35);
}
.dp-empty-illu path,
.dp-empty-illu circle,
.dp-empty-illu rect,
.dp-empty-illu line,
.dp-empty-illu polyline{
    fill: none;
    stroke: currentColor;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 220;
    stroke-dashoffset: 220;
    animation: dpDraw 2s var(--pro-ease-out) forwards;
}
.dp-empty-illu *:nth-child(2){ animation-delay: .3s; }
.dp-empty-illu *:nth-child(3){ animation-delay: .6s; }
.dp-empty-illu *:nth-child(4){ animation-delay: .9s; }
@keyframes dpDraw{
    to { stroke-dashoffset: 0; }
}
.dp-empty h3{
    font-size: 1.2rem;
    font-weight: 800;
    color: #fff;
    margin: 0 0 .4rem;
    letter-spacing: -.02em;
}
.dp-empty p{
    max-width: 360px;
    font-size: .9rem;
    line-height: 1.55;
    margin: 0 0 1.2rem;
}

/* ═══════════════════════════════════════════════════════════════════════
   FASE δ — EFECTOS WOW
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── δ.1 MAGNETIC BUTTONS (data-magnetic) ────────────────────────── */
[data-magnetic]{
    transition: transform .35s var(--spring);
    will-change: transform;
}

/* ─── δ.1 CURSOR custom (visible solo en desktop con mouse fino) ───── */
.dp-cursor-dot,
.dp-cursor-ring{
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%, -50%);
    will-change: transform;
}
.dp-cursor-dot{
    width: 6px;
    height: 6px;
    background: var(--pro-magenta);
    border-radius: 50%;
    box-shadow: 0 0 12px rgba(217,40,229,.7);
    transition: transform .08s linear, opacity .2s;
}
.dp-cursor-ring{
    width: 32px;
    height: 32px;
    border: 1.5px solid rgba(217,40,229,.55);
    border-radius: 50%;
    transition: transform .15s var(--pro-ease), width .25s var(--pro-ease), height .25s var(--pro-ease), border-color .2s, opacity .2s;
}
.dp-cursor-ring.hover{
    width: 48px;
    height: 48px;
    border-color: var(--pro-magenta);
    background: rgba(217,40,229,.06);
}
@media (hover: none), (pointer: coarse){
    .dp-cursor-dot, .dp-cursor-ring{ display: none !important; }
}

/* Esconder cursor nativo cuando custom está activo */
body.dp-has-custom-cursor,
body.dp-has-custom-cursor *{
    cursor: none !important;
}
@media (hover: none), (pointer: coarse){
    body.dp-has-custom-cursor,
    body.dp-has-custom-cursor *{ cursor: auto !important; }
}

/* ─── δ.2 PARTICLE/ORB BACKGROUND (clase dp-orbs en una vista) ───── */
.dp-orbs{
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
.dp-orb{
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: .35;
    animation: dpOrbFloat var(--orb-dur, 18s) var(--pro-ease) infinite;
}
@keyframes dpOrbFloat{
    0%, 100% { transform: translate(0,0) scale(1); }
    33%      { transform: translate(8%, -10%) scale(1.15); }
    66%      { transform: translate(-6%, 8%) scale(.9); }
}

/* ─── δ.3 LOADING BAR superior (estilo NProgress) ─────────────────── */
.dp-progress{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: transparent;
    z-index: 9998;
    pointer-events: none;
}
.dp-progress-fill{
    height: 100%;
    background: linear-gradient(90deg, var(--pro-purple), var(--pro-magenta));
    width: 0%;
    box-shadow: 0 0 10px rgba(217,40,229,.6);
    transition: width .25s var(--pro-ease);
}
.dp-progress-fill.indeterminate{
    width: 30%;
    animation: dpProgressIndet 1.2s var(--pro-ease) infinite;
}
@keyframes dpProgressIndet{
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(400%); }
}

/* ─── δ.3 CONFETTI (CSS pura, lanzar con clase .firing) ──────────── */
.dp-confetti{
    position: fixed;
    inset: 0;
    z-index: 9997;
    pointer-events: none;
    overflow: hidden;
}
.dp-confetti-piece{
    position: absolute;
    top: -20px;
    width: 8px;
    height: 14px;
    border-radius: 2px;
    opacity: 0;
    animation: dpConfetti 2.6s var(--pro-ease-out) forwards;
}
@keyframes dpConfetti{
    0%   { opacity: 1; transform: translate(0, 0) rotate(0deg); }
    100% { opacity: 0; transform: translate(var(--confetti-x, 0), 110vh) rotate(var(--confetti-r, 720deg)); }
}

/* Reduced motion safety FASE γ+δ */
@media (prefers-reduced-motion: reduce){
    [data-tilt]:hover{ transform: none !important; }
    [data-glow-card]::before{ animation: none !important; }
    .dp-mesh-bg::before, .dp-mesh-bg::after{ animation: none !important; }
    .dp-empty-illu *{ animation: none !important; stroke-dashoffset: 0 !important; }
    .dp-equalizer span{ animation: none !important; height: 60% !important; }
    .dp-cursor-dot, .dp-cursor-ring{ display: none !important; }
    .dp-orb{ animation: none !important; }
}

/* ═══════════════════════════════════════════════════════════════════════
   Reduced motion safety
   ═══════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce){
    .ds-avatar-ring{ animation: none !important; }
    .ds-header::before{ display: none; }
    .ds-active-indicator{ transition: none !important; }
    .dido-brand:hover .dido-brand-text{ animation: none !important; }
}
