/* main.css — Xinhai theme. Source: static design (common.css + per-page <style>). */
/* ============ GLOBAL LAYER (from common.css) ============ */
/* =====================================================================
   common.css — Xinhai Mineral Processing EPC · global layer
   Brand: deep navy (#143A7B) + signal red (#C8161C), industrial/engineered
   Edit shared things here (topbar / nav / footer / buttons / tokens / 版心)
   ===================================================================== */

/* ===== 1. Design tokens ===== */
:root{
  --blue:var(--st-theme-color-one,#143A7B);        /* primary brand navy */
  --blue-deep:#0E2A5C;   /* darker navy for depth */
  --blue-700:#1C4C9C;
  --red:var(--st-theme-color-two,#C8161C);         /* signal red accent */
  --red-deep:#A2101A;
  --ink:#16202E;         /* near-black text */
  --body:#3C4858;        /* body grey */
  --mid:#6B7686;         /* muted */
  --line:#E2E7EE;        /* borders */
  --bg:#FFFFFF;
  --bg-soft:#F4F6FA;     /* soft panel */
  --bg-steel:#EAEEF4;    /* steel panel */
  --footer:#0C1B33;      /* footer navy */
  --footer-2:#0A1629;
  --gold:#E8A12C;        /* subtle "ore" accent for stats */
  --max:1280px;          /* 版心 — single switch for the whole site */
  --r:4px;               /* industrial = small radii, not pillowy */
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow:0 10px 30px rgba(16,32,60,.10);
  --shadow-lg:0 24px 60px rgba(16,32,60,.16);
}

/* ===== 2. Reset / base ===== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:"Barlow","Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--body);background:var(--bg);line-height:1.7;font-size:16px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
ul{list-style:none}
h1,h2,h3,h4{font-family:"Saira Condensed","Barlow Semi Condensed","Barlow",sans-serif;color:var(--ink);line-height:1.08;font-weight:700;letter-spacing:.2px}
strong{color:var(--ink)}
::selection{background:var(--blue);color:#fff}

/* ===== 3. Container (版心) ===== */
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 28px}

/* ===== 4. Section helpers ===== */
.section{padding:96px 0}
.section--soft{background:var(--bg-soft)}
.section--steel{background:var(--bg-steel)}
.section--dark{background:var(--footer);color:#C7D2E4}
.section-head{max-width:760px;margin:0 0 52px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font:700 13px/1 "Barlow",sans-serif;letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);margin-bottom:16px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red)}
.center .eyebrow::after{content:"";width:26px;height:2px;background:var(--red)}
.section-title{font-size:clamp(30px,3.6vw,46px);color:var(--ink);letter-spacing:.3px}
.section-title .hl{color:var(--blue)}
.section-sub{margin-top:18px;font-size:17px;color:var(--mid);line-height:1.75}

/* ===== 5. Buttons ===== */
.btn{
  --bg:var(--red);--fg:#fff;
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;background:var(--bg);color:var(--fg);
  font:700 14px/1 "Barlow",sans-serif;letter-spacing:.06em;text-transform:uppercase;
  border:2px solid var(--bg);border-radius:var(--r);cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s,border-color .25s;
}
.btn svg{width:16px;height:16px}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(200,22,28,.32)}
.btn--blue{--bg:var(--blue);box-shadow:none}
.btn--blue:hover{box-shadow:0 10px 24px rgba(20,58,123,.32)}
.btn--ghost{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.55)}
.btn--ghost:hover{background:#fff;color:var(--blue);border-color:#fff;box-shadow:none}
.btn--outline{--bg:transparent;--fg:var(--blue);border-color:var(--blue)}
.btn--outline:hover{background:var(--blue);color:#fff}
.btn--lg{padding:18px 38px;font-size:15px}

/* ===== 6. Reveal animation ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}

/* ===== 7. Top bar ===== */
.topbar{background:var(--blue-deep);color:#AFC0DD;font-size:13.5px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:42px}
.topbar a{color:#C7D5EC}
.topbar a:hover{color:#fff}
.topbar-left{display:flex;gap:26px;align-items:center}
.topbar-left .ti{display:flex;align-items:center;gap:7px}
.topbar-left svg{width:14px;height:14px;color:var(--red);flex:none}
.topbar-right{display:flex;gap:14px;align-items:center}
.topbar-social{display:flex;gap:10px}
.topbar-social a{width:24px;height:24px;border:1px solid rgba(255,255,255,.18);border-radius:3px;display:grid;place-items:center}
.topbar-social a:hover{background:var(--red);border-color:var(--red)}
.topbar-social svg{width:12px;height:12px}

/* ===== 8. Header / nav ===== */
.header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 1px 0 rgba(16,32,60,.04)}
.header.scrolled{box-shadow:0 6px 22px rgba(16,32,60,.10)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px}
.nav-logo img{height:50px;width:auto}
.nav-menu{display:flex;align-items:center;gap:4px;height:100%}
.nav-menu>li{position:relative;height:100%;display:flex;align-items:center}
.nav-link{
  display:flex;align-items:center;gap:6px;height:100%;padding:0 17px;
  font:600 15px/1 "Barlow",sans-serif;color:var(--ink);letter-spacing:.01em;position:relative;
}
.nav-link .caret{width:10px;height:10px;transition:transform .25s}
.nav-menu>li>.nav-link::after{content:"";position:absolute;left:17px;right:17px;bottom:24px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}
.nav-menu>li:hover>.nav-link::after,.nav-menu>li.active>.nav-link::after{transform:scaleX(1)}
.nav-menu>li:hover>.nav-link{color:var(--blue)}
.nav-menu>li:hover .caret{transform:rotate(180deg)}
/* dropdown */
.dropdown{
  position:absolute;top:100%;left:0;min-width:280px;background:#fff;
  border:1px solid var(--line);border-top:3px solid var(--red);box-shadow:var(--shadow);
  padding:10px;opacity:0;visibility:hidden;transform:translateY(10px);
  transition:all .26s var(--ease);border-radius:0 0 var(--r) var(--r);
}
.nav-menu>li:hover .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown a{display:flex;align-items:center;gap:10px;padding:11px 14px;font-size:14.5px;font-weight:500;color:var(--body);border-radius:3px}
.dropdown a::before{content:"";width:6px;height:6px;background:var(--line);transform:rotate(45deg);transition:background .2s}
.dropdown a:hover{background:var(--bg-soft);color:var(--blue)}
.dropdown a:hover::before{background:var(--red)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-tel{display:flex;align-items:center;gap:11px}
.nav-tel .ic{width:42px;height:42px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;color:var(--blue)}
.nav-tel .ic svg{width:19px;height:19px}
.nav-tel .t{font-size:12px;color:var(--mid);line-height:1.3}
.nav-tel .n{font:700 16px/1.2 "Barlow",sans-serif;color:var(--ink)}
.hamburger{display:none;width:46px;height:46px;border:1px solid var(--line);background:#fff;border-radius:var(--r);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.hamburger span{width:22px;height:2px;background:var(--ink);transition:.3s}

/* mobile menu */
.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(360px,86vw);background:#fff;z-index:120;transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:var(--shadow-lg);overflow-y:auto;padding:24px}
.mobile-menu.open{transform:none}
.mobile-menu .mm-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:14px}
.mobile-menu .mm-head img{height:40px}
.mm-close{width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:var(--r);font-size:22px;cursor:pointer;color:var(--ink)}
.mobile-link{display:block;padding:14px 6px;font:600 16px "Barlow",sans-serif;color:var(--ink);border-bottom:1px solid var(--line)}
.mobile-link:hover{color:var(--blue)}
.mobile-sub a{display:block;padding:10px 6px 10px 22px;font-size:14.5px;color:var(--body)}
.menu-backdrop{position:fixed;inset:0;background:rgba(8,16,32,.5);z-index:110;opacity:0;visibility:hidden;transition:.3s}
.menu-backdrop.open{opacity:1;visibility:visible}

/* ===== 9. Page banner (inner pages) ===== */
.page-banner{position:relative;padding:118px 0 88px;background:var(--blue-deep);color:#fff;overflow:hidden}
.page-banner::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(12,27,51,.93),rgba(12,27,51,.62));z-index:1}
.page-banner .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04)}
.page-banner .container{position:relative;z-index:2}
.page-banner .crumb{display:flex;gap:9px;align-items:center;font-size:13.5px;color:#9DB2D6;margin-bottom:16px;letter-spacing:.04em}
.page-banner .crumb a:hover{color:#fff}
.page-banner .crumb .sep{opacity:.5}
.page-banner h1{font-size:clamp(34px,4.6vw,58px);color:#fff;letter-spacing:.4px}
.page-banner p{margin-top:14px;max-width:640px;color:#C7D5EC;font-size:17px}
.page-banner .accent{width:64px;height:4px;background:var(--red);margin-top:22px}

/* ===== 10. Footer ===== */
.footer{background:var(--footer);color:#94A6C4;font-size:14.5px}
.footer a:hover{color:#fff}
.footer-top{padding:74px 0 54px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:44px}
.footer .f-logo{height:46px;margin-bottom:20px;filter:brightness(0) invert(1);opacity:.95}
.f-wordmark{font:800 30px/1 "Saira Condensed",sans-serif;color:#fff;letter-spacing:1px;margin-bottom:8px}
.f-wordmark span{color:var(--red)}
.f-tag{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#7C90B2;margin-bottom:18px}
.footer .f-desc{line-height:1.8;color:#93A5C3;max-width:360px}
.footer h4{color:#fff;font-size:18px;margin-bottom:22px;letter-spacing:.5px;position:relative;padding-bottom:12px}
.footer h4::after{content:"";position:absolute;left:0;bottom:0;width:34px;height:2px;background:var(--red)}
.footer-links li{margin-bottom:12px}
.footer-links a{display:inline-flex;align-items:center;gap:9px;color:#9CAFCD}
.footer-links a::before{content:"›";color:var(--red);font-size:16px;line-height:1}
.f-contact li{display:flex;gap:13px;margin-bottom:16px;align-items:flex-start}
.f-contact .ic{width:34px;height:34px;background:rgba(255,255,255,.06);border-radius:var(--r);display:grid;place-items:center;flex:none;color:var(--red)}
.f-contact .ic svg{width:16px;height:16px}
.f-contact .tx{color:#A9BAD6;line-height:1.55}
.f-contact .tx b{display:block;color:#fff;font-weight:600;font-size:13px;margin-bottom:1px;font-family:"Barlow"}
.f-social{display:flex;gap:10px;margin-top:8px}
.f-social a{width:38px;height:38px;border:1px solid rgba(255,255,255,.14);border-radius:var(--r);display:grid;place-items:center;color:#A9BAD6}
.f-social a:hover{background:var(--red);border-color:var(--red);color:#fff}
.f-social svg{width:16px;height:16px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.09);padding:22px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13.5px;color:#7C90B2}
.footer-bottom a{color:#93A5C3}

/* back to top */
.totop{position:fixed;right:26px;bottom:26px;width:50px;height:50px;background:var(--blue);color:#fff;border:none;border-radius:var(--r);cursor:pointer;display:grid;place-items:center;opacity:0;visibility:hidden;transform:translateY(14px);transition:.3s;z-index:60;box-shadow:var(--shadow)}
.totop.show{opacity:1;visibility:visible;transform:none}
.totop:hover{background:var(--red)}
.totop svg{width:20px;height:20px}

/* ===== 10b. Shared content components (used on multiple pages) ===== */

/* breadcrumb-style intro grid helpers */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}

/* PRODUCT card */
.prod-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.prod-thumb{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--bg-soft)}
.prod-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.prod-card:hover .prod-thumb img{transform:scale(1.07)}
.prod-cat{position:absolute;top:14px;left:14px;background:var(--blue);color:#fff;font:700 11px/1 "Barlow",sans-serif;letter-spacing:.1em;text-transform:uppercase;padding:7px 12px;border-radius:3px}
.prod-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.prod-body h3{font-size:21px;margin-bottom:10px;color:var(--ink)}
.prod-body p{font-size:14.5px;color:var(--mid);line-height:1.65;flex:1}
.prod-spec{display:flex;gap:18px;margin:16px 0 18px;padding-top:16px;border-top:1px solid var(--line)}
.prod-spec .s b{display:block;font:700 17px/1 "Saira Condensed",sans-serif;color:var(--blue)}
.prod-spec .s span{font-size:12px;color:var(--mid)}
.prod-more{display:inline-flex;align-items:center;gap:8px;font:700 13px/1 "Barlow",sans-serif;letter-spacing:.08em;text-transform:uppercase;color:var(--red)}
.prod-more svg{width:15px;height:15px;transition:transform .25s}
.prod-card:hover .prod-more svg{transform:translateX(4px)}

/* APPLICATION card */
.app-card{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;cursor:pointer;display:block}
.app-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.app-card:hover img{transform:scale(1.08)}
.app-card::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,22,41,.92) 0%,rgba(10,22,41,.25) 55%,transparent 100%)}
.app-card .ac{position:absolute;z-index:2;left:0;right:0;bottom:0;padding:26px 24px;color:#fff}
.app-card .ac .cat{font:700 11px/1 "Barlow",sans-serif;letter-spacing:.14em;text-transform:uppercase;color:#7FB0FF;margin-bottom:8px}
.app-card .ac h3{color:#fff;font-size:23px;margin-bottom:6px}
.app-card .ac p{font-size:13.5px;color:#C2D1EA;max-height:0;opacity:0;overflow:hidden;transition:.4s var(--ease)}
.app-card:hover .ac p{max-height:90px;opacity:1;margin-top:6px}

/* CASE card */
.case-card{display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.3s}
.case-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.case-card .ci{width:42%;flex:none;overflow:hidden;position:relative}
.case-card .ci img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.case-card:hover .ci img{transform:scale(1.07)}
.case-card .flag{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font:700 11px/1 "Barlow",sans-serif;letter-spacing:.08em;padding:6px 10px;border-radius:3px;text-transform:uppercase}
.case-card .cb{padding:26px;display:flex;flex-direction:column}
.case-card .cb .tpd{font:700 13px/1 "Saira Condensed",sans-serif;color:var(--red);letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}
.case-card .cb h3{font-size:21px;margin-bottom:10px;color:var(--ink);line-height:1.15}
.case-card .cb p{font-size:14px;color:var(--mid);line-height:1.6;flex:1}
.case-card .cb .more{margin-top:14px;font:700 12.5px/1 "Barlow",sans-serif;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);display:inline-flex;gap:7px;align-items:center}

/* BLOG card */
.blog-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:transparent}
.blog-thumb{aspect-ratio:16/10;overflow:hidden;display:block}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.blog-card:hover .blog-thumb img{transform:scale(1.07)}
.blog-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;gap:14px;font-size:12.5px;color:var(--mid);margin-bottom:12px;letter-spacing:.02em}
.blog-meta .tag{color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.blog-body h3{font-size:19px;line-height:1.25;margin-bottom:10px;color:var(--ink)}
.blog-body p{font-size:14px;color:var(--mid);line-height:1.6;flex:1}
.blog-body .more{margin-top:14px;font:700 12.5px/1 "Barlow",sans-serif;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);display:inline-flex;gap:7px;align-items:center}

/* INQUIRY form (shared) */
.cta-form{background:#fff;border-radius:var(--r);padding:38px;box-shadow:var(--shadow-lg)}
.cta-form h3{color:var(--ink);font-size:24px;margin-bottom:6px}
.cta-form .fsub{color:var(--mid);font-size:14px;margin-bottom:22px}
.cta-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cta-form input,.cta-form textarea,.cta-form select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:var(--r);font:500 14.5px "Barlow",sans-serif;color:var(--ink);margin-bottom:14px;background:var(--bg-soft);transition:.2s}
.cta-form input:focus,.cta-form textarea:focus,.cta-form select:focus{outline:none;border-color:var(--blue);background:#fff}
.cta-form textarea{resize:vertical;min-height:96px}
.cta-form .btn{width:100%;justify-content:center}

/* prose (detail/article body) */
.prose{font-size:16.5px;color:var(--body);line-height:1.85}
.prose h2{font-size:28px;color:var(--ink);margin:38px 0 16px}
.prose h3{font-size:22px;color:var(--ink);margin:30px 0 12px}
.prose p{margin-bottom:18px}
.prose ul{margin:0 0 20px;padding-left:4px}
.prose ul li{position:relative;padding:6px 0 6px 26px}
.prose ul li::before{content:"";position:absolute;left:0;top:14px;width:7px;height:7px;background:var(--red);transform:rotate(45deg)}
.prose blockquote{border-left:4px solid var(--blue);background:var(--bg-soft);padding:20px 26px;margin:24px 0;font-style:italic;color:var(--ink)}
.prose table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.prose th{background:var(--blue);color:#fff;text-align:left;padding:13px 16px;font-family:"Barlow",sans-serif;font-weight:600}
.prose td{padding:12px 16px;border:1px solid var(--line)}
.prose tr:nth-child(even) td{background:var(--bg-soft)}
.prose img{border-radius:var(--r);margin:24px 0}

/* responsive for shared components */
@media(max-width:980px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
}
@media(max-width:640px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .case-card{flex-direction:column}.case-card .ci{width:100%;aspect-ratio:16/10}
  .cta-form .row{grid-template-columns:1fr}
}

/* ===== 11. Shared responsive (header/footer/版心) ===== */
@media(max-width:1080px){
  .nav-menu,.nav-tel,.topbar-left .ti.hide-md{display:none}
  .hamburger{display:flex}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:640px){
  .section{padding:64px 0}
  .container{padding:0 20px}
  .topbar-left{gap:16px}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}


/* ============ PAGE: index ============ */
/* ====== HOME-ONLY styles ====== */

/* HERO */
.hero{position:relative;height:clamp(560px,82vh,760px);overflow:hidden;background:var(--blue-deep)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s var(--ease);background-size:cover;background-position:center}
.hero-slide.active{opacity:1}
.hero-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(10,22,41,.92) 0%,rgba(10,22,41,.72) 42%,rgba(10,22,41,.30) 100%)}
.hero-inner{position:relative;z-index:3;height:100%;display:flex;align-items:center}
.hero-card{max-width:720px;color:#fff}
.hero-tag{display:inline-flex;align-items:center;gap:10px;background:rgba(200,22,28,.16);border:1px solid rgba(200,22,28,.5);color:#FF9AA0;font:700 12.5px/1 "Barlow";letter-spacing:.16em;text-transform:uppercase;padding:9px 16px;border-radius:var(--r);margin-bottom:22px}
.hero-tag::before{content:"";width:8px;height:8px;background:var(--red);border-radius:50%;box-shadow:0 0 0 4px rgba(200,22,28,.3)}
.hero h1{font-size:clamp(38px,5.4vw,68px);color:#fff;letter-spacing:.5px;margin-bottom:20px}
.hero h1 em{font-style:normal;color:#7FB0FF}
.hero p{font-size:clamp(16px,1.7vw,20px);color:#C8D6EE;max-width:600px;margin-bottom:34px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-nav{position:absolute;z-index:4;bottom:38px;right:0;left:0}
.hero-nav .container{display:flex;justify-content:space-between;align-items:center}
.hero-dots{display:flex;gap:10px}
.hero-dot{width:38px;height:4px;background:rgba(255,255,255,.3);border:none;cursor:pointer;border-radius:2px;transition:.3s}
.hero-dot.active{background:var(--red);width:54px}
.hero-arrows{display:flex;gap:10px}
.hero-arrows button{width:50px;height:50px;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.05);color:#fff;cursor:pointer;border-radius:var(--r);display:grid;place-items:center;transition:.25s}
.hero-arrows button:hover{background:var(--red);border-color:var(--red)}
.hero-arrows svg{width:20px;height:20px}
/* hero stat strip */
.hero-strip{background:var(--blue);color:#fff}
.hero-strip .container{display:grid;grid-template-columns:repeat(4,1fr)}
.hero-strip .hs{padding:26px 28px;display:flex;align-items:center;gap:16px;border-right:1px solid rgba(255,255,255,.12)}
.hero-strip .hs:last-child{border-right:none}
.hero-strip .hs .ic{width:46px;height:46px;flex:none;display:grid;place-items:center;color:#9FC0FF}
.hero-strip .hs .ic svg{width:30px;height:30px}
.hero-strip .num{font:800 26px/1 "Saira Condensed";color:#fff}
.hero-strip .lb{font-size:13px;color:#B9CBE8;letter-spacing:.02em}

/* EPCM band */
.epcm{position:relative;background:var(--footer);color:#C7D2E4;overflow:hidden}
.epcm::before{content:"E P C M + O";position:absolute;top:-30px;right:-10px;font:800 200px/1 "Saira Condensed";color:rgba(255,255,255,.03);white-space:nowrap;pointer-events:none}
.epcm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;z-index:2}
.epcm-step{padding:38px 26px;border-left:1px solid rgba(255,255,255,.09);position:relative;transition:background .3s}
.epcm-step:first-child{border-left:none}
.epcm-step:hover{background:rgba(255,255,255,.03)}
.epcm-step .lt{font:800 56px/1 "Saira Condensed";color:rgba(127,176,255,.28);margin-bottom:14px}
.epcm-step:hover .lt{color:var(--red)}
.epcm-step h3{color:#fff;font-size:21px;margin-bottom:14px;letter-spacing:.3px}
.epcm-step ul li{font-size:14px;color:#9FB2D2;padding:5px 0 5px 16px;position:relative}
.epcm-step ul li::before{content:"";position:absolute;left:0;top:13px;width:6px;height:6px;background:var(--red);transform:rotate(45deg)}

/* PRODUCT grid */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.prod-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.prod-thumb{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--bg-soft)}
.prod-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.prod-card:hover .prod-thumb img{transform:scale(1.07)}
.prod-cat{position:absolute;top:14px;left:14px;background:var(--blue);color:#fff;font:700 11px/1 "Barlow";letter-spacing:.1em;text-transform:uppercase;padding:7px 12px;border-radius:3px}
.prod-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.prod-body h3{font-size:21px;margin-bottom:10px;color:var(--ink)}
.prod-body p{font-size:14.5px;color:var(--mid);line-height:1.65;flex:1}
.prod-spec{display:flex;gap:18px;margin:16px 0 18px;padding-top:16px;border-top:1px solid var(--line)}
.prod-spec .s b{display:block;font:700 17px/1 "Saira Condensed";color:var(--blue)}
.prod-spec .s span{font-size:12px;color:var(--mid)}
.prod-more{display:inline-flex;align-items:center;gap:8px;font:700 13px/1 "Barlow";letter-spacing:.08em;text-transform:uppercase;color:var(--red)}
.prod-more svg{width:15px;height:15px;transition:transform .25s}
.prod-card:hover .prod-more svg{transform:translateX(4px)}

/* ADVANTAGES */
.adv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);background:var(--line);gap:1px}
.adv-card{background:#fff;padding:40px 34px;transition:background .3s}
.adv-card:hover{background:var(--bg-soft)}
.adv-card .ic{width:62px;height:62px;border-radius:var(--r);background:linear-gradient(135deg,var(--blue),var(--blue-700));display:grid;place-items:center;color:#fff;margin-bottom:22px}
.adv-card:hover .ic{background:linear-gradient(135deg,var(--red),var(--red-deep))}
.adv-card .ic svg{width:30px;height:30px}
.adv-card .no{font:800 14px/1 "Saira Condensed";color:var(--line);position:absolute}
.adv-card h3{font-size:20px;margin-bottom:12px;color:var(--ink)}
.adv-card p{font-size:14.5px;color:var(--mid);line-height:1.7}

/* APPLICATIONS */
.app-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.app-card{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;cursor:pointer}
.app-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.app-card:hover img{transform:scale(1.08)}
.app-card::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,22,41,.92) 0%,rgba(10,22,41,.25) 55%,transparent 100%)}
.app-card .ac{position:absolute;z-index:2;left:0;right:0;bottom:0;padding:26px 24px;color:#fff}
.app-card .ac .cat{font:700 11px/1 "Barlow";letter-spacing:.14em;text-transform:uppercase;color:#7FB0FF;margin-bottom:8px}
.app-card .ac h3{color:#fff;font-size:23px;margin-bottom:6px}
.app-card .ac p{font-size:13.5px;color:#C2D1EA;max-height:0;opacity:0;overflow:hidden;transition:.4s var(--ease)}
.app-card:hover .ac p{max-height:80px;opacity:1;margin-top:6px}

/* CASES */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.case-card{display:flex;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.3s}
.case-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.case-card .ci{width:42%;flex:none;overflow:hidden;position:relative}
.case-card .ci img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.case-card:hover .ci img{transform:scale(1.07)}
.case-card .flag{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font:700 11px/1 "Barlow";letter-spacing:.08em;padding:6px 10px;border-radius:3px;text-transform:uppercase}
.case-card .cb{padding:26px 26px;display:flex;flex-direction:column}
.case-card .cb .tpd{font:700 13px/1 "Saira Condensed";color:var(--red);letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}
.case-card .cb h3{font-size:21px;margin-bottom:10px;color:var(--ink);line-height:1.15}
.case-card .cb p{font-size:14px;color:var(--mid);line-height:1.6;flex:1}
.case-card .cb .more{margin-top:14px;font:700 12.5px/1 "Barlow";letter-spacing:.08em;text-transform:uppercase;color:var(--blue);display:inline-flex;gap:7px;align-items:center}

/* FACTORY */
.fac{position:relative;color:#fff;overflow:hidden;background:var(--blue-deep)}
.fac .fac-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.22}
.fac::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,var(--blue-deep) 30%,rgba(14,42,92,.7))}
.fac .container{position:relative;z-index:2}
.fac-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.fac-wrap .eyebrow{color:#FF9AA0}
.fac-wrap .eyebrow::before{background:var(--red)}
.fac h2{color:#fff;font-size:clamp(28px,3.4vw,44px);margin-bottom:20px}
.fac p{color:#C7D5EC;margin-bottom:30px;font-size:16px}
.fac-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);overflow:hidden}
.fac-stats .fs{background:var(--blue-deep);padding:30px 28px}
.fac-stats .fs .n{font:800 42px/1 "Saira Condensed";color:#fff}
.fac-stats .fs .n .u{color:var(--red)}
.fac-stats .fs .l{font-size:14px;color:#A9BAD6;margin-top:8px}

/* QUALITY */
.qua-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.qua-card{text-align:center;padding:36px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--r);transition:.3s}
.qua-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-4px)}
.qua-card .ic{width:70px;height:70px;margin:0 auto 20px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;color:var(--blue)}
.qua-card:hover .ic{background:var(--blue);color:#fff}
.qua-card .ic svg{width:34px;height:34px}
.qua-card h3{font-size:19px;margin-bottom:9px}
.qua-card p{font-size:13.5px;color:var(--mid);line-height:1.6}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:transparent}
.blog-thumb{aspect-ratio:16/10;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.blog-card:hover .blog-thumb img{transform:scale(1.07)}
.blog-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;gap:14px;font-size:12.5px;color:var(--mid);margin-bottom:12px;letter-spacing:.02em}
.blog-meta .tag{color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.blog-body h3{font-size:19px;line-height:1.25;margin-bottom:10px;color:var(--ink)}
.blog-body p{font-size:14px;color:var(--mid);line-height:1.6;flex:1}
.blog-body .more{margin-top:14px;font:700 12.5px/1 "Barlow";letter-spacing:.08em;text-transform:uppercase;color:var(--blue);display:inline-flex;gap:7px;align-items:center}

/* FORM CTA */
.cta{position:relative;background:var(--blue);color:#fff;overflow:hidden}
.cta::before{content:"";position:absolute;top:-80px;right:-60px;width:380px;height:380px;border:60px solid rgba(255,255,255,.05);border-radius:50%}
.cta-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.cta h2{color:#fff;font-size:clamp(28px,3.4vw,44px);margin-bottom:18px}
.cta p{color:#C8D6EE;margin-bottom:26px;font-size:16px}
.cta-points li{display:flex;gap:12px;align-items:center;margin-bottom:14px;font-size:15.5px;color:#E1E9F6}
.cta-points .ck{width:24px;height:24px;flex:none;background:var(--red);border-radius:50%;display:grid;place-items:center}
.cta-points .ck svg{width:13px;height:13px;color:#fff}
.cta-form{background:#fff;border-radius:var(--r);padding:38px;box-shadow:var(--shadow-lg)}
.cta-form h3{color:var(--ink);font-size:24px;margin-bottom:6px}
.cta-form .fsub{color:var(--mid);font-size:14px;margin-bottom:22px}
.cta-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cta-form input,.cta-form textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:var(--r);font:500 14.5px "Barlow";color:var(--ink);margin-bottom:14px;background:var(--bg-soft);transition:.2s}
.cta-form input:focus,.cta-form textarea:focus{outline:none;border-color:var(--blue);background:#fff}
.cta-form textarea{resize:vertical;min-height:96px}
.cta-form .btn{width:100%;justify-content:center}

@media(max-width:980px){
  .prod-grid,.adv-grid,.app-grid,.qua-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .epcm-grid{grid-template-columns:repeat(2,1fr)}
  .epcm-step{border-left:none;border-top:1px solid rgba(255,255,255,.09)}
  .case-grid{grid-template-columns:1fr}
  .fac-wrap,.cta-wrap{grid-template-columns:1fr;gap:36px}
  .hero-strip .container{grid-template-columns:repeat(2,1fr)}
  .hero-strip .hs:nth-child(2){border-right:none}
}
@media(max-width:640px){
  .prod-grid,.adv-grid,.app-grid,.qua-grid,.blog-grid,.epcm-grid{grid-template-columns:1fr}
  .case-card{flex-direction:column}.case-card .ci{width:100%;aspect-ratio:16/10}
  .fac-stats,.qua-grid{grid-template-columns:repeat(2,1fr)}
  .cta-form .row{grid-template-columns:1fr}
}

/* ============ PAGE: products ============ */
.cat-nav{position:sticky;top:84px;z-index:30;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 12px rgba(16,32,60,.05)}
.cat-nav .container{display:flex;gap:6px;overflow-x:auto;padding:0 28px}
.cat-nav a{white-space:nowrap;padding:18px 16px;font:600 14.5px "Barlow",sans-serif;color:var(--body);border-bottom:3px solid transparent;transition:.2s}
.cat-nav a:hover{color:var(--blue)}
.cat-block{padding:80px 0 0}
.cat-block:last-of-type{padding-bottom:96px}
.cat-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:36px;padding-bottom:22px;border-bottom:2px solid var(--line)}
.cat-head .lt{font:800 18px/1 "Saira Condensed",sans-serif;color:#fff;background:var(--blue);width:54px;height:54px;display:grid;place-items:center;border-radius:var(--r);flex:none;margin-right:18px}
.cat-head .ht{display:flex;align-items:center}
.cat-head h2{font-size:clamp(26px,3vw,38px);color:var(--ink)}
.cat-head p{color:var(--mid);font-size:14.5px;max-width:480px}
@media(max-width:980px){.cat-nav{top:0}}

/* ============ PAGE: product-detail ============ */
.pd-layout{display:grid;grid-template-columns:1.6fr 1fr;gap:54px;padding:64px 0}
.pd-gallery .main{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--bg-soft)}
.pd-gallery .main img{width:100%;aspect-ratio:16/11;object-fit:cover}
.pd-thumbs{display:flex;gap:12px;margin-top:14px}
.pd-thumbs img{width:88px;height:66px;object-fit:cover;border:2px solid var(--line);border-radius:4px;cursor:pointer;transition:.2s}
.pd-thumbs img:hover,.pd-thumbs img.active{border-color:var(--red)}
.pd-info .tag{display:inline-block;background:var(--bg-soft);color:var(--blue);font:700 12px/1 "Barlow",sans-serif;letter-spacing:.08em;text-transform:uppercase;padding:8px 14px;border-radius:3px;margin-bottom:16px}
.pd-info h1{font-size:clamp(30px,3.4vw,42px);color:var(--ink);margin-bottom:16px;line-height:1.12}
.pd-info .lead{font-size:16px;color:var(--body);line-height:1.75;margin-bottom:24px}
.pd-keyspecs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:28px}
.pd-keyspecs .k{background:#fff;padding:18px 20px}
.pd-keyspecs .k b{display:block;font:700 22px/1 "Saira Condensed",sans-serif;color:var(--blue)}
.pd-keyspecs .k span{font-size:13px;color:var(--mid)}
.pd-actions{display:flex;gap:14px;flex-wrap:wrap}
.pd-aside-box{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:26px;margin-top:24px}
.pd-aside-box h4{font-size:18px;margin-bottom:8px}
.pd-aside-box p{font-size:14px;color:var(--mid);margin-bottom:16px}
.pd-tabs{border-top:1px solid var(--line);background:var(--bg-soft)}
.pd-tabbar{display:flex;gap:0;border-bottom:1px solid var(--line);background:#fff}
.pd-tabbar button{padding:20px 28px;font:700 15px "Barlow",sans-serif;color:var(--body);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer}
.pd-tabbar button.active{color:var(--blue);border-color:var(--red)}
.pd-panel{display:none;padding:48px 0}
.pd-panel.active{display:block}
@media(max-width:980px){.pd-layout{grid-template-columns:1fr;gap:36px}}

/* ============ PAGE: applications ============ */
.sol{padding:84px 0;border-bottom:1px solid var(--line)}
.sol-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.sol:nth-child(even) .sol-img{order:2}
.sol-img{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow)}
.sol-img img{width:100%;height:100%;object-fit:cover}
.sol-img .badge{position:absolute;top:18px;left:18px;background:var(--blue);color:#fff;font:700 12px/1 "Barlow",sans-serif;letter-spacing:.1em;text-transform:uppercase;padding:9px 14px;border-radius:3px}
.sol h2{font-size:clamp(26px,3vw,38px);color:var(--ink);margin-bottom:14px}
.sol .sub{color:var(--mid);font-size:16px;line-height:1.75;margin-bottom:22px}
.flow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.flow .step{display:flex;align-items:center;gap:8px;background:var(--bg-soft);border:1px solid var(--line);padding:9px 14px;border-radius:30px;font:600 13px "Barlow",sans-serif;color:var(--ink)}
.flow .step .n{width:20px;height:20px;background:var(--blue);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:11px}
.flow .arr{display:grid;place-items:center;color:var(--red);font-weight:700}
.sol ul.pts li{position:relative;padding:6px 0 6px 26px;color:var(--body);font-size:15px}
.sol ul.pts li::before{content:"";position:absolute;left:0;top:13px;width:7px;height:7px;background:var(--red);transform:rotate(45deg)}
@media(max-width:980px){.sol-row{grid-template-columns:1fr;gap:30px}.sol:nth-child(even) .sol-img{order:0}}

/* ============ PAGE: cases ============ */
.case-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:44px}
.case-filter button{padding:11px 22px;border:1px solid var(--line);background:#fff;border-radius:30px;font:600 14px "Barlow",sans-serif;color:var(--body);cursor:pointer;transition:.2s}
.case-filter button.active,.case-filter button:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ============ PAGE: case-detail ============ */
.single{display:grid;grid-template-columns:1fr 340px;gap:54px;padding:64px 0}
.single-main img.hero{width:100%;border-radius:var(--r);margin-bottom:30px}
.case-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:34px}
.case-facts .cf{background:#fff;padding:20px}
.case-facts .cf b{display:block;font:700 20px/1 "Saira Condensed";color:var(--blue)}
.case-facts .cf span{font-size:12.5px;color:var(--mid)}
.aside-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:26px;margin-bottom:24px;position:sticky;top:104px}
.aside-card h4{font-size:18px;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--line)}
.aside-card .il{display:flex;gap:10px;padding:8px 0;font-size:14.5px;color:var(--body)}
.aside-card .il svg{width:18px;height:18px;color:var(--red);flex:none;margin-top:2px}
@media(max-width:980px){.single{grid-template-columns:1fr;gap:36px}.case-facts{grid-template-columns:repeat(2,1fr)}}

/* ============ PAGE: about ============ */
.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-intro .ai-img{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);position:relative}
.about-intro .ai-img img{width:100%;display:block}
.about-intro .stat-overlay{position:absolute;left:24px;bottom:24px;background:var(--red);color:#fff;padding:18px 24px;border-radius:var(--r)}
.about-intro .stat-overlay b{font:800 34px/1 "Saira Condensed"}
.about-intro .stat-overlay span{display:block;font-size:13px;opacity:.92}
.tl{position:relative;margin-top:20px}
.tl::before{content:"";position:absolute;left:90px;top:0;bottom:0;width:2px;background:var(--line)}
.tl-item{position:relative;display:grid;grid-template-columns:90px 1fr;gap:36px;padding:18px 0}
.tl-year{font:800 20px/1 "Saira Condensed";color:var(--blue);text-align:right;padding-top:4px}
.tl-dot{position:absolute;left:85px;top:24px;width:12px;height:12px;background:var(--red);border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 2px var(--line)}
.tl-body h3{font-size:19px;margin-bottom:6px}
.tl-body p{color:var(--mid);font-size:14.5px}
.mk-bar{margin-bottom:16px}
.mk-bar .top{display:flex;justify-content:space-between;font-size:14px;margin-bottom:7px;color:var(--ink);font-weight:600}
.mk-bar .track{height:9px;background:var(--bg-steel);border-radius:6px;overflow:hidden}
.mk-bar .fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--blue-700));border-radius:6px;width:0;transition:width 1.2s var(--ease)}
.cert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cert{text-align:center;padding:32px 20px;background:#fff;border:1px solid var(--line);border-radius:var(--r);transition:.3s}
.cert:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue)}
.cert .ic{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;background:var(--bg-soft);display:grid;place-items:center;color:var(--blue)}
.cert:hover .ic{background:var(--blue);color:#fff}
.cert .ic svg{width:32px;height:32px}
.cert h3{font-size:17px;margin-bottom:6px}
.cert p{font-size:13px;color:var(--mid)}
@media(max-width:980px){.about-intro{grid-template-columns:1fr;gap:34px}.cert-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ PAGE: blog ============ */
.feat{display:grid;grid-template-columns:1.3fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:48px;background:#fff}
.feat .fi{overflow:hidden}.feat .fi img{width:100%;height:100%;object-fit:cover;min-height:340px}
.feat .fc{padding:46px}
.feat .fc .blog-meta{margin-bottom:16px}
.feat .fc h2{font-size:clamp(24px,2.6vw,34px);margin-bottom:16px;color:var(--ink);line-height:1.18}
.feat .fc p{color:var(--mid);margin-bottom:22px;font-size:15.5px}
@media(max-width:980px){.feat{grid-template-columns:1fr}}

/* ============ PAGE: blog-detail ============ */
.single{display:grid;grid-template-columns:1fr 320px;gap:54px;padding:64px 0}
.art-meta{display:flex;gap:16px;align-items:center;margin-bottom:22px;font-size:13.5px;color:var(--mid)}
.art-meta .tag{background:var(--red);color:#fff;padding:6px 12px;border-radius:3px;font:700 11px "Barlow";letter-spacing:.08em;text-transform:uppercase}
.art-hero{width:100%;border-radius:var(--r);margin-bottom:30px}
.toc{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:24px;position:sticky;top:104px}
.toc h4{font-size:16px;margin-bottom:14px}
.toc a{display:block;padding:7px 0;font-size:14px;color:var(--body);border-bottom:1px dashed var(--line)}
.toc a:hover{color:var(--blue)}
@media(max-width:980px){.single{grid-template-columns:1fr;gap:32px}.toc{position:static}}

/* ============ PAGE: contact ============ */
.contact-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:54px;align-items:start}
.ci-card{display:flex;gap:16px;padding:24px;background:#fff;border:1px solid var(--line);border-radius:var(--r);margin-bottom:18px;transition:.3s}
.ci-card:hover{box-shadow:var(--shadow);border-color:var(--blue)}
.ci-card .ic{width:52px;height:52px;flex:none;border-radius:var(--r);background:var(--blue);color:#fff;display:grid;place-items:center}
.ci-card .ic svg{width:24px;height:24px}
.ci-card h4{font-size:17px;margin-bottom:4px}
.ci-card p{font-size:14.5px;color:var(--mid);line-height:1.6}
.map{margin-top:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:340px;background:var(--bg-steel)}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(.2)}
@media(max-width:980px){.contact-wrap{grid-template-columns:1fr;gap:36px}}
