/* ===== Pang-Yang Service – Kawaii Pastel Blue & Gold ===== */
:root{
  --navy:#0b2a5b;
  --navy-2:#16407f;
  --blue:#4a7fd6;
  --sky:#cfe1ff;
  --ice:#eaf2ff;
  --cream:#fff8e7;
  --gold:#e2b340;
  --gold-2:#c98f1f;
  --gold-soft:#f8e3a8;
  --ink:#1b2440;
  --muted:#5b6a8a;
  --line:#dfe7f5;
  --rose:#ffd9d2;
  --mint:#d4f1e2;
  --shadow:0 14px 40px rgba(11,42,91,.12);
  --shadow-sm:0 6px 18px rgba(11,42,91,.10);
  --radius:22px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Mali','Sarabun','Noto Sans Thai',sans-serif;
  color:var(--ink);
  background:
    radial-gradient(900px 600px at 90% -10%, #ffeec2 0%, transparent 60%),
    radial-gradient(900px 700px at -10% 10%, #d6e6ff 0%, transparent 55%),
    linear-gradient(180deg,#f6faff 0%, #fffdf6 100%);
  line-height:1.7;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--navy-2);text-decoration:none}

/* Decorative blobs */
.blob{
  position:absolute;border-radius:50%;filter:blur(40px);opacity:.55;z-index:0;pointer-events:none;
}
.blob.b1{width:280px;height:280px;background:#ffe6a8;top:-80px;left:-80px}
.blob.b2{width:320px;height:320px;background:#c9dcff;top:200px;right:-120px}

/* Navigation */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1180px;margin:0 auto;padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:46px;height:46px;border-radius:14px;background:white;padding:4px;box-shadow:var(--shadow-sm)}
.brand .name{font-weight:800;color:var(--navy);font-size:18px;line-height:1.15}
.brand .name span{display:block;font-weight:600;font-size:12px;color:var(--gold-2)}
.nav-cta{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;border-radius:999px;font-weight:700;font-size:15px;
  border:2px solid transparent;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-call{background:linear-gradient(135deg,var(--gold) 0%, var(--gold-2) 100%);color:#3b2700;box-shadow:0 8px 20px rgba(201,143,31,.35)}
.btn-line{background:#06c755;color:white;box-shadow:0 8px 20px rgba(6,199,85,.35)}
.btn-ghost{background:white;color:var(--navy);border-color:var(--line)}
.btn-blue{background:linear-gradient(135deg,var(--navy) 0%, var(--blue) 100%);color:white;box-shadow:0 8px 20px rgba(11,42,91,.3)}

/* Hero */
.hero{position:relative;max-width:1180px;margin:0 auto;padding:48px 22px 36px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;position:relative;z-index:2}
.hero h1{
  font-family:'Mali',sans-serif;font-weight:800;
  font-size:clamp(30px, 4.4vw, 52px);line-height:1.15;
  color:var(--navy);margin:0 0 16px;letter-spacing:-.3px;
}
.hero h1 .accent{
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p.lead{font-size:18px;color:var(--muted);margin:0 0 22px;max-width:560px}
.hero .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:var(--cream);border:1.5px solid var(--gold-soft);
  color:var(--gold-2);font-weight:700;font-size:13px;margin-bottom:16px;
}
.hero .pill .dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.25)}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.hero-stats{display:flex;gap:22px;margin-top:28px;flex-wrap:wrap}
.hero-stats .s{display:flex;flex-direction:column}
.hero-stats .s b{font-family:'Mali';color:var(--navy);font-size:24px;line-height:1}
.hero-stats .s span{font-size:13px;color:var(--muted)}

.hero-card{
  position:relative;border-radius:28px;overflow:hidden;
  box-shadow:var(--shadow);border:6px solid white;background:white;
  transform:rotate(1deg);
}
.hero-card img{width:100%;height:420px;object-fit:cover}
.hero-card .tag{
  position:absolute;left:14px;top:14px;
  background:white;border-radius:14px;padding:10px 14px;
  display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-sm);
}
.hero-card .tag .ico{width:38px;height:38px;border-radius:12px;background:var(--ice);display:grid;place-items:center;font-size:20px}
.hero-card .tag b{display:block;font-size:14px;color:var(--navy)}
.hero-card .tag span{font-size:12px;color:var(--muted)}

/* Sections */
.section{max-width:1180px;margin:0 auto;padding:56px 22px;position:relative}
.section h2{
  font-family:'Mali';color:var(--navy);
  font-size:clamp(24px,3vw,36px);margin:0 0 8px;letter-spacing:-.3px;
}
.section .sub{color:var(--muted);margin:0 0 28px;max-width:720px}
.eyebrow{
  display:inline-block;color:var(--gold-2);font-weight:800;letter-spacing:2px;
  font-size:12px;text-transform:uppercase;margin-bottom:10px;
}

/* Services */
.services{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.svc{
  background:white;border:1.5px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow-sm);transition:transform .2s ease, box-shadow .2s ease;
  position:relative;overflow:hidden;
}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.svc .emoji{
  width:54px;height:54px;border-radius:16px;display:grid;place-items:center;font-size:28px;
  background:linear-gradient(135deg,var(--ice),var(--sky));margin-bottom:12px;
}
.svc:nth-child(2) .emoji{background:linear-gradient(135deg,var(--cream),var(--gold-soft))}
.svc:nth-child(3) .emoji{background:linear-gradient(135deg,var(--mint),#a8e2c1)}
.svc:nth-child(4) .emoji{background:linear-gradient(135deg,var(--rose),#ffb3a4)}
.svc h3{margin:0 0 6px;color:var(--navy);font-size:18px}
.svc p{margin:0;color:var(--muted);font-size:14.5px}

/* Coverage grid */
.coverage{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.cov{
  background:white;border-radius:var(--radius);border:1.5px solid var(--line);
  padding:20px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
}
.cov h4{margin:0 0 10px;color:var(--navy);display:flex;align-items:center;gap:8px;font-size:17px;flex-wrap:wrap}
.cov h4 .cov-ico{font-size:20px;background:var(--ice);width:32px;height:32px;border-radius:10px;display:grid;place-items:center}
.cov h4 .badge{background:var(--cream);color:var(--gold-2);padding:3px 10px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid var(--gold-soft);margin-left:auto}
.cov ul{margin:4px 0 0;padding:0;list-style:none;flex:1}
.cov li{padding:8px 0;border-top:1px dashed var(--line);font-size:14.5px}
.cov li:first-child{border-top:0}
.cov li a{color:var(--navy-2);font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:8px}
.cov li a::after{content:'›';color:var(--gold-2);font-weight:800;font-size:18px;opacity:.6;transition:transform .15s ease}
.cov li a:hover{color:var(--gold-2)}
.cov li a:hover::after{transform:translateX(3px);opacity:1}

/* Tabs */
.tabs{
  display:inline-flex;gap:6px;background:white;padding:6px;border-radius:999px;
  border:1.5px solid var(--line);box-shadow:var(--shadow-sm);margin-bottom:22px;flex-wrap:wrap;
}
.tab{
  border:0;background:transparent;cursor:pointer;
  padding:10px 18px;border-radius:999px;font-family:inherit;font-weight:700;font-size:14.5px;
  color:var(--muted);display:inline-flex;align-items:center;gap:10px;transition:all .18s ease;
}
.tab:hover{color:var(--navy)}
.tab .tab-ico{font-size:18px}
.tab .tab-text em{font-style:normal;font-weight:600;color:var(--gold-2);margin-left:4px;font-size:13px}
.tab.active{
  background:linear-gradient(135deg,var(--navy),var(--navy-2));color:white;
  box-shadow:0 6px 14px rgba(11,42,91,.25);
}
.tab.active .tab-text em{color:var(--gold-soft)}
.tab-panel{display:none;animation:fadeIn .25s ease}
.tab-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* Coverage note (รถเช่า / ข้อมูลพิเศษ) */
.coverage-note{
  margin-top:22px;background:linear-gradient(135deg,var(--cream),#fff);
  border:1.5px solid var(--gold-soft);border-radius:var(--radius);
  padding:18px 22px;display:flex;align-items:center;gap:18px;box-shadow:var(--shadow-sm);
}
.coverage-note .cn-ico{
  width:54px;height:54px;border-radius:16px;background:white;display:grid;place-items:center;
  font-size:26px;box-shadow:var(--shadow-sm);flex-shrink:0;
}
.coverage-note b{color:var(--navy);display:block;margin-bottom:2px;font-size:16px}
.coverage-note p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.coverage-note .btn{flex-shrink:0;margin-left:auto}

/* Routes (recommended) */
.routes{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.route{
  background:white;border-radius:var(--radius);overflow:hidden;border:1.5px solid var(--line);
  display:grid;grid-template-columns:130px 1fr;box-shadow:var(--shadow-sm);
}
.route img{width:130px;height:130px;object-fit:cover}
.route .meat{padding:14px 16px}
.route .meat b{color:var(--navy);font-size:16px}
.route .meat p{margin:4px 0 8px;color:var(--muted);font-size:13.5px}
.route .meat a{font-size:13px;font-weight:700;color:var(--gold-2)}

/* Spots */
.spots{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.spot{
  background:linear-gradient(135deg,white,var(--ice));border-radius:18px;padding:16px;
  border:1.5px solid var(--line);display:flex;align-items:center;gap:12px;
}
.spot .em{width:42px;height:42px;border-radius:12px;background:white;display:grid;place-items:center;font-size:20px;box-shadow:var(--shadow-sm)}
.spot b{color:var(--navy);font-size:15px}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{
  background:white;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);
  border:1.5px solid var(--line);position:relative;
}
.review .head{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.review .head img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:3px solid var(--cream)}
.review b{color:var(--navy);font-size:15px;display:block}
.review .place{color:var(--muted);font-size:12.5px}
.review .stars{color:var(--gold);font-size:15px;margin:6px 0 8px}
.review p{margin:0;color:var(--ink);font-size:14.5px}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:start}
.faq details{
  background:white;border:1.5px solid var(--line);border-radius:16px;
  padding:14px 18px;margin-bottom:10px;box-shadow:var(--shadow-sm);
}
.faq summary{
  cursor:pointer;font-weight:700;color:var(--navy);
  display:flex;justify-content:space-between;align-items:center;gap:10px;list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--gold-2);font-size:22px;font-weight:800}
.faq details[open] summary::after{content:'–'}
.faq p{margin:10px 0 0;color:var(--muted)}
.faq-aside{
  background:linear-gradient(160deg,var(--navy),var(--navy-2));color:white;
  border-radius:var(--radius);padding:22px;position:sticky;top:90px;
  background-image:linear-gradient(160deg,var(--navy),var(--navy-2));
}
.faq-aside img{border-radius:16px;margin-bottom:14px;width:100%;height:200px;object-fit:cover}
.faq-aside h3{margin:0 0 6px;font-size:20px;color:white}
.faq-aside p{margin:0 0 14px;color:#cfd8ee;font-size:14px}
.faq-aside .btn{width:100%;justify-content:center;margin-bottom:8px}

/* Map */
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1.5px solid var(--line)}
.map-wrap iframe{display:block;width:100%;height:420px;border:0}

/* CTA banner */
.cta-banner{
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-2) 60%, var(--blue) 100%);
  color:white;border-radius:28px;padding:34px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  position:relative;overflow:hidden;box-shadow:var(--shadow);
}
.cta-banner::before{
  content:'';position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(closest-side,var(--gold-soft),transparent);opacity:.7;
}
.cta-banner h3{margin:0 0 6px;color:white;font-family:'Mali';font-size:26px}
.cta-banner p{margin:0;color:#d9e2f6}
.cta-banner .actions{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1}

/* Footer */
footer{
  background:linear-gradient(180deg,#0a1f44,#0b2a5b);color:#cfd8ee;margin-top:30px;
}
.foot-inner{max-width:1180px;margin:0 auto;padding:40px 22px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.foot-inner h5{color:white;margin:0 0 12px;font-size:16px}
.foot-inner a{color:#cfd8ee;display:block;padding:4px 0;font-size:14px}
.foot-inner a:hover{color:var(--gold)}
.foot-brand p{font-size:14px;line-height:1.7}
.copy{border-top:1px solid rgba(255,255,255,.1);padding:14px 22px;text-align:center;font-size:13px;color:#9fb1d6;max-width:1180px;margin:0 auto}

/* Floating buttons */
.float-cta{
  position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;z-index:60;
}
.float-cta a{
  display:inline-flex;align-items:center;gap:10px;background:white;
  padding:12px 16px;border-radius:999px;box-shadow:var(--shadow);font-weight:800;
}
.float-cta a.call{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#3b2700}
.float-cta a.line{background:#06c755;color:white}

/* Breadcrumbs */
.crumbs{max-width:1180px;margin:14px auto 0;padding:0 22px;color:var(--muted);font-size:13.5px}
.crumbs a{color:var(--navy-2);font-weight:600}
.crumbs span{margin:0 8px;color:#aab4cc}

/* Subpage hero */
.sub-hero{
  background:linear-gradient(135deg, #eef3ff 0%, #fff7df 100%);
  border-radius:0 0 32px 32px;border-bottom:1px solid var(--line);position:relative;overflow:hidden;
}
.sub-hero .inner{max-width:1180px;margin:0 auto;padding:36px 22px;display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:center}
.sub-hero h1{font-family:'Mali';color:var(--navy);font-size:clamp(26px,3.4vw,40px);margin:8px 0 10px;line-height:1.2}
.sub-hero p{color:var(--muted);margin:0 0 16px}
.sub-hero img{border-radius:22px;height:300px;width:100%;object-fit:cover;box-shadow:var(--shadow);border:5px solid white;transform:rotate(-1deg)}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.tag-list span{background:white;border:1.5px solid var(--gold-soft);color:var(--gold-2);padding:5px 12px;border-radius:999px;font-size:12.5px;font-weight:700}

/* Problem list */
.problems{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.prob{background:white;border-radius:18px;padding:18px;border:1.5px solid var(--line);box-shadow:var(--shadow-sm)}
.prob .em{font-size:30px;margin-bottom:8px}
.prob b{display:block;color:var(--navy);margin-bottom:4px}
.prob span{color:var(--muted);font-size:13.5px}

/* Subpage content image strip */
.imgstrip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0}
.imgstrip img{border-radius:18px;height:180px;width:100%;object-fit:cover;box-shadow:var(--shadow-sm)}

/* Related routes */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.related a{
  display:block;background:white;border:1.5px solid var(--line);border-radius:16px;
  padding:14px;font-weight:700;color:var(--navy);box-shadow:var(--shadow-sm);
}
.related a:hover{border-color:var(--gold-soft);background:var(--cream)}
.related a span{display:block;font-weight:500;color:var(--muted);font-size:13px;margin-top:4px}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-card{transform:none}
  .services{grid-template-columns:repeat(2,1fr)}
  .coverage{grid-template-columns:1fr 1fr}
  .routes,.reviews,.faq-grid,.related{grid-template-columns:1fr}
  .spots,.problems,.imgstrip{grid-template-columns:1fr 1fr}
  .sub-hero .inner{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr}
  .cta-banner{flex-direction:column;align-items:flex-start}
  .coverage-note{flex-direction:column;align-items:flex-start;text-align:left}
  .coverage-note .btn{margin-left:0;margin-top:6px;width:100%;justify-content:center}
  .nav-cta .btn-ghost{display:none}
}
@media (max-width: 560px){
  .services,.coverage,.spots,.problems,.imgstrip{grid-template-columns:1fr}
  .hero-card img{height:280px}
  .route{grid-template-columns:100px 1fr}
  .route img{width:100px;height:130px}
  .tabs{width:100%;flex-direction:column}
  .tab{justify-content:flex-start;width:100%}
}
