/* ═══════════════════════════════════════════
   TravelReap — Design System
   Single source of truth: CSS variables, components, responsive
   ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand: #0B4F6C;
  --brand-dark: #083D54;
  --brand-light: #E8F4F8;
  --accent: #D4763C;
  --accent-light: #FFF3EB;
  --green: #1B7A4A;
  --green-light: #E6F5ED;
  --red: #C0392B;
  --red-light: #FDECEA;
  --blue: #2471A3;
  --blue-light: #EBF5FB;
  --text: #1A1A2E;
  --text-secondary: #555B6E;
  --text-muted: #8A8FA3;
  --border: #E2E4EA;
  --border-light: #F0F1F4;
  --bg: #FFFFFF;
  --bg-subtle: #F7F8FA;
  --bg-warm: #FFFCF9;
  --shadow-sm: 0 1px 3px rgba(11,79,108,0.06);
  --shadow-md: 0 4px 12px rgba(11,79,108,0.08);
  --shadow-lg: 0 8px 30px rgba(11,79,108,0.10);
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --container: 1400px;
  --font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-display: 'Fraunces', Georgia, serif;
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}
ul{list-style:none}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
@media(max-width:600px){.container{padding:0 16px}}
@media(max-width:360px){.container{padding:0 12px}}

/* ═══════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════ */
.site-header{
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:1000;
}
.header-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;height:64px;max-width:var(--container);margin:0 auto;
}
.logo{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:800;font-size:1.35rem;color:var(--brand);letter-spacing:-0.5px}
.logo-icon{width:32px;height:32px;background:var(--brand);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;font-family:var(--font-body)}
.logo span{color:var(--accent)}

.header-search{
  flex:0 1 380px;position:relative;
}
.header-search input{
  width:100%;height:40px;padding:0 40px 0 14px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  font-family:var(--font-body);font-size:0.875rem;color:var(--text);
  background:var(--bg-subtle);transition:border-color .2s,background .2s;
}
.header-search input:focus{outline:none;border-color:var(--brand);background:#fff}
.header-search input::placeholder{color:var(--text-muted)}
.header-search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}

.nav-main{display:flex;align-items:center;gap:0}
.nav-main a{
  padding:8px 13px;font-size:0.8125rem;font-weight:500;color:var(--text-secondary);
  border-radius:var(--radius-sm);transition:background .2s,color .2s;white-space:nowrap;
}
.nav-main a:hover{background:var(--bg-subtle);color:var(--brand)}
.nav-main a.nav-accent{color:var(--accent);font-weight:600}
.nav-main a.nav-accent:hover{background:var(--accent-light)}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{
  display:none;background:var(--bg);border-top:1px solid var(--border);
  padding:16px 24px 20px;
}
.mobile-nav.open{display:block}
.mobile-nav a{
  display:block;padding:10px 0;font-size:0.9375rem;font-weight:500;color:var(--text);
  border-bottom:1px solid var(--border-light);
}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav .mobile-search{margin-bottom:12px}
.mobile-nav .mobile-search input{
  width:100%;height:44px;padding:0 14px;border:1px solid var(--border);
  border-radius:var(--radius-sm);font-size:0.9375rem;font-family:var(--font-body);
  background:var(--bg-subtle);
}

/* ═══════════════════════════════════════════
   HEADER DROPDOWN MENUS (replaces old .nav-bar)
   ═══════════════════════════════════════════ */
.nav-item{position:relative}
.nav-item > a{display:flex;align-items:center;gap:4px}
.nav-item > a .caret{
  display:inline-block;width:0;height:0;
  border-left:4px solid transparent;border-right:4px solid transparent;
  border-top:4px solid currentColor;opacity:0.6;margin-top:1px;
}
.nav-dropdown{
  position:absolute;top:100%;left:0;min-width:240px;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-md);box-shadow:var(--shadow-lg);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .15s,transform .15s,visibility .15s;
  z-index:1100;
}
.nav-item:hover > .nav-dropdown,
.nav-item:focus-within > .nav-dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-dropdown a{
  display:block;padding:8px 12px;font-size:0.8125rem;font-weight:500;
  color:var(--text);border-radius:var(--radius-sm);text-transform:none;
  letter-spacing:0;line-height:1.4;
}
.nav-dropdown a:hover{background:var(--bg-subtle);color:var(--brand)}
.nav-dropdown a small{display:block;font-size:0.6875rem;color:var(--text-muted);font-weight:400;margin-top:1px}
.nav-dropdown hr{
  border:none;border-top:1px solid var(--border-light);margin:6px 0;
}
.nav-dropdown .col-2{display:grid;grid-template-columns:1fr 1fr;gap:2px;min-width:380px}
.nav-dropdown .col-2 a{font-size:0.75rem;padding:6px 10px}

/* Right-anchor for menu items near the right edge of the screen */
.nav-item.is-right > .nav-dropdown{left:auto;right:0}

/* Mobile-nav accordion sections */
.mobile-nav details{border-bottom:1px solid var(--border-light)}
.mobile-nav details > summary{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;font-size:0.9375rem;font-weight:600;color:var(--text);
  cursor:pointer;list-style:none;
}
.mobile-nav details > summary::-webkit-details-marker{display:none}
.mobile-nav details > summary::after{content:'+';color:var(--text-muted);font-size:1.125rem;font-weight:400}
.mobile-nav details[open] > summary::after{content:'−'}
.mobile-nav details ul{padding:4px 0 10px 12px;list-style:none}
.mobile-nav details ul li a{padding:8px 0;font-size:0.875rem;color:var(--text-secondary);border:none}

@media(max-width:1080px){
  .nav-main{display:none}
  .hamburger{display:flex}
  .header-search{flex:0 1 280px}
}
@media(max-width:600px){
  .header-top{padding:0 16px;height:56px}
  .header-search{display:none}
  .logo{font-size:1.2rem}
}
@media(max-width:360px){
  .header-top{padding:0 12px}
}

/* ═══════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════ */
.hero{
  background:var(--bg);
  padding:48px 0 40px;
  border-bottom:1px solid var(--border);
}
.hero-inner{display:flex;gap:48px;align-items:flex-start}
.hero-content{flex:1;min-width:0}
.hero-content h1{
  font-family:var(--font-display);font-weight:800;font-size:2.25rem;
  line-height:1.2;color:var(--text);letter-spacing:-0.5px;margin-bottom:12px;
}
.hero-content h1 em{font-style:italic;color:var(--brand)}
.hero-subtitle{font-size:1.0625rem;color:var(--text-secondary);max-width:540px;margin-bottom:28px;line-height:1.55}
.hero-stats{display:flex;gap:32px;margin-bottom:32px;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column}
.hero-stat-num{font-family:var(--font-display);font-weight:700;font-size:1.75rem;color:var(--brand);line-height:1}
.hero-stat-label{font-size:0.75rem;color:var(--text-muted);font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:0.3px}

.hero-search{flex:0 0 480px}
.search-card{
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow-md);
}
.search-card-title{font-size:0.8125rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:16px}
.search-row{display:flex;gap:10px;margin-bottom:12px}
.search-field{flex:1;display:flex;flex-direction:column;gap:4px}
.search-field label{font-size:0.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}
.search-field select,.search-field input{
  height:42px;padding:0 12px;border:1px solid var(--border);
  border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.875rem;
  color:var(--text);background:var(--bg);appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A8FA3' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.search-field input{background-image:none}
.search-field select:focus,.search-field input:focus{outline:none;border-color:var(--brand)}
.btn-search{
  width:100%;height:44px;background:var(--brand);color:#fff;border:none;
  border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.9375rem;
  font-weight:600;cursor:pointer;transition:background .2s;
}
.btn-search:hover{background:var(--brand-dark)}
.search-quick{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap}
.search-quick a{
  padding:5px 10px;font-size:0.6875rem;font-weight:500;
  background:var(--bg-subtle);border:1px solid var(--border-light);
  border-radius:20px;color:var(--text-secondary);transition:border-color .2s,color .2s;
}
.search-quick a:hover{border-color:var(--brand);color:var(--brand)}

@media(max-width:900px){
  .hero-inner{flex-direction:column;gap:28px}
  .hero-search{flex:none;width:100%}
  .hero-content h1{font-size:1.875rem}
}
@media(max-width:600px){
  .hero{padding:32px 0 28px}
  .hero-content h1{font-size:1.5rem}
  .hero-subtitle{font-size:0.9375rem}
  .hero-stats{gap:20px}
  .hero-stat-num{font-size:1.4rem}
  .search-row{flex-direction:column}
  .search-card{padding:18px}
}
@media(max-width:360px){
  .hero-content h1{font-size:1.3rem}
  .hero-stat-num{font-size:1.2rem}
}

/* ═══════════════════════════════════════════
   SECTIONS GLOBAL
   ═══════════════════════════════════════════ */
.section{padding:40px 0}
.section + .section{border-top:1px solid var(--border-light)}
.section-alt{background:var(--bg-subtle)}
.section-warm{background:var(--bg-warm)}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}
.section-header h2{
  font-family:var(--font-display);font-weight:700;font-size:1.375rem;
  color:var(--text);letter-spacing:-0.3px;line-height:1.25;
}
.section-header h2 span{color:var(--brand)}
.section-link{font-size:0.8125rem;font-weight:600;color:var(--brand);white-space:nowrap;display:flex;align-items:center;gap:4px}
.section-link:hover{color:var(--accent)}
.section-desc{font-size:0.875rem;color:var(--text-secondary);margin-top:-12px;margin-bottom:20px;max-width:680px}

@media(max-width:600px){
  .section{padding:28px 0}
  .section-header h2{font-size:1.15rem}
}

/* ═══════════════════════════════════════════
   CARD GRIDS
   ═══════════════════════════════════════════ */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .grid-4.keep-2,.grid-3.keep-2{grid-template-columns:repeat(2,1fr);gap:10px}
}
@media(max-width:360px){
  .grid-4.keep-2,.grid-3.keep-2{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════
   ROUTE CARDS
   ═══════════════════════════════════════════ */
.route-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:10px;
}
.route-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.route-card-path{display:flex;align-items:center;gap:8px}
.route-card-city{font-weight:600;font-size:0.9375rem;color:var(--text)}
.route-card-arrow{color:var(--text-muted);font-size:0.75rem;flex-shrink:0}
.route-card-meta{display:flex;gap:12px;flex-wrap:wrap}
.route-meta-item{display:flex;align-items:center;gap:4px;font-size:0.75rem;color:var(--text-secondary)}
.route-meta-item svg{flex-shrink:0}
.route-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px;border-top:1px solid var(--border-light)}
.route-price{font-family:var(--font-display);font-weight:700;font-size:1.0625rem;color:var(--brand)}
.route-badge{
  padding:3px 8px;font-size:0.625rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.5px;border-radius:4px;
}
.badge-bus{background:var(--blue-light);color:var(--blue)}
.badge-flight{background:var(--accent-light);color:var(--accent)}
.badge-train{background:var(--green-light);color:var(--green)}
.badge-ferry{background:var(--brand-light);color:var(--brand)}

/* ═══════════════════════════════════════════
   CITY CARDS
   ═══════════════════════════════════════════ */
.city-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  overflow:hidden;background:var(--bg);transition:box-shadow .2s,border-color .2s;
}
.city-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.city-card-img{
  height:130px;background:var(--bg-subtle);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.city-card-img .city-placeholder{
  font-family:var(--font-display);font-size:2rem;font-weight:700;
  color:var(--brand);opacity:0.15;
}
.city-card-body{padding:14px 16px}
.city-card-name{font-weight:700;font-size:1rem;color:var(--text);margin-bottom:4px}
.city-card-state{font-size:0.75rem;color:var(--text-muted);margin-bottom:10px}
.city-card-stats{display:flex;gap:8px;flex-wrap:wrap}
.city-stat{
  padding:3px 8px;font-size:0.625rem;font-weight:600;
  background:var(--bg-subtle);border-radius:4px;color:var(--text-secondary);
}

/* ═══════════════════════════════════════════
   VISA CARDS
   ═══════════════════════════════════════════ */
.visa-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.visa-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.visa-card-top{display:flex;align-items:center;justify-content:space-between}
.visa-card-country{font-weight:700;font-size:0.9375rem;color:var(--text)}
.visa-status{
  padding:3px 8px;font-size:0.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.3px;border-radius:4px;
}
.status-free{background:var(--green-light);color:var(--green)}
.status-required{background:var(--red-light);color:var(--red)}
.status-arrival{background:var(--accent-light);color:var(--accent)}
.status-evisa{background:var(--blue-light);color:var(--blue)}
.visa-card-info{font-size:0.8125rem;color:var(--text-secondary);line-height:1.45}
.visa-card-meta{display:flex;gap:12px;margin-top:auto;padding-top:8px;border-top:1px solid var(--border-light);font-size:0.75rem;color:var(--text-muted)}

/* ═══════════════════════════════════════════
   BOOKING CARDS
   ═══════════════════════════════════════════ */
.booking-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:10px;
}
.booking-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.booking-card-header{display:flex;align-items:center;gap:10px}
.booking-card-logo{
  width:40px;height:40px;border-radius:8px;background:var(--bg-subtle);
  display:flex;align-items:center;justify-content:center;font-weight:700;
  font-size:0.75rem;color:var(--brand);border:1px solid var(--border-light);
  flex-shrink:0;
}
.booking-card-name{font-weight:700;font-size:0.9375rem;color:var(--text)}
.booking-card-type{font-size:0.6875rem;color:var(--text-muted)}
.booking-channels{display:flex;gap:6px;flex-wrap:wrap}
.channel-tag{
  padding:3px 7px;font-size:0.625rem;font-weight:600;
  border-radius:3px;border:1px solid var(--border-light);color:var(--text-secondary);
}
.channel-tag.available{background:var(--green-light);border-color:var(--green-light);color:var(--green)}
.booking-card-cta{
  display:inline-flex;align-items:center;gap:4px;
  padding:8px 14px;background:var(--brand);color:#fff;
  border-radius:var(--radius-sm);font-size:0.8125rem;font-weight:600;
  margin-top:auto;transition:background .2s;text-align:center;justify-content:center;
}
.booking-card-cta:hover{background:var(--brand-dark);color:#fff}

/* ═══════════════════════════════════════════
   TOOL CARDS
   ═══════════════════════════════════════════ */
.tool-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:18px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.tool-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.tool-card-icon{
  width:40px;height:40px;border-radius:10px;display:flex;
  align-items:center;justify-content:center;font-size:1.1rem;
}
.tool-card-icon.icon-blue{background:var(--blue-light);color:var(--blue)}
.tool-card-icon.icon-green{background:var(--green-light);color:var(--green)}
.tool-card-icon.icon-accent{background:var(--accent-light);color:var(--accent)}
.tool-card-icon.icon-brand{background:var(--brand-light);color:var(--brand)}
.tool-card h3{font-weight:700;font-size:0.9375rem;color:var(--text)}
.tool-card p{font-size:0.8125rem;color:var(--text-secondary);line-height:1.45;flex:1}
.tool-card-link{
  font-size:0.8125rem;font-weight:600;color:var(--brand);
  display:flex;align-items:center;gap:4px;margin-top:auto;
}

/* ═══════════════════════════════════════════
   ATTRACTION / HOTEL CARDS
   ═══════════════════════════════════════════ */
.attraction-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  overflow:hidden;background:var(--bg);transition:box-shadow .2s,border-color .2s;
}
.attraction-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.attraction-card-img{
  height:110px;background:var(--bg-subtle);display:flex;
  align-items:center;justify-content:center;
}
.attraction-card-img .placeholder-icon{font-size:1.5rem;opacity:0.2}
.attraction-card-body{padding:12px 14px}
.attraction-card-name{font-weight:700;font-size:0.875rem;color:var(--text);margin-bottom:2px}
.attraction-card-loc{font-size:0.6875rem;color:var(--text-muted);margin-bottom:8px}
.attraction-card-footer{display:flex;justify-content:space-between;align-items:center}
.attraction-card-price{font-weight:700;font-size:0.8125rem;color:var(--brand)}
.attraction-card-tag{
  padding:2px 7px;font-size:0.5625rem;font-weight:700;
  text-transform:uppercase;border-radius:3px;
  background:var(--brand-light);color:var(--brand);
}

.hotel-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.hotel-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.hotel-card-name{font-weight:700;font-size:0.9375rem;color:var(--text)}
.hotel-card-loc{font-size:0.75rem;color:var(--text-muted)}
.hotel-stars{color:var(--accent);font-size:0.75rem;letter-spacing:1px}
.hotel-card-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px;border-top:1px solid var(--border-light)}
.hotel-price{font-family:var(--font-display);font-weight:700;font-size:0.9375rem;color:var(--brand)}
.hotel-price span{font-size:0.6875rem;font-weight:400;color:var(--text-muted);font-family:var(--font-body)}
.hotel-amenities{display:flex;gap:4px}
.amenity-dot{
  width:22px;height:22px;border-radius:4px;background:var(--bg-subtle);
  display:flex;align-items:center;justify-content:center;font-size:0.5625rem;
  color:var(--text-muted);border:1px solid var(--border-light);
}

/* ═══════════════════════════════════════════
   NEWS CARDS
   ═══════════════════════════════════════════ */
.news-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:6px;
}
.news-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.news-card-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.news-category{
  padding:2px 7px;font-size:0.5625rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.3px;border-radius:3px;background:var(--blue-light);color:var(--blue);
}
.news-date{font-size:0.6875rem;color:var(--text-muted)}
.news-card h3{font-weight:700;font-size:0.875rem;color:var(--text);line-height:1.35}
.news-card p{font-size:0.8125rem;color:var(--text-secondary);line-height:1.4}

/* ═══════════════════════════════════════════
   DEALS BANNER
   ═══════════════════════════════════════════ */
.deals-banner{
  background:var(--brand-light);border:1px solid #C7E3ED;border-radius:var(--radius-lg);
  padding:24px 28px;display:flex;align-items:center;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
}
.deals-banner-text h3{font-family:var(--font-display);font-weight:700;font-size:1.125rem;color:var(--brand);margin-bottom:4px}
.deals-banner-text p{font-size:0.875rem;color:var(--text-secondary)}
.btn-deals{
  padding:10px 22px;background:var(--accent);color:#fff;border-radius:var(--radius-sm);
  font-weight:600;font-size:0.875rem;white-space:nowrap;transition:background .2s;
}
.btn-deals:hover{background:#C06A34;color:#fff}

/* ═══════════════════════════════════════════
   CTA STRIP
   ═══════════════════════════════════════════ */
.cta-strip{
  background:var(--bg-warm);border-top:1px solid var(--border-light);
  border-bottom:1px solid var(--border-light);
  padding:36px 0;text-align:center;
}
.cta-strip h2{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text);margin-bottom:6px}
.cta-strip p{font-size:0.9375rem;color:var(--text-secondary);margin-bottom:20px}
.cta-tools{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.cta-tool{
  padding:10px 18px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--bg);font-size:0.8125rem;font-weight:600;color:var(--text);
  transition:border-color .2s,box-shadow .2s;display:flex;align-items:center;gap:6px;
}
.cta-tool:hover{border-color:var(--brand);box-shadow:var(--shadow-sm);color:var(--brand)}
.cta-tool svg{flex-shrink:0}

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
.site-footer{
  background:var(--bg-subtle);border-top:1px solid var(--border);
  padding:48px 0 0;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:32px;
  padding-bottom:36px;
}
.footer-brand{padding-right:24px}
.footer-brand .logo{margin-bottom:12px}
.footer-brand p{font-size:0.8125rem;color:var(--text-secondary);line-height:1.55;margin-bottom:16px}
.footer-social{display:flex;gap:8px}
.footer-social a{
  width:34px;height:34px;border-radius:8px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:0.75rem;font-weight:700;
  transition:border-color .2s,color .2s;background:var(--bg);
}
.footer-social a:hover{border-color:var(--brand);color:var(--brand)}

.footer-col h4{
  font-size:0.6875rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.8px;color:var(--text-muted);margin-bottom:14px;
}
.footer-col a{
  display:block;font-size:0.8125rem;color:var(--text-secondary);
  padding:3px 0;transition:color .2s;
}
.footer-col a:hover{color:var(--brand)}

.footer-popular{
  border-top:1px solid var(--border);padding:20px 0;
}
.footer-popular h4{
  font-size:0.6875rem;font-weight:700;text-transform:uppercase;
  letter-spacing:0.8px;color:var(--text-muted);margin-bottom:10px;
}
.footer-popular-links{display:flex;gap:8px;flex-wrap:wrap}
.footer-popular-links a{
  padding:4px 10px;font-size:0.6875rem;color:var(--text-secondary);font-weight:500;
  background:var(--bg);border:1px solid var(--border-light);border-radius:4px;
  transition:border-color .2s,color .2s;
}
.footer-popular-links a:hover{border-color:var(--brand);color:var(--brand)}

.footer-bottom{
  border-top:1px solid var(--border);padding:16px 0;
  display:flex;align-items:center;justify-content:space-between;
  font-size:0.75rem;color:var(--text-muted);flex-wrap:wrap;gap:8px;
}
.footer-bottom-links{display:flex;gap:16px}
.footer-bottom-links a{color:var(--text-muted);font-size:0.75rem}
.footer-bottom-links a:hover{color:var(--brand)}

@media(max-width:900px){
  .footer-grid{grid-template-columns:repeat(3,1fr)}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .footer-brand{grid-column:1/-1}
  .site-footer{padding:36px 0 0}
  .deals-banner{padding:18px 16px}
}
@media(max-width:360px){
  .footer-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════
   TRANSPORT COMPANY STRIP
   ═══════════════════════════════════════════ */
.company-strip{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.company-strip::-webkit-scrollbar{display:none}
.company-chip{
  display:flex;align-items:center;gap:10px;padding:10px 16px;
  border:1px solid var(--border);border-radius:var(--radius-md);
  background:var(--bg);white-space:nowrap;flex-shrink:0;
  transition:border-color .2s,box-shadow .2s;
}
.company-chip:hover{border-color:var(--brand);box-shadow:var(--shadow-sm)}
.company-chip-logo{
  width:36px;height:36px;border-radius:8px;background:var(--bg-subtle);
  display:flex;align-items:center;justify-content:center;font-weight:700;
  font-size:0.6875rem;color:var(--brand);border:1px solid var(--border-light);flex-shrink:0;
}
.company-chip-info{display:flex;flex-direction:column}
.company-chip-name{font-weight:700;font-size:0.8125rem;color:var(--text)}
.company-chip-meta{font-size:0.6875rem;color:var(--text-muted)}

/* ═══════════════════════════════════════════
   AIRPORT CARDS
   ═══════════════════════════════════════════ */
.airport-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.airport-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.airport-card-header{display:flex;align-items:center;justify-content:space-between}
.airport-card-name{font-weight:700;font-size:0.9375rem;color:var(--text)}
.airport-iata{
  padding:4px 10px;font-size:0.75rem;font-weight:800;font-family:var(--font-body);
  letter-spacing:1px;background:var(--brand-light);color:var(--brand);border-radius:4px;
}
.airport-card-loc{font-size:0.75rem;color:var(--text-muted)}
.airport-card-features{display:flex;gap:6px;flex-wrap:wrap}
.airport-feature{
  padding:3px 7px;font-size:0.625rem;font-weight:600;border-radius:3px;
  background:var(--bg-subtle);color:var(--text-secondary);
}
.airport-feature.yes{background:var(--green-light);color:var(--green)}
.airport-card-footer{display:flex;gap:8px;margin-top:auto;padding-top:8px;border-top:1px solid var(--border-light)}
.airport-card-footer a{font-size:0.75rem;font-weight:600;color:var(--brand)}

.airline-strip{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.airline-chip{
  display:flex;align-items:center;gap:8px;padding:8px 14px;
  border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);
  font-size:0.8125rem;font-weight:600;color:var(--text);
  transition:border-color .2s,box-shadow .2s;
}
.airline-chip:hover{border-color:var(--brand);box-shadow:var(--shadow-sm);color:var(--brand)}
.airline-chip-code{
  font-size:0.625rem;font-weight:800;letter-spacing:0.5px;padding:2px 6px;
  background:var(--accent-light);color:var(--accent);border-radius:3px;
}

/* ═══════════════════════════════════════════
   RELOCATION / JAPA CARDS
   ═══════════════════════════════════════════ */
.japa-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.japa-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.japa-card-header{display:flex;align-items:center;justify-content:space-between}
.japa-card-country{font-weight:700;font-size:0.9375rem;color:var(--text)}
.japa-card-flag{font-size:1.25rem}
.japa-card-desc{font-size:0.8125rem;color:var(--text-secondary);line-height:1.45}
.japa-cost-bar{display:flex;gap:4px;margin-top:2px}
.japa-cost-tier{
  flex:1;padding:6px 8px;border-radius:4px;text-align:center;
  font-size:0.625rem;font-weight:600;text-transform:uppercase;letter-spacing:0.3px;
}
.tier-budget{background:#F0FAF4;color:var(--green)}
.tier-mid{background:var(--blue-light);color:var(--blue)}
.tier-premium{background:var(--accent-light);color:var(--accent)}
.japa-cost-tier strong{display:block;font-size:0.8125rem;margin-top:2px;letter-spacing:0}
.japa-card-links{display:flex;gap:10px;margin-top:auto;padding-top:8px;border-top:1px solid var(--border-light);font-size:0.75rem}
.japa-card-links a{font-weight:600;color:var(--brand)}

/* ═══════════════════════════════════════════
   EVENT CARDS
   ═══════════════════════════════════════════ */
.event-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;gap:14px;align-items:flex-start;
}
.event-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.event-date-block{
  flex-shrink:0;width:52px;text-align:center;
  border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;
}
.event-date-month{
  background:var(--brand);color:#fff;font-size:0.5625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.8px;padding:3px 0;
}
.event-date-day{
  font-family:var(--font-display);font-weight:800;font-size:1.25rem;
  color:var(--text);padding:4px 0;
}
.event-card-body{flex:1;min-width:0}
.event-card-name{font-weight:700;font-size:0.875rem;color:var(--text);margin-bottom:2px}
.event-card-loc{font-size:0.6875rem;color:var(--text-muted);margin-bottom:6px}
.event-card-meta{display:flex;gap:8px;flex-wrap:wrap}
.event-tag{
  padding:2px 7px;font-size:0.5625rem;font-weight:700;text-transform:uppercase;
  border-radius:3px;
}
.event-tag-festival{background:#F5EEF8;color:#7D3C98}
.event-tag-annual{background:var(--green-light);color:var(--green)}
.event-tag-free{background:var(--blue-light);color:var(--blue)}
.event-tag-price{background:var(--bg-subtle);color:var(--text-secondary)}

/* ═══════════════════════════════════════════
   ROAD TRIP CARDS
   ═══════════════════════════════════════════ */
.roadtrip-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.roadtrip-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.roadtrip-card-route{
  font-weight:700;font-size:0.9375rem;color:var(--text);
  display:flex;align-items:center;gap:6px;
}
.roadtrip-card-route .rt-arrow{color:var(--accent);font-size:0.75rem}
.roadtrip-card-desc{font-size:0.8125rem;color:var(--text-secondary);line-height:1.4}
.roadtrip-meta{display:flex;gap:12px;flex-wrap:wrap}
.roadtrip-meta-item{
  display:flex;align-items:center;gap:4px;font-size:0.75rem;color:var(--text-secondary);
}
.roadtrip-card-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px;border-top:1px solid var(--border-light)}
.roadtrip-budget{font-family:var(--font-display);font-weight:700;font-size:0.9375rem;color:var(--brand)}
.roadtrip-condition{
  padding:3px 8px;font-size:0.625rem;font-weight:700;text-transform:uppercase;
  border-radius:3px;
}
.condition-good{background:var(--green-light);color:var(--green)}
.condition-fair{background:var(--accent-light);color:var(--accent)}
.condition-poor{background:var(--red-light);color:var(--red)}

/* ═══════════════════════════════════════════
   BUDGET CARDS
   ═══════════════════════════════════════════ */
.budget-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;background:var(--bg);transition:box-shadow .2s,border-color .2s;
  display:flex;flex-direction:column;gap:8px;
}
.budget-card:hover{box-shadow:var(--shadow-md);border-color:var(--brand)}
.budget-card-dest{font-weight:700;font-size:0.9375rem;color:var(--text)}
.budget-card-duration{font-size:0.75rem;color:var(--text-muted)}
.budget-tiers{display:flex;gap:6px;margin-top:2px}
.budget-tier{
  flex:1;padding:8px 6px;border-radius:var(--radius-sm);text-align:center;
  border:1px solid var(--border-light);
}
.budget-tier-label{font-size:0.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:0.3px;color:var(--text-muted)}
.budget-tier-amount{font-family:var(--font-display);font-weight:700;font-size:0.875rem;color:var(--text);margin-top:2px}
.budget-tier.highlight{border-color:var(--brand);background:var(--brand-light)}
.budget-tier.highlight .budget-tier-label{color:var(--brand)}
.budget-tier.highlight .budget-tier-amount{color:var(--brand)}

/* ═══════════════════════════════════════════
   STATE EXPLORER
   ═══════════════════════════════════════════ */
.state-grid{display:flex;flex-wrap:wrap;gap:8px}
.state-pill{
  padding:7px 14px;border:1px solid var(--border);border-radius:20px;
  font-size:0.75rem;font-weight:500;color:var(--text-secondary);background:var(--bg);
  transition:border-color .2s,color .2s,background .2s;
}
.state-pill:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}
.state-pill .state-count{
  font-size:0.625rem;font-weight:700;color:var(--text-muted);margin-left:4px;
}

/* ═══════════════════════════════════════════
   WHY TRAVELREAP STRIP
   ═══════════════════════════════════════════ */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-item{text-align:center;padding:20px 16px}
.why-item-icon{
  width:48px;height:48px;border-radius:12px;margin:0 auto 12px;
  display:flex;align-items:center;justify-content:center;font-size:1.25rem;
}
.why-item-icon.wi-blue{background:var(--blue-light)}
.why-item-icon.wi-green{background:var(--green-light)}
.why-item-icon.wi-accent{background:var(--accent-light)}
.why-item-icon.wi-brand{background:var(--brand-light)}
.why-item h3{font-size:0.875rem;font-weight:700;color:var(--text);margin-bottom:4px}
.why-item p{font-size:0.75rem;color:var(--text-secondary);line-height:1.45}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:400px){.why-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════
   EMBASSY STRIP
   ═══════════════════════════════════════════ */
.embassy-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.embassy-row::-webkit-scrollbar{display:none}
.embassy-chip{
  display:flex;align-items:center;gap:8px;padding:10px 14px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--bg);white-space:nowrap;flex-shrink:0;
  font-size:0.8125rem;font-weight:500;color:var(--text);
  transition:border-color .2s;
}
.embassy-chip:hover{border-color:var(--brand);color:var(--brand)}
.embassy-chip-flag{font-size:1.1rem}

/* Animations */
@media(prefers-reduced-motion: no-preference){
  .route-card,.city-card,.visa-card,.booking-card,.tool-card,.attraction-card,.hotel-card,.news-card,.airport-card,.japa-card,.event-card,.roadtrip-card,.budget-card,.why-item{
    opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease,box-shadow .2s,border-color .2s;
  }
  .route-card.visible,.city-card.visible,.visa-card.visible,.booking-card.visible,.tool-card.visible,.attraction-card.visible,.hotel-card.visible,.news-card.visible,.airport-card.visible,.japa-card.visible,.event-card.visible,.roadtrip-card.visible,.budget-card.visible,.why-item.visible{
    opacity:1;transform:translateY(0);
  }
}

/* ═══════════════════════════════════════════
   GENERIC PAGE / ENTITY DETAIL STYLES
   (used by inner pages: transport route, visa, hotel, etc.)
   ═══════════════════════════════════════════ */
.page-wrap{display:grid;grid-template-columns:1fr 320px;gap:32px;padding:32px 0}
@media(max-width:960px){.page-wrap{grid-template-columns:1fr}}
.page-main{min-width:0}
.page-aside{display:flex;flex-direction:column;gap:20px}

.breadcrumb{display:flex;flex-wrap:wrap;gap:6px;font-size:0.75rem;color:var(--text-muted);margin-bottom:14px}
.breadcrumb a{color:var(--text-secondary)}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb .sep{color:var(--text-muted)}

.entity-h1{font-family:var(--font-display);font-weight:800;font-size:2rem;line-height:1.2;color:var(--text);margin-bottom:6px;letter-spacing:-0.5px}
.entity-subtitle{font-size:0.9375rem;color:var(--text-secondary);margin-bottom:20px}
@media(max-width:600px){.entity-h1{font-size:1.5rem}}

.key-facts{
  border:1px solid var(--border);border-radius:var(--radius-lg);
  background:var(--bg);padding:18px 22px;margin-bottom:24px;
}
.key-facts-title{font-size:0.6875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:12px}
.key-facts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px 22px}
.key-fact{display:flex;flex-direction:column;gap:2px}
.key-fact-label{font-size:0.6875rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.4px}
.key-fact-value{font-weight:700;font-size:0.9375rem;color:var(--text)}

.content-section{margin-bottom:32px}
.content-section h2{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--text);margin-bottom:14px;letter-spacing:-0.3px}
.content-section h3{font-weight:700;font-size:1rem;color:var(--text);margin:18px 0 10px}
.content-section p{font-size:0.9375rem;color:var(--text-secondary);margin-bottom:12px;line-height:1.65}
.content-section ul,.content-section ol{padding-left:22px;margin-bottom:12px;color:var(--text-secondary)}
.content-section ul li,.content-section ol li{font-size:0.9375rem;margin-bottom:6px;line-height:1.55;list-style:revert}

.data-table{width:100%;border-collapse:collapse;font-size:0.875rem;margin:8px 0 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}
.data-table th{text-align:left;padding:10px 14px;background:var(--bg-subtle);font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.4px;color:var(--text-muted);border-bottom:1px solid var(--border)}
.data-table td{padding:12px 14px;border-bottom:1px solid var(--border-light);color:var(--text)}
.data-table tr:last-child td{border-bottom:none}
.data-table .num{font-family:var(--font-display);font-weight:700;color:var(--brand)}
@media(max-width:600px){.data-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}}

.notice{
  border:1px solid var(--border);background:var(--bg-warm);border-radius:var(--radius-md);
  padding:12px 16px;font-size:0.8125rem;color:var(--text-secondary);margin:14px 0;
  display:flex;gap:10px;align-items:flex-start;
}
.notice.warn{background:#FFFBEB;border-color:#FDE68A;color:#7C5A05}
.notice.error{background:var(--red-light);border-color:#F5C6CB;color:var(--red)}
.notice.success{background:var(--green-light);border-color:#A8D5B9;color:var(--green)}
.notice strong{display:block;margin-bottom:2px}

.faq-list{margin:8px 0}
.faq-item{
  border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);
  margin-bottom:8px;overflow:hidden;
}
.faq-item summary{
  cursor:pointer;padding:14px 18px;font-weight:600;font-size:0.9375rem;color:var(--text);
  list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.25rem;color:var(--text-muted);font-weight:400}
.faq-item[open] summary::after{content:'−'}
.faq-item-body{padding:0 18px 16px;font-size:0.875rem;color:var(--text-secondary);line-height:1.6}

.related-section h2{margin-bottom:14px}
.related-group{margin-bottom:18px}
.related-group h4{font-size:0.6875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:10px}

.btn{
  display:inline-flex;align-items:center;gap:6px;padding:10px 20px;
  background:var(--brand);color:#fff;border-radius:var(--radius-sm);
  font-weight:600;font-size:0.875rem;cursor:pointer;border:none;
  transition:background .2s,box-shadow .2s;text-decoration:none;
}
.btn:hover{background:var(--brand-dark);color:#fff}
.btn-accent{background:var(--accent)}
.btn-accent:hover{background:#C06A34}
.btn-outline{background:transparent;color:var(--brand);border:1px solid var(--brand)}
.btn-outline:hover{background:var(--brand);color:#fff}
.btn-block{display:flex;justify-content:center;width:100%}

.aside-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  background:var(--bg);padding:16px;
}
.aside-card-title{font-size:0.6875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.6px;margin-bottom:12px}
.aside-card ul{display:flex;flex-direction:column;gap:8px}
.aside-card ul a{font-size:0.875rem;color:var(--text);font-weight:500}
.aside-card ul a:hover{color:var(--brand)}

.share-row{display:flex;gap:8px;margin:12px 0 18px;flex-wrap:wrap}
.share-row a{
  padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--bg);font-size:0.75rem;font-weight:600;color:var(--text-secondary);
  transition:border-color .2s,color .2s;
}
.share-row a:hover{border-color:var(--brand);color:var(--brand)}

.last-updated{font-size:0.75rem;color:var(--text-muted);margin:24px 0 8px;font-style:italic}

.affiliate-note{
  display:inline-block;font-size:0.625rem;color:var(--text-muted);
  font-weight:500;margin-left:6px;text-transform:uppercase;letter-spacing:0.3px;
}
.affiliate-disclosure{
  font-size:0.75rem;color:var(--text-muted);background:var(--bg-subtle);
  border:1px solid var(--border-light);border-radius:var(--radius-sm);
  padding:10px 14px;margin:18px 0;line-height:1.45;
}

/* ═══════════════════════════════════════════
   TOOL CONTAINERS
   ═══════════════════════════════════════════ */
.tool-shell{
  display:grid;grid-template-columns:340px 1fr;gap:24px;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;margin:18px 0 28px;
}
.tool-controls{background:var(--bg-subtle);padding:22px;border-right:1px solid var(--border)}
.tool-output{padding:22px;min-height:280px}
.tool-controls .field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.tool-controls .field label{font-size:0.6875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}
.tool-controls .field input,.tool-controls .field select{
  height:42px;padding:0 12px;border:1px solid var(--border);
  border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.875rem;
  background:var(--bg);color:var(--text);
}
.tool-controls .field input:focus,.tool-controls .field select:focus{outline:none;border-color:var(--brand)}
.radio-group{display:flex;gap:8px}
.radio-group label{
  flex:1;padding:8px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:0.75rem;text-align:center;cursor:pointer;font-weight:600;color:var(--text-secondary);
  background:var(--bg);transition:border-color .2s,background .2s,color .2s;
}
.radio-group input{display:none}
.radio-group input:checked + label,.radio-group label.active{border-color:var(--brand);background:var(--brand-light);color:var(--brand)}
@media(max-width:780px){.tool-shell{grid-template-columns:1fr}.tool-controls{border-right:none;border-bottom:1px solid var(--border)}}

.tool-output-empty{color:var(--text-muted);font-size:0.875rem;text-align:center;padding:40px 0}
.tool-output-loading{color:var(--text-muted);font-size:0.875rem;text-align:center;padding:40px 0}

.budget-output{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
@media(max-width:600px){.budget-output{grid-template-columns:1fr}}
.budget-col{border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;background:var(--bg)}
.budget-col h4{font-size:0.6875rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.budget-col.highlight{border-color:var(--brand);background:var(--brand-light)}
.budget-col-total{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--text);margin:6px 0 10px}
.budget-col.highlight .budget-col-total{color:var(--brand)}
.budget-col ul li{display:flex;justify-content:space-between;font-size:0.8125rem;color:var(--text-secondary);padding:4px 0;border-bottom:1px solid var(--border-light)}
.budget-col ul li:last-child{border-bottom:none}

/* ═══════════════════════════════════════════
   STATUS / BADGE UTILITIES
   ═══════════════════════════════════════════ */
.status-badge{
  display:inline-block;padding:5px 12px;font-size:0.6875rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;border-radius:4px;
}
.bar-meter{display:flex;align-items:center;gap:8px;margin:4px 0}
.bar-meter-track{flex:1;height:8px;background:var(--bg-subtle);border-radius:4px;overflow:hidden}
.bar-meter-fill{height:100%;background:var(--brand);border-radius:4px;transition:width .3s}
.bar-meter-label{font-size:0.75rem;font-weight:600;color:var(--text-secondary);min-width:32px;text-align:right}

/* ═══════════════════════════════════════════
   ADMIN PANEL STYLES (minimal, distinct)
   ═══════════════════════════════════════════ */
.admin-shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr;background:var(--bg-subtle)}
.admin-sidebar{background:var(--text);color:#fff;padding:20px 0}
.admin-sidebar .logo{padding:0 20px;margin-bottom:20px;color:#fff}
.admin-sidebar .logo span{color:var(--accent)}
.admin-sidebar nav a{
  display:block;padding:10px 20px;color:#cbd5e0;font-size:0.875rem;
  font-weight:500;transition:background .2s,color .2s;
}
.admin-sidebar nav a:hover,.admin-sidebar nav a.active{background:rgba(255,255,255,0.08);color:#fff}
.admin-main{padding:24px 32px}
.admin-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}
@media(max-width:780px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{display:none}}

/* ═══════════════════════════════════════════
   FORM STYLES
   ═══════════════════════════════════════════ */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:0.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-family:var(--font-body);font-size:0.9375rem;background:var(--bg);color:var(--text);
}
.form-group textarea{min-height:140px;resize:vertical}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--brand)}
.form-error{color:var(--red);font-size:0.75rem;margin-top:4px}
.form-help{color:var(--text-muted);font-size:0.75rem;margin-top:4px}

/* ═══════════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════════ */
.pagination{display:flex;gap:6px;flex-wrap:wrap;margin:24px 0;justify-content:center}
.pagination a,.pagination span{
  padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:0.8125rem;font-weight:600;color:var(--text-secondary);background:var(--bg);
}
.pagination a:hover{border-color:var(--brand);color:var(--brand)}
.pagination .active{background:var(--brand);border-color:var(--brand);color:#fff}
.pagination .disabled{opacity:0.4}

/* Skip link / accessibility */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;background:var(--text);color:#fff;padding:8px 14px;z-index:9999}
.skip-link:focus{left:8px;top:8px}

/* Print */
@media print{
  .site-header,.site-footer,.cta-strip,.page-aside,.share-row{display:none}
  body{font-size:11pt}
  a{color:#000;text-decoration:underline}
}
