/* ==========================================================================
   DubaiOS — Main Stylesheet
   Mobile-first · Dark luxury · Glassmorphism · Cinematic
   ========================================================================== */

:root {
    --bg-primary:    #D5AC68;
    --bg-secondary:  #121821;
    --bg-tertiary:   #1A2230;
    --gold:          #D4AF37;
    --gold-soft:     #E8C66B;
    --emerald:       #00C896;
    --emerald-deep:  #008F6C;
    --text-primary:  #FFFFFF;
    --text-muted:    #94A3B8;
    --text-dim:      #64748B;
    --glass:         rgba(255,255,255,0.06);
    --glass-strong:  rgba(255,255,255,0.10);
    --shadow-luxe:   0 20px 60px -10px rgba(0,0,0,0.6);

    --r-sm: 12px;
    --r-md: 20px;
    --r-lg: 28px;
    --r-xl: 36px;
    --r-2xl: 44px;

    --safe-bottom: env(safe-area-inset-bottom);
}

* { box-sizing: border-box; }

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

body {
    margin: 0;
    background: var(--bg-primary);
    color: var(--text-primary);
    font-family: 'Inter', system-ui, sans-serif;
    font-feature-settings: 'cv11', 'ss01';
    line-height: 1.55;
    overflow-x: hidden;
    /* leave space for floating mobile bottom nav */
    padding-bottom: calc(92px + var(--safe-bottom));
}

@media (min-width: 1024px) {
    body { padding-bottom: 0; }
}

/* ========== TYPOGRAPHY ========== */
h1, h2, h3, h4, h5, h6 {
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0;
}

h1 { font-size: clamp(2rem, 6vw, 4.5rem); }
h2 { font-size: clamp(1.5rem, 4vw, 2.75rem); }
h3 { font-size: clamp(1.25rem, 3vw, 1.75rem); }

.font-display { font-family: 'Poppins', sans-serif; }
.font-serif   { font-family: 'Playfair Display', serif; }

a { color: inherit; text-decoration: none; }

/* ========== UTILITIES ========== */
.line-clamp-1 { display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden; }
.line-clamp-2 { display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.line-clamp-3 { display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden; }

.text-gold     { color: var(--gold) !important; }
.text-emerald  { color: var(--emerald) !important; }
.text-muted    { color: var(--text-muted) !important; }
.bg-glass      { background: var(--glass); }
.bg-glass-strong { background: var(--glass-strong); }

/* ========== GLASS PANELS ========== */
.glass {
    background: rgba(18, 24, 33, 0.65);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(255,255,255,0.08);
}

.glass-strong {
    background: rgba(18, 24, 33, 0.85);
    backdrop-filter: blur(28px) saturate(200%);
    -webkit-backdrop-filter: blur(28px) saturate(200%);
    border: 1px solid rgba(255,255,255,0.12);
}

/* ========== GRADIENT TEXT ========== */
.text-gradient-gold {
    background: linear-gradient(135deg, var(--gold-soft) 0%, var(--gold) 50%, #B8941F 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.text-gradient-aurora {
    background: linear-gradient(135deg, #fff 0%, var(--emerald) 35%, var(--gold) 70%, #fff 100%);
    background-size: 200% 200%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: aurora 8s ease-in-out infinite;
}

@keyframes aurora {
    0%,100% { background-position: 0% 50%; }
    50%     { background-position: 100% 50%; }
}

/* ========== HERO SECTION ========== */
.hero-section {
    position: relative;
    min-height: 100svh;
    overflow: hidden;
    isolation: isolate;
}

.hero-bg {
    position: absolute;
    inset: 0;
    z-index: -2;
}

.hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform: scale(1.05);
    animation: heroZoom 20s ease-in-out infinite alternate;
}

@keyframes heroZoom {
    from { transform: scale(1.05); }
    to   { transform: scale(1.15); }
}

.hero-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at top, rgba(11,15,20,0.4) 0%, rgba(11,15,20,0.85) 50%, rgba(11,15,20,1) 100%),
        linear-gradient(180deg, transparent 0%, var(--bg-primary) 100%);
}

.hero-grid-overlay {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(212,175,55,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(212,175,55,0.04) 1px, transparent 1px);
    background-size: 60px 60px;
    z-index: -1;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}

/* Floating orbs */
.orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.5;
    z-index: -1;
    animation: float 8s ease-in-out infinite;
}
.orb-gold    { background: var(--gold);    width: 400px; height: 400px; top: 10%;  left: -10%; }
.orb-emerald { background: var(--emerald); width: 350px; height: 350px; bottom: 5%; right: -10%; animation-delay: -3s; }

@keyframes float {
    0%,100% { transform: translateY(0) translateX(0); }
    33%     { transform: translateY(-30px) translateX(20px); }
    66%     { transform: translateY(20px) translateX(-15px); }
}

/* ========== HERO CONTENT ========== */
.hero-content {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 6rem 1.25rem 4rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100svh;
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.25rem;
    border-radius: 999px;
    border: 1px solid rgba(212,175,55,0.3);
    background: rgba(212,175,55,0.05);
    color: var(--gold);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-bottom: 1.5rem;
    animation: fadeUp 1s 0.1s both;
}

.hero-eyebrow .dot {
    width: 6px; height: 6px;
    background: var(--gold);
    border-radius: 50%;
    box-shadow: 0 0 12px var(--gold);
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
    0%,100% { opacity: 1; transform: scale(1); }
    50%     { opacity: 0.6; transform: scale(1.4); }
}

.hero-title {
    font-size: clamp(2.5rem, 9vw, 6rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 0.95;
    margin-bottom: 1.5rem;
    animation: fadeUp 1s 0.2s both;
}

.hero-subtitle {
    font-size: clamp(1rem, 2.5vw, 1.35rem);
    color: var(--text-muted);
    max-width: 38rem;
    margin: 0 auto 2.5rem;
    line-height: 1.6;
    animation: fadeUp 1s 0.35s both;
}

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(40px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ========== QUICK CHIPS ========== */
.hero-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    margin-top: 2rem;
    animation: fadeUp 1s 0.6s both;
}

.chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.125rem;
    background: var(--glass);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 999px;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-primary);
    backdrop-filter: blur(10px);
    transition: all 0.3s;
    cursor: pointer;
}

.chip:hover {
    background: rgba(212,175,55,0.15);
    border-color: var(--gold);
    color: var(--gold);
    transform: translateY(-2px);
}

/* ========== WEATHER + CURRENCY ========== */
.hero-meta {
    position: absolute;
    top: 5.5rem;
    right: 1.5rem;
    display: flex;
    gap: 0.75rem;
    z-index: 2;
}

@media (max-width: 768px) {
    .hero-meta { top: 4.5rem; right: 0.75rem; gap: 0.5rem; }
}

.meta-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.9rem;
    background: var(--glass);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 999px;
    font-size: 0.75rem;
    color: var(--text-primary);
}

/* ========== HEADER ========== */
.dubaios-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    padding: 1rem 1.25rem;
    background: rgba(11,15,20,0);
    transition: all 0.4s;
}

.dubaios-header.scrolled {
    background: rgba(11,15,20,0.85);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.header-inner {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.header-logo {
    font-family: 'Poppins', sans-serif;
    font-weight: 800;
    font-size: 1.5rem;
    letter-spacing: -0.02em;
    background: linear-gradient(135deg, var(--gold-soft), var(--gold));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.header-logo::before {
    content: "◆ ";
    color: var(--gold);
    -webkit-text-fill-color: var(--gold);
}

.header-nav {
    display: none;
    gap: 2rem;
    font-size: 0.875rem;
    font-weight: 500;
}

@media (min-width: 1024px) {
    .header-nav { display: flex; }
}

.header-nav a {
    color: var(--text-muted);
    transition: color 0.3s;
}
.header-nav a:hover { color: var(--gold); }

/* ========== MOBILE BOTTOM NAV ========== */
.mobile-bottom-nav {
    position: fixed;
    bottom: 1rem;
    bottom: calc(1rem + var(--safe-bottom));
    left: 1rem;
    right: 1rem;
    z-index: 100;
    background: rgba(18, 24, 33, 0.88);
    backdrop-filter: blur(28px) saturate(180%);
    -webkit-backdrop-filter: blur(28px) saturate(180%);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--r-xl);
    box-shadow: var(--shadow-luxe);
    padding: 0.625rem;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.25rem;
}

@media (min-width: 1024px) {
    .mobile-bottom-nav { display: none; }
}

.mbn-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    padding: 0.625rem 0.25rem;
    border-radius: var(--r-sm);
    color: var(--text-muted);
    font-size: 0.6875rem;
    font-weight: 500;
    transition: all 0.3s;
    position: relative;
}

.mbn-item svg {
    width: 22px;
    height: 22px;
    stroke-width: 1.8;
}

.mbn-item.active {
    background: rgba(212,175,55,0.12);
    color: var(--gold);
}

.mbn-item.active::after {
    content: "";
    position: absolute;
    top: 4px;
    width: 4px;
    height: 4px;
    background: var(--gold);
    border-radius: 50%;
    box-shadow: 0 0 8px var(--gold);
}

.mbn-item.center {
    position: relative;
    background: linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
    color: var(--bg-primary);
    transform: translateY(-12px);
    width: 56px;
    height: 56px;
    border-radius: 50%;
    justify-self: center;
    padding: 0;
    box-shadow: 0 8px 24px rgba(212,175,55,0.4);
}
.mbn-item.center svg { width: 26px; height: 26px; stroke-width: 2.2; }
.mbn-item.center span { display: none; }

/* ========== SECTIONS ========== */
.section {
    padding: 4rem 1.25rem;
    position: relative;
}

@media (min-width: 768px) {
    .section { padding: 6rem 2rem; }
}

.section-inner {
    max-width: 1400px;
    margin: 0 auto;
}

.section-header {
    margin-bottom: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

@media (min-width: 768px) {
    .section-header {
        flex-direction: row;
        align-items: flex-end;
        justify-content: space-between;
    }
}

.section-eyebrow {
    color: var(--gold);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.section-title {
    font-size: clamp(1.75rem, 4vw, 3rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.1;
    max-width: 36rem;
}

.section-link {
    color: var(--text-muted);
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: color 0.3s;
}
.section-link:hover { color: var(--gold); }
.section-link::after { content: "→"; transition: transform 0.3s; }
.section-link:hover::after { transform: translateX(4px); }

/* ========== FEED GRID ========== */
.feed-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .feed-grid { gap: 1.5rem; }
}

/* ========== CARDS — DUBAIOS-CARD ========== */
.dubaios-card {
    position: relative;
    overflow: hidden;
    border-radius: var(--r-md);
    background: var(--bg-secondary);
    border: 1px solid rgba(255,255,255,0.05);
    transition: transform 0.5s cubic-bezier(.16,1,.3,1), box-shadow 0.5s;
}

.dubaios-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6);
}

/* save button */
.save-btn {
    background: rgba(11,15,20,0.6);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.1);
    color: #fff;
    cursor: pointer;
    transition: all 0.3s;
}
.save-btn:hover {
    background: rgba(11,15,20,0.85);
    color: var(--gold);
    transform: scale(1.08);
}
.save-btn.is-saved {
    color: var(--gold);
    background: rgba(212,175,55,0.2);
    border-color: var(--gold);
}

/* ========== CATEGORY TILE ========== */
.cat-tile {
    position: relative;
    aspect-ratio: 1 / 1;
    border-radius: var(--r-md);
    overflow: hidden;
    background: var(--bg-secondary);
    border: 1px solid rgba(255,255,255,0.06);
    transition: all 0.4s;
}
.cat-tile:hover {
    border-color: var(--gold);
    transform: scale(1.03);
}
.cat-tile-icon {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    transition: transform 0.5s;
}
.cat-tile:hover .cat-tile-icon { transform: scale(1.15) rotate(-5deg); }
.cat-tile-label {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 1rem;
    background: linear-gradient(to top, rgba(0,0,0,0.9), transparent);
    text-align: center;
    font-weight: 600;
    font-size: 0.95rem;
}

/* ========== AI CONCIERGE WIDGET ========== */
.ai-concierge {
    background:
        radial-gradient(ellipse at top left, rgba(212,175,55,0.12) 0%, transparent 50%),
        radial-gradient(ellipse at bottom right, rgba(0,200,150,0.10) 0%, transparent 50%),
        var(--bg-secondary);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--r-lg);
    padding: 2rem 1.5rem;
    position: relative;
    overflow: hidden;
}

@media (min-width: 768px) {
    .ai-concierge { padding: 3rem 2.5rem; }
}

.ai-concierge::before {
    content: "";
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: conic-gradient(from 0deg, transparent 0%, rgba(212,175,55,0.05) 25%, transparent 50%);
    animation: rotate 20s linear infinite;
    z-index: 0;
}

.ai-concierge > * { position: relative; z-index: 1; }

@keyframes rotate {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

.ai-orb {
    width: 80px; height: 80px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, var(--gold-soft), var(--gold) 60%, var(--emerald-deep) 100%);
    margin: 0 auto 1.5rem;
    position: relative;
    animation: orbFloat 6s ease-in-out infinite;
    box-shadow: 0 0 60px rgba(212,175,55,0.4);
}
.ai-orb::after {
    content: "";
    position: absolute;
    inset: -10px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--gold) 0%, transparent 70%);
    opacity: 0.3;
    animation: pulse 3s ease-in-out infinite;
}

@keyframes orbFloat {
    0%,100% { transform: translateY(0) scale(1); }
    50%     { transform: translateY(-8px) scale(1.05); }
}

.ai-mode-tabs {
    display: flex;
    gap: 0.5rem;
    margin: 1.5rem 0;
    overflow-x: auto;
    scrollbar-width: none;
    padding-bottom: 4px;
}
.ai-mode-tabs::-webkit-scrollbar { display: none; }

.ai-mode-tab {
    padding: 0.5rem 1rem;
    background: var(--glass);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--text-muted);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.3s;
}
.ai-mode-tab.active {
    background: var(--gold);
    color: var(--bg-primary);
    border-color: var(--gold);
}

.ai-input-wrap {
    position: relative;
    background: rgba(11,15,20,0.6);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: var(--r-md);
    padding: 0.5rem 0.5rem 0.5rem 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.ai-input-wrap:focus-within {
    border-color: var(--gold);
    box-shadow: 0 0 0 4px rgba(212,175,55,0.1);
}
.ai-input-wrap input {
    flex: 1;
    background: transparent;
    border: 0;
    outline: 0;
    color: var(--text-primary);
    font-size: 1rem;
    padding: 0.75rem 0;
}
.ai-input-wrap input::placeholder { color: var(--text-dim); }

.ai-send {
    background: linear-gradient(135deg, var(--gold), var(--gold-soft));
    color: var(--bg-primary);
    border: 0;
    border-radius: var(--r-sm);
    padding: 0.625rem 1rem;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: all 0.3s;
}
.ai-send:hover { transform: translateX(2px); box-shadow: 0 0 20px rgba(212,175,55,0.5); }
.ai-send:disabled { opacity: 0.5; cursor: not-allowed; }

.ai-suggestions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1.25rem;
}
.ai-suggestion {
    padding: 0.5rem 0.875rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 999px;
    font-size: 0.8125rem;
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.3s;
}
.ai-suggestion:hover { background: rgba(212,175,55,0.1); color: var(--gold); border-color: var(--gold); }

.ai-response {
    margin-top: 1.5rem;
    padding: 1.25rem;
    background: rgba(11,15,20,0.5);
    border-radius: var(--r-sm);
    border: 1px solid rgba(255,255,255,0.06);
}

/* ========== MAP ========== */
.dubaios-map {
    width: 100%;
    height: 600px;
    border-radius: var(--r-md);
    overflow: hidden;
    position: relative;
    border: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 768px) {
    .dubaios-map { height: 480px; border-radius: var(--r-sm); }
}

.map-filters {
    position: absolute;
    top: 1rem;
    left: 1rem;
    right: 1rem;
    z-index: 10;
    display: flex;
    gap: 0.5rem;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;
}
.map-filters::-webkit-scrollbar { display: none; }

.map-filter {
    padding: 0.5rem 0.875rem;
    background: rgba(11,15,20,0.85);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--text-primary);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.3s;
}
.map-filter.active {
    background: var(--gold);
    color: var(--bg-primary);
    border-color: var(--gold);
}

.mapboxgl-popup-content {
    background: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-radius: var(--r-sm) !important;
    padding: 0 !important;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: var(--shadow-luxe);
}
.mapboxgl-popup-tip { border-top-color: var(--bg-secondary) !important; }
.mapboxgl-popup-close-button {
    color: var(--text-muted) !important;
    font-size: 1.5rem !important;
    padding: 0.25rem 0.5rem !important;
}

/* ========== BUSINESS CALCULATOR ========== */
.biz-calc {
    background: var(--bg-secondary);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--r-lg);
    padding: 1.5rem;
}
@media (min-width: 768px) { .biz-calc { padding: 2.5rem; } }

.biz-calc-row {
    margin-bottom: 1.5rem;
}
.biz-calc-row label {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: var(--text-muted);
}
.biz-calc-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 0.5rem;
}
.biz-calc-option {
    padding: 0.875rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--r-sm);
    text-align: center;
    cursor: pointer;
    font-size: 0.875rem;
    transition: all 0.3s;
    color: var(--text-muted);
}
.biz-calc-option.active {
    background: rgba(212,175,55,0.1);
    border-color: var(--gold);
    color: var(--gold);
}

.biz-calc-result {
    margin-top: 2rem;
    padding: 2rem;
    background: linear-gradient(135deg, rgba(212,175,55,0.1), rgba(0,200,150,0.05));
    border: 1px solid rgba(212,175,55,0.2);
    border-radius: var(--r-md);
    text-align: center;
}
.biz-calc-total {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(2rem, 6vw, 3.5rem);
    font-weight: 800;
    color: var(--gold);
    letter-spacing: -0.02em;
}

/* ========== VIDEO REEL ========== */
.video-reel {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.75rem;
}
@media (min-width: 768px) {
    .video-reel { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1rem; }
}

.video-card {
    position: relative;
    aspect-ratio: 9/16;
    border-radius: var(--r-md);
    overflow: hidden;
    background: var(--bg-secondary);
    cursor: pointer;
}
.video-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.video-card:hover img { transform: scale(1.05); }
.video-card-play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
}
.video-card-play svg {
    width: 50px; height: 50px;
    color: #fff;
    filter: drop-shadow(0 0 12px rgba(0,0,0,0.4));
}
.video-card-info {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 1rem;
    color: #fff;
}
.video-card-title {
    font-weight: 600;
    font-size: 0.875rem;
    line-height: 1.3;
}

/* ========== FOOTER ========== */
.dubaios-footer {
    background:
        radial-gradient(ellipse at top, rgba(212,175,55,0.05) 0%, transparent 60%),
        var(--bg-secondary);
    padding: 4rem 1.25rem 6rem;
    border-top: 1px solid rgba(255,255,255,0.06);
}

@media (min-width: 1024px) {
    .dubaios-footer { padding: 5rem 2rem 3rem; }
}

.footer-grid {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 768px) {
    .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
}

.footer-bottom {
    max-width: 1400px;
    margin: 3rem auto 0;
    padding-top: 2rem;
    border-top: 1px solid rgba(255,255,255,0.06);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    justify-content: space-between;
    color: var(--text-dim);
    font-size: 0.8125rem;
}

@media (min-width: 768px) {
    .footer-bottom { flex-direction: row; }
}

/* ========== BUTTONS ========== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.75rem;
    border-radius: var(--r-sm);
    font-weight: 600;
    font-size: 0.9375rem;
    cursor: pointer;
    border: 0;
    transition: all 0.3s;
    text-decoration: none;
}
.btn-primary {
    background: linear-gradient(135deg, var(--gold), var(--gold-soft));
    color: var(--bg-primary);
    box-shadow: 0 8px 24px rgba(212,175,55,0.3);
}
.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(212,175,55,0.5);
}
.btn-secondary {
    background: var(--glass);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-primary);
    backdrop-filter: blur(12px);
}
.btn-secondary:hover {
    background: var(--glass-strong);
    border-color: var(--gold);
    color: var(--gold);
}

/* ========== LOADER ========== */
.dubaios-loader {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(212,175,55,0.15);
    border-top-color: var(--gold);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 2rem auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ========== TOAST ========== */
.dubaios-toast {
    position: fixed;
    top: 5rem;
    right: 1rem;
    z-index: 200;
    padding: 1rem 1.25rem;
    background: var(--bg-secondary);
    border: 1px solid var(--gold);
    border-radius: var(--r-sm);
    color: var(--text-primary);
    box-shadow: var(--shadow-luxe);
    transform: translateX(120%);
    transition: transform 0.4s cubic-bezier(.16,1,.3,1);
}
.dubaios-toast.show { transform: translateX(0); }

/* ========== AREA HERO ========== */
.area-hero {
    position: relative;
    min-height: 60svh;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}
.area-hero img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.area-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, var(--bg-primary), transparent 70%);
}
.area-hero-content {
    position: relative;
    z-index: 1;
    padding: 3rem 1.5rem;
    max-width: 1400px;
    width: 100%;
    margin: 0 auto;
}

/* ========== UTILITIES — MOTION ========== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ========== HORIZONTAL SCROLL ROW ========== */
.scroll-row {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    scrollbar-width: none;
    padding: 0.25rem 1.25rem;
    margin: 0 -1.25rem;
    scroll-snap-type: x mandatory;
}
.scroll-row::-webkit-scrollbar { display: none; }
.scroll-row > * {
    flex: 0 0 280px;
    scroll-snap-align: start;
}
@media (min-width: 768px) {
    .scroll-row > * { flex: 0 0 320px; }
}

/* =================================================================
   ADDITIONAL TEMPLATE STYLES
================================================================= */
.dubaios-body{background:var(--bg-primary);color:var(--text);font-family:Inter,system-ui,sans-serif;margin:0;-webkit-font-smoothing:antialiased}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;background:var(--gold);color:#000;padding:.5rem 1rem;border-radius:8px;z-index:9999}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* HEADER */
.dubaios-header{position:fixed;top:0;left:0;right:0;z-index:80;padding:14px 0;transition:background .3s,box-shadow .3s,transform .3s;background:rgba(11,15,20,.0)}
.dubaios-header.scrolled{background:rgba(11,15,20,.78);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);box-shadow:0 8px 30px -10px rgba(0,0,0,.4);border-bottom:1px solid rgba(212,175,55,.1)}
.dubaios-header.hide-on-scroll{transform:translateY(-100%)}
.dubaios-header-inner{max-width:1320px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:24px}
.dubaios-brand{display:flex;align-items:center;gap:10px}
.brand-name strong{display:block;font-family:Poppins,Inter;font-size:18px;line-height:1;font-weight:800;letter-spacing:-.5px;color:#fff}
.brand-name strong em{font-style:normal;background:linear-gradient(135deg,#D4AF37,#E8C66B);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.brand-name small{display:block;font-size:10px;color:var(--muted);margin-top:2px;letter-spacing:.5px;text-transform:uppercase}
.dubaios-primary-nav{flex:1}
.nav-list{display:flex;gap:6px;list-style:none;margin:0;padding:0;justify-content:center}
.nav-list a{padding:8px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text);transition:background .2s,color .2s}
.nav-list a:hover{background:rgba(212,175,55,.08);color:var(--gold-soft)}
.dubaios-header-actions{display:flex;align-items:center;gap:10px}
.header-search{position:relative;display:flex;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.15);border-radius:999px;padding:6px 6px 6px 16px;width:240px;transition:border-color .2s}
.header-search:focus-within{border-color:var(--gold)}
.header-search input{background:transparent;border:none;outline:none;color:#fff;font-size:13px;flex:1;min-width:0}
.header-search input::placeholder{color:var(--muted)}
.header-search button{background:linear-gradient(135deg,#D4AF37,#E8C66B);border:none;color:#0B0F14;padding:7px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}
.search-suggest{position:absolute;top:calc(100% + 6px);left:0;right:0;background:rgba(18,24,33,.96);backdrop-filter:blur(20px);border:1px solid rgba(212,175,55,.18);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.search-suggest:empty{display:none}
.suggest-row{display:flex;align-items:center;gap:10px;padding:10px 14px;color:var(--text);font-size:13px;border-bottom:1px solid rgba(255,255,255,.04)}
.suggest-row:hover{background:rgba(212,175,55,.08)}
.suggest-type{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--gold-soft);background:rgba(212,175,55,.12);padding:2px 8px;border-radius:6px}
.header-icon-btn{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);color:var(--text);transition:background .2s,color .2s;overflow:hidden}
.header-icon-btn:hover{background:rgba(212,175,55,.12);color:var(--gold)}
.btn-ghost-sm{padding:8px 16px;border-radius:999px;border:1px solid rgba(212,175,55,.25);color:var(--gold);font-size:13px;font-weight:600;transition:background .2s}
.btn-ghost-sm:hover{background:rgba(212,175,55,.08)}
.header-menu-btn{display:none;width:38px;height:38px;background:rgba(255,255,255,.04);border:none;border-radius:10px;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer}
.header-menu-btn span{display:block;width:18px;height:2px;background:#fff;border-radius:2px}
.dubaios-mobile-menu{position:fixed;top:0;right:-100%;width:min(88%,360px);height:100vh;background:rgba(11,15,20,.98);backdrop-filter:blur(20px);padding:90px 28px 28px;transition:right .35s cubic-bezier(.22,.8,.32,1);z-index:70;border-left:1px solid rgba(212,175,55,.15)}
.dubaios-mobile-menu.open{right:0}
.mobile-nav-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.mobile-nav-list a{display:block;padding:14px 16px;border-radius:12px;color:var(--text);font-size:16px;font-weight:500;border:1px solid transparent}
.mobile-nav-list a:hover,.mobile-nav-list a:focus{background:rgba(212,175,55,.08);border-color:rgba(212,175,55,.2);color:var(--gold)}

@media(max-width:980px){
  .dubaios-primary-nav,.header-search{display:none}
  .header-menu-btn{display:flex}
}

.dubaios-main{padding-top:88px;min-height:60vh}

/* CARD COMPONENT */
.dubaios-card{display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid rgba(212,175,55,.12);border-radius:20px;overflow:hidden;transition:transform .35s cubic-bezier(.22,.8,.32,1),border-color .25s,box-shadow .25s;position:relative}
.dubaios-card:hover{transform:translateY(-6px);border-color:rgba(212,175,55,.35);box-shadow:0 18px 50px -16px rgba(0,0,0,.6),0 0 0 1px rgba(212,175,55,.08)}
.card-thumb{aspect-ratio:4/3;background-size:cover;background-position:center;background-color:#1A2230;position:relative}
.card-thumb-empty{background:linear-gradient(135deg,#1A2230,#0B0F14)}
.card-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(11,15,20,.4))}
.card-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:11px}
.card-type{padding:3px 10px;border-radius:999px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:10px}
.card-type.type-restaurants{background:rgba(255,122,92,.15);color:#FF7A5C}
.card-type.type-hotels{background:rgba(0,200,150,.15);color:#00C896}
.card-type.type-places{background:rgba(212,175,55,.15);color:#D4AF37}
.card-type.type-events{background:rgba(123,92,255,.15);color:#A78CFF}
.card-type.type-videos{background:rgba(92,200,255,.15);color:#5CC8FF}
.card-type.type-deals{background:rgba(255,92,138,.15);color:#FF5C8A}
.card-type.type-guides{background:rgba(200,255,92,.15);color:#C8FF5C}
.card-type.type-business{background:rgba(232,198,107,.15);color:#E8C66B}
.card-area{color:var(--muted);font-size:11px;display:flex;align-items:center;gap:3px}
.dubaios-card h3{font-family:Poppins;font-weight:600;font-size:16px;margin:0;color:#fff;line-height:1.3}
.dubaios-card p{font-size:13px;color:var(--muted);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-foot{display:flex;gap:10px;align-items:center;margin-top:auto;padding-top:6px}
.card-rating{color:var(--gold-soft);font-size:13px;font-weight:600}
.card-price{color:var(--emerald-x);font-size:13px;font-weight:600}
.card-save{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(11,15,20,.6);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s;z-index:2;cursor:pointer}
.card-save:hover{background:rgba(212,175,55,.2);color:var(--gold);border-color:var(--gold)}
.card-save.is-saved{background:var(--gold);color:#0B0F14;border-color:var(--gold)}

/* SECTION TITLES */
.dubaios-section{max-width:1320px;margin:0 auto;padding:56px 24px}
.section-head{margin-bottom:32px;display:flex;flex-direction:column;gap:6px;text-align:center}
.section-head h1,.section-head h2{font-family:Poppins;font-weight:700;color:#fff;margin:0;font-size:clamp(24px,4vw,38px);letter-spacing:-.5px}
.section-head p{color:var(--muted);margin:0;font-size:14px}
.section-head-row{flex-direction:row;justify-content:space-between;align-items:flex-end;text-align:left}
.section-head-row h2{font-size:24px}
.link-gold{color:var(--gold-soft);font-size:14px;font-weight:600}

/* FEED GRID */
.feed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.feed-grid-tight{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.feed-loader{display:flex;justify-content:center;gap:6px;padding:30px}
.feed-loader span{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:bounce 1.2s infinite ease-in-out both}
.feed-loader span:nth-child(2){animation-delay:.15s}
.feed-loader span:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,80%,100%{transform:scale(0);opacity:.3}40%{transform:scale(1);opacity:1}}

/* SCROLL ROW */
.scroll-row{display:flex;gap:16px;overflow-x:auto;padding:4px 4px 20px;scroll-snap-type:x mandatory;scrollbar-width:thin}
.scroll-row > *{flex:0 0 280px;scroll-snap-align:start}

/* REEL ROW (videos 9:16) */
.reel-row{display:flex;gap:14px;overflow-x:auto;padding:4px 4px 20px;scroll-snap-type:x mandatory}
.reel-card{flex:0 0 200px;aspect-ratio:9/16;border-radius:20px;overflow:hidden;position:relative;background:#1A2230;scroll-snap-align:start;transition:transform .3s}
.reel-card:hover{transform:scale(1.03)}
.reel-card img{width:100%;height:100%;object-fit:cover}
.reel-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:rgba(212,175,55,.9);color:#0B0F14;display:flex;align-items:center;justify-content:center;font-size:22px;backdrop-filter:blur(10px)}
.reel-overlay{position:absolute;bottom:0;left:0;right:0;padding:14px;background:linear-gradient(180deg,transparent,rgba(11,15,20,.9));color:#fff}
.reel-overlay strong{display:block;font-size:13px;font-weight:600}
.reel-overlay small{font-size:11px;color:var(--gold-soft);opacity:.85}

/* CATEGORY GRID */
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.cat-tile{display:flex;flex-direction:column;gap:6px;padding:22px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid rgba(212,175,55,.12);transition:all .3s;position:relative;overflow:hidden}
.cat-tile:hover{transform:translateY(-4px);border-color:rgba(212,175,55,.35);background:linear-gradient(180deg,rgba(212,175,55,.06),rgba(255,255,255,.01))}
.cat-emoji{font-size:28px}
.cat-tile strong{color:#fff;font-family:Poppins;font-weight:600;font-size:16px}
.cat-desc{color:var(--muted);font-size:12px;line-height:1.5}
.cat-arrow{position:absolute;top:22px;right:22px;color:var(--gold-soft);font-size:18px;opacity:.6;transition:transform .25s,opacity .25s}
.cat-tile:hover .cat-arrow{transform:translateX(4px);opacity:1}

/* HERO CHIPS */
.hero-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:18px}
.hero-chip{padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.15);color:var(--text);font-size:13px;transition:all .2s}
.hero-chip:hover{background:rgba(212,175,55,.1);border-color:var(--gold);color:var(--gold-soft)}

/* BUSINESS CTA */
.business-cta{display:grid;grid-template-columns:1.2fr 1fr;gap:36px;background:linear-gradient(135deg,#121821,#1A2230);border:1px solid rgba(212,175,55,.18);border-radius:28px;padding:48px;align-items:center;position:relative;overflow:hidden}
.business-cta::before{content:"";position:absolute;top:-50%;right:-20%;width:500px;height:500px;background:radial-gradient(circle,rgba(212,175,55,.18),transparent 60%);pointer-events:none}
.business-cta-text .eyebrow{color:var(--gold-soft);font-size:12px;text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-bottom:6px;display:block}
.business-cta-text h2{font-family:Poppins;font-size:32px;color:#fff;margin:6px 0 12px;font-weight:700;letter-spacing:-.5px}
.business-cta-text p{color:var(--muted);font-size:15px;line-height:1.6;margin:0 0 22px}
.cta-row{display:flex;gap:10px;flex-wrap:wrap}
.business-cta-visual{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;position:relative;z-index:1}
.bcta-card{background:rgba(11,15,20,.6);backdrop-filter:blur(10px);border:1px solid rgba(212,175,55,.18);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:4px}
.bcta-card span{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.bcta-card strong{color:#fff;font-family:Poppins;font-size:20px;font-weight:700}
.bcta-card small{color:var(--gold-soft);font-size:11px}
.bcta-card-1{transform:translateY(-10px)}
.bcta-card-3{transform:translateY(10px);grid-column:1/-1}

/* AREAS */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.area-tile{padding:16px 20px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(212,175,55,.1);display:flex;flex-direction:column;gap:4px;transition:all .25s}
.area-tile:hover{background:rgba(212,175,55,.06);border-color:rgba(212,175,55,.3)}
.area-tile strong{color:#fff;font-size:14px;font-weight:600}
.area-tile small{color:var(--muted);font-size:11px}

/* MAP */
.map-preview-wrap,.map-page-wrap{position:relative;border-radius:24px;overflow:hidden;border:1px solid rgba(212,175,55,.18)}
.map-preview{height:480px}
.map-page{height:calc(100vh - 240px);min-height:520px}
.map-filter-row{display:flex;gap:6px;flex-wrap:wrap;padding:12px;background:rgba(11,15,20,.7);backdrop-filter:blur(10px);position:absolute;top:14px;left:14px;border-radius:14px;border:1px solid rgba(212,175,55,.15);z-index:10}
.map-filter-row-top{position:relative;top:auto;left:auto;margin-bottom:14px;display:flex;justify-content:flex-start}
.js-map-filter{background:transparent;border:none;color:var(--text);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}
.js-map-filter:hover{background:rgba(255,255,255,.06)}
.js-map-filter.active{background:linear-gradient(135deg,#D4AF37,#E8C66B);color:#0B0F14;font-weight:600}
.do-map-pin{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#D4AF37,#E8C66B);border:3px solid rgba(11,15,20,.9);box-shadow:0 4px 12px rgba(0,0,0,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}
.do-map-pin:hover{transform:scale(1.2)}
.do-pin-restaurants{background:linear-gradient(135deg,#FF7A5C,#FFB28C)}
.do-pin-hotels{background:linear-gradient(135deg,#00C896,#5CFFD0)}
.do-pin-events{background:linear-gradient(135deg,#7B5CFF,#A78CFF)}
.do-pin-deals{background:linear-gradient(135deg,#FF5C8A,#FF9AB8)}
.do-map-popup .mapboxgl-popup-content{background:rgba(18,24,33,.98)!important;backdrop-filter:blur(20px);border:1px solid rgba(212,175,55,.2);border-radius:14px;padding:0!important;overflow:hidden}
.do-map-popup .mapboxgl-popup-close-button{color:#fff;font-size:18px;padding:6px 10px}
.do-pop{display:flex;gap:12px;padding:8px;align-items:center;color:#fff;width:240px}
.do-pop-img{width:60px;height:60px;border-radius:10px;background-size:cover;background-position:center;flex-shrink:0}
.do-pop-body{display:flex;flex-direction:column;gap:2px;font-size:13px}
.do-pop-body strong{color:#fff}
.do-pop-body span{color:var(--muted);font-size:11px}
.do-pop-rating{color:var(--gold-soft)!important;font-weight:600}
.map-open-btn{position:absolute;bottom:18px;right:18px;z-index:5}

/* CALCULATOR */
.calc-widget{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid rgba(212,175,55,.18);border-radius:24px;padding:32px;max-width:760px;margin:0 auto}
.calc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}
.calc-field label{display:block;font-size:12px;color:var(--gold-soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}
.calc-field select,.calc-field input{width:100%;background:rgba(11,15,20,.7);border:1px solid rgba(212,175,55,.18);color:#fff;padding:12px 14px;border-radius:12px;font-size:14px;outline:none;transition:border-color .2s}
.calc-field select:focus,.calc-field input:focus{border-color:var(--gold)}
.calc-submit{width:100%;justify-content:center}
.calc-output{margin-top:24px}
.calc-result{background:rgba(11,15,20,.6);border:1px solid rgba(212,175,55,.2);border-radius:18px;padding:24px}
.calc-total{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid rgba(212,175,55,.15);margin-bottom:14px}
.calc-total span{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.5px}
.calc-total strong{font-family:Poppins;font-size:28px;color:#fff;background:linear-gradient(135deg,#D4AF37,#E8C66B);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.calc-breakdown{list-style:none;margin:0;padding:0}
.calc-breakdown li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed rgba(255,255,255,.05);font-size:13px;color:var(--text)}
.calc-breakdown li:last-child{border-bottom:none}
.calc-breakdown b{color:var(--gold-soft);font-weight:600}
.calc-note{margin-top:14px;font-size:12px;color:var(--muted);line-height:1.6}
.calc-disclaimer{margin-top:18px;font-size:11px;color:var(--muted);text-align:center;line-height:1.6}

/* AI CONCIERGE WIDGET */
.ai-concierge-widget{max-width:820px;margin:0 auto}
.ai-concierge-card{position:relative;background:linear-gradient(180deg,rgba(20,28,40,.9),rgba(11,15,20,.95));border:1px solid rgba(212,175,55,.22);border-radius:28px;padding:36px;overflow:hidden}
.ai-orb-wrap{position:absolute;top:-80px;right:-60px;pointer-events:none}
.ai-orb{width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(212,175,55,.35),transparent 60%);filter:blur(40px);animation:float 8s ease-in-out infinite}
@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(-15px,15px)}}
.ai-modes{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;position:relative;z-index:1}
.js-ai-mode{padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.12);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s}
.js-ai-mode:hover{background:rgba(212,175,55,.08)}
.js-ai-mode.active{background:linear-gradient(135deg,#D4AF37,#E8C66B);color:#0B0F14;border-color:var(--gold);font-weight:600}
.ai-input-row{display:flex;gap:8px;align-items:center;background:rgba(11,15,20,.7);border:1px solid rgba(212,175,55,.18);border-radius:14px;padding:6px;position:relative;z-index:1}
.ai-input-row:focus-within{border-color:var(--gold);box-shadow:0 0 0 4px rgba(212,175,55,.12)}
.ai-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:15px;padding:12px 14px}
.ai-input::placeholder{color:var(--muted)}
.ai-send{background:linear-gradient(135deg,#D4AF37,#E8C66B);border:none;color:#0B0F14;width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s}
.ai-send:hover:not(:disabled){transform:translateX(2px)}
.ai-send:disabled{opacity:.5;cursor:not-allowed}
.ai-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px;position:relative;z-index:1}
.js-ai-chip{padding:6px 12px;border-radius:999px;background:rgba(212,175,55,.06);border:1px solid rgba(212,175,55,.15);color:var(--gold-soft);font-size:12px;cursor:pointer;transition:all .2s}
.js-ai-chip:hover{background:rgba(212,175,55,.14);color:var(--gold)}
.ai-output{margin-top:22px;position:relative;z-index:1}
.ai-output:empty{display:none}
.ai-answer{background:rgba(11,15,20,.5);border-left:3px solid var(--gold);border-radius:0 14px 14px 0;padding:16px 18px;color:var(--text);font-size:14px;line-height:1.7}
.ai-loading{display:flex;gap:6px;padding:20px;justify-content:center}
.ai-loading span{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:bounce 1.2s infinite ease-in-out both}
.ai-loading span:nth-child(2){animation-delay:.15s}
.ai-loading span:nth-child(3){animation-delay:.3s}
.ai-error{color:#FF7A5C;font-size:13px;padding:14px;background:rgba(255,122,92,.08);border-radius:12px}
.ai-suggestions{margin-top:14px}
.ai-suggestions h4{color:var(--gold-soft);font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px;font-weight:600}
.ai-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.ai-sug-card{display:flex;gap:10px;align-items:center;padding:8px;background:rgba(11,15,20,.6);border:1px solid rgba(212,175,55,.12);border-radius:12px;color:var(--text);transition:all .2s}
.ai-sug-card:hover{background:rgba(212,175,55,.08);border-color:rgba(212,175,55,.3)}
.ai-sug-thumb{width:48px;height:48px;border-radius:10px;background-size:cover;background-position:center;flex-shrink:0}
.ai-sug-body{display:flex;flex-direction:column;gap:2px;font-size:13px}
.ai-sug-body strong{color:#fff;line-height:1.2;font-size:13px}
.ai-sug-body span{color:var(--muted);font-size:11px}

.concierge-uses{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.use-card{padding:22px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid rgba(212,175,55,.12)}
.use-card strong{display:block;color:#fff;font-size:15px;font-family:Poppins;font-weight:600;margin-bottom:6px}
.use-card p{color:var(--muted);font-size:13px;line-height:1.6;margin:0;font-style:italic}

/* MOBILE BOTTOM NAV */
.dubaios-bottom-nav{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:60;background:rgba(11,15,20,.85);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(212,175,55,.2);border-radius:24px;padding:8px;display:none;gap:4px;box-shadow:0 14px 40px -10px rgba(0,0,0,.6)}
@media(max-width:980px){.dubaios-bottom-nav{display:flex}}
.bn-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 14px;border-radius:14px;color:var(--muted);transition:color .2s,background .2s;min-width:54px}
.bn-item svg{width:20px;height:20px}
.bn-item span{font-size:10px;font-weight:500}
.bn-item:hover,.bn-item.active{color:var(--gold)}
.bn-fab{background:linear-gradient(135deg,#D4AF37,#E8C66B);color:#0B0F14;transform:translateY(-12px);width:54px;height:54px;border-radius:50%;justify-content:center;box-shadow:0 8px 24px -6px rgba(212,175,55,.5);position:relative}
.bn-fab svg{width:24px;height:24px}
.bn-fab:hover{color:#0B0F14}
.bn-fab-glow{position:absolute;inset:-3px;border-radius:50%;background:radial-gradient(circle,rgba(212,175,55,.5),transparent 60%);filter:blur(6px);z-index:-1;animation:pulseGlow 2.5s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{opacity:.5}50%{opacity:.9}}

/* SINGLE TEMPLATE */
.dubaios-single{background:var(--bg-primary)}
.single-hero{position:relative;height:60vh;min-height:480px;overflow:hidden}
.single-hero-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.single-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,15,20,.3) 0%,rgba(11,15,20,.6) 60%,#0B0F14 100%)}
.single-hero-content{position:absolute;bottom:30px;left:0;right:0;max-width:1320px;margin:0 auto;padding:0 24px;color:#fff;z-index:2}
.single-hero-content h1{font-family:Poppins;font-size:clamp(28px,5vw,52px);font-weight:700;margin:8px 0;letter-spacing:-.5px;color:#fff;line-height:1.05}
.single-meta{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:14px;margin:10px 0 16px}
.single-meta .m-rating{color:var(--gold-soft)}
.single-actions{display:flex;gap:10px;flex-wrap:wrap}
.single-grid{max-width:1320px;margin:0 auto;padding:48px 24px;display:grid;grid-template-columns:1fr 320px;gap:36px}
@media(max-width:900px){.single-grid{grid-template-columns:1fr}}
.single-main.prose{color:var(--text);line-height:1.8;font-size:16px}
.prose h2,.prose h3{font-family:Poppins;color:#fff;margin:32px 0 12px;font-weight:600}
.prose h2{font-size:26px}
.prose h3{font-size:20px}
.prose a{color:var(--gold-soft);text-decoration:underline;text-decoration-color:rgba(212,175,55,.3)}
.prose ul,.prose ol{padding-left:22px;line-height:1.8}
.prose blockquote{border-left:3px solid var(--gold);background:rgba(212,175,55,.05);padding:16px 20px;margin:24px 0;border-radius:0 14px 14px 0;font-style:italic;color:var(--gold-soft)}
.single-map-block{margin:36px 0}
.single-map{height:300px;border-radius:18px;background:#1A2230}
.single-addr{font-size:13px;color:var(--muted);margin-top:10px}
.single-related{margin:36px 0}
.single-aside{display:flex;flex-direction:column;gap:18px;position:sticky;top:100px;align-self:flex-start}
.aside-card{background:rgba(255,255,255,.02);border:1px solid rgba(212,175,55,.15);border-radius:18px;padding:22px}
.aside-card h4{font-family:Poppins;color:#fff;font-size:14px;margin:0 0 12px;font-weight:600}
.aside-card p{color:var(--muted);font-size:13px;margin:0 0 14px;line-height:1.6}
.btn-block{display:block;text-align:center}
.facts-list{list-style:none;margin:0;padding:0}
.facts-list li{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;color:var(--text);border-bottom:1px solid rgba(255,255,255,.05)}
.facts-list li:last-child{border-bottom:none}
.facts-list li span{color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px}
.facts-list li a{color:var(--gold-soft)}

/* FOOTER */
.dubaios-footer{background:#070A0F;border-top:1px solid rgba(212,175,55,.1);padding:64px 0 24px;margin-top:80px}
.footer-inner{max-width:1320px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.4fr repeat(3,1fr) 1.6fr;gap:36px}
@media(max-width:980px){.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-inner{grid-template-columns:1fr}}
.footer-col h4{font-family:Poppins;color:#fff;font-size:14px;margin:0 0 14px;font-weight:600}
.footer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.footer-list a{color:var(--muted);font-size:13px;transition:color .2s}
.footer-list a:hover{color:var(--gold)}
.footer-tag{color:var(--muted);font-size:13px;line-height:1.6;margin:14px 0 16px;max-width:320px}
.footer-social{display:flex;gap:8px}
.footer-social a{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.15);color:var(--gold-soft);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;transition:all .2s}
.footer-social a:hover{background:rgba(212,175,55,.12);border-color:var(--gold);color:var(--gold)}
.footer-newsletter p{color:var(--muted);font-size:13px;margin:0 0 12px;line-height:1.5}
.footer-subscribe{display:flex;gap:6px}
.footer-subscribe input{flex:1;background:rgba(11,15,20,.7);border:1px solid rgba(212,175,55,.18);color:#fff;padding:10px 14px;border-radius:10px;font-size:13px;outline:none}
.footer-subscribe input:focus{border-color:var(--gold)}
.footer-subscribe .btn-primary{padding:10px 16px;font-size:13px}
.footer-bar{max-width:1320px;margin:48px auto 0;padding:20px 24px 0;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;color:var(--muted);font-size:12px;flex-wrap:wrap;gap:10px}
.footer-meta .gold-accent{color:var(--gold)}

/* TOAST */
.dubaios-toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:rgba(11,15,20,.95);backdrop-filter:blur(20px);color:#fff;padding:12px 22px;border-radius:14px;border:1px solid rgba(212,175,55,.3);font-size:13px;font-weight:500;z-index:1000;opacity:0;transition:all .3s;box-shadow:0 12px 40px -10px rgba(0,0,0,.6)}
.dubaios-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.dubaios-toast.warn{border-color:#E8C66B;color:#E8C66B}
.dubaios-toast.error{border-color:#FF7A5C;color:#FF7A5C}

/* 404 */
.error-404{text-align:center;padding:80px 24px;position:relative;overflow:hidden}
.error-orb{position:absolute;top:50%;left:50%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(212,175,55,.18),transparent 60%);filter:blur(40px);transform:translate(-50%,-50%);z-index:0;animation:float 6s ease-in-out infinite}
.error-404 > *{position:relative;z-index:1}
.error-404 h1{font-family:Poppins;font-size:120px;font-weight:800;margin:0;letter-spacing:-3px;line-height:1}
.error-404 h2{font-family:Poppins;color:#fff;font-size:28px;margin:12px 0}
.error-404 p{color:var(--muted);font-size:15px;max-width:480px;margin:0 auto 28px}
.error-404 .cta-row{justify-content:center;margin-bottom:30px}

/* DEAL CARDS — add discount badge */
.card-thumb .deal-badge{position:absolute;top:12px;left:12px;background:#FF5C8A;color:#fff;padding:5px 10px;border-radius:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;z-index:1}

/* EMPTY STATE */
.empty-state-block{text-align:center;padding:80px 24px;max-width:560px;margin:0 auto}
.empty-state-block h2,.empty-state-block h3{font-family:Poppins;color:#fff;margin:0 0 10px}
.empty-state-block p{color:var(--muted);margin:0 0 22px}

/* PAGINATION */
.dubaios-pagination{margin-top:48px;display:flex;justify-content:center}
.dubaios-pagination .page-numbers{padding:10px 14px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid rgba(212,175,55,.12);color:var(--text);margin:0 3px;font-weight:500;font-size:14px;transition:all .2s}
.dubaios-pagination .page-numbers:hover,.dubaios-pagination .current{background:linear-gradient(135deg,#D4AF37,#E8C66B);color:#0B0F14;border-color:var(--gold)}

/* PAGE */
.dubaios-page{max-width:840px;margin:0 auto;padding:48px 24px}
.page-head{text-align:center;margin-bottom:32px}
.page-head h1{font-family:Poppins;color:#fff;font-size:clamp(28px,5vw,46px);margin:0;letter-spacing:-.5px}
.page-lede{color:var(--muted);font-size:16px;margin-top:10px}
.page-hero-img{margin-bottom:32px;border-radius:20px;overflow:hidden}
