/* =========================================================
   Perfect Agra Tours — GLOBAL THEME CSS
   Paste into: Appearance -> Customize -> Additional CSS
   (single source of truth for tokens, buttons, breadcrumb, form)
   ========================================================= */

/* --- Design tokens --- */
:root{
  --navy: #0F1F3D;
  --navy-mid: #1A2F52;
  --navy-light: #243a63;
  --navy-dark: #070F1E;
  --gold: #C9A84C;
  --gold-light: #E0BD72;
  --gold-pale: #FBF6EB;
  --gold-faint: #FDFAF3;
  --cream: #F7F4EE;
  --white: #FFFFFF;
  --off-white: #F8F7F3;
  --text: #1C1C2E;
  --text-muted: #6B7080;
  --border: #E4E2DB;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.08);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.12);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.18);
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --font-head: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
  --max-w: 1200px;
  --sv: 88px;
  --nav-h: 108px;
}

/* --- Base / reset --- */
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-body); color: var(--text); background: var(--white); line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
ul { list-style: none; }
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 28px; }

/* --- Buttons --- */
.btn {
      display: inline-flex; align-items: center; gap: 7px;
      padding: 12px 24px; border-radius: var(--radius-sm);
      font-family: var(--font-body); font-size: 14px; font-weight: 600;
      cursor: pointer; transition: all 0.22s;
      border: 1.5px solid transparent; line-height: 1; white-space: nowrap;
    }
.btn-primary  { background: var(--gold); color: var(--navy); border-color: var(--gold); }
.btn-primary:hover { background: var(--gold-light); border-color: var(--gold-light); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(201,168,76,0.4); }
.btn-navy     { background: var(--navy); color: var(--white); border-color: var(--navy); }
.btn-navy:hover { background: var(--navy-light); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(26,43,74,0.35); }
.btn-outline  { background: transparent; color: var(--white); border-color: rgba(255,255,255,0.5); }
.btn-outline:hover { background: rgba(255,255,255,0.1); border-color: var(--white); }
.btn-ghost    { background: transparent; color: var(--navy); border-color: var(--navy); }
.btn-ghost:hover { background: var(--navy); color: var(--white); }
.btn-wa{background:#25D366;color:white;}
.btn-wa:hover{background:#128C7E;}

/* --- Breadcrumb --- */
#breadcrumb{background:var(--cream);padding:10px 0;border-bottom:1px solid var(--border);}
.bc-list{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);flex-wrap:wrap;list-style:none;}
.bc-list a{color:var(--text-muted);transition:color 0.2s;}
.bc-list a:hover{color:var(--gold);}
.bc-list li{display:flex;align-items:center;gap:6px;}
.bc-list li:last-child span{color:var(--navy);font-weight:500;}
.bc-sep{opacity:0.5;}

/* --- Enquiry form (rendered by [pat_lead_form]) --- */
.form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);padding:40px;box-shadow:var(--shadow-md);}
.form-divider{text-align:center;font-size:13px;color:var(--text-muted);margin:16px 0;position:relative;}
.form-divider span{background:var(--white);padding:0 12px;position:relative;}
.form-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border);}
.form-group{margin-bottom:16px;}
.form-group input,
    .form-group select,
    .form-group textarea {
      width: 100%; padding: 11px 14px;
      border: 1.5px solid var(--border); border-radius: var(--radius-sm);
      font-family: var(--font-body); font-size: 14px; color: var(--text);
      background: var(--white); transition: border-color 0.2s; outline: none;
    }
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--white);transition:border-color 0.2s;outline:none;resize:none;}
.form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus { border-color: var(--gold); }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);}
.form-group label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px;}
.form-group textarea{min-height:110px;}
.form-header{margin-bottom:28px;}
.form-note{text-align:center;font-size:12px;color:var(--text-muted);margin-top:12px;line-height:1.5;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-sub{font-size:14px;color:var(--text-muted);font-weight:300;}
.form-submit{width:100%;padding:14px;background:var(--navy);color:white;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:15px;font-weight:600;cursor:pointer;transition:all 0.22s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px;}
.form-submit:hover{background:var(--gold);color:var(--navy);transform:translateY(-1px);}
.form-success{display:none;text-align:center;padding:40px 20px;}
.form-success h3{font-family:var(--font-head);font-size:26px;font-weight:700;color:var(--navy);margin-bottom:8px;}
.form-success p{font-size:14px;color:var(--text-muted);font-weight:300;line-height:1.6;}
.form-success-icon{width:64px;height:64px;background:#E8F8EE;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px;color:#2D6A4F;}
.form-success.show{display:block;}
.form-title{font-family:var(--font-head);font-size:30px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.form-wa-btn{width:100%;padding:13px;background:#25D366;color:white;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all 0.22s;}
.form-wa-btn:hover{background:#128C7E;}
.pat-msg{margin:10px 0 0;font-weight:600;font-size:14px;}
/* --- Site header & footer (rendered by perfect-agra-leads) --- */
#site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;}
.nav-top-bar{background:var(--navy);padding:8px 0;font-size:13px;color:rgba(255,255,255,0.8);}
.nav-top-bar .container{display:flex;align-items:center;justify-content:space-between;}
.nav-top-bar a{color:rgba(255,255,255,0.8);gap:6px;transition:color 0.2s;display:flex;align-items:center;}
.nav-top-bar a:hover{color:var(--gold-light);}
.nav-top-links{display:flex;gap:24px;}
.nav-main{background:rgba(255,255,255,0.97);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--border);}
.nav-main .container{display:flex;align-items:center;justify-content:space-between;height:72px;}
.nav-logo img{height:50px;width:auto;}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links>li{position:relative;}
.nav-links>li>a{display:block;padding:8px 13px;font-size:14px;font-weight:500;color:var(--navy);border-radius:var(--radius-sm);transition:all 0.2s;}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--gold);background:var(--gold-pale);}
.nav-dropdown{display:none;position:absolute;top:calc(100% + 8px);left:0;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:240px;padding:8px 0;z-index:100;}
.nav-links>li:hover .nav-dropdown{display:block;}
.nav-dropdown a{display:block;padding:10px 20px;font-size:13px;color:var(--text);transition:all 0.2s;}
.nav-dropdown a:hover,.nav-dropdown a.active{color:var(--gold);background:var(--gold-pale);padding-left:24px;}
.nav-cta{display:flex;align-items:center;gap:10px;}
.nav-wa{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#25D366;color:white;border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:all 0.2s;}
.nav-wa:hover{background:#128C7E;transform:translateY(-1px);}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;}
.nav-mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:1099;}
.nav-mobile-overlay.open{display:block;}
.nav-mobile-menu{position:fixed;top:0;right:0;bottom:0;width:300px;background:var(--white);z-index:1100;padding:80px 24px 40px;overflow-y:auto;transform:translateX(100%);transition:transform 0.3s;box-shadow:-8px 0 40px rgba(0,0,0,0.2);}
.nav-mobile-menu.open{transform:translateX(0);}
.nav-mobile-close{position:absolute;top:20px;right:20px;width:36px;height:36px;background:var(--off-white);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:18px;color:var(--navy);display:flex;align-items:center;justify-content:center;}
.nav-mob-links{display:flex;flex-direction:column;gap:2px;}
.nav-mob-links a{display:block;padding:11px 14px;font-size:15px;font-weight:500;color:var(--navy);border-radius:var(--radius-sm);transition:all 0.2s;}
.nav-mob-links a:hover{background:var(--gold-pale);color:var(--gold);}
.mob-section{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);padding:14px 14px 4px;}
.nav-mob-cta{margin-top:20px;display:flex;flex-direction:column;gap:10px;}
.nav-mob-cta .btn{justify-content:center;}
#footer{background:var(--navy-dark);padding:60px 0 28px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px;}
.footer-brand img{height:44px;width:auto;margin-bottom:14px;filter:brightness(0) invert(1);opacity:0.85;}
.footer-brand p{font-size:13px;color:rgba(255,255,255,0.45);line-height:1.7;margin-bottom:14px;font-weight:300;}
.footer-iato{font-size:12px;color:var(--gold);font-weight:600;}
.footer-h{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--white);margin-bottom:18px;}
.footer-links li{margin-bottom:9px;}
.footer-links a{font-size:13px;color:rgba(255,255,255,0.4);transition:all 0.2s;display:flex;align-items:center;gap:4px;font-weight:300;}
.footer-links a:hover{color:var(--gold-light);padding-left:4px;}
.footer-contact-row{display:flex;gap:8px;margin-bottom:12px;}
.footer-contact-row a,.footer-contact-row span:last-child{font-size:13px;color:rgba(255,255,255,0.4);transition:color 0.2s;line-height:1.5;font-weight:300;}
.footer-contact-row a:hover{color:var(--gold-light);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding-top:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.28);font-weight:300;}
.footer-social{display:flex;gap:8px;}
@media(max-width:1024px){.tour-layout{grid-template-columns:1fr;}.tour-sidebar{position:static;}.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
      .nav-links,.nav-cta .btn-navy{display:none;}.nav-toggle{display:flex;}.nav-top-links{display:none;}
      .inc-exc-grid{grid-template-columns:1fr;}.related-grid{grid-template-columns:1fr;}.pe-factors{grid-template-columns:1fr;}
      .qs-strip{grid-template-columns:repeat(2,1fr);}.qs-item:nth-child(2){border-right:none;}.qs-item:nth-child(3){border-right:1px solid var(--border);}
      .fcta-inner{flex-direction:column;text-align:center;}.fcta-btns{justify-content:center;}
      .footer-grid{grid-template-columns:1fr;gap:24px;}.footer-bottom{flex-direction:column;text-align:center;}
      .fleet-grid{grid-template-columns:1fr 1fr!important;}
      .hero-thumbs{display:none;}.tour-sidebar{display:none;}.mobile-booking-insert{display:block;}
      .bw-row{grid-template-columns:1fr;}
    }
#site-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; }
.nav-top-bar {
      background: var(--navy); padding: 8px 0;
      font-size: 13px; color: rgba(255,255,255,0.8);
    }
.nav-top-bar .container { display: flex; align-items: center; justify-content: space-between; }
.nav-top-bar a { color: rgba(255,255,255,0.8); display: flex; align-items: center; gap: 6px; transition: color 0.2s; }
.nav-top-bar a:hover { color: var(--gold-light); }
.nav-top-links { display: flex; gap: 24px; }
.nav-main {
      background: rgba(255,255,255,0.97);
      backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
      box-shadow: 0 1px 0 var(--border);
    }
.nav-main .container { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.nav-logo img { height: 50px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 2px; }
.nav-links > li { position: relative; }
.nav-links > li > a {
      display: block; padding: 8px 13px;
      font-size: 14px; font-weight: 500; color: var(--navy);
      border-radius: var(--radius-sm); transition: all 0.2s;
    }
.nav-links > li > a:hover { color: var(--gold); background: var(--gold-pale); }
.nav-dropdown {
      display: none; position: absolute; top: calc(100% + 8px); left: 0;
      background: var(--white); border: 1px solid var(--border);
      border-radius: var(--radius-md); box-shadow: var(--shadow-md);
      min-width: 220px; padding: 8px 0; z-index: 100;
    }
.nav-links > li:hover .nav-dropdown { display: block; }
.nav-dropdown a { display: block; padding: 10px 20px; font-size: 13px; color: var(--text); transition: all 0.2s; }
.nav-dropdown a:hover { color: var(--gold); background: var(--gold-pale); padding-left: 24px; }
.nav-cta { display: flex; align-items: center; gap: 10px; }
.nav-wa {
      display: flex; align-items: center; gap: 6px;
      padding: 8px 14px; background: #25D366; color: white;
      border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; transition: all 0.2s;
    }
.nav-wa:hover { background: #128C7E; transform: translateY(-1px); }
.nav-toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; background: none; border: none; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--navy); border-radius: 2px; }
.nav-mobile-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 1099; }
.nav-mobile-overlay.open { display: block; }
.nav-mobile-menu {
      position: fixed; top: 0; right: 0; bottom: 0; width: 300px;
      background: var(--white); z-index: 1100;
      padding: 80px 24px 40px; overflow-y: auto;
      transform: translateX(100%); transition: transform 0.3s ease;
      box-shadow: -8px 0 40px rgba(0,0,0,0.2);
    }
.nav-mobile-menu.open { transform: translateX(0); }
.nav-mobile-close {
      position: absolute; top: 20px; right: 20px;
      width: 36px; height: 36px; background: var(--off-white);
      border: none; border-radius: var(--radius-sm);
      cursor: pointer; font-size: 18px; color: var(--navy);
      display: flex; align-items: center; justify-content: center;
    }
.nav-mob-links { display: flex; flex-direction: column; gap: 2px; }
.nav-mob-links a { display: block; padding: 11px 14px; font-size: 15px; font-weight: 500; color: var(--navy); border-radius: var(--radius-sm); transition: all 0.2s; }
.nav-mob-links a:hover { background: var(--gold-pale); color: var(--gold); }
.mob-section { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); padding: 14px 14px 4px; }
.nav-mob-cta { margin-top: 20px; display: flex; flex-direction: column; gap: 10px; }
.nav-mob-cta .btn { justify-content: center; }
#footer-cta {
      padding: var(--sv) 0;
      background: linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 100%);
      position: relative; overflow: hidden;
    }
#footer-cta::before {
      content: ''; position: absolute; top: -100px; right: -100px;
      width: 400px; height: 400px;
      background: radial-gradient(circle, rgba(201,168,76,0.1) 0%, transparent 70%);
    }
#footer { background: var(--navy-dark); padding: 64px 0 32px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer-brand img { height: 46px; width: auto; margin-bottom: 16px; filter: brightness(0) invert(1); opacity: 0.85; }
.footer-brand p { font-size: 14px; color: rgba(255,255,255,0.5); line-height: 1.7; margin-bottom: 16px; font-weight: 300; }
.footer-iato { font-size: 12px; color: var(--gold); font-weight: 600; }
.footer-h { font-family: var(--font-head); font-size: 16px; font-weight: 600; color: var(--white); margin-bottom: 20px; }
.footer-links li { margin-bottom: 10px; }
.footer-links a { font-size: 14px; color: rgba(255,255,255,0.45); transition: all 0.2s; display: flex; align-items: center; gap: 5px; font-weight: 300; }
.footer-links a:hover { color: var(--gold-light); padding-left: 4px; }
.footer-contact-row { display: flex; gap: 10px; margin-bottom: 14px; }
.footer-contact-row span:first-child { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
.footer-contact-row a,
    .footer-contact-row span:last-child { font-size: 14px; color: rgba(255,255,255,0.45); transition: color 0.2s; line-height: 1.5; font-weight: 300; }
.footer-contact-row a:hover { color: var(--gold-light); }
.footer-bottom {
      border-top: 1px solid rgba(255,255,255,0.08); padding-top: 28px;
      display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
    }
.footer-bottom p { font-size: 13px; color: rgba(255,255,255,0.3); font-weight: 300; }
.footer-social { display: flex; gap: 10px; }
@media (max-width: 1024px) {
      .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
      .rt-layout { gap: 40px; }
      .why-layout { gap: 40px; }
    }
@media (max-width: 768px) {
      :root { --sv: 64px; }
      .nav-links, .nav-cta .btn-navy { display: none; }
      .nav-toggle { display: flex; }
      .nav-top-links { display: none; }
      .tours-grid, .testi-grid, .dest-grid { grid-template-columns: 1fr; }
      .steps-grid { grid-template-columns: 1fr; gap: 40px; }
      .steps-grid::before { display: none; }
      .trust-strip { grid-template-columns: repeat(2,1fr); }
      .tstat { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); }
      .tstat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.07); }
      .tstat:nth-last-child(-n+2) { border-bottom: none; }
      .why-layout { grid-template-columns: 1fr; }
      .why-img-col { display: none; }
      .why-grid { grid-template-columns: 1fr; }
      .rt-layout, .faq-layout { grid-template-columns: 1fr; }
      .fcta-layout { grid-template-columns: 1fr; gap: 40px; }
      .footer-grid { grid-template-columns: 1fr; gap: 28px; }
      .footer-bottom { flex-direction: column; text-align: center; }
      .hero-ctas { flex-direction: column; }
      .hero-ctas .btn { justify-content: center; }
      .form-row { grid-template-columns: 1fr; }
    }
.nav-top-bar a{color:rgba(255,255,255,0.8);transition:color 0.2s;display:flex;align-items:center;gap:6px;}
.nav-dropdown a:hover{color:var(--gold);background:var(--gold-pale);padding-left:24px;}
.nav-wa:hover{background:#128C7E;}
.footer-links a{font-size:13px;color:rgba(255,255,255,0.4);transition:all 0.2s;font-weight:300;}
.footer-links a:hover{color:var(--gold-light);}
.footer-contact-row a,.footer-contact-row span:last-child{font-size:13px;color:rgba(255,255,255,0.4);font-weight:300;}
@media(max-width:1024px){.contact-layout{grid-template-columns:1fr;}.map-layout{grid-template-columns:1fr;}.map-embed{height:320px;}.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){.nav-links,.nav-cta .btn-navy{display:none;}.nav-toggle{display:flex;}.nav-top-links{display:none;}.form-row{grid-template-columns:1fr;}.channels-grid{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr;gap:24px;}.footer-bottom{flex-direction:column;text-align:center;}}

/* --- Header/footer specificity guards (win over theme base styles) --- */
#site-nav ul, #site-nav li, #site-nav .nav-links, #site-nav .nav-dropdown,
#footer ul, #footer li { list-style: none !important; margin: 0; padding: 0; }
#site-nav .nav-links { display: flex; align-items: center; }
#site-nav .nav-links > li { position: relative; display: block; }
#site-nav .nav-links > li > a, #site-nav .nav-dropdown a { white-space: nowrap !important; }
#site-nav .nav-main .container { max-width: 1280px; }
#footer .footer-links li { margin-bottom: 8px; }

/* --- Pages render full-width like the header/footer (remove Kadence content inset) --- */
.page .entry-content-wrap, .home .entry-content-wrap { padding-left: 0; padding-right: 0; }

/* --- Dropdown polish: smooth fade + hover bridge (no gap flicker) --- */
#site-nav .nav-dropdown{ display:block; top:100%; left:0; margin-top:8px; min-width:240px; padding:8px 0;
  opacity:0; visibility:hidden; transform:translateY(8px); pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease; z-index:1001; }
#site-nav .nav-links > li:hover > .nav-dropdown{ opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; }
#site-nav .nav-dropdown::before{ content:""; position:absolute; top:-10px; left:0; right:0; height:12px; }
#site-nav .nav-dropdown a{ display:block; padding:9px 18px; font-size:13.5px; line-height:1.35; color:var(--navy); white-space:nowrap; transition:background .15s ease, color .15s ease; }
#site-nav .nav-dropdown a:hover{ background:var(--gold-pale); color:var(--gold); }

/* ---- v1.2.4: homepage full-width + footer gap ---- */
/* Widen content sections on the homepage (less boxed); footer container untouched */
body.home .entry-content-wrap .container{ max-width: 1440px; }
/* Remove the white band between last section and the footer */
.page .entry-content-wrap, .home .entry-content-wrap{ padding-bottom: 0 !important; }

/* ---- v1.2.5: heading top-margin + responsive nav ---- */
/* Kadence injects ~1.5em top-margin on content headings; the pages' own *{margin:0}
   reset loses on specificity, creating a big gap under each eyebrow. Restore zero. */
.entry-content-wrap h1, .entry-content-wrap h2, .entry-content-wrap h3,
.entry-content-wrap h4, .entry-content-wrap h5, .entry-content-wrap h6 { margin-top: 0; }
/* Burger nav on tablet/phone. ID-scoped + !important so it beats #site-nav .nav-links{display:flex}. */
@media (max-width: 1024px){
  #site-nav .nav-links, #site-nav .nav-cta, #site-nav .nav-top-links { display: none !important; }
  #site-nav .nav-toggle { display: flex !important; }
}

/* ===================== v1.2.6: hub / reviews / legal pages ===================== */
/* ---- Hub / category landing ---- */
.hub-hero{ background:var(--navy); color:var(--white); padding:calc(var(--nav-h) + 48px) 0 56px; position:relative; overflow:hidden; }
.hub-hero::before{ content:""; position:absolute; top:-140px; right:-120px; width:520px; height:520px; background:radial-gradient(circle,rgba(201,168,76,0.10) 0%,transparent 70%); pointer-events:none; }
.hub-hero .container{ position:relative; z-index:1; }
.hub-hero .bc-list{ color:rgba(255,255,255,0.5); margin-bottom:18px; }
.hub-hero .bc-list a{ color:rgba(255,255,255,0.5); }
.hub-hero .bc-list a:hover{ color:var(--gold-light); }
.hub-hero .bc-list li:last-child span{ color:rgba(255,255,255,0.8); }
.hub-hero .section-label{ color:var(--gold); }
.hub-hero h1{ font-family:var(--font-head); font-size:clamp(34px,4.4vw,56px); font-weight:700; line-height:1.1; color:var(--white); margin:0 0 16px; letter-spacing:-0.01em; }
.hub-lead{ max-width:700px; font-size:17px; line-height:1.7; color:rgba(255,255,255,0.72); }
.hub-stats{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; }
.hub-chip{ display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12); border-radius:100px; padding:7px 16px; font-size:13px; color:rgba(255,255,255,0.85); }
.hub-chip b{ color:var(--gold-light); font-weight:600; }
.hub-grid-sec{ padding:var(--sv) 0; background:var(--cream); }
.hub-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.hub-card{ display:flex; flex-direction:column; background:var(--white); border:1px solid var(--border); border-radius:var(--radius-md); overflow:hidden; text-decoration:none; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.hub-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(201,168,76,0.4); }
.hub-card-img{ position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--off-white); }
.hub-card-img img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.hub-card:hover .hub-card-img img{ transform:scale(1.05); }
.hub-card-dur{ position:absolute; top:12px; left:12px; background:rgba(15,31,61,0.92); color:#fff; font-size:12px; font-weight:600; letter-spacing:.5px; padding:5px 12px; border-radius:100px; }
.hub-card-body{ display:flex; flex-direction:column; flex:1; padding:22px 22px 24px; }
.hub-card-body h3{ font-family:var(--font-head); font-size:23px; font-weight:700; color:var(--navy); line-height:1.2; margin:0 0 10px; }
.hub-card-body p{ font-size:14px; line-height:1.6; color:var(--text-muted); flex:1; margin:0 0 18px; }
.hub-card-cta{ font-size:13px; font-weight:600; letter-spacing:.3px; color:var(--gold); }
/* ---- CTA band (hubs + others) ---- */
.hub-cta{ padding:var(--sv) 0; background:var(--navy-dark); color:#fff; }
.hub-cta .container{ max-width:680px; text-align:center; }
.hub-cta .section-label{ color:var(--gold); }
.hub-cta h2{ font-family:var(--font-head); font-size:clamp(28px,3.4vw,42px); color:#fff; margin:0 0 14px; }
.hub-cta > .container > p{ color:rgba(255,255,255,0.7); margin:0 auto 30px; font-size:16px; max-width:560px; }
.hub-cta .form-card{ text-align:left; max-width:640px; margin:0 auto; }
/* ---- Reviews ---- */
.rev-sec{ padding:var(--sv) 0; background:var(--white); }
.rev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rev-card{ display:flex; flex-direction:column; background:var(--white); border:1px solid var(--border); border-radius:var(--radius-md); padding:28px 26px; }
.rev-stars{ color:var(--gold); font-size:15px; letter-spacing:1px; margin-bottom:14px; }
.rev-quote{ font-family:var(--font-head); font-size:17px; font-style:italic; line-height:1.7; color:var(--text); flex:1; margin:0 0 20px; }
.rev-author{ display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid var(--border); }
.rev-avatar{ width:42px; height:42px; border-radius:50%; background:var(--navy); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-family:var(--font-head); font-size:18px; flex-shrink:0; }
.rev-name{ font-weight:600; font-size:14px; color:var(--navy); }
.rev-src{ font-size:12px; color:var(--text-muted); }
.rev-videos{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.rev-vid{ position:relative; display:block; aspect-ratio:16/9; border-radius:var(--radius-md); overflow:hidden; background:var(--navy); }
.rev-vid img{ width:100%; height:100%; object-fit:cover; opacity:.85; transition:opacity .2s; }
.rev-vid:hover img{ opacity:1; }
.rev-vid::after{ content:"\25B6"; position:absolute; inset:0; margin:auto; width:46px; height:46px; background:rgba(201,168,76,0.95); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:16px; }
/* ---- Legal / prose ---- */
.prose-hero{ background:var(--navy); color:#fff; padding:calc(var(--nav-h) + 40px) 0 44px; }
.prose-hero h1{ font-family:var(--font-head); font-size:clamp(32px,4vw,48px); color:#fff; margin:0; }
.prose-hero p{ color:rgba(255,255,255,0.55); margin-top:10px; font-size:14px; }
.prose-sec{ padding:var(--sv) 0; background:var(--white); }
.prose-body{ max-width:780px; }
.prose-body h2{ font-family:var(--font-head); font-size:26px; color:var(--navy); margin:34px 0 12px; }
.prose-body h2:first-child{ margin-top:0; }
.prose-body p, .prose-body li{ font-size:15.5px; line-height:1.75; color:var(--text); }
.prose-body p{ margin-bottom:16px; }
.prose-body ul{ margin:0 0 16px 20px; }
.prose-body li{ margin-bottom:8px; }
.prose-body a{ color:var(--gold); text-decoration:underline; }
.prose-body strong{ color:var(--navy); }
@media (max-width:1024px){ .hub-grid, .rev-grid{ grid-template-columns:repeat(2,1fr); } .rev-videos{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .hub-grid, .rev-grid, .rev-videos{ grid-template-columns:1fr; } }

/* ---- shared section eyebrow + title (promoted from homepage so all pages can use them) ---- */
.section-label{ font-family:var(--font-body); font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:12px; }
.section-title{ font-family:var(--font-head); font-size:clamp(30px,4vw,48px); font-weight:700; color:var(--navy); line-height:1.15; margin-bottom:14px; letter-spacing:-0.01em; }
.section-title.light{ color:var(--white); }
.section-desc{ font-size:16px; line-height:1.7; color:var(--text-muted); max-width:640px; }
