/* ============================================================================
 * Extra Archivet — Components (Design System)
 * ----------------------------------------------------------------------------
 * Classi ds-* condivise dalla Suite Archivet.
 * Allineate al Design System di Extra.Archivet.IDP (theme.css).
 *
 * Le vecchie classi as-* (card, btn, tag, suite chrome) sono mantenute
 * come alias visivi sopra ai token DS, così Hub e MainLayout.razor
 * continuano a funzionare senza riscritture.
 * ========================================================================== */

/* ---- BASE su app-shell ---- */
.app-shell *,
.app-shell *::before,
.app-shell *::after { box-sizing: border-box; }

body.app-shell,
.app-shell body {
    font-family: var(--font-sans);
    background: var(--bg);
    color: var(--text);
    margin: 0;
    min-height: 100vh;
}

/*
 * Link reset usando :where() per specificità zero:
 * così qualunque componente che è un <a> (ds-btn, ds-app-tile, ds-article-card,
 * ds-article-row, ds-news-nav__item, ds-link-list a, ds-filterbar__chip)
 * può ridefinire colore/decoration senza dover combattere con la regola generale.
 */
.app-shell :where(a) { color: var(--accent2); text-decoration: none; }
.app-shell :where(a):hover { color: var(--accent); text-decoration: underline; }

/* Heading: H1 in DM Serif Display, gli altri DM Sans (regola firma DS). */
.app-shell h1 {
    font-family: var(--font-display);
    color: var(--text);
    font-weight: 400;
    margin: 0 0 .5rem;
    line-height: var(--leading-tight);
}

.app-shell h2,
.app-shell h3,
.app-shell h4 {
    font-family: var(--font-sans);
    color: var(--text);
    font-weight: 600;
    margin: 0 0 .5rem;
    line-height: 1.25;
}

.app-shell hr { border: none; border-top: 1px solid var(--border); margin: 1rem 0; }

/* ---- FOCUS RING firma (oro) ---- */
.app-shell :focus-visible {
    outline: 2px solid var(--gold);
    outline-offset: 2px;
    border-radius: 4px;
    box-shadow: var(--shadow-focus);
}

/* ---- CARD ---- */
.ds-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    padding: var(--space-6);
    margin-bottom: var(--space-5);
}

.ds-card .ds-card-title {
    font-family: var(--font-sans);
    font-weight: 600;
    color: var(--text);
    font-size: var(--text-xl);
    margin: 0 0 var(--space-1);
}

.ds-card .ds-card-subtitle {
    font-size: var(--text-sm);
    color: var(--text2);
    margin: 0 0 var(--space-4);
}

.ds-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

/* ---- BUTTONS ---- */
.ds-btn {
    padding: .5rem 1.15rem;
    border-radius: var(--radius-sm);
    border: none;
    font-family: var(--font-sans);
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    text-decoration: none;
    line-height: 1.2;
}

.ds-btn:active:not(:disabled) { transform: scale(.97); }
.ds-btn:disabled { opacity: .45; cursor: not-allowed; }

.ds-btn-primary {
    background: var(--accent2);
    color: #fff;
    box-shadow: 0 2px 8px rgba(245,130,32,.25);
}
.ds-btn-primary:hover { background: var(--accent); color: #fff; box-shadow: 0 4px 12px rgba(245,130,32,.30); }

.ds-btn-ghost {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text2);
}
.ds-btn-ghost:hover { background: var(--bg2); color: var(--text); }

.ds-btn-gold { background: var(--gold); color: #1c1917; }
.ds-btn-gold:hover { filter: brightness(.93); color: #1c1917; }

.ds-btn-danger { background: var(--danger); color: #fff; }
.ds-btn-danger:hover { background: #7f1d1d; color: #fff; }

.ds-btn-sm { padding: 4px 10px; font-size: var(--text-sm); line-height: 1.2; }
.ds-btn-lg { padding: .7rem 1.6rem; font-size: .95rem; }

/* ---- BADGE ---- */
.ds-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .15rem .55rem;
    border-radius: var(--radius-pill);
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: 1.4;
    border: 1px solid transparent;
    white-space: nowrap;
}

.ds-badge-success { background: var(--success-light); color: var(--success); border-color: color-mix(in srgb, var(--success) 30%, transparent); }
.ds-badge-info    { background: var(--info-light);    color: var(--info);    border-color: color-mix(in srgb, var(--info) 30%, transparent); }
.ds-badge-danger  { background: var(--danger-light);  color: var(--danger);  border-color: color-mix(in srgb, var(--danger) 25%, transparent); }
.ds-badge-warning { background: var(--warning-light); color: var(--warning); border-color: color-mix(in srgb, var(--warning) 30%, transparent); }
.ds-badge-neutral { background: var(--bg2); color: var(--text2); border-color: var(--border); }

/* ---- TABLE ---- */
.ds-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
    background: var(--surface);
}

.ds-table thead th {
    text-align: left;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text2);
    background: var(--bg2);
    padding: .7rem 1rem;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
}

.ds-table tbody td {
    padding: .65rem 1rem;
    border-bottom: 1px solid var(--border);
    color: var(--text);
    vertical-align: middle;
}

.ds-table tbody tr:last-child td { border-bottom: none; }
.ds-table tbody tr { transition: background var(--transition); }
.ds-table tbody tr:hover { background: var(--bg2); }

/* ---- ALERT ---- */
.ds-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius);
    border-left: 4px solid;
    font-size: var(--text-sm);
    margin-bottom: var(--space-4);
    background: var(--surface);
}
.ds-alert i { font-size: 1.05rem; flex-shrink: 0; margin-top: 2px; }
.ds-alert-success { background: var(--success-light); border-color: var(--success); color: var(--success); }
.ds-alert-warning { background: var(--warning-light); border-color: var(--warning); color: var(--warning); }
.ds-alert-danger  { background: var(--danger-light);  border-color: var(--danger);  color: var(--danger); }
.ds-alert-info    { background: var(--info-light);    border-color: var(--info);    color: var(--info); }

/* ---- PAGE HEADER (titolo pagina + linea oro firma) ---- */
.ds-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-4);
    padding-bottom: var(--space-5);
    margin-bottom: var(--space-6);
    border-bottom: 1px solid var(--border);
}

.ds-page-header-text { flex: 1 1 auto; min-width: 0; }

.ds-page-header h1 {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: var(--text-3xl);
    line-height: var(--leading-tight);
    margin: 0 0 var(--space-2);
    color: var(--text);
    display: block;
}

.ds-page-header h1::after {
    content: "";
    display: block;
    width: 40px;
    height: 2px;
    background: var(--gold);
    border-radius: 2px;
    margin-top: var(--space-3);
}

.ds-page-header p {
    margin: 0;
    color: var(--text2);
    font-size: var(--text-base);
    max-width: 720px;
}

.ds-page-header-actions {
    display: flex;
    gap: var(--space-2);
    align-items: center;
    flex-wrap: wrap;
    flex-shrink: 0;
}

@media (max-width: 600px) {
    .ds-page-header h1 { font-size: var(--text-2xl); }
}

/* ---- EMPTY STATE ---- */
.ds-empty-state {
    text-align: center;
    padding: var(--space-12) var(--space-6);
    color: var(--text2);
}

.ds-empty-state .ds-empty-icon {
    font-size: 2.5rem;
    color: var(--text3);
    margin-bottom: var(--space-3);
    display: block;
}

.ds-empty-state h3 {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--text-lg);
    color: var(--text2);
    margin: 0 0 var(--space-2);
}

.ds-empty-state p {
    color: var(--text3);
    font-size: var(--text-sm);
    margin: 0 auto var(--space-5);
    max-width: 420px;
}

/* ---- FORM GRID ---- */
.ds-form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

.ds-form-grid > .ds-col-full { grid-column: 1 / -1; }

@media (max-width: 600px) {
    .ds-form-grid { grid-template-columns: 1fr; }
}

.ds-field { display: flex; flex-direction: column; gap: var(--space-1); }
.ds-field label,
.ds-field .form-label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--text2);
    margin: 0;
}
.ds-field-help { font-size: var(--text-xs); color: var(--text3); }

/* ---- ANIMATIONS ---- */
@keyframes ds-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes ds-slide-up {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

.ds-anim-fade-in  { animation: ds-fade-in  var(--dur-3) var(--ease) both; }
.ds-anim-slide-up { animation: ds-slide-up var(--dur-3) var(--ease) both; }

/* ---- TOAST ---- */
.ds-toast-stack {
    position: fixed;
    top: var(--space-5);
    right: var(--space-5);
    z-index: 9500;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    max-width: calc(100vw - var(--space-10));
    pointer-events: none;
}

.ds-toast {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    min-width: 280px;
    max-width: 380px;
    padding: var(--space-3) var(--space-4);
    background: var(--surface);
    color: var(--text);
    border-radius: var(--radius);
    border: 1px solid var(--border);
    border-left: 4px solid var(--steel);
    box-shadow: var(--shadow-lg);
    font-size: var(--text-sm);
    line-height: 1.4;
    pointer-events: auto;
}
.ds-toast-success { border-left-color: var(--success); }
.ds-toast-warning { border-left-color: var(--warning); }
.ds-toast-danger  { border-left-color: var(--danger); }
.ds-toast-info    { border-left-color: var(--info); }

/* ---- FOOTER ---- */
.ds-footer {
    text-align: center;
    padding: 1.25rem 1rem;
    color: var(--text3);
    font-size: var(--text-xs);
    border-top: 1px solid var(--border);
    margin-top: var(--space-8);
}
.ds-footer a { color: var(--text2); }

/* ============================================================================
 * Alias retrocompatibili (legacy as-*)
 * Mantenuti per non rompere ArchivetHub e MainLayout.razor che li usano.
 * Mappano lo stile sui token semantici del DS.
 * ========================================================================== */

.as-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-4);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--dur-2) var(--ease);
}
.as-card:hover { box-shadow: var(--shadow-md); }

.as-card__title {
    font-size: var(--text-lg);
    font-weight: 600;
    line-height: var(--leading-tight);
    margin: 0 0 var(--space-2) 0;
    color: var(--text);
}

.as-card__subtitle {
    font-size: var(--text-sm);
    color: var(--text2);
    margin: 0 0 var(--space-3) 0;
}

.as-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: 500;
    line-height: var(--leading-tight);
    border-radius: var(--radius-sm);
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: background-color var(--dur-1) var(--ease),
                border-color var(--dur-1) var(--ease);
}

.as-btn--primary { background: var(--accent2); color: #fff; }
.as-btn--primary:hover { background: var(--accent); color: #fff; }

.as-btn--ghost {
    background: transparent;
    color: var(--accent);
    border-color: var(--border);
}
.as-btn--ghost:hover { background: var(--bg2); border-color: var(--accent2); }

.as-tag {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    font-weight: 600;
    border-radius: var(--radius-pill);
    background: var(--accent-light);
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.as-tag--warning { background: var(--warning-light); color: var(--warning); }
.as-tag--danger  { background: var(--danger-light);  color: var(--danger); }
.as-tag--success { background: var(--success-light); color: var(--success); }
.as-tag--info    { background: var(--info-light);    color: var(--info); }

/* Suite chrome legacy: ricolorato sui token DS */
.as-suite-header {
    display: flex;
    align-items: center;
    height: var(--as-header-height);
    padding: 0 var(--space-5);
    background: linear-gradient(135deg, var(--steel-dark) 0%, var(--steel) 100%);
    color: #fff;
    border-bottom: 1px solid var(--border);
}

.as-suite-header__brand {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.as-suite-header__title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    color: #fff;
    letter-spacing: .02em;
}

.as-suite-footer {
    padding: var(--space-4) var(--space-5);
    border-top: 1px solid var(--border);
    background: var(--bg2);
    color: var(--text3);
    font-size: var(--text-xs);
    text-align: center;
}

/* ============================================================================
 * EDITORIAL PATTERNS — "rivista zootecnica + gestionale"
 * ----------------------------------------------------------------------------
 * Pattern composti pensati per ArchivetHub (e riusabili da altre app):
 * hero, kicker/lead/byline/meta, section header, article cards, app launcher.
 * Tutto basato sui token di design-tokens.css.
 * ========================================================================== */

/* ---- Tipografia editoriale ---- */
.ds-kicker {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent);
    padding: 2px 0;
    border-bottom: 2px solid var(--gold);
    margin-bottom: var(--space-3);
}

.ds-lead {
    font-family: var(--font-sans);
    font-size: 1.15rem;
    font-weight: 400;
    line-height: 1.55;
    color: var(--text2);
    max-width: 62ch;
    margin: 0 0 var(--space-4);
}

.ds-byline {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--text3);
    letter-spacing: .04em;
    text-transform: uppercase;
}

.ds-meta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--text3);
    letter-spacing: .04em;
}

.ds-meta .ds-meta-dot {
    width: 4px;
    height: 4px;
    background: var(--text3);
    border-radius: 50%;
    display: inline-block;
}

/* ---- Section header (occhiello + titolo + linea oro) ---- */
.ds-section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin: var(--space-10) 0 var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--border);
}

.ds-section-header h2 {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: var(--text-2xl);
    line-height: 1.15;
    color: var(--text);
    margin: 0;
}

.ds-section-header .ds-kicker { margin-bottom: var(--space-1); }

.ds-section-header__link {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    padding-bottom: 2px;
    transition: border-color var(--dur-1) var(--ease);
}
.ds-section-header__link:hover { border-color: var(--accent); }

/* ---- HERO EDITORIALE (variante "testata") ---- */
.ds-hero {
    position: relative;
    padding: var(--space-12) var(--space-6) var(--space-10);
    margin: 0 0 var(--space-8);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    isolation: isolate;
}

.ds-hero::before {
    /* Texture sottile in stile carta da quotidiano */
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--accent2) 10%, transparent) 0%, transparent 45%),
        radial-gradient(circle at 0% 100%, color-mix(in srgb, var(--gold) 10%, transparent) 0%, transparent 50%);
    z-index: -1;
}

.ds-hero__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    gap: var(--space-8);
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}

.ds-hero__title {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(2.2rem, 4.2vw, 3.6rem);
    line-height: 1.05;
    color: var(--text);
    margin: 0 0 var(--space-4);
    letter-spacing: -0.01em;
}

.ds-hero__title em {
    font-style: italic;
    color: var(--accent);
}

.ds-hero__lead {
    font-size: 1.18rem;
    line-height: 1.55;
    color: var(--text2);
    margin: 0 0 var(--space-6);
    max-width: 56ch;
}

.ds-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
}

.ds-hero__aside {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-5);
    background: var(--bg2);
    border-left: 3px solid var(--gold);
    border-radius: var(--radius-sm);
}

.ds-hero__aside-title {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--text3);
    margin: 0;
}

.ds-hero__aside ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.ds-hero__aside li a {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--text);
    font-weight: 500;
    text-decoration: none;
    padding: var(--space-1) 0;
    border-bottom: 1px solid transparent;
    transition: color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease);
}

.ds-hero__aside li a:hover {
    color: var(--accent);
    border-color: var(--accent2);
}

.ds-hero__aside li a i { color: var(--accent2); width: 1.2rem; text-align: center; }

@media (max-width: 900px) {
    .ds-hero__inner { grid-template-columns: 1fr; gap: var(--space-6); }
    .ds-hero { padding: var(--space-8) var(--space-5); }
}

/* ---- HERO DASHBOARD (variante sobria) ---- */
.ds-hero-compact {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-4);
    padding: var(--space-6) var(--space-6);
    margin: 0 0 var(--space-6);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    border-left: 4px solid var(--accent2);
}

.ds-hero-compact__greet {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 400;
    color: var(--text);
    margin: 0 0 var(--space-1);
    line-height: 1.15;
}

.ds-hero-compact__sub {
    font-size: var(--text-sm);
    color: var(--text2);
    margin: 0;
}

.ds-hero-compact__quicks {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

/* ---- ARTICLE CARD (lead story / secondaria) ---- */
.ds-article-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    text-decoration: none;
    color: var(--text);
    transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease);
    height: 100%;
    isolation: isolate;
}

.ds-article-card,
.ds-article-card:hover,
.ds-article-card *,
.ds-article-card *:hover { text-decoration: none !important; }

.ds-article-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    border-color: color-mix(in srgb, var(--accent2) 35%, var(--border));
    color: var(--text);
}

.ds-article-card__media {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--bg2);
}

.ds-article-card__media::after {
    /* Sfumatura editoriale dal basso per leggibilità */
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(28,25,23,.35) 100%);
    pointer-events: none;
}

.ds-article-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--dur-3) var(--ease);
}

.ds-article-card:hover .ds-article-card__media img { transform: scale(1.05); }

.ds-article-card__body {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-5);
    flex: 1;
}

.ds-article-card__title {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: 1.25rem;
    line-height: 1.2;
    color: var(--text);
    margin: 0;
    letter-spacing: -0.005em;
    transition: color var(--dur-1) var(--ease);
}

.ds-article-card:hover .ds-article-card__title { color: var(--accent); }

.ds-article-card__excerpt {
    font-size: var(--text-sm);
    color: var(--text2);
    line-height: 1.55;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ds-article-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    margin-top: auto;
    padding-top: var(--space-3);
    border-top: 1px solid var(--border);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text3);
}

.ds-article-card__footer .ds-meta { color: var(--text3); }
.ds-article-card__footer .ds-badge { text-transform: none; letter-spacing: 0; }

/*
 * Variante "lead": magazine cover full-bleed.
 * L'immagine occupa tutta la card; titolo, kicker ed excerpt sono sovrapposti
 * in basso su un gradient scuro per garantire leggibilità.
 */
.ds-article-card--lead {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    min-height: 480px;
    background: var(--ink);
    border-color: transparent;
    color: #fff;
    box-shadow: var(--shadow-md);
}

.ds-article-card--lead:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg, 0 16px 40px rgba(0,0,0,.18));
    border-color: transparent;
    color: #fff;
}

.ds-article-card--lead .ds-article-card__media {
    position: absolute;
    inset: 0;
    aspect-ratio: auto;
    height: 100%;
    width: 100%;
    z-index: 0;
}

.ds-article-card--lead .ds-article-card__media::after {
    /* Gradient editoriale dal basso: nero pieno -> trasparente in alto */
    background: linear-gradient(180deg,
        rgba(28,25,23,.05) 0%,
        rgba(28,25,23,.35) 45%,
        rgba(28,25,23,.85) 80%,
        rgba(28,25,23,.95) 100%);
}

.ds-article-card--lead .ds-article-card__media img {
    filter: saturate(1.05);
}

.ds-article-card--lead .ds-article-card__body {
    position: relative;
    z-index: 1;
    /* Body riempie la card (flex:1 ereditato) ma il contenuto è ancorato in basso */
    justify-content: flex-end;
    align-items: flex-start;
    padding: 2.5rem 2.75rem 2.25rem;
    gap: 0.9rem;
}

.ds-article-card--lead .ds-article-card__body > * { max-width: 760px; }
.ds-article-card--lead .ds-article-card__footer { width: 100%; max-width: 760px; }

.ds-article-card--lead .ds-kicker {
    color: var(--accent);
    background: rgba(255,255,255,.08);
    backdrop-filter: blur(6px);
    padding: 4px 10px;
    border-radius: 999px;
    align-self: flex-start;
    border: 1px solid rgba(255,255,255,.18);
}

.ds-article-card--lead .ds-article-card__title {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(1.9rem, 3vw, 2.8rem);
    line-height: 1.05;
    color: #fff;
    letter-spacing: -0.01em;
    text-shadow: 0 2px 16px rgba(0,0,0,.35);
}

.ds-article-card--lead:hover .ds-article-card__title { color: #fff; }

.ds-article-card--lead .ds-article-card__excerpt {
    font-size: 1.05rem;
    line-height: 1.5;
    color: rgba(255,255,255,.88);
    -webkit-line-clamp: 3;
    max-width: 62ch;
}

.ds-article-card--lead .ds-article-card__footer {
    border-top: 1px solid rgba(255,255,255,.18);
    padding-top: var(--space-3);
    color: rgba(255,255,255,.72);
}

.ds-article-card--lead .ds-article-card__footer .ds-meta { color: rgba(255,255,255,.78); }

@media (max-width: 800px) {
    .ds-article-card--lead { min-height: 420px; }
    .ds-article-card--lead .ds-article-card__body { padding: var(--space-5) var(--space-5) var(--space-5); }
}

/* Variante "no image": bordo arancio più deciso, niente media */
.ds-article-card--no-image .ds-article-card__media { display: none; }
.ds-article-card--no-image {
    border-left: 4px solid var(--accent2);
    background: linear-gradient(135deg, var(--surface) 0%, var(--bg2) 100%);
}

/* Lead senza copertina: torna a fondo chiaro editoriale (non c'è l'immagine sotto) */
.ds-article-card--lead.ds-article-card--no-image {
    background: linear-gradient(135deg, var(--surface) 0%, var(--bg2) 100%);
    color: var(--text);
    min-height: 320px;
    border-left: 6px solid var(--accent2);
}
.ds-article-card--lead.ds-article-card--no-image .ds-article-card__title { color: var(--text); text-shadow: none; }
.ds-article-card--lead.ds-article-card--no-image .ds-article-card__excerpt { color: var(--text2); }
.ds-article-card--lead.ds-article-card--no-image .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    backdrop-filter: none;
}
.ds-article-card--lead.ds-article-card--no-image .ds-article-card__footer {
    border-top-color: var(--border);
    color: var(--text3);
}

/* ---- ARTICLE ROW (riga compatta per archivio news) ---- */
.ds-article-row {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr) auto;
    gap: var(--space-4);
    padding: var(--space-3) var(--space-4);
    align-items: center;
    border-bottom: 1px solid var(--border);
    text-decoration: none;
    color: var(--text);
    transition: background var(--dur-1) var(--ease);
}

.ds-article-row:hover { background: var(--bg2); color: var(--text); }
.ds-article-row,
.ds-article-row:hover,
.ds-article-row * { text-decoration: none !important; }

.ds-article-row__thumb {
    width: 96px;
    height: 64px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    background: var(--bg2);
}

.ds-article-row__title {
    font-weight: 600;
    font-size: var(--text-base);
    margin: 0 0 2px;
    color: var(--text);
}

.ds-article-row__sub {
    font-size: var(--text-sm);
    color: var(--text2);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ds-article-row__tags {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--space-1);
}

@media (max-width: 600px) {
    .ds-article-row { grid-template-columns: 64px minmax(0, 1fr); }
    .ds-article-row__thumb { width: 64px; height: 48px; }
    .ds-article-row__tags { display: none; }
}

/* ---- NEWS GRID (1 lead + N secondarie) ---- */
.ds-news-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-5);
}

.ds-news-grid__lead { grid-column: 1 / -1; }

.ds-news-grid__rest {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--space-4);
    grid-column: 1 / -1;
}

/* ---- APP LAUNCHER (tile gestionali) ---- */
.ds-app-launcher {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--space-4);
}

.ds-app-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    text-decoration: none;
    color: var(--text);
    transition: transform var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease);
    overflow: hidden;
    isolation: isolate;
}

.ds-app-tile,
.ds-app-tile:hover,
.ds-app-tile *,
.ds-app-tile *:hover { text-decoration: none !important; }

.ds-app-tile::after {
    content: "";
    position: absolute;
    left: 0; right: 0; top: 0;
    height: 3px;
    background: var(--accent2);
    opacity: 0;
    transition: opacity var(--dur-2) var(--ease);
}

.ds-app-tile:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    border-color: color-mix(in srgb, var(--accent2) 40%, var(--border));
    color: var(--text);
    text-decoration: none;
}
.ds-app-tile:hover::after { opacity: 1; }

.ds-app-tile__head {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.ds-app-tile__icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-sm);
    background: var(--bg2);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.ds-app-tile__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 6px;
}

.ds-app-tile__title {
    font-family: var(--font-sans);
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0;
    color: var(--text);
    letter-spacing: .01em;
}

.ds-app-tile__desc {
    font-size: var(--text-sm);
    color: var(--text2);
    line-height: 1.45;
    margin: 0;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ds-app-tile__roles {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
}

.ds-app-tile__cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--accent);
    margin-top: var(--space-2);
}

.ds-app-tile__cta i { transition: transform var(--dur-1) var(--ease); }
.ds-app-tile:hover .ds-app-tile__cta i { transform: translateX(3px); }

.ds-app-tile__badge-new {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    background: var(--gold);
    color: #1c1917;
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    padding: 2px 8px;
    border-radius: var(--radius-pill);
}

/* ============================================================================
 * EDITORIAL — variante hero con illustrazione + ds-prose + link list
 * ========================================================================== */

/* Hero con artwork di sfondo (foto / SVG zootecnico) */
.ds-hero--with-art {
    color: #fff;
    border: none;
    background: linear-gradient(135deg, var(--steel-dark) 0%, var(--accent) 100%);
}

.ds-hero--with-art::before {
    /* Sostituisce la sfumatura originale con una scura per leggibilità sopra l'art */
    background:
        linear-gradient(180deg, rgba(28,25,23,.15) 0%, rgba(28,25,23,.55) 100%);
}

.ds-hero--with-art .ds-hero__art {
    position: absolute;
    inset: 0;
    z-index: -2;
    background-position: center;
    background-size: cover;
    opacity: .55;
}

.ds-hero--with-art .ds-kicker {
    color: var(--gold);
    border-bottom-color: var(--gold);
}

.ds-hero--with-art .ds-hero__title { color: #fff; }
.ds-hero--with-art .ds-hero__title em { color: var(--gold); font-style: italic; }
.ds-hero--with-art .ds-hero__lead { color: rgba(255,255,255,.85); }

.ds-hero--with-art .ds-hero__aside {
    background: rgba(255,255,255,.08);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border-left-color: var(--gold);
}

.ds-hero--with-art .ds-hero__aside-title { color: rgba(255,255,255,.7); }

.ds-hero--with-art .ds-hero__aside li a {
    color: #fff;
    border-bottom-color: rgba(255,255,255,.1);
}
.ds-hero--with-art .ds-hero__aside li a:hover {
    color: var(--gold);
    border-bottom-color: var(--gold);
}
.ds-hero--with-art .ds-hero__aside li a i { color: var(--gold); }

.ds-hero--with-art .ds-btn-ghost {
    color: #fff;
    border-color: rgba(255,255,255,.4);
    background: rgba(255,255,255,.05);
}
.ds-hero--with-art .ds-btn-ghost:hover {
    background: rgba(255,255,255,.12);
    color: #fff;
    border-color: var(--gold);
}

/* ---- DS-PROSE: corpo articolo ---- */
.ds-prose {
    max-width: 70ch;
    font-family: var(--font-sans);
    font-size: 1.06rem;
    line-height: 1.7;
    color: var(--text);
}

.ds-prose > * + * { margin-top: var(--space-4); }
.ds-prose p { margin: 0 0 var(--space-4); }

.ds-prose h2 {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1.2;
    margin: var(--space-8) 0 var(--space-3);
    color: var(--text);
}

.ds-prose h3 {
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: 1.2rem;
    margin: var(--space-6) 0 var(--space-2);
    color: var(--text);
}

.ds-prose a {
    color: var(--accent);
    text-decoration: underline;
    text-decoration-color: color-mix(in srgb, var(--accent) 35%, transparent);
    text-underline-offset: 3px;
}
.ds-prose a:hover {
    text-decoration-color: var(--accent);
}

.ds-prose blockquote {
    margin: var(--space-6) 0;
    padding: var(--space-3) var(--space-5);
    border-left: 4px solid var(--gold);
    background: var(--bg2);
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.2rem;
    line-height: 1.4;
    color: var(--text);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.ds-prose ul, .ds-prose ol {
    padding-left: var(--space-6);
    margin: 0 0 var(--space-4);
}
.ds-prose li { margin-bottom: var(--space-2); }

.ds-prose img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius);
    margin: var(--space-5) 0;
}

.ds-prose hr {
    border: none;
    border-top: 1px solid var(--border);
    margin: var(--space-8) 0;
}

/* ---- DS-LINK-LIST: card con elenco link a colonna ---- */
.ds-link-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0;
}

.ds-link-list li + li { border-top: 1px solid var(--border); }

.ds-link-list a {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    color: var(--text);
    text-decoration: none;
    transition: background var(--dur-1) var(--ease), padding-left var(--dur-1) var(--ease);
}

.ds-link-list a:hover {
    background: var(--bg2);
    color: var(--text);
    padding-left: calc(var(--space-5) + 4px);
    text-decoration: none;
}

.ds-link-list a .ds-link-list__icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    background: var(--accent-light);
    color: var(--accent);
    flex-shrink: 0;
}

.ds-link-list a .ds-link-list__body { flex: 1; min-width: 0; }
.ds-link-list a .ds-link-list__title { font-weight: 600; color: var(--text); margin: 0; }
.ds-link-list a .ds-link-list__sub { font-size: var(--text-sm); color: var(--text2); margin: 0; }
.ds-link-list a .ds-link-list__chev { color: var(--text3); }
.ds-link-list a:hover .ds-link-list__chev { color: var(--accent); }

/* ---- DS-NEWS-NAV: navigazione precedente/successiva tra articoli ---- */
.ds-news-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin-top: var(--space-8);
}

.ds-news-nav__item {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    padding: var(--space-4) var(--space-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    text-decoration: none;
    color: var(--text);
    transition: border-color var(--dur-2) var(--ease), background var(--dur-2) var(--ease);
}

.ds-news-nav__item:hover {
    border-color: var(--accent2);
    background: var(--bg2);
    color: var(--text);
}
.ds-news-nav__item,
.ds-news-nav__item:hover,
.ds-news-nav__item * { text-decoration: none !important; }

.ds-news-nav__item--next { text-align: right; }

.ds-news-nav__label {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--accent);
}

.ds-news-nav__title {
    font-weight: 600;
    color: var(--text);
    line-height: 1.3;
}

.ds-news-nav__sub {
    font-size: var(--text-sm);
    color: var(--text2);
}

.ds-news-nav__placeholder {
    padding: var(--space-4) var(--space-5);
    background: var(--bg2);
    border: 1px dashed var(--border);
    border-radius: var(--radius);
    color: var(--text3);
    font-size: var(--text-sm);
    font-style: italic;
}

@media (max-width: 700px) {
    .ds-news-nav { grid-template-columns: 1fr; }
    .ds-news-nav__item--next { text-align: left; }
}

/* ---- DS-FILTERBAR: barra filtri sopra liste ---- */
.ds-filterbar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    padding: var(--space-3) 0;
    margin-bottom: var(--space-5);
    border-bottom: 1px solid var(--border);
}

.ds-filterbar__chip {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 4px 12px;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--text2);
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--radius-pill);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--dur-1) var(--ease);
}
.ds-filterbar__chip:hover {
    border-color: var(--accent2);
    color: var(--accent);
}
.ds-filterbar__chip--active {
    background: var(--accent2);
    border-color: var(--accent2);
    color: #fff;
}
.ds-filterbar__chip--active:hover { color: #fff; }

/* ============================================================
 * LEAD CARD VARIANTS
 * Il markup della lead card include sempre 4 decorazioni (ribbon,
 * banner cornice, pin, big number) inizialmente nascoste.
 * La griglia parent ha `data-lead-variant="..."` che attiva gli
 * stili giusti. Switcher dev in fondo alla pagina (solo Development).
 * ============================================================ */

/* Default: nascondi tutte le decorazioni opzionali */
.ds-article-card--lead .ds-lead-ribbon,
.ds-article-card--lead .ds-lead-edition-banner,
.ds-article-card--lead .ds-lead-pin,
.ds-article-card--lead .ds-lead-bigno { display: none; }

/* ---------------------------------------------------------------
 * Variante "ribbon": stessa dimensione card normale + nastro rotato
 * --------------------------------------------------------------- */
[data-lead-variant="ribbon"] .ds-article-card--lead {
    min-height: 0;
    background: var(--surface);
    color: var(--text);
    border: 1.5px solid var(--accent2);
    box-shadow: 0 8px 24px rgba(245,130,32,.18);
    overflow: hidden;
}
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-article-card__media { position: relative; aspect-ratio: 16/9; height: auto; }
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-article-card__media::after { background: linear-gradient(180deg, transparent 60%, rgba(28,25,23,.25) 100%); }
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-article-card__body {
    padding: 1.5rem 1.75rem;
    gap: .6rem;
    justify-content: flex-start;
}
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    backdrop-filter: none;
}
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-article-card__title {
    color: var(--text);
    font-size: 1.5rem;
    text-shadow: none;
}
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-article-card__excerpt { color: var(--text2); }
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-article-card__footer { border-top-color: var(--border); color: var(--text3); }
[data-lead-variant="ribbon"] .ds-article-card--lead .ds-lead-ribbon {
    display: block;
    position: absolute;
    top: 22px;
    right: -42px;
    transform: rotate(35deg);
    background: var(--accent2);
    color: #fff;
    font-family: var(--font-display);
    font-size: .85rem;
    letter-spacing: .04em;
    padding: 6px 50px;
    z-index: 5;
    box-shadow: 0 4px 12px rgba(0,0,0,.25);
    pointer-events: none;
}

/* ---------------------------------------------------------------
 * Variante "frame": banda arancio sopra + card editoriale senza foto
 * --------------------------------------------------------------- */
[data-lead-variant="frame"] .ds-article-card--lead {
    min-height: 0;
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-top: none;
    margin-top: 38px;
    position: relative;
}
[data-lead-variant="frame"] .ds-article-card--lead .ds-article-card__media { display: none; }
[data-lead-variant="frame"] .ds-article-card--lead .ds-lead-edition-banner {
    display: block;
    position: absolute;
    top: -30px;
    left: 0;
    right: 0;
    background: var(--accent2);
    color: #fff;
    font-family: var(--font-mono);
    font-size: .75rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 8px 1.75rem;
    z-index: 2;
}
[data-lead-variant="frame"] .ds-article-card--lead .ds-article-card__body {
    padding: 2.25rem 2.5rem;
    gap: 1rem;
}
[data-lead-variant="frame"] .ds-article-card--lead .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    font-family: var(--font-mono);
    font-size: .72rem;
    letter-spacing: .14em;
}
[data-lead-variant="frame"] .ds-article-card--lead .ds-article-card__title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 2.6vw, 2.4rem);
    text-shadow: none;
    line-height: 1.1;
}
[data-lead-variant="frame"] .ds-article-card--lead .ds-article-card__excerpt { color: var(--text2); font-size: 1.05rem; -webkit-line-clamp: 4; }
[data-lead-variant="frame"] .ds-article-card--lead .ds-article-card__footer { border-top-color: var(--border); color: var(--text3); }

/* ---------------------------------------------------------------
 * Variante "spread": rivista, foto a sinistra, formato compatto
 * --------------------------------------------------------------- */
[data-lead-variant="spread"] .ds-article-card--lead {
    min-height: 0;
    max-height: 320px;
    background: var(--surface);
    color: var(--text);
    display: grid;
    grid-template-columns: minmax(260px, 1fr) 1.8fr;
    border: 1px solid var(--border);
    overflow: hidden;
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__media {
    position: relative;
    aspect-ratio: auto;
    height: 100%;
    width: 100%;
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__media::after {
    background: linear-gradient(180deg, transparent 70%, rgba(28,25,23,.25) 100%);
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__body {
    padding: 1.5rem 1.75rem;
    gap: .65rem;
    justify-content: center;
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    font-family: var(--font-mono);
    font-size: .72rem;
    letter-spacing: .14em;
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__title {
    color: var(--text);
    font-size: clamp(1.25rem, 1.8vw, 1.6rem);
    line-height: 1.15;
    text-shadow: none;
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__excerpt {
    color: var(--text2);
    font-size: .95rem;
    line-height: 1.45;
    -webkit-line-clamp: 2;
}
[data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__footer {
    border-top-color: var(--border);
    color: var(--text3);
    padding-top: var(--space-2);
    width: 100%;
    max-width: none;
    align-self: stretch;
}
@media (max-width: 700px) {
    [data-lead-variant="spread"] .ds-article-card--lead {
        grid-template-columns: 1fr;
        max-height: none;
    }
    [data-lead-variant="spread"] .ds-article-card--lead .ds-article-card__media { aspect-ratio: 16/9; }
}

/* ---------------------------------------------------------------
 * Variante "numbered": Monocle-style, numero in filigrana
 * --------------------------------------------------------------- */
[data-lead-variant="numbered"] .ds-article-card--lead {
    min-height: 0;
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent2);
    overflow: hidden;
    position: relative;
}
[data-lead-variant="numbered"] .ds-article-card--lead .ds-article-card__media { display: none; }
[data-lead-variant="numbered"] .ds-article-card--lead .ds-lead-bigno {
    display: block;
    position: absolute;
    top: 50%;
    right: 1.5rem;
    transform: translateY(-50%);
    font-family: var(--font-display);
    font-size: clamp(7rem, 16vw, 14rem);
    line-height: 1;
    color: transparent;
    -webkit-text-stroke: 2px color-mix(in srgb, var(--accent2) 30%, transparent);
    letter-spacing: -0.05em;
    pointer-events: none;
    z-index: 0;
    user-select: none;
}
[data-lead-variant="numbered"] .ds-article-card--lead .ds-article-card__body {
    position: relative;
    z-index: 1;
    padding: 2.5rem 2.75rem;
    max-width: 70%;
    gap: 1rem;
    justify-content: center;
}
[data-lead-variant="numbered"] .ds-article-card--lead .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    font-family: var(--font-mono);
    font-size: .72rem;
    letter-spacing: .14em;
}
[data-lead-variant="numbered"] .ds-article-card--lead .ds-article-card__title {
    color: var(--text);
    font-size: clamp(1.6rem, 2.4vw, 2.2rem);
    text-shadow: none;
}
[data-lead-variant="numbered"] .ds-article-card--lead .ds-article-card__excerpt { color: var(--text2); -webkit-line-clamp: 3; }
[data-lead-variant="numbered"] .ds-article-card--lead .ds-article-card__footer { border-top-color: var(--border); color: var(--text3); }

/* ---------------------------------------------------------------
 * Variante "pinned": digital, pin + bordo top arancio + glow
 * --------------------------------------------------------------- */
@keyframes ds-pin-glow {
    0%, 100% { box-shadow: 0 0 0 rgba(245,130,32,0), var(--shadow-md); }
    50%      { box-shadow: 0 0 24px rgba(245,130,32,.25), var(--shadow-md); }
}
[data-lead-variant="pinned"] .ds-article-card--lead {
    min-height: 0;
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-top: 4px solid var(--accent2);
    animation: ds-pin-glow 4s ease-in-out infinite;
    position: relative;
}
[data-lead-variant="pinned"] .ds-article-card--lead .ds-article-card__media { aspect-ratio: 16/9; height: auto; position: relative; }
[data-lead-variant="pinned"] .ds-article-card--lead .ds-article-card__media::after { background: linear-gradient(180deg, transparent 70%, rgba(28,25,23,.2) 100%); }
[data-lead-variant="pinned"] .ds-article-card--lead .ds-lead-pin {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 14px;
    right: 14px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--accent2);
    color: #fff;
    z-index: 5;
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
    transform: rotate(20deg);
    font-size: .85rem;
}
[data-lead-variant="pinned"] .ds-article-card--lead .ds-article-card__body {
    padding: 1.5rem 1.75rem;
    gap: .6rem;
    justify-content: flex-start;
}
[data-lead-variant="pinned"] .ds-article-card--lead .ds-kicker::before {
    content: "★ ";
    color: var(--accent2);
}
[data-lead-variant="pinned"] .ds-article-card--lead .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    font-family: var(--font-mono);
    font-size: .72rem;
    letter-spacing: .14em;
    text-transform: uppercase;
}
[data-lead-variant="pinned"] .ds-article-card--lead .ds-article-card__title {
    color: var(--text);
    font-size: 1.5rem;
    text-shadow: none;
}
[data-lead-variant="pinned"] .ds-article-card--lead .ds-article-card__excerpt { color: var(--text2); }
[data-lead-variant="pinned"] .ds-article-card--lead .ds-article-card__footer { border-top-color: var(--border); color: var(--text3); }

/* ---------------------------------------------------------------
 * Variante "combo": discreta, etichetta numerata + sfondo crema
 * --------------------------------------------------------------- */
[data-lead-variant="combo"] .ds-article-card--lead {
    min-height: 0;
    background: var(--bg2);
    color: var(--text);
    border: 1px solid var(--border);
    border-top: 4px solid var(--accent2);
}
[data-lead-variant="combo"] .ds-article-card--lead .ds-article-card__media { aspect-ratio: 16/9; height: auto; position: relative; }
[data-lead-variant="combo"] .ds-article-card--lead .ds-article-card__media::after { background: linear-gradient(180deg, transparent 70%, rgba(28,25,23,.2) 100%); }
[data-lead-variant="combo"] .ds-article-card--lead .ds-article-card__body {
    padding: 1.75rem 2rem;
    gap: .75rem;
    justify-content: flex-start;
}
[data-lead-variant="combo"] .ds-article-card--lead .ds-kicker::before {
    content: attr(data-edition-prefix, "01") " — ";
    color: var(--accent2);
    font-weight: 600;
}
[data-lead-variant="combo"] .ds-article-card--lead .ds-kicker {
    color: var(--accent2);
    background: transparent;
    border: none;
    padding: 0;
    font-family: var(--font-mono);
    font-size: .75rem;
    letter-spacing: .14em;
    text-transform: uppercase;
}
[data-lead-variant="combo"] .ds-article-card--lead .ds-article-card__title {
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 2.2vw, 2rem);
    text-shadow: none;
}
[data-lead-variant="combo"] .ds-article-card--lead .ds-article-card__excerpt { color: var(--text2); }
[data-lead-variant="combo"] .ds-article-card--lead .ds-article-card__footer { border-top-color: var(--border); color: var(--text3); }

/* ============================================================
 * DEV-ONLY: switcher flottante per varianti lead
 * ============================================================ */
.ds-lead-switcher {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9000;
    font-family: var(--font-sans);
}

.ds-lead-switcher__toggle {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--accent2);
    box-shadow: var(--shadow-md);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    transition: transform var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease);
}
.ds-lead-switcher__toggle:hover { transform: scale(1.08); box-shadow: 0 8px 20px rgba(0,0,0,.18); }
.ds-lead-switcher__toggle[aria-expanded="true"] { background: var(--accent2); color: #fff; }

.ds-lead-switcher__panel {
    position: absolute;
    bottom: calc(100% + 10px);
    right: 0;
    min-width: 240px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-4);
    box-shadow: var(--shadow-lg, 0 16px 40px rgba(0,0,0,.18));
    animation: ds-fade-in var(--dur-2) var(--ease);
}

.ds-lead-switcher__title {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--text3);
    margin-bottom: var(--space-3);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
}
.ds-lead-switcher__title span {
    background: var(--accent2);
    color: #fff;
    padding: 2px 8px;
    border-radius: 999px;
    font-family: var(--font-mono);
    font-size: .65rem;
    letter-spacing: .1em;
}

.ds-lead-switcher__options {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.ds-lead-switcher__options button {
    text-align: left;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text2);
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: var(--text-sm);
    transition: background var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
}
.ds-lead-switcher__options button:hover { background: var(--bg2); color: var(--text); }
.ds-lead-switcher__options button.is-active {
    background: color-mix(in srgb, var(--accent2) 12%, transparent);
    border-color: color-mix(in srgb, var(--accent2) 35%, transparent);
    color: var(--accent2);
    font-weight: 600;
}

/* ============================================================
 * USER MENU (header profilo + dropdown)
 * ============================================================ */
.ds-user-menu {
    position: relative;
    display: inline-block;
    text-align: left;
}

.ds-user-menu__trigger {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 4px 12px 4px 4px;
    cursor: pointer;
    transition: border-color var(--dur-1) var(--ease), box-shadow var(--dur-1) var(--ease), background var(--dur-1) var(--ease);
    color: var(--text);
    font-family: var(--font-sans);
    line-height: 1.1;
    max-width: 280px;
}

.ds-user-menu__trigger:hover {
    border-color: var(--accent2);
    box-shadow: 0 4px 12px rgba(0,0,0,.06);
}

.ds-user-menu__trigger[aria-expanded="true"] {
    border-color: var(--accent2);
    background: var(--bg2);
}

.ds-user-menu__avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent2), var(--accent));
    color: #fff;
    font-family: var(--font-display);
    font-size: .9rem;
    letter-spacing: .02em;
    flex: 0 0 auto;
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.18);
}

.ds-user-menu__avatar--lg {
    width: 48px;
    height: 48px;
    font-size: 1.1rem;
}

.ds-user-menu__meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    min-width: 0;
}

.ds-user-menu__name {
    font-size: .9rem;
    font-weight: 600;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 160px;
}

.ds-user-menu__role {
    font-family: var(--font-mono);
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--accent2);
}

.ds-user-menu__chev {
    color: var(--text3);
    font-size: .7rem;
    transition: transform var(--dur-1) var(--ease);
}

.ds-user-menu__trigger[aria-expanded="true"] .ds-user-menu__chev {
    transform: rotate(180deg);
}

.ds-user-menu__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 280px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg, 0 16px 40px rgba(0,0,0,.18));
    z-index: 1000;
    overflow: hidden;
    animation: ds-fade-in var(--dur-2) var(--ease);
}

.ds-user-menu__header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-4);
    background: linear-gradient(135deg, var(--bg2) 0%, var(--surface) 100%);
    border-bottom: 1px solid var(--border);
}

.ds-user-menu__items {
    display: flex;
    flex-direction: column;
    padding: 6px;
}

.ds-user-menu__group-label {
    font-family: var(--font-mono);
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--text3);
    padding: 8px 12px 4px;
}

.ds-user-menu__item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 9px 12px;
    border-radius: 6px;
    color: var(--text2);
    font-size: var(--text-sm);
    text-decoration: none !important;
    border: none;
    background: transparent;
    cursor: pointer;
    width: 100%;
    text-align: left;
    font-family: var(--font-sans);
    transition: background var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
}

.ds-user-menu__item i {
    width: 16px;
    color: var(--text3);
    text-align: center;
}

.ds-user-menu__item:hover {
    background: var(--bg2);
    color: var(--text);
}

.ds-user-menu__item:hover i {
    color: var(--accent2);
}

.ds-user-menu__item--danger { color: var(--danger, #b91c1c); }
.ds-user-menu__item--danger i { color: var(--danger, #b91c1c); }
.ds-user-menu__item--danger:hover {
    background: color-mix(in srgb, var(--danger, #b91c1c) 8%, transparent);
    color: var(--danger, #b91c1c);
}

.ds-user-menu__divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 6px 4px;
}

.ds-user-menu__form { margin: 0; padding: 0; }

@media (max-width: 600px) {
    .ds-user-menu__meta { display: none; }
    .ds-user-menu__chev { display: none; }
    .ds-user-menu__trigger { padding: 4px; }
    .ds-user-menu__panel { right: 0; left: auto; min-width: 260px; }
}

/* ============================================================ */
/* SPOTLIGHT (Ctrl+K)                                            */
/* ============================================================ */
body.ds-spotlight-open { overflow: hidden; }

.ds-spotlight {
    position: fixed; inset: 0; z-index: 1080;
    display: flex; align-items: flex-start; justify-content: center;
    padding-top: clamp(48px, 12vh, 140px);
}
.ds-spotlight[hidden] { display: none; }

.ds-spotlight__backdrop {
    position: absolute; inset: 0;
    background: rgba(15, 17, 21, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    animation: dsSpotlightFade 120ms ease-out;
}
.ds-spotlight__panel {
    position: relative;
    width: min(640px, calc(100vw - 32px));
    max-height: 70vh;
    display: flex; flex-direction: column;
    background: var(--ds-color-surface, #fff);
    border: 1px solid var(--ds-color-border, rgba(0,0,0,.08));
    border-radius: 14px;
    box-shadow: 0 20px 60px rgba(15, 17, 21, .35);
    overflow: hidden;
    animation: dsSpotlightPop 140ms cubic-bezier(.2,.8,.2,1);
}

.ds-spotlight__searchbox {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--ds-color-border, rgba(0,0,0,.06));
}
.ds-spotlight__icon { font-size: 18px; opacity: .55; }
.ds-spotlight__input {
    flex: 1; min-width: 0;
    border: none; outline: none; background: transparent;
    font: 500 18px/1.3 var(--ds-font-sans, "DM Sans"), system-ui, sans-serif;
    color: var(--ds-color-text, #1a1d22);
}
.ds-spotlight__input::placeholder { color: rgba(0,0,0,.4); }

kbd, .ds-spotlight__kbd, .ds-spotlight__footer kbd {
    font-family: var(--ds-font-mono, "DM Mono"), ui-monospace, monospace;
    font-size: 11px; line-height: 1;
    padding: 3px 6px; border-radius: 4px;
    border: 1px solid rgba(0,0,0,.15);
    background: rgba(0,0,0,.04);
    color: rgba(0,0,0,.65);
    cursor: default;
}
.ds-spotlight__kbd { cursor: pointer; }

.ds-spotlight__results {
    flex: 1; overflow-y: auto;
    padding: 8px 0;
}
.ds-spotlight__empty {
    padding: 28px 20px; text-align: center;
    color: rgba(0,0,0,.5); font-size: 14px;
}

.ds-spotlight__group + .ds-spotlight__group { margin-top: 4px; }
.ds-spotlight__group-label {
    padding: 10px 18px 4px;
    font: 600 11px/1 var(--ds-font-mono, "DM Mono"), monospace;
    text-transform: uppercase; letter-spacing: .08em;
    color: rgba(0,0,0,.45);
}
.ds-spotlight__list {
    list-style: none; margin: 0; padding: 0;
}
.ds-spotlight__item {
    display: flex; align-items: center; gap: 14px;
    padding: 10px 18px;
    cursor: pointer;
    color: var(--ds-color-text, #1a1d22);
    border-left: 3px solid transparent;
    transition: background-color 80ms ease, border-color 80ms ease;
}
.ds-spotlight__item.is-active {
    background: rgba(0, 80, 180, .08);
    border-left-color: var(--ds-color-accent, #0a66c2);
}
.ds-spotlight__item-icon {
    width: 20px; text-align: center;
    font-size: 15px; opacity: .7;
}
.ds-spotlight__item-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.ds-spotlight__item-title {
    font: 500 14.5px/1.3 var(--ds-font-sans, "DM Sans"), sans-serif;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ds-spotlight__item-subtitle {
    font: 400 12.5px/1.3 var(--ds-font-sans, "DM Sans"), sans-serif;
    color: rgba(0,0,0,.55);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ds-spotlight__item-title mark,
.ds-spotlight__item-subtitle mark {
    background: rgba(255, 215, 0, .45);
    color: inherit; padding: 0 1px; border-radius: 2px;
}
.ds-spotlight__item-meta { font-size: 12px; opacity: .4; }
.ds-spotlight__item.is-active .ds-spotlight__item-meta { opacity: .9; }

.ds-spotlight__footer {
    display: flex; align-items: center; gap: 14px;
    padding: 8px 16px;
    border-top: 1px solid var(--ds-color-border, rgba(0,0,0,.06));
    font-size: 11.5px; color: rgba(0,0,0,.55);
    background: rgba(0,0,0,.02);
}
.ds-spotlight__footer kbd { font-size: 10px; padding: 2px 5px; }
.ds-spotlight__brand {
    margin-left: auto;
    font: 600 10.5px/1 var(--ds-font-mono, "DM Mono"), monospace;
    text-transform: uppercase; letter-spacing: .12em;
    color: rgba(0,0,0,.4);
}

@keyframes dsSpotlightFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes dsSpotlightPop  { from { opacity: 0; transform: translateY(-6px) scale(.98); } to { opacity: 1; transform: none; } }

@media (max-width: 640px) {
    .ds-spotlight { padding-top: 24px; }
    .ds-spotlight__panel { max-height: 88vh; }
    .ds-spotlight__footer { flex-wrap: wrap; }
}

/* ============================================================ */
/* DASHBOARD PERSONALE (/Me)                                     */
/* ============================================================ */
.ds-me-hero h1 strong { color: var(--ds-color-accent, #0a66c2); font-weight: 700; }

.ds-me-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 32px;
    align-items: start;
    margin-top: 24px;
}
@media (max-width: 980px) {
    .ds-me-grid { grid-template-columns: 1fr; }
}

.ds-me-main { display: flex; flex-direction: column; gap: 36px; min-width: 0; }
.ds-me-side { display: flex; flex-direction: column; gap: 20px; }

.ds-me-section { display: flex; flex-direction: column; gap: 14px; }
.ds-me-section__head {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 16px; flex-wrap: wrap;
    border-bottom: 1px solid rgba(0,0,0,.08);
    padding-bottom: 8px;
}
.ds-me-section__head h2 {
    font: 600 18px/1.2 var(--ds-font-sans, "DM Sans"), sans-serif;
    margin: 0; display: flex; align-items: center; gap: 10px;
}
.ds-me-section__head h2 i { color: var(--ds-color-accent, #0a66c2); font-size: 16px; }
.ds-me-section__hint { font-size: 12.5px; color: rgba(0,0,0,.55); }
.ds-me-section__link {
    font-size: 13px; color: var(--ds-color-accent, #0a66c2);
    text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
}
.ds-me-section__link:hover { text-decoration: underline; }

.ds-me-empty {
    display: flex; align-items: center; gap: 14px;
    padding: 20px;
    background: rgba(0,0,0,.025);
    border: 1px dashed rgba(0,0,0,.12);
    border-radius: 10px;
    color: rgba(0,0,0,.6);
}
.ds-me-empty i { font-size: 22px; opacity: .5; }
.ds-me-empty p { margin: 0; font-size: 14px; }

.ds-me-fav-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 14px;
}
.ds-me-fav-card {
    position: relative;
    display: flex; gap: 14px; align-items: center;
    padding: 16px;
    background: var(--ds-color-surface, #fff);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 12px;
    color: inherit; text-decoration: none;
    transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}
.ds-me-fav-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(15,17,21,.08);
    border-color: var(--ds-color-accent, #0a66c2);
}
.ds-me-fav-card__icon {
    width: 48px; height: 48px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0,80,180,.08);
    border-radius: 10px;
}
.ds-me-fav-card__icon img { max-width: 32px; max-height: 32px; }
.ds-me-fav-card__icon i { font-size: 22px; color: var(--ds-color-accent, #0a66c2); }
.ds-me-fav-card__body { flex: 1; min-width: 0; }
.ds-me-fav-card__body h3 {
    margin: 0 0 4px;
    font: 600 15px/1.2 var(--ds-font-sans, "DM Sans"), sans-serif;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ds-me-fav-card__body p {
    margin: 0;
    font-size: 12.5px; color: rgba(0,0,0,.55);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
}

.ds-me-fav-toggle {
    position: absolute; top: 8px; right: 8px;
    width: 30px; height: 30px;
    display: flex; align-items: center; justify-content: center;
    background: transparent; border: none; border-radius: 50%;
    cursor: pointer; color: rgba(0,0,0,.3);
    transition: color 120ms ease, background-color 120ms ease, transform 120ms ease;
}
.ds-me-fav-toggle:hover { background: rgba(0,0,0,.06); color: #f0a000; transform: scale(1.1); }
.ds-me-fav-toggle.is-fav { color: #f5a623; }
.ds-me-fav-toggle.is-fav:hover { color: #d68910; }

.ds-me-apps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 12px;
}
.ds-me-app-card {
    position: relative;
    background: var(--ds-color-surface, #fff);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 10px;
    transition: border-color 120ms ease, box-shadow 120ms ease;
}
.ds-me-app-card:hover {
    border-color: var(--ds-color-accent, #0a66c2);
    box-shadow: 0 4px 12px rgba(15,17,21,.06);
}
.ds-me-app-card__link {
    display: flex; gap: 12px; align-items: flex-start;
    padding: 14px;
    color: inherit; text-decoration: none;
}
.ds-me-app-card__icon {
    width: 36px; height: 36px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0,0,0,.04); border-radius: 8px;
}
.ds-me-app-card__icon img { max-width: 24px; max-height: 24px; }
.ds-me-app-card__icon i { font-size: 16px; color: rgba(0,0,0,.5); }
.ds-me-app-card__link h3 {
    margin: 0 0 2px;
    font: 600 14px/1.2 var(--ds-font-sans, "DM Sans"), sans-serif;
}
.ds-me-app-card__link p {
    margin: 0;
    font-size: 12px; color: rgba(0,0,0,.55);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
}

.ds-me-news-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.ds-me-news-item a {
    display: flex; flex-direction: column; gap: 4px;
    padding: 12px 14px;
    background: var(--ds-color-surface, #fff);
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 8px;
    color: inherit; text-decoration: none;
    transition: border-color 120ms ease, background-color 120ms ease;
    position: relative;
}
.ds-me-news-item a:hover { border-color: var(--ds-color-accent, #0a66c2); background: rgba(0,80,180,.03); }
.ds-me-news-item__date {
    font: 500 11px/1 var(--ds-font-mono, "DM Mono"), monospace;
    text-transform: uppercase; letter-spacing: .06em; color: rgba(0,0,0,.5);
}
.ds-me-news-item__title { font: 600 14.5px/1.3 var(--ds-font-sans, "DM Sans"), sans-serif; }
.ds-me-news-item__subtitle { font-size: 12.5px; color: rgba(0,0,0,.6); }
.ds-me-news-item__badge {
    position: absolute; top: 10px; right: 10px;
    font: 500 10px/1 var(--ds-font-mono, "DM Mono"), monospace;
    text-transform: uppercase; letter-spacing: .06em;
    padding: 4px 7px; border-radius: 4px;
    background: rgba(0,80,180,.1); color: var(--ds-color-accent, #0a66c2);
}
.ds-me-news-item__badge--urgent { background: rgba(220,53,69,.12); color: #b02a37; }

.ds-me-side-section {
    background: var(--ds-color-surface, #fff);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 10px;
    padding: 16px;
}
.ds-me-side-section--accent {
    background: rgba(0,80,180,.04);
    border-color: rgba(0,80,180,.18);
}
.ds-me-side-section h3 {
    margin: 0 0 12px;
    font: 600 13px/1 var(--ds-font-mono, "DM Mono"), monospace;
    text-transform: uppercase; letter-spacing: .08em;
    color: rgba(0,0,0,.6);
    display: flex; align-items: center; gap: 8px;
}
.ds-me-side-section h3 i { color: var(--ds-color-accent, #0a66c2); }
.ds-me-side-empty { font-size: 12.5px; color: rgba(0,0,0,.5); margin: 0; }

.ds-me-side-list, .ds-me-side-actions { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.ds-me-side-list a, .ds-me-side-actions a {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px;
    border-radius: 6px;
    color: inherit; text-decoration: none;
    font-size: 13.5px;
    transition: background-color 100ms ease;
}
.ds-me-side-list a:hover, .ds-me-side-actions a:hover { background: rgba(0,0,0,.05); }
.ds-me-side-list a img { width: 18px; height: 18px; }
.ds-me-side-list a i, .ds-me-side-actions a i { width: 18px; text-align: center; color: rgba(0,0,0,.5); }
.ds-me-side-actions a:hover i { color: var(--ds-color-accent, #0a66c2); }

/* ============================================================ */
/* TOAST                                                         */
/* ============================================================ */
.ds-toast-host {
    position: fixed; bottom: 24px; right: 24px; z-index: 1090;
    display: flex; flex-direction: column; gap: 8px;
    pointer-events: none;
}
.ds-toast {
    background: rgba(15,17,21,.92); color: #fff;
    padding: 10px 16px; border-radius: 8px;
    font: 500 13px/1.3 var(--ds-font-sans, "DM Sans"), sans-serif;
    box-shadow: 0 8px 24px rgba(0,0,0,.2);
    animation: dsToastIn 180ms ease-out;
    pointer-events: auto;
}
.ds-toast.is-out { animation: dsToastOut 380ms ease-in forwards; }
@keyframes dsToastIn  { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@keyframes dsToastOut { to   { opacity: 0; transform: translateY(8px); } }
