:root{
    --brand:#2b528e; --brand-dark:#1b3563; --brand-darker:#16294d;
    --accent:#ff5a00; --teal:#16a9c0;
    --ink:#1d2733; --muted:#5f6b7a; --line:#e6eaf0;
    --bg:#f4f7fb; --card:#ffffff;
    --shadow:0 6px 24px rgba(22,41,77,.08); --shadow-lg:0 14px 40px rgba(22,41,77,.14);
    --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    color:var(--ink);background:var(--bg);line-height:1.6;font-size:16px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 20px}

/* ---------- top utility bar ---------- */
.topbar{background:var(--brand-darker);color:#cdd8ec;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;height:38px}
.topbar a:hover{color:#fff}
.topbar .tline{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .contact{display:flex;gap:18px;white-space:nowrap}
@media(max-width:760px){.topbar .contact{display:none}}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
    backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.logo img{height:46px;width:auto}
nav.main{display:flex;align-items:center;gap:8px}
nav.main a{padding:10px 16px;border-radius:10px;font-weight:600;color:var(--brand-dark);
    font-size:15px;transition:.18s}
nav.main a:hover{background:#eef3fb;color:var(--brand)}
nav.main a.active{color:var(--brand)}
nav.main a.cta{background:var(--accent);color:#fff}
nav.main a.cta:hover{background:#e64f00;color:#fff}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:3px;background:var(--brand-dark);margin:5px 0;border-radius:3px;transition:.2s}
@media(max-width:860px){
    nav.main{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;
        background:#fff;border-bottom:1px solid var(--line);padding:14px 20px;gap:6px;
        transform:translateY(-120%);transition:transform .28s;box-shadow:var(--shadow);
        visibility:hidden}
    nav.main.open{transform:translateY(0);visibility:visible}
    .nav-toggle{display:block}
}

/* ---------- news ticker ---------- */
.newsbar{background:#fff;border-bottom:1px solid var(--line)}
.newsbar .wrap{display:flex;align-items:center;gap:16px;height:46px;overflow:hidden}
.news-pill{flex:none;background:var(--accent);color:#fff;font-weight:700;font-size:12px;
    letter-spacing:.04em;text-transform:uppercase;padding:5px 12px;border-radius:20px}
.ticker{flex:1;overflow:hidden;white-space:nowrap}
.ticker a{display:inline-block;padding-left:100%;font-size:14px;color:var(--muted);
    animation:ticker 22s linear infinite}
.ticker a:hover{color:var(--brand);animation-play-state:paused}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

/* ---------- hero ---------- */
.hero{padding:34px 0 10px}
.hero-grid{display:grid;grid-template-columns:1fr 340px;gap:24px}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr}}

.slider{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
    background:var(--brand-dark)}
.slide{display:none;position:relative}
.slide.active{display:block;animation:fade .8s ease}
@keyframes fade{from{opacity:.2}to{opacity:1}}
.slide img{width:100%;height:360px;object-fit:cover;object-position:center right}
@media(max-width:960px){.slide img{height:280px}}
@media(max-width:520px){.slide img{height:220px}}
.slide-cap{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
    padding:0 9%;background:linear-gradient(90deg,rgba(16,41,77,.9) 0%,rgba(16,41,77,.55) 46%,rgba(16,41,77,0) 78%)}
.slide-cap h2{color:#fff;font-size:27px;font-weight:800;line-height:1.25;max-width:62%;
    text-shadow:0 2px 12px rgba(0,0,0,.35)}
@media(max-width:520px){.slide-cap{padding:0 7%}.slide-cap h2{font-size:17px;max-width:88%}}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;
    width:42px;height:42px;border:0;border-radius:50%;cursor:pointer;
    background:rgba(255,255,255,.85);color:var(--brand-dark);font-size:20px;line-height:1;
    display:flex;align-items:center;justify-content:center;transition:.18s}
.slider-btn:hover{background:#fff}
.slider-btn.prev{left:14px}.slider-btn.next{right:14px}
.dots{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:center;gap:8px;z-index:3}
.dots button{width:10px;height:10px;border-radius:50%;border:0;cursor:pointer;
    background:rgba(255,255,255,.55);transition:.2s}
.dots button.active{background:#fff;width:26px;border-radius:6px}

/* ---------- price card ---------- */
.price-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
    overflow:hidden;border:1px solid var(--line);align-self:start}
.price-head{background:var(--accent);color:#fff;text-align:center;font-weight:700;
    padding:12px;font-size:15px;letter-spacing:.02em}
table.pricetbl{width:100%;border-collapse:collapse;table-layout:fixed;font-size:14px}
table.pricetbl th{background:var(--brand);color:#fff;font-weight:600;font-size:13px;
    padding:10px 6px;text-align:center}
table.pricetbl th:first-child{text-align:left;padding-left:14px;width:46%}
table.pricetbl td{padding:11px 6px;text-align:center;border-top:1px solid var(--line);vertical-align:middle}
table.pricetbl td:first-child{text-align:left;padding-left:14px;font-weight:600;color:var(--ink)}
table.pricetbl tbody tr:hover{background:#f7faff}
.pricetbl .unit{display:block;color:var(--muted);font-size:11px;font-weight:400}
.price-note{font-size:11px;color:var(--muted);padding:10px 14px;background:#fafbfd}

/* ---------- section heading ---------- */
.section{padding:48px 0}
.section h2{font-size:30px;font-weight:800;color:var(--brand-dark);text-align:center}
.section .sub{text-align:center;color:var(--muted);max-width:680px;margin:10px auto 0}
.eyebrow{display:block;text-align:center;color:var(--accent);font-weight:700;font-size:13px;
    letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}

/* ---------- about ---------- */
.about{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about p.lead{max-width:900px;margin:18px auto 0;text-align:center;font-size:18px;color:#33414f}

/* ---------- services grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
    overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.22s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card .thumb{height:170px;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .thumb img{transform:scale(1.06)}
.card .body{padding:20px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:18px;color:var(--brand-dark);margin-bottom:8px}
.card p{color:var(--muted);font-size:14.5px;flex:1}
.readmore{margin-top:14px;align-self:flex-start;background:none;border:0;cursor:pointer;
    color:var(--accent);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px}
.readmore:hover{gap:10px}

/* ---------- modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(16,28,48,.55);z-index:100;
    display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex;animation:fade .2s}
.modal{background:#fff;border-radius:var(--radius);max-width:560px;width:100%;
    box-shadow:var(--shadow-lg);overflow:hidden}
.modal-head{background:var(--brand);color:#fff;padding:18px 22px;display:flex;
    justify-content:space-between;align-items:center;gap:16px}
.modal-head h3{font-size:19px}
.modal-close{background:none;border:0;color:#fff;font-size:26px;line-height:1;cursor:pointer;opacity:.85}
.modal-close:hover{opacity:1}
.modal-body{padding:22px;color:#39454f;font-size:15.5px}

/* ---------- inner page hero band ---------- */
.page-hero{background:linear-gradient(120deg,var(--brand-darker),var(--brand));color:#fff;padding:54px 0}
.page-hero .eyebrow{color:#ffd2b8;text-align:left;margin-bottom:6px}
.page-hero h1{font-size:34px;font-weight:800;line-height:1.2}
.page-hero p{color:#cdd8ec;max-width:780px;margin-top:12px}
@media(max-width:600px){.page-hero h1{font-size:26px}}

/* ---------- solution blocks ---------- */
.sol-intro{max-width:920px;color:#39454f;font-size:17px}
.sol-block{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow);padding:28px;margin-top:24px}
.sol-block h3{color:var(--brand-dark);font-size:22px;margin-bottom:8px;display:flex;align-items:center;gap:11px}
.sol-block h3 .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);flex:none}
.sol-block .intro{color:var(--muted);margin-bottom:18px}
.sol-list{display:grid;grid-template-columns:1fr 1fr;gap:9px 28px;list-style:none}
@media(max-width:640px){.sol-list{grid-template-columns:1fr}}
.sol-list li{position:relative;padding-left:26px;color:#39454f;font-size:15px}
.sol-list li::before{content:"";position:absolute;left:6px;top:5px;width:6px;height:11px;
    border:solid var(--teal);border-width:0 2px 2px 0;transform:rotate(45deg)}

/* ---------- news list ---------- */
.news-list{display:grid;gap:20px}
.news-item{background:#fff;border:1px solid var(--line);border-left:4px solid var(--accent);
    border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 26px}
.news-item .date{color:var(--accent);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.05em}
.news-item h3{color:var(--brand-dark);font-size:20px;margin:6px 0 8px}
.news-item p{color:var(--muted);font-size:15px}

/* ---------- footer ---------- */
footer{background:var(--brand-darker);color:#c3cfe4;padding:40px 0 26px;margin-top:10px}
.foot-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;align-items:flex-start}
footer .ftitle{color:#fff;font-weight:700;margin-bottom:8px;font-size:15px}
footer a:hover{color:#fff}
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;
    justify-content:center;background:rgba(255,255,255,.1);transition:.2s}
.socials a:hover{background:var(--accent)}
.socials svg{width:18px;height:18px;fill:#fff}
.copyright{text-align:center;margin-top:28px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);
    font-size:13px;color:#9fb0cd}
