/* =========================================================
   OutBreak mobile public + admin UI
   ========================================================= */

:root {
    --ob-mobile-safe-x: 14px;
    --ob-mobile-radius: 22px;
}

/* ---------- PUBLIC HEADER MOBILE ---------- */

.ob-mobile-nav-toggle,
.ob-mobile-nav-panel {
    display: none;
}

@media (max-width: 920px) {
    body {
        overflow-x: hidden;
    }

    .site-header {
        position: sticky !important;
        top: 0 !important;
        z-index: 9990 !important;
        background: rgba(28, 31, 30, .94) !important;
        backdrop-filter: blur(14px);
        -webkit-backdrop-filter: blur(14px);
        border-bottom: 1px solid rgba(255,255,255,.08) !important;
    }

    .site-header .container,
    .site-header .header-inner,
    .header-inner {
        min-height: 64px !important;
        padding: 8px var(--ob-mobile-safe-x) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 10px !important;
    }

    .site-header .brand,
    .brand {
        min-width: 0 !important;
        flex: 1 1 auto !important;
        gap: 9px !important;
        text-decoration: none !important;
    }

    .brand-mark {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        border-radius: 16px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 20px !important;
    }

    .brand strong {
        display: block !important;
        font-size: 15px !important;
        line-height: 1.12 !important;
        max-width: 130px !important;
        white-space: normal !important;
    }

    .brand small {
        display: block !important;
        font-size: 10px !important;
        line-height: 1.2 !important;
        max-width: 140px !important;
        opacity: .82 !important;
    }

    .main-nav {
        display: none !important;
    }

    .header-phone {
        display: none !important;
    }

    .ob-mobile-nav-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        height: 42px !important;
        min-width: 42px !important;
        padding: 0 14px !important;
        border-radius: 999px !important;
        border: 1px solid rgba(255,255,255,.14) !important;
        background: rgba(255,255,255,.08) !important;
        color: #f3f6ef !important;
        font-weight: 950 !important;
        font-size: 13px !important;
        cursor: pointer !important;
        box-shadow: 0 12px 28px rgba(0,0,0,.18) !important;
        -webkit-tap-highlight-color: transparent;
    }

    .ob-mobile-nav-toggle::before {
        content: "☰";
        font-size: 18px;
        line-height: 1;
    }

    .ob-mobile-nav-panel {
        display: block !important;
        position: fixed !important;
        top: 74px !important;
        left: var(--ob-mobile-safe-x) !important;
        right: var(--ob-mobile-safe-x) !important;
        z-index: 9999 !important;
        border-radius: 24px !important;
        background: rgba(25, 29, 27, .98) !important;
        border: 1px solid rgba(255,255,255,.12) !important;
        box-shadow: 0 24px 70px rgba(0,0,0,.38) !important;
        padding: 10px !important;
        transform: translateY(-8px) scale(.98);
        opacity: 0;
        pointer-events: none;
        transition: opacity .18s ease, transform .18s ease;
        max-height: calc(100vh - 94px);
        overflow: auto;
    }

    .ob-mobile-nav-panel.is-open {
        transform: translateY(0) scale(1);
        opacity: 1;
        pointer-events: auto;
    }

    .ob-mobile-nav-panel a {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 12px !important;
        min-height: 48px !important;
        padding: 12px 14px !important;
        border-radius: 16px !important;
        color: #eef5ea !important;
        text-decoration: none !important;
        font-size: 15px !important;
        font-weight: 900 !important;
        border: 1px solid transparent !important;
    }

    .ob-mobile-nav-panel a::after {
        content: "›";
        opacity: .65;
        font-size: 22px;
        line-height: 1;
    }

    .ob-mobile-nav-panel a:active,
    .ob-mobile-nav-panel a:hover {
        background: rgba(215,230,196,.12) !important;
        border-color: rgba(215,230,196,.14) !important;
    }

    .ob-mobile-nav-phone {
        margin-top: 8px !important;
        background: linear-gradient(135deg, #d7e6c4, #8fa785) !important;
        color: #172017 !important;
        justify-content: center !important;
    }

    .ob-mobile-nav-phone::after {
        display: none;
    }

    body.ob-mobile-menu-open::before {
        content: "";
        position: fixed;
        inset: 0;
        z-index: 9991;
        background: rgba(0,0,0,.38);
        backdrop-filter: blur(2px);
        -webkit-backdrop-filter: blur(2px);
    }
}

/* ---------- PUBLIC MOBILE CONTENT COMPACT ---------- */

@media (max-width: 760px) {
    .container {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: var(--ob-mobile-safe-x) !important;
        padding-right: var(--ob-mobile-safe-x) !important;
    }

    .section {
        padding-top: 42px !important;
        padding-bottom: 42px !important;
    }

    .section-head {
        margin-bottom: 20px !important;
    }

    .section-head h1,
    .section-head h2,
    .hero h1 {
        font-size: clamp(28px, 9vw, 42px) !important;
        line-height: 1.05 !important;
        letter-spacing: -.04em !important;
    }

    .section-head p,
    .hero p {
        font-size: 15px !important;
        line-height: 1.55 !important;
    }

    .hero,
    .hero-card,
    .card {
        border-radius: var(--ob-mobile-radius) !important;
    }

    .hero {
        padding-top: 34px !important;
        padding-bottom: 30px !important;
        min-height: auto !important;
    }

    .services-grid,
    .grid,
    .cards-grid,
    .works-grid,
    .reviews-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .service-card {
        border-radius: 26px !important;
        max-width: 100% !important;
    }

    .service-card:has(.ob-service-image-wrap) {
        min-height: 420px !important;
    }

    .service-card:has(.ob-service-image-wrap) .ob-service-image-wrap {
        height: 288px !important;
    }

    .service-card:has(.ob-service-image-wrap) h3 {
        margin-top: 218px !important;
        font-size: 21px !important;
    }

    .service-card:has(.ob-service-image-wrap) p {
        font-size: 15px !important;
        line-height: 1.48 !important;
    }

    .service-card:has(.ob-service-image-wrap) .service-bottom {
        padding-top: 14px !important;
    }

    input,
    textarea,
    select,
    button {
        font-size: 16px !important;
    }

    .form-grid,
    form .grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .floating-contacts,
    .live-chat-widget {
        right: 12px !important;
        bottom: 12px !important;
    }
}

/* ---------- ADMIN MOBILE BASE ---------- */

@media (max-width: 920px) {
    body:has([href*="garden-control-x7a92"]),
    body.ob-admin-mobile {
        overflow-x: hidden !important;
    }

    .admin-layout,
    .admin-shell,
    .dashboard-layout,
    .control-layout {
        display: block !important;
        grid-template-columns: 1fr !important;
    }

    .admin-sidebar,
    aside,
    .sidebar {
        max-width: 100% !important;
    }

    .admin-content,
    main,
    .content,
    .dashboard-content {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .admin-card,
    .panel,
    .card,
    .table-card {
        border-radius: 20px !important;
        overflow: hidden !important;
    }

    .admin-header,
    .page-header,
    .dashboard-header {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px !important;
    }

    .admin-header h1,
    .page-header h1,
    .dashboard-header h1 {
        font-size: 24px !important;
        line-height: 1.12 !important;
    }

    .admin-table,
    table {
        display: block !important;
        width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }

    .form-grid {
        grid-template-columns: 1fr !important;
    }

    form label {
        width: 100% !important;
    }

    form input,
    form textarea,
    form select {
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .btn,
    .admin-btn,
    .button,
    .ob-service-save-btn,
    .ob-service-back-btn,
    button[type="submit"] {
        min-height: 44px !important;
        width: 100%;
    }

    .actions,
    .admin-actions,
    .form-actions {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }
}

/* ---------- ADMIN FLOATING MENU ---------- */

.ob-admin-mobile-toggle,
.ob-admin-mobile-panel {
    display: none;
}

@media (max-width: 920px) {
    .ob-admin-mobile-toggle {
        display: inline-flex !important;
        position: fixed !important;
        right: 14px !important;
        bottom: 14px !important;
        z-index: 99999 !important;
        width: 54px !important;
        height: 54px !important;
        border-radius: 18px !important;
        border: 1px solid rgba(255,255,255,.14) !important;
        background: linear-gradient(135deg, #d7e6c4, #8fa785) !important;
        color: #132013 !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 23px !important;
        font-weight: 950 !important;
        box-shadow: 0 20px 48px rgba(0,0,0,.35) !important;
        cursor: pointer !important;
    }

    .ob-admin-mobile-panel {
        display: block !important;
        position: fixed !important;
        left: 12px !important;
        right: 12px !important;
        bottom: 78px !important;
        z-index: 99998 !important;
        max-height: min(540px, calc(100vh - 104px)) !important;
        overflow: auto !important;
        padding: 10px !important;
        border-radius: 24px !important;
        background: rgba(22,25,24,.98) !important;
        border: 1px solid rgba(255,255,255,.12) !important;
        box-shadow: 0 24px 70px rgba(0,0,0,.42) !important;
        opacity: 0;
        transform: translateY(10px) scale(.98);
        pointer-events: none;
        transition: opacity .18s ease, transform .18s ease;
    }

    .ob-admin-mobile-panel.is-open {
        opacity: 1;
        transform: translateY(0) scale(1);
        pointer-events: auto;
    }

    .ob-admin-mobile-panel a {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        min-height: 46px !important;
        padding: 11px 13px !important;
        border-radius: 15px !important;
        color: #f1f5ee !important;
        text-decoration: none !important;
        font-weight: 850 !important;
        border: 1px solid transparent !important;
    }

    .ob-admin-mobile-panel a:hover,
    .ob-admin-mobile-panel a:active {
        background: rgba(215,230,196,.12) !important;
        border-color: rgba(215,230,196,.14) !important;
    }
}