/* ============================================
   NYC City Guide – style.css
   nyc.weekendtourguide.com
   ============================================ */
:root{
  --navy:#0a1628;--navy2:#112040;--gold:#c8a84b;--gold2:#e8c86b;
  --bg:#0d1b2a;--bg2:#112035;--bg3:#162840;
  --card:#13223a;--card2:#1a2e4a;
  --border:#1e3a5a;--border2:#254870;
  --text1:#f0f4f8;--text2:#a8bfd4;--text3:#6a8aa8;
  --accent:#c8a84b;--accent2:#e8c86b;
  --red:#e63946;--green:#2dc653;
  --radius:10px;--radius2:16px;
  --shadow:0 4px 20px rgba(0,0,0,.4);
  --font:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text1);min-height:100vh;font-size:15px;line-height:1.6}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.container{max-width:1200px;margin:0 auto;padding:0 1rem}

/* ── NAVBAR ── */
.navbar{position:sticky;top:0;z-index:1000;background:rgba(10,22,40,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;gap:1rem;height:60px;padding:0 1.25rem}
.nav-logo{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;font-weight:700;flex-shrink:0}
.logo-icon{font-size:1.4rem}
.logo-text{color:var(--text1)}.logo-text em{color:var(--gold);font-style:normal}
.nav-links{display:flex;align-items:center;gap:.25rem;margin-left:auto;flex-wrap:wrap}
.nav-dropdown{position:relative}
.nav-city-link{display:flex;align-items:center;gap:.25rem;padding:.4rem .65rem;border-radius:6px;font-size:.82rem;color:var(--text2);transition:all .2s;white-space:nowrap}
.nav-city-link:hover,.nav-dropdown:hover .nav-city-link{color:var(--gold);background:var(--bg2)}
.nav-chev{font-size:.6rem;transition:transform .2s}
.nav-dropdown:hover .nav-chev{transform:rotate(180deg)}
.nav-mega{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem;min-width:280px;box-shadow:var(--shadow);z-index:200}
.nav-dropdown:hover .nav-mega{display:block}
.nm-head{padding-bottom:.75rem;border-bottom:1px solid var(--border);margin-bottom:.75rem}
.nm-city-link{color:var(--gold);font-weight:600;font-size:.9rem}
.nm-grid{display:grid;grid-template-columns:1fr 1fr;gap:.35rem}
.nm-item{padding:.3rem .5rem;border-radius:6px;font-size:.8rem;color:var(--text2);transition:all .15s}
.nm-item:hover{color:var(--gold);background:var(--bg2)}
.nav-cta{padding:.4rem .9rem;background:var(--gold);color:#000;border-radius:6px;font-size:.82rem;font-weight:600;margin-left:.5rem;transition:all .2s}
.nav-cta:hover{background:var(--gold2)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.3rem;margin-left:auto}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text1);border-radius:2px;transition:all .3s}
.nav-mobile{display:none;padding:.75rem 1rem;background:var(--bg2);border-top:1px solid var(--border);max-height:80vh;overflow-y:auto}
.mob-city-head{display:flex;justify-content:space-between;align-items:center;padding:.6rem .5rem;border-radius:8px;cursor:pointer;color:var(--text1);font-weight:500}
.mob-city-head:hover{background:var(--bg3)}
.mob-chev{transition:transform .2s;font-size:.7rem}
.mob-city-stations{display:none;padding:.25rem 0 .25rem .75rem;border-left:2px solid var(--border);margin:.25rem .5rem .5rem 1rem}
.mob-station{display:block;padding:.35rem .5rem;color:var(--text2);font-size:.84rem;border-radius:5px}
.mob-station:hover,.mob-all{color:var(--gold)}
.mob-cta{display:block;margin:.75rem .5rem .25rem;padding:.65rem;background:var(--gold);color:#000;border-radius:8px;font-weight:600;text-align:center}
@media(max-width:900px){.nav-links{display:none}.nav-burger{display:flex}.nav-mobile.open{display:block}}

/* ── HERO ── */
.hero{position:relative;padding:4rem 0 3rem;overflow:hidden;background:linear-gradient(135deg,#050d1a 0%,#0a1628 50%,#0d2040 100%)}
.hero-skyline{position:absolute;bottom:0;left:0;right:0;height:200px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 1200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='0' y='100' width='30' height='100' fill='%230d2040'/%3E%3Crect x='35' y='60' width='25' height='140' fill='%230a1830'/%3E%3Crect x='65' y='80' width='40' height='120' fill='%230d2040'/%3E%3Crect x='110' y='40' width='20' height='160' fill='%23112040'/%3E%3Crect x='135' y='70' width='35' height='130' fill='%230a1830'/%3E%3Crect x='175' y='20' width='15' height='180' fill='%230d2040'/%3E%3Crect x='195' y='55' width='45' height='145' fill='%23112040'/%3E%3Crect x='245' y='75' width='30' height='125' fill='%230a1830'/%3E%3Crect x='280' y='90' width='50' height='110' fill='%230d2040'/%3E%3Crect x='335' y='50' width='25' height='150' fill='%23112040'/%3E%3Crect x='365' y='30' width='20' height='170' fill='%230a1830'/%3E%3Crect x='390' y='65' width='60' height='135' fill='%230d2040'/%3E%3Crect x='455' y='85' width='35' height='115' fill='%23112040'/%3E%3Crect x='495' y='45' width='15' height='155' fill='%230a1830'/%3E%3Crect x='515' y='70' width='40' height='130' fill='%230d2040'/%3E%3Crect x='560' y='35' width='25' height='165' fill='%23112040'/%3E%3Crect x='590' y='60' width='55' height='140' fill='%230a1830'/%3E%3Crect x='650' y='80' width='30' height='120' fill='%230d2040'/%3E%3Crect x='685' y='25' width='20' height='175' fill='%23112040'/%3E%3Crect x='710' y='55' width='45' height='145' fill='%230a1830'/%3E%3Crect x='760' y='90' width='35' height='110' fill='%230d2040'/%3E%3Crect x='800' y='50' width='25' height='150' fill='%23112040'/%3E%3Crect x='830' y='40' width='60' height='160' fill='%230a1830'/%3E%3Crect x='895' y='70' width='30' height='130' fill='%230d2040'/%3E%3Crect x='930' y='85' width='40' height='115' fill='%23112040'/%3E%3Crect x='975' y='55' width='20' height='145' fill='%230a1830'/%3E%3Crect x='1000' y='75' width='50' height='125' fill='%230d2040'/%3E%3Crect x='1055' y='45' width='25' height='155' fill='%23112040'/%3E%3Crect x='1085' y='65' width='35' height='135' fill='%230a1830'/%3E%3Crect x='1125' y='80' width='30' height='120' fill='%230d2040'/%3E%3Crect x='1160' y='30' width='40' height='170' fill='%23112040'/%3E%3C/svg%3E") bottom/cover no-repeat;opacity:.6;pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:700px;margin:0 auto;text-align:center}
.hero-badge{display:inline-block;background:rgba(200,168,75,.15);border:1px solid rgba(200,168,75,.3);color:var(--gold);padding:.3rem 1rem;border-radius:20px;font-size:.82rem;font-weight:600;margin-bottom:1.25rem;letter-spacing:.05em}
.hero-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.1;margin-bottom:.75rem;color:var(--text1)}
.hero-cities{display:block;font-size:clamp(1rem,2.5vw,1.4rem);color:var(--gold);font-weight:600;margin-top:.4rem;letter-spacing:.04em}
.hero-sub{color:var(--text2);font-size:1rem;margin-bottom:1.75rem;max-width:550px;margin-left:auto;margin-right:auto}
.hero-search{width:100%;max-width:560px;margin:0 auto 1.25rem}
.hs-inner{display:flex;background:var(--card);border:1px solid var(--border2);border-radius:10px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.4)}
.hs-input{flex:1;background:none;border:none;padding:.85rem 1rem;color:var(--text1);font-size:.95rem;outline:none}
.hs-input::placeholder{color:var(--text3)}
.hs-btn{background:var(--gold);color:#000;border:none;padding:.85rem 1.25rem;cursor:pointer;font-weight:700;font-size:.9rem;transition:background .2s;white-space:nowrap}
.hs-btn:hover{background:var(--gold2)}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap;font-size:.82rem;color:var(--text3)}
.hs-stat b{color:var(--gold)}
.hs-sep{color:var(--border2)}

/* ── BOROUGH CARDS ── */
.cities-section{padding:2rem 0 1rem}
.city-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}
@media(max-width:900px){.city-cards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:500px){.city-cards{grid-template-columns:repeat(2,1fr)}}
.city-card{position:relative;border-radius:12px;padding:1.1rem .75rem;text-align:center;border:1px solid rgba(255,255,255,.08);transition:all .2s;cursor:pointer}
.city-card:hover{transform:translateY(-3px);border-color:var(--gold)}
.city-card.active{border-color:var(--gold);box-shadow:0 0 0 2px rgba(200,168,75,.25)}
.cc-emoji{font-size:1.8rem;margin-bottom:.4rem}
.cc-name{font-weight:700;font-size:.9rem;color:var(--text1)}
.cc-tag{font-size:.7rem;color:rgba(255,255,255,.55);margin-top:.2rem}
.cc-check{position:absolute;top:.5rem;right:.5rem;color:var(--gold);font-size:.9rem}

/* ── AREAS ── */
.areas-section{padding:.75rem 0}
.areas-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;flex-wrap:wrap;gap:.5rem}
.areas-label{font-size:.82rem;color:var(--text3);font-weight:500}
.area-dropdown{background:var(--card);border:1px solid var(--border);color:var(--text1);padding:.35rem .65rem;border-radius:7px;font-size:.82rem;cursor:pointer}
.area-pills-home{display:flex;gap:.4rem;flex-wrap:wrap}
.area-pill-home{padding:.3rem .75rem;border-radius:20px;border:1px solid var(--border);font-size:.78rem;color:var(--text2);background:var(--card);transition:all .15s}
.area-pill-home:hover,.area-pill-home.active{border-color:var(--gold);color:var(--gold);background:rgba(200,168,75,.1)}

/* ── FILTER BAR ── */
.filter-bar{background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:60px;z-index:90}
.fb-inner{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;flex-wrap:wrap}
.fb-btn{display:flex;align-items:center;gap:.4rem;background:var(--card);border:1px solid var(--border);color:var(--text2);padding:.4rem .85rem;border-radius:8px;cursor:pointer;font-size:.82rem;transition:all .15s}
.fb-btn.active,.fb-btn:hover{border-color:var(--gold);color:var(--gold)}
.fb-val{background:var(--gold);color:#000;padding:.1rem .4rem;border-radius:4px;font-size:.72rem;font-weight:700}
.fb-chev{font-size:.65rem;margin-left:.15rem}
.fb-clear{display:flex;align-items:center;gap:.25rem;color:var(--red);font-size:.8rem;border:1px solid rgba(230,57,70,.3);padding:.35rem .7rem;border-radius:7px;background:rgba(230,57,70,.08)}
.fb-count{margin-left:auto;font-size:.8rem;color:var(--text3)}
.filter-panel{background:var(--bg2);border-top:1px solid var(--border);padding:.75rem 0}
.fp-grid{display:flex;gap:.45rem;flex-wrap:wrap}
.fp-chip{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:20px;border:1px solid var(--border);font-size:.79rem;color:var(--text2);background:var(--card);transition:all .15s;cursor:pointer}
.fp-chip:hover,.fp-chip.active{border-color:var(--chip-color,var(--gold));color:var(--chip-color,var(--gold));background:rgba(var(--chip-color,200,168,75),.08)}
.fp-chip.active{font-weight:600}

/* ── LISTINGS GRID ── */
.listings-section{padding:1.75rem 0 2.5rem}
.listings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:900px){.listings-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.listings-grid{grid-template-columns:1fr}}
.listing-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius2);overflow:hidden;transition:all .2s;display:flex;flex-direction:column}
.listing-card:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:0 8px 30px rgba(0,0,0,.5)}
.lc-img{height:180px;overflow:hidden;position:relative;background:var(--bg3)}
.lc-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.listing-card:hover .lc-img img{transform:scale(1.05)}
.lc-img-placeholder{height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--cat-color,var(--gold));background:rgba(0,0,0,.2)}
.lc-city-badge{position:absolute;top:.5rem;left:.5rem;background:rgba(10,22,40,.8);backdrop-filter:blur(4px);color:var(--text1);padding:.2rem .55rem;border-radius:5px;font-size:.72rem;font-weight:500;border:1px solid var(--border)}
.lc-body{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.45rem}
.lc-cats{display:flex;gap:.3rem;flex-wrap:wrap}
.lc-cat{font-size:.71rem;padding:.2rem .5rem;border-radius:4px;border:1px solid var(--border);color:var(--cc,var(--gold));display:flex;align-items:center;gap:.25rem}
.lc-name{font-size:1rem;font-weight:700;color:var(--text1);line-height:1.3}
.lc-desc{font-size:.82rem;color:var(--text2);flex:1;line-height:1.5}
.lc-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid var(--border)}
.lc-area{font-size:.76rem;color:var(--text3);display:flex;align-items:center;gap:.25rem}
.lc-maps{font-size:.76rem;color:var(--gold);display:flex;align-items:center;gap:.25rem}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:4rem 1rem}
.es-icon{font-size:3rem;margin-bottom:1rem}
.empty-state h3{color:var(--text1);margin-bottom:.5rem}
.empty-state p{color:var(--text2)}
.empty-state a{color:var(--gold);text-decoration:underline}

/* ── PAGINATION ── */
.pagination{display:flex;justify-content:center;gap:.4rem;margin-top:2rem;flex-wrap:wrap}
.pg-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);color:var(--text2);font-size:.85rem;background:var(--card);transition:all .15s}
.pg-btn:hover,.pg-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(200,168,75,.1)}
.pg-btn.active{font-weight:700}

/* ── SECTION HEADING ── */
.section-heading{font-size:1.35rem;font-weight:700;color:var(--text1);margin-bottom:1.25rem}

/* ── CATEGORY SHOWCASE ── */
.cat-showcase{padding:2rem 0}
.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.75rem}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:500px){.cat-grid{grid-template-columns:repeat(3,1fr)}}
.cat-tile{display:flex;flex-direction:column;align-items:center;gap:.45rem;padding:1rem .75rem;background:var(--card);border:1px solid var(--border);border-radius:12px;font-size:.8rem;color:var(--text2);transition:all .2s;text-align:center}
.cat-tile i{font-size:1.5rem;color:var(--tc,var(--gold))}
.cat-tile:hover{border-color:var(--tc,var(--gold));color:var(--tc,var(--gold));transform:translateY(-3px)}

/* ── CTA SECTION ── */
.cta-section{padding:2rem 0 3rem}
.cta-card{background:linear-gradient(135deg,var(--navy2),var(--bg3));border:1px solid var(--gold);border-radius:16px;padding:2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cta-left h2{font-size:1.3rem;font-weight:700;margin-bottom:.4rem}
.cta-left p{color:var(--text2);font-size:.9rem;max-width:500px}
.cta-btn{background:var(--gold);color:#000;padding:.75rem 1.75rem;border-radius:8px;font-weight:700;font-size:.95rem;white-space:nowrap;transition:background .2s}
.cta-btn:hover{background:var(--gold2)}

/* ── FOOTER ── */
.site-footer{background:var(--navy);border-top:1px solid var(--border);padding:2.5rem 0 1.25rem;margin-top:1rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{font-size:1.3rem;font-weight:700;display:block;margin-bottom:.75rem;color:var(--text1)}
.footer-logo em{color:var(--gold);font-style:normal}
.footer-brand p{font-size:.82rem;color:var(--text3);line-height:1.6}
.footer-col h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:.75rem;font-weight:600}
.footer-col a{display:block;font-size:.84rem;color:var(--text2);padding:.25rem 0;transition:color .15s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.25rem;font-size:.82rem;color:var(--text3);text-align:center}
.footer-bottom a{color:var(--gold)}

/* ── LISTING DETAIL ── */
.detail-hero{padding:1.75rem 0 .75rem}
.dh-inner{display:grid;grid-template-columns:1fr 340px;gap:2rem;align-items:start}
@media(max-width:760px){.dh-inner{grid-template-columns:1fr}}
.detail-gallery{border-radius:14px;overflow:hidden;background:var(--card);min-height:260px}
.detail-gallery img{width:100%;height:300px;object-fit:cover}
.detail-img-placeholder{height:260px;display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--gold)}
.detail-sidebar{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.25rem;display:flex;flex-direction:column;gap:.85rem}
.ds-title{font-size:1.3rem;font-weight:700;line-height:1.25}
.ds-cats{display:flex;gap:.35rem;flex-wrap:wrap}
.ds-cat{font-size:.76rem;padding:.25rem .6rem;border-radius:5px;border:1px solid var(--border);color:var(--cc,var(--gold))}
.ds-row{display:flex;align-items:flex-start;gap:.6rem;font-size:.86rem;color:var(--text2)}
.ds-row i{color:var(--gold);font-size:.9rem;margin-top:.1rem;flex-shrink:0}
.ds-row a{color:var(--gold)}
.detail-body{padding:1.5rem 0 3rem}
.db-grid{display:grid;grid-template-columns:1fr 340px;gap:2rem}
@media(max-width:760px){.db-grid{grid-template-columns:1fr}}
.detail-content{font-size:.9rem;color:var(--text2);line-height:1.75}
.detail-content h2,.detail-content h3{color:var(--text1);margin:1.25rem 0 .5rem;font-size:1.1rem}
.detail-content p{margin-bottom:.75rem}

/* ── SUBMIT FORM ── */
.submit-section{padding:2rem 0 4rem}
.submit-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2rem;max-width:720px;margin:0 auto}
.submit-card h1{font-size:1.5rem;font-weight:700;margin-bottom:.35rem}
.submit-card>p{color:var(--text2);font-size:.9rem;margin-bottom:1.75rem}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:.83rem;font-weight:500;color:var(--text2);margin-bottom:.35rem}
.form-group input,.form-group textarea,.form-group select{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:.65rem .85rem;color:var(--text1);font-size:.9rem;outline:none;font-family:var(--font);transition:border .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:110px}
.form-group select option{background:var(--bg2)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:540px){.form-row{grid-template-columns:1fr}}
.cat-checkboxes{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
@media(max-width:540px){.cat-checkboxes{grid-template-columns:repeat(2,1fr)}}
.cat-checkbox-item{display:flex;align-items:center;gap:.5rem;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:.45rem .65rem;cursor:pointer;transition:all .15s}
.cat-checkbox-item:has(input:checked){border-color:var(--gold);background:rgba(200,168,75,.1)}
.cat-checkbox-item input{accent-color:var(--gold);width:14px;height:14px}
.cat-checkbox-item label{font-size:.8rem;color:var(--text2);cursor:pointer}
.cat-checkbox-item:has(input:checked) label{color:var(--gold)}
.submit-btn{width:100%;background:var(--gold);color:#000;border:none;padding:.85rem;border-radius:9px;font-weight:700;font-size:1rem;cursor:pointer;margin-top:.75rem;transition:background .2s}
.submit-btn:hover{background:var(--gold2)}

/* ── STATIC PAGES ── */
.static-hero{padding:2.5rem 0 1rem;background:linear-gradient(135deg,var(--navy),var(--bg3))}
.static-hero h1{font-size:1.8rem;font-weight:700}
.static-hero p{color:var(--text2);margin-top:.5rem}
.static-body{padding:2rem 0 4rem;max-width:780px}
.static-body h2{font-size:1.15rem;font-weight:700;color:var(--text1);margin:1.5rem 0 .5rem}
.static-body p,.static-body li{font-size:.9rem;color:var(--text2);line-height:1.75}
.static-body ul{padding-left:1.2rem;margin-bottom:.75rem}

/* ── UTILS ── */
.main-wrap{padding-top:0}
main{min-height:70vh}
.breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text3);padding:.75rem 0}
.breadcrumb a{color:var(--text3)}.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{color:var(--border2)}
