/* ============================================================
   DIARIO ANIMAL — HEADER & OFF-CANVAS
   Estilo editorial / magazine, colores: verde bosque + negro
   ============================================================ */

:root {
    /* Paleta */
    --da-green:        #1B6B3A;
    --da-green-dark:   #134D2A;
    --da-green-light:  #28A85B;
    --da-black:        #111111;
    --da-dark:         #1A1A1A;
    --da-gray-900:     #222222;
    --da-gray-700:     #444444;
    --da-gray-500:     #777777;
    --da-gray-300:     #BBBBBB;
    --da-gray-100:     #F2F2F0;
    --da-white:        #FFFFFF;
    --da-red:          #D72638;
    --da-cream:        #FAF9F6;

    /* Tipografía */
    --da-font-display: 'DM Serif Display', Georgia, serif;
    --da-font-body:    'Instrument Sans', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Dimensiones */
    --da-header-h:     64px;
    --da-topbar-h:     36px;
    --da-nav-h:        44px;
    --da-offcanvas-w:  360px;

    /* Transiciones */
    --da-ease:         cubic-bezier(.4, 0, .2, 1);
}

/* ─── RESET selectivo ─────────────────────────────────────── */
.da-header *,
.da-offcanvas *,
.da-overlay { box-sizing: border-box; margin: 0; padding: 0; }

/* ============================================================
   OVERLAY
   ============================================================ */
.da-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: opacity .35s var(--da-ease), visibility .35s;
}
.da-overlay.is-visible { opacity: 1; visibility: visible; }

/* ============================================================
   OFF-CANVAS
   ============================================================ */
.da-offcanvas {
    position: fixed; top: 0; left: 0;
    width: var(--da-offcanvas-w);
    max-width: 90vw;
    height: 100vh;
    background: var(--da-dark);
    color: var(--da-gray-300);
    z-index: 9999;
    display: flex; flex-direction: column;
    transform: translateX(-100%);
    transition: transform .4s var(--da-ease);
    overflow: hidden;
}
.da-offcanvas.is-open { transform: translateX(0); }

/* Header del offcanvas */
.da-offcanvas__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    flex-shrink: 0;
}
.da-offcanvas__brand { display: flex; align-items: center; gap: 10px; }
.da-offcanvas__logo-text {
    font-family: var(--da-font-display);
    font-size: 22px; color: var(--da-white);
    letter-spacing: -.02em;
}
.da-offcanvas__close {
    background: none; border: none; cursor: pointer;
    color: var(--da-gray-500); padding: 4px;
    border-radius: 6px;
    transition: color .2s, background .2s;
}
.da-offcanvas__close:hover { color: var(--da-white); background: rgba(255,255,255,.08); }

/* Cuerpo scrollable */
.da-offcanvas__body {
    flex: 1; overflow-y: auto; overflow-x: hidden;
    padding: 12px 0;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.12) transparent;
}
.da-offcanvas__body::-webkit-scrollbar { width: 4px; }
.da-offcanvas__body::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 4px; }

/* Bloques */
.da-offcanvas__block {
    padding: 12px 24px;
}
.da-offcanvas__block--separator {
    margin-top: 8px;
    border-top: 1px solid rgba(255,255,255,.06);
    padding-top: 20px;
}
.da-offcanvas__block-title {
    font-family: var(--da-font-body);
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em;
    color: var(--da-gray-500);
    margin-bottom: 10px;
}

/* Menú items */
.da-offcanvas__menu { list-style: none; margin: 0; padding: 0; }
.da-offcanvas__menu li { margin: 0; }
.da-offcanvas__menu a,
.da-offcanvas__sub-toggle {
    display: flex; align-items: center; gap: 12px;
    width: 100%;
    padding: 10px 12px;
    font-family: var(--da-font-body);
    font-size: 14px; font-weight: 500;
    color: var(--da-gray-300);
    text-decoration: none; border: none; background: none;
    border-radius: 8px; cursor: pointer;
    transition: background .2s, color .2s;
}
.da-offcanvas__menu a .material-symbols-outlined,
.da-offcanvas__sub-toggle .material-symbols-outlined { font-size: 20px; }
.da-offcanvas__menu a:hover,
.da-offcanvas__sub-toggle:hover {
    background: rgba(255,255,255,.06);
    color: var(--da-white);
}

/* Highlight (Animalízate en Bloque 1) */
.da-offcanvas__highlight {
    color: var(--da-green-light) !important;
    font-weight: 600 !important;
}
.da-offcanvas__highlight:hover { background: rgba(40,168,91,.1) !important; }

/* Sub-toggle arrow */
.da-offcanvas__arrow {
    margin-left: auto; font-size: 20px !important;
    transition: transform .25s var(--da-ease);
}

/* Submenú accordion */
.da-offcanvas__submenu {
    list-style: none;
    max-height: 0; overflow: hidden;
    transition: max-height .3s var(--da-ease);
    padding-left: 20px;
}

/* Nivel 2 indentado extra */
.da-offcanvas__has-sub--level2 .da-offcanvas__submenu { padding-left: 16px; }
.da-offcanvas__submenu a { font-size: 13px; padding: 8px 12px; }

/* Menú compacto */
.da-offcanvas__menu--compact a { font-size: 13px; padding: 8px 12px; }

/* WordPress active/current item in offcanvas */
.da-offcanvas__menu .current-menu-item > a,
.da-offcanvas__menu .current-menu-item > .da-offcanvas__item-row > a,
.da-offcanvas__menu .current_page_item > a {
    color: var(--da-green-light, #4ADE80) !important;
    background: rgba(40,168,91,.08);
}

/* ─── Item row: link + toggle arrow side by side ────────── */
.da-offcanvas__item-row {
    display: flex;
    align-items: center;
    gap: 0;
}

.da-offcanvas__item-row > a {
    flex: 1;
    min-width: 0;
}

.da-offcanvas__sub-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    background: none;
    border: none;
    color: rgba(255,255,255,.4);
    cursor: pointer;
    border-radius: 8px;
    transition: background .2s, color .2s;
}

.da-offcanvas__sub-arrow:hover {
    background: rgba(255,255,255,.08);
    color: var(--da-white);
}

.da-offcanvas__sub-arrow .material-symbols-outlined {
    font-size: 22px;
    transition: transform .25s ease;
}

/* ─── Submenús WordPress multi-nivel ────────────────────── */
.da-offcanvas__menu .sub-menu {
    list-style: none;
    margin: 0;
    padding: 0 0 0 12px;
    border-left: 2px solid rgba(255,255,255,.06);
    margin-left: 14px;
}

.da-offcanvas__menu .sub-menu li { margin: 0; }

.da-offcanvas__menu .sub-menu a {
    font-size: 13px;
    padding: 9px 12px;
    color: rgba(255,255,255,.55);
}

.da-offcanvas__menu .sub-menu a:hover {
    color: var(--da-white);
    background: rgba(255,255,255,.06);
}

/* Nivel 3 */
.da-offcanvas__menu .sub-menu .sub-menu {
    padding-left: 10px;
    margin-left: 10px;
    border-left-color: rgba(255,255,255,.04);
}

.da-offcanvas__menu .sub-menu .sub-menu a {
    font-size: 12.5px;
    padding: 8px 10px;
    color: rgba(255,255,255,.45);
}

/* Nivel 4 */
.da-offcanvas__menu .sub-menu .sub-menu .sub-menu {
    padding-left: 8px;
    margin-left: 8px;
}

.da-offcanvas__menu .sub-menu .sub-menu .sub-menu a {
    font-size: 12px;
    padding: 7px 10px;
    color: rgba(255,255,255,.4);
}

/* Nivel 5 */
.da-offcanvas__menu .sub-menu .sub-menu .sub-menu .sub-menu a {
    font-size: 11.5px;
    padding: 6px 10px;
    color: rgba(255,255,255,.35);
}

/* Nivel 6 */
.da-offcanvas__menu .sub-menu .sub-menu .sub-menu .sub-menu .sub-menu a {
    font-size: 11px;
    padding: 5px 10px;
    color: rgba(255,255,255,.3);
}

/* Arrow for items with children - hide the CSS-only one since JS adds a button */
.da-offcanvas__menu .menu-item-has-children > a::after {
    display: none;
}
.da-offcanvas__menu--compact a { font-size: 13px; padding: 8px 12px; gap: 8px; }

/* CTAs */
.da-offcanvas__cta-group {
    display: flex; flex-direction: column; gap: 8px;
}
.da-offcanvas__cta {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 12px 16px; border-radius: 10px;
    font-family: var(--da-font-body);
    font-size: 14px; font-weight: 600;
    text-decoration: none;
    transition: transform .2s, box-shadow .2s;
}
.da-offcanvas__cta:hover { transform: translateY(-1px); }
.da-offcanvas__cta--primary {
    background: var(--da-green);
    color: var(--da-white);
}
.da-offcanvas__cta--primary:hover { box-shadow: 0 4px 16px rgba(27,107,58,.35); }
.da-offcanvas__cta--secondary {
    background: rgba(255,255,255,.06);
    color: var(--da-gray-300);
    border: 1px solid rgba(255,255,255,.1);
}
.da-offcanvas__cta--secondary:hover { background: rgba(255,255,255,.1); color: var(--da-white); }
.da-offcanvas__cta .material-symbols-outlined { font-size: 18px; }

/* Usuario */
.da-offcanvas__block--user {
    display: flex; gap: 8px; flex-wrap: wrap;
    border-top: 1px solid rgba(255,255,255,.06);
    padding-top: 16px;
    margin-top: 4px;
}
.da-offcanvas__user-link {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 12px; border-radius: 8px;
    font-family: var(--da-font-body);
    font-size: 13px; font-weight: 500;
    color: var(--da-gray-500); text-decoration: none;
    transition: color .2s, background .2s;
}
.da-offcanvas__user-link:hover { color: var(--da-white); background: rgba(255,255,255,.06); }
.da-offcanvas__user-link .material-symbols-outlined { font-size: 18px; }

/* Footer offcanvas */
.da-offcanvas__footer {
    padding: 16px 24px;
    border-top: 1px solid rgba(255,255,255,.06);
    flex-shrink: 0;
    text-align: center;
}
.da-offcanvas__social { display: flex; justify-content: center; gap: 16px; margin-bottom: 10px; }
.da-offcanvas__social a {
    color: var(--da-gray-500);
    transition: color .2s;
}
.da-offcanvas__social a:hover { color: var(--da-white); }
.da-offcanvas__copy {
    font-family: var(--da-font-body);
    font-size: 11px; color: var(--da-gray-700);
}

/* ============================================================
   TOPBAR
   ============================================================ */
.da-topbar {
    background: var(--da-black);
    color: var(--da-gray-300);
    height: var(--da-topbar-h);
    font-family: var(--da-font-body);
    font-size: 12px;
    border-bottom: 1px solid rgba(255,255,255,.06);
}
.da-topbar__inner {
    max-width: 1140px; margin: 0 auto;
    padding: 0 24px; height: 100%;
    display: flex; align-items: center; justify-content: space-between;
}
.da-topbar__left { display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.da-topbar__date { display: flex; align-items: center; gap: 5px; text-transform: capitalize; }
.da-topbar__date .material-symbols-outlined { font-size: 14px; }

.da-topbar__center {
    display: flex; align-items: center; gap: 10px;
    flex: 1; overflow: hidden; margin: 0 20px;
}
.da-topbar__breaking-label {
    background: var(--da-red);
    color: var(--da-white);
    padding: 2px 8px; border-radius: 3px;
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em;
    white-space: nowrap;
    animation: da-pulse 2s ease-in-out infinite;
}
@keyframes da-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .6; }
}
.da-topbar__ticker { overflow: hidden; flex: 1; }
.da-topbar__ticker-item {
    color: var(--da-gray-300); text-decoration: none;
    font-size: 12px; white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis;
    display: block;
}
.da-topbar__ticker-item:hover { color: var(--da-white); }

.da-topbar__right { display: flex; align-items: center; }
.da-topbar__social { display: flex; gap: 12px; }
.da-topbar__social a { color: var(--da-gray-500); transition: color .2s; }
.da-topbar__social a:hover { color: var(--da-white); }

/* ============================================================
   HEADER PRINCIPAL
   ============================================================ */
.da-header {
    position: relative; z-index: 999;
    background: var(--da-white);
}

/* Sticky */
.da-header.is-sticky .da-header__main {
    position: fixed; top: 0; left: 0; right: 0;
    box-shadow: 0 2px 20px rgba(0,0,0,.08);
    z-index: 999;
    animation: da-slideDown .3s var(--da-ease);
}
.da-header.is-sticky .da-topbar { visibility: hidden; height: 0; overflow: hidden; }
.da-header.is-sticky .da-nav {
    position: fixed; top: var(--da-header-h); left: 0; right: 0;
    z-index: 998;
    box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.da-header.is-hidden .da-header__main,
.da-header.is-hidden .da-nav {
    transform: translateY(-100%);
    transition: transform .3s var(--da-ease);
}
.da-header.is-sticky .da-header__main,
.da-header.is-sticky .da-nav {
    transition: transform .3s var(--da-ease);
}

@keyframes da-slideDown {
    from { transform: translateY(-100%); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}

/* Main bar */
.da-header__main {
    height: var(--da-header-h);
    background: var(--da-white);
    border-bottom: 1px solid var(--da-gray-100);
}
.da-header__inner {
    max-width: 1140px; margin: 0 auto;
    padding: 0 24px; height: 100%;
    display: flex; align-items: center; justify-content: space-between;
}

/* Hamburguesa */
.da-header__hamburger {
    background: none; border: none; cursor: pointer;
    width: 36px; height: 36px;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 5px; padding: 0;
    border-radius: 6px;
    transition: background .2s;
}
.da-header__hamburger:hover { background: var(--da-gray-100); }
.da-header__hamburger span {
    display: block; width: 22px; height: 2px;
    background: var(--da-black);
    border-radius: 2px;
    transition: all .25s var(--da-ease);
}

/* Logo */
.da-header__logo { position: absolute; left: 50%; transform: translateX(-50%); }
.da-header__logo-link {
    display: flex; align-items: center; gap: 10px;
    text-decoration: none; color: var(--da-black);
}
.da-header__logo-icon { font-size: 28px; line-height: 1; }
.da-header__logo-text { display: flex; flex-direction: column; }
.da-header__logo-main {
    font-family: var(--da-font-display);
    font-size: 26px; line-height: 1.1;
    letter-spacing: -.02em;
    color: var(--da-black);
}
.da-header__logo-tagline {
    font-family: var(--da-font-body);
    font-size: 10px; font-weight: 500;
    color: var(--da-gray-500);
    letter-spacing: .04em;
    text-transform: uppercase;
}

/* Acciones derecha */
.da-header__actions { display: flex; align-items: center; gap: 8px; }

.da-header__cta-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 18px; border-radius: 8px;
    background: var(--da-green);
    color: var(--da-white) !important;
    font-family: var(--da-font-body);
    font-size: 13px; font-weight: 600;
    text-decoration: none;
    transition: background .2s, box-shadow .2s, transform .2s;
}
.da-header__cta-btn:hover {
    background: var(--da-green-dark);
    box-shadow: 0 4px 14px rgba(27,107,58,.25);
    transform: translateY(-1px);
}
.da-header__cta-btn .material-symbols-outlined { font-size: 16px; }

.da-header__search-toggle,
.da-header__user-btn {
    background: none; border: none; cursor: pointer;
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 8px;
    color: var(--da-gray-700);
    transition: background .2s, color .2s;
    text-decoration: none;
}
.da-header__search-toggle:hover,
.da-header__user-btn:hover {
    background: var(--da-gray-100);
    color: var(--da-black);
}

/* ============================================================
   NAVEGACIÓN HORIZONTAL
   ============================================================ */
.da-nav {
    background: var(--da-white);
    border-bottom: 2px solid var(--da-green);
    height: var(--da-nav-h);
}
.da-nav__inner {
    max-width: 1140px; margin: 0 auto;
    padding: 0 24px; height: 100%;
}
.da-nav__list {
    list-style: none; display: flex; align-items: center;
    height: 100%; gap: 0; margin: 0; padding: 0;
}
.da-nav__list > li { position: relative; height: 100%; }
.da-nav__list > li > a {
    display: flex; align-items: center;
    height: 100%; padding: 0 16px;
    font-family: var(--da-font-body);
    font-size: 13px; font-weight: 600;
    color: var(--da-gray-700);
    text-decoration: none;
    letter-spacing: .04em;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color .2s, border-color .2s;
    white-space: nowrap;
}
.da-nav__list > li > a:hover,
.da-nav__list > li.current-menu-item > a,
.da-nav__list > li.current_page_item > a {
    color: var(--da-green);
    border-bottom-color: var(--da-green);
}

/* Uppercase controlado desde el admin */
.da-nav--uppercase .da-nav__list > li > a {
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* Dropdown nivel 2 */
.da-nav__list > li > .sub-menu {
    position: absolute; top: 100%; left: 0;
    min-width: 210px;
    background: var(--da-white);
    border: 1px solid var(--da-gray-100);
    border-top: 2px solid var(--da-green);
    border-radius: 0 0 8px 8px;
    box-shadow: 0 8px 30px rgba(0,0,0,.08);
    list-style: none; padding: 6px 0;
    opacity: 0; visibility: hidden;
    transform: translateY(8px);
    transition: opacity .25s, visibility .25s, transform .25s var(--da-ease);
}
.da-nav__list > li:hover > .sub-menu {
    opacity: 1; visibility: visible;
    transform: translateY(0);
}
.da-nav__list .sub-menu a {
    display: block; padding: 10px 18px;
    font-family: var(--da-font-body);
    font-size: 13px; font-weight: 500;
    color: var(--da-gray-700);
    text-decoration: none;
    transition: background .2s, color .2s;
}
.da-nav__list .sub-menu a:hover {
    background: var(--da-gray-100);
    color: var(--da-green);
}

/* ============================================================
   BUSCADOR EXPANDIBLE
   ============================================================ */
.da-search {
    background: var(--da-cream);
    max-height: 0; overflow: hidden;
    transition: max-height .35s var(--da-ease);
}
.da-search.is-open { max-height: 80px; }
.da-search__inner {
    max-width: 1140px; margin: 0 auto;
    padding: 12px 24px;
}
.da-search__form {
    display: flex; align-items: center; gap: 10px;
    background: var(--da-white);
    border: 1px solid var(--da-gray-300);
    border-radius: 10px; padding: 0 14px;
    transition: border-color .2s, box-shadow .2s;
}
.da-search__form:focus-within {
    border-color: var(--da-green);
    box-shadow: 0 0 0 3px rgba(27,107,58,.1);
}
.da-search__form .material-symbols-outlined { color: var(--da-gray-500); font-size: 22px; }
.da-search__input {
    flex: 1; border: none; outline: none;
    padding: 12px 0;
    font-family: var(--da-font-body);
    font-size: 15px; color: var(--da-black);
    background: transparent;
}
.da-search__input::placeholder { color: var(--da-gray-500); }
.da-search__close {
    background: none; border: none; cursor: pointer;
    color: var(--da-gray-500); padding: 4px;
    border-radius: 4px;
    transition: color .2s;
}
.da-search__close:hover { color: var(--da-black); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
    .da-nav__list > li > a { padding: 0 10px; font-size: 12px; }
}

@media (max-width: 768px) {
    .da-topbar__center { display: flex; margin: 0 10px; }
    .da-topbar__social { display: none; }
    .da-topbar__date { display: none; }
    .da-topbar__breaking-label { font-size: 9px; padding: 2px 6px; white-space: nowrap; }
    .da-topbar__ticker-item { font-size: 12px; }

    .da-topbar__inner,
    .da-header__inner,
    .da-nav__inner,
    .da-search__inner { padding-left: 16px; padding-right: 16px; }

    .da-header__logo-main { font-size: 20px; }
    .da-header__logo-tagline { display: none; }
    .da-header__logo-icon { font-size: 22px; }

    .da-header__cta-label { display: none; }
    .da-header__cta-btn { padding: 8px 10px; border-radius: 8px; }

    .da-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .da-nav__list { width: max-content; }
    .da-nav__list > li > a { padding: 0 12px; font-size: 11px; }

    .da-nav__list > li > .sub-menu {
        position: fixed; left: 10px; right: 10px;
        width: auto; border-radius: 8px;
    }
}

@media (max-width: 480px) {
    :root { --da-header-h: 56px; }
    .da-topbar__inner { padding-left: 12px; padding-right: 12px; }
    .da-topbar__left { display: none; }
    .da-topbar__right { display: none; }
    .da-topbar__center { margin: 0; flex: 1; }
    .da-topbar__breaking-label { font-size: 8px; padding: 2px 5px; min-width: auto; }
    .da-topbar__ticker-item { font-size: 11px; }
    .da-header__logo { position: relative; left: auto; transform: none; flex: 1; text-align: center; }
    .da-header__logo-link { justify-content: center; }
    .da-offcanvas { width: 100vw; max-width: 100vw; }
}

/* ============================================================
   RESET EXTRA
   ============================================================ */
.da-header a { box-shadow: none !important; }
.da-header .da-nav__list > li > a:after { display: none !important; }

/* ============================================================
   TERRITORIES BAR — Barra de comunidades autónomas
   ============================================================ */
.da-territories {
    background: var(--da-white);
    border-bottom: 1px solid var(--da-gray-100);
    overflow: hidden;
}

.da-territories__inner {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.da-territories__inner::-webkit-scrollbar { display: none; }

.da-territories__item {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    font-size: 11px;
    font-weight: 500;
    color: var(--da-gray-500);
    text-decoration: none;
    white-space: nowrap;
    transition: color .2s;
    border-right: 1px solid var(--da-gray-100);
    flex-shrink: 0;
}

.da-territories__item:first-child {
    border-left: none;
}

.da-territories__item:hover {
    color: var(--da-green);
}

.da-territories__item--active {
    color: var(--da-green);
    font-weight: 700;
}

@media (max-width: 768px) {
    .da-territories {
        display: none;
    }
}


/* ============================================================
   OFFCANVAS — Grupos con etiquetas, iconos, territorios
   ============================================================ */

/* Etiqueta de grupo */
.da-offcanvas__group-label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
    color: var(--da-green, #1B6B3A);
    padding: 4px 0 8px;
    text-transform: uppercase;
}

/* Menú con iconos */
.da-offcanvas__menu--icons { list-style: none; margin: 0; padding: 0; }
.da-offcanvas__menu--icons li { margin: 0; }
.da-offcanvas__menu--icons a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    font-size: 14px;
    font-weight: 500;
    color: rgba(255,255,255,.75);
    text-decoration: none;
    border-radius: 8px;
    transition: background .2s, color .2s;
}
.da-offcanvas__menu--icons a:hover {
    background: rgba(255,255,255,.08);
    color: var(--da-white);
}

.da-offcanvas__item-icon {
    font-size: 20px !important;
    color: rgba(255,255,255,.4);
    width: 24px;
    flex-shrink: 0;
}

/* Territorios */
.da-offcanvas__territories {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 4px 0;
}

.da-offcanvas__territory {
    font-size: 12px;
    color: rgba(255,255,255,.5);
    text-decoration: none;
    padding: 4px 10px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.1);
    transition: all .2s;
}

.da-offcanvas__territory:hover {
    background: rgba(255,255,255,.1);
    color: var(--da-white);
    border-color: rgba(255,255,255,.2);
}

/* Hazte socio — botón verde completo */
.da-offcanvas__hazte-socio {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 14px;
    background: var(--da-green, #1B6B3A);
    color: var(--da-white) !important;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
    transition: background .2s;
}

.da-offcanvas__hazte-socio:hover {
    background: var(--da-green-dark, #134D2A);
}

.da-offcanvas__hazte-socio .material-symbols-outlined {
    font-size: 20px;
}

/* Footer del offcanvas */
.da-offcanvas__footer-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
    color: rgba(255,255,255,.3);
    text-align: center;
    margin: 0 0 10px;
}

/* Chip "Todas" en territorios */
.da-offcanvas__territory--all {
    background: rgba(27,107,58,.15);
    border-color: rgba(27,107,58,.3);
    color: var(--da-green-light, #4ade80);
    font-weight: 600;
}
.da-offcanvas__territory--all:hover {
    background: rgba(27,107,58,.25);
}
