:root {
  --navy: #0d1b3e;
  --blue: #1456d9;
  --sky: #4da8ff;
  --light: #f7fbff;
  --text: #1a2540;
  --muted: #667085;
  --line: rgba(20, 86, 217, 0.12);
  --amber: #ffb400;
  --white: #ffffff;
  --shadow: 0 20px 60px rgba(13, 27, 62, 0.14);
  --radius-lg: 28px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --max: 1200px;
  --ek-bg: #f4f9ff;
  --ek-card-bg: #ffffff;
  --ek-accent: #1456d9;
  --ek-text: #1a2540;
  --ek-text-dim: #667085;
  --ek-border: rgba(20, 86, 217, 0.12);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Kanit', sans-serif;
  color: var(--ek-text);
  background: var(--ek-bg);
  line-height: 1.6;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
.container { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; }
.topbar { background: var(--navy); color: rgba(255,255,255,0.9); font-size: 14px; }
.topbar-inner {
  min-height: 44px; display:flex; justify-content:space-between; align-items:center;
  gap:12px; flex-wrap:wrap; padding:8px 0;
}
.topbar-group { display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
header {
  position: sticky; top:0; z-index:100; backdrop-filter: blur(18px);
  background: rgba(255,255,255,0.86); border-bottom:1px solid rgba(20,86,217,0.08);
}
.nav { min-height: 78px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand { display:flex; align-items:center; gap:14px; font-weight:800; color:var(--navy); }
.brand-badge {
  width:48px; height:48px; border-radius:16px;
  background: linear-gradient(135deg, var(--blue), var(--sky));
  box-shadow: 0 12px 30px rgba(20,86,217,0.28);
  position:relative; overflow:hidden;
}
.brand-badge::before,.brand-badge::after{
  content:""; position:absolute; border-radius:999px; background:rgba(255,255,255,0.22);
}
.brand-badge::before{ width:34px; height:34px; right:-8px; top:-6px; }
.brand-badge::after{ width:20px; height:20px; left:6px; bottom:6px; }
.brand small{ display:block; font-size:12px; font-weight:600; color:var(--muted); margin-top:2px; }
.menu { display:flex; gap:26px; align-items:center; font-weight:600; color:#33415f; }
.menu a:hover, .menu a.active { color: var(--blue); }
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:10px; border:none;
  border-radius:999px; padding:14px 22px; font-size:15px; font-weight:700; cursor:pointer; transition:0.28s ease;
}
.btn-primary {
  background: linear-gradient(135deg, var(--blue), var(--sky)); color:#fff;
  box-shadow: 0 14px 30px rgba(20,86,217,0.22);
}
.btn-primary:hover, .btn-accent:hover { transform: translateY(-2px); }
.btn-accent {
  background: linear-gradient(135deg, #ffbf1f, #ffb400); color:#1e2538;
  box-shadow: 0 14px 30px rgba(255,180,0,0.25);
}
.btn-outline {
  background: rgba(255,255,255,0.7); color: var(--navy);
  border: 1px solid rgba(255,255,255,0.22); backdrop-filter: blur(12px);
}
.page-hero {
  position: relative; overflow: hidden; color:#fff;
  background:
    radial-gradient(circle at 82% 22%, rgba(77,168,255,0.35), transparent 16%),
    radial-gradient(circle at 20% 10%, rgba(255,255,255,0.16), transparent 20%),
    linear-gradient(135deg, #0a1633 0%, #10337d 48%, #1456d9 100%);
}
.page-hero::before,.page-hero::after{
  content:""; position:absolute; border-radius:999px; filter: blur(4px); opacity:0.35; pointer-events:none;
}
.page-hero::before{
  width:420px; height:420px; background:linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
  right:-120px; top:40px; transform: rotate(-22deg);
}
.page-hero::after{
  width:260px; height:260px; background:linear-gradient(135deg, rgba(77,168,255,0.32), rgba(255,255,255,0.02));
  left:-40px; bottom:-60px; transform: rotate(18deg);
}
.page-hero-inner{
  position:relative; z-index:1; padding:72px 0 66px; display:grid; gap:18px;
}
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background: rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.14);
  padding:9px 14px; border-radius:999px; backdrop-filter: blur(10px);
  font-size:14px; margin-bottom: 8px;
}
.page-hero h1, .hero h1 {
  font-size: clamp(34px, 4vw, 60px); line-height:1.12; margin:0 0 12px; letter-spacing:-0.02em;
}
.page-hero p, .hero p { font-size:18px; margin:0; color: rgba(255,255,255,0.85); max-width:760px; }
section { padding: 90px 0; }
.section-head { text-align:center; margin-bottom:42px; }
.section-head.left { text-align:left; }
.section-head .mini {
  display:inline-block; padding:8px 14px; border-radius:999px; background:rgba(20,86,217,0.08);
  color:var(--blue); font-weight:700; font-size:14px; margin-bottom:14px;
}
.section-head h2 { margin:0 0 10px; font-size: clamp(28px, 3vw, 42px); line-height:1.2; color: var(--navy); }
.section-head h1 { margin:0 0 10px; font-size: clamp(28px, 3vw, 42px); line-height:1.2; color: var(--navy); }
.section-head p { margin:0 auto; max-width:720px; color: var(--muted); font-size:17px; }
.section-head.left p { margin:0; }
.cards-2, .cards-3, .cards-4, .stats-grid, .steps, .contact-grid, .quote-grid, .footer-grid, .portfolio-grid, .review-grid {
  display:grid; gap:22px;
}
.cards-2 { grid-template-columns: repeat(2, 1fr); }
.cards-3, .portfolio-grid, .review-grid { grid-template-columns: repeat(3, 1fr); }
.cards-4, .stats-grid, .steps { grid-template-columns: repeat(4, 1fr); }
.contact-grid { grid-template-columns: 1fr 1.1fr; }
.quote-grid { grid-template-columns: 1fr 1.2fr; }
.footer-grid { grid-template-columns: 1.1fr 0.8fr 0.8fr 1fr; }
.card, .service-card, .feature-card, .review-card, .portfolio-card, .contact-card, .step-card, .faq-item, .stat-card {
  background: rgba(255,255,255,0.8); border: 1px solid var(--line); border-radius: var(--radius-md);
  box-shadow: 0 18px 45px rgba(22, 38, 76, 0.07); backdrop-filter: blur(12px); color: var(--text);
}
.service-card, .feature-card, .review-card, .portfolio-card, .contact-card, .step-card, .faq-item, .stat-card, .card { padding:24px; }
.icon-box {
  width:62px; height:62px; border-radius:18px; display:grid; place-items:center; font-size:28px; margin-bottom:18px;
  background: linear-gradient(135deg, rgba(20,86,217,0.12), rgba(77,168,255,0.18));
}
/* ── iOS 26 Liquid Glass — Service Cards ── */
.service-grid { gap: 18px; }
.service-card.glass-card {
  padding: 0; overflow: hidden; position: relative;
  background: linear-gradient(
    160deg,
    rgba(255,255,255,0.65) 0%,
    rgba(255,255,255,0.35) 40%,
    rgba(240,248,255,0.45) 100%
  );
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: 26px;
  backdrop-filter: blur(50px) saturate(2);
  -webkit-backdrop-filter: blur(50px) saturate(2);
  box-shadow:
    0 1px 2px rgba(0,0,0,0.04),
    0 8px 32px rgba(20,86,217,0.08),
    inset 0 1.5px 0 rgba(255,255,255,0.9),
    inset 0 -0.5px 0 rgba(0,0,0,0.04);
  transition:
    transform 0.45s cubic-bezier(0.2, 0.9, 0.3, 1),
    box-shadow 0.45s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.service-card.glass-card:hover {
  transform: translateY(-6px) scale(1.015);
  box-shadow:
    0 2px 4px rgba(0,0,0,0.06),
    0 20px 50px rgba(20,86,217,0.14),
    inset 0 1.5px 0 rgba(255,255,255,1),
    inset 0 -0.5px 0 rgba(0,0,0,0.05);
}
.service-img {
  width: 100%; height: 190px; overflow: hidden;
  background: linear-gradient(135deg, rgba(20,86,217,0.06), rgba(77,168,255,0.1));
  position: relative;
}
.service-img::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(255,255,255,0.3) 100%);
  pointer-events: none;
}
.service-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.5s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.service-card.glass-card:hover .service-img img {
  transform: scale(1.06);
}
.service-card-body {
  padding: 20px 22px 24px;
}
.service-card.glass-card h3 {
  margin: 0 0 8px; font-size: 19px; font-weight: 800; color: var(--navy);
  letter-spacing: -0.01em;
}
.service-card.glass-card p {
  margin: 0; color: var(--muted); font-size: 14.5px; line-height: 1.55;
}
.service-card.glass-card ul {
  margin: 14px 0 0; padding: 0; list-style: none;
}
.service-card.glass-card li {
  padding: 8px 0; color: #3a4967; font-size: 14px;
  border-top: 1px solid rgba(20,86,217,0.07);
}
.feature-card h3, .portfolio-card h3, .contact-card h3, .step-card h3, .card h3, .review-card h3 {
  margin:0 0 10px; font-size:22px; color:var(--navy);
}
.service-card p, .feature-card p, .review-card p, .portfolio-card p, .contact-card p, .step-card p, .faq-item p, .card p {
  margin:0; color:var(--muted);
}
.service-card ul, .feature-list, .contact-list, .tick-list { margin:16px 0 0; padding:0; list-style:none; }
.service-card li, .feature-list li, .contact-list li, .tick-list li {
  padding:10px 0; color:#3a4967; border-top:1px dashed rgba(20,86,217,0.12);
}
.stats-band{ margin-top:-26px; position:relative; z-index:3; }
.stat-card { text-align:center; }
.stat-card strong { display:block; font-size:30px; color:var(--blue); line-height:1; margin-bottom:8px; }
.hero {
  position:relative; overflow:hidden; color:#fff;
  background:
    radial-gradient(circle at 82% 22%, rgba(77,168,255,0.35), transparent 16%),
    radial-gradient(circle at 20% 10%, rgba(255,255,255,0.16), transparent 20%),
    linear-gradient(135deg, #0a1633 0%, #10337d 48%, #1456d9 100%);
}
.hero::before,.hero::after{ content:""; position:absolute; border-radius:999px; filter:blur(4px); opacity:0.35; pointer-events:none; }
.hero::before{
  width:420px; height:420px; background:linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
  right:-120px; top:40px; transform: rotate(-22deg);
}
.hero::after{
  width:260px; height:260px; background:linear-gradient(135deg, rgba(77,168,255,0.32), rgba(255,255,255,0.02));
  left:-40px; bottom:-60px; transform: rotate(18deg);
}
.hero-inner{
  display:grid; grid-template-columns:1.15fr 0.85fr; gap:44px; align-items:center; padding:84px 0 70px; position:relative; z-index:1;
}
.hero-actions, .hero-badges, .cta-actions { display:flex; flex-wrap:wrap; gap:14px; }
.hero-actions { margin: 0 0 26px; }
.hero-badges { gap:10px; }
.chip, .tag {
  display:inline-block; padding:9px 14px; border-radius:999px; font-size:13px; font-weight:700;
}
.chip { background: rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.14); color: rgba(255,255,255,0.9); }
.tag { background: rgba(20,86,217,0.08); color: var(--blue); margin-bottom:10px; }
.hero-card-wrap { position:relative; min-height:480px; }
.main-card,.floating-card{
  background: rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(18px); box-shadow: 0 20px 60px rgba(7,20,54,0.22);
}
.main-card { position:absolute; inset:24px 0 0 36px; border-radius:30px; padding:24px; }
.truck-visual {
  height:100%; min-height:420px; border-radius:24px;
  background: radial-gradient(circle at 70% 20%, rgba(255,255,255,0.22), transparent 20%),
  linear-gradient(135deg, rgba(255,255,255,0.22), rgba(255,255,255,0.06));
  position:relative; overflow:hidden;
}
.truck-visual::before{
  content:""; position:absolute; width:240px; height:240px; background:rgba(255,255,255,0.08); border-radius:50%;
  right:-40px; top:-50px;
}
.truck-box{
  position:absolute; left:8%; right:8%; bottom:18%; height:190px; border-radius:28px;
  background:linear-gradient(135deg, #ffffff, #dbe8ff); box-shadow: inset 0 -18px 40px rgba(20,86,217,0.08);
}
.truck-head{
  position:absolute; width:150px; height:110px; right:12%; bottom:26%;
  border-radius:24px 28px 18px 18px; background:linear-gradient(135deg, #fdfefe, #ccdfff);
}
.wheel{
  position:absolute; width:78px; height:78px; border-radius:50%; background:#0b1732; bottom:8%;
  box-shadow: inset 0 0 0 14px #2f4e8c;
}
.wheel.one { left:20%; } .wheel.two { left:44%; } .wheel.three { right:17%; }
.road { position:absolute; left:7%; right:7%; bottom:8%; height:12px; border-radius:999px; background: rgba(255,255,255,0.18); }
.floating-card{ position:absolute; border-radius:22px; padding:16px 18px; min-width:200px; }
.floating-card.top{ top:0; left:0; } .floating-card.bottom{ right:0; bottom:0; }
.floating-card strong{ display:block; font-size:20px; margin-bottom:4px; color:#fff; }
.floating-card span{ color:rgba(255,255,255,0.8); font-size:14px; }
.feature-wrap { display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:stretch; }
.feature-visual{
  border-radius:28px; min-height:420px; background:
  radial-gradient(circle at 20% 20%, rgba(77,168,255,0.2), transparent 24%),
  linear-gradient(135deg, #eff6ff, #dbeaff);
  border:1px solid rgba(20,86,217,0.1); position:relative; overflow:hidden;
}
.feature-visual .panel{
  position:absolute; background:rgba(255,255,255,0.8); border:1px solid rgba(20,86,217,0.1);
  backdrop-filter: blur(10px); border-radius:22px; box-shadow: 0 18px 40px rgba(20,86,217,0.12); padding:18px;
}
.panel.one{ left:32px; top:36px; width:210px; }
.panel.two{ right:28px; top:120px; width:220px; }
.panel.three{ left:90px; bottom:36px; width:240px; }
.step-no{
  width:54px; height:54px; display:grid; place-items:center; border-radius:50%; margin:0 auto 16px;
  background: linear-gradient(135deg, var(--blue), var(--sky)); color:white; font-weight:800; font-size:20px;
}
.portfolio-thumb{
  aspect-ratio:16 / 11; border-radius:18px; margin-bottom:18px; background:linear-gradient(135deg, #dbeaff, #f5f9ff);
  position:relative; overflow:hidden;
}
.portfolio-thumb::before,.portfolio-thumb::after{
  content:""; position:absolute; border-radius:24px; background: rgba(20,86,217,0.12);
}
.portfolio-thumb::before{ width:120px; height:120px; top:12px; right:-16px; }
.portfolio-thumb::after{ width:180px; height:26px; left:18px; bottom:22px; }
.review-stars{ color:#ffb400; letter-spacing:3px; font-size:18px; margin-bottom:10px; }
.review-name{ margin-top:14px; font-weight:800; color:var(--navy); }
.cta-box{
  background:
    radial-gradient(circle at top right, rgba(77,168,255,0.22), transparent 22%),
    linear-gradient(135deg, #0d1b3e 0%, #1456d9 100%);
  color:white; border-radius:34px; padding:44px; position:relative; overflow:hidden; box-shadow: 0 25px 70px rgba(13,27,62,0.24);
}
.cta-box::before{
  content:""; position:absolute; width:220px; height:220px; border-radius:50%; right:-50px; top:-40px; background:rgba(255,255,255,0.08);
}
.cta-box h2{ margin:0 0 12px; font-size: clamp(28px, 3vw, 42px); position:relative; z-index:1; }
.cta-box p{ margin:0 0 22px; color:rgba(255,255,255,0.86); max-width:700px; position:relative; z-index:1; }
form { display:grid; gap:14px; }
.input-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
input, select, textarea{
  width:100%; border:1px solid rgba(20,86,217,0.12); background:rgba(255,255,255,0.92); border-radius:16px;
  padding:15px 16px; font:inherit; color:var(--text); outline:none;
}
textarea{ min-height:130px; resize:vertical; }
input:focus, select:focus, textarea:focus{ border-color:var(--blue); }
.faq-list{ display:grid; gap:16px; max-width:920px; margin:0 auto; }
footer {
  background:#0f172a; color:rgba(255,255,255,0.8); padding:70px 0 26px; margin-top:90px;
}
footer h3, footer h4 { color:white; margin-top:0; }
footer ul { list-style:none; padding:0; margin:0; }
footer li{ padding:7px 0; }
.footer-bottom{
  margin-top:28px; padding-top:20px; border-top:1px solid rgba(255,255,255,0.1); font-size:14px;
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
@media (max-width:1100px){
  .hero-inner,.feature-wrap,.contact-grid,.quote-grid,.footer-grid,.cards-4,.steps,.stats-grid,.portfolio-grid,.review-grid,.cards-3 { grid-template-columns: repeat(2, 1fr); }
  .feature-wrap,.contact-grid,.quote-grid,.footer-grid,.hero-inner { grid-template-columns:1fr; }
  .main-card { position:relative; inset:0; }
  .hero-card-wrap { min-height:auto; }
  .floating-card.top { left:16px; top:16px; }
  .floating-card.bottom { right:16px; bottom:16px; }
  .review-photos-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width:760px){
  .menu { display:none; }
  .nav { min-height:70px; }
  .hero-inner { padding:62px 0 52px; gap:26px; }
  .hero p, .page-hero p { font-size:16px; }
  .cards-2,.cards-3,.cards-4,.steps,.stats-grid,.portfolio-grid,.review-grid,.input-grid { grid-template-columns:1fr; }
  .service-img { height: 170px; }
  .service-card.glass-card { border-radius: 22px; }
  section { padding:72px 0; }
  .cta-box { padding:30px 24px; }
  .brand div:last-child { display:none; }
  .hero-actions .btn, .cta-actions .btn { width:100%; }
}

/* ── Review Photos Gallery ── */
.review-photos-section {
  padding: 90px 0;
}
.review-photos-section .section-head h2 {
  color: #fff;
}
.review-photos-section .section-head p {
  color: rgba(255,255,255,0.65);
}
.review-photos-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding: 0 6px;
}
.review-photo-item {
  border-radius: var(--radius-sm);
  overflow: hidden;
  aspect-ratio: 1 / 1;
  position: relative;
  cursor: pointer;
  box-shadow: 0 8px 30px rgba(0,0,0,0.25);
  transition: transform 0.4s cubic-bezier(0.2, 0.9, 0.3, 1),
              box-shadow 0.4s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.review-photo-item:hover {
  transform: translateY(-6px) scale(1.03);
  box-shadow: 0 16px 50px rgba(20,86,217,0.3);
  z-index: 2;
}
.review-photo-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.review-photo-item:hover img {
  transform: scale(1.08);
}

/* ── Portfolio Stats Band ── */
.portfolio-stats-section {
  padding: 60px 0;
}
.portfolio-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.portfolio-stat {
  text-align: center;
  padding: 36px 20px;
  border-radius: var(--radius-md);
  background: var(--blue);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 10px 30px rgba(20,86,217,0.22);
  transition: transform 0.4s cubic-bezier(0.2,0.9,0.3,1), box-shadow 0.4s ease;
}
.portfolio-stat:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(20,86,217,0.35);
}
.portfolio-stat i {
  font-size: 32px;
  margin-bottom: 14px;
  display: block;
  color: #ffffff;
}
.portfolio-stat strong {
  display: block;
  font-size: 38px;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.1;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}
.portfolio-stat span {
  color: rgba(255, 255, 255, 0.9);
  font-size: 15px;
  font-weight: 500;
}

/* ── Portfolio CTA ── */
.portfolio-cta-section {
  padding: 30px 0 90px;
}
.portfolio-cta {
  background:
    radial-gradient(circle at 85% 20%, rgba(77,168,255,0.25), transparent 25%),
    radial-gradient(circle at 10% 80%, rgba(255,180,0,0.12), transparent 20%),
    linear-gradient(135deg, #0d1b3e 0%, #1456d9 100%);
  border-radius: 30px;
  padding: 56px 44px;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(13,27,62,0.35);
}
.portfolio-cta::before {
  content: "";
  position: absolute;
  width: 260px; height: 260px;
  border-radius: 50%;
  right: -60px; top: -50px;
  background: rgba(255,255,255,0.06);
  pointer-events: none;
}
.portfolio-cta h2 {
  margin: 0 0 12px;
  font-size: clamp(26px, 3vw, 38px);
  color: #fff;
  font-weight: 800;
  position: relative; z-index: 1;
}
.portfolio-cta p {
  margin: 0 0 28px;
  color: rgba(255,255,255,0.78);
  font-size: 17px;
  max-width: 600px;
  margin-left: auto; margin-right: auto;
  position: relative; z-index: 1;
}
.portfolio-cta-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
  position: relative; z-index: 1;
}

@media (max-width: 1100px) {
  .portfolio-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .portfolio-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .portfolio-cta { padding: 40px 24px; border-radius: 22px; }
  .portfolio-cta-actions .btn { width: 100%; }
  
  /* Portfolio Mobile Override */
  .review-photos-section .section-head h2 { font-size: 26px; line-height: 1.35; margin-bottom: 8px; }
  .review-photos-section .section-head p { font-size: 15px; margin-bottom: 24px; }
  .review-photos-grid { 
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 16px;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    padding: 10px 16px 40px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .review-photos-grid::-webkit-scrollbar { display: none; }
  .review-photo-item {
    flex: 0 0 90%;
    scroll-snap-align: center;
  }
}