/* ============================================================================
   SPURA HUB v3 - Mobile Legacy Slice 01
   Mechanical split from mobile-ios.css; preserve load order.
   ============================================================================ */
/* ============================================================================
   SPURA HUB v3 - Mobile / iOS Safari UX layer
   Loaded after view-local styles to normalize viewport, touch and keyboard fixes.
   ============================================================================ */
:root {
    --touch-target-min: 44px;
    --native-keyboard-height: 0px;
}
html,
body {
    max-width: 100%;
    overflow-x: clip;
}
@supports not (overflow-x: clip) {
    html,
    body {
        overflow-x: hidden;
    }
}
button,
a,
input,
select,
textarea,
summary,
[role="button"] {
    -webkit-tap-highlight-color: transparent;
}
input,
select,
textarea {
    min-width: 0;
    max-width: 100%;
}
button,
.btn {
    min-width: 0;
}
.form-group,
.form-input,
.form-select,
.auth-input {
    min-width: 0;
}
.data-table-scroll,
.table-responsive,
.publications-table-body {
    overscroll-behavior-x: contain;
}
@media (hover: none) and (pointer: coarse) {
    .btn:hover,
    .card:hover,
    .landing-module-card:hover,
    .color-swatch:hover {
        transform: none;
    }
    .btn,
    .tab,
    .topbar-toggle,
    .topbar-action-btn,
    .modal-close,
    .sidebar-brand-toggle,
    .sidebar-collapse-btn,
    .sidebar-link,
    .sidebar-group-toggle,
    .sidebar-child-link,
    .notif-item,
    .topbar-search-result,
    .publication-link-search-results__item,
    .landing-btn-ghost,
    .landing-btn-solid,
    .landing-hero-cta-primary,
    .landing-hero-cta-secondary,
    .landing-module-action,
    .auth-btn,
    .submit-btn,
    .cta-btn,
    .back-link,
    .showroom-back-link,
    .showroom-thumbnail,
    .gallery-thumb,
    .color-swatch,
    .option-card {
        min-height: var(--touch-target-min);
    }
    .btn-icon,
    .topbar-toggle,
    .topbar-action-btn,
    .modal-close,
    .sidebar-brand-toggle,
    .sidebar-collapse-btn,
    .showroom-thumbnail,
    .gallery-thumb,
    .color-swatch,
    .mobile-bottom-nav__item,
    .mobile-home-greeting,
    .mobile-home-alerts {
        min-width: var(--touch-target-min);
        min-height: var(--touch-target-min);
    }
    .mobile-bottom-nav__item {
        min-height: var(--touch-target-min);
    }
    .row-menu-trigger,
    .topbar-search-clear,
    .mobile-search-close,
    .ui-filter-form .btn,
    .ui-filter-form .form-input,
    .ui-filter-form .form-select,
    .ui-filter-field .btn,
    .ui-action-row .btn,
    .ui-button-group .btn,
    .page-header-actions .btn,
    .inbox-card-item,
    .row-action-item,
    details.card > summary {
        min-height: var(--touch-target-min);
    }
    .row-menu-trigger,
    .topbar-search-clear,
    .mobile-search-close {
        min-width: var(--touch-target-min);
    }
    .row-menu-trigger {
        width: var(--touch-target-min);
        height: var(--touch-target-min);
        padding: 0;
    }
    .ui-filter-form .btn-sm,
    .page-header-actions .btn-sm {
        min-height: var(--touch-target-min);
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
    }
    .btn-sm {
        padding: 0.5rem 0.875rem;
    }
    /* ── Active (press) feedback — instant tactile response ── */
    .btn:active,
    .sidebar-link:active,
    .sidebar-child-link:active,
    .card[onclick]:active,
    a.card:active {
        opacity: 0.72;
        transform: scale(0.975);
        transition: opacity 0.05s ease, transform 0.05s ease;
    }
    .mobile-bottom-nav__item:active {
        opacity: 0.6;
        transform: scale(0.92);
        transition: opacity 0.05s ease, transform 0.05s ease;
    }
    .installer-picker-card:active label,
    .option-card:active {
        opacity: 0.8;
        transform: scale(0.97);
        transition: opacity 0.05s ease, transform 0.05s ease;
    }
}
@media (max-width: 768px) {
    .topbar-toggle {
        display: none !important;
    }
    body.app-body {
        min-height: calc(100svh - var(--safe-area-top) - var(--safe-area-bottom));
    }
    @supports (height: 100dvh) {
        body.app-body {
            min-height: calc(100dvh - var(--safe-area-top) - var(--safe-area-bottom));
        }
    }
    body.sidebar-open {
        overflow: hidden;
    }
    .app-shell {
        min-height: calc(100svh - var(--safe-area-top) - var(--safe-area-bottom));
    }
    @supports (height: 100dvh) {
        .app-shell {
            min-height: calc(100dvh - var(--safe-area-top) - var(--safe-area-bottom));
        }
    }
    .page-content {
        padding-top: 1rem;
        padding-right: max(var(--page-padding-mobile), var(--safe-area-right));
        padding-bottom: calc(1.25rem + var(--safe-area-bottom));
        padding-left: max(var(--page-padding-mobile), var(--safe-area-left));
    }
    .mobile-home-panel {
        display: grid;
        gap: 0.875rem;
        margin-bottom: 1rem;
    }
    .admin-dashboard-page-header {
        display: none;
    }
    .mobile-home-greeting,
    .mobile-home-alerts,
    .mobile-home-card {
        min-width: 0;
        border: 1px solid var(--border-color, var(--gray-200));
        background: var(--bg-surface, var(--bg-surface));
        box-shadow: var(--shadow-sm, 0 1px 3px var(--glass-ink-08));
    }
    .mobile-home-greeting {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.95rem;
        border-radius: var(--radius-lg, 14px);
    }
    .mobile-home-greeting__text,
    .mobile-home-greeting__sub,
    .mobile-home-alerts__title,
    .mobile-home-alerts__sub,
    .mobile-home-card__label,
    .mobile-home-card__sub {
        display: block;
    }
    .mobile-home-greeting__text {
        color: var(--text-primary, var(--ink-950));
        font-size: 1.15rem;
        font-weight: 750;
        line-height: 1.15;
    }
    .mobile-home-greeting__sub {
        margin-top: 0.2rem;
        color: var(--text-muted, var(--ink-400));
        font-size: 0.82rem;
        font-weight: 600;
    }
    .mobile-home-alerts {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        align-items: center;
        gap: 0.75rem;
        padding: 0.85rem 0.95rem;
        border-radius: var(--radius-lg, 14px);
        color: var(--brand-700, var(--brand-600));
        text-decoration: none;
    }
    .mobile-home-alerts__icon {
        display: inline-flex;
        width: 2.25rem;
        height: 2.25rem;
        align-items: center;
        justify-content: center;
        border-radius: var(--radius-full, 9999px);
        background: var(--glass-danger-10);
        color: var(--danger, var(--danger-500));
    }
    .mobile-home-alerts__title {
        color: var(--text-primary, var(--ink-950));
        font-size: 0.9rem;
        font-weight: 750;
        line-height: 1.2;
    }
    .mobile-home-alerts__sub {
        margin-top: 0.15rem;
        color: var(--text-muted, var(--ink-400));
        font-size: 0.78rem;
        line-height: 1.25;
    }
    .mobile-home-cards {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }
    .mobile-home-card {
        display: grid;
        gap: 0.25rem;
        min-height: 116px;
        align-content: start;
        padding: 0.9rem;
        border-radius: var(--radius-lg, 14px);
        color: var(--text-primary, var(--ink-950));
        text-decoration: none;
    }
    .mobile-home-card__icon {
        display: inline-flex;
        width: 2rem;
        height: 2rem;
        align-items: center;
        justify-content: center;
        margin-bottom: 0.25rem;
        border-radius: var(--radius-md, 10px);
        background: rgba(var(--brand-500-rgb), 0.10);
        color: var(--brand-700, var(--brand-600));
    }
    .mobile-home-card__icon--sales {
        background: rgba(var(--brand-500-rgb), 0.10);
        color: var(--brand-600, var(--brand-600));
    }
    .mobile-home-card__icon--logistics {
        background: rgba(var(--brand-500-rgb), 0.10);
        color: var(--brand-700, var(--brand-600));
    }
    .mobile-home-card__icon--brand {
        background: var(--glass-misc-12458237-10);
        color: var(--purple-600);
    }
    .mobile-home-card__icon--admin {
        background: var(--glass-warning-12);
        color: var(--color-warning-dark);
    }
    .mobile-home-card__value {
        color: var(--text-primary, var(--ink-950));
        font-size: 1.35rem;
        font-weight: 800;
        line-height: 1;
    }
    .mobile-home-card__label {
        color: var(--text-primary, var(--ink-950));
        font-size: 0.9rem;
        font-weight: 750;
        line-height: 1.2;
        overflow-wrap: anywhere;
    }
    .mobile-home-card__sub {
        color: var(--text-muted, var(--ink-400));
        font-size: 0.76rem;
        line-height: 1.25;
        overflow-wrap: anywhere;
    }
    .topbar {
        top: var(--safe-area-top);
        height: auto;
        min-height: var(--topbar-height);
        gap: 0.75rem;
        justify-content: space-between;
        padding-top: 0;
        padding-right: max(0.75rem, var(--safe-area-right));
        padding-bottom: 0;
        padding-left: max(0.75rem, var(--safe-area-left));
    }
    .mobile-topbar-heading {
        display: flex;
        align-items: center;
        min-width: 0;
        flex: 1 1 auto;
    }
    .mobile-topbar-title {
        margin: 0;
        max-width: 100%;
        overflow: hidden;
        color: var(--text-primary);
        font-size: 1rem;
        font-weight: 700;
        line-height: 1.2;
        letter-spacing: 0;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .mobile-topbar-user {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        flex: 0 0 auto;
    }
    .mobile-topbar-avatar {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 2.25rem;
        height: 2.25rem;
        border-radius: var(--radius-full);
        background: linear-gradient(135deg, var(--brand-500, var(--brand-500)), var(--brand-700, var(--brand-600)));
        color: var(--bg-surface);
        font-size: 0.9rem;
        font-weight: 700;
        box-shadow: 0 0.5rem 1.25rem var(--glass-brand-22);
    }
    .topbar-search {
        display: none;
    }

    body.cmd-palette-active .topbar-search {
        display: flex;
    }

    .topbar-search-wrapper .search-kbd {
        display: none;
    }

    .topbar-actions {
        display: none !important;
    }
    /* Hide the desktop bell/dropdown in mobile; Inbox has its own fullscreen panel */
    .notif-bell-wrap {
        width: 0;
        height: 0;
        overflow: visible;
        padding: 0;
        margin: 0;
    }
    .notif-bell-btn {
        display: none !important;
    }
    .notif-dropdown {
        display: none !important;
    }
    .sidebar {
        top: var(--safe-area-top);
        bottom: var(--safe-area-bottom);
        left: var(--safe-area-left);
        width: min(var(--sidebar-width), calc(100vw - var(--safe-area-left) - var(--safe-area-right) - 0.75rem));
        max-width: calc(100vw - var(--safe-area-left) - var(--safe-area-right));
        padding-top: 0;
        padding-bottom: 0;
    }
    .sidebar-footer {
        padding-bottom: max(0.875rem, calc(0.875rem + var(--safe-area-bottom)));
    }
    .modal-overlay {
        min-height: 100svh;
        align-items: center;
        overflow-y: auto;
        padding-top: max(0.75rem, var(--safe-area-top));
        padding-right: max(0.75rem, var(--safe-area-right));
        padding-bottom: max(0.75rem, var(--safe-area-bottom));
        padding-left: max(0.75rem, var(--safe-area-left));
    }
    @supports (height: 100dvh) {
        .modal-overlay {
            min-height: 100dvh;
        }
    }
    .modal {
        width: 100%;
        max-height: calc(100svh - var(--safe-area-top) - var(--safe-area-bottom) - 1.5rem);
        overscroll-behavior: contain;
    }
    @supports (height: 100dvh) {
        .modal {
            max-height: calc(100dvh - var(--safe-area-top) - var(--safe-area-bottom) - 1.5rem);
        }
    }
    .modal-header,
    .modal-body,
    .modal-footer {
        padding-right: 1rem;
        padding-left: 1rem;
    }
    .modal-footer {
        flex-wrap: wrap;
        padding-bottom: max(1rem, calc(0.75rem + var(--safe-area-bottom)));
    }
    .modal-footer .btn {
        justify-content: center;
    }
    .btn:not(.btn-icon) {
        white-space: normal;
        text-align: center;
    }
    input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]),
    select,
    textarea,
    .form-input,
    .form-select,
    .auth-input {
        width: 100%;
        min-width: 0;
        max-width: 100%;
        min-height: var(--touch-target-min);
        font-size: 16px !important;
        line-height: 1.35;
    }
    select,
    select.form-input,
    .form-select {
        -webkit-appearance: none;
        appearance: none;
        background-position: right 0.875rem center;
        text-overflow: ellipsis;
    }
    input[type="date"].form-input,
    input[type="datetime-local"].form-input,
    input[type="month"].form-input,
    input[type="number"].form-input,
    input[type="time"].form-input {
        height: auto;
        padding-top: 0.625rem;
        padding-bottom: 0.625rem;
    }
    textarea,
    textarea.form-input {
        min-height: calc(var(--touch-target-min) * 2);
        resize: vertical;
    }
    input[type="file"].form-input,
    input[type="file"].auth-input {
        height: auto;
        min-height: var(--touch-target-min);
        padding-top: 0.65rem;
        padding-bottom: 0.65rem;
        white-space: normal;
    }
    input[type="file"].form-input::file-selector-button,
    input[type="file"].auth-input::file-selector-button {
        min-height: var(--touch-target-min);
        margin: -0.25rem 0.75rem -0.25rem 0;
        padding: 0.4rem 0.75rem;
        border: 1px solid var(--border-color-strong);
        border-radius: var(--radius-sm);
        background: var(--bg-secondary);
        color: var(--text-primary);
        font: inherit;
    }
    input[type="file"].form-input::-webkit-file-upload-button,
    input[type="file"].auth-input::-webkit-file-upload-button {
        min-height: var(--touch-target-min);
        margin: -0.25rem 0.75rem -0.25rem 0;
        padding: 0.4rem 0.75rem;
        border: 1px solid var(--border-color-strong);
        border-radius: var(--radius-sm);
        background: var(--bg-secondary);
        color: var(--text-primary);
        font: inherit;
    }
    input[type="checkbox"],
    input[type="radio"] {
        min-width: 22px;
        min-height: 22px;
    }
    .page-content,
    .page-content > *,
    .card,
    .card-header,
    .card-body,
    .card-footer,
    .modal,
    .modal-body,
    .form-group,
    .flex > *,
    .grid > *,
    .ui-form-grid > *,
    .ui-filter-form > *,
    .ui-action-row > *,
    .ui-button-group > *,
    .ui-inline-meta > *,
    .stats-row > *,
    .mobile-card > * {
        min-width: 0;
    }
    .form-label,
    .auth-label,
    .form-group label {
        font-size: 0.875rem;
    }
    .page-header-title,
    .ops-page-surface .page-header-title {
        font-size: min(1.5rem, 5.5vw);
        letter-spacing: -0.02em;
        line-height: 1.25;
        overflow-wrap: anywhere;
    }
    .page-header-actions {
        gap: 0.32rem;
    }
    .page-header-actions > * {
        flex: 1 1 100%;
    }
    .card-header,
    .card-body,
    .card-footer {
        padding-right: var(--page-padding-mobile);
        padding-left: var(--page-padding-mobile);
    }
    .grid-cols-2 {
        grid-template-columns: 1fr;
    }
    .grid-cols-3 {
        grid-template-columns: 1fr;
    }
    .grid-cols-4 {
        grid-template-columns: 1fr;
    }
    .card {
        max-width: 100%;
    }
    .card-header {
        align-items: flex-start;
        flex-wrap: wrap;
        gap: 0.75rem;
        padding: 1rem;
    }
    .card-body {
        padding: 1rem;
    }
    .data-table-scroll.table-mobile-scroll,
    .table-responsive.table-mobile-scroll {
        max-width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .data-table-scroll.table-mobile-scroll > .data-table,
    .table-responsive.table-mobile-scroll > .data-table {
        width: max-content;
        min-width: 100%;
    }
    .data-table thead th,
    .data-table tbody td {
        padding: 0.75rem;
    }
    .stat-card--with-icon {
        align-items: flex-start;
        flex-wrap: wrap;
    }
    .stat-card-link {
        width: 100%;
        margin-left: 0;
    }
    .empty-state {
        padding: 2.25rem 1rem;
    }
    .tabs-bar {
        overflow-x: auto;
    }
    .tabs-bar::-webkit-scrollbar {
        display: none;
    }
    .tab {
        white-space: nowrap;
    }
    html.mobile-shell-locked,
    body.mobile-shell-locked,
    body.cmd-palette-active {
        overflow: hidden;
        overscroll-behavior: none;
    }
    body.mobile-shell-locked {
        position: fixed;
        left: 0;
        right: 0;
        width: 100%;
    }
    body.mobile-hub-open .page-content,
    body.mobile-inbox-open .page-content,
    body.cmd-palette-active .page-content {
        visibility: hidden;
    }
    .auth-shell,
    .landing-shell {
        min-height: 100svh;
    }
    @supports (height: 100dvh) {
        .auth-shell,
        .landing-shell {
            min-height: 100dvh;
        }
    }
    .auth-panel-form,
    .landing-container,
    .showroom-container,
    .customize-page,
    .product-detail {
        max-width: 100%;
    }
    .publication-link-modal {
        height: 100svh;
        padding-top: max(0.75rem, var(--safe-area-top));
        padding-right: max(0.75rem, var(--safe-area-right));
        padding-bottom: max(0.75rem, var(--safe-area-bottom));
        padding-left: max(0.75rem, var(--safe-area-left));
    }
    @supports (height: 100dvh) {
        .publication-link-modal {
            height: 100dvh;
        }
    }
    .publication-link-modal__dialog {
        margin: 0 auto;
        max-height: calc(100svh - var(--safe-area-top) - var(--safe-area-bottom) - 1.5rem);
    }
    @supports (height: 100dvh) {
        .publication-link-modal__dialog {
            max-height: calc(100dvh - var(--safe-area-top) - var(--safe-area-bottom) - 1.5rem);
        }
    }
    .publication-link-search-results {
        max-height: calc(100svh - var(--safe-area-top) - var(--safe-area-bottom) - 12rem);
    }
    @supports (height: 100dvh) {
        .publication-link-search-results {
            max-height: calc(100dvh - var(--safe-area-top) - var(--safe-area-bottom) - 12rem);
        }
    }
}
