@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --ink:#1b262b; --muted:#66716a; --paper:#f5efe4; --soft:#fffaf0; --white:#fff;
  --olive:#5b6d4e; --olive-dark:#273326; --moss:#405039; --sand:#d9c49a; --clay:#a96d43; --gold:#be9b30;
  --line:rgba(27,38,43,.14); --shadow:0 24px 80px rgba(27,38,43,.15); --radius:24px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;color:var(--ink);background:var(--paper);font-family:Manrope,system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.62;font-size:16px} a{color:inherit;text-decoration:none} img{display:block;max-width:100%}.wrap{width:min(1180px,calc(100% - 40px));margin-inline:auto}.narrow{width:min(840px,calc(100% - 40px));margin-inline:auto}.serif{font-family:Manrope,Georgia,serif}.eyebrow,.kicker{letter-spacing:.12em;text-transform:uppercase;font-size:12px;font-weight:850}.eyebrow{color:var(--gold);margin-bottom:18px}.kicker{color:var(--clay);margin-bottom:14px}.muted{color:var(--muted)}
.topbar{position:sticky;top:0;z-index:100;background:rgba(245,239,228,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}.nav{min-height:86px;display:flex;align-items:center;gap:26px;justify-content:space-between}.brand{display:flex;align-items:center;min-width:210px}.brand img{width:174px;height:auto;object-fit:contain}.links{display:flex;align-items:center;gap:21px;font-size:14px;font-weight:760;color:#263239}.links a{opacity:.84}.links a:hover{opacity:1}.nav-cta{display:flex;align-items:center;gap:10px}.lang{font-size:13px;font-weight:800;color:var(--muted)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:13px 18px;font-size:14px;font-weight:850;border:1px solid transparent;transition:.18s ease;white-space:nowrap}.btn.primary{background:var(--ink);color:#fff}.btn.primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(27,38,43,.2)}.btn.secondary{background:rgba(255,255,255,.68);border-color:var(--line)}.btn.secondary:hover{background:#fff}.btn.ghost{border-color:rgba(255,255,255,.45);color:#fff;background:rgba(255,255,255,.10)}.btn.light{background:#fff;color:var(--ink)}
.mobile-toggle{display:none;background:transparent;border:0;font-weight:900;font-size:24px;color:var(--ink)}
.hero{position:relative;min-height:760px;display:flex;align-items:end;padding:140px 0 70px;overflow:hidden;background:#101614}.hero:before{content:"";position:absolute;inset:0;background:var(--hero-image, url('/assets/images/projects/wocal/wocal-camp-ke-ga-029-aerial-view.webp')) center/cover no-repeat;transform:scale(1.02)}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,23,22,.88),rgba(13,23,22,.58) 45%,rgba(13,23,22,.18)),linear-gradient(0deg,rgba(13,23,22,.72),rgba(13,23,22,0) 46%)}.hero .wrap{position:relative;z-index:1}.hero h1{font-family:Manrope,Georgia,serif;font-size:clamp(42px,6vw,78px);line-height:1.03;letter-spacing:-.045em;color:#fff;max-width:960px;margin:0 0 22px}.hero p{font-size:clamp(17px,2vw,21px);max-width:760px;color:rgba(255,255,255,.84);margin:0 0 30px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.hero-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:54px}.hero-card{background:rgba(255,250,240,.94);border:1px solid rgba(255,255,255,.42);border-radius:18px;padding:18px}.hero-card b{display:block;font-size:14px;margin-bottom:4px}.hero-card span{font-size:13px;color:var(--muted)}
.page-hero{padding:90px 0 54px;background:linear-gradient(135deg,var(--olive-dark),#17231f);color:#fff}.page-hero h1{font-family:Manrope,Georgia,serif;font-size:clamp(38px,5vw,68px);line-height:1.06;letter-spacing:-.045em;margin:0 0 18px;max-width:940px}.page-hero p{max-width:760px;color:rgba(255,255,255,.78);font-size:19px;margin:0}.breadcrumb{font-size:13px;color:rgba(255,255,255,.66);margin-bottom:20px}.breadcrumb a{color:rgba(255,255,255,.78)}
section{padding:82px 0}.section-head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:36px}.section-head h2{font-family:Manrope,Georgia,serif;font-size:clamp(32px,4vw,54px);line-height:1.08;letter-spacing:-.035em;margin:0}.section-head p{font-size:17px;color:var(--muted);margin:0}.split{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}.panel{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:34px}.panel h2,.panel h3{font-family:Manrope,Georgia,serif;font-size:clamp(28px,3vw,42px);line-height:1.12;letter-spacing:-.03em;margin:0 0 12px}.panel p{color:var(--muted)}.panel ul,.content ul{padding-left:20px;color:#415044}.panel li,.content li{margin:8px 0}.photo-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#ddd}.photo-card img{aspect-ratio:4/3;object-fit:cover;width:100%}.photo-card.tall img{aspect-ratio:3/4}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.photo-grid img{border-radius:20px;aspect-ratio:4/3;object-fit:cover;width:100%;box-shadow:0 10px 32px rgba(27,38,43,.08)}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{background:var(--soft);border:1px solid var(--line);border-radius:22px;overflow:hidden}.card img{width:100%;height:230px;object-fit:cover}.card .body{padding:22px}.tag{display:inline-flex;border:1px solid var(--line);border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;color:var(--olive-dark);background:rgba(255,255,255,.62)}.card h3{font-family:Manrope,Georgia,serif;font-size:24px;line-height:1.14;margin:13px 0 8px;letter-spacing:-.025em}.card p{font-size:14px;color:var(--muted);margin:0}.meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.dark{background:var(--ink);color:#fff}.dark .section-head p,.dark .muted{color:rgba(255,255,255,.68)}.dark .kicker{color:#e0bf58}.dark .card{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}.dark .card p{color:rgba(255,255,255,.68)}.dark .tag{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18);color:#fff}
.proof-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:18px}.proof-main,.proof-side{border-radius:24px;overflow:hidden;position:relative;min-height:480px;background:#1a1a1a}.proof-main img,.proof-side img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.proof-main:after,.proof-side:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.70),rgba(0,0,0,.05))}.caption{position:absolute;z-index:1;left:24px;right:24px;bottom:22px;color:#fff}.caption h3{font-family:Manrope,Georgia,serif;font-size:32px;line-height:1.05;margin:0 0 8px}.caption p{margin:0;color:rgba(255,255,255,.78)}.side-stack{display:grid;gap:18px}.proof-side{min-height:231px}.proof-side .caption h3{font-size:24px}.tech-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.tech{background:var(--soft);border:1px solid var(--line);border-radius:20px;padding:22px}.tech b{display:block;font-size:16px;margin-bottom:8px}.tech p{font-size:14px;color:var(--muted);margin:0}.process{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;counter-reset:step}.step{background:rgba(255,255,255,.58);border:1px solid var(--line);border-radius:20px;padding:22px;min-height:170px}.step:before{counter-increment:step;content:"0" counter(step);display:block;font-weight:900;color:var(--clay);margin-bottom:16px}.step b{display:block;margin-bottom:8px}.step span{font-size:14px;color:var(--muted)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:22px;background:var(--soft)}table{width:100%;border-collapse:collapse;min-width:720px}th,td{padding:17px 18px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left}th{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--moss)}td{color:#3f4b44}.content{font-size:17px}.content h2{font-family:Manrope,Georgia,serif;font-size:36px;line-height:1.12;margin:42px 0 12px}.content h3{font-size:22px;margin:26px 0 8px}.content p{color:#42504a}.note{border-left:4px solid var(--clay);padding:18px 22px;background:var(--soft);border-radius:0 18px 18px 0;color:#435046}.cta{background:linear-gradient(135deg,var(--olive-dark),#17231f);color:#fff;border-radius:32px;padding:48px;display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;box-shadow:var(--shadow)}.cta h2{font-family:Manrope,Georgia,serif;font-size:42px;line-height:1.08;letter-spacing:-.035em;margin:0 0 12px}.cta p{color:rgba(255,255,255,.74);margin:0}.formbox{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:22px}.formbox label{display:block;font-size:13px;font-weight:800;margin:12px 0 6px}.formbox input,.formbox select,.formbox textarea{width:100%;padding:12px 13px;border-radius:12px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.92);font:inherit}.formbox textarea{min-height:110px}.formbox button{margin-top:14px;width:100%}
footer{padding:54px 0 34px;background:#111b18;color:#fff}.foot{display:grid;grid-template-columns:1fr 1fr;gap:40px}.foot p,.foot a{color:rgba(255,255,255,.7);font-size:14px}.foot-nav{display:flex;gap:14px;flex-wrap:wrap;margin-top:16px}.contact-dock{position:fixed;right:18px;bottom:18px;z-index:120;display:flex;flex-direction:column;gap:10px}.dock{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#fff;color:var(--ink);box-shadow:0 12px 30px rgba(0,0,0,.18);font-weight:900;font-size:12px}.dock.zalo{background:#0a7cff;color:#fff}.dock.fb{background:#1877f2;color:#fff}.dock.phone{font-size:18px}.hidden{display:none!important}
@media (max-width:980px){.links{display:none}.mobile-toggle{display:block}.nav{min-height:76px}.brand img{width:154px}.nav-cta .secondary{display:none}.hero-cards,.section-head,.split,.proof-grid,.cta,.foot{grid-template-columns:1fr}.card-grid{grid-template-columns:1fr 1fr}.tech-grid,.process{grid-template-columns:1fr 1fr}.proof-main,.proof-side{min-height:330px}.cta{padding:32px}.photo-grid{grid-template-columns:1fr 1fr}.mobile-menu{display:none;position:absolute;top:76px;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--line);padding:14px 20px 22px}.mobile-menu a{display:block;padding:12px 0;font-weight:800}.mobile-menu.open{display:block}}
@media (max-width:620px){.wrap,.narrow{width:min(100% - 28px,1180px)}.hero{min-height:700px;padding-top:100px}.hero h1{font-size:42px}.card-grid,.tech-grid,.process,.photo-grid{grid-template-columns:1fr}.card img{height:250px}.photo-card img{aspect-ratio:1/1}.cta h2{font-size:31px}.hero-card{padding:15px}.hero-cards{gap:10px}.nav-cta .primary{display:none}}


/* v4 product detail system */
.product-nav{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}.product-nav a{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.08);color:#fff;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800}.spec-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}.spec-pill{background:rgba(255,250,240,.94);border:1px solid rgba(255,255,255,.38);border-radius:18px;padding:16px}.spec-pill b{display:block;font-size:20px;line-height:1.1}.spec-pill span{display:block;color:var(--muted);font-size:13px;margin-top:5px}.product-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}.product-intro h2,.spec-section h2{font-family:Manrope,Georgia,serif;font-size:clamp(31px,4vw,48px);line-height:1.1;letter-spacing:-.035em;margin:0 0 14px}.product-intro p,.spec-section p{color:var(--muted)}.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-top:22px}.fact{background:var(--soft);border:1px solid var(--line);border-radius:18px;padding:18px}.fact b{display:block;margin-bottom:5px}.fact span{font-size:14px;color:var(--muted)}.spec-section{padding-top:28px}.variant-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}.variant{background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:22px}.variant h3{font-family:Manrope,Georgia,serif;font-size:25px;margin:0 0 10px}.variant dl{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;margin:0}.variant dt{color:var(--muted);font-size:13px}.variant dd{margin:0;font-weight:800}.gallery-wide{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:14px}.gallery-wide img{width:100%;height:100%;min-height:280px;object-fit:cover;border-radius:22px}.material-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.material{background:var(--soft);border:1px solid var(--line);border-radius:20px;padding:20px}.material b{display:block;margin-bottom:7px}.material p{margin:0;color:var(--muted);font-size:14px}.notice{background:#fffaf0;border:1px solid var(--line);border-radius:22px;padding:22px;color:#48534d}.notice strong{color:var(--ink)}.compare-table td:first-child,.compare-table th:first-child{position:sticky;left:0;background:var(--soft);z-index:1}.foot-logo{max-width:175px;margin-bottom:14px}.footer-grid{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:36px}.copyright{margin-top:32px;color:rgba(255,255,255,.55);font-size:13px}.quick-contact{position:fixed;right:18px;bottom:18px;z-index:120;display:flex;flex-direction:column;gap:12px}.quick-contact a{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:transparent;box-shadow:0 10px 24px rgba(0,0,0,.16);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}.quick-contact a:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(0,0,0,.20)}.quick-contact a img{width:100%;height:100%;object-fit:cover;display:block}.quick-contact a span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(max-width:980px){.product-intro,.spec-strip,.facts,.variant-cards,.material-grid,.footer-grid{grid-template-columns:1fr 1fr}.gallery-wide{grid-template-columns:1fr}.gallery-wide img{min-height:220px}.spec-strip{margin-top:20px}}
@media(max-width:620px){.spec-strip,.facts,.variant-cards,.material-grid,.footer-grid{grid-template-columns:1fr}.product-nav{display:none}}

/* v6 customer-experience additions */
.tech a{color:inherit}
.tech:hover,.card:hover{transform:translateY(-2px);transition:.18s ease;box-shadow:0 16px 42px rgba(27,38,43,.10)}
.btn.secondary{background:#eef1e7;color:var(--olive-dark);border:1px solid var(--line)}
.formbox input::placeholder,.formbox textarea::placeholder{color:#7b8580}
.page-hero .breadcrumb{margin-bottom:18px}


/* v7 knowledge hub */
.hub-hero{padding:88px 0 52px;background:linear-gradient(135deg,#253327,#14211e);color:#fff}.hub-hero h1{font-family:Manrope,Georgia,serif;font-size:clamp(38px,5vw,68px);line-height:1.06;letter-spacing:-.045em;margin:0 0 18px;max-width:980px}.hub-hero p{max-width:780px;color:rgba(255,255,255,.78);font-size:19px;margin:0}.hub-layout{display:grid;grid-template-columns:1fr 320px;gap:34px;align-items:start}.article-list{display:grid;gap:18px}.article-card{display:grid;grid-template-columns:260px 1fr;gap:0;background:var(--soft);border:1px solid var(--line);border-radius:24px;overflow:hidden}.article-card img{height:100%;min-height:220px;width:100%;object-fit:cover}.article-card .body{padding:24px}.article-card h2,.article-card h3{font-family:Manrope,Georgia,serif;font-size:28px;line-height:1.12;margin:10px 0 10px;letter-spacing:-.025em}.article-card p{color:var(--muted);margin:0}.article-meta{display:flex;gap:9px;flex-wrap:wrap;color:var(--muted);font-size:13px;font-weight:750}.sidebar-box{background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:22px;position:sticky;top:110px}.sidebar-box h3{font-family:Manrope,Georgia,serif;font-size:24px;line-height:1.15;margin:0 0 12px}.sidebar-box a{display:block;padding:10px 0;border-bottom:1px solid var(--line);font-weight:760;color:#34443b}.sidebar-box a:last-child{border-bottom:0}.article{padding:68px 0}.article-wrap{display:grid;grid-template-columns:minmax(0,760px) 310px;gap:48px;align-items:start}.article-main{background:rgba(255,250,240,.55);border:1px solid var(--line);border-radius:28px;padding:38px}.article-main h2{font-family:Manrope,Georgia,serif;font-size:34px;line-height:1.15;margin:38px 0 12px;letter-spacing:-.025em}.article-main h3{font-size:22px;margin:26px 0 8px}.article-main p{color:#3f4e47}.article-main ul,.article-main ol{padding-left:22px;color:#3f4e47}.article-main li{margin:9px 0}.article-main .lead{font-size:20px;color:#33423b}.article-hero-img{border-radius:24px;overflow:hidden;margin:0 0 28px;box-shadow:var(--shadow)}.article-hero-img img{width:100%;aspect-ratio:16/9;object-fit:cover}.inline-cta{margin-top:34px;background:linear-gradient(135deg,var(--olive-dark),#17231f);color:#fff;border-radius:22px;padding:26px}.inline-cta h3{font-family:Manrope,Georgia,serif;font-size:27px;margin:0 0 8px}.inline-cta p{color:rgba(255,255,255,.74);margin-bottom:18px}.toc{background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:20px;position:sticky;top:110px}.toc h3{font-family:Manrope,Georgia,serif;font-size:22px;margin:0 0 12px}.toc a{display:block;padding:8px 0;color:#405039;font-weight:750;border-bottom:1px solid var(--line)}.toc a:last-child{border-bottom:0}.category-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}.category-strip a{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.08);color:#fff;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800}.source-note{margin-top:30px;font-size:13px;color:var(--muted);border-top:1px solid var(--line);padding-top:14px}
@media(max-width:980px){.hub-layout,.article-wrap{grid-template-columns:1fr}.sidebar-box,.toc{position:static}.article-card{grid-template-columns:1fr}.article-card img{height:250px}.article-main{padding:26px}}


/* v9 professionalism layer */
.faq-list{display:grid;gap:16px;margin-top:28px}.faq-item{background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:24px}.faq-item h3{font-family:Manrope,Georgia,serif;font-size:25px;line-height:1.16;margin:0 0 8px}.faq-item p{margin:0;color:#435046}.trust-line{font-size:13px;color:rgba(255,255,255,.62)}.footer-grid{grid-template-columns:1.2fr .8fr 1fr .8fr}.page-hero{background:linear-gradient(135deg,var(--olive-dark),#17231f)}
@media(max-width:980px){.footer-grid{grid-template-columns:1fr 1fr}.process{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.footer-grid,.process{grid-template-columns:1fr}}



/* V11 — header band with logo overhang */
.topbar{
  position:sticky !important;
  top:0 !important;
  z-index:100 !important;
  background:transparent !important;
  overflow:visible !important;
}
.topbar::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:82px;
  background:rgba(245,239,228,.94);
  border-bottom:1px solid rgba(27,38,43,.10);
  backdrop-filter:blur(14px);
  z-index:0;
}
.nav{
  position:relative !important;
  z-index:1 !important;
  min-height:96px !important;
  padding-top:10px !important;
  padding-bottom:0 !important;
  align-items:flex-start !important;
}
.brand{
  align-items:flex-start !important;
  min-width:210px !important;
}
.brand img{
  width:174px !important;
  height:auto !important;
  max-height:none !important;
  object-fit:contain !important;
  display:block !important;
  position:relative !important;
  z-index:2 !important;
}
.links,.nav-actions{
  padding-top:18px !important;
}
@media (max-width:900px){
  .topbar::before{height:74px}
  .nav{min-height:88px !important;padding-top:8px !important}
  .brand img{width:146px !important}
  .mobile-toggle{margin-top:18px}
}


/* V13 — image heroes and cleaner project form */
.page-hero,.hub-hero{
  position:relative;
  overflow:hidden;
  background:#17231f;
  isolation:isolate;
}
.page-hero::before,.hub-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--page-hero-image, url('/assets/images/projects/wocal/wocal-camp-ke-ga-029-aerial-view.webp')) center/cover no-repeat;
  transform:scale(1.03);
  z-index:-2;
}
.page-hero::after,.hub-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(15,24,22,.86),rgba(15,24,22,.58) 48%,rgba(15,24,22,.25)),
    linear-gradient(0deg,rgba(15,24,22,.62),rgba(15,24,22,.12) 55%);
  z-index:-1;
}
.page-hero h1,.hub-hero h1{max-width:900px;text-shadow:0 2px 18px rgba(0,0,0,.18)}
.page-hero p,.hub-hero p{max-width:720px;color:rgba(255,255,255,.86)}
.page-hero .eyebrow,.hub-hero .eyebrow{color:#e8c75c}
.formbox{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 16px;
  align-items:start;
}
.formbox .form-field{display:flex;flex-direction:column;gap:6px}
.formbox .form-field.full,.formbox .form-actions.full{grid-column:1/-1}
.formbox label{margin:0!important}
.formbox input,.formbox select,.formbox textarea{margin:0}
.formbox textarea{min-height:118px;resize:vertical}
.formbox .form-actions{display:flex;justify-content:flex-start;padding-top:4px}
@media(max-width:760px){.formbox{grid-template-columns:1fr}.page-hero,.hub-hero{padding-top:82px}}



/* V15 — richer expert articles */
.article-content{
  max-width: 880px;
  margin: 0 auto;
}
.article-content .article-kicker{
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .78rem;
  font-weight: 800;
  color: var(--accent);
  margin: 28px 0 10px;
}
.article-content h1{
  max-width: 820px;
  margin-bottom: 22px;
}
.article-content h2{
  margin-top: 42px;
  margin-bottom: 14px;
  font-size: clamp(1.35rem, 2vw, 2rem);
}
.article-content p{
  font-size: 1.05rem;
  line-height: 1.82;
  color: #33423b;
  margin: 0 0 18px;
}
.article-content p.lead{
  font-size: clamp(1.12rem, 1.6vw, 1.28rem);
  line-height: 1.75;
  color: #25322e;
}
.article-content ul{
  margin: 18px 0 26px;
  padding-left: 22px;
}
.article-content li{
  margin: 9px 0;
  line-height: 1.75;
  color:#33423b;
}
.article-note{
  margin: 38px 0;
  padding: 24px 26px;
  border-radius: 22px;
  border: 1px solid rgba(138,111,72,.22);
  background: rgba(245,239,228,.72);
  color:#2f3c36;
  line-height:1.72;
}
.article-cta{
  margin-top: 48px;
  padding: 32px;
  border-radius: 26px;
  background: #21352e;
  color: #fff;
}
.article-cta h2{
  color:#fff;
  margin-top:0;
}
.article-cta p{
  color:rgba(255,255,255,.84);
}
.article-cta .btn{
  margin-top: 6px;
}
@media(max-width:760px){
  .article-content p{font-size:1rem;line-height:1.75}
  .article-cta,.article-note{padding:22px}
}

/* V16 — concise decision blocks for product pages */
.decision-summary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin-top:34px;
  margin-bottom:18px;
}
.decision-summary>div{
  border:1px solid rgba(27,38,43,.12);
  background:rgba(255,255,255,.78);
  border-radius:22px;
  padding:24px;
  box-shadow:0 14px 34px rgba(0,0,0,.05);
}
.decision-summary h2{
  font-size:1.08rem;
  margin:0 0 8px;
}
.decision-summary p{
  margin:0;
  line-height:1.65;
  color:#425048;
}
@media(max-width:760px){
  .decision-summary{grid-template-columns:1fr}
}


/* V17 — header band transparency fix */
.topbar{
  background: transparent !important;
}
.topbar::before{
  background: #f5efe4 !important;
  opacity: 1 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
}
.nav,
.brand,
.links,
.nav-actions,
.mobile-panel{
  background: transparent !important;
}



/* V20 — typography refinement: Manrope + Manrope */
:root{
  --font-heading:'Manrope',serif;
  --font-body:'Manrope',sans-serif;
}
html,body{
  font-family:var(--font-body);
  font-weight:400;
  letter-spacing:-.004em;
  text-rendering:optimizeLegibility;
}
h1,h2,.hero h1,.page-hero h1,.article-content h1{
  font-family:var(--font-heading);
  font-weight:650;
  letter-spacing:-.035em;
  line-height:.98;
}
h3,h4,.card h3,.feature-card h3,.product-card h3,.decision-summary h2{
  font-family:var(--font-body);
  font-weight:650;
  letter-spacing:-.018em;
}
.hero h1{
  max-width:900px;
  font-size:clamp(3rem,7vw,6.25rem);
}
.hero p{
  max-width:680px;
  font-size:clamp(1.05rem,1.35vw,1.28rem);
  line-height:1.62;
  letter-spacing:-.006em;
}
.page-hero h1{
  max-width:920px;
  font-size:clamp(2.65rem,5.4vw,5.25rem);
}
.page-hero p{
  max-width:720px;
  font-size:clamp(1.04rem,1.25vw,1.22rem);
  line-height:1.62;
}
section h2,.section-title h2{
  font-size:clamp(2rem,3.4vw,3.55rem);
  line-height:1.04;
  letter-spacing:-.032em;
}
p,.content p,.text-block p{
  line-height:1.72;
}
.article-content{
  max-width:820px;
}
.article-content h1{
  font-size:clamp(2.35rem,4.6vw,4.65rem);
  line-height:1;
}
.article-content h2{
  font-family:var(--font-heading);
  font-weight:620;
  letter-spacing:-.03em;
  line-height:1.08;
}
.article-content p{
  max-width:760px;
  font-size:1.045rem;
  line-height:1.78;
}
.article-content p.lead{
  font-size:clamp(1.08rem,1.45vw,1.24rem);
  line-height:1.72;
}
.nav,.btn,.eyebrow,.kicker,label,input,select,textarea,button,.quick-contact,.footer,.spec-table,.decision-summary{
  font-family:var(--font-body);
}
.btn{
  font-weight:650;
  letter-spacing:-.006em;
}
.card p,.feature-card p,.product-card p,.decision-summary p{
  line-height:1.64;
}
.spec-table,.spec-table td,.spec-table th{
  font-size:.96rem;
  line-height:1.55;
}
@media(max-width:760px){
  .hero h1{font-size:clamp(2.45rem,13vw,4.1rem);line-height:1.02}
  .page-hero h1{font-size:clamp(2.2rem,11vw,3.65rem);line-height:1.04}
  section h2,.section-title h2{font-size:clamp(1.85rem,9vw,2.65rem)}
  .article-content h1{font-size:clamp(2rem,10vw,3.35rem)}
  .article-content p{font-size:1rem;line-height:1.74}
}



/* V21 — architectural typography and true transparent header lower area */
:root{
  --font-heading:'Manrope',serif;
  --font-body:'Manrope',sans-serif;
}
html,body{
  font-family:var(--font-body) !important;
}
h1,h2,.hero h1,.page-hero h1,.article-content h1,.article-content h2{
  font-family:var(--font-heading) !important;
  font-weight:400 !important;
  letter-spacing:-.045em;
  line-height:.96;
}
h3,h4,.card h3,.feature-card h3,.product-card h3,.decision-summary h2,
.nav,.btn,.eyebrow,.kicker,label,input,select,textarea,button,.footer,.spec-table{
  font-family:var(--font-body) !important;
}
.hero h1{font-size:clamp(3rem,7vw,6.15rem);max-width:900px}
.page-hero h1{font-size:clamp(2.65rem,5.4vw,5.2rem);max-width:920px}
section h2,.section-title h2{font-size:clamp(2rem,3.5vw,3.65rem);line-height:1}
.article-content h1{font-size:clamp(2.35rem,4.7vw,4.7rem)}
.article-content h2{font-size:clamp(1.45rem,2.25vw,2.35rem);line-height:1.04}

/* Header: only the cream band exists; everything below is fully transparent */
.topbar{
  background:transparent !important;
  background-color:transparent !important;
  box-shadow:none !important;
  border:0 !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  overflow:visible !important;
}
.topbar::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  top:0 !important;
  height:82px !important;
  background:#f5efe4 !important;
  opacity:1 !important;
  border-bottom:1px solid rgba(27,38,43,.10) !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  z-index:0 !important;
}
.topbar::after{display:none !important;content:none !important}
.nav{
  background:transparent !important;
  background-color:transparent !important;
  box-shadow:none !important;
  border:0 !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.nav::before,.nav::after,
.brand::before,.brand::after,
.links::before,.links::after,
.nav-actions::before,.nav-actions::after{
  display:none !important;
  content:none !important;
}
.brand,.links,.nav-actions{
  background:transparent !important;
  background-color:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
@media(max-width:900px){
  .topbar::before{height:74px !important}
}
@media(max-width:760px){
  .hero h1{font-size:clamp(2.5rem,13vw,4.05rem)}
  .page-hero h1{font-size:clamp(2.25rem,11vw,3.6rem)}
}



/* V22 — complete top transparency fix
   The cream header band remains. The logo overhang area below the band is fully transparent.
   Hero/page overlays start lower, so they do not create a grey veil behind the lower logo. */
.topbar,
.topbar .nav,
.topbar .brand,
.topbar .links,
.topbar .nav-actions{
  background:transparent !important;
  background-color:transparent !important;
  box-shadow:none !important;
  border:0 !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.topbar::before{
  height:82px !important;
  background:#f5efe4 !important;
  opacity:1 !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  box-shadow:none !important;
}
.topbar::after,
.nav::before,.nav::after,
.brand::before,.brand::after,
.links::before,.links::after,
.nav-actions::before,.nav-actions::after{
  display:none !important;
  content:none !important;
  background:transparent !important;
}

/* Home hero: transparent where logo overhangs, darker only where text begins */
.hero{
  background-image:
    linear-gradient(180deg,
      rgba(13,23,22,0) 0px,
      rgba(13,23,22,0) 150px,
      rgba(13,23,22,.30) 260px,
      rgba(13,23,22,.68) 100%),
    var(--hero-image) !important;
  background-size:cover !important;
  background-position:center !important;
}
.hero::before,
.hero::after{
  display:none !important;
  content:none !important;
  background:transparent !important;
}

/* Inner page heroes: same transparent top zone */
.page-hero,
.hub-hero{
  background-image:
    linear-gradient(180deg,
      rgba(13,23,22,0) 0px,
      rgba(13,23,22,0) 142px,
      rgba(13,23,22,.36) 230px,
      rgba(13,23,22,.70) 100%),
    var(--hero-image) !important;
  background-size:cover !important;
  background-position:center !important;
}
.page-hero::before,
.page-hero::after,
.hub-hero::before,
.hub-hero::after{
  display:none !important;
  content:none !important;
  background:transparent !important;
}

/* If any image block inside hero uses a generated overlay, remove it from the top area */
.hero .wrap,
.page-hero .wrap,
.hub-hero .wrap{
  position:relative !important;
  z-index:1 !important;
  background:transparent !important;
}

@media(max-width:900px){
  .topbar::before{height:74px !important}
  .hero{
    background-image:
      linear-gradient(180deg,
        rgba(13,23,22,0) 0px,
        rgba(13,23,22,0) 128px,
        rgba(13,23,22,.34) 220px,
        rgba(13,23,22,.72) 100%),
      var(--hero-image) !important;
  }
  .page-hero,
  .hub-hero{
    background-image:
      linear-gradient(180deg,
        rgba(13,23,22,0) 0px,
        rgba(13,23,22,0) 120px,
        rgba(13,23,22,.38) 200px,
        rgba(13,23,22,.72) 100%),
      var(--hero-image) !important;
  }
}



/* V24 — corporate premium typography: Manrope + Manrope */
:root{
  --font-heading:'Manrope',serif;
  --font-body:'Manrope',sans-serif;
}
html,body{
  font-family:var(--font-body) !important;
  font-weight:400;
  letter-spacing:0;
  text-rendering:optimizeLegibility;
}
h1,h2,.hero h1,.page-hero h1,.article-content h1,.article-content h2{
  font-family:var(--font-heading) !important;
  font-weight:400 !important;
  letter-spacing:-.025em !important;
  line-height:1.03 !important;
}
h3,h4,.card h3,.feature-card h3,.product-card h3,.decision-summary h2,
.nav,.btn,.eyebrow,.kicker,label,input,select,textarea,button,.footer,.spec-table{
  font-family:var(--font-body) !important;
}
.hero h1{
  font-size:clamp(2.85rem,6.2vw,5.65rem) !important;
  max-width:920px;
}
.hero p{
  font-family:var(--font-body) !important;
  font-size:clamp(1.05rem,1.28vw,1.22rem);
  line-height:1.58;
  max-width:690px;
}
.page-hero h1{
  font-size:clamp(2.45rem,4.9vw,4.8rem) !important;
  max-width:920px;
}
.page-hero p{
  font-family:var(--font-body) !important;
  font-size:clamp(1.04rem,1.2vw,1.18rem);
  line-height:1.6;
  max-width:720px;
}
section h2,.section-title h2{
  font-size:clamp(1.9rem,3.05vw,3.15rem) !important;
  line-height:1.08 !important;
  letter-spacing:-.022em !important;
}
.article-content h1{
  font-size:clamp(2.25rem,4.25vw,4.25rem) !important;
}
.article-content h2{
  font-size:clamp(1.4rem,2.05vw,2.15rem) !important;
  line-height:1.1 !important;
}
.article-content p{
  font-family:var(--font-body) !important;
  font-size:1.045rem;
  line-height:1.76;
}
.card h3,.feature-card h3,.product-card h3,.decision-summary h2{
  font-weight:650;
  letter-spacing:-.012em;
}
.btn{
  font-weight:700;
  letter-spacing:.002em;
}
@media(max-width:760px){
  .hero h1{font-size:clamp(2.35rem,11.5vw,3.75rem) !important}
  .page-hero h1{font-size:clamp(2.1rem,10vw,3.35rem) !important}
  section h2,.section-title h2{font-size:clamp(1.75rem,8.2vw,2.45rem) !important}
  .article-content h1{font-size:clamp(2rem,9.2vw,3.15rem) !important}
}



/* V25 — Manrope only */
:root{
  --font-heading:'Manrope',sans-serif;
  --font-body:'Manrope',sans-serif;
}
html,body,
h1,h2,h3,h4,h5,h6,
.hero h1,.page-hero h1,.article-content h1,.article-content h2,
.nav,.btn,.eyebrow,.kicker,label,input,select,textarea,button,
.footer,.spec-table,.decision-summary{
  font-family:'Manrope',sans-serif !important;
}
h1,h2,.hero h1,.page-hero h1,.article-content h1{
  font-weight:700 !important;
  letter-spacing:-.035em !important;
  line-height:1.03 !important;
}
h3,h4,.card h3,.feature-card h3,.product-card h3,.decision-summary h2{
  font-weight:700 !important;
  letter-spacing:-.018em !important;
}
.hero h1{
  font-size:clamp(2.75rem,5.8vw,5.35rem) !important;
  max-width:920px;
}
.page-hero h1{
  font-size:clamp(2.35rem,4.7vw,4.55rem) !important;
  max-width:920px;
}
section h2,.section-title h2{
  font-size:clamp(1.85rem,3vw,3.05rem) !important;
  font-weight:700 !important;
  letter-spacing:-.03em !important;
  line-height:1.08 !important;
}
.hero p,.page-hero p{
  font-weight:400;
  line-height:1.6;
}
.article-content h1{
  font-size:clamp(2.2rem,4.1vw,4.1rem) !important;
}
.article-content h2{
  font-weight:700 !important;
  letter-spacing:-.025em !important;
}
.article-content p{
  font-size:1.045rem;
  line-height:1.76;
}
.btn{
  font-weight:700 !important;
}
@media(max-width:760px){
  .hero h1{font-size:clamp(2.25rem,10.8vw,3.6rem) !important}
  .page-hero h1{font-size:clamp(2rem,9.5vw,3.25rem) !important}
  section h2,.section-title h2{font-size:clamp(1.7rem,8vw,2.35rem) !important}
  .article-content h1{font-size:clamp(1.95rem,9vw,3rem) !important}
}



/* V27 — Vietnamese-first typography: Manrope */
:root{
  --font-heading:'Manrope',sans-serif;
  --font-body:'Manrope',sans-serif;
}
html,body,
h1,h2,h3,h4,h5,h6,
.hero h1,.page-hero h1,.article-content h1,.article-content h2,
.nav,.btn,.eyebrow,.kicker,label,input,select,textarea,button,
.footer,.spec-table,.decision-summary{
  font-family:'Manrope',sans-serif !important;
}
body{
  font-weight:400;
  letter-spacing:-.002em;
}
h1,h2,.hero h1,.page-hero h1,.article-content h1{
  font-weight:700 !important;
  letter-spacing:-.04em !important;
  line-height:1.04 !important;
}
h3,h4,.card h3,.feature-card h3,.product-card h3,.decision-summary h2{
  font-weight:700 !important;
  letter-spacing:-.022em !important;
}
.hero h1{
  font-size:clamp(2.65rem,5.55vw,5.15rem) !important;
  max-width:920px;
}
.page-hero h1{
  font-size:clamp(2.25rem,4.45vw,4.35rem) !important;
  max-width:920px;
}
section h2,.section-title h2{
  font-size:clamp(1.8rem,2.85vw,2.95rem) !important;
  font-weight:700 !important;
  letter-spacing:-.034em !important;
  line-height:1.1 !important;
}
.hero p,.page-hero p{
  font-weight:400;
  line-height:1.62;
}
.article-content h1{
  font-size:clamp(2.1rem,3.95vw,3.95rem) !important;
}
.article-content h2{
  font-weight:700 !important;
  letter-spacing:-.028em !important;
}
.article-content p{
  font-size:1.03rem;
  line-height:1.76;
}
.btn{
  font-weight:700 !important;
}
.nav a{
  font-weight:600;
}
@media(max-width:760px){
  .hero h1{font-size:clamp(2.15rem,10.3vw,3.45rem) !important}
  .page-hero h1{font-size:clamp(1.95rem,9.2vw,3.1rem) !important}
  section h2,.section-title h2{font-size:clamp(1.62rem,7.6vw,2.25rem) !important}
  .article-content h1{font-size:clamp(1.88rem,8.7vw,2.85rem) !important}
}



/* V28 — Vietnamese line-break refinement */
body,p,li,a,span,div,h1,h2,h3,h4,h5,h6,
.hero h1,.hero p,.page-hero h1,.page-hero p,
.card h3,.card p,.feature-card h3,.feature-card p,
.article-content h1,.article-content h2,.article-content p,
.btn,.nav a{
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: manual !important;
}
.nav a,.btn,.eyebrow,.kicker{
  white-space: normal;
}
.hero h1,.page-hero h1,section h2,.section-title h2,.article-content h1,.article-content h2{
  text-wrap: balance;
}
p,.article-content p,.text-block p,.card p{
  text-wrap: pretty;
}
@supports not (text-wrap: balance){
  .hero h1,.page-hero h1,section h2,.section-title h2,.article-content h1,.article-content h2{
    word-break: normal !important;
    overflow-wrap: normal !important;
  }
}



/* V29 — Manrope only */
:root{
  --font-heading:'Manrope',sans-serif;
  --font-body:'Manrope',sans-serif;
}
html,body,
h1,h2,h3,h4,h5,h6,
.hero h1,.page-hero h1,.article-content h1,.article-content h2,
.nav,.btn,.eyebrow,.kicker,label,input,select,textarea,button,
.footer,.spec-table,.decision-summary{
  font-family:'Manrope',sans-serif !important;
}
body{
  font-weight:400;
  letter-spacing:-.004em;
}
h1,h2,.hero h1,.page-hero h1,.article-content h1{
  font-weight:700 !important;
  letter-spacing:-.055em !important;
  line-height:1.01 !important;
}
h3,h4,.card h3,.feature-card h3,.product-card h3,.decision-summary h2{
  font-weight:700 !important;
  letter-spacing:-.028em !important;
}
.hero h1{
  font-size:clamp(2.85rem,5.9vw,5.55rem) !important;
  max-width:920px;
}
.page-hero h1{
  font-size:clamp(2.35rem,4.75vw,4.6rem) !important;
  max-width:920px;
}
section h2,.section-title h2{
  font-size:clamp(1.88rem,3vw,3.08rem) !important;
  font-weight:700 !important;
  letter-spacing:-.045em !important;
  line-height:1.06 !important;
}
.hero p,.page-hero p{
  font-weight:400;
  line-height:1.58;
}
.article-content h1{
  font-size:clamp(2.18rem,4.15vw,4.05rem) !important;
}
.article-content h2{
  font-weight:700 !important;
  letter-spacing:-.038em !important;
}
.article-content p{
  font-size:1.035rem;
  line-height:1.74;
}
.btn{
  font-weight:700 !important;
}
.nav a{
  font-weight:650;
}
.card p,.feature-card p,.product-card p,.decision-summary p{
  line-height:1.62;
}
@media(max-width:760px){
  .hero h1{font-size:clamp(2.2rem,10.5vw,3.5rem) !important}
  .page-hero h1{font-size:clamp(2rem,9.5vw,3.15rem) !important}
  section h2,.section-title h2{font-size:clamp(1.68rem,7.7vw,2.32rem) !important}
  .article-content h1{font-size:clamp(1.9rem,8.8vw,2.9rem) !important}
}


/* V30 — homepage hero darker and remove redundant kicker */
.hero{
  background-image:
    linear-gradient(180deg,
      rgba(13,23,22,0) 0px,
      rgba(13,23,22,0) 140px,
      rgba(13,23,22,.42) 245px,
      rgba(13,23,22,.78) 100%),
    var(--hero-image) !important;
}
@media(max-width:900px){
  .hero{
    background-image:
      linear-gradient(180deg,
        rgba(13,23,22,0) 0px,
        rgba(13,23,22,0) 120px,
        rgba(13,23,22,.46) 210px,
        rgba(13,23,22,.80) 100%),
      var(--hero-image) !important;
  }
}



/* V31 — page hero image restoration and darker overlay */
.page-hero,
.hub-hero{
  background-image:
    linear-gradient(180deg,
      rgba(13,23,22,0) 0px,
      rgba(13,23,22,0) 125px,
      rgba(13,23,22,.48) 210px,
      rgba(13,23,22,.82) 100%),
    var(--page-hero-image, var(--hero-image, url('/assets/images/projects/wocal/wocal-camp-ke-ga-029-aerial-view.webp'))) !important;
  background-size:cover !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
  color:#fff !important;
}
.page-hero::before,
.page-hero::after,
.hub-hero::before,
.hub-hero::after{
  display:none !important;
  content:none !important;
  background:transparent !important;
}
.page-hero h1,
.page-hero p,
.hub-hero h1,
.hub-hero p{
  color:#fff !important;
  text-shadow:0 2px 18px rgba(0,0,0,.32);
}
@media(max-width:900px){
  .page-hero,
  .hub-hero{
    background-image:
      linear-gradient(180deg,
        rgba(13,23,22,0) 0px,
        rgba(13,23,22,0) 112px,
        rgba(13,23,22,.52) 190px,
        rgba(13,23,22,.84) 100%),
      var(--page-hero-image, var(--hero-image, url('/assets/images/projects/wocal/wocal-camp-ke-ga-029-aerial-view.webp'))) !important;
  }
}



/* V32 — business, SEO and conversion layer */
.fact-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-top:28px;
}
.fact-grid>div{
  border:1px solid rgba(27,38,43,.12);
  border-radius:20px;
  padding:20px;
  background:rgba(255,255,255,.82);
}
.fact-grid strong{
  display:block;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#8a6f48;
  margin-bottom:8px;
}
.fact-grid span{line-height:1.55;color:#2c3833}
.check-card{
  border-radius:24px;
  padding:28px;
  background:#21352e;
  color:#fff;
}
.check-card h3{margin-top:0;color:#fff}
.check-card li{margin:10px 0;line-height:1.55}
.compare-table-wrap{overflow-x:auto;border-radius:22px;border:1px solid rgba(27,38,43,.12);background:#fff}
.compare-table{width:100%;border-collapse:collapse;min-width:720px}
.compare-table th,.compare-table td{padding:18px 20px;border-bottom:1px solid rgba(27,38,43,.10);text-align:left;vertical-align:top;line-height:1.55}
.compare-table th{background:#f5efe4;color:#21352e;font-weight:700}
.compare-table tr:last-child td{border-bottom:0}
.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.image-grid img{width:100%;height:320px;object-fit:cover;border-radius:24px}
.cta-context .cta-card{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:center;
  border-radius:28px;
  padding:32px;
  background:#21352e;
  color:#fff;
}
.cta-card h2,.cta-card p{color:#fff}
.cta-card p{max-width:720px;opacity:.86}
.cards.three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.cards.three .card{text-decoration:none;color:inherit}
@media(max-width:900px){
  .fact-grid,.image-grid,.cards.three{grid-template-columns:1fr 1fr}
  .cta-context .cta-card{align-items:flex-start;flex-direction:column}
}
@media(max-width:680px){
  .fact-grid,.image-grid,.cards.three{grid-template-columns:1fr}
  .image-grid img{height:240px}
}
