
:root{
  --green-950:#041f1b;
  --green-900:#08352e;
  --green-800:#0e4f43;
  --green-700:#176b5c;
  --sage:#dfece6;
  --mint:#eaf6f0;
  --mint2:#f4faf7;
  --cream:#fbfaf4;
  --sand:#f1eadc;
  --lime:#b9df6a;
  --gold:#c8a75e;
  --ink:#14201d;
  --muted:#3d524b;
  --line:#dce8e3;
  --white:#ffffff;
  --shadow:0 26px 90px rgba(4,31,27,.13);
  --soft-shadow:0 18px 55px rgba(4,31,27,.08);
  --radius:28px;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"IBM Plex Sans Thai",Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:var(--cream);
  font-size:16px;
  line-height:1.75;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(var(--max),calc(100% - 42px));margin:0 auto}

.topbar{
  background:var(--green-950);
  color:rgba(255,255,255,.96);
  font-size:13px;
  padding:8px 0;
}
.topbar .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.topbar strong{color:#fff}

header{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(251,250,244,.9);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(220,232,227,.9);
}
.nav{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.logo{
  width:152px;
  height:auto;
  display:block;
}
nav{
  display:flex;
  align-items:center;
  gap:5px;
  font-size:13.5px;
  font-weight:700;
  color:#304942;
}
nav a{
  opacity:.92;
  padding:9px 11px;
  border-radius:999px;
  transition:.18s ease;
}
nav a:hover{
  opacity:1;
  color:var(--green-800);
  background:rgba(234,246,240,.95);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  padding:12px 20px;
  border:1px solid transparent;
  font-weight:800;
  font-size:14px;
  transition:.2s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:linear-gradient(135deg,var(--green-800),var(--green-950));
  color:white;
  box-shadow:0 16px 34px rgba(14,79,67,.24);
}
.btn-primary:hover{background:var(--green-950)}
.btn-light{
  background:white;
  color:var(--green-950);
  border-color:var(--line);
}
.btn-light:hover{
  border-color:var(--green-700);
  box-shadow:var(--soft-shadow);
}

.hero{
  position:relative;
  overflow:hidden;
  padding:86px 0 72px;
  background:
    radial-gradient(circle at 86% 14%,rgba(185,223,106,.38),transparent 25%),
    radial-gradient(circle at 12% 76%,rgba(220,236,230,.9),transparent 30%),
    linear-gradient(180deg,var(--cream) 0%,#fff 100%);
}
.hero:before{
  content:"";
  position:absolute;
  inset:auto -15% -38% -15%;
  height:360px;
  background:linear-gradient(90deg,rgba(14,79,67,.08),rgba(185,223,106,.1),rgba(200,167,94,.08));
  transform:rotate(-3deg);
}
.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:52px;
  align-items:center;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:8px 15px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.78);
  color:var(--green-800);
  font-size:13px;
  font-weight:800;
  margin-bottom:20px;
}
.dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--lime);
  box-shadow:0 0 0 5px rgba(185,223,106,.22);
}
h1{
  margin:0 0 20px;
  color:var(--green-950);
  font-size:clamp(36px,5.2vw,64px);
  line-height:1.13;
  letter-spacing:-.018em;
  font-weight:800;
}
h2{
  margin:0 0 14px;
  color:var(--green-950);
  font-size:clamp(28px,4vw,46px);
  line-height:1.25;
  letter-spacing:-.014em;
  font-weight:800;
}
h3{
  color:var(--green-950);
  line-height:1.42;
}
.lead{
  max-width:790px;
  margin:0 0 30px;
  color:var(--muted);
  font-size:17px;
  line-height:1.9;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:28px;
}
.trust-row{
  display:flex;
  flex-wrap:wrap;
  gap:11px;
}
.trust-pill{
  padding:9px 13px;
  border:1px solid var(--line);
  border-radius:999px;
  background:white;
  color:#425853;
  font-size:13px;
  font-weight:700;
}

.hero-card{
  border:1px solid var(--line);
  border-radius:36px;
  padding:18px;
  background:rgba(255,255,255,.66);
  box-shadow:var(--shadow);
}
.hero-visual{
  min-height:470px;
  border-radius:29px;
  padding:30px;
  color:#fff;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  background:
    linear-gradient(145deg,rgba(4,31,27,.96),rgba(23,107,92,.74)),
    url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?q=80&w=1600&auto=format&fit=crop");
  background-position:center;
  background-size:cover;
}
.hero-visual:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(4,31,27,.04),rgba(4,31,27,.36));
}
.metric-card{
  position:absolute;
  top:24px;
  right:24px;
  z-index:1;
  width:230px;
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.93);
  color:var(--green-950);
  box-shadow:0 20px 50px rgba(0,0,0,.18);
}
.metric-card strong{
  display:block;
  font-family:Inter,sans-serif;
  font-size:33px;
  line-height:1;
  letter-spacing:-.03em;
  margin-bottom:8px;
}
.metric-card span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}
.hero-visual-content{
  position:relative;
  z-index:1;
  max-width:470px;
}
.hero-visual h2{
  color:#fff;
  margin:0 0 8px;
  font-size:26px;
  line-height:1.32;
  letter-spacing:-.01em;
}
.hero-visual p{
  color:rgba(255,255,255,.95);
  margin:0;
  font-size:14px;
}

section{padding:80px 0}
.section-head{
  max-width:860px;
  margin-bottom:36px;
}
.kicker{
  color:var(--green-700);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-family:Inter,"IBM Plex Sans Thai",sans-serif;
  font-size:12px;
  font-weight:900;
  margin-bottom:10px;
}
.section-head p{
  color:var(--muted);
  font-size:16px;
  margin:0;
}

.grid3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.grid2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.card{
  position:relative;
  overflow:hidden;
  background:white;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  box-shadow:0 1px 0 rgba(4,31,27,.02);
  transition:.22s ease;
}
.card:hover{
  transform:translateY(-5px);
  box-shadow:var(--soft-shadow);
  border-color:rgba(23,107,92,.32);
}
.card:before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:4px;
  background:linear-gradient(90deg,var(--green-800),var(--lime),var(--gold));
  opacity:.82;
}
.card p{
  color:var(--muted);
  font-size:15px;
  margin:0;
}
.card h3 span{
  display:block;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
  line-height:1.45;
  margin-top:3px;
}
.icon{
  width:50px;
  height:50px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg,var(--mint),#fff);
  color:var(--green-950);
  border:1px solid var(--line);
  font-family:Inter,sans-serif;
  font-weight:900;
  font-size:13px;
  margin-bottom:18px;
}

.process{
  background:linear-gradient(180deg,var(--mint2),#fff);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.process-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  counter-reset:step;
}
.step{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:22px;
  min-height:210px;
}
.step:before{
  counter-increment:step;
  content:"0" counter(step);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:999px;
  background:var(--green-950);
  color:white;
  font-family:Inter,sans-serif;
  font-size:12px;
  font-weight:900;
  margin-bottom:18px;
}
.step h3{
  margin:0 0 8px;
  font-size:18px;
}
.step p{
  margin:0;
  color:var(--muted);
  font-size:15px;
}

.split{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:44px;
  align-items:center;
}
.panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:34px;
  padding:36px;
  box-shadow:var(--shadow);
}
.list{
  display:grid;
  gap:14px;
  margin:24px 0 0;
  padding:0;
  list-style:none;
}
.list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:#344842;
  line-height:1.75;
}
.check{
  flex:0 0 24px;
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:var(--mint);
  color:var(--green-800);
  font-weight:900;
  font-size:13px;
  margin-top:2px;
}

.faq{
  background:linear-gradient(180deg,#fff,var(--soft));
}
.faq-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px 20px;
  box-shadow:0 1px 0 rgba(4,31,27,.02);
}
summary{
  cursor:pointer;
  color:var(--green-950);
  font-weight:800;
  line-height:1.5;
}
details p{
  color:var(--muted);
  margin:12px 0 0;
  font-size:15px;
}

.contact-band{
  background:
    radial-gradient(circle at 80% 18%,rgba(185,223,106,.16),transparent 28%),
    linear-gradient(135deg,var(--green-950),var(--green-800));
  color:white;
}
.contact-band h2{color:white}
.contact-band p{color:rgba(255,255,255,.82)}
.contact-grid{
  display:grid;
  grid-template-columns:.98fr 1.02fr;
  gap:36px;
  align-items:start;
}
.contact-methods{
  display:grid;
  gap:12px;
  margin-top:24px;
}
.contact-method{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  color:#fff;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.08);
  border-radius:18px;
  padding:14px 16px;
}
.contact-method span{
  color:rgba(255,255,255,.90);
  font-size:13px;
}
.contact-card{
  background:#fff;
  color:var(--ink);
  border-radius:30px;
  padding:32px;
}
.contact-card h3{
  margin:0 0 10px;
  color:var(--green-950);
  font-size:25px;
  line-height:1.35;
}
.contact-card p{
  color:var(--muted);
  margin:0 0 20px;
}
.contact-buttons{
  display:grid;
  gap:12px;
}

.footer{
  background:#041f1b;
  color:rgba(255,255,255,.92);
  padding:38px 0;
  font-size:14px;
}
.footer-grid{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.footer-logo{
  width:154px;
  margin-bottom:8px;
}
.footer-links{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

.breadcrumb{
  padding:18px 0;
  background:#fff;
  border-bottom:1px solid var(--line);
  font-size:13px;
  color:var(--muted);
}
.breadcrumb a{
  color:var(--green-700);
  font-weight:800;
}
.service-hero{
  padding:78px 0;
  background:
    radial-gradient(circle at 84% 18%,rgba(185,223,106,.32),transparent 27%),
    linear-gradient(180deg,var(--cream),#fff);
}
.service-hero .container{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:44px;
  align-items:center;
}
.service-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:34px;
  padding:32px;
  box-shadow:var(--shadow);
}
.data-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.data-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
}
.data-card strong{
  display:block;
  color:var(--green-950);
  margin-bottom:5px;
}
.data-card span{
  color:var(--muted);
  font-size:13px;
}
.form-frame{
  width:100%;
  min-height:760px;
  border:1px solid var(--line);
  border-radius:28px;
  background:#fff;
  box-shadow:var(--shadow);
}
.form-placeholder{
  background:#fff;
  border:1px dashed #b8c9c2;
  border-radius:28px;
  padding:34px;
}
.notice{
  background:var(--mint2);
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  color:#36514a;
}

@media(max-width:1180px){
  nav{gap:3px;font-size:13px}
  nav a{padding:8px 8px}
  .logo{width:142px}
  .nav .btn-primary{padding:12px 17px}
}
@media(max-width:1080px){
  nav{display:none}
  .process-grid,.data-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:940px){
  .hero-grid,.split,.contact-grid,.service-hero .container{grid-template-columns:1fr}
  .grid3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .container{width:min(100% - 28px,var(--max))}
  .topbar{display:none}
  .nav{min-height:68px}
  .logo{width:134px}
  .nav .btn{display:none}
  .hero,.service-hero{padding:58px 0}
  h1{font-size:clamp(31px,9vw,44px);line-height:1.22}
  section{padding:60px 0}
  .grid3,.grid2,.faq-grid,.process-grid,.data-grid{grid-template-columns:1fr}
  .metric-card{position:static;width:100%;margin-bottom:110px}
  .hero-visual{min-height:380px}
  .footer-grid{align-items:flex-start}
}


/* Hero redesign V3 */
.hero{
  padding:88px 0 76px;
  background:
    radial-gradient(circle at 86% 12%,rgba(185,223,106,.28),transparent 25%),
    radial-gradient(circle at 8% 88%,rgba(220,236,230,.75),transparent 30%),
    linear-gradient(180deg,#fbfaf4 0%,#ffffff 100%);
}
.hero:before{
  inset:auto -16% -42% -16%;
  height:330px;
  background:linear-gradient(90deg,rgba(14,79,67,.06),rgba(185,223,106,.08),rgba(200,167,94,.05));
}
.hero-grid{
  grid-template-columns:1.02fr .98fr;
  gap:58px;
}
.hero h1{
  max-width:760px;
  font-size:clamp(34px,4.45vw,56px);
  line-height:1.16;
  letter-spacing:-.014em;
  margin-bottom:18px;
}
.hero h1 .en-key{
  color:var(--green-800);
}
.hero .lead{
  max-width:720px;
  font-size:16.2px;
  line-height:1.9;
  margin-bottom:26px;
}
.hero .lead strong{
  color:var(--green-950);
  font-weight:800;
}
.hero-actions{
  margin-bottom:24px;
}
.trust-row{
  max-width:720px;
}
.hero-card{
  border-radius:34px;
  padding:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.62));
}
.hero-visual{
  min-height:456px;
  border-radius:28px;
  padding:28px;
  justify-content:space-between;
  background:
    linear-gradient(145deg,rgba(4,31,27,.94),rgba(16,82,70,.86)),
    radial-gradient(circle at 80% 16%,rgba(185,223,106,.22),transparent 30%);
}
.hero-visual:after{
  display:none;
}
.metric-card{
  position:relative;
  top:auto;
  right:auto;
  width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  padding:0;
  background:transparent;
  box-shadow:none;
  color:white;
}
.hero-metric{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.16);
  border-radius:20px;
  padding:16px;
  backdrop-filter:blur(10px);
}
.hero-metric strong{
  display:block;
  font-family:Inter,sans-serif;
  color:white;
  font-size:26px;
  line-height:1;
  letter-spacing:-.02em;
  margin-bottom:7px;
}
.hero-metric span{
  color:rgba(255,255,255,.90);
  font-size:12.5px;
  line-height:1.55;
}
.hero-visual-content{
  max-width:100%;
}
.hero-visual h2{
  font-size:28px;
  max-width:520px;
  margin-bottom:10px;
}
.hero-visual p{
  max-width:520px;
  font-size:15px;
  line-height:1.75;
}
.hero-path{
  position:relative;
  z-index:1;
  display:grid;
  gap:10px;
  margin-top:24px;
}
.hero-path-item{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.9);
  font-weight:700;
  font-size:13.5px;
}
.hero-path-item:before{
  content:"";
  width:9px;
  height:9px;
  border-radius:50%;
  background:var(--lime);
  box-shadow:0 0 0 5px rgba(185,223,106,.14);
}
@media(max-width:940px){
  .hero-grid{grid-template-columns:1fr}
  .hero h1{max-width:820px}
}
@media(max-width:680px){
  .hero{padding:54px 0}
  .hero h1{font-size:clamp(30px,8.4vw,42px)}
  .metric-card{grid-template-columns:1fr}
  .hero-visual{min-height:420px}
}


/* Customer-first Hero Selector */
.hero-grid{
  grid-template-columns:1.02fr .98fr;
  gap:56px;
}
.hero h1{
  max-width:760px;
  font-size:clamp(34px,4.55vw,58px);
  line-height:1.16;
}
.hero .lead{
  max-width:740px;
}
.selector-panel{
  width:100%;
  max-width:520px;
  justify-self:end;
  border-radius:34px;
  padding:18px;
  background:rgba(255,255,255,.74);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.selector-card{
  border-radius:26px;
  padding:26px;
  color:white;
  background:
    radial-gradient(circle at 95% 0%, rgba(185,223,106,.24), transparent 26%),
    linear-gradient(145deg, var(--green-950), var(--green-800));
}
.selector-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:20px;
}
.selector-head h2{
  margin:0;
  color:white;
  font-size:25px;
  line-height:1.3;
}
.selector-head p{
  margin:7px 0 0;
  color:rgba(255,255,255,.90);
  font-size:13.2px;
  line-height:1.6;
}
.selector-badge{
  flex:0 0 auto;
  width:70px;
  height:70px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  font-family:Inter,"IBM Plex Sans Thai",sans-serif;
  font-weight:900;
  font-size:18px;
}
.selector-list{
  display:grid;
  gap:10px;
}
.selector-item{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:12px;
  padding:13px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.13);
  transition:.18s ease;
}
.selector-item:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.14);
}
.selector-item strong{
  display:block;
  color:white;
  font-size:14.5px;
  line-height:1.35;
}
.selector-item span{
  display:block;
  color:rgba(255,255,255,.68);
  font-size:12.2px;
  line-height:1.45;
  margin-top:2px;
}
.selector-service{
  white-space:nowrap;
  color:var(--green-950);
  background:var(--lime);
  border-radius:999px;
  padding:7px 10px;
  font-size:11.5px;
  font-weight:900;
}
.selector-note{
  margin-top:14px;
  padding:14px 15px;
  border-radius:18px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.13);
}
.selector-note strong{
  display:block;
  color:white;
  font-size:14px;
  margin-bottom:3px;
}
.selector-note span{
  color:rgba(255,255,255,.90);
  font-size:12.5px;
  line-height:1.55;
}
@media(max-width:940px){
  .hero-grid{grid-template-columns:1fr}
  .selector-panel{justify-self:start;max-width:680px}
}
@media(max-width:680px){
  .selector-panel{padding:12px;border-radius:26px}
  .selector-card{padding:20px;border-radius:21px}
  .selector-head{display:block}
  .selector-badge{margin-top:15px}
  .selector-item{grid-template-columns:1fr}
  .selector-service{width:max-content}
}


/* V4 customer-first homepage refinements */
.service-meta{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.service-meta-row{
  padding:12px 13px;
  border-radius:16px;
  background:var(--mint2);
  border:1px solid var(--line);
}
.service-meta-row strong{
  display:block;
  color:var(--green-950);
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin-bottom:3px;
}
.service-meta-row span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}
.service-card-cta{
  margin-top:18px;
}
.card.feature-card{
  background:
    radial-gradient(circle at 100% 0%, rgba(185,223,106,.2), transparent 28%),
    linear-gradient(145deg, var(--green-950), var(--green-800));
  color:white;
}
.card.feature-card:before{
  background:linear-gradient(90deg,var(--lime),var(--gold));
}
.card.feature-card h3,
.card.feature-card h3 span{
  color:white;
}
.card.feature-card p,
.card.feature-card .service-meta-row span{
  color:rgba(255,255,255,.92);
}
.card.feature-card .service-meta-row{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.15);
}
.card.feature-card .service-meta-row strong{
  color:var(--lime);
}
.card.feature-card .icon{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.18);
  color:white;
}
.card.feature-card .btn-light{
  background:white;
  color:var(--green-950);
}
.engagement-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  counter-reset:engage;
}
.engagement-step{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px 22px;
  min-height:245px;
  box-shadow:0 1px 0 rgba(4,31,27,.02);
}
.engagement-step:before{
  counter-increment:engage;
  content:"0" counter(engage);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:999px;
  background:var(--green-950);
  color:white;
  font-family:Inter,"IBM Plex Sans Thai",sans-serif;
  font-size:12px;
  font-weight:900;
  margin-bottom:18px;
}
.engagement-step h3{
  margin:0 0 9px;
  font-size:18px;
  line-height:1.35;
}
.engagement-step p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.7;
}
.engagement-note{
  margin-top:22px;
  padding:18px 20px;
  border-radius:22px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--muted);
}
.engagement-note strong{
  color:var(--green-950);
}
@media(max-width:1080px){
  .engagement-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .engagement-grid{grid-template-columns:1fr}
}


/* V6 Clean Core Service Rows */
.service-rows{
  display:grid;
  gap:12px;
}
.service-row{
  display:grid;
  grid-template-columns:86px 1.25fr .9fr auto;
  gap:22px;
  align-items:center;
  padding:22px 24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 1px 0 rgba(4,31,27,.02);
  transition:.2s ease;
}
.service-row:hover{
  transform:translateY(-3px);
  box-shadow:var(--soft-shadow);
  border-color:rgba(23,107,92,.28);
}
.service-code{
  width:62px;
  height:62px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:linear-gradient(135deg,var(--mint),#fff);
  border:1px solid var(--line);
  color:var(--green-950);
  font-family:Inter,"IBM Plex Sans Thai",sans-serif;
  font-weight:900;
  font-size:15px;
}
.service-main h3{
  margin:0 0 5px;
  color:var(--green-950);
  font-size:20px;
  line-height:1.35;
}
.service-main small{
  display:block;
  color:var(--muted);
  font-size:13px;
  font-weight:700;
  margin-bottom:8px;
}
.service-main p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.7;
}
.service-output{
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
}
.service-output strong{
  display:block;
  color:var(--green-950);
  font-size:12px;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-weight:900;
  margin-bottom:4px;
}
.service-row .btn{
  padding:10px 15px;
  font-size:13px;
}
.service-help{
  margin-top:18px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:20px;
  align-items:center;
  padding:24px 26px;
  border-radius:26px;
  background:
    radial-gradient(circle at 95% 0%, rgba(185,223,106,.22), transparent 26%),
    linear-gradient(145deg,var(--green-950),var(--green-800));
  color:white;
  box-shadow:var(--shadow);
}
.service-help h3{
  margin:0 0 6px;
  color:white;
  font-size:22px;
}
.service-help p{
  margin:0;
  color:rgba(255,255,255,.78);
  font-size:14px;
  line-height:1.7;
}
.service-help .btn-light{
  color:var(--green-950);
  background:white;
  border-color:white;
}
@media(max-width:1040px){
  .service-row{
    grid-template-columns:70px 1fr;
    align-items:start;
  }
  .service-output,
  .service-row .btn{
    grid-column:2;
  }
}
@media(max-width:680px){
  .service-row{
    grid-template-columns:1fr;
    padding:22px;
  }
  .service-output,
  .service-row .btn{
    grid-column:auto;
  }
  .service-help{
    grid-template-columns:1fr;
  }
}


/* V7 Hero business-risk message */
.hero-risk-note{
  max-width:680px;
  margin-top:18px;
  padding:15px 17px;
  border-radius:18px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  color:var(--green-950);
  font-size:14px;
  line-height:1.65;
  box-shadow:0 10px 30px rgba(4,31,27,.05);
}
.hero-risk-note strong{
  color:var(--green-800);
}


/* V8 Hero typography refinement */
.hero-copy{
  max-width:760px;
}
.hero-copy .eyebrow{
  margin-bottom:22px;
}
.hero-title{
  margin:0 0 18px;
  color:var(--green-950);
  font-size:clamp(36px,4.8vw,60px);
  line-height:1.12;
  letter-spacing:-.025em;
  font-weight:800;
}
.hero-title .line{
  display:block;
}
.hero-title .emphasis{
  color:var(--green-800);
}
.hero-question{
  max-width:650px;
  margin:0 0 14px;
  color:var(--green-950);
  font-size:clamp(18px,1.85vw,23px);
  line-height:1.55;
  font-weight:700;
}
.hero-support{
  max-width:680px;
  margin:0 0 28px;
  color:var(--muted);
  font-size:16px;
  line-height:1.85;
}
.hero-actions.single-action{
  margin-bottom:22px;
}
.hero-actions.single-action .btn{
  padding:14px 24px;
  font-size:15px;
}
.hero-risk-note{
  max-width:650px;
  margin-top:0;
  padding:15px 17px;
  border-radius:18px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  color:var(--green-950);
  font-size:14px;
  line-height:1.65;
  box-shadow:0 10px 30px rgba(4,31,27,.05);
}
.hero-risk-note strong{
  color:var(--green-800);
}
@media(max-width:680px){
  .hero-title{
    font-size:clamp(31px,8.6vw,42px);
    line-height:1.18;
  }
  .hero-question{
    font-size:17px;
  }
}


/* V9 Hero contact actions */
.hero-actions.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  margin-bottom:22px;
}
.hero-actions.contact-actions .btn{
  padding:13px 20px;
  font-size:14px;
}
.btn-soft{
  background:rgba(255,255,255,.95);
  color:var(--green-950);
  border-color:var(--line);
  box-shadow:0 10px 30px rgba(4,31,27,.04);
}
.btn-soft:hover{
  border-color:var(--green-700);
  box-shadow:var(--soft-shadow);
}
@media(max-width:560px){
  .hero-actions.contact-actions .btn{
    width:100%;
  }
}


/* V10 How We Work compact 4-step */
.engagement-grid.compact-steps{
  grid-template-columns:repeat(4,1fr);
}
.engagement-grid.compact-steps .engagement-step{
  min-height:220px;
}
@media(max-width:1080px){
  .engagement-grid.compact-steps{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .engagement-grid.compact-steps{grid-template-columns:1fr}
}


/* V11 How We Work refined design */
.work-section{
  background:
    radial-gradient(circle at 88% 10%, rgba(185,223,106,.18), transparent 24%),
    linear-gradient(180deg, var(--mint2), #fff);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.work-head{
  max-width:760px;
  margin-bottom:42px;
}
.work-head .kicker{
  margin-bottom:12px;
}
.work-head h2{
  max-width:720px;
  font-size:clamp(30px,3.7vw,44px);
  line-height:1.25;
  letter-spacing:-.018em;
}
.work-head p{
  max-width:700px;
  color:var(--muted);
  font-size:16px;
  line-height:1.85;
  margin:0;
}
.work-flow{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.work-flow:before{
  content:"";
  position:absolute;
  top:38px;
  left:9%;
  right:9%;
  height:2px;
  background:linear-gradient(90deg, rgba(14,79,67,.12), rgba(185,223,106,.65), rgba(200,167,94,.55));
  z-index:0;
}
.work-card{
  position:relative;
  z-index:1;
  background:rgba(255,255,255,.96);
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px 22px 22px;
  box-shadow:0 14px 40px rgba(4,31,27,.055);
  min-height:250px;
}
.work-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--soft-shadow);
  border-color:rgba(23,107,92,.28);
}
.work-number{
  width:52px;
  height:52px;
  display:grid;
  place-items:center;
  border-radius:18px;
  margin-bottom:20px;
  background:linear-gradient(135deg,var(--green-950),var(--green-800));
  color:white;
  font-family:Inter,"IBM Plex Sans Thai",sans-serif;
  font-size:14px;
  font-weight:900;
  box-shadow:0 14px 30px rgba(14,79,67,.22);
}
.work-card h3{
  margin:0 0 10px;
  color:var(--green-950);
  font-size:21px;
  line-height:1.3;
  letter-spacing:-.01em;
  font-weight:800;
}
.work-card p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.78;
}
.work-note{
  margin-top:22px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:start;
  padding:18px 20px;
  border-radius:22px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--muted);
  box-shadow:0 10px 32px rgba(4,31,27,.045);
}
.work-note-icon{
  width:36px;
  height:36px;
  border-radius:13px;
  display:grid;
  place-items:center;
  background:var(--mint);
  color:var(--green-800);
  font-weight:900;
}
.work-note strong{
  display:block;
  color:var(--green-950);
  margin-bottom:3px;
  font-size:15px;
}
.work-note span{
  display:block;
  font-size:14px;
  line-height:1.7;
}
@media(max-width:1080px){
  .work-flow{
    grid-template-columns:repeat(2,1fr);
  }
  .work-flow:before{
    display:none;
  }
}
@media(max-width:680px){
  .work-flow{
    grid-template-columns:1fr;
  }
  .work-card{
    min-height:auto;
  }
  .work-note{
    grid-template-columns:1fr;
  }
}

/* V41 Contact page refinement */
.contact-hero{
  padding:72px 0 54px;
  background:
    radial-gradient(circle at 88% 12%, rgba(185,223,106,.20), transparent 30%),
    radial-gradient(circle at 12% 18%, rgba(28,138,112,.16), transparent 28%),
    linear-gradient(135deg, var(--green-950), var(--green-800));
  color:#fff;
}
.contact-hero-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:34px;
  align-items:center;
}
.contact-hero-copy h1{
  color:#fff;
  font-size:clamp(36px,5vw,58px);
  line-height:1.14;
  letter-spacing:-.035em;
  margin:16px 0 18px;
}
.contact-hero-copy .lead{
  color:rgba(255,255,255,.82);
  max-width:720px;
  font-size:clamp(16px,1.55vw,19px);
  line-height:1.78;
}
.contact-eyebrow{
  color:#e7f6c3;
}
.contact-primary-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.btn-ghost-light{
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
}
.btn-ghost-light:hover{
  background:rgba(255,255,255,.16);
}
.contact-quick-card{
  background:rgba(255,255,255,.96);
  color:var(--ink);
  border:1px solid rgba(255,255,255,.35);
  border-radius:30px;
  padding:30px;
  box-shadow:0 24px 60px rgba(3,31,27,.22);
}
.contact-card-kicker{
  color:var(--green-700);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:900;
  margin-bottom:10px;
}
.contact-quick-card h2{
  font-size:30px;
  line-height:1.22;
  margin:0 0 8px;
  color:var(--green-950);
}
.contact-quick-card p{
  color:var(--muted);
  margin:0 0 20px;
}
.contact-detail-list{
  display:grid;
  gap:10px;
}
.contact-detail-list a,
.contact-detail-list div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:13px 14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#f8fbf7;
}
.contact-detail-list span{
  color:var(--muted);
  font-size:13px;
  font-weight:700;
}
.contact-detail-list strong{
  color:var(--green-950);
  font-size:15px;
  text-align:right;
}
.contact-section{
  padding:64px 0;
}
.contact-panel-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:24px;
  align-items:stretch;
}
.contact-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:30px;
  box-shadow:0 12px 32px rgba(4,31,27,.05);
}
.contact-panel h2{
  font-size:clamp(26px,3vw,36px);
  line-height:1.25;
  letter-spacing:-.025em;
  margin:8px 0 12px;
}
.contact-panel p{
  color:var(--muted);
  line-height:1.75;
  margin:0;
}
.service-chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}
.service-chip-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:9px 14px;
  border-radius:999px;
  background:var(--green-50);
  color:var(--green-950);
  border:1px solid rgba(28,138,112,.18);
  font-size:14px;
  font-weight:800;
}
.contact-check-list{
  display:grid;
  gap:14px;
  margin:22px 0 0;
  padding:0;
  list-style:none;
}
.contact-check-list li{
  display:flex;
  gap:12px;
  color:var(--ink);
  line-height:1.65;
  font-size:15px;
}
.contact-panel-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}
.contact-soft-section{
  background:linear-gradient(180deg,#fff,#f7fbf7);
  padding-top:56px;
}
.contact-flow{
  display:grid;
  gap:26px;
}
.compact-head{
  max-width:780px;
}
.compact-head h2{
  font-size:clamp(28px,3.2vw,40px);
  line-height:1.24;
}
.compact-head p{
  max-width:720px;
}
.contact-step-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.contact-step-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px;
}
.contact-step-card span{
  display:inline-flex;
  width:44px;
  height:44px;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:var(--green-950);
  color:#fff;
  font-weight:900;
  margin-bottom:16px;
}
.contact-step-card h3{
  font-size:20px;
  margin:0 0 8px;
}
.contact-step-card p{
  color:var(--muted);
  font-size:15px;
  line-height:1.7;
  margin:0;
}
@media (max-width: 900px){
  .contact-hero-grid,
  .contact-panel-grid,
  .contact-step-grid{
    grid-template-columns:1fr;
  }
  .contact-hero{
    padding:58px 0 44px;
  }
  .contact-section{
    padding:48px 0;
  }
}
@media (max-width: 560px){
  .contact-primary-actions .btn,
  .contact-panel-actions .btn{
    width:100%;
  }
  .contact-detail-list a,
  .contact-detail-list div{
    align-items:flex-start;
    flex-direction:column;
    gap:4px;
  }
  .contact-detail-list strong{
    text-align:left;
  }
  .contact-quick-card,
  .contact-panel{
    padding:24px;
    border-radius:24px;
  }
}

/* V42 Contact consultation form */
.contact-form-layout{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(320px,.75fr);
  gap:24px;
  align-items:start;
}
.contact-form-card,
.contact-guidance-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:0 12px 32px rgba(4,31,27,.05);
}
.contact-form-card{padding:32px;}
.contact-guidance-card{
  padding:28px;
  position:sticky;
  top:92px;
}
.contact-form-card h2,
.contact-guidance-card h2{
  font-size:clamp(26px,3vw,36px);
  line-height:1.22;
  letter-spacing:-.025em;
  margin:8px 0 12px;
}
.form-intro{
  color:var(--muted);
  line-height:1.75;
  margin:0 0 26px;
  max-width:760px;
}
.consult-form{display:grid;gap:20px;}
.hidden-field{display:none;}
.form-section-title{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:6px;
  color:var(--green-950);
  font-weight:900;
  font-size:15px;
}
.form-section-title:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--lime);
  box-shadow:0 0 0 6px rgba(185,223,106,.18);
}
.form-grid{display:grid;gap:14px;}
.form-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr));}
.consult-form label{
  display:grid;
  gap:7px;
  color:var(--green-950);
  font-size:13px;
  font-weight:800;
}
.consult-form input,
.consult-form select,
.consult-form textarea{
  width:100%;
  border:1px solid var(--line);
  background:#f8fbf7;
  color:var(--ink);
  border-radius:14px;
  padding:12px 13px;
  font:inherit;
  font-size:15px;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.consult-form textarea{resize:vertical;line-height:1.65;}
.consult-form input:focus,
.consult-form select:focus,
.consult-form textarea:focus{
  background:#fff;
  border-color:rgba(28,138,112,.55);
  box-shadow:0 0 0 4px rgba(28,138,112,.10);
}
.checkbox-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.checkbox-grid label{
  display:flex;
  align-items:center;
  gap:9px;
  padding:11px 12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#f8fbf7;
  color:var(--ink);
  font-size:14px;
  font-weight:800;
  cursor:pointer;
}
.checkbox-grid input{width:auto;accent-color:var(--green-700);}
.form-detail-group{
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f9fcf7);
  overflow:hidden;
}
.form-detail-group summary{
  cursor:pointer;
  padding:16px 18px;
  color:var(--green-950);
  font-size:15px;
  font-weight:900;
  list-style:none;
}
.form-detail-group summary::-webkit-details-marker{display:none;}
.form-detail-group summary:after{
  content:"+";
  float:right;
  color:var(--green-700);
  font-weight:900;
}
.form-detail-group[open] summary:after{content:"−";}
.detail-inner{
  padding:0 18px 18px;
}
.textarea-label{margin-top:2px;}
.form-submit{justify-self:start;margin-top:4px;}
.form-note{
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
  margin:-4px 0 0;
}
.guidance-list{display:grid;gap:12px;margin-top:22px;}
.guidance-list div{
  padding:15px;
  border:1px solid var(--line);
  border-radius:18px;
  background:#f8fbf7;
}
.guidance-list strong{
  display:block;
  color:var(--green-950);
  font-size:15px;
  margin-bottom:5px;
}
.guidance-list p{
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
  margin:0;
}
.guidance-callout{
  margin-top:16px;
  padding:16px;
  border-radius:18px;
  background:rgba(185,223,106,.20);
  color:var(--green-950);
  font-weight:800;
  line-height:1.65;
}
@media (max-width: 980px){
  .contact-form-layout{grid-template-columns:1fr;}
  .contact-guidance-card{position:static;}
}
@media (max-width: 640px){
  .contact-form-card,.contact-guidance-card{padding:24px;border-radius:24px;}
  .form-grid.two-col,.checkbox-grid{grid-template-columns:1fr;}
  .form-submit{width:100%;}
}


/* V43 Quotation dynamic form */
.quotation-hero .container{align-items:center;}
.quotation-help-box .list{margin-top:16px;}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;}
.form-helper{margin:-6px 0 0;color:var(--muted);font-size:14px;line-height:1.6;}
.conditional-form-area{
  display:grid;
  gap:14px;
  padding:16px;
  border:1px solid var(--line);
  border-radius:22px;
  background:linear-gradient(180deg,#fbfdf8,#f7fbf5);
}
.quotation-empty-state{
  min-height:150px;
  display:grid;
  place-items:center;
  text-align:center;
  padding:20px;
  border:1px dashed rgba(14,79,67,.24);
  border-radius:18px;
  color:var(--green-950);
  background:#fff;
}
.quotation-empty-state .empty-icon{
  width:38px;height:38px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(185,223,106,.24);
  color:var(--green-800);
  font-weight:900;
  margin-bottom:8px;
}
.quotation-empty-state strong{font-size:18px;}
.quotation-empty-state p{margin:4px 0 0;color:var(--muted);font-size:14px;}
.conditional-panel{
  display:none;
  padding:18px;
  border:1px solid var(--line);
  border-radius:20px;
  background:#fff;
  box-shadow:0 8px 22px rgba(4,31,27,.04);
}
.conditional-panel.is-visible{display:grid;gap:16px;}
.panel-title{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:2px;}
.panel-title span{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:999px;
  background:rgba(14,79,67,.08);
  color:var(--green-800);
  font-size:12px;font-weight:900;letter-spacing:.03em;
}
.panel-title strong{font-size:18px;color:var(--green-950);letter-spacing:-.01em;}
.no-pad{padding:0;}
.quotation-guidance-card{top:92px;}
@media (max-width:640px){
  .hero-actions .btn{width:100%;}
  .conditional-form-area{padding:12px;border-radius:18px;}
  .conditional-panel{padding:14px;border-radius:16px;}
}

/* V44 Quotation - Tally-like easy flow */
.v44-quote-hero .container{align-items:center;}
.quote-preview-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:0 18px 44px rgba(4,31,27,.08);
}
.quote-preview-top{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:20px;}
.quote-preview-top span{font-size:12px;font-weight:900;color:var(--green-800);letter-spacing:.06em;text-transform:uppercase;}
.quote-preview-top strong{font-size:13px;color:var(--muted);font-weight:800;}
.quote-flow-mini{display:grid;gap:12px;margin:18px 0;}
.quote-flow-mini div{display:flex;align-items:center;gap:12px;padding:14px;border-radius:18px;background:linear-gradient(90deg,rgba(14,79,67,.06),rgba(185,223,106,.12));border:1px solid rgba(14,79,67,.08);}
.quote-flow-mini b{width:30px;height:30px;border-radius:12px;display:grid;place-items:center;background:var(--green-800);color:white;font-size:14px;}
.quote-flow-mini span{font-weight:900;color:var(--green-950);}
.quote-preview-card p{margin:16px 0 0;color:var(--muted);line-height:1.75;font-size:15px;}
.quote-form-section{padding:76px 0;background:#fff;}
.quote-layout-v44{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:28px;align-items:start;}
.quote-form-card-v44{background:#fff;border:1px solid var(--line);border-radius:32px;padding:34px;box-shadow:0 18px 48px rgba(4,31,27,.06);}
.quote-form-card-v44 h2{font-size:clamp(26px,3vw,34px);line-height:1.25;margin:8px 0 8px;color:var(--green-950);letter-spacing:-.03em;}
.quote-muted{margin:0 0 22px;color:var(--muted);line-height:1.7;font-size:15px;max-width:760px;}
.quote-step-label{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:rgba(14,79,67,.08);color:var(--green-800);font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;}
.service-card-grid-v44{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:22px 0 26px;}
.service-choice-card{position:relative;display:grid;gap:8px;align-content:start;min-height:144px;padding:18px;border:1px solid var(--line);border-radius:22px;background:#fbfdf9;cursor:pointer;transition:.18s ease;}
.service-choice-card:hover{transform:translateY(-2px);border-color:rgba(14,79,67,.25);box-shadow:0 12px 28px rgba(4,31,27,.06);}
.service-choice-card input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.service-choice-card .service-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:#fff;border:1px solid rgba(14,79,67,.10);font-size:20px;}
.service-choice-card strong{font-size:18px;color:var(--green-950);line-height:1.25;}
.service-choice-card small{font-size:13px;color:var(--muted);line-height:1.5;font-weight:700;}
.service-choice-card.is-selected{background:linear-gradient(180deg,rgba(185,223,106,.18),#fff);border-color:rgba(14,79,67,.55);box-shadow:0 12px 32px rgba(14,79,67,.10);}
.service-choice-card.is-selected:after{content:'✓';position:absolute;top:14px;right:14px;width:26px;height:26px;border-radius:999px;background:var(--green-800);color:#fff;display:grid;place-items:center;font-weight:900;font-size:13px;}
.quote-dynamic-block{display:grid;gap:16px;margin:6px 0 30px;padding:18px;border-radius:26px;border:1px solid rgba(14,79,67,.12);background:linear-gradient(180deg,#f9fcf5,#fff);}
.quote-empty-v44{min-height:180px;display:grid;place-items:center;text-align:center;padding:24px;border:1px dashed rgba(14,79,67,.25);border-radius:20px;background:#fff;color:var(--green-950);}
.quote-empty-v44 span{font-size:20px;font-weight:900;}
.quote-empty-v44 p{margin:8px 0 0;color:var(--muted);max-width:420px;line-height:1.7;}
.quote-panel-v44{display:none;background:#fff;border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 10px 28px rgba(4,31,27,.04);}
.quote-panel-v44.is-visible{display:block;}
.quote-panel-v44 h3{margin:12px 0 20px;font-size:24px;line-height:1.35;color:var(--green-950);letter-spacing:-.02em;}
.quote-contact-block-v44{margin-top:30px;padding-top:30px;border-top:1px solid var(--line);}
.quote-contact-block-v44 h2{font-size:28px;margin-top:10px;}
.quote-tally-like-form label{font-weight:800;color:var(--green-950);font-size:14px;line-height:1.45;}
.quote-tally-like-form input,.quote-tally-like-form select,.quote-tally-like-form textarea{margin-top:8px;}
.quote-side-v44{position:sticky;top:92px;display:grid;gap:16px;}
.side-card-v44{background:linear-gradient(180deg,#f6fbf1,#fff);border:1px solid rgba(14,79,67,.12);border-radius:28px;padding:26px;box-shadow:0 12px 32px rgba(4,31,27,.04);}
.side-card-v44 h3{font-size:24px;line-height:1.3;color:var(--green-950);margin:10px 0 10px;letter-spacing:-.02em;}
.side-card-v44 p{color:var(--muted);line-height:1.75;font-size:15px;}
.side-mini-list{display:grid;gap:10px;}
.side-mini-list div{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;}
.side-mini-list span{display:inline-flex;width:30px;height:30px;border-radius:12px;align-items:center;justify-content:center;background:rgba(14,79,67,.08);color:var(--green-800);font-size:12px;font-weight:900;margin-bottom:10px;}
.side-mini-list strong{display:block;color:var(--green-950);font-size:16px;margin-bottom:4px;}
.side-mini-list p{margin:0;color:var(--muted);font-size:14px;line-height:1.55;}
@media (max-width: 1040px){.quote-layout-v44{grid-template-columns:1fr;}.quote-side-v44{position:static;grid-template-columns:1fr;}.service-card-grid-v44{grid-template-columns:repeat(2,1fr);}}
@media (max-width: 640px){.quote-form-section{padding:52px 0;}.quote-form-card-v44{padding:22px;border-radius:24px;}.service-card-grid-v44{grid-template-columns:1fr;gap:10px;}.service-choice-card{min-height:auto;grid-template-columns:auto 1fr;align-items:center;column-gap:12px;}.service-choice-card small{grid-column:2;}.quote-dynamic-block{padding:12px;border-radius:20px;}.quote-panel-v44{padding:18px;border-radius:20px;}.quote-panel-v44 h3{font-size:21px;}.quote-preview-card{padding:22px;border-radius:24px;}.quote-preview-top{display:grid;}.quote-tally-like-form .form-submit{width:100%;}}


/* V45 Carbon Credit & I-REC page */
.credit-hero h1{
  max-width:760px;
  font-size:clamp(31px,3.7vw,50px);
  line-height:1.18;
  letter-spacing:-.024em;
  margin-bottom:18px;
}
.credit-punch{
  display:grid;
  gap:10px;
  margin:0 0 22px;
}
.credit-punch span{
  display:block;
  color:var(--green-950);
  font-weight:900;
  font-size:clamp(24px,2.6vw,37px);
  line-height:1.18;
  letter-spacing:-.018em;
}
.credit-punch span:nth-child(2){color:var(--green-800)}
.credit-punch span:nth-child(3){font-size:clamp(22px,2.3vw,34px)}
.credit-report-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:28px;
  box-shadow:var(--shadow);
}
.credit-report-top{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  margin-bottom:18px;
}
.credit-report-title{
  color:var(--green-950);
  font-size:22px;
  line-height:1.25;
  font-weight:900;
  letter-spacing:-.012em;
}
.credit-report-sub{
  margin-top:5px;
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
  font-weight:700;
}
.credit-badge,.credit-option-label,.credit-tag{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(185,223,106,.22);
  color:var(--green-800);
  border:1px solid rgba(185,223,106,.55);
  font-size:12px;
  line-height:1;
  font-weight:900;
  white-space:nowrap;
}
.credit-choice-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:16px;
}
.credit-choice-card{
  border:1px solid var(--line);
  border-radius:22px;
  padding:18px;
  background:linear-gradient(180deg,#fff,#fbfcf8);
}
.credit-choice-card span{
  display:block;
  color:var(--muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-weight:900;
  margin-bottom:8px;
}
.credit-choice-card strong{
  display:block;
  color:var(--green-950);
  font-size:20px;
  line-height:1.25;
  letter-spacing:-.01em;
}
.credit-choice-card p{
  margin:10px 0 0;
  color:var(--muted);
  font-size:15px;
  line-height:1.65;
}
.credit-mini-flow{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.credit-mini-flow div{
  display:grid;
  grid-template-columns:34px 1fr;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border-radius:18px;
  background:var(--mint2);
  border:1px solid var(--line);
}
.credit-mini-flow b{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--green-950),var(--green-800));
  color:#fff;font-size:13px;font-weight:900;
}
.credit-mini-flow span{
  color:var(--green-950);
  font-weight:900;
  font-size:14px;
  line-height:1.35;
}
.credit-note{
  margin:18px 0 0;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
}
.credit-framework-section,.credit-options-section,.credit-assess-section,.credit-get-section{
  background:#fff;
}
.credit-framework-card,.credit-option-card,.credit-assess-card,.credit-get-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:0 12px 34px rgba(4,31,27,.05);
}
.credit-framework-card{
  padding:28px;
}
.credit-framework-card h3{
  margin:0 0 16px;
  color:var(--green-950);
  font-size:24px;
  line-height:1.25;
  letter-spacing:-.012em;
}
.credit-mini-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.credit-mini{
  border:1px solid var(--line);
  border-radius:18px;
  padding:15px;
  background:var(--mint2);
}
.credit-mini span{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:7px;
}
.credit-mini strong{
  color:var(--green-950);
  font-size:15px;
  line-height:1.42;
}
.compact-section-head h2{
  font-size:clamp(28px,3.1vw,38px);
  line-height:1.28;
}
.compact-section-head p{
  max-width:780px;
}
.credit-options-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.credit-option-card{
  padding:24px;
}
.credit-option-card h3,.credit-get-card h3,.credit-assess-card h3{
  margin:14px 0 10px;
  color:var(--green-950);
  font-size:21px;
  line-height:1.28;
  letter-spacing:-.01em;
}
.credit-option-card p,.credit-get-card p,.credit-assess-card p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.75;
}
.credit-option-card ul{
  margin:16px 0 0;
  padding-left:18px;
  color:#36514a;
  font-size:14px;
  line-height:1.85;
}
.credit-option-card li::marker{color:var(--green-800)}
.credit-assess-grid,.credit-get-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.credit-assess-card,.credit-get-card{
  padding:22px;
}
.credit-assess-card .num{
  width:42px;height:42px;border-radius:15px;
  display:grid;place-items:center;
  background:var(--mint);
  color:var(--green-800);
  font-weight:900;
  font-family:Inter,"IBM Plex Sans Thai",sans-serif;
}
.credit-get-card .credit-tag{
  margin-bottom:2px;
}
.credit-faq .faq-grid{
  align-items:start;
}
@media(max-width:1080px){
  .credit-options-grid,.credit-assess-grid,.credit-get-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .credit-choice-grid,.credit-mini-grid,.credit-options-grid,.credit-assess-grid,.credit-get-grid{grid-template-columns:1fr}
  .credit-report-top{flex-direction:column}
  .credit-report-card,.credit-framework-card{padding:22px}
  .credit-punch span{font-size:clamp(24px,7vw,34px)}
  .credit-punch span:nth-child(3){font-size:clamp(22px,6.3vw,31px)}
}

/* V46 Carbon Offset & I-REC detail update */
.credit-offset-guide-section{
  background:#fff;
}
.credit-compare-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  align-items:stretch;
}
.credit-compare-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:0 14px 38px rgba(4,31,27,.055);
  display:grid;
  gap:16px;
}
.credit-compare-card.offset-card{
  background:linear-gradient(180deg,#fff,#f8fcf4);
}
.credit-compare-card.irec-card{
  background:linear-gradient(180deg,#fff,#f7fbfb);
}
.credit-compare-card h3{
  margin:0;
  color:var(--green-950);
  font-size:clamp(22px,2.2vw,28px);
  line-height:1.25;
  letter-spacing:-.018em;
}
.credit-compare-card p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.78;
}
.credit-use-block{
  padding:17px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(14,79,67,.10);
}
.credit-use-block h4{
  margin:0 0 10px;
  color:var(--green-950);
  font-size:15px;
  letter-spacing:-.005em;
}
.credit-use-block ul{
  margin:0;
  padding-left:18px;
  color:#36514a;
  font-size:14px;
  line-height:1.75;
}
.credit-use-block li::marker{
  color:var(--green-800);
}
.credit-guidance-callout{
  margin-top:20px;
  padding:18px 20px;
  border-radius:22px;
  border:1px solid rgba(14,79,67,.13);
  background:linear-gradient(90deg,rgba(185,223,106,.20),rgba(14,79,67,.045));
  color:#29443d;
  font-size:15px;
  line-height:1.78;
}
.credit-guidance-callout strong{
  color:var(--green-950);
}
@media(max-width:860px){
  .credit-compare-grid{grid-template-columns:1fr;}
  .credit-compare-card{padding:22px;border-radius:24px;}
}

/* V47 Carbon Offset & I-REC reporting update */
.credit-reporting-section{
  background:#fff;
}
.credit-reporting-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  align-items:stretch;
}
.credit-reporting-card{
  border:1px solid var(--line);
  border-radius:28px;
  padding:28px;
  box-shadow:0 14px 38px rgba(4,31,27,.055);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.credit-reporting-card.carbon-reporting{
  background:linear-gradient(180deg,#ffffff,#f8fcf4);
}
.credit-reporting-card.irec-reporting{
  background:linear-gradient(180deg,#ffffff,#f7fbfb);
}
.credit-reporting-card h3{
  margin:0;
  color:var(--green-950);
  font-size:clamp(22px,2.2vw,28px);
  line-height:1.25;
  letter-spacing:-.018em;
}
.credit-reporting-card p{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.78;
}
.report-chip-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:4px;
}
.report-chip-wrap span{
  display:inline-flex;
  align-items:center;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(14,79,67,.12);
  color:var(--green-950);
  font-size:13px;
  font-weight:800;
  line-height:1.2;
}
.climate-disclosure-note{
  margin-top:20px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:center;
  padding:22px;
  border-radius:26px;
  border:1px solid rgba(14,79,67,.13);
  background:linear-gradient(90deg,rgba(185,223,106,.16),rgba(14,79,67,.04));
}
.climate-disclosure-note strong{
  display:block;
  color:var(--green-950);
  font-size:18px;
  line-height:1.35;
  margin-bottom:6px;
}
.climate-disclosure-note p{
  margin:0;
  color:#36514a;
  font-size:15px;
  line-height:1.75;
}
.disclosure-tags{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  justify-content:flex-end;
}
.disclosure-tags span{
  display:inline-flex;
  padding:8px 11px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(14,79,67,.12);
  color:var(--green-950);
  font-size:12.5px;
  font-weight:900;
}
@media(max-width:860px){
  .credit-reporting-layout,.climate-disclosure-note{grid-template-columns:1fr;}
  .credit-reporting-card{padding:22px;border-radius:24px;}
  .disclosure-tags{justify-content:flex-start;}
}

/* v48 Tally quotation landing */
.tally-landing-hero .lead{max-width:720px;}
.tally-note{margin-top:16px;color:#5f766f;font-size:14px;line-height:1.7;}
.tally-preview-card{background:linear-gradient(180deg,#ffffff,#f7fbfb);}
.tally-link-section{padding-top:56px;}
.tally-link-layout{align-items:start;}
.tally-link-card h2{font-size:clamp(28px,3vw,40px);line-height:1.2;letter-spacing:-.02em;margin-bottom:12px;}
.tally-cta-box{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 22px;}
.tally-cta-box .btn{min-width:180px;}
.tally-benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:20px;}
.tally-benefit-grid>div{padding:18px;border-radius:20px;background:#f8fbfa;border:1px solid rgba(14,79,67,.10);}
.tally-benefit-grid span{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;background:rgba(185,223,106,.22);color:var(--green-950);font-size:13px;font-weight:900;margin-bottom:12px;}
.tally-benefit-grid strong{display:block;color:var(--green-950);font-size:16px;line-height:1.35;margin-bottom:6px;}
.tally-benefit-grid p{margin:0;color:var(--muted);font-size:14px;line-height:1.65;}
@media(max-width:900px){.tally-benefit-grid{grid-template-columns:1fr;}.tally-cta-box .btn{width:100%;}}


/* Pricing Section */
.pricing-section{
  background:linear-gradient(180deg,var(--mint2),#fff);
  border-top:1px solid var(--line);
  padding:72px 0;
}
.pricing-card{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:40px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  padding:40px;
  box-shadow:var(--soft-shadow);
}
.pricing-card .kicker{margin-bottom:10px;}
.pricing-card h2{
  font-size:clamp(24px,2.8vw,34px);
  line-height:1.25;
  margin-bottom:12px;
}
.pricing-card>div>p{
  color:var(--muted);
  font-size:15px;
  line-height:1.8;
  margin-bottom:20px;
}
.pricing-factors{
  display:grid;
  gap:10px;
  margin-bottom:20px;
}
.pricing-factor-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  background:var(--mint2);
  border:1px solid var(--line);
  border-radius:14px;
  color:var(--ink);
  font-size:14px;
  font-weight:700;
}
.pricing-factor-item i{
  font-size:18px;
  color:var(--green-700);
  flex-shrink:0;
}
.pricing-note{
  color:var(--muted);
  font-size:14px;
  line-height:1.7;
  margin:0!important;
  padding:14px 16px;
  background:rgba(185,223,106,.15);
  border-radius:14px;
  border:1px solid rgba(185,223,106,.35);
}
.pricing-right{
  display:flex;
  flex-direction:column;
  gap:20px;
  align-items:flex-start;
}
.pricing-time{
  text-align:center;
  width:100%;
  padding:28px;
  background:linear-gradient(135deg,var(--green-950),var(--green-800));
  border-radius:24px;
  color:#fff;
}
.pricing-time strong{
  display:block;
  font-family:Inter,sans-serif;
  font-size:52px;
  line-height:1;
  letter-spacing:-.03em;
  margin-bottom:8px;
}
.pricing-time span{
  color:rgba(255,255,255,.85);
  font-size:14px;
}
.pricing-actions{
  display:grid;
  gap:10px;
  width:100%;
}
.pricing-free-note{
  color:var(--muted);
  font-size:13px;
  text-align:center;
  width:100%;
  margin:0!important;
}
@media(max-width:860px){
  .pricing-card{
    grid-template-columns:1fr;
    padding:28px;
  }
}
@media(max-width:680px){
  .pricing-section{padding:52px 0;}
  .pricing-card{padding:22px;border-radius:24px;}
  .pricing-time strong{font-size:42px;}
}


/* Combined CTA Section */
.combined-cta-inner{
  display:grid;
  grid-template-columns:1.1fr .85fr;
  gap:48px;
  align-items:center;
}
.combined-cta-left h2{color:white;margin-bottom:10px;}
.combined-cta-left p{color:rgba(255,255,255,.82);font-size:15px;margin-bottom:20px;}
.pf-grid{display:grid;gap:8px;margin-bottom:0;}
.pf-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  border-radius:12px;
  color:rgba(255,255,255,.9);
  font-size:13px;font-weight:500;
}
.pf-item i{font-size:16px;color:var(--lime);flex-shrink:0;}
.combined-cta-right{
  display:flex;flex-direction:column;gap:14px;
  align-items:stretch;
}
.combined-actions{display:grid;gap:10px;}
.combined-actions .btn-primary{
  background:var(--lime);color:var(--green-950);
  font-size:15px;padding:14px 20px;text-align:center;
}
.combined-actions .btn-light{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.3);
  color:white;text-align:center;
}
.combined-actions .btn-ghost{
  background:transparent;
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.7);
  font-size:13px;text-align:center;
  padding:10px 20px;border-radius:var(--radius);
}
.cta-footnote{
  color:rgba(255,255,255,.5);font-size:12px;
  text-align:center;margin:0!important;
}
@media(max-width:860px){
  .combined-cta-inner{grid-template-columns:1fr;gap:28px;}
}


/* ── Blog ─────────────────────────────────────────────────────────────────── */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;
  margin-top:40px;
}
.blog-card{
  display:flex;flex-direction:column;gap:12px;
  background:#fff;border:1px solid var(--line);
  border-radius:24px;padding:28px;
  text-decoration:none;color:var(--ink);
  box-shadow:var(--soft-shadow);
  transition:transform .2s,box-shadow .2s;
}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.1);}
.blog-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.blog-tag{
  background:var(--mint2);color:var(--green-800);
  font-size:11px;font-weight:700;letter-spacing:.04em;
  padding:4px 12px;border-radius:20px;border:1px solid var(--line);
}
.blog-date{font-size:12px;color:var(--muted);}
.blog-card h2{font-size:18px;line-height:1.4;margin:0;}
.blog-card p{font-size:14px;color:var(--muted);line-height:1.75;margin:0;flex:1;}
.blog-card-footer{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--line);
  font-size:13px;color:var(--green-800);font-weight:600;
}
.blog-read-time{font-size:12px;color:var(--muted);font-weight:400;}

/* Article body */
.article-body{font-size:16px;line-height:1.85;color:var(--ink);}
.article-body h2{
  font-size:clamp(20px,2.2vw,26px);
  margin:48px 0 16px;color:var(--green-950);
}
.article-body h3{font-size:18px;margin:32px 0 12px;}
.article-body p{margin:0 0 18px;}
.article-body strong{font-weight:700;}
.article-callout{
  background:var(--mint2);border:1px solid var(--line);
  border-left:4px solid var(--green-800);
  border-radius:16px;padding:20px 22px;margin:28px 0;
}
.article-callout strong{display:block;margin-bottom:8px;font-size:15px;color:var(--green-950);}
.article-callout p{margin:0;font-size:14px;color:var(--muted);}
.article-callout-green{border-left-color:var(--lime);background:rgba(185,223,106,.12);}

.article-scope-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:24px 0 32px;}
.article-scope-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;
  box-shadow:var(--soft-shadow);
}
.article-scope-label{
  display:inline-block;background:var(--green-950);color:var(--lime);
  font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:10px;
}
.article-scope-title{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--ink);}
.article-scope-card p{font-size:13px;color:var(--muted);margin:0 0 10px;line-height:1.7;}
.article-scope-examples{font-size:12px;color:var(--green-800);font-weight:600;}

.article-reason-list{display:flex;flex-direction:column;gap:16px;margin:24px 0 32px;}
.article-reason-item{
  display:flex;gap:16px;align-items:flex-start;
  background:var(--mint2);border:1px solid var(--line);border-radius:16px;padding:18px 20px;
}
.article-reason-item i{font-size:22px;color:var(--green-800);flex-shrink:0;margin-top:2px;}
.article-reason-item strong{display:block;font-size:14px;margin-bottom:6px;}
.article-reason-item p{font-size:13px;color:var(--muted);margin:0;line-height:1.7;}

.article-steps{display:flex;flex-direction:column;gap:12px;margin:24px 0 32px;}
.article-step{
  display:flex;gap:16px;align-items:flex-start;
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 20px;
}
.article-step-num{
  background:var(--green-950);color:var(--lime);
  font-size:14px;font-weight:700;width:32px;height:32px;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.article-step strong{display:block;font-size:14px;margin-bottom:6px;}
.article-step p{font-size:13px;color:var(--muted);margin:0;line-height:1.7;}

@media(max-width:680px){
  .blog-grid{grid-template-columns:1fr;}
  .article-scope-grid{grid-template-columns:1fr;}
  .article-body h2{margin-top:36px;}
}


/* ── Article Visual Enhancements ───────────────────────────────────────────── */

/* SVG diagram colors for article (works light + dark) */
:root {
  --ab-s1-bg:#fdf3e3;--ab-s1-stroke:#d4931a;--ab-s1-text:#7a4f0a;--ab-s1-sub:#a06818;
  --ab-s2-bg:#e5f4ef;--ab-s2-stroke:#0e9e6e;--ab-s2-text:#0a5e40;--ab-s2-sub:#0e7a54;--ab-s2-chip:#d0ede3;
  --ab-s3-bg:#e8f0fc;--ab-s3-stroke:#3b7dd8;--ab-s3-text:#1a4a9e;--ab-s3-sub:#2558b8;--ab-s3-chip:#cdddf8;
  --ab-chip-bg:#f5f5f3;--ab-chip-stroke:#c8c6be;--ab-chip-text:#2c2c2a;--ab-chip-sub:#5f5e5a;
  --ab-legend:#5f5e5a;
}
@media(prefers-color-scheme:dark){
  :root{
    --ab-s1-bg:#3d2800;--ab-s1-stroke:#d4931a;--ab-s1-text:#fac75a;--ab-s1-sub:#e09a30;
    --ab-s2-bg:#003d28;--ab-s2-stroke:#1dcf90;--ab-s2-text:#7de8c0;--ab-s2-sub:#3ecfa0;--ab-s2-chip:#004d34;
    --ab-s3-bg:#001a4d;--ab-s3-stroke:#5b9cf6;--ab-s3-text:#a3c4fb;--ab-s3-sub:#7aaaf8;--ab-s3-chip:#002260;
    --ab-chip-bg:#2c2c2a;--ab-chip-stroke:#444441;--ab-chip-text:#d3d1c7;--ab-chip-sub:#888780;
    --ab-legend:#888780;
  }
}
.article-diagram-wrap{
  margin:24px 0 28px;
  background:var(--color-background-secondary);
  border:1px solid var(--line);
  border-radius:20px;
  padding:20px;
  overflow:hidden;
}

/* Process flow strip */
.article-flow-wrap{
  display:flex;align-items:center;gap:6px;
  margin:24px 0;padding:20px;
  background:var(--mint2);
  border:1px solid var(--line);
  border-radius:18px;
  flex-wrap:wrap;
  justify-content:center;
}
.article-flow-step{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:12px 16px;min-width:88px;
}
.article-flow-step-last{background:var(--green-950);}
.article-flow-step-last .article-flow-num{background:var(--lime);color:var(--green-950);}
.article-flow-step-last .article-flow-label{color:rgba(255,255,255,.85);}
.article-flow-num{
  background:var(--green-950);color:var(--lime);
  font-size:13px;font-weight:700;
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.article-flow-label{font-size:12px;font-weight:600;color:var(--ink);text-align:center;}
.article-flow-arrow{font-size:18px;color:var(--muted);}

/* CFO vs CFP comparison */
.article-compare-grid{
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:16px;align-items:center;margin:24px 0 28px;
}
.article-compare-card{
  background:#fff;border:1px solid var(--line);
  border-radius:20px;padding:22px;
}
.article-compare-left{border-top:3px solid var(--green-800);}
.article-compare-right{border-top:3px solid var(--green-700,#3b6d11);}
.article-compare-badge{
  display:inline-block;
  background:var(--green-950);color:var(--lime);
  font-size:11px;font-weight:700;letter-spacing:.06em;
  padding:3px 12px;border-radius:20px;margin-bottom:10px;
}
.article-compare-title{
  font-size:15px;font-weight:700;line-height:1.4;
  margin-bottom:14px;color:var(--ink);
}
.article-compare-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.article-compare-list li{
  font-size:13px;color:var(--muted);
  padding-left:16px;position:relative;line-height:1.6;
}
.article-compare-list li::before{content:"✓";position:absolute;left:0;color:var(--green-800);font-weight:700;}
.article-compare-vs{
  font-size:13px;font-weight:700;color:var(--muted);
  background:var(--mint2);border:1px solid var(--line);
  border-radius:50%;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
@media(max-width:600px){
  .article-compare-grid{grid-template-columns:1fr;gap:8px;}
  .article-compare-vs{display:none;}
  .article-flow-wrap{gap:4px;}
  .article-flow-step{min-width:72px;padding:10px 12px;}
}
