/* ============================================================
   RecorderMax — main.css
   Global layout, nav, footer, components, utilities.
   CSS custom properties are defined in style.css
   ============================================================ */

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--rm-font-body);
    background: var(--rm-bg);
    color: var(--rm-dark);
    overflow-x: hidden;
    line-height: 1.6;
}

img { display: block; max-width: 100%; }
/* SVG: block by default but never stretch beyond explicit sizes */
svg { display: block; overflow: visible; }
svg:not([width]):not([height]) { max-width: 100%; }
svg { flex-shrink: 0; }
a { color: inherit; }
button { font-family: inherit; cursor: pointer; }
ul, ol { list-style: none; }

/* ── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--rm-font-heading);
    font-weight: 800;
    line-height: 1.1;
    color: var(--rm-black);
}

p { line-height: 1.7; }

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.rm-announce-bar {
    background: var(--rm-black);
    color: var(--rm-white);
    font-size: 12px;
    font-weight: 600;
    text-align: center;
    padding: 9px var(--rm-gutter);
    border-bottom: 1px solid #2a2a2a;
    position: relative;
    z-index: 301;
}

.rm-announce-bar__inner {
    max-width: var(--rm-max-w);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}

.rm-announce-bar__text em { color: var(--rm-amber); font-style: normal; }

.rm-announce-bar__text a {
    color: var(--rm-amber);
    text-decoration: none;
}
.rm-announce-bar__text a:hover { text-decoration: underline; }

.rm-announce-bar__close {
    background: none;
    border: none;
    color: #555;
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    position: absolute;
    right: var(--rm-gutter);
    top: 50%;
    transform: translateY(-50%);
    transition: color var(--rm-transition);
}
.rm-announce-bar__close:hover { color: var(--rm-white); }
.rm-announce-bar__close svg { width: 16px; height: 16px; fill: currentColor; }

.rm-announce-bar.rm-hidden { display: none; }

/* ============================================================
   NAV
   ============================================================ */
.rm-nav {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    z-index: 300;
    height: var(--rm-nav-height);
    background: var(--rm-amber);
    border-bottom: 3px solid var(--rm-amber-dark);
    box-shadow: 0 2px 16px rgba(244, 173, 61, 0.3);
    transition: box-shadow var(--rm-transition);
}

.rm-nav--scrolled { box-shadow: 0 4px 24px rgba(244, 173, 61, 0.45); }

.rm-nav__inner {
    max-width: calc(var(--rm-max-w) + 2 * var(--rm-gutter));
    margin: 0 auto;
    height: 100%;
    padding: 0 var(--rm-gutter);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

/* ── Logo ─────────────────────────────────────────────────── */
.rm-nav-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    flex-shrink: 0;
}

.rm-nav-logo__icon {
    width: 34px;
    height: 34px;
    background: var(--rm-black);
    border-radius: var(--rm-radius);
    display: grid;
    place-items: center;
    font-family: var(--rm-font-heading);
    font-weight: 900;
    font-size: 12px;
    color: var(--rm-amber);
    letter-spacing: .5px;
    flex-shrink: 0;
}

.rm-nav-logo__name {
    font-family: var(--rm-font-heading);
    font-weight: 800;
    font-size: 16px;
    color: var(--rm-black);
    letter-spacing: .5px;
}

/* Custom logo image */
.rm-nav-logo .rm-logo-img {
    height: 38px;
    width: auto;
    max-width: 160px;
    object-fit: contain;
}

/* ── Desktop nav list ─────────────────────────────────────── */
.rm-nav__list {
    display: flex;
    align-items: center;
    gap: 2px;
    flex: 1;
    padding: 0;
}

.rm-nav__item { position: relative; }

.rm-nav__link {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--rm-black);
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .4px;
    text-transform: uppercase;
    padding: 8px 12px;
    border-radius: var(--rm-radius);
    transition: background var(--rm-transition), color var(--rm-transition);
    white-space: nowrap;
}

.rm-nav__link:hover,
.rm-nav__item--active > .rm-nav__link {
    background: rgba(0, 0, 0, 0.1);
}

.rm-nav__caret {
    width: 18px;
    height: 18px;
    fill: currentColor;
    transition: transform var(--rm-transition);
}
.rm-nav__item--drop:hover .rm-nav__caret { transform: rotate(180deg); }

/* ── Dropdown ─────────────────────────────────────────────── */
.rm-drop-menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    background: var(--rm-white);
    border: 1px solid var(--rm-border);
    border-top: 2px solid var(--rm-amber-dark);
    border-radius: var(--rm-radius);
    min-width: 270px;
    padding: 8px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity var(--rm-transition), visibility var(--rm-transition), transform var(--rm-transition);
    z-index: 400;
    box-shadow: var(--rm-shadow-lg);
}

.rm-nav__item--drop:hover .rm-drop-menu,
.rm-nav__item--drop:focus-within .rm-drop-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.rm-drop-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    color: var(--rm-dark);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: background var(--rm-transition), color var(--rm-transition);
}

.rm-drop-item:hover {
    background: var(--rm-amber-light);
    color: var(--rm-amber-dark);
}

.rm-drop-item__icon {
    width: 30px;
    height: 30px;
    background: var(--rm-bg2);
    border-radius: var(--rm-radius);
    display: grid;
    place-items: center;
    flex-shrink: 0;
    transition: background var(--rm-transition);
}
.rm-drop-item:hover .rm-drop-item__icon { background: var(--rm-amber-light); }
.rm-drop-item__icon svg { width: 15px; height: 15px; fill: var(--rm-mid); transition: fill var(--rm-transition); }
.rm-drop-item:hover .rm-drop-item__icon svg { fill: var(--rm-amber-dark); }

.rm-drop-item__title { display: block; font-weight: 600; font-size: 13px; color: var(--rm-dark); }
.rm-drop-item__sub   { display: block; font-size: 10px; color: var(--rm-muted); margin-top: 1px; font-weight: 400; }

/* Drop separator — standard WP menu dividers */
.rm-drop-menu .menu-item-type-custom a[href="#"],
.rm-drop-menu li.rm-drop-sep {
    height: 1px;
    background: var(--rm-border);
    padding: 0;
    margin: 4px 0;
    pointer-events: none;
}

/* ── Nav Actions ──────────────────────────────────────────── */
.rm-nav__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

/* Cart icon */
.rm-cart-link {
    position: relative;
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    text-decoration: none;
    color: var(--rm-black);
    border-radius: var(--rm-radius);
    transition: background var(--rm-transition);
}
.rm-cart-link:hover { background: rgba(0,0,0,0.08); }
.rm-cart-link svg { width: 22px; height: 22px; fill: var(--rm-black); }

.rm-cart-count {
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(30%, -30%);
    background: var(--rm-black);
    color: var(--rm-amber);
    font-size: 9px;
    font-weight: 900;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    line-height: 1;
}
.rm-cart-count:empty { display: none; }

/* Hamburger */
.rm-nav__hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: none;
    width: 38px;
    height: 38px;
    padding: 6px;
    border-radius: var(--rm-radius);
    transition: background var(--rm-transition);
}
.rm-nav__hamburger:hover { background: rgba(0,0,0,0.1); }
.rm-nav__hamburger span {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--rm-black);
    border-radius: 2px;
    transition: transform var(--rm-transition), opacity var(--rm-transition);
}
.rm-nav__hamburger.rm-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.rm-nav__hamburger.rm-active span:nth-child(2) { opacity: 0; }
.rm-nav__hamburger.rm-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   MOBILE MENU DRAWER
   ============================================================ */
.rm-mobile-menu__overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.6);
    z-index: 490;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--rm-transition-slow), visibility var(--rm-transition-slow);
}

.rm-mobile-menu__drawer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(320px, 85vw);
    background: var(--rm-white);
    z-index: 500;
    display: flex;
    flex-direction: column;
    transform: translateX(-100%);
    transition: transform var(--rm-transition-slow);
    box-shadow: var(--rm-shadow-lg);
}

.rm-mobile-menu.rm-open .rm-mobile-menu__overlay { opacity: 1; visibility: visible; }
.rm-mobile-menu.rm-open .rm-mobile-menu__drawer  { transform: translateX(0); }

.rm-mobile-menu__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    border-bottom: 1px solid var(--rm-border);
    background: var(--rm-amber);
}

.rm-mobile-menu__close {
    background: rgba(0,0,0,0.1);
    border: none;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 20px;
    line-height: 1;
    color: var(--rm-black);
    display: grid;
    place-items: center;
    transition: background var(--rm-transition);
}
.rm-mobile-menu__close:hover { background: rgba(0,0,0,0.2); }

.rm-mobile-menu__list {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}
.rm-mobile-menu__list li a {
    display: block;
    padding: 12px 20px;
    font-size: 15px;
    font-weight: 600;
    color: var(--rm-dark);
    text-decoration: none;
    border-bottom: 1px solid var(--rm-border);
    transition: background var(--rm-transition), color var(--rm-transition);
}
.rm-mobile-menu__list li a:hover { background: var(--rm-amber-light); color: var(--rm-amber-dark); }
.rm-mobile-menu__list .sub-menu li a { padding-left: 36px; font-size: 13px; font-weight: 500; }

.rm-mobile-menu__footer {
    padding: 16px 18px;
    border-top: 1px solid var(--rm-border);
}
.rm-mobile-menu__wa {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #25D366;
    color: var(--rm-white);
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    padding: 12px 18px;
    border-radius: var(--rm-radius);
    transition: background var(--rm-transition);
}
.rm-mobile-menu__wa:hover { background: #1ebe57; }
.rm-mobile-menu__wa svg { width: 20px; height: 20px; fill: var(--rm-white); }

/* ============================================================
   PAGE WRAPPER
   ============================================================ */
.rm-page {
    min-height: 60vh;
}

/* ── Inner page content area ──────────────────────────────── */
.rm-page-content {
    max-width: var(--rm-max-w);
    margin: 0 auto;
    padding: 60px var(--rm-gutter);
}

.rm-page-content h1 {
    font-size: clamp(28px, 4vw, 48px);
    margin-bottom: 24px;
}

.rm-page-content p { margin-bottom: 16px; }
.rm-page-content a { color: var(--rm-amber-dark); text-decoration: underline; }

/* ── Page title bar ───────────────────────────────────────── */
.rm-page-title-bar {
    background: var(--rm-black);
    padding: 52px var(--rm-gutter);
    text-align: center;
}
.rm-page-title-bar h1 {
    font-size: clamp(28px, 4vw, 44px);
    color: var(--rm-white);
    margin-bottom: 10px;
}
.rm-page-title-bar .rm-breadcrumb {
    font-size: 13px;
    color: #555;
}
.rm-page-title-bar .rm-breadcrumb a { color: var(--rm-amber); text-decoration: none; }
.rm-page-title-bar .rm-breadcrumb a:hover { text-decoration: underline; }

/* ============================================================
   BUTTONS
   ============================================================ */
/* ── SVG icon sizing — prevent blowout from global display:block reset ── */

/* Inside buttons — no decorative SVGs in buttons per original HTML design */
.rm-btn svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    fill: currentColor;
    display: inline-block;
}

/* Nav icons */
.rm-nav__caret { width: 18px !important; height: 18px !important; }
.rm-cart-link svg { width: 22px !important; height: 22px !important; }
.rm-nav__hamburger span { display: block; } /* spans not SVGs */

/* Footer social icons */
.rm-footer__social svg { width: 16px !important; height: 16px !important; }

/* WhatsApp float */
.rm-wa-float svg { width: 28px !important; height: 28px !important; }

/* Mobile menu WA icon */
.rm-mobile-menu__wa svg { width: 20px !important; height: 20px !important; }

/* Announce bar close */
.rm-announce-bar__close svg { width: 16px !important; height: 16px !important; }

/* Trust badge icons inside .rm-cta-badge spans */
.rm-cta-badge svg { width: 14px !important; height: 14px !important; }

/* App card icons */
.rm-app-card__icon svg { width: 26px !important; height: 26px !important; }

/* Category card icons */
.rm-cat-card__icon svg { width: 32px !important; height: 32px !important; }

/* Stat item icons */
.rm-stat-item__icon svg { width: 36px !important; height: 36px !important; }

/* Dropdown item icons */
.rm-drop-item__icon svg { width: 15px !important; height: 15px !important; }

/* Popup close */
.rm-popup-close { font-size: 20px; }

/* WA float in footer mobile menu */
.rm-mobile-menu__wa svg { width: 20px; height: 20px; flex-shrink: 0; }

.rm-btn { 
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--rm-font-heading);
    font-weight: 800;
    font-size: 14px;
    letter-spacing: .4px;
    padding: 12px 24px;
    border-radius: var(--rm-radius);
    border: none;
    text-decoration: none;
    cursor: pointer;
    transition: background var(--rm-transition), color var(--rm-transition), transform var(--rm-transition), border-color var(--rm-transition);
    white-space: nowrap;
    line-height: 1.2;
}

.rm-btn:hover { transform: translateY(-1px); }
.rm-btn:active { transform: translateY(0); }

/* Amber (primary) */
.rm-btn--amber { background: var(--rm-amber); color: var(--rm-black); }
.rm-btn--amber:hover { background: var(--rm-amber-dark); color: var(--rm-white); }

/* Dark */
.rm-btn--dark { background: var(--rm-black); color: var(--rm-white); }
.rm-btn--dark:hover { background: var(--rm-dark); }

/* Outline amber */
.rm-btn--outline-amber {
    background: transparent;
    color: var(--rm-amber-dark);
    border: 1.5px solid rgba(244, 173, 61, 0.5);
}
.rm-btn--outline-amber:hover {
    background: var(--rm-amber-light);
    border-color: var(--rm-amber);
}

/* Full width */
.rm-btn--full { width: 100%; }

/* Large */
.rm-btn--lg { font-size: 16px; padding: 15px 36px; }

/* Nav quote button */
.rm-nav__quote-btn {
    font-size: 13px;
    padding: 9px 18px;
    letter-spacing: .5px;
    text-transform: uppercase;
}

/* ============================================================
   FORMS (global — used in popup + checkout override)
   ============================================================ */
.rm-form { width: 100%; }

.rm-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}

.rm-form__group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.rm-form__group--full { grid-column: 1 / -1; }

.rm-form__group label {
    font-size: 11px;
    font-weight: 700;
    color: var(--rm-mid);
    letter-spacing: .8px;
    text-transform: uppercase;
}

.rm-form__req { color: var(--rm-amber); }

.rm-form__group input,
.rm-form__group select,
.rm-form__group textarea {
    background: var(--rm-white);
    border: 1.5px solid rgba(244, 173, 61, 0.35);
    border-radius: var(--rm-radius);
    padding: 11px 14px;
    font-size: 14px;
    font-family: var(--rm-font-body);
    color: var(--rm-dark);
    outline: none;
    transition: border-color var(--rm-transition), box-shadow var(--rm-transition);
    resize: none;
    width: 100%;
}
.rm-form__group input:focus,
.rm-form__group select:focus,
.rm-form__group textarea:focus {
    border-color: var(--rm-amber-dark);
    box-shadow: 0 0 0 3px rgba(244, 173, 61, 0.15);
}
.rm-form__group input::placeholder,
.rm-form__group textarea::placeholder { color: #bbb; }

.rm-form__privacy {
    font-size: 11px;
    color: var(--rm-mid);
    text-align: center;
    margin-top: 12px;
    line-height: 1.5;
}
.rm-form__privacy a { color: var(--rm-mid); text-decoration: underline; }

/* ============================================================
   ENQUIRY POPUP
   ============================================================ */
.rm-popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.75);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--rm-transition-slow), visibility var(--rm-transition-slow);
    backdrop-filter: blur(4px);
}
.rm-popup-overlay.rm-open { opacity: 1; visibility: visible; }

.rm-popup-box {
    background: var(--rm-amber-light);
    border: 1px solid rgba(244, 173, 61, 0.35);
    border-top: 3px solid var(--rm-amber);
    border-radius: var(--rm-radius-lg);
    width: 100%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
    padding: 40px;
    position: relative;
    transform: translateY(20px);
    transition: transform var(--rm-transition-slow);
    box-shadow: var(--rm-shadow-lg);
}
.rm-popup-overlay.rm-open .rm-popup-box { transform: translateY(0); }

.rm-popup-close {
    position: absolute;
    top: 14px;
    right: 16px;
    width: 32px;
    height: 32px;
    background: rgba(0,0,0,0.08);
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-size: 18px;
    color: var(--rm-mid);
    transition: background var(--rm-transition), color var(--rm-transition);
    line-height: 1;
}
.rm-popup-close:hover { background: rgba(0,0,0,0.15); color: var(--rm-black); }

.rm-popup-eyebrow {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--rm-amber-dark);
    margin-bottom: 8px;
}

.rm-popup-title {
    font-size: 26px;
    font-weight: 800;
    color: var(--rm-black);
    line-height: 1.15;
    margin-bottom: 6px;
}
.rm-popup-title span { color: var(--rm-amber-dark); }

.rm-popup-sub {
    font-size: 13px;
    color: var(--rm-mid);
    margin-bottom: 24px;
    line-height: 1.5;
}

/* Success state */
.rm-popup-success {
    text-align: center;
    padding: 40px 20px;
}
.rm-popup-success__icon {
    width: 64px;
    height: 64px;
    background: rgba(61, 204, 112, 0.15);
    border: 2px solid var(--rm-success);
    border-radius: 50%;
    display: grid;
    place-items: center;
    margin: 0 auto 20px;
    font-size: 28px;
    color: var(--rm-success);
}
.rm-popup-success h3 { font-size: 22px; margin-bottom: 8px; }
.rm-popup-success p  { font-size: 14px; color: var(--rm-mid); }

/* ============================================================
   FOOTER
   ============================================================ */
.rm-footer { background: var(--rm-black); }

.rm-footer__top { border-bottom: 1px solid #1a1a1a; }

.rm-footer__inner {
    max-width: var(--rm-max-w);
    margin: 0 auto;
    padding: 60px var(--rm-gutter) 48px;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
}

/* Brand column */
.rm-footer__brand .rm-nav-logo { margin-bottom: 16px; }
.rm-footer__brand .rm-nav-logo__icon { background: var(--rm-amber); color: var(--rm-black); }
.rm-footer__brand .rm-nav-logo__name { color: var(--rm-white); }

.rm-footer__tagline {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--rm-amber);
    margin-bottom: 10px;
}

.rm-footer__sub { font-size: 13px; color: #666; line-height: 1.65; max-width: 260px; }

.rm-footer__social {
    display: flex;
    gap: 10px;
    margin-top: 20px;
}
.rm-footer__social a {
    width: 36px;
    height: 36px;
    background: #1a1a1a;
    border: 1px solid #2a2a2a;
    border-radius: var(--rm-radius);
    display: grid;
    place-items: center;
    color: #555;
    text-decoration: none;
    transition: background var(--rm-transition), border-color var(--rm-transition), color var(--rm-transition);
}
.rm-footer__social a:hover { background: var(--rm-amber); border-color: var(--rm-amber); color: var(--rm-black); }
.rm-footer__social svg { width: 16px; height: 16px; fill: currentColor; stroke: currentColor; stroke-width: 0; }

/* Footer columns */
.rm-footer__col-title {
    font-family: var(--rm-font-heading);
    font-weight: 800;
    font-size: 13px;
    color: var(--rm-white);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 18px;
}

.rm-footer__col-list { display: flex; flex-direction: column; gap: 10px; }
.rm-footer__col-list li a {
    color: #666;
    text-decoration: none;
    font-size: 13px;
    transition: color var(--rm-transition);
}
.rm-footer__col-list li a:hover { color: var(--rm-amber); }

.rm-footer__dealer-desc { font-size: 13px; color: #555; line-height: 1.6; margin-bottom: 16px; }

.rm-footer__dealer-btn { font-size: 12px; padding: 10px 16px; }

/* Bottom bar */
.rm-footer__bottom { border-top: 1px solid #1a1a1a; padding: 24px var(--rm-gutter); }

.rm-footer__bottom-inner {
    max-width: var(--rm-max-w);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 14px;
}

.rm-footer__copy { font-size: 12px; color: #444; }

.rm-footer__legal-links { display: flex; flex-wrap: wrap; gap: 6px 16px; }
.rm-footer__legal-links a {
    font-size: 12px;
    color: #444;
    text-decoration: none;
    transition: color var(--rm-transition);
}
.rm-footer__legal-links a:hover { color: var(--rm-amber); }

.rm-footer__payment { display: flex; gap: 8px; flex-wrap: wrap; }
.rm-payment-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: #1a1a1a;
    border: 1px solid #2a2a2a;
    border-radius: var(--rm-radius);
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 700;
    color: #555;
    white-space: nowrap;
    transition: border-color var(--rm-transition);
}
.rm-payment-badge:hover { border-color: #444; }

/* Disclaimer */
.rm-footer__disclaimer { background: #0a0a0a; border-top: 1px solid #1a1a1a; padding: 20px var(--rm-gutter); }
.rm-footer__disclaimer-inner { max-width: var(--rm-max-w); margin: 0 auto; }
.rm-footer__disclaimer p { font-size: 11px; color: #3a3a3a; line-height: 1.7; }
.rm-footer__disclaimer strong { color: #4a4a4a; }

/* ============================================================
   WHATSAPP FLOATING BUTTON
   ============================================================ */
.rm-wa-float {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 200;
    width: 54px;
    height: 54px;
    background: #25D366;
    border-radius: 50%;
    display: grid;
    place-items: center;
    box-shadow: 0 4px 16px rgba(37, 211, 102, 0.45);
    transition: transform var(--rm-transition), box-shadow var(--rm-transition);
    text-decoration: none;
}
.rm-wa-float:hover {
    transform: scale(1.08);
    box-shadow: 0 8px 24px rgba(37, 211, 102, 0.55);
}
.rm-wa-float svg { width: 28px; height: 28px; fill: var(--rm-white); }

/* ============================================================
   SCROLL REVEAL UTILITY
   ============================================================ */
.rm-reveal {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .6s ease, transform .6s ease;
}
.rm-reveal.rm-visible { opacity: 1; transform: none; }

/* ============================================================
   SECTION SHARED STYLES
   ============================================================ */
.rm-section { padding: 90px var(--rm-gutter); }
.rm-section__inner { max-width: var(--rm-max-w); margin: 0 auto; }

.rm-eyebrow {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--rm-amber);
    margin-bottom: 10px;
    display: block;
}

.rm-section__title {
    font-family: var(--rm-font-heading);
    font-weight: 800;
    font-size: clamp(28px, 4.5vw, 48px);
    color: var(--rm-black);
    line-height: 1.05;
    margin-bottom: 16px;
}
.rm-section__title span { color: var(--rm-amber); }

.rm-section__lead { font-size: 15px; color: var(--rm-mid); line-height: 1.7; max-width: 560px; }

/* ============================================================
   404 PAGE
   ============================================================ */
.rm-404 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 60px var(--rm-gutter);
    text-align: center;
    background: var(--rm-black);
}
.rm-404__code {
    font-family: var(--rm-font-heading);
    font-weight: 900;
    font-size: clamp(80px, 15vw, 160px);
    color: var(--rm-amber);
    line-height: 1;
    letter-spacing: -4px;
    margin-bottom: 12px;
}
.rm-404__title  { font-size: clamp(20px, 3vw, 32px); color: var(--rm-white); margin-bottom: 12px; }
.rm-404__desc   { font-size: 15px; color: #666; margin-bottom: 32px; }
.rm-404__search { display: flex; gap: 8px; max-width: 420px; width: 100%; }
.rm-404__search input {
    flex: 1;
    background: #1a1a1a;
    border: 1.5px solid #2a2a2a;
    border-radius: var(--rm-radius);
    padding: 12px 16px;
    font-size: 14px;
    color: var(--rm-white);
    outline: none;
    transition: border-color var(--rm-transition);
}
.rm-404__search input:focus { border-color: var(--rm-amber); }

/* ============================================================
   BLOG ARCHIVE
   ============================================================ */
.rm-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

.rm-post-card {
    background: var(--rm-white);
    border: 1px solid var(--rm-border);
    border-radius: var(--rm-radius-lg);
    overflow: hidden;
    transition: box-shadow var(--rm-transition), transform var(--rm-transition);
}
.rm-post-card:hover { box-shadow: var(--rm-shadow-md); transform: translateY(-3px); }

.rm-post-card__thumb { aspect-ratio: 3/2; overflow: hidden; }
.rm-post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--rm-transition-slow); }
.rm-post-card:hover .rm-post-card__thumb img { transform: scale(1.04); }

.rm-post-card__body { padding: 22px 22px 26px; }

.rm-post-card__cat {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--rm-amber-dark);
    text-decoration: none;
    margin-bottom: 8px;
    display: block;
}

.rm-post-card__title {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 10px;
}
.rm-post-card__title a { text-decoration: none; color: var(--rm-black); transition: color var(--rm-transition); }
.rm-post-card__title a:hover { color: var(--rm-amber-dark); }

.rm-post-card__excerpt { font-size: 13px; color: var(--rm-mid); line-height: 1.6; margin-bottom: 16px; }

.rm-post-card__meta { font-size: 12px; color: var(--rm-muted); }

/* ============================================================
   PAGINATION
   ============================================================ */
.rm-pagination { display: flex; justify-content: center; gap: 8px; margin-top: 48px; }
.rm-pagination a,
.rm-pagination span {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1.5px solid var(--rm-border);
    border-radius: var(--rm-radius);
    font-size: 13px;
    font-weight: 700;
    color: var(--rm-mid);
    text-decoration: none;
    transition: background var(--rm-transition), border-color var(--rm-transition), color var(--rm-transition);
}
.rm-pagination a:hover { background: var(--rm-amber-light); border-color: var(--rm-amber); color: var(--rm-amber-dark); }
.rm-pagination .current { background: var(--rm-amber); border-color: var(--rm-amber); color: var(--rm-black); }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.rm-breadcrumb {
    font-size: 12px;
    color: var(--rm-muted);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}
.rm-breadcrumb a { color: var(--rm-amber); text-decoration: none; }
.rm-breadcrumb a:hover { text-decoration: underline; }
.rm-breadcrumb__sep { color: #ccc; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
    .rm-nav__list { gap: 0; }
    .rm-nav__link { font-size: 12px; padding: 8px 10px; }
}

@media (max-width: 860px) {
    .rm-nav__list { display: none; } /* Hidden on mobile — use drawer */
    .rm-nav__hamburger { display: flex; }
    .rm-nav__quote-btn { display: none; } /* Show in mobile drawer instead */

    .rm-footer__inner { grid-template-columns: 1fr 1fr; }

    .rm-blog-grid { grid-template-columns: 1fr 1fr; }

    .rm-form__row { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
    .rm-footer__inner { grid-template-columns: 1fr; }
    .rm-footer__bottom-inner { flex-direction: column; align-items: flex-start; gap: 16px; }
    .rm-blog-grid { grid-template-columns: 1fr; }
    .rm-popup-box { padding: 24px 18px; }
    .rm-footer__legal-links { gap: 6px 12px; }
}

/* ============================================================
   POLICY PAGE CONTENT
   Applies to Terms of Use, Privacy Policy, Returns, Shipping.
   Uses .rm-page-content wrapper in page.php
   ============================================================ */
.rm-page-content h2 {
    font-family: var(--rm-font-heading);
    font-size: 22px;
    font-weight: 800;
    color: var(--rm-black);
    margin: 40px 0 12px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--rm-border);
}
.rm-page-content h2:first-child { margin-top: 0; }
.rm-page-content h3 {
    font-family: var(--rm-font-heading);
    font-size: 16px;
    font-weight: 700;
    color: var(--rm-dark);
    margin: 28px 0 8px;
}
.rm-page-content p  { margin-bottom: 16px; font-size: 15px; line-height: 1.75; color: #444; }
.rm-page-content ul,
.rm-page-content ol { margin: 0 0 18px 24px; }
.rm-page-content li { font-size: 15px; line-height: 1.75; color: #444; margin-bottom: 6px; }
.rm-page-content ul li { list-style: disc; }
.rm-page-content ol li { list-style: decimal; }
.rm-page-content a  { color: var(--rm-amber-dark); text-decoration: underline; }
.rm-page-content a:hover { color: var(--rm-amber); }
.rm-page-content strong { color: var(--rm-dark); }

/* ── Cart icon in header ── */
.rm-header-cart{display:flex;align-items:center;gap:7px;position:relative;color:var(--rm-white);padding:9px 18px;text-decoration:none;transition:opacity .2s;background:none;font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;white-space:nowrap}
.rm-header-cart:hover{opacity:.75}
.rm-header-cart svg{width:22px;height:22px;flex-shrink:0}
.rm-cart-count{background:var(--rm-amber);color:var(--rm-black);font-size:11px;font-weight:800;min-width:20px;height:20px;padding:0 5px;border-radius:20px;display:flex;align-items:center;justify-content:center;line-height:1;position:static;transform:none}
.rm-cart-count:empty,.rm-cart-count[data-count="0"]{display:none}

/* ── SIDE CART DRAWER ── */
.rm-side-cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9998;opacity:0;pointer-events:none;transition:opacity .3s}
.rm-side-cart-overlay.open{opacity:1;pointer-events:all}
.rm-side-cart{position:fixed;top:0;right:-420px;width:min(420px,100vw);height:100%;background:#fff;z-index:9999;display:flex;flex-direction:column;box-shadow:-4px 0 24px rgba(0,0,0,.15);transition:right .3s cubic-bezier(.4,0,.2,1)}
.rm-side-cart.open{right:0}
.rm-side-cart-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #f0ede7}
.rm-side-cart-title{font-family:'Poppins',sans-serif;font-weight:700;font-size:16px;display:flex;align-items:center;gap:8px}
.rm-side-cart-title svg{width:20px;height:20px}
.rm-side-cart-close{background:none;border:none;cursor:pointer;padding:6px;color:#666;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}
.rm-side-cart-close:hover{background:#f5f5f5}
.rm-side-cart-close svg{width:20px;height:20px}
.rm-side-cart-free{background:#e6f5ee;border-bottom:1px solid #a8dbca;padding:10px 20px;font-size:12px;font-weight:700;color:#0c6e51;text-align:center}
.rm-side-cart-items{flex:1;overflow-y:auto;padding:16px 20px}
.rm-side-cart-item{display:flex;gap:14px;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid #f0ede7;margin-bottom:16px}
.rm-side-cart-item:last-child{border-bottom:none;margin-bottom:0}
.rm-side-cart-img{width:72px;height:72px;border-radius:8px;object-fit:contain;border:1px solid #f0ede7;background:#fdf8f0;flex-shrink:0}
.rm-sci-info{flex:1}
.rm-sci-name{font-size:13px;font-weight:600;color:#1a1916;line-height:1.4;margin-bottom:4px}
.rm-sci-meta{font-size:11px;color:#888;margin-bottom:6px}
.rm-sci-price{font-family:'Poppins',sans-serif;font-weight:700;font-size:14px;color:#1a1916}
.rm-sci-was{font-size:11px;color:#bbb;text-decoration:line-through;margin-left:6px}
.rm-sci-remove{background:none;border:none;cursor:pointer;color:#ccc;font-size:18px;padding:2px 4px;line-height:1;transition:color .2s;flex-shrink:0}
.rm-sci-remove:hover{color:#e53935}
.rm-side-cart-footer{border-top:1px solid #f0ede7;padding:16px 20px 24px}
.rm-sc-subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.rm-sc-subtotal-label{font-size:14px;font-weight:700;color:#1a1916}
.rm-sc-subtotal-val{font-family:'Poppins',sans-serif;font-weight:800;font-size:20px;color:#1a1916}
.rm-sc-checkout{display:block;width:100%;background:#1a1916;color:#fff;text-align:center;font-family:'Poppins',sans-serif;font-weight:700;font-size:15px;padding:15px;border-radius:8px;text-decoration:none;transition:background .2s;border:none;cursor:pointer}
.rm-sc-checkout:hover{background:#333}
.rm-sc-continue{display:block;text-align:center;font-size:12px;color:#888;margin-top:10px;cursor:pointer;text-decoration:underline;background:none;border:none;width:100%}
.rm-sc-empty{text-align:center;padding:48px 20px;color:#999}
.rm-sc-empty svg{width:48px;height:48px;fill:#ddd;margin-bottom:12px}

/* ── Legal disclaimer in footer ── */
.footer-legal{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;margin-top:24px}
.footer-legal p{font-size:10.5px;color:rgba(255,255,255,.3);line-height:1.7;max-width:900px}
.footer-legal strong{color:rgba(255,255,255,.45)}

/* ══════════════════════════════════════════════
   MOBILE HAMBURGER + DRAWER
══════════════════════════════════════════════ */
.rm-nav-mobile-right{display:none;align-items:center;gap:8px}
.rm-header-cart--mobile{display:flex}
.rm-hamburger{width:40px;height:40px;background:rgba(0,0,0,.12);border:none;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;padding:0;transition:background .2s}
.rm-hamburger:hover{background:rgba(0,0,0,.22)}
.rm-hamburger span{display:block;width:20px;height:2px;background:#111;border-radius:2px;transition:all .25s}

/* Mobile drawer */
.rm-mob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:8000;opacity:0;pointer-events:none;transition:opacity .3s}
.rm-mob-overlay.open{opacity:1;pointer-events:all}
.rm-mob-drawer{position:fixed;top:0;left:-300px;width:280px;height:100%;background:#fff;z-index:8001;overflow-y:auto;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px rgba(0,0,0,.15)}
.rm-mob-drawer.open{left:0}
.rm-mob-head{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #f0f0f0;background:var(--amber)}
.rm-mob-nav{display:flex;flex-direction:column}
.rm-mob-nav a{display:block;padding:14px 20px;color:#222;text-decoration:none;font-size:14px;font-weight:600;border-bottom:1px solid #f5f5f5;transition:background .15s}
.rm-mob-nav a:hover{background:#fef3dc}
.rm-mob-nav a.rm-mob-sub{padding-left:36px;font-weight:500;font-size:13px;color:#555}
.rm-mob-section{padding:10px 20px 6px;font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#aaa;background:#f7f7f7}

@media(max-width:960px){
  .nav-links{display:none!important}
  .rm-nav-mobile-right{display:flex}
}
@media(min-width:961px){
  .rm-header-cart--mobile{display:none!important}
}

/* ══════════════════════════════════════════════
   MOBILE: Hero + Category layout fixes
══════════════════════════════════════════════ */
@media(max-width:860px){
  /* Categories: 2-col on tablet */
  .rm-cats-grid{grid-template-columns:repeat(2,1fr)!important}
  /* Hero */
  .hero-inner,.rm-hero__inner{padding:40px 5vw 48px}
  .hero-title,.rm-hero__title{font-size:clamp(32px,8vw,52px)!important}
  .hero-btns,.rm-hero__btns{flex-direction:column;align-items:flex-start;gap:10px}
}
@media(max-width:520px){
  /* Categories: 1-col on phone */
  .rm-cats-grid{grid-template-columns:1fr!important}
  .rm-cat-card{padding:24px 16px}
  /* Hero text clamp */
  .hero-title,.rm-hero__title{font-size:clamp(28px,9vw,42px)!important}
}

/* ══════════════════════════════════════════════
   FLOATING CART BUTTON (bottom-left)
══════════════════════════════════════════════ */
.rm-float-cart{
  position:fixed;bottom:24px;left:24px;z-index:9000;
  background:#fff;border-radius:16px;padding:14px 22px;
  box-shadow:0 4px 20px rgba(0,0,0,.18);
  border:1px solid #eee;
  display:flex;align-items:center;gap:10px;cursor:pointer;
  opacity:0;transform:translateY(8px);pointer-events:none;
  transition:all .3s;
}
.rm-float-cart.visible{opacity:1;transform:translateY(0);pointer-events:all}
.rm-float-cart svg{width:26px;height:26px;fill:#111}
.rm-float-cart-count{font-family:'Poppins',sans-serif;font-weight:800;font-size:15px;color:#111}
.rm-float-cart-qty{display:flex;align-items:center;gap:6px;border-left:1px solid #eee;padding-left:10px}
.rm-float-qty-btn{width:24px;height:24px;border-radius:6px;border:1px solid #ddd;background:#f7f7f7;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;color:#333;transition:all .2s;padding:0}
.rm-float-qty-btn:hover{background:var(--amber);border-color:var(--amber);color:#111}
.rm-float-qty-num{font-weight:700;font-size:13px;min-width:14px;text-align:center}

/* ══════════════════════════════════════════════
   SIDE CART: Quantity buttons + green checkout
══════════════════════════════════════════════ */
.rm-sci-qty-row{display:flex;align-items:center;gap:8px;margin-top:8px}
.rm-sci-qty-btn{width:28px;height:28px;border-radius:6px;border:1px solid #e0e0e0;background:#f7f7f7;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;transition:all .2s;padding:0;flex-shrink:0}
.rm-sci-qty-btn:hover{background:var(--amber);border-color:var(--amber)}
.rm-sci-qty-num{font-size:13px;font-weight:700;color:#1a1916;min-width:20px;text-align:center}
/* Green checkout button */
.rm-sc-checkout{background:#27ae60!important;color:#fff!important}
.rm-sc-checkout:hover{background:#219653!important}

/* ══════════════════════════════════════════════
   FLOAT CART — simplified (image 5 style)
   Just icon + count, no qty controls
══════════════════════════════════════════════ */
.rm-float-cart-qty { display: none !important; }

/* ══════════════════════════════════════════════
   HIDE "VIEW CART" after Add to Cart
══════════════════════════════════════════════ */
.added_to_cart,
.woocommerce-message a.button,
.wc-block-components-notice-banner a.wc-forward,
.woocommerce .woocommerce-message .button { display: none !important; }
.woocommerce-notices-wrapper { display: none !important; }

/* ══════════════════════════════════════════════
   PROCEED TO CHECKOUT — green (matches side cart)
══════════════════════════════════════════════ */
.rm-sc-checkout,
.rm-sc-checkout:link,
.rm-sc-checkout:visited,
a.rm-sc-checkout,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.wc-proceed-to-checkout .checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a { 
    background: #27ae60 !important; 
    color: #fff !important; 
    border-color: #27ae60 !important;
}
.rm-sc-checkout:hover,
.wc-proceed-to-checkout .checkout-button:hover,
.woocommerce-cart .wc-proceed-to-checkout a:hover { 
    background: #219653 !important; 
}

/* ============================================================
   GMB REVIEWS — homepage + product page shared styles
   ============================================================ */
.rm-gmb-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid #eee;
}
.rm-gmb-score {
    display: flex;
    align-items: center;
    gap: 10px;
}
.rm-gmb-num {
    font-family: var(--rm-font-heading, 'Poppins', sans-serif);
    font-size: 36px;
    font-weight: 900;
    color: var(--rm-black, #1a1916);
    line-height: 1;
}
.rm-gmb-stars {
    color: #f5a623;
    font-size: 20px;
    letter-spacing: 1px;
}
.rm-gmb-total {
    font-size: 13px;
    color: var(--rm-mid, #666);
}
.rm-gmb-write-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border: 1.5px solid #ddd;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    color: var(--rm-black, #1a1916);
    text-decoration: none;
    transition: border-color 0.2s, background 0.2s;
}
.rm-gmb-write-btn:hover {
    border-color: #4285F4;
    background: #f0f4ff;
    color: #1a1916;
}

/* Grid */
.rm-gmb-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

/* Card */
.rm-gmb-card {
    background: #fff;
    border: 1.5px solid #eee;
    border-radius: 12px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: box-shadow 0.2s;
}
.rm-gmb-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.07); }

.rm-gmb-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
}
.rm-gmb-card__avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}
.rm-gmb-card__avatar--initials {
    background: var(--rm-amber, #e89000);
    color: #111;
    font-weight: 700;
    font-size: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.rm-gmb-card__meta {
    flex: 1;
    min-width: 0;
}
.rm-gmb-card__name {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: var(--rm-black, #1a1916);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.rm-gmb-card__name:hover { text-decoration: underline; }
.rm-gmb-card__role {
    display: block;
    font-size: 11px;
    color: var(--rm-amber, #e89000);
    font-weight: 600;
}
.rm-gmb-card__time {
    font-size: 11px;
    color: var(--rm-muted, #aaa);
}
.rm-gmb-card__glogo { flex-shrink: 0; margin-left: auto; }
.rm-gmb-card__stars { color: #f5a623; font-size: 14px; letter-spacing: 0.5px; }
.rm-gmb-card__text p {
    font-size: 13px;
    color: var(--rm-mid, #555);
    line-height: 1.7;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Responsive */
@media (max-width: 900px) { .rm-gmb-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .rm-gmb-grid { grid-template-columns: 1fr; } }
