/* ===================== Fonts & Tokens ===================== */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;700;900&display=swap');

:root{
  --green:#2f9e54;
  --green-d:#23854a;
  --green-l:#4cb96e;
  --green-tint:#eef8f1;
  --green-tint2:#f4faf6;
  --ink:#1f2a24;
  --ink-2:#3c4a42;
  --gray:#6b7a72;
  --gray-l:#9aa6a0;
  --line:#e7efe9;
  --bg:#ffffff;
  --dark:#1e2925;
  --shadow:0 18px 50px -20px rgba(34,90,55,.22);
  --shadow-sm:0 8px 24px -12px rgba(34,90,55,.18);
  --radius:16px;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans SC",-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ===================== Header ===================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s;
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 20px -16px rgba(0,0,0,.25)}
.header-inner{display:flex;align-items:center;gap:40px;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:20px;letter-spacing:.5px}
.brand-icon{width:30px;height:30px;display:grid;place-items:center;color:var(--green)}
.brand-icon svg{width:26px;height:26px}
.brand-name{color:var(--ink)}
.header-nav{display:flex;gap:30px;margin-left:6px}
.header-nav a{color:var(--ink-2);font-size:15px;font-weight:500;position:relative;padding:4px 0;transition:color .2s}
.header-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--green);transition:width .25s}
.header-nav a:hover{color:var(--green)}
.header-nav a:hover::after{width:100%}
.header-login{margin-left:auto;color:var(--ink-2);font-size:15px;font-weight:600;cursor:pointer;transition:color .2s}
.header-login:hover{color:var(--green)}

/* ===================== Buttons ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;border:none;transition:transform .15s, box-shadow .25s, background .25s}
.btn-primary{background:var(--green);color:#fff;padding:15px 40px;border-radius:30px;font-size:16px;box-shadow:0 14px 30px -12px rgba(47,158,84,.6)}
.btn-primary:hover{background:var(--green-d);transform:translateY(-2px);box-shadow:0 20px 36px -12px rgba(47,158,84,.7)}
.btn-white{background:#fff;color:var(--green-d);padding:15px 46px;border-radius:12px;font-size:17px;box-shadow:0 14px 30px -10px rgba(0,0,0,.18)}
.btn-white:hover{transform:translateY(-2px);background:#f3fff7}

/* ===================== Hero ===================== */
.hero{position:relative;overflow:hidden;padding:64px 0 80px}
.hero-bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(1100px 520px at 8% -8%, #e7f6ec 0%, rgba(231,246,236,0) 60%),
    radial-gradient(900px 500px at 100% 0%, #effaf2 0%, rgba(239,250,242,0) 55%),
    linear-gradient(180deg,#f6fbf7 0%, #ffffff 70%);
}
.hero-bg::after{
  content:"";position:absolute;left:-5%;bottom:-40px;width:60%;height:240px;
  background:radial-gradient(closest-side, rgba(76,185,110,.18), transparent);
  filter:blur(10px);
}
.hero-grid{display:grid;grid-template-columns:0.82fr 1.18fr;gap:48px;align-items:center}
.hero-title{font-size:54px;font-weight:900;line-height:1.18;letter-spacing:1px;color:var(--ink)}
.hero-title .accent{color:var(--green)}
.hero-sub{margin-top:22px;font-size:17px;color:var(--gray);line-height:1.9}
.hero-points{list-style:none;display:flex;align-items:center;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero-points li{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--ink-2)}
.hero-points .sep{width:1px;height:16px;background:var(--line)}
.chk{width:22px;height:22px;border-radius:7px;background:var(--green-tint);color:var(--green);display:grid;place-items:center}
.chk svg{width:14px;height:14px}
.hero-copy .btn-primary{margin-top:38px}

/* ===================== Dashboard mock ===================== */
.hero-visual{position:relative}
.dash{
  position:relative;display:flex;background:#fff;border-radius:18px;
  box-shadow:0 30px 70px -24px rgba(31,80,48,.4);
  border:1px solid var(--line);overflow:hidden;min-height:340px;
}
.dash-side{width:54px;background:var(--dark);display:flex;flex-direction:column;align-items:center;padding:14px 0;gap:18px;flex-shrink:0}
.dash-logo{width:30px;height:30px;border-radius:9px;background:var(--green);color:#fff;display:grid;place-items:center}
.dash-logo svg{width:18px;height:18px}
.dash-menu{list-style:none;display:flex;flex-direction:column;gap:14px;width:100%;align-items:center}
.dash-menu li{width:34px;height:30px;border-radius:8px;display:grid;place-items:center}
.dash-menu li i{width:16px;height:16px;border-radius:4px;border:1.6px solid #5d6b64}
.dash-menu li.on{background:var(--green)}
.dash-menu li.on i{border-color:#fff;background:rgba(255,255,255,.2)}
.dash-main{flex:1;padding:14px 14px 16px;display:flex;flex-direction:column;gap:10px;min-width:0}
.dash-topbar{display:flex;justify-content:space-between;align-items:center}
.dt-title{font-size:13px;font-weight:700;color:var(--ink)}
.dt-pill{font-size:10px;background:var(--green-tint);color:var(--green-d);padding:3px 10px;border-radius:20px;font-weight:600}
.dash-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.kpi{background:var(--green-tint2);border:1px solid var(--line);border-radius:10px;padding:8px 9px}
.kpi-label{font-size:9px;color:var(--gray)}
.kpi b{display:block;font-size:15px;color:var(--ink);margin-top:2px;font-weight:800;white-space:nowrap}
.kpi em{font-size:8px;font-style:normal}
.up{color:var(--green)}
.dash-row{display:flex;gap:8px}
.dash-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 10px}
.dash-card.grow{flex:1.6}
.dc-title{font-size:10px;color:var(--gray);font-weight:600;display:block;margin-bottom:5px}
.line-chart{width:100%;height:54px;display:block}
.donut-card{flex:1;display:flex;flex-direction:column;align-items:center}
.donut{
  --p:80;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;position:relative;margin-top:3px;
  background:conic-gradient(var(--green) calc(var(--p)*1%), #e9f0eb 0);
}
.donut::after{content:"";position:absolute;inset:8px;background:#fff;border-radius:50%}
.donut span{position:relative;z-index:1;font-size:13px;font-weight:800;color:var(--ink)}
.mini-stats{flex:1;display:flex;justify-content:space-around;align-items:center;text-align:center}
.mini-stats b{font-size:16px;font-weight:800;color:var(--ink);display:block}
.mini-stats span{font-size:9px;color:var(--gray)}
.notice{flex:1.2}
.notice p{font-size:9.5px;color:var(--ink-2);margin-top:4px;display:flex;justify-content:space-between}
.notice small{color:var(--gray-l)}

/* floating cards */
.dash-floats{position:absolute;right:-8px;top:18px;bottom:18px;display:flex;flex-direction:column;justify-content:space-between;gap:8px}
.float-card{
  display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:9px 11px;box-shadow:var(--shadow-sm);min-width:124px;
}
.float-card em{font-size:9px;color:var(--gray);font-style:normal;display:block}
.float-card b{font-size:18px;font-weight:800;color:var(--ink);line-height:1.1}
.float-card i{font-size:8px;font-style:normal}
.fc-icon{width:30px;height:30px;border-radius:9px;background:var(--green-tint);flex-shrink:0;position:relative}
.fc-icon::after{content:"";position:absolute;inset:7px;background:var(--green);-webkit-mask:center/contain no-repeat;mask:center/contain no-repeat}
.fc-icon.wrench::after{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.7 6.3a4 4 0 0 0-5.3 5.3l-6 6 2.7 2.7 6-6a4 4 0 0 0 5.3-5.3l-2.4 2.4-2-2 2.4-2.4Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.7 6.3a4 4 0 0 0-5.3 5.3l-6 6 2.7 2.7 6-6a4 4 0 0 0 5.3-5.3l-2.4 2.4-2-2 2.4-2.4Z'/%3E%3C/svg%3E")}
.fc-icon.target::after{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3C/svg%3E")}
.fc-icon.check::after{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m9 11 3 3L22 4'/%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m9 11 3 3L22 4'/%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'/%3E%3C/svg%3E")}
.fc-icon.smile::after{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M8 14s1.5 2 4 2 4-2 4-2'/%3E%3Cline x1='9' y1='9' x2='9.01' y2='9'/%3E%3Cline x1='15' y1='9' x2='15.01' y2='9'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M8 14s1.5 2 4 2 4-2 4-2'/%3E%3Cline x1='9' y1='9' x2='9.01' y2='9'/%3E%3Cline x1='15' y1='9' x2='15.01' y2='9'/%3E%3C/svg%3E")}

/* ===================== Sections ===================== */
.section{padding:62px 0}
.section-tint{background:linear-gradient(180deg,var(--green-tint2),#fff)}
.section-title{text-align:center;font-size:30px;font-weight:800;color:var(--ink);margin-bottom:42px;position:relative}
.section-title.left{text-align:left}
.section-title::after{content:"";display:block;width:42px;height:3px;border-radius:2px;background:var(--green);margin:14px auto 0}
.section-title.left::after{margin-left:0}

/* core capability */
.cap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cap-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .25s, box-shadow .25s, border-color .25s}
.cap-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#cfe7d6}
.cap-icon{width:48px;height:48px;border-radius:12px;background:var(--green-tint);color:var(--green);display:grid;place-items:center;margin-bottom:18px}
.cap-icon svg{width:26px;height:26px}
.cap-card h3{font-size:18px;font-weight:700;margin-bottom:10px}
.cap-card p{font-size:14px;color:var(--gray);line-height:1.8}

/* process */
.process-grid{display:flex;align-items:center;justify-content:center;gap:8px}
.proc-card{flex:1;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;text-align:left;max-width:240px;transition:transform .25s, box-shadow .25s}
.proc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.proc-icon{width:46px;height:46px;border-radius:50%;background:var(--green-tint);color:var(--green);display:grid;place-items:center;margin-bottom:16px}
.proc-icon svg{width:24px;height:24px}
.proc-card h3{font-size:17px;font-weight:700;margin-bottom:8px}
.proc-card p{font-size:13px;color:var(--gray);line-height:1.7}
.proc-arrow{color:var(--green-l);font-size:18px;letter-spacing:-2px;flex-shrink:0;opacity:.7}

/* two-col panels */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:stretch}
.panel{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;box-shadow:var(--shadow-sm)}
.panel-title{font-size:21px;font-weight:800;margin-bottom:22px;position:relative;padding-left:14px}
.panel-title::before{content:"";position:absolute;left:0;top:3px;width:5px;height:20px;border-radius:3px;background:var(--green)}

/* equipment */
.equip-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:18px}
.equip-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.equip-list li{display:flex;gap:11px;align-items:flex-start}
.el-icon{width:34px;height:34px;border-radius:10px;background:var(--green-tint);color:var(--green);display:grid;place-items:center;flex-shrink:0}
.el-icon svg{width:18px;height:18px}
.equip-list b{font-size:14px;display:block}
.equip-list span{font-size:12px;color:var(--gray)}
.equip-photo{position:relative;border-radius:14px;overflow:hidden;min-height:200px}
.equip-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.equip-stats{position:absolute;right:10px;top:10px;background:rgba(255,255,255,.94);border-radius:12px;padding:12px 14px;backdrop-filter:blur(4px);box-shadow:var(--shadow-sm)}
.equip-stats h4{font-size:12px;margin-bottom:8px;color:var(--ink)}
.equip-stats p{font-size:11.5px;display:flex;align-items:center;gap:6px;color:var(--ink-2);margin:3px 0}
.equip-stats b{margin-left:auto;font-weight:800}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.g{background:var(--green)}.dot.o{background:#f0883e}.dot.y{background:#e8b53d}
.dot.ltg{background:#bfe6cb}.dot.mg{background:#6cc488}.dot.dg{background:#206e3e}

/* quality */
.quality-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.qk{background:var(--green-tint2);border:1px solid var(--line);border-radius:12px;padding:12px;display:flex;gap:9px;align-items:center}
.qk-icon{width:30px;height:30px;border-radius:8px;background:#dcefe2;flex-shrink:0}
.qk-icon.green{background:var(--green)}
.qk b{font-size:20px;font-weight:800;display:block;line-height:1}
.qk em{font-size:11px;color:var(--gray);font-style:normal}
.quality-body{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.qt-title{font-size:13px;font-weight:700;display:block;margin-bottom:8px}
.quality-table table{width:100%;border-collapse:collapse}
.quality-table td{font-size:11.5px;padding:7px 4px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.quality-table td:first-child{color:var(--ink)}
.quality-table .ok{color:var(--green);font-weight:600}
.quality-table .warn{color:#e08a3c;font-weight:600}
.quality-donut{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.qd-cap{font-size:12px;color:var(--gray);margin-top:6px}
.quality-donut ul{list-style:none;margin-top:10px;display:flex;flex-direction:column;gap:5px}
.quality-donut li{font-size:11px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.donut.big{--p:86;width:96px;height:96px}
.donut.big span{font-size:18px}
.donut.big::after{inset:11px}

/* ===================== Mobile office ===================== */
.mobile-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.phones{position:relative;height:380px;display:flex;justify-content:center;align-items:center}
.phone{width:160px;height:330px;background:#10221a;border-radius:28px;padding:8px;box-shadow:0 30px 60px -20px rgba(20,60,35,.5);position:absolute}
.phone-screen{width:100%;height:100%;border-radius:22px;overflow:hidden;background:#f2f7f3;position:relative}
.phone-screen::before{content:"";position:absolute;top:0;left:0;right:0;height:74px;background:linear-gradient(135deg,var(--green),var(--green-l))}
.phone-back{transform:translateX(-110px) scale(.9) rotate(-5deg);z-index:1;opacity:.92}
.phone-side{transform:translateX(110px) scale(.9) rotate(5deg);z-index:1;opacity:.92}
.phone-front{z-index:3}
.ps-home .psh-apps{position:absolute;top:88px;left:14px;right:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ps-home .psh-apps::before{content:"";grid-column:1/-1;height:0}
.ps-home::after{content:"";position:absolute;top:90px;left:14px;right:14px;bottom:20px;
  background-image:radial-gradient(circle at 16px 16px, #cfe7d6 13px, transparent 14px);
  background-size:48px 56px;background-position:0 0;opacity:.9}
.ps-grid::after,.ps-list::after{content:"";position:absolute;top:86px;left:12px;right:12px;bottom:16px;
  background-image:linear-gradient(#e0ece4 0 0);background-size:100% 26px;background-repeat:repeat-y;opacity:.6}

.mobile-feats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.mf{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;transition:transform .2s,box-shadow .2s}
.mf:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.mf-icon{width:38px;height:38px;border-radius:10px;background:var(--green-tint);color:var(--green);display:grid;place-items:center;flex-shrink:0}
.mf-icon svg{width:20px;height:20px}
.mf b{font-size:15px;display:block;margin-bottom:3px}
.mf span{font-size:12.5px;color:var(--gray)}

/* ===================== Cockpit ===================== */
.cockpit{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;box-shadow:var(--shadow-sm)}
.cockpit-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.ck{background:var(--green-tint2);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.ck em{font-size:12.5px;color:var(--gray);font-style:normal}
.ck b{display:block;font-size:30px;font-weight:800;color:var(--ink);margin:4px 0}
.ck i{font-size:11px;font-style:normal}
.cockpit-charts{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.chart-box{background:var(--green-tint2);border:1px solid var(--line);border-radius:14px;padding:16px}
.cb-title{font-size:13px;font-weight:700;display:block;margin-bottom:10px}
.bar-chart,.trend-chart{width:100%;height:130px}
.pie-wrap{display:flex;align-items:center;gap:14px}
.donut.big2{--p:48;width:108px;height:108px;border-radius:50%;position:relative;display:grid;place-items:center;flex-shrink:0;
  background:conic-gradient(var(--green) 0 48%, #6cc488 48% 64%, #2f9e54aa 64% 80%, #bfe6cb 80% 100%);}
.donut.big2::after{content:"";position:absolute;inset:14px;background:var(--green-tint2);border-radius:50%}
.donut.big2 span{position:relative;z-index:1;text-align:center}
.donut.big2 b{font-size:18px;font-weight:800;color:var(--ink);display:block;line-height:1}
.donut.big2 small{font-size:10px;color:var(--gray)}
.pie-legend{list-style:none;display:flex;flex-direction:column;gap:8px}
.pie-legend li{font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:7px}
.pie-legend b{margin-left:auto;color:var(--ink)}

/* ===================== Solutions ===================== */
.sol-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.sol-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .25s,box-shadow .25s}
.sol-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.sol-card img{width:100%;height:120px;object-fit:cover}
.sol-card>div{padding:18px 20px}
.sol-card h3{font-size:17px;font-weight:700;margin-bottom:8px}
.sol-card p{font-size:13px;color:var(--gray);line-height:1.7}

/* ===================== Customer value ===================== */
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.value-card{text-align:center;padding:34px 28px;border-radius:var(--radius);background:linear-gradient(180deg,var(--green-tint2),#fff);border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.value-icon{width:62px;height:62px;border-radius:50%;background:var(--green-tint);color:var(--green);display:grid;place-items:center;margin:0 auto 18px}
.value-icon svg{width:30px;height:30px}
.value-card h3{font-size:19px;font-weight:700;color:var(--green-d);margin-bottom:10px}
.value-card p{font-size:14px;color:var(--gray);line-height:1.8}

/* ===================== CTA ===================== */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(115deg,var(--green-d),var(--green) 55%,var(--green-l));color:#fff}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:48px 28px;position:relative;z-index:2}
.cta-text h2{font-size:30px;font-weight:800;margin-bottom:10px}
.cta-text p{font-size:16px;opacity:.92}
.cta-skyline{position:absolute;right:0;bottom:0;width:55%;height:100%;z-index:1;opacity:.35;
  background:url("assets/skyline.svg") right bottom / contain no-repeat}

/* ===================== Footer ===================== */
.site-footer{background:#13201a;color:#cdd8d1;padding:34px 0}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.footer-brand .brand-name{color:#fff}
.footer-brand .brand-icon{color:var(--green-l)}
.footer-copy{font-size:13px;color:#8b988f}

/* ===================== Reveal animation ===================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ===================== Responsive ===================== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-title{font-size:42px}
  .dash-floats{position:static;flex-direction:row;flex-wrap:wrap;margin-top:14px}
  .cap-grid,.sol-grid{grid-template-columns:repeat(2,1fr)}
  .two-col,.mobile-grid{grid-template-columns:1fr}
  .cockpit-charts{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .process-grid{flex-wrap:wrap}
  .proc-arrow{display:none}
  .header-nav{display:none}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .hero-title{font-size:34px}
  .cap-grid,.sol-grid,.cockpit-kpis,.quality-kpis,.dash-kpis,.mobile-feats{grid-template-columns:1fr 1fr}
  .equip-grid,.quality-body{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;text-align:center}
  .phones{transform:scale(.85)}
}
