/*
Theme Name:  Noor Al Nakheel Traverse
Theme URI:   https://nooralnakheel.ae
Description: Premium WordPress theme for Noor Al Nakheel Traverse Tourism L.L.C — Luxury transport and inbound tourism operator in Dubai, UAE.
Version:     1.0.0
Author:      Noor Al Nakheel Traverse Tourism
Author URI:  https://nooralnakheel.ae
License:     GPL-2.0-or-later
Text Domain: nan
*/

/* ============================================================
   CSS CUSTOM PROPERTIES — Logo colour palette
   Gold   #C49A3C | Teal  #2A7F8F | Brown #5C3A1E
   Cream  #F5ECD7 | Navy  #0B1E26
   ============================================================ */
:root {
    --gold:    #C49A3C;
    --gold-l:  #E8C96A;
    --gold-d:  #8A6A20;
    --teal:    #2A7F8F;
    --teal-l:  #3BA0B4;
    --teal-d:  #1A5260;
    --brown:   #5C3A1E;
    --cream:   #F5ECD7;
    --cream-d: #E0CDA8;
    --bg:      #0B1E26;
    --bg2:     #112733;
    --bg3:     #0E222E;
    --text:    #F5ECD7;
    --muted:   rgba(245,236,215,0.6);
    --border:  rgba(196,154,60,0.18);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
    font-family: 'Raleway', system-ui, -apple-system, sans-serif;
    background: var(--bg);
    color: var(--cream);
    overflow-x: hidden;
    line-height: 1.7;
}
img { max-width:100%; height:auto; display:block; }
a { color:var(--gold); text-decoration:none; transition:color .2s; }
a:hover { color:var(--gold-l); }
ul { list-style:none; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--gold-d); border-radius:3px; }

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5,h6 {
    font-family: 'Cinzel', Georgia, serif;
    color: var(--cream);
    line-height: 1.2;
}
.em-gold { font-family:'Playfair Display',Georgia,serif; font-style:italic; color:var(--gold); font-weight:400; }
p { color: var(--muted); }

/* ── CONTAINER ── */
.nan-container { max-width:1200px; margin:0 auto; padding:0 5%; }
.nan-container-wide { max-width:1400px; margin:0 auto; padding:0 5%; }

/* ── NAVIGATION ── */
#nan-header {
    position: fixed; top:0; left:0; right:0; z-index:1000;
    background: rgba(11,30,38,0.97);
    border-bottom: 1px solid var(--border);
    backdrop-filter: blur(14px);
    transition: box-shadow .3s;
}
#nan-header.scrolled { box-shadow:0 4px 24px rgba(0,0,0,0.4); }
.nan-nav {
    display: flex; align-items:center; justify-content:space-between;
    height: 68px;
}
.nan-logo { display:flex; align-items:center; gap:12px; }
.nan-logo img { height:46px; object-fit:contain; }
.nan-logo-text { font-family:'Cinzel',serif; font-size:14px; font-weight:700; color:var(--gold); line-height:1.2; letter-spacing:.5px; }
.nan-logo-text span { display:block; font-size:9px; font-weight:400; color:var(--teal-l); letter-spacing:3px; text-transform:uppercase; font-family:'Raleway',sans-serif; }
.nan-nav-links { display:flex; align-items:center; gap:20px; }
.nan-nav-links a { color:var(--cream-d); font-size:11.5px; font-weight:600; letter-spacing:1px; text-transform:uppercase; padding:4px 0; border-bottom:2px solid transparent; transition:color .2s, border-color .2s; }
.nan-nav-links a:hover, .nan-nav-links a.current { color:var(--gold); border-bottom-color:var(--gold); }
.nan-nav-cta {
    background:var(--gold); color:var(--bg) !important; border:none; border-radius:3px;
    padding:9px 20px; font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
    cursor:pointer; font-family:'Raleway',sans-serif; transition:background .2s;
    border-bottom:none !important;
}
.nan-nav-cta:hover { background:var(--gold-l); color:var(--bg) !important; }
.nan-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:5px; }
.nan-hamburger span { width:24px; height:2px; background:var(--gold); display:block; transition:all .3s; }
.nan-mobile-nav { display:none; position:fixed; top:68px; left:0; right:0; background:var(--bg2); border-bottom:1px solid var(--border); z-index:999; padding:1rem 5%; }
.nan-mobile-nav.open { display:block; }
.nan-mobile-nav a { display:block; padding:.75rem 0; color:var(--cream-d); font-size:13px; font-weight:600; letter-spacing:1px; text-transform:uppercase; border-bottom:1px solid rgba(255,255,255,0.05); }
.nan-mobile-nav a:last-child { border-bottom:none; }

/* ── HERO ── */
.nan-page-hero {
    padding: 130px 5% 70px;
    text-align: center;
    position: relative;
    background: radial-gradient(ellipse 70% 50% at 50% 30%, rgba(42,127,143,0.1) 0%, transparent 70%), var(--bg);
}
.nan-page-hero::before, .nan-page-hero::after {
    content:''; position:absolute; width:120px; height:120px;
    border:1px solid rgba(196,154,60,0.15); pointer-events:none;
}
.nan-page-hero::before { top:85px; left:5%; border-right:none; border-bottom:none; }
.nan-page-hero::after  { bottom:20px; right:5%; border-left:none; border-top:none; }
.nan-hero-tag {
    display:inline-block; border:1px solid rgba(196,154,60,0.35);
    color:var(--gold); font-size:10px; font-weight:600; letter-spacing:4px;
    text-transform:uppercase; padding:6px 18px; border-radius:2px; margin-bottom:20px;
}
.nan-hero-h1 { font-size:clamp(26px,4.5vw,50px); font-weight:700; margin-bottom:14px; letter-spacing:1.5px; }
.nan-hero-sub { font-size:15px; font-weight:300; color:var(--muted); line-height:1.8; max-width:600px; margin:0 auto; }

/* ── SECTIONS ── */
.nan-section { padding:75px 5%; }
.nan-section-alt { background:var(--bg2); padding:75px 5%; }
.nan-section-tag { font-size:10px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--teal-l); margin-bottom:8px; }
.nan-section-title { font-size:clamp(22px,3.2vw,34px); font-weight:700; margin-bottom:12px; line-height:1.25; }
.nan-section-sub { font-size:14px; color:var(--muted); line-height:1.85; max-width:580px; margin-bottom:44px; }

/* ── GRIDS ── */
.nan-grid-2 { display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:20px; }
.nan-grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px; }
.nan-grid-4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(195px,1fr)); gap:16px; }

/* ── CARDS ── */
.nan-card {
    background:var(--bg3); border:1px solid var(--border); border-radius:10px;
    padding:28px; transition:border-color .3s, transform .3s;
}
.nan-card:hover { border-color:rgba(196,154,60,0.42); transform:translateY(-5px); }
.nan-card::before { content:''; display:block; height:2px; background:linear-gradient(to right,var(--teal),var(--gold)); border-radius:10px 10px 0 0; margin:-28px -28px 20px; opacity:0; transition:opacity .3s; }
.nan-card:hover::before { opacity:1; }
.nan-card h3 { font-family:'Cinzel',serif; font-size:15px; font-weight:600; color:var(--cream); margin-bottom:10px; }
.nan-card p { font-size:13px; color:var(--muted); line-height:1.75; }
.nan-icon-box { width:48px; height:48px; background:rgba(42,127,143,0.13); border:1px solid rgba(42,127,143,0.28); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:18px; }
.nan-badge { display:inline-block; background:rgba(196,154,60,0.1); border:1px solid rgba(196,154,60,0.25); color:var(--gold); font-size:9.5px; font-weight:600; letter-spacing:2px; text-transform:uppercase; padding:3px 10px; border-radius:2px; margin-bottom:12px; }

/* ── TOUR CARD (CPT) ── */
.nan-tour-card { background:var(--bg3); border:1px solid var(--border); border-radius:10px; overflow:hidden; transition:border-color .3s, transform .3s; }
.nan-tour-card:hover { border-color:rgba(196,154,60,0.42); transform:translateY(-5px); }
.nan-tour-card-thumb { position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--bg2); }
.nan-tour-card-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.nan-tour-card:hover .nan-tour-card-thumb img { transform:scale(1.06); }
.nan-tour-card-thumb-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; min-height:180px; }
.nan-tour-card-badge { position:absolute; top:12px; left:12px; background:var(--gold); color:var(--bg); font-size:10px; font-weight:700; letter-spacing:1px; padding:4px 10px; border-radius:2px; }
.nan-tour-card-body { padding:22px; }
.nan-tour-card-meta { display:flex; flex-wrap:wrap; gap:.35rem .9rem; margin-bottom:.65rem; }
.nan-tour-card-meta span { font-size:11px; color:var(--teal-l); display:flex; align-items:center; gap:4px; }
.nan-tour-card-title { font-family:'Cinzel',serif; font-size:15px; font-weight:600; color:var(--cream); margin-bottom:8px; }
.nan-tour-card-title a { color:var(--cream); }
.nan-tour-card-title a:hover { color:var(--gold); }
.nan-tour-card-excerpt { font-size:12.5px; color:var(--muted); line-height:1.7; margin-bottom:16px; }
.nan-tour-card-footer { display:flex; align-items:center; justify-content:space-between; gap:.75rem; border-top:1px solid var(--border); padding-top:14px; flex-wrap:wrap; }
.nan-tour-card-price { font-family:'Cinzel',serif; color:var(--gold); font-size:15px; font-weight:600; }
.nan-tour-card-price .from { font-size:10px; color:var(--muted); display:block; font-family:'Raleway',sans-serif; }

/* ── FLEET CARD ── */
.nan-fleet-card { background:var(--bg3); border:1px solid rgba(42,127,143,0.22); border-radius:10px; padding:28px; text-align:center; transition:border-color .3s; }
.nan-fleet-card:hover { border-color:var(--teal); }
.nan-fleet-emoji { font-size:44px; display:block; margin-bottom:14px; }
.nan-fleet-name { font-family:'Cinzel',serif; font-size:15px; font-weight:600; color:var(--cream); margin-bottom:8px; }
.nan-fleet-seats { display:inline-block; background:var(--teal-d); color:var(--teal-l); font-size:11px; font-weight:700; letter-spacing:1.5px; padding:4px 14px; border-radius:20px; margin-bottom:14px; }
.nan-fleet-features { text-align:left; }
.nan-fleet-features li { font-size:12px; color:var(--muted); padding:4px 0; border-bottom:1px solid rgba(255,255,255,0.04); display:flex; align-items:center; gap:8px; }
.nan-fleet-features li::before { content:'✦'; color:var(--gold); font-size:8px; flex-shrink:0; }

/* ── STATS BAND ── */
.nan-stats-band { background:var(--teal-d); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:28px 5%; display:grid; grid-template-columns:repeat(4,1fr); }
.nan-stat { text-align:center; border-right:1px solid rgba(196,154,60,0.14); padding:8px 0; }
.nan-stat:last-child { border-right:none; }
.nan-stat-num { font-family:'Cinzel',serif; font-size:24px; font-weight:700; color:var(--gold); display:block; }
.nan-stat-lbl { font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); display:block; margin-top:3px; }

/* ── BUTTONS ── */
.nan-btn, .btn-gold { display:inline-block; background:var(--gold); color:var(--bg); border:none; border-radius:3px; padding:12px 28px; font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; font-family:'Raleway',sans-serif; transition:background .2s; }
.nan-btn:hover, .btn-gold:hover { background:var(--gold-l); color:var(--bg); }
.nan-btn-outline, .btn-outline { display:inline-block; background:none; color:var(--cream); border:1px solid rgba(245,236,215,0.3); border-radius:3px; padding:12px 28px; font-size:12px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; font-family:'Raleway',sans-serif; transition:border-color .2s, color .2s; }
.nan-btn-outline:hover, .btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.nan-btn-sm { padding:8px 18px; font-size:10px; }
.nan-btn-group { display:flex; gap:12px; flex-wrap:wrap; }

/* ── ORN DIVIDER ── */
.nan-orn { text-align:center; padding:16px 0; color:rgba(196,154,60,0.3); font-size:16px; letter-spacing:10px; }

/* ── TICKET CARD ── */
.nan-ticket-card { background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:18px; display:flex; gap:14px; align-items:flex-start; transition:border-color .3s; }
.nan-ticket-card:hover { border-color:rgba(196,154,60,0.4); }
.nan-ticket-emoji { font-size:28px; flex-shrink:0; }
.nan-ticket-city { font-size:9px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--teal-l); margin-bottom:4px; }
.nan-ticket-name { font-family:'Cinzel',serif; font-size:13px; font-weight:600; color:var(--cream); margin-bottom:5px; }
.nan-ticket-desc { font-size:11.5px; color:var(--muted); line-height:1.6; margin-bottom:10px; }

/* ── CONTACT FORM ── */
.nan-form { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:36px; }
.nan-form h3 { font-family:'Cinzel',serif; font-size:20px; font-weight:600; color:var(--cream); margin-bottom:28px; }
.nan-form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.nan-form-group { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.nan-form-group label { font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:rgba(245,236,215,0.45); }
.nan-form-group input,
.nan-form-group select,
.nan-form-group textarea {
    background:rgba(11,30,38,0.7); border:1px solid rgba(196,154,60,0.2); border-radius:5px;
    padding:11px 13px; font-size:13px; color:var(--cream); font-family:'Raleway',sans-serif;
    outline:none; transition:border-color .2s; width:100%;
}
.nan-form-group input:focus, .nan-form-group select:focus, .nan-form-group textarea:focus { border-color:rgba(196,154,60,0.5); }
.nan-form-group textarea { resize:vertical; min-height:90px; }
.nan-form-group select option { background:var(--bg); }
.nan-form-submit { width:100%; background:var(--gold); color:var(--bg); border:none; border-radius:5px; padding:14px; font-size:13px; font-weight:700; letter-spacing:2px; text-transform:uppercase; cursor:pointer; font-family:'Raleway',sans-serif; transition:background .2s; }
.nan-form-submit:hover { background:var(--gold-l); }

/* ── CONTACT INFO BLOCKS ── */
.nan-contact-block { display:flex; gap:16px; align-items:flex-start; margin-bottom:28px; }
.nan-contact-icon { width:44px; height:44px; background:rgba(42,127,143,0.14); border:1px solid rgba(42,127,143,0.28); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.nan-contact-block h4 { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--teal-l); margin-bottom:5px; }
.nan-contact-block p, .nan-contact-block a { font-size:14px; color:var(--cream-d); line-height:1.7; display:block; }
.nan-contact-block a:hover { color:var(--gold); }

/* ── FOOTER ── */
#nan-footer { background:var(--bg3); border-top:1px solid var(--border); padding:44px 5% 22px; }
.nan-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; margin-bottom:30px; }
.nan-footer-brand-logo { height:58px; object-fit:contain; margin-bottom:14px; }
.nan-footer-brand p { font-size:12px; color:rgba(245,236,215,0.4); line-height:1.8; max-width:270px; }
.nan-footer-col h4 { font-family:'Cinzel',serif; font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.nan-footer-col ul li { margin-bottom:8px; }
.nan-footer-col ul li a { font-size:12px; color:rgba(245,236,215,0.45); transition:color .2s; }
.nan-footer-col ul li a:hover { color:var(--gold); }
.nan-footer-bottom { border-top:1px solid rgba(196,154,60,0.1); padding-top:18px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.nan-footer-bottom p { font-size:11px; color:rgba(245,236,215,0.28); }
.nan-wa-btn { background:#25D366; color:#fff; border:none; border-radius:3px; padding:8px 18px; font-size:11px; font-weight:700; letter-spacing:1px; cursor:pointer; font-family:'Raleway',sans-serif; transition:background .2s; }
.nan-wa-btn:hover { background:#1db954; }

/* ── FLOATING WHATSAPP ── */
.nan-wa-float { position:fixed; bottom:22px; right:22px; z-index:900; width:54px; height:54px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; font-size:26px; box-shadow:0 4px 18px rgba(37,211,102,0.38); transition:transform .2s; text-decoration:none; }
.nan-wa-float:hover { transform:scale(1.1); }

/* ── PACKAGE CARD ── */
.nan-package-card { background:var(--bg3); border:1px solid var(--border); border-radius:10px; overflow:hidden; display:flex; flex-direction:column; }
.nan-package-header { background:linear-gradient(135deg,rgba(42,127,143,0.25),var(--bg3)); padding:26px 24px 20px; border-bottom:1px solid var(--border); }
.nan-package-icon { font-size:34px; display:block; margin-bottom:10px; }
.nan-package-dur { font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:4px; }
.nan-package-body { padding:22px; flex:1; }
.nan-package-body p { font-size:12.5px; color:var(--muted); line-height:1.7; margin-bottom:14px; }
.nan-package-includes { list-style:none; margin-bottom:18px; }
.nan-package-includes li { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--muted); padding:4px 0; border-bottom:1px solid rgba(255,255,255,0.04); }
.nan-package-includes li::before { content:'✦'; color:var(--gold); font-size:8px; flex-shrink:0; }
.nan-package-footer { display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--border); padding:14px 24px; flex-wrap:wrap; gap:8px; }
.nan-package-price { font-family:'Cinzel',serif; color:var(--gold); font-size:14px; font-weight:600; }

/* ── WHY ITEM ── */
.nan-why-item { display:flex; gap:16px; align-items:flex-start; padding:22px; background:var(--bg3); border:1px solid var(--border); border-radius:10px; }
.nan-why-item h4 { font-family:'Cinzel',serif; font-size:13px; font-weight:600; color:var(--cream); margin-bottom:6px; }
.nan-why-item p { font-size:12px; color:var(--muted); line-height:1.65; }

/* ── ARCHIVE FILTERS ── */
.nan-filter-bar { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:32px; }
.nan-filter-btn { background:none; border:1px solid var(--border); color:var(--muted); font-size:11px; font-weight:600; letter-spacing:1px; text-transform:uppercase; padding:7px 16px; border-radius:3px; cursor:pointer; font-family:'Raleway',sans-serif; transition:all .2s; }
.nan-filter-btn:hover, .nan-filter-btn.active { background:var(--gold); color:var(--bg); border-color:var(--gold); }

/* ── SINGLE TOUR ── */
.nan-single-hero { padding:120px 5% 50px; position:relative; }
.nan-single-img { border-radius:10px; overflow:hidden; margin-bottom:30px; max-height:460px; }
.nan-single-img img { width:100%; height:100%; object-fit:cover; }
.nan-single-grid { display:grid; grid-template-columns:1fr 340px; gap:40px; align-items:start; }
.nan-single-content h1 { font-family:'Cinzel',serif; font-size:clamp(22px,3.5vw,38px); margin-bottom:14px; }
.nan-single-content p { font-size:14px; line-height:1.85; color:var(--muted); margin-bottom:20px; }
.nan-includes-list { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:24px; }
.nan-includes-list li { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); }
.nan-includes-list li::before { content:'✦'; color:var(--gold); font-size:8px; flex-shrink:0; }
.nan-booking-box { background:var(--bg3); border:1px solid var(--border); border-radius:10px; padding:26px; position:sticky; top:90px; }
.nan-booking-box h3 { font-family:'Cinzel',serif; font-size:16px; font-weight:600; margin-bottom:20px; }
.nan-price-big { font-family:'Cinzel',serif; font-size:32px; color:var(--gold); margin-bottom:6px; }
.nan-price-big .from { font-size:12px; color:var(--muted); font-family:'Raleway',sans-serif; display:block; margin-bottom:4px; }

/* ── BREADCRUMBS ── */
.nan-breadcrumb { padding:90px 5% 0; font-size:12px; color:var(--muted); display:flex; align-items:center; gap:6px; }
.nan-breadcrumb a { color:var(--teal-l); }
.nan-breadcrumb span { color:var(--gold); }

/* ── PAGINATION ── */
.nan-pagination { display:flex; justify-content:center; gap:8px; margin-top:48px; }
.nan-pagination a, .nan-pagination span { background:var(--bg3); border:1px solid var(--border); color:var(--cream-d); padding:8px 14px; border-radius:3px; font-size:13px; transition:all .2s; }
.nan-pagination a:hover, .nan-pagination .current { background:var(--gold); border-color:var(--gold); color:var(--bg); }

/* ── RESPONSIVE ── */
@media(max-width:960px) {
    .nan-nav-links { display:none; }
    .nan-hamburger { display:flex; }
    .nan-stats-band { grid-template-columns:1fr 1fr; }
    .nan-single-grid { grid-template-columns:1fr; }
    .nan-booking-box { position:static; }
    .nan-footer-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:640px) {
    .nan-page-hero { padding:110px 5% 50px; }
    .nan-form-row { grid-template-columns:1fr; }
    .nan-stats-band { grid-template-columns:1fr 1fr; }
    .nan-includes-list { grid-template-columns:1fr; }
    .nan-footer-grid { grid-template-columns:1fr; }
    .nan-footer-brand p { max-width:100%; }
}
@media(prefers-reduced-motion:reduce) {
    *, .nan-card, .nan-tour-card { transition:none !important; }
}
