/* ==========================================================
   Dreambit mobile menu — v2 (action-first design).
   Namespaced to .dm-menu, mounted on #mobileMenu.
   Open state: .mob-menu-open (toggled by the burger button).
   ========================================================== */

#mobileMenu.dm-menu {
    --dm-blue:#385098;
    --dm-blue-ink:#2A3F7C;
    --dm-blue-tint:#EEF1F8;
    --dm-cream:#F4F5F0;
    --dm-line:#E8EAEF;
    --dm-line-soft:#EFF1F4;
    --dm-ink:#0A1322;
    --dm-ink-2:#1B2436;
    --dm-muted:#6B7280;

    position: fixed;
    inset: 0;
    z-index: 9999;
    background: var(--dm-cream);
    color: var(--dm-ink);
    font-family: 'Onest', system-ui, sans-serif;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transform: translateY(100%);
    visibility: hidden;
    pointer-events: none;
    transition: transform 320ms cubic-bezier(.2,.7,.2,1), visibility 0s linear 320ms;
}
#mobileMenu.dm-menu.mob-menu-open {
    transform: translateY(0);
    visibility: visible;
    pointer-events: auto;
    transition: transform 320ms cubic-bezier(.2,.7,.2,1), visibility 0s;
}

#mobileMenu.dm-menu ul,
#mobileMenu.dm-menu li {
    list-style: none;
    margin: 0;
    padding: 0;
}
#mobileMenu.dm-menu a { text-decoration: none; }

.dm-menu__scroll {
    flex: 1;
    overflow-y: auto;
    padding-top: env(safe-area-inset-top, 0);
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex-direction: column;
}

/* ---------- header ---------- */
.dm-menu__header {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 14px 20px 12px;
}
.dm-menu__logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    letter-spacing: -0.02em;
    font-size: 17px;
    color: var(--dm-ink);
}
.dm-menu__logo-mark {
    width: 28px;
    height: 28px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
.dm-menu__close {
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--dm-line);
    color: var(--dm-ink);
    display: grid;
    place-items: center;
    cursor: pointer;
    padding: 0;
    transition: background .15s ease, color .15s ease;
}
.dm-menu__close:hover { background: var(--dm-ink); color: #fff; }
.dm-menu__close svg { width: 16px; height: 16px; display: block; }

/* ---------- quick actions ---------- */
.dm-menu__actions {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 8px;
    padding: 6px 20px 18px;
}
.dm-menu__action {
    display: flex;
    flex-direction: column;
    gap: 10px;
    background: #fff;
    color: var(--dm-ink);
    border: 1px solid var(--dm-line);
    border-radius: 16px;
    padding: 14px 14px 16px;
    font: inherit;
    text-align: left;
    cursor: pointer;
    transition: transform .15s ease, border-color .15s ease;
    min-height: 96px;
}
.dm-menu__action:active { transform: scale(.985); }
.dm-menu__action:hover { border-color: var(--dm-ink); }
.dm-menu__action--primary {
    background: var(--dm-ink);
    border-color: var(--dm-ink);
    color: #fff;
}
.dm-menu__action--primary:hover { background: var(--dm-blue-ink); border-color: var(--dm-blue-ink); }
.dm-menu__action-icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: var(--dm-cream);
    color: var(--dm-ink);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}
.dm-menu__action--primary .dm-menu__action-icon {
    background: var(--dm-blue);
    color: #fff;
}
.dm-menu__action-icon svg { width: 18px; height: 18px; display: block; }
.dm-menu__action-label {
    font-size: 13.5px;
    font-weight: 600;
    letter-spacing: -0.005em;
    line-height: 1.15;
    display: block;
}
.dm-menu__action-sub {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10.5px;
    opacity: .55;
    display: block;
    margin-top: 3px;
    letter-spacing: .02em;
}

/* ---------- nav list ---------- */
.dm-menu__nav {
    margin: 0 20px;
    background: #fff;
    border: 1px solid var(--dm-line);
    border-radius: 18px;
    overflow: hidden;
}
.dm-menu__nav-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
    border-top: 1px solid var(--dm-line-soft);
    color: var(--dm-ink);
    font: inherit;
    background: transparent;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    width: 100%;
    text-align: left;
    cursor: pointer;
    min-height: 56px;
}
.dm-menu__nav li:first-child .dm-menu__nav-item { border-top: 0; }
.dm-menu__nav-item:hover { background: var(--dm-cream); }
.dm-menu__nav-label {
    font-size: 17px;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--dm-ink);
}
.dm-menu__nav-meta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--dm-muted);
}
.dm-menu__nav-count {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    color: var(--dm-muted);
    letter-spacing: .04em;
}
.dm-menu__nav-icon {
    width: 16px;
    height: 16px;
    color: var(--dm-ink-2);
    display: grid;
    place-items: center;
    transition: transform .25s ease;
}
.dm-menu__nav-icon svg { width: 16px; height: 16px; display: block; }
.dm-menu__nav-item[aria-current="page"] { background: var(--dm-blue-tint); }
.dm-menu__nav-item[aria-current="page"] .dm-menu__nav-label,
.dm-menu__nav-item[aria-current="page"] .dm-menu__nav-count,
.dm-menu__nav-item[aria-current="page"] .dm-menu__nav-icon { color: var(--dm-blue); }
.dm-menu__nav-item[aria-expanded="true"] .dm-menu__nav-icon { transform: rotate(90deg); }

/* ---------- expandable submenu ---------- */
.dm-menu__submenu {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .3s ease;
    background: var(--dm-cream);
}
.dm-menu__submenu > .dm-menu__submenu-inner {
    overflow: hidden;
    min-height: 0;
}
.dm-menu__submenu[data-open="true"] { grid-template-rows: 1fr; }
.dm-menu__submenu ul { padding: 6px 0 10px; }
.dm-menu__submenu a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 22px 12px 36px;
    font-size: 15px;
    color: var(--dm-ink-2);
    min-height: 44px;
}
.dm-menu__submenu a:hover { color: var(--dm-blue); }
.dm-menu__submenu .mono {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    color: var(--dm-muted);
}

/* ---------- footer ---------- */
.dm-menu__footer {
    margin-top: auto;
    padding: 16px 20px 26px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    color: var(--dm-muted);
    letter-spacing: .04em;
}
.dm-menu__locales { display: flex; gap: 6px; }
.dm-menu__locale {
    padding: 6px 10px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--dm-line);
    color: var(--dm-muted);
    cursor: pointer;
    font: inherit;
}
.dm-menu__locale[aria-current="true"] {
    background: var(--dm-ink);
    border-color: var(--dm-ink);
    color: #fff;
}
.dm-menu__offices { letter-spacing: .04em; }

@supports (padding: env(safe-area-inset-bottom)) {
    .dm-menu__footer { padding-bottom: calc(26px + env(safe-area-inset-bottom)); }
}
