
:root{
  --bg:#f7f8f5;
  --text:#1d2a24;
  --muted:#5d6c64;
  --primary:#2f7d4f;
  --primary-dark:#20563a;
  --accent:#f2c14e;
  --white:#ffffff;
  --card:#ffffff;
  --border:#dbe4dd;
  --shadow:0 12px 30px rgba(0,0,0,0.08);
  --radius:18px;
  --max:1220px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--bg);line-height:1.7}
img{max-width:100%;display:block;border-radius:14px}
a{color:var(--primary-dark);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(92%,var(--max));margin:auto}
.topbar{background:rgba(255,255,255,.96);backdrop-filter:blur(10px);position:sticky;top:0;z-index:999;border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:15px 0}
.logo{font-size:1.5rem;font-weight:800;color:var(--primary-dark);letter-spacing:.2px}
.logo span{color:var(--accent)}
.menu{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.menu a{font-weight:700;color:var(--text);font-size:.95rem}
.menu-toggle{display:none;border:0;background:var(--primary);color:#fff;padding:10px 14px;border-radius:10px;cursor:pointer}
.hero{padding:74px 0 42px}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:38px;align-items:center}
.kicker{color:var(--primary);font-weight:800;text-transform:uppercase;letter-spacing:1px;font-size:.85rem}
h1,h2,h3,h4{line-height:1.2;margin:0 0 14px}
h1{font-size:3.15rem}
h2{font-size:2.15rem}
h3{font-size:1.35rem}
p.lead{font-size:1.12rem;color:var(--muted)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.btn{display:inline-block;padding:13px 20px;border-radius:12px;font-weight:800;transition:.2s ease}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);text-decoration:none}
.btn-secondary{background:#eef6f1;color:var(--primary-dark);border:1px solid var(--border)}
.section{padding:58px 0}
.section.alt{background:#eef4f0}
.grid-2,.grid-3,.grid-4{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.card.compact{padding:18px}
.card h3,.card h4{margin-top:0}
.badge{display:inline-block;background:#e6f3eb;color:var(--primary-dark);padding:7px 10px;border-radius:999px;font-size:.85rem;font-weight:800;margin-bottom:12px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:24px}
.stat{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;text-align:center}
.stat strong{display:block;font-size:1.4rem;color:var(--primary-dark)}
.route-list{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.route-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.route-card .content{padding:22px}
.route-meta{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0 14px}
.route-meta span{background:#eef6f1;border-radius:999px;padding:7px 10px;font-size:.85rem;color:var(--primary-dark);font-weight:800}
.route-stops{margin:14px 0 0;padding-left:18px}
.route-stops li{margin-bottom:8px}
.hero-image-stack{display:grid;gap:18px}
.hero-image-stack img{box-shadow:var(--shadow)}
.image-caption{font-size:.92rem;color:var(--muted);margin-top:6px}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
th,td{border:1px solid var(--border);padding:14px;text-align:left;vertical-align:top}
th{background:#edf5f0}
.feature-list{padding-left:20px}
.feature-list li{margin-bottom:9px}
.page-hero{padding:55px 0 24px}
.page-hero h1{font-size:2.55rem}
.callout{background:#fff9e7;border:1px solid #f0df9c;padding:20px 22px;border-radius:14px}
.footer{background:#16221c;color:#d7e3db;padding:36px 0;margin-top:40px}
.footer a{color:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.small{font-size:.92rem;color:var(--muted)}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:14px;margin-bottom:14px;overflow:hidden}
.faq-question{width:100%;background:#fff;border:0;padding:18px 20px;text-align:left;font-size:1rem;font-weight:800;cursor:pointer}
.faq-answer{display:none;padding:0 20px 18px;color:var(--muted)}
.faq-item.active .faq-answer{display:block}
.breadcrumbs{font-size:.92rem;color:var(--muted);margin-bottom:10px}
.tip-box{background:#f1f7f3;border:1px solid var(--border);border-radius:16px;padding:18px}
.article{max-width:900px;margin:auto}
.article p{font-size:1.04rem}
.article h2{margin-top:34px}
.article h3{margin-top:24px}
.pullquote{font-size:1.22rem;font-weight:700;color:var(--primary-dark);border-left:5px solid var(--accent);padding:12px 0 12px 18px;background:#fff;border-radius:0 14px 14px 0}
.notice{border:1px solid var(--border);background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.anchor-list a{display:inline-block;margin:4px 8px 4px 0;padding:8px 11px;background:#eef6f1;border-radius:999px;font-weight:700}
@media (max-width:980px){
  .hero-grid,.grid-2,.grid-3,.grid-4,.route-list,.footer-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  h1{font-size:2.35rem}
  h2{font-size:1.9rem}
}
@media (max-width:760px){
  .menu{display:none;flex-direction:column;align-items:flex-start;background:#fff;padding:14px;position:absolute;right:4%;top:70px;width:min(88vw,320px);border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--border)}
  .menu.show{display:flex}
  .menu-toggle{display:block}
  .stats{grid-template-columns:1fr}
}


.stop-detail{background:#fff;border:1px solid var(--border);border-radius:18px;padding:24px;margin:22px 0;box-shadow:var(--shadow)}
.stop-detail h3{color:var(--primary-dark);margin-bottom:8px}
.stop-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px}
.stop-note{background:#f1f7f3;border:1px solid var(--border);border-radius:14px;padding:14px}
.route-plan{counter-reset:stopcounter}
.stop-detail h3:before{counter-increment:stopcounter;content:"Stop " counter(stopcounter) ": ";color:var(--accent)}
.mini-itinerary{background:#fff;border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:var(--shadow)}
@media (max-width:980px){.stop-grid{grid-template-columns:1fr}}
