/* ================================================================
   NearMe app.css — complete design system
   All colours come from CSS custom properties set in index.php
   from admin Settings → Appearance. Change settings → see instantly.
   ================================================================ */

/* ── reset ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:var(--nm-font-size,16px);-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--nm-font);background:var(--nm-bg);color:var(--nm-text);line-height:1.5;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button{cursor:pointer;border:none;background:none;font:inherit;line-height:inherit}
ul,ol{list-style:none}
input,textarea,select{font:inherit}
svg{display:block}

/* ── app shell ────────────────────────────────────────────────── */
#nm-app{display:flex;flex-direction:column;min-height:100dvh;position:relative}
#nm-view{padding-top:var(--nm-header-h);overflow-x:hidden;will-change:contents;flex:1 0 auto;display:flex;flex-direction:column}
#nm-view>*:last-child{margin-top:auto}
.nm-header-top-bottom #nm-view{padding-bottom:calc(var(--nm-bnav-h) + env(safe-area-inset-bottom,0px))}

/* ── header ───────────────────────────────────────────────────── */
#nm-header{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nm-header-h)}

.nm-header{
    height:var(--nm-header-h);
    background:var(--nm-surface);
    border-bottom:1px solid var(--nm-border);
    display:flex;align-items:center;gap:10px;padding:0 16px;
    box-shadow:var(--nm-shadow);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
}
.nm-header__logo{
    font-size:1.2rem;font-weight:800;color:var(--nm-primary);
    flex-shrink:0;letter-spacing:-.02em;
    display:flex;align-items:center;gap:6px;
}
.nm-header__logo img{width:28px;height:28px;object-fit:contain}
.nm-header__search{flex:1;max-width:420px}
.nm-header__actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.nm-header__nav{display:flex;align-items:center;gap:4px}
.nm-header__nav a{
    padding:6px 12px;border-radius:var(--nm-radius-sm);
    font-size:.875rem;font-weight:500;color:var(--nm-text-muted);
    transition:color var(--nm-transition),background var(--nm-transition);
}
.nm-header__nav a:hover,.nm-header__nav a.active{color:var(--nm-primary);background:var(--nm-primary-10)}

/* ── search input ─────────────────────────────────────────────── */
.nm-search-wrap{position:relative}
.nm-search-input{
    width:100%;height:38px;padding:0 36px 0 14px;
    border:1.5px solid var(--nm-border);border-radius:999px;
    font-size:.875rem;background:var(--nm-bg);color:var(--nm-text);
    transition:border-color var(--nm-transition),box-shadow var(--nm-transition);
    outline:none;
}
.nm-search-input:focus{border-color:var(--nm-primary);box-shadow:0 0 0 3px var(--nm-primary-10)}
.nm-search-input::placeholder{color:var(--nm-text-muted)}
.nm-search-icon{
    position:absolute;right:12px;top:50%;transform:translateY(-50%);
    color:var(--nm-text-muted);pointer-events:none;
}

/* suggestions */
.nm-search-suggestions{
    position:absolute;top:calc(100% + 6px);left:0;right:0;
    background:var(--nm-surface);border:1px solid var(--nm-border);
    border-radius:var(--nm-radius);box-shadow:var(--nm-shadow-lg);
    overflow:hidden;z-index:300;
    animation:nm-fade-in .15s ease;
}
.nm-suggestion-item{
    display:flex;align-items:center;gap:10px;padding:10px 14px;
    cursor:pointer;transition:background var(--nm-transition);
    font-size:.875rem;
}
.nm-suggestion-item:hover{background:var(--nm-bg)}
.nm-suggestion-item__icon{color:var(--nm-text-muted);font-size:.8rem;flex-shrink:0}
.nm-suggestion-item__name{font-weight:500}
.nm-suggestion-item__meta{font-size:.75rem;color:var(--nm-text-muted)}

/* ── bottom nav ───────────────────────────────────────────────── */
#nm-bottom-nav{
    position:fixed;bottom:0;left:0;right:0;z-index:200;
    height:var(--nm-bnav-h);
    background:var(--nm-surface);
    border-top:1px solid var(--nm-border);
    display:flex;
    padding-bottom:env(safe-area-inset-bottom,0px);
    box-shadow:0 -4px 20px rgba(0,0,0,.05);
}
.nm-bnav__item{
    flex:1;display:flex;flex-direction:column;align-items:center;
    justify-content:center;gap:3px;padding:6px 4px;
    color:var(--nm-text-muted);font-size:.65rem;font-weight:500;
    transition:color var(--nm-transition);position:relative;
}
.nm-bnav__item--active{color:var(--nm-primary)}
.nm-bnav__icon{
    font-size:1.25rem;display:flex;align-items:center;justify-content:center;
    width:28px;height:28px;border-radius:var(--nm-radius-sm);
    transition:background var(--nm-transition),transform var(--nm-transition);
}
.nm-bnav__item--active .nm-bnav__icon{background:var(--nm-primary-10);transform:scale(1.05)}
.nm-bnav__badge{
    position:absolute;top:4px;right:calc(50% - 18px);
    background:var(--nm-accent);color:#fff;
    border-radius:999px;font-size:.6rem;font-weight:700;
    padding:1px 5px;min-width:16px;text-align:center;
}

/* ── buttons ──────────────────────────────────────────────────── */
.nm-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:6px;
    padding:10px 22px;border-radius:999px;font-size:.875rem;font-weight:600;
    cursor:pointer;border:2px solid transparent;
    transition:all var(--nm-transition);white-space:nowrap;
}
.nm-btn--primary{background:var(--nm-primary);color:#fff;border-color:var(--nm-primary)}
.nm-btn--primary:hover{background:var(--nm-primary-dark);border-color:var(--nm-primary-dark)}
.nm-btn--outline{background:transparent;color:var(--nm-primary);border-color:var(--nm-primary)}
.nm-btn--outline:hover{background:var(--nm-primary);color:#fff}
.nm-btn--ghost{background:transparent;color:var(--nm-text-muted)}
.nm-btn--ghost:hover{background:var(--nm-bg);color:var(--nm-text)}
.nm-btn--accent{background:var(--nm-accent);color:#fff;border-color:var(--nm-accent)}
.nm-btn--sm{padding:6px 14px;font-size:.8rem}
.nm-btn--lg{padding:14px 28px;font-size:1rem}
.nm-btn--full{width:100%}
.nm-btn:disabled{opacity:.45;cursor:not-allowed}
.nm-btn--loading{position:relative;color:transparent}
.nm-btn--loading::after{
    content:'';position:absolute;width:16px;height:16px;
    border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
    border-radius:50%;animation:nm-spin .6s linear infinite;
}

/* ── forms ────────────────────────────────────────────────────── */
.nm-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.nm-form-group label{font-size:.8rem;font-weight:600;color:var(--nm-text)}
.nm-input{
    padding:10px 14px;border:1.5px solid var(--nm-border);
    border-radius:var(--nm-radius-sm);font-size:.9rem;
    outline:none;background:var(--nm-bg);color:var(--nm-text);
    transition:border-color var(--nm-transition),box-shadow var(--nm-transition);width:100%;
}
.nm-input:focus{border-color:var(--nm-primary);box-shadow:0 0 0 3px var(--nm-primary-10)}
.nm-form-hint{font-size:.75rem;color:var(--nm-text-muted)}
textarea.nm-input{resize:vertical;min-height:100px}
.nm-select{
    padding:10px 36px 10px 14px;border:1.5px solid var(--nm-border);
    border-radius:var(--nm-radius-sm);font-size:.9rem;
    background:var(--nm-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 12px center;
    color:var(--nm-text);appearance:none;outline:none;cursor:pointer;width:100%;
}

/* ── skeleton loaders ─────────────────────────────────────────── */
@keyframes nm-shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.nm-skeleton{
    background:linear-gradient(90deg,var(--nm-border) 25%,color-mix(in srgb,var(--nm-border) 50%,var(--nm-surface)) 50%,var(--nm-border) 75%);
    background-size:200% 100%;animation:nm-shimmer 1.4s infinite;
    border-radius:var(--nm-radius-sm);
}
.nm-skeleton--card{min-height:220px;border-radius:var(--nm-radius)}
.nm-skeleton--tile{height:96px;border-radius:var(--nm-radius)}
.nm-skeleton--line{height:12px;margin-bottom:6px}
.nm-skeleton--title{height:18px;width:65%;margin-bottom:8px}

/* ── hero section ─────────────────────────────────────────────── */
.nm-hero{
    position:relative;overflow:hidden;
    min-height:220px;display:flex;flex-direction:column;
    align-items:center;justify-content:center;
    padding:40px 20px;text-align:center;
    background:var(--nm-primary);
}
.nm-hero__bg{
    position:absolute;inset:0;object-fit:cover;width:100%;height:100%;
    z-index:0;
}
.nm-hero__overlay{position:absolute;inset:0;z-index:1;background:rgba(0,0,0,.45)}
.nm-hero__content{position:relative;z-index:2;max-width:560px}
.nm-hero__title{
    font-size:clamp(1.4rem,5vw,2.2rem);font-weight:800;
    color:#fff;line-height:1.2;margin-bottom:10px;
}
.nm-hero__subtitle{font-size:1rem;color:rgba(255,255,255,.85);margin-bottom:20px}
.nm-hero__search{
    display:flex;gap:0;max-width:420px;width:100%;margin:0 auto;
    background:var(--nm-surface);border-radius:999px;overflow:hidden;
    box-shadow:var(--nm-shadow-lg);
}
.nm-hero__search input{
    flex:1;padding:12px 18px;border:none;outline:none;font-size:.95rem;
    background:transparent;color:var(--nm-text);
}
.nm-hero__search button{
    padding:10px 20px;background:var(--nm-primary);color:#fff;
    border-radius:0 999px 999px 0;font-weight:600;font-size:.9rem;
    flex-shrink:0;
}

/* ── categories ───────────────────────────────────────────────── */
.nm-categories-section{padding:20px 16px 8px}
.nm-categories-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.nm-section-title{font-size:1.05rem;font-weight:700;letter-spacing:-.01em}
.nm-see-all{font-size:.8rem;color:var(--nm-primary);font-weight:600}

.nm-categories-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(80px,1fr));
    gap:10px;
}
.nm-cat-tile{
    display:flex;flex-direction:column;align-items:center;gap:6px;
    padding:14px 8px 10px;background:var(--nm-surface);
    border-radius:var(--nm-radius);box-shadow:var(--nm-shadow);
    border:2px solid transparent;cursor:pointer;
    transition:all var(--nm-transition);
    text-align:center;
}
.nm-cat-tile:hover{box-shadow:var(--nm-shadow-md);transform:translateY(-2px)}
.nm-cat-tile--active{border-color:var(--nm-primary);background:var(--nm-primary-10)}
.nm-cat-tile__icon{font-size:1.6rem;line-height:1}
.nm-cat-tile__name{font-size:.72rem;font-weight:600;color:var(--nm-text);line-height:1.2}
.nm-cat-tile--active .nm-cat-tile__name{color:var(--nm-primary)}
.nm-cat-tile__count{font-size:.65rem;color:var(--nm-text-muted)}

/* ── listings section ─────────────────────────────────────────── */
.nm-listings-section{padding:8px 16px 24px}
.nm-listings-header{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:14px;gap:8px;flex-wrap:wrap;
}
.nm-view-toggle{display:flex;gap:4px}
.nm-view-btn{
    width:34px;height:34px;border-radius:var(--nm-radius-sm);
    border:1.5px solid var(--nm-border);color:var(--nm-text-muted);
    display:flex;align-items:center;justify-content:center;font-size:.9rem;
    transition:all var(--nm-transition);background:var(--nm-surface);
}
.nm-view-btn--active{border-color:var(--nm-primary);color:var(--nm-primary);background:var(--nm-primary-10)}
.nm-sort-select{
    height:34px;padding:0 28px 0 10px;font-size:.8rem;
    border:1.5px solid var(--nm-border);border-radius:var(--nm-radius-sm);
    background:var(--nm-surface);cursor:pointer;outline:none;
    color:var(--nm-text);appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 8px center;
}

/* listings grid */
.nm-listings-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(158px,1fr));
    gap:14px;
}
.nm-listings-list{display:flex;flex-direction:column;gap:12px}

/* ── listing card ─────────────────────────────────────────────── */
.nm-card{
    background:var(--nm-surface);border-radius:var(--nm-radius);
    box-shadow:var(--nm-shadow);overflow:hidden;
    display:flex;flex-direction:column;
    border:1.5px solid transparent;
    transition:transform var(--nm-transition),box-shadow var(--nm-transition),border-color var(--nm-transition);
    cursor:pointer;
}
.nm-card:hover{transform:translateY(-3px);box-shadow:var(--nm-shadow-md)}
.nm-card--promoted{border-color:var(--nm-primary)}
.nm-card--horizontal{flex-direction:row}

.nm-card__media{
    position:relative;aspect-ratio:4/3;overflow:hidden;flex-shrink:0;
}
.nm-card--horizontal .nm-card__media{width:100px;aspect-ratio:1/1}
.nm-card__img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.nm-card:hover .nm-card__img{transform:scale(1.04)}
.nm-card__img--placeholder{width:100%;height:100%;background:var(--nm-border);display:flex;align-items:center;justify-content:center;font-size:2rem}

.nm-card__body{padding:10px 12px;flex:1;display:flex;flex-direction:column;gap:4px}
.nm-card__title{font-size:.875rem;font-weight:700;line-height:1.3;color:var(--nm-text)}
.nm-card__address{font-size:.72rem;color:var(--nm-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nm-card__distance{font-size:.7rem;color:var(--nm-primary);font-weight:500}
.nm-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:6px}
.nm-card__cats{display:flex;gap:4px;flex-wrap:wrap}
.nm-card__rating{display:flex;align-items:center;gap:3px;font-size:.72rem;color:var(--nm-text-muted)}
.nm-card__rating span{color:#f59e0b}

/* badge */
.nm-badge{
    position:absolute;top:8px;left:8px;
    font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
    padding:3px 8px;border-radius:999px;
}
.nm-badge--promoted{background:var(--nm-primary);color:#fff}
.nm-badge--event{background:var(--nm-accent);color:#fff}
.nm-badge--verified{background:#10b981;color:#fff}
.nm-badge--free{background:#f59e0b;color:#fff}
.nm-tag{
    display:inline-block;font-size:.68rem;font-weight:500;
    padding:2px 8px;border-radius:999px;
    background:var(--nm-primary-10);color:var(--nm-primary);
    border:1px solid var(--nm-primary-20);
}

/* fav button */
.nm-fav-btn{
    position:absolute;top:8px;right:8px;
    width:30px;height:30px;border-radius:50%;
    background:rgba(255,255,255,.9);
    display:flex;align-items:center;justify-content:center;
    font-size:.9rem;transition:transform var(--nm-transition),background var(--nm-transition);
    box-shadow:var(--nm-shadow);
}
.nm-fav-btn:hover{transform:scale(1.1);background:#fff}
.nm-fav-btn--active{background:var(--nm-accent);color:#fff}

/* ── location pill ────────────────────────────────────────────── */
.nm-location-pill{
    display:inline-flex;align-items:center;gap:6px;
    padding:6px 14px;border-radius:999px;
    background:var(--nm-primary-10);color:var(--nm-primary);
    font-size:.8rem;font-weight:600;cursor:pointer;
    border:1.5px solid var(--nm-primary-20);
    transition:all var(--nm-transition);
}
.nm-location-pill:hover{background:var(--nm-primary);color:#fff}

/* ── filter chips bar ─────────────────────────────────────────── */
.nm-filter-bar{
    display:flex;gap:8px;padding:0 16px 12px;
    overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
}
.nm-filter-bar::-webkit-scrollbar{display:none}
.nm-filter-chip{
    display:inline-flex;align-items:center;gap:5px;
    padding:6px 14px;border-radius:999px;font-size:.8rem;font-weight:500;
    border:1.5px solid var(--nm-border);background:var(--nm-surface);
    cursor:pointer;white-space:nowrap;transition:all var(--nm-transition);flex-shrink:0;
}
.nm-filter-chip:hover{border-color:var(--nm-primary);color:var(--nm-primary)}
.nm-filter-chip--active{background:var(--nm-primary);border-color:var(--nm-primary);color:#fff}

/* ── empty state ──────────────────────────────────────────────── */
.nm-empty{
    display:flex;flex-direction:column;align-items:center;gap:12px;
    padding:60px 20px;text-align:center;color:var(--nm-text-muted);
}
.nm-empty__icon{font-size:3rem;opacity:.5}
.nm-empty__title{font-size:1rem;font-weight:700;color:var(--nm-text)}
.nm-empty__text{font-size:.875rem;max-width:280px}

/* ── pagination ───────────────────────────────────────────────── */
.nm-pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:24px 16px;flex-wrap:wrap}
.nm-page-btn{
    min-width:36px;height:36px;padding:0 10px;
    border:1.5px solid var(--nm-border);border-radius:var(--nm-radius-sm);
    font-size:.85rem;font-weight:500;background:var(--nm-surface);
    cursor:pointer;transition:all var(--nm-transition);color:var(--nm-text);
}
.nm-page-btn:hover:not([disabled]):not(.nm-page-btn--active){border-color:var(--nm-primary);color:var(--nm-primary)}
.nm-page-btn--active{background:var(--nm-primary);border-color:var(--nm-primary);color:#fff;font-weight:700}
.nm-page-btn[disabled]{opacity:.4;cursor:not-allowed}
.nm-page-ellipsis{color:var(--nm-text-muted);font-size:.85rem;padding:0 4px}

/* ── map view ─────────────────────────────────────────────────── */
.nm-map-view{
    position:relative;
    height:calc(100dvh - var(--nm-header-h) - var(--nm-bnav-h));
}
.nm-map-view__map{width:100%;height:100%}
.nm-map-view__filter-bar{
    position:absolute;top:12px;left:12px;right:12px;z-index:10;
    display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;
    padding-bottom:2px;
}
.nm-map-view__filter-bar::-webkit-scrollbar{display:none}
.nm-map-filter-chip{
    padding:7px 14px;border-radius:999px;font-size:.8rem;font-weight:600;
    background:var(--nm-surface);box-shadow:var(--nm-shadow-md);
    border:1.5px solid transparent;white-space:nowrap;flex-shrink:0;
    cursor:pointer;transition:all var(--nm-transition);
}
.nm-map-filter-chip--active{background:var(--nm-primary);color:#fff}
.nm-map-filter-chip:not(.nm-map-filter-chip--active):hover{border-color:var(--nm-primary);color:var(--nm-primary)}

.nm-map-locate-btn{
    position:absolute;right:12px;z-index:10;
    width:42px;height:42px;border-radius:50%;
    background:var(--nm-surface);box-shadow:var(--nm-shadow-md);
    display:flex;align-items:center;justify-content:center;font-size:1rem;
    border:1.5px solid var(--nm-border);transition:all var(--nm-transition);
}
.nm-map-locate-btn:hover{background:var(--nm-primary);color:#fff;border-color:var(--nm-primary)}
.nm-map-locate-btn--bottom{bottom:calc(var(--nm-bnav-h) + 80px + env(safe-area-inset-bottom,0px))}

/* map panel */
.nm-map-panel{
    position:absolute;bottom:0;left:0;right:0;z-index:20;
    background:var(--nm-surface);
    border-radius:var(--nm-radius-lg) var(--nm-radius-lg) 0 0;
    box-shadow:0 -8px 40px rgba(0,0,0,.15);
    padding:16px;transform:translateY(100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.nm-map-panel--open{transform:translateY(0)}
.nm-map-panel__handle{width:36px;height:4px;background:var(--nm-border);border-radius:2px;margin:0 auto 14px}
.nm-map-panel__card{display:flex;gap:12px;align-items:flex-start}
.nm-map-panel__img{width:70px;height:70px;object-fit:cover;border-radius:var(--nm-radius-sm);flex-shrink:0}
.nm-map-panel__img--placeholder{background:var(--nm-border);width:70px;height:70px;border-radius:var(--nm-radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.nm-map-panel__info strong{display:block;font-size:.95rem;font-weight:700;margin-bottom:3px}
.nm-map-panel__info p{font-size:.8rem;color:var(--nm-text-muted)}

/* map pins */
.nm-map-pin{width:32px;height:38px;display:flex;flex-direction:column;align-items:center;cursor:pointer;filter:drop-shadow(0 3px 6px rgba(0,0,0,.25))}
.nm-map-pin__dot{width:24px;height:24px;background:var(--nm-primary);border:3px solid #fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);transition:transform .15s ease}
.nm-map-pin:hover .nm-map-pin__dot{transform:rotate(-45deg) scale(1.15)}
.nm-map-pin--promoted .nm-map-pin__dot{background:var(--nm-accent)}
.nm-map-pin--event .nm-map-pin__dot{background:#f59e0b}
.nm-map-pin__tail{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:7px solid var(--nm-primary)}
.nm-map-pin--promoted .nm-map-pin__tail{border-top-color:var(--nm-accent)}
.nm-map-pin--event .nm-map-pin__tail{border-top-color:#f59e0b}

/* ── listing / event detail ───────────────────────────────────── */
.nm-detail{max-width:680px;margin:0 auto;padding-bottom:32px}

/* image slideshow */
.nm-slideshow{position:relative;background:var(--nm-border);overflow:hidden}
.nm-slideshow__track{display:flex;transition:transform .4s cubic-bezier(.4,0,.2,1);will-change:transform}
.nm-slideshow__slide{min-width:100%;aspect-ratio:16/9;flex-shrink:0;overflow:hidden}
.nm-slideshow__slide img{width:100%;height:100%;object-fit:cover}
.nm-slideshow__placeholder{width:100%;aspect-ratio:16/9;background:var(--nm-border);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--nm-text-muted)}
.nm-slideshow__prev,.nm-slideshow__next{
    position:absolute;top:50%;transform:translateY(-50%);z-index:2;
    width:38px;height:38px;border-radius:50%;
    background:rgba(0,0,0,.45);color:#fff;
    display:flex;align-items:center;justify-content:center;
    font-size:1rem;transition:background var(--nm-transition);
}
.nm-slideshow__prev:hover,.nm-slideshow__next:hover{background:rgba(0,0,0,.7)}
.nm-slideshow__prev{left:10px}
.nm-slideshow__next{right:10px}
.nm-slideshow__dots{
    position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
    display:flex;gap:5px;z-index:2;
}
.nm-slideshow__dot{
    width:6px;height:6px;border-radius:3px;background:rgba(255,255,255,.5);
    transition:all .3s ease;cursor:pointer;
}
.nm-slideshow__dot--active{width:18px;background:#fff}
.nm-slideshow__counter{
    position:absolute;top:10px;right:10px;z-index:2;
    background:rgba(0,0,0,.5);color:#fff;
    padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:600;
}

/* detail body */
.nm-detail__body{padding:20px 16px}
.nm-detail__badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.nm-detail__title{font-size:1.4rem;font-weight:800;line-height:1.2;margin-bottom:8px}
.nm-detail__address{display:flex;align-items:flex-start;gap:6px;color:var(--nm-text-muted);font-size:.875rem;margin-bottom:12px}
.nm-detail__address-icon{color:var(--nm-primary);flex-shrink:0;margin-top:2px}

/* contact strip */
.nm-detail__contacts{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.nm-contact-btn{
    display:inline-flex;align-items:center;gap:6px;
    padding:8px 14px;border-radius:999px;font-size:.8rem;font-weight:600;
    border:1.5px solid var(--nm-border);color:var(--nm-text);
    transition:all var(--nm-transition);background:var(--nm-surface);
}
.nm-contact-btn:hover{border-color:var(--nm-primary);color:var(--nm-primary)}
.nm-contact-btn--whatsapp{border-color:#25D366;color:#25D366}
.nm-contact-btn--whatsapp:hover{background:#25D366;color:#fff;border-color:#25D366}

.nm-detail__hours{
    display:flex;align-items:center;gap:8px;
    font-size:.85rem;color:var(--nm-text-muted);margin-bottom:14px;
}
.nm-detail__divider{border:none;border-top:1px solid var(--nm-border);margin:20px 0}

/* description (the_content) */
.nm-detail__description{
    font-size:.9rem;line-height:1.75;color:var(--nm-text);
}
.nm-detail__description p{margin-bottom:12px}
.nm-detail__description h2,.nm-detail__description h3{font-weight:700;margin:20px 0 8px}
.nm-detail__description img{border-radius:var(--nm-radius-sm);margin:12px 0}
.nm-detail__description a{color:var(--nm-primary);text-decoration:underline}

/* sections */
.nm-detail__section{margin-bottom:24px}
.nm-detail__section-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--nm-text-muted);margin-bottom:12px}

/* directions map */
.nm-detail__map-wrap{
    border-radius:var(--nm-radius);overflow:hidden;
    height:220px;border:1px solid var(--nm-border);margin-bottom:12px;
}
.nm-directions-strip{display:flex;gap:8px;flex-wrap:wrap}
.nm-directions-btn{
    display:inline-flex;align-items:center;gap:6px;
    padding:8px 16px;border-radius:999px;font-size:.8rem;font-weight:600;
    background:var(--nm-primary);color:#fff;transition:background var(--nm-transition);
}
.nm-directions-btn:hover{background:var(--nm-primary-dark)}
.nm-directions-btn--alt{background:transparent;color:var(--nm-primary);border:1.5px solid var(--nm-primary)}
.nm-directions-btn--alt:hover{background:var(--nm-primary);color:#fff}

/* ticket purchase section */
.nm-ticket-box{
    background:var(--nm-surface);border:2px solid var(--nm-primary);
    border-radius:var(--nm-radius);padding:20px;margin-bottom:24px;
}
.nm-ticket-box__title{font-size:1rem;font-weight:700;margin-bottom:4px}
.nm-ticket-box__price{font-size:1.6rem;font-weight:800;color:var(--nm-primary);margin-bottom:12px}
.nm-ticket-box__price span{font-size:.85rem;font-weight:400;color:var(--nm-text-muted)}
.nm-ticket-qty{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.nm-ticket-qty__btn{
    width:34px;height:34px;border-radius:50%;
    border:1.5px solid var(--nm-border);font-size:1.1rem;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    transition:all var(--nm-transition);
}
.nm-ticket-qty__btn:hover{border-color:var(--nm-primary);color:var(--nm-primary)}
.nm-ticket-qty__value{font-size:1rem;font-weight:700;min-width:24px;text-align:center}
.nm-ticket-sold-out{background:#fef2f2;color:#ef4444;border-radius:var(--nm-radius-sm);padding:10px 14px;font-weight:600;font-size:.875rem;text-align:center}

/* claim CTA */
.nm-claim-cta{
    background:var(--nm-bg);border:1px solid var(--nm-border);
    border-radius:var(--nm-radius);padding:16px;
    display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
}
.nm-claim-cta__text strong{display:block;font-size:.9rem;margin-bottom:2px}
.nm-claim-cta__text p{font-size:.8rem;color:var(--nm-text-muted);margin:0}

/* event dates */
.nm-event-dates{
    display:grid;grid-template-columns:1fr 1fr;gap:10px;
    background:var(--nm-bg);border-radius:var(--nm-radius);padding:14px;
    border:1px solid var(--nm-border);margin-bottom:16px;
}
.nm-event-date__label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--nm-text-muted);margin-bottom:3px}
.nm-event-date__value{font-size:.875rem;font-weight:600}
.nm-event-expired-banner{
    background:#fef2f2;border:1px solid #fecaca;color:#ef4444;
    border-radius:var(--nm-radius-sm);padding:10px 14px;font-weight:600;
    font-size:.85rem;margin-bottom:14px;
}
.nm-event-live-badge{
    display:inline-flex;align-items:center;gap:5px;
    background:#ef4444;color:#fff;padding:4px 12px;border-radius:999px;
    font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
}
.nm-event-live-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:#fff;animation:nm-pulse 1s infinite}

/* ── reviews ──────────────────────────────────────────────────── */
.nm-reviews{padding:0}
.nm-review-form{
    background:var(--nm-bg);border-radius:var(--nm-radius);
    padding:16px;margin-bottom:20px;border:1px solid var(--nm-border);
}
.nm-star-picker{display:flex;gap:4px;margin-bottom:10px}
.nm-star-picker span{font-size:1.5rem;cursor:pointer;opacity:.35;transition:opacity var(--nm-transition)}
.nm-star-picker span.nm-star--active,.nm-star-picker span:hover{opacity:1}
.nm-review-card{border-bottom:1px solid var(--nm-border);padding:14px 0}
.nm-review-card:last-child{border-bottom:none}
.nm-review-card__header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.nm-review-card__avatar{
    width:32px;height:32px;border-radius:50%;
    background:var(--nm-primary);color:#fff;
    display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;
}
.nm-review-card__name{font-weight:600;font-size:.875rem}
.nm-review-card__date{font-size:.72rem;color:var(--nm-text-muted);margin-left:auto}
.nm-review-card__stars{color:#f59e0b;font-size:.875rem;margin-bottom:6px}
.nm-star-empty{color:var(--nm-border)}
.nm-review-card__text{font-size:.875rem;color:var(--nm-text);line-height:1.6}
.nm-avg-rating{display:flex;align-items:baseline;gap:8px;margin-bottom:16px}
.nm-avg-rating__score{font-size:2.4rem;font-weight:800;color:var(--nm-text)}
.nm-avg-rating__stars{color:#f59e0b;font-size:1rem}
.nm-avg-rating__count{font-size:.8rem;color:var(--nm-text-muted)}

/* ── search view ──────────────────────────────────────────────── */
.nm-search-view{padding:16px}
.nm-search-view__bar{display:flex;gap:8px;margin-bottom:14px}
.nm-search-view__bar .nm-search-input{border-radius:var(--nm-radius-sm);border-radius:var(--nm-radius)}
.nm-search-count{font-size:.8rem;color:var(--nm-text-muted);margin-bottom:12px}

/* ── dashboard ────────────────────────────────────────────────── */
.nm-dashboard{padding:20px;max-width:680px;margin:0 auto}
.nm-dashboard__header{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.nm-dashboard__header h1{font-size:1.3rem;font-weight:800}
.nm-plan-card{
    background:linear-gradient(135deg,var(--nm-primary),var(--nm-primary-dark));
    color:#fff;border-radius:var(--nm-radius-lg);padding:20px;
    margin-bottom:24px;position:relative;overflow:hidden;
}
.nm-plan-card__tier{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.8;margin-bottom:4px}
.nm-plan-card__name{font-size:1.5rem;font-weight:800;margin-bottom:6px}
.nm-plan-card__limits{font-size:.85rem;opacity:.85}
.nm-plan-card__upgrade{
    position:absolute;bottom:16px;right:16px;
    background:rgba(255,255,255,.2);color:#fff;
    padding:6px 16px;border-radius:999px;font-size:.8rem;font-weight:700;
    border:1.5px solid rgba(255,255,255,.4);transition:background var(--nm-transition);
}
.nm-plan-card__upgrade:hover{background:rgba(255,255,255,.35)}
.nm-plan-card__bg{position:absolute;right:-20px;top:-20px;font-size:7rem;opacity:.1;pointer-events:none}

.nm-dashboard__section{margin-bottom:28px}
.nm-dashboard__section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.nm-dashboard__section-title{font-size:1rem;font-weight:700}
.nm-listing-row{
    display:flex;align-items:center;gap:12px;
    background:var(--nm-surface);border:1px solid var(--nm-border);
    border-radius:var(--nm-radius);padding:12px;margin-bottom:8px;
}
.nm-listing-row__thumb{width:52px;height:52px;border-radius:var(--nm-radius-sm);object-fit:cover;flex-shrink:0;background:var(--nm-border)}
.nm-listing-row__info{flex:1;min-width:0}
.nm-listing-row__name{font-weight:700;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nm-listing-row__meta{font-size:.72rem;color:var(--nm-text-muted);margin-top:2px}
.nm-listing-row__actions{display:flex;gap:6px;flex-shrink:0}

/* ── subscription plans ───────────────────────────────────────── */
.nm-subscribe{padding:20px;max-width:900px;margin:0 auto}
.nm-subscribe__header{text-align:center;margin-bottom:32px}
.nm-subscribe__header h1{font-size:1.6rem;font-weight:800;margin-bottom:8px}
.nm-subscribe__header p{color:var(--nm-text-muted)}
.nm-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:32px}
.nm-plan{
    background:var(--nm-surface);border:2px solid var(--nm-border);
    border-radius:var(--nm-radius-lg);padding:24px 20px;
    position:relative;display:flex;flex-direction:column;gap:16px;
    transition:box-shadow var(--nm-transition),transform var(--nm-transition);
}
.nm-plan:hover{box-shadow:var(--nm-shadow-md);transform:translateY(-2px)}
.nm-plan--current{border-color:var(--nm-primary)}
.nm-plan--featured{border-color:var(--nm-accent);box-shadow:0 0 0 3px var(--nm-primary-10)}
.nm-plan__ribbon{
    position:absolute;top:-1px;right:20px;
    background:var(--nm-accent);color:#fff;
    font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
    padding:4px 10px;border-radius:0 0 8px 8px;
}
.nm-plan__name{font-size:1.05rem;font-weight:800}
.nm-plan__amount{font-size:1.9rem;font-weight:800;color:var(--nm-primary)}
.nm-plan__period{font-size:.8rem;color:var(--nm-text-muted);font-weight:400}
.nm-plan__features{list-style:none;display:flex;flex-direction:column;gap:7px;flex:1}
.nm-plan__features li{font-size:.82rem;color:var(--nm-text-muted);display:flex;align-items:flex-start;gap:6px}
.nm-plan__features li::before{content:'✓';color:var(--nm-primary);font-weight:700;flex-shrink:0}

/* ── auth view ────────────────────────────────────────────────── */
.nm-auth{min-height:calc(100dvh - var(--nm-header-h) - var(--nm-bnav-h));display:flex;align-items:center;justify-content:center;padding:24px 16px}
.nm-auth__card{background:var(--nm-surface);border-radius:var(--nm-radius-lg);box-shadow:var(--nm-shadow-lg);padding:32px 28px;width:100%;max-width:400px}
.nm-auth__logo{font-size:2rem;font-weight:800;color:var(--nm-primary);text-align:center;margin-bottom:4px}
.nm-auth__subtitle{text-align:center;color:var(--nm-text-muted);font-size:.9rem;margin-bottom:28px}
.nm-auth__toggle{text-align:center;font-size:.85rem;margin-top:16px;color:var(--nm-text-muted)}
.nm-auth__toggle a{color:var(--nm-primary);font-weight:700}

/* ── claim view ───────────────────────────────────────────────── */
.nm-claim-view{padding:24px 16px;display:flex;justify-content:center}
.nm-claim-card{background:var(--nm-surface);border-radius:var(--nm-radius-lg);box-shadow:var(--nm-shadow-lg);padding:32px 28px;width:100%;max-width:480px}
.nm-claim-card__title{font-size:1.2rem;font-weight:800;margin-bottom:8px}
.nm-claim-card__title em{color:var(--nm-primary);font-style:normal}
.nm-claim-card__intro{font-size:.85rem;color:var(--nm-text-muted);margin-bottom:24px;line-height:1.6}
.nm-claim-success{text-align:center}
.nm-claim-success__icon{font-size:3.5rem;margin-bottom:12px}
.nm-claim-success h2{font-size:1.3rem;font-weight:800;margin-bottom:8px}
.nm-claim-success p{font-size:.875rem;color:var(--nm-text-muted);line-height:1.6;max-width:280px;margin:0 auto 20px}

/* ── gateway picker ───────────────────────────────────────────── */
.nm-gateway-picker{background:var(--nm-surface);border-radius:var(--nm-radius-lg);padding:24px;box-shadow:var(--nm-shadow-md);margin-top:24px}
.nm-gateway-picker h3{margin-bottom:16px;font-size:1rem;font-weight:700}
.nm-gateway-list{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.nm-gateway-btn{
    padding:10px 18px;border:2px solid var(--nm-border);border-radius:var(--nm-radius);
    font-size:.875rem;font-weight:700;background:var(--nm-surface);transition:all var(--nm-transition);
}
.nm-gateway-btn:hover{border-color:var(--nm-primary);color:var(--nm-primary)}

/* ── listing form ─────────────────────────────────────────────── */
.nm-listing-form{max-width:680px;margin:0 auto;padding:20px 16px}
.nm-listing-form__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.nm-listing-form__header h1{font-size:1.3rem;font-weight:800}
.nm-form-section{margin-bottom:24px}
.nm-form-section__title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--nm-text-muted);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--nm-border)}
.nm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.nm-form-row{grid-template-columns:1fr}}
.nm-type-toggle{display:flex;gap:8px;margin-bottom:4px}
.nm-type-btn{flex:1;padding:12px;border:2px solid var(--nm-border);border-radius:var(--nm-radius);text-align:center;cursor:pointer;font-weight:700;font-size:.875rem;background:var(--nm-surface);transition:all var(--nm-transition)}
.nm-type-btn--active{border-color:var(--nm-primary);background:var(--nm-primary-10);color:var(--nm-primary)}
.nm-form-error{background:#fef2f2;border:1px solid #fecaca;color:#ef4444;padding:12px 16px;border-radius:var(--nm-radius-sm);font-size:.875rem;margin-top:12px}
.nm-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:28px;padding-top:20px;border-top:1px solid var(--nm-border)}

/* ── image uploader ───────────────────────────────────────────── */
.nm-uploader__grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.nm-uploader__thumb{position:relative;width:88px;height:88px}
.nm-uploader__thumb img{width:100%;height:100%;object-fit:cover;border-radius:var(--nm-radius-sm);border:2px solid var(--nm-border)}
.nm-uploader__remove{position:absolute;top:-7px;right:-7px;width:22px;height:22px;background:#ef4444;color:#fff;border-radius:50%;font-size:11px;display:flex;align-items:center;justify-content:center}
.nm-uploader__primary{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.55);color:#fff;font-size:9px;font-weight:700;text-align:center;padding:3px;border-radius:0 0 var(--nm-radius-sm) var(--nm-radius-sm);text-transform:uppercase;letter-spacing:.04em}
.nm-uploader__drop{
    display:flex;flex-direction:column;align-items:center;gap:6px;
    padding:24px 16px;border:2px dashed var(--nm-border);border-radius:var(--nm-radius);
    cursor:pointer;text-align:center;transition:all var(--nm-transition);
}
.nm-uploader__drop:hover,.nm-uploader__drop--over{border-color:var(--nm-primary);background:var(--nm-primary-10)}
.nm-uploader__input{display:none}
.nm-uploader__icon{font-size:1.8rem}
.nm-uploader__label{font-size:.875rem;font-weight:500}
.nm-uploader__hint{font-size:.75rem;color:var(--nm-text-muted)}

/* ── toasts & notifications ───────────────────────────────────── */
#nm-toasts{
    position:fixed;bottom:calc(var(--nm-bnav-h) + 12px);
    left:50%;transform:translateX(-50%);
    display:flex;flex-direction:column;gap:8px;
    z-index:9000;pointer-events:none;min-width:240px;max-width:90vw;
}
.nm-toast{
    padding:12px 18px;border-radius:var(--nm-radius);font-size:.875rem;font-weight:600;
    opacity:0;transform:translateY(10px) scale(.97);
    transition:opacity .25s,transform .25s;pointer-events:auto;
    display:flex;align-items:center;gap:10px;box-shadow:var(--nm-shadow-lg);
    white-space:nowrap;
}
.nm-toast--visible{opacity:1;transform:none}
.nm-toast--success{background:#10b981;color:#fff}
.nm-toast--error{background:#ef4444;color:#fff}
.nm-toast--info{background:var(--nm-primary);color:#fff}
.nm-toast--warn{background:#f59e0b;color:#fff}
.nm-toast__close{margin-left:auto;opacity:.7;cursor:pointer;font-size:1rem}
.nm-toast__close:hover{opacity:1}

/* ── modal ────────────────────────────────────────────────────── */
#nm-modal{display:none;position:fixed;inset:0;z-index:8000;align-items:center;justify-content:center}
#nm-modal.nm-modal--open{display:flex}
.nm-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(3px)}
.nm-modal__box{
    position:relative;background:var(--nm-surface);border-radius:var(--nm-radius-lg);
    box-shadow:var(--nm-shadow-lg);width:calc(100% - 32px);max-width:440px;
    max-height:90dvh;overflow-y:auto;display:flex;flex-direction:column;
    animation:nm-modal-in .25s cubic-bezier(.34,1.56,.64,1);
}
.nm-modal__box--wide{max-width:680px}
@keyframes nm-modal-in{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
.nm-modal__header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 0}
.nm-modal__title{font-size:1.05rem;font-weight:800}
.nm-modal__close{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--nm-text-muted);transition:background var(--nm-transition)}
.nm-modal__close:hover{background:var(--nm-bg)}
.nm-modal__body{padding:16px 22px;flex:1;line-height:1.6}
.nm-modal__actions{display:flex;gap:10px;justify-content:flex-end;padding:0 22px 20px}
.nm-modal__image{width:100%;border-radius:var(--nm-radius-sm)}
.nm-scroll-locked{overflow:hidden}

/* ── footer ───────────────────────────────────────────────────── */
.nm-footer{
    background:var(--nm-surface);border-top:1px solid var(--nm-border);
    padding:32px 20px 20px;margin-top:auto;
    position:relative;overflow:hidden;
}
.nm-footer__bg-image{
    position:absolute;inset:0;background-size:cover;background-position:center;
    z-index:0;pointer-events:none;
}
.nm-footer__content{position:relative;z-index:1}
.nm-footer__top{display:flex;gap:24px;justify-content:space-between;flex-wrap:wrap;margin-bottom:24px}
.nm-footer__brand{flex:1;min-width:160px}
.nm-footer__brand-name{font-size:1.1rem;font-weight:800;color:var(--nm-primary);margin-bottom:8px}
.nm-footer__tagline{font-size:.8rem;color:var(--nm-text-muted);line-height:1.6;max-width:220px}
.nm-footer__socials{display:flex;gap:8px;margin-top:14px}
.nm-footer__social{
    width:34px;height:34px;border-radius:50%;background:var(--nm-bg);
    display:flex;align-items:center;justify-content:center;font-size:.95rem;
    border:1px solid var(--nm-border);transition:all var(--nm-transition);
}
.nm-footer__social:hover{background:var(--nm-primary);color:#fff;border-color:var(--nm-primary)}
.nm-footer__bottom{
    display:flex;align-items:center;justify-content:space-between;
    font-size:.75rem;color:var(--nm-text-muted);flex-wrap:wrap;gap:8px;
    border-top:1px solid var(--nm-border);padding-top:16px;
}
.nm-footer__links{display:flex;gap:16px}
.nm-footer__links a:hover{color:var(--nm-primary)}

/* ── misc utilities ───────────────────────────────────────────── */
.nm-divider{border:none;border-top:1px solid var(--nm-border);margin:20px 0}
.nm-loading-spinner{
    width:36px;height:36px;border:3px solid var(--nm-border);
    border-top-color:var(--nm-primary);border-radius:50%;
    animation:nm-spin .7s linear infinite;margin:0 auto;
}
.nm-loading-overlay{display:flex;align-items:center;justify-content:center;min-height:180px}
.nm-auth-gate{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 24px;text-align:center}
.nm-auth-gate h2{font-size:1.2rem;font-weight:800}
.nm-auth-gate p{font-size:.875rem;color:var(--nm-text-muted);max-width:260px}
.nm-404{text-align:center;padding:80px 20px;color:var(--nm-text-muted)}
.nm-404 h1{font-size:4rem;font-weight:800;color:var(--nm-primary);margin-bottom:8px}

/* ── animations ───────────────────────────────────────────────── */
@keyframes nm-fade-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@keyframes nm-spin{to{transform:rotate(360deg)}}
@keyframes nm-pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes nm-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* page enter transition */
#nm-view[aria-busy="true"]{opacity:.6;transition:opacity .15s}
#nm-view[aria-busy="false"]{opacity:1;transition:opacity .2s}

/* ── responsive ───────────────────────────────────────────────── */
@media(max-width:480px){
    .nm-listings-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .nm-plans{grid-template-columns:1fr 1fr}
    .nm-modal__box{width:100%;max-width:100%;border-radius:var(--nm-radius-lg) var(--nm-radius-lg) 0 0;align-self:flex-end}
    .nm-event-dates{grid-template-columns:1fr}
    .nm-auth__card{padding:24px 18px}
}
@media(max-width:360px){
    .nm-listings-grid{grid-template-columns:1fr}
    .nm-plans{grid-template-columns:1fr}
    .nm-categories-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:768px){
    .nm-listings-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
    .nm-header__nav{display:flex}
    .nm-detail{padding:0 0 32px}
}
@media(min-width:1024px){
    .nm-listings-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
    .nm-slideshow__slide{aspect-ratio:21/9}
}
@import url('./utilities.css');

/* ── sidebar (slide-in nav) ───────────────────────────────────── */
#nm-sidebar{
    position:fixed;top:0;bottom:0;left:0;width:280px;z-index:400;
    background:var(--nm-surface);box-shadow:var(--nm-shadow-lg);
    transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);
    display:flex;flex-direction:column;padding:20px;
}
#nm-sidebar.nm-sidebar--open{transform:translateX(0)}
#nm-sidebar-overlay{
    position:fixed;inset:0;z-index:390;background:rgba(0,0,0,.4);
    opacity:0;pointer-events:none;transition:opacity .25s;
}
#nm-sidebar.nm-sidebar--open ~ #nm-sidebar-overlay,
body:has(#nm-sidebar.nm-sidebar--open) #nm-sidebar-overlay{opacity:1;pointer-events:auto}
.nm-sidebar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.nm-sidebar__logo{font-weight:800;color:var(--nm-primary);font-size:1.1rem}
.nm-sidebar__close{font-size:1.2rem;color:var(--nm-text-muted)}
.nm-sidebar__nav{display:flex;flex-direction:column;gap:4px}
.nm-sidebar__nav a{
    padding:12px 14px;border-radius:var(--nm-radius-sm);font-weight:600;font-size:.9rem;
    color:var(--nm-text);transition:background var(--nm-transition);
}
.nm-sidebar__nav a:hover{background:var(--nm-bg)}
