/* ====================================================
   ลักมีทัวร์ — เช่ารถบัส/รถตู้ VIP
   Kawaii Pastel × Navy + Gold + White
==================================================== */

:root{
  --navy-900:#0b2540;
  --navy-800:#13335e;
  --navy-700:#1d4a86;
  --navy-600:#2a5fa8;
  --navy-500:#4a7bc7;
  --blue-100:#dbe7f6;
  --blue-50:#eaf2fb;
  --gold-700:#a37214;
  --gold-600:#c8932c;
  --gold-500:#e0b34a;
  --gold-400:#f2c969;
  --gold-100:#fbeec9;
  --gold-50:#fff7e0;
  --white:#ffffff;
  --bg:#f4f8ff;
  --text:#16243b;
  --muted:#5b6b85;
  --line:#dee7f3;
  --shadow:0 8px 24px rgba(15,42,84,.08);
  --shadow-lg:0 14px 38px rgba(15,42,84,.14);
  --radius:18px;
  --radius-lg:26px;
  --radius-pill:999px;
  --font:'Sarabun','Prompt',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
}

/* blob พื้นหลังนุ่มๆ */
body::before, body::after{
  content:'';
  position:fixed;
  border-radius:50%;
  filter:blur(80px);
  opacity:.55;
  z-index:-1;
  pointer-events:none;
}
body::before{
  width:520px; height:520px;
  background:radial-gradient(circle,#dfeaff 0%,transparent 70%);
  top:-120px; right:-120px;
}
body::after{
  width:460px; height:460px;
  background:radial-gradient(circle,#ffeec5 0%,transparent 70%);
  bottom:-100px; left:-140px;
}

img{max-width:100%;display:block;height:auto}
a{color:var(--navy-700);text-decoration:none;transition:.2s}
a:hover{color:var(--gold-600)}

.container{max-width:1200px;margin:0 auto;padding:0 18px}

/* ===== TOP BAR ===== */
.topbar{
  background:linear-gradient(90deg,var(--navy-900),var(--navy-700));
  color:#fff;
  font-size:13.5px;
  padding:8px 0;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.topbar a{color:var(--gold-400);font-weight:600}
.topbar a:hover{color:var(--gold-100)}
.topbar .quick{display:flex;gap:14px;flex-wrap:wrap}

/* ===== HEADER ===== */
.header{
  background:#fff;
  border-bottom:3px solid var(--gold-400);
  position:sticky;top:0;z-index:90;
  box-shadow:0 2px 18px rgba(15,42,84,.06);
}
.header .container{display:flex;align-items:center;justify-content:space-between;padding-top:12px;padding-bottom:12px;gap:18px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:12px}
.logo img{width:56px;height:56px;object-fit:contain;background:linear-gradient(135deg,#fff,var(--blue-50));border-radius:14px;padding:6px;border:2px solid var(--gold-300,#f5d98a)}
.brand{font-weight:800;font-size:20px;line-height:1.1;color:var(--navy-900);display:flex;flex-direction:column}
.brand small{display:block;font-size:11.5px;color:var(--gold-600);font-weight:600;margin-top:2px}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.nav a{
  padding:8px 14px;
  border-radius:var(--radius-pill);
  color:var(--navy-800);
  font-weight:600;
  font-size:14.5px;
}
.nav a:hover{background:var(--blue-50);color:var(--navy-900)}

/* ===== BREADCRUMB ===== */
.breadcrumb{background:var(--blue-50);padding:11px 0;font-size:13.5px;color:var(--muted);border-bottom:1px dashed var(--line)}
.breadcrumb a{color:var(--navy-700);font-weight:600}
.breadcrumb span{margin:0 7px;color:var(--gold-500)}

/* ===== HERO ===== */
.hero{
  position:relative;
  padding:54px 0 64px;
  background:
    radial-gradient(circle at 10% 10%, #fff7e0 0, transparent 40%),
    radial-gradient(circle at 90% 90%, #e1eafa 0, transparent 45%),
    linear-gradient(135deg, #f0f6ff 0%, #ffffff 100%);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;border:2px dashed var(--gold-400);
  color:var(--navy-800);
  padding:5px 12px;border-radius:var(--radius-pill);
  font-size:12.5px;font-weight:600;
}
.hero h1{
  font-size:42px;line-height:1.18;font-weight:800;color:var(--navy-900);
  margin-bottom:14px;
}
.hero h1 span{
  background:linear-gradient(135deg,var(--gold-600),var(--gold-400));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p{color:var(--muted);font-size:17px;margin-bottom:22px;max-width:560px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;border-radius:var(--radius-pill);
  font-weight:700;font-size:15.5px;
  transition:.25s;border:none;cursor:pointer;
  box-shadow:var(--shadow);
}
.btn-call{background:linear-gradient(135deg,var(--gold-600),var(--gold-400));color:#fff}
.btn-call:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:#fff;filter:brightness(1.05)}
.btn-line{background:linear-gradient(135deg,#00b900,#06c755);color:#fff}
.btn-line:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:#fff}
.btn-outline{background:#fff;color:var(--navy-700);border:2px solid var(--navy-700)}
.btn-outline:hover{background:var(--navy-700);color:#fff}

.hero-img{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  border:5px solid #fff;
  transform:rotate(-1.5deg);
  transition:.4s;
}
.hero-img:hover{transform:rotate(0)}
.hero-img img{width:100%;height:380px;object-fit:cover}
.hero-img::after{
  content:'🚌';position:absolute;bottom:-20px;right:-10px;
  font-size:60px;animation:wiggle 3s ease-in-out infinite;
}
@keyframes wiggle{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}

/* ===== SECTIONS ===== */
section{padding:60px 0;position:relative}
.bg-soft{background:linear-gradient(180deg,#fff 0%, #f4f8ff 100%)}
.bg-navy{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff}
.bg-navy h2,.bg-navy h3{color:#fff}
.bg-navy p{color:#dbe7f6}

.section-title{text-align:center;max-width:780px;margin:0 auto 40px}
.eyebrow{
  display:inline-block;
  background:var(--gold-50);
  color:var(--gold-700);
  padding:5px 16px;border-radius:var(--radius-pill);
  font-size:13px;font-weight:700;letter-spacing:.5px;
  margin-bottom:10px;border:1.5px dashed var(--gold-500);
}
.section-title h2{
  font-size:32px;font-weight:800;color:var(--navy-900);
  margin-bottom:10px;line-height:1.25;
}
.section-title p{color:var(--muted);font-size:16px}

/* wave divider */
.wave-divider{
  display:block;width:100%;height:60px;
}

/* ===== STATS ===== */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
.stat-card{
  background:#fff;border-radius:var(--radius);padding:18px 14px;text-align:center;
  border:2px dashed var(--blue-100);
  transition:.3s;
}
.stat-card:hover{transform:translateY(-4px);border-color:var(--gold-400);border-style:solid}
.stat-card .num{font-size:30px;font-weight:800;color:var(--navy-700);line-height:1}
.stat-card .lbl{font-size:13px;color:var(--muted);margin-top:6px}

/* ===== SERVICES (circle cards) ===== */
.services-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;
}
.service-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);
  transition:.35s;
  border:2px solid transparent;
  position:relative;
}
.service-card:nth-child(3n+1){border-color:var(--blue-100)}
.service-card:nth-child(3n+2){border-color:var(--gold-100)}
.service-card:nth-child(3n+3){border-color:#d8edd5}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--gold-400)}
.service-card .img-wrap{
  width:130px;height:130px;border-radius:50%;
  overflow:hidden;margin:22px auto 14px;
  border:4px solid #fff;
  box-shadow:var(--shadow);
  background:var(--blue-50);
}
.service-card .img-wrap img{width:100%;height:100%;object-fit:cover}
.service-card .body{padding:0 20px 22px;text-align:center}
.service-card h3{font-size:18px;font-weight:700;color:var(--navy-900);margin-bottom:8px}
.service-card p{color:var(--muted);font-size:14px;margin-bottom:12px}
.service-card .tag{
  display:inline-block;background:linear-gradient(135deg,var(--gold-100),var(--gold-50));
  color:var(--gold-700);
  padding:3px 12px;border-radius:var(--radius-pill);
  font-size:12.5px;font-weight:700;
  border:1px dashed var(--gold-500);
}

/* ===== FLEET (รถบัส/รถตู้ types) ===== */
.fleet-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.fleet-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);transition:.35s;
  border:2px solid var(--blue-100);
  display:flex;flex-direction:column;
}
.fleet-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold-400)}
.fleet-card .img-wrap{
  height:200px;overflow:hidden;position:relative;background:var(--blue-50);
}
.fleet-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:.4s}
.fleet-card:hover .img-wrap img{transform:scale(1.05)}
.fleet-card .badge-corner{
  position:absolute;top:12px;left:12px;
  background:linear-gradient(135deg,var(--gold-600),var(--gold-400));
  color:#fff;padding:5px 12px;border-radius:var(--radius-pill);
  font-size:12px;font-weight:700;
}
.fleet-card .body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column}
.fleet-card h3{font-size:19px;font-weight:700;color:var(--navy-900);margin-bottom:8px}
.fleet-card p{color:var(--muted);font-size:14px;margin-bottom:12px;flex:1}
.fleet-card .specs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.fleet-card .spec{
  background:var(--blue-50);color:var(--navy-700);
  font-size:12px;padding:3px 10px;border-radius:var(--radius-pill);font-weight:600;
}

/* ===== USECASES (กรณีใช้งาน) ===== */
.usecases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.usecase-card{
  background:#fff;padding:24px 20px;border-radius:var(--radius);
  text-align:center;
  border:2px dashed var(--blue-100);
  transition:.3s;
}
.usecase-card:hover{border-color:var(--gold-400);border-style:solid;transform:translateY(-4px);box-shadow:var(--shadow)}
.usecase-card .icon{
  font-size:38px;display:block;margin-bottom:10px;
  animation:wiggle 4s ease-in-out infinite;
}
.usecase-card:nth-child(odd) .icon{animation-delay:.5s}
.usecase-card h4{color:var(--navy-900);font-weight:700;font-size:16px;margin-bottom:6px}
.usecase-card p{color:var(--muted);font-size:13.5px}

/* ===== CALCULATOR ===== */
.calc-wrap{
  background:#fff;border-radius:var(--radius-lg);padding:32px;
  max-width:780px;margin:0 auto;
  box-shadow:var(--shadow);border:2px solid var(--gold-100);
}
.calc-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:14px}
.calc-field label{display:block;font-weight:700;color:var(--navy-800);margin-bottom:6px;font-size:14.5px}
.calc-field input,.calc-field select{
  width:100%;padding:12px 14px;border-radius:14px;
  border:2px solid var(--line);background:var(--bg);
  font-family:inherit;font-size:15px;color:var(--text);
  transition:.2s;
}
.calc-field input:focus,.calc-field select:focus{outline:none;border-color:var(--gold-500);background:#fff}
.calc-result{
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:#fff;padding:22px;border-radius:var(--radius);
  text-align:center;margin-top:18px;
}
.calc-result small{color:var(--gold-300,#f5d98a);font-size:13px;font-weight:600}
.calc-result .price{font-size:32px;font-weight:800;color:var(--gold-400);margin-top:6px}
.calc-note{font-size:12.5px;color:var(--muted);margin-top:10px;text-align:center}

/* ===== AREAS ===== */
.areas-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;
}
.area-link{
  display:block;padding:11px 16px;background:#fff;border-radius:14px;
  font-size:14px;color:var(--navy-800);font-weight:600;
  border:1.5px solid var(--line);
  transition:.2s;text-align:center;
}
a.area-link:hover{background:var(--gold-50);border-color:var(--gold-500);color:var(--gold-700);transform:translateY(-2px)}
.area-link.no-link{cursor:default;color:var(--muted);font-weight:500}

/* ===== TABS / FILTER (index) ===== */
.area-tabs{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.tab-btn{
  padding:9px 22px;background:#fff;border:2px solid var(--line);
  border-radius:var(--radius-pill);font-weight:700;color:var(--navy-700);
  cursor:pointer;font-family:inherit;font-size:14px;transition:.2s;
}
.tab-btn:hover{border-color:var(--gold-500);color:var(--gold-700)}
.tab-btn.active{background:linear-gradient(135deg,var(--navy-800),var(--navy-600));color:#fff;border-color:var(--navy-800)}
.area-search{
  max-width:520px;margin:0 auto 22px;position:relative;
}
.area-search input{
  width:100%;padding:13px 18px 13px 44px;border-radius:var(--radius-pill);
  border:2px solid var(--line);background:#fff;font-size:15px;font-family:inherit;
  transition:.2s;
}
.area-search input:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 4px var(--gold-50)}
.area-search::before{content:'🔍';position:absolute;top:50%;left:16px;transform:translateY(-50%);font-size:16px}

/* ===== FAQ ===== */
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:#fff;border-radius:var(--radius);
  border:2px solid var(--blue-100);
  overflow:hidden;transition:.25s;
}
.faq-item:hover{border-color:var(--gold-400)}
.faq-q{
  padding:16px 22px;font-weight:700;color:var(--navy-900);
  cursor:pointer;display:flex;align-items:center;gap:10px;
  font-size:15.5px;
}
.faq-q::before{content:'❓';font-size:18px}
.faq-a{padding:0 22px 18px 50px;color:var(--muted);font-size:14.5px;line-height:1.7}

/* ===== REVIEWS ===== */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.review-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:2px dashed var(--blue-100);transition:.3s;
  box-shadow:var(--shadow);
}
.review-card:hover{border-style:solid;border-color:var(--gold-400);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.review-card .img-wrap{height:170px;overflow:hidden;background:var(--blue-50)}
.review-card .img-wrap img{width:100%;height:100%;object-fit:cover}
.review-card .body{padding:16px 18px 18px}
.stars{color:var(--gold-500);font-size:17px;letter-spacing:2px;margin-bottom:6px}
.review-text{color:var(--text);font-size:14.5px;font-style:italic;margin-bottom:10px;line-height:1.7}
.reviewer{font-weight:700;color:var(--navy-800);font-size:14px}
.review-service{font-size:12.5px;color:var(--gold-600);margin-top:2px;font-weight:600}

/* ===== MAP ===== */
.map-wrap{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);border:4px solid #fff;
  max-width:1000px;margin:0 auto;
}
.map-wrap iframe{width:100%;height:380px;border:0;display:block}

/* ===== GALLERY ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.gallery-item{
  border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;
  border:3px solid #fff;box-shadow:var(--shadow);
  transition:.3s;cursor:pointer;
}
.gallery-item:hover{transform:scale(1.03)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery-item:hover img{transform:scale(1.08)}

/* ===== CTA SECTION ===== */
.cta-section{
  background:linear-gradient(135deg,var(--navy-900),var(--navy-700));
  color:#fff;padding:60px 0;text-align:center;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;top:-50px;left:-50px;width:200px;height:200px;
  background:radial-gradient(circle,var(--gold-400),transparent 70%);
  opacity:.3;border-radius:50%;
}
.cta-section::after{
  content:'';position:absolute;bottom:-50px;right:-50px;width:240px;height:240px;
  background:radial-gradient(circle,var(--gold-500),transparent 70%);
  opacity:.25;border-radius:50%;
}
.cta-section h2{color:#fff;font-size:30px;font-weight:800;margin-bottom:10px;position:relative}
.cta-section p{color:#dbe7f6;font-size:17px;margin-bottom:20px;position:relative}

/* ===== ARTICLES PREVIEW ===== */
.articles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.article-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);transition:.3s;
  border:2px solid var(--blue-100);
  display:flex;flex-direction:column;
}
.article-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold-400)}
.article-card .img-wrap{height:180px;overflow:hidden;background:var(--blue-50)}
.article-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:.4s}
.article-card:hover .img-wrap img{transform:scale(1.05)}
.article-card .body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column}
.article-card .cat{
  display:inline-block;background:var(--gold-50);color:var(--gold-700);
  font-size:11.5px;padding:3px 10px;border-radius:var(--radius-pill);
  font-weight:700;margin-bottom:8px;border:1px dashed var(--gold-500);
  align-self:flex-start;
}
.article-card h3{font-size:17px;font-weight:700;color:var(--navy-900);margin-bottom:8px;line-height:1.4}
.article-card p{color:var(--muted);font-size:14px;margin-bottom:12px;flex:1}
.article-card .read-more{font-weight:700;color:var(--navy-700);font-size:14px}
.article-card .read-more::after{content:' →';transition:.2s}
.article-card:hover .read-more::after{margin-left:4px}

/* ===== FOOTER ===== */
.footer{
  background:linear-gradient(180deg,var(--navy-900),#06192d);
  color:#dbe7f6;padding:50px 0 0;
  position:relative;
}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:28px;margin-bottom:34px}
.footer h4{color:var(--gold-400);margin-bottom:14px;font-size:16px;font-weight:700;letter-spacing:.3px}
.footer p,.footer a{color:#c0cee0;font-size:14px;line-height:1.9;display:block}
.footer a:hover{color:var(--gold-400)}
.footer-bottom{
  border-top:1px solid #1a3859;padding:18px 0;text-align:center;color:#8ea3c0;font-size:13px;
}
.footer-bottom a{color:var(--gold-400);display:inline}

/* ===== FLOATING ===== */
.floating{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;z-index:99}
.float-btn{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;color:#fff;
  box-shadow:var(--shadow-lg);
  transition:.3s;
}
.float-call{background:linear-gradient(135deg,var(--gold-600),var(--gold-400))}
.float-line{background:linear-gradient(135deg,#00b900,#06c755)}
.float-btn:hover{transform:scale(1.08) translateY(-2px);color:#fff}

/* ===== ARTICLE PAGE ===== */
.article-hero{
  padding:50px 0 30px;
  background:linear-gradient(135deg,#eef4ff,#fff);
}
.article-hero .container{max-width:840px}
.article-hero h1{font-size:34px;font-weight:800;color:var(--navy-900);line-height:1.3;margin-bottom:14px}
.article-meta{color:var(--muted);font-size:14px;margin-bottom:14px}
.article-meta .cat{
  display:inline-block;background:var(--gold-50);color:var(--gold-700);
  padding:3px 12px;border-radius:var(--radius-pill);font-weight:700;font-size:12px;margin-right:8px;
  border:1px dashed var(--gold-500);
}
.article-body{max-width:840px;margin:0 auto;padding:30px 18px 60px}
.article-body img{border-radius:var(--radius);box-shadow:var(--shadow);margin:18px 0}
.article-body h2{font-size:24px;font-weight:800;color:var(--navy-900);margin:28px 0 12px;padding-bottom:8px;border-bottom:3px dashed var(--gold-400)}
.article-body h3{font-size:19px;font-weight:700;color:var(--navy-800);margin:22px 0 8px}
.article-body p{margin-bottom:14px;font-size:16px;color:var(--text)}
.article-body ul,.article-body ol{margin:8px 0 16px 28px}
.article-body li{margin-bottom:6px}
.article-body blockquote{
  border-left:4px solid var(--gold-500);background:var(--gold-50);
  padding:14px 18px;margin:18px 0;border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic;color:var(--navy-800);
}
.cta-inline{
  background:linear-gradient(135deg,var(--blue-50),#fff);
  border:2px dashed var(--gold-400);border-radius:var(--radius);
  padding:22px;text-align:center;margin:24px 0;
}
.cta-inline h3{color:var(--navy-900);margin-bottom:8px}
.cta-inline .btn{margin:6px}

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero h1{font-size:32px}
  .hero-img img{height:280px}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .calc-row{grid-template-columns:1fr}
  .section-title h2{font-size:26px}
  .nav{display:none}
  .logo img{width:46px;height:46px}
  .brand{font-size:17px}
  .cta-section h2{font-size:24px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .stats-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-card .num{font-size:24px}
  .hero{padding:32px 0 40px}
  .hero h1{font-size:26px}
  .areas-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .map-wrap iframe{height:280px}
  .footer-grid{grid-template-columns:1fr}
  .article-hero h1{font-size:24px}
  .article-body h2{font-size:20px}
}

/* fade-up animation */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .7s ease both}
.fade-up.d1{animation-delay:.1s}
.fade-up.d2{animation-delay:.2s}
.fade-up.d3{animation-delay:.3s}

/* ===== Index page extra styles ===== */
.stats-bar{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff;padding:28px 0;margin:24px 0}
.stats-inner{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;text-align:center}
.stats-inner .stat strong{display:block;font-size:32px;font-weight:800;color:var(--gold-500);line-height:1.1}
.stats-inner .stat span{display:block;font-size:13px;color:#dbe5f0;margin-top:4px}
@media (max-width:720px){.stats-inner{grid-template-columns:repeat(2,1fr);gap:14px 8px}.stats-inner .stat strong{font-size:24px}}

.hero-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.hero-chips .chip{background:#fff;border:1px dashed var(--gold-500);color:var(--navy-900);padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}

.areas-section{background:#F0F6FF;padding:48px 0}
.search-bar{max-width:600px;margin:0 auto 24px}
.search-bar input{width:100%;padding:14px 20px;border:2px solid var(--navy-100);background:#fff;border-radius:999px;font-size:15px;font-family:inherit;outline:none;transition:.2s}
.search-bar input:focus{border-color:var(--gold-500);box-shadow:0 0 0 4px rgba(224,179,74,.18)}

.tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.tabs .tab{background:#fff;border:2px solid var(--navy-100);color:var(--navy-900);padding:10px 20px;border-radius:999px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:.2s}
.tabs .tab:hover{border-color:var(--gold-500)}
.tabs .tab.active{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff;border-color:var(--navy-900)}

.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadeUp .4s ease both}

.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.area-card{background:#fff;border:1px solid var(--navy-100);border-radius:14px;padding:14px 12px;display:flex;align-items:center;gap:10px;color:var(--navy-900);text-decoration:none;font-weight:600;font-size:14px;transition:.2s;box-shadow:0 2px 6px rgba(11,37,64,.04)}
.area-card:hover{border-color:var(--gold-500);transform:translateY(-2px);box-shadow:0 8px 20px rgba(11,37,64,.10);background:#FFFDF5}
.area-card .area-icon{font-size:16px}
.area-card.hidden{display:none}
@media (max-width:520px){.area-grid{grid-template-columns:repeat(2,1fr)}.area-card{font-size:13px;padding:12px 10px}}

/* stats-bar in container */
.stats-bar .container{max-width:1100px}
