:root{
  --ink:#0B110E; --hero:#0B130F; --panel:#0E1813;
  --green:#1C7A4E; --green-d:#13543A; --green-l:#7FD6A6; --accent:#2E8B57;
  --paper:#ECEAE2; --paper2:#E2DFD5; --card:#F4F2EC;
  --tx:#11201A; --tx2:#5C6B63; --tx3:#93A099;
  --line:#D8D4C9; --line-d:rgba(255,255,255,.12);
  --maxw:1200px;
  --cn:"Noto Sans SC",-apple-system,"PingFang SC","Microsoft YaHei",sans-serif;
  --dp:"Space Grotesk","Noto Sans SC",sans-serif;
  --mo:"Space Mono",monospace;
  --bd:"Inter","Noto Sans SC",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--cn);color:var(--tx);background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.7}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
a{text-decoration:none;color:inherit}
.mono{font-family:var(--mo);letter-spacing:.16em;text-transform:uppercase}
.eng{font-family:var(--dp)}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(11,19,15,.72);backdrop-filter:saturate(140%) blur(16px);border-bottom:1px solid var(--line-d)}
.nav{display:flex;align-items:center;gap:30px;height:70px}
.brand{display:flex;align-items:center;gap:11px}
.brand .w{font-family:var(--dp);font-weight:600;font-size:21px;letter-spacing:.02em;color:#fff;line-height:1}
.brand .w b{color:var(--green-l);font-weight:600}
.logo-r{height:34px;width:auto;display:block;filter:brightness(0) invert(1)}
nav.menu{display:flex;gap:24px;margin-left:6px;flex:1}
nav.menu a{font-size:14px;color:rgba(255,255,255,.78);font-weight:400;padding:6px 0;position:relative;white-space:nowrap}
nav.menu a:hover,nav.menu a.on{color:#fff}
nav.menu a::after{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--green-l);transition:.25s}
nav.menu a:hover::after,nav.menu a.on::after{width:100%}
.lang{display:flex;gap:2px;align-items:center;font-family:var(--mo);font-size:11px;color:rgba(255,255,255,.5)}
.lang a{padding:3px 7px;border-radius:5px}
.lang a.on{color:var(--ink);background:var(--green-l)}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;border-radius:8px;padding:10px 18px;transition:.2s;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-g{background:var(--green);color:#fff}
.btn-g:hover{background:var(--accent)}
.btn-o{border-color:var(--line-d);color:#fff}
.btn-o:hover{border-color:var(--green-l);color:var(--green-l)}
.mtoggle{display:none}
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:34px;height:34px;cursor:pointer;flex:none}
.burger span{display:block;height:2px;width:22px;background:#fff;border-radius:2px}

/* affiliates dropdown */
.has-sub{position:relative;display:flex;align-items:center}
.has-sub .sub-t{display:flex;align-items:center;gap:5px;font-size:14px;color:rgba(255,255,255,.78);padding:6px 0;cursor:default;white-space:nowrap}
.has-sub:hover .sub-t,.has-sub .sub-t.on{color:#fff}
.has-sub .caret{opacity:.65;transition:transform .25s}
.has-sub:hover .caret{transform:rotate(180deg)}
.has-sub::after{content:"";position:absolute;left:-14px;right:-14px;top:100%;height:16px}
.submenu{position:absolute;top:calc(100% + 11px);left:-16px;min-width:194px;background:rgba(11,19,15,.97);backdrop-filter:saturate(140%) blur(16px);border:1px solid var(--line-d);border-radius:11px;padding:7px;display:flex;flex-direction:column;gap:1px;box-shadow:0 22px 46px -14px rgba(0,0,0,.6);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.2s}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:none}
.has-sub .submenu a{font-size:14px;color:rgba(255,255,255,.8);padding:10px 13px;border-radius:7px;white-space:nowrap}
.has-sub .submenu a::after{display:none}
.has-sub .submenu a:hover{background:rgba(255,255,255,.07);color:#fff}

/* hero */
.hero{background:var(--hero);color:#fff;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 90% 80% at 70% 20%,#000,transparent 75%)}
.hero-in{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:96px 0 104px}
.eyebrow{font-family:var(--mo);font-size:11.5px;letter-spacing:.2em;color:var(--green-l);margin-bottom:30px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--green-l)}
h1.t{font-family:var(--dp);font-weight:500;font-size:clamp(2.5rem,4.6vw,4rem);line-height:1.06;letter-spacing:-.02em;color:#fff}
h1.t em{font-style:normal;color:var(--green-l)}
.t-cn{margin-top:20px;font-family:var(--cn);font-weight:300;font-size:clamp(1.15rem,1.7vw,1.5rem);color:rgba(255,255,255,.82);letter-spacing:.01em}
.lede{margin:26px 0 34px;font-size:15.5px;line-height:1.85;color:rgba(255,255,255,.62);max-width:520px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.pin{margin-top:30px;font-family:var(--mo);font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.4);text-transform:uppercase}
.hero-art{position:relative;height:400px}
.hero-art svg{width:100%;height:100%;overflow:visible}

/* page hero (inner pages) */
.pagehero{background:var(--hero);color:#fff;position:relative;overflow:hidden;border-bottom:1px solid var(--line-d)}
.pagehero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 90% at 75% 10%,#000,transparent 72%)}
.pagehero-in{position:relative;padding:84px 0 74px;max-width:860px}
.pagehero .lab{font-family:var(--mo);font-size:11.5px;letter-spacing:.2em;color:var(--green-l);text-transform:uppercase;display:flex;align-items:center;gap:10px}
.pagehero .lab::before{content:"";width:24px;height:1px;background:var(--green-l)}
.pagehero h1{font-family:var(--dp);font-weight:500;font-size:clamp(2rem,3.6vw,3rem);line-height:1.12;letter-spacing:-.015em;color:#fff;margin-top:24px}
.pagehero h1 em{font-style:normal;color:var(--green-l)}
.pagehero .cn{margin-top:16px;font-family:var(--cn);font-weight:300;font-size:clamp(1.05rem,1.5vw,1.3rem);color:rgba(255,255,255,.78)}

/* stats */
.stats{background:var(--panel);border-top:1px solid var(--line-d)}
.stats-in{display:grid;grid-template-columns:repeat(4,1fr)}
.st{padding:40px 30px;border-left:1px solid var(--line-d)}
.st:first-child{border-left:none}
.st .n{font-family:var(--dp);font-weight:500;font-size:34px;color:#fff;line-height:1;letter-spacing:-.01em}
.st .n s{color:var(--green-l);text-decoration:none;font-size:18px}
.st .l{margin-top:9px;font-size:13px;color:rgba(255,255,255,.55)}
.st .l .e{display:none}

/* section */
section{padding:96px 0}
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:52px}
.head .lab{font-family:var(--mo);font-size:11.5px;letter-spacing:.2em;color:var(--green);text-transform:uppercase}
.head h2{font-family:var(--dp);font-weight:500;font-size:34px;color:var(--tx);letter-spacing:-.01em;margin-top:12px;line-height:1.2}
.head h2 span{display:none}
.head p{font-size:14.5px;color:var(--tx2);max-width:340px;text-align:right}

/* editorial / prose */
.ed{display:grid;grid-template-columns:.82fr 1.18fr;gap:54px;align-items:start}
.ed .side .k{font-family:var(--dp);font-weight:500;font-size:22px;color:var(--tx);line-height:1.3}
.ed .side .tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:7px}
.prose p{font-size:15.5px;line-height:1.95;color:var(--tx2);margin-bottom:18px}
.prose p:last-child{margin-bottom:0}
.pull{margin-top:30px;padding:22px 26px;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--green);border-radius:0 12px 12px 0;font-family:var(--dp);font-weight:500;font-size:18px;line-height:1.6;color:var(--tx)}

/* products */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.pc{background:var(--card);padding:38px 32px 32px;transition:.25s;position:relative}
.pc:hover{background:#F8F6F0}
.pc .ic{width:46px;height:46px;border-radius:11px;background:var(--paper2);display:flex;align-items:center;justify-content:center;color:var(--green);margin-bottom:26px;transition:.25s}
.pc:hover .ic{background:var(--green);color:#fff}
.pc .no{position:absolute;top:30px;right:30px;font-family:var(--mo);font-size:12px;color:var(--tx3)}
.pc h3{font-family:var(--dp);font-weight:500;font-size:21px;color:var(--tx)}
.pc .h-cn{display:none}
.pc p{font-size:14px;line-height:1.8;color:var(--tx2);margin-top:16px}
.pc .tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:7px}
.tag{font-family:var(--cn);font-size:12px;letter-spacing:.02em;color:var(--green-d);border:1px solid var(--line);border-radius:6px;padding:3px 9px}
.pc .more{margin-top:22px;font-size:13px;color:var(--green);font-weight:500;display:inline-flex;align-items:center;gap:7px}
.pc:hover .more svg{transform:translateX(4px)}.pc .more svg{transition:.2s}

/* capabilities dark */
.cap{background:var(--ink);color:#fff;padding:88px 0}
.cap .head h2{color:#fff}.cap .head h2 span{color:rgba(255,255,255,.4)}
.cap .head .lab{color:var(--green-l)}.cap .head p{color:rgba(255,255,255,.5)}
.cap .tag{color:var(--green-l);border-color:var(--line-d)}
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.cap-grid.two{grid-template-columns:repeat(2,1fr)}
.cap-it{padding:0 36px;border-left:1px solid var(--line-d)}
.cap-it:first-child{padding-left:0;border-left:none}
.cap-it .no{font-family:var(--mo);font-size:13px;color:var(--green-l)}
.cap-it .e{font-family:var(--mo);font-size:10.5px;letter-spacing:.16em;color:rgba(255,255,255,.4);text-transform:uppercase;margin-top:18px}
.cap-it h3{font-family:var(--dp);font-weight:500;font-size:23px;color:#fff;margin-top:7px}
.cap-it p{font-size:14px;line-height:1.85;color:rgba(255,255,255,.62);margin-top:16px}
.cap-it ul{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:9px}
.cap-it li{position:relative;padding-left:16px;font-size:13.5px;line-height:1.6;color:rgba(255,255,255,.66)}
.cap-it li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;background:var(--green-l);border-radius:50%}
.brandrow{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.brandchip{font-family:var(--mo);font-size:10.5px;letter-spacing:.04em;color:rgba(255,255,255,.82);border:1px solid var(--line-d);border-radius:6px;padding:4px 9px}

/* light logo wall (partner brands) */
.logowall{display:flex;flex-wrap:wrap;gap:12px}
.logoplate{font-family:var(--dp);font-weight:500;font-size:15.5px;letter-spacing:.01em;color:var(--tx);background:var(--card);border:1px solid var(--line);border-radius:10px;padding:13px 21px;transition:.2s}
.logoplate:hover{border-color:var(--green);color:var(--green)}

/* honors */
.honors{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.honor{background:var(--card);padding:22px 24px;display:flex;gap:13px;align-items:flex-start;font-size:14px;line-height:1.6;color:var(--tx)}
.honor svg{color:var(--green);flex:none;margin-top:2px}

/* global band */
.glob{background:var(--paper2);padding:88px 0}
.glob-in{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.glob .lab{font-family:var(--mo);font-size:11.5px;letter-spacing:.2em;color:var(--green);text-transform:uppercase}
.glob h2{font-family:var(--dp);font-weight:500;font-size:32px;color:var(--tx);margin-top:14px;line-height:1.25;letter-spacing:-.01em}
.glob p{font-size:15px;color:var(--tx2);line-height:1.9;margin-top:20px;max-width:480px}
.glob .pts{margin-top:26px;display:flex;flex-direction:column;gap:14px}
.glob .pt{display:flex;gap:13px;align-items:flex-start;font-size:14.5px;color:var(--tx)}
.glob .pt svg{flex:none;margin-top:3px;color:var(--green)}
.globe-art{display:flex;align-items:center;justify-content:center;height:330px}

/* cta */
.cta{background:var(--hero);color:#fff;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(ellipse 70% 90% at 30% 50%,#000,transparent)}
.cta-in{position:relative;display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;padding:76px 0}
.cta h2{font-family:var(--dp);font-weight:500;font-size:34px;color:#fff;line-height:1.2;letter-spacing:-.01em}
.cta .cn{font-family:var(--cn);font-weight:300;font-size:18px;color:rgba(255,255,255,.6);margin-top:10px}

/* footer */
footer{background:#070C09;color:rgba(255,255,255,.55);padding:64px 0 30px;font-size:14px}
.ft{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid var(--line-d)}
.ft .w{font-family:var(--dp);font-weight:600;font-size:20px;color:#fff;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.ft .w b{color:var(--green-l)}
.ft p{line-height:1.9;font-size:13.5px}
.ft h4{font-family:var(--mo);color:rgba(255,255,255,.4);font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:15px;font-weight:400}
.ft a{display:block;padding:5px 0;color:rgba(255,255,255,.62);font-size:13.5px}
.ft a:hover{color:var(--green-l)}
.ftb{padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:var(--mo);font-size:11px;letter-spacing:.06em;color:rgba(255,255,255,.32)}

.flag{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:99;background:#F4F2EC;color:var(--ink);font-size:12.5px;padding:9px 17px;border-radius:999px;box-shadow:0 10px 34px -10px rgba(0,0,0,.5);border:1px solid var(--line)}
.flag b{color:var(--green)}

@media(max-width:920px){
  .wrap{padding:0 18px}
  header{background:rgba(11,19,15,.97)}
  h1.t{font-size:clamp(2rem,6.8vw,2.5rem);line-height:1.14}
  .nav{flex-wrap:wrap;gap:10px;height:auto;min-height:70px}
  .burger{display:flex;order:3}
  .nav .btn-g{order:6;display:none;width:min(64vw,260px);margin:12px auto 2px;justify-content:center;padding:13px;font-size:15px;border-radius:9px}
  .mtoggle:checked ~ .btn-g{display:flex}
  nav.menu{display:none;order:5;width:100%;flex-direction:column;align-items:center;gap:0;margin:0;padding:2px 0 6px}
  .mtoggle:checked ~ nav.menu{display:flex}
  nav.menu a{width:min(64vw,260px);text-align:center;padding:13px 2px;font-size:16px;border-top:1px solid var(--line-d)}
  nav.menu a:first-child{border-top:none}
  nav.menu a::after{display:none}
  .has-sub{flex-direction:column;align-items:center;width:min(64vw,260px);position:static}
  .has-sub .sub-t{justify-content:center;width:100%;padding:13px 2px;font-size:16px;border-top:1px solid var(--line-d)}
  .has-sub .caret{display:none}
  .has-sub::after{display:none}
  .has-sub .submenu{position:static;opacity:1;visibility:visible;transform:none;width:100%;background:none;border:none;box-shadow:none;backdrop-filter:none;padding:2px 0 4px;min-width:0}
  .has-sub .submenu a{text-align:center;width:100%;padding:9px 2px;font-size:14px;color:rgba(255,255,255,.58);border-radius:0}
  .has-sub .submenu a::before{content:"· "}
  .lang{order:2;margin-left:auto;margin-right:2px;gap:5px;padding:0}
  .lang a{padding:6px 10px;font-size:12.5px}
  .hero-in,.glob-in,.ed{grid-template-columns:1fr;gap:32px}
  .hero-art{height:230px;order:-1}
  .stats-in{grid-template-columns:repeat(2,1fr)}.st:nth-child(3){border-left:none}
  .cards,.cap-grid,.cap-grid.two,.honors{grid-template-columns:1fr}
  .cap-it{padding:0;border-left:none;border-top:1px solid var(--line-d);padding-top:28px;margin-top:28px}
  .cap-it:first-child{border-top:none;margin-top:0;padding-top:0}
  .head{flex-direction:column;align-items:flex-start}.head p{text-align:left}
  .ft{grid-template-columns:1fr 1fr}
}

/* product list */
.pgroup{margin-bottom:46px}
.pgroup:last-child{margin-bottom:0}
.pgroup-h{display:flex;align-items:baseline;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.pgroup-h .x{font-family:var(--mo);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.pgroup-h h3{font-family:var(--dp);font-weight:500;font-size:22px;color:var(--tx)}
/* product category tabs */
.ptab-nav{display:flex;flex-wrap:wrap;gap:2px 4px;border-bottom:1px solid var(--line);margin-bottom:42px}
.ptab-btn{font-family:var(--dp);font-weight:500;font-size:14.5px;color:var(--tx2);background:none;border:none;border-bottom:2px solid transparent;padding:11px 15px;margin-bottom:-1px;cursor:pointer;transition:.2s;white-space:nowrap;border-radius:0}
.ptab-btn:hover{color:var(--tx)}
.ptab-btn.on{color:var(--green);border-bottom-color:var(--green)}
@media(max-width:920px){.ptab-nav{gap:0 2px}.ptab-btn{font-size:12.5px;padding:9px 9px}}
.plist{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.pitem{background:var(--card);padding:22px 22px;min-height:104px;display:flex;flex-direction:column;justify-content:space-between;transition:.2s}
.pitem:hover{background:#F8F6F0}
.pitem .pn{font-family:var(--dp);font-weight:400;font-size:15.5px;color:var(--tx);line-height:1.5}
.pitem .pt{font-family:var(--cn);font-size:12.5px;letter-spacing:.02em;color:var(--green-d);text-transform:uppercase;margin-top:12px}

/* equipment / spec list */
.eqgrid{border-top:1px solid var(--line)}
.eqcat{display:grid;grid-template-columns:96px 1fr;gap:24px;align-items:baseline;padding:22px 0;border-bottom:1px solid var(--line)}
.eqcat .el{font-family:var(--dp);font-weight:500;font-size:17px;color:var(--green)}
.eqcat .ev{display:flex;flex-wrap:wrap;gap:8px}
.eqcat .ev .tag{font-size:13px;padding:5px 11px}
@media(max-width:920px){.eqcat{grid-template-columns:1fr;gap:11px;padding:18px 0}}

/* product grade table */
.ptable{width:100%;border-collapse:collapse;margin-top:14px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--card)}
.ptable td{padding:15px 18px;border-bottom:1px solid var(--line);font-size:14px;line-height:1.65;color:var(--tx2);vertical-align:top}
.ptable tr:last-child td{border-bottom:0}
.ptable td:first-child{width:40%}
.ptable tr:hover td{background:#F8F6F0}
.ptable .g{font-family:var(--dp);font-weight:500;color:var(--tx);font-size:15px;letter-spacing:.01em}
.ptable .g .m{display:block;font-family:var(--cn);font-weight:400;font-size:13px;color:var(--green-d);margin-top:6px}
@media(max-width:920px){.ptable td{padding:12px 11px;font-size:13.5px}.ptable td:first-child{width:44%}.ptable .g{font-size:14px}}

/* news list */
.news{border-top:1px solid var(--line)}
.nitem{display:flex;gap:28px;align-items:baseline;padding:22px 6px;border-bottom:1px solid var(--line);transition:.2s;cursor:pointer}
.nitem:hover{background:var(--card)}
.nitem .nd{font-family:var(--mo);font-size:12.5px;color:var(--tx3);white-space:nowrap;min-width:104px}
.nitem .nt{font-size:16px;color:var(--tx);line-height:1.5;font-weight:400}
.nitem:hover .nt{color:var(--green)}
.nitem .na{margin-left:auto;color:var(--tx3);flex:none}
.nitem:hover .na{color:var(--green)}

/* contact cards + form */
.ccards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ccard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:28px 26px}
.ccard .ce{font-family:var(--mo);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}
.ccard .ct{font-family:var(--dp);font-weight:500;font-size:18px;color:var(--tx);margin-top:6px}
.ccard .cl{margin-top:16px;font-size:14px;line-height:1.85;color:var(--tx2)}
.ccard .cl b{color:var(--tx);font-weight:500}
.cform{display:grid;gap:13px;max-width:600px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.cform input,.cform textarea{font-family:var(--cn);font-size:15px;padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:var(--card);color:var(--tx);width:100%}
.cform textarea{min-height:130px;resize:vertical}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,139,87,.12)}
.cform button{justify-self:start}

@media(max-width:920px){
  .plist{grid-template-columns:repeat(2,1fr)}
  .ccards{grid-template-columns:1fr}
  .cform .row2{grid-template-columns:1fr}
  .nitem{flex-wrap:wrap;gap:4px 20px}
}

/* group grid (2-col) */
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}

/* timeline */
.tl{margin-top:6px}
.tl-i{display:grid;grid-template-columns:84px 1fr;gap:22px;align-items:start}
.tl-i .yr{font-family:var(--dp);font-weight:600;font-size:19px;color:var(--green);padding-top:1px}
.tl-i .bd{border-left:2px solid var(--line);padding:0 0 26px 26px;position:relative}
.tl-i:last-child .bd{padding-bottom:2px}
.tl-i .bd::before{content:"";position:absolute;left:-8px;top:4px;width:13px;height:13px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--paper)}
.tl-i .tt{font-family:var(--dp);font-weight:500;font-size:16px;color:var(--tx)}
.tl-i .td{font-size:13.5px;color:var(--tx2);margin-top:5px;line-height:1.7}

@media(max-width:920px){
  .grid2{grid-template-columns:1fr}
  .tl-i{grid-template-columns:54px 1fr;gap:14px}
}

/* Japanese heroes: long katakana compounds need smaller heads to avoid mid-word wraps */
html[lang="ja"] h1.t{font-size:clamp(1.85rem,3.3vw,2.7rem);line-height:1.24}
html[lang="ja"] .pagehero h1{font-size:clamp(1.6rem,2.9vw,2.3rem);line-height:1.28}

/* advisor headshots */
.ccard .advisor-photo{width:76px;height:76px;border-radius:50%;object-fit:cover;object-position:center top;border:1px solid var(--line);display:block;margin-bottom:18px}
/* certificate view link */
.cert-link{font-size:11.5px;font-weight:500;color:var(--green);white-space:nowrap}
.cert-link:hover{text-decoration:underline}
/* feature image (e.g. plaque) */
.feat-img{width:100%;border-radius:12px;border:1px solid var(--line);display:block;margin-bottom:22px}
/* QR scan card */
.qr-card{display:flex;align-items:center;gap:20px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 20px;max-width:540px}
.qr-card img{width:96px;height:96px;flex:none;background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px;box-sizing:border-box;object-fit:contain}
.qr-card .qr-t{font-family:var(--dp);font-weight:600;font-size:18px;color:var(--tx)}
.qr-card .qr-d{font-size:13.5px;color:var(--tx2);margin-top:6px;line-height:1.6}
.qr-card .qr-h{font-family:var(--mo);font-size:10.5px;letter-spacing:.06em;color:var(--tx3);margin-top:8px;text-transform:uppercase}
@media(max-width:920px){.qr-card{gap:16px;padding:14px 16px}.qr-card img{width:84px;height:84px}}
/* business model (自主 + ODM/OEM) */
.ratio-bar{display:flex;height:11px;border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.ratio-bar span{display:block}
.ratio-bar .r-self{background:var(--green)}
.ratio-bar .r-odm{background:var(--tx)}
.ratio-lab{display:flex;justify-content:space-between;font-family:var(--mo);font-size:11.5px;color:var(--tx2);margin-top:9px}
.ratio-lab .rl-self{color:var(--green)}
.bm-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px 20px;margin-top:18px}
.bm-it .bm-t{font-size:14.5px;color:var(--tx)}
.bm-it .bm-d{font-size:12px;color:var(--tx3);margin-top:3px}
/* application fields strip (homepage products) */
.appfields{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-top:36px;padding-top:28px;border-top:1px solid var(--line)}
.appfields .af-lab{font-family:var(--mo);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx3);margin-right:8px}
/* culture page amenity grid */
.culture-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:6px}
@media(max-width:900px){.culture-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.culture-grid{grid-template-columns:1fr}}
/* amenity photo cards + gallery */
.amen-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.amen-card img{width:100%;height:190px;object-fit:cover;display:block}
.amen-card .ac-body{padding:15px 17px 17px}
.amen-card .ac-cn{font-family:var(--mo);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx3)}
.amen-card .ac-t{font-family:var(--dp);font-weight:600;font-size:16px;color:var(--tx);margin:3px 0 7px}
.amen-card .ac-d{font-size:12.5px;color:var(--tx2);line-height:1.55}
.amen-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px}
.amen-gallery img{width:100%;height:160px;object-fit:cover;border-radius:10px;border:1px solid var(--line);display:block}
@media(max-width:900px){.amen-gallery{grid-template-columns:repeat(2,1fr)}}
/* park / facility feature images */
.park-imgs{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:32px}
.park-imgs img{width:100%;height:290px;object-fit:cover;border-radius:12px;border:1px solid var(--line);display:block}
@media(max-width:680px){.park-imgs{grid-template-columns:1fr}.park-imgs img{height:230px}}
/* team-life gallery (culture) */
.team-hero{width:100%;height:360px;object-fit:cover;border-radius:14px;border:1px solid var(--line);display:block;margin-bottom:13px}
.team-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.team-gallery img{width:100%;height:170px;object-fit:cover;border-radius:10px;border:1px solid var(--line);display:block}
@media(max-width:680px){.team-hero{height:240px}.team-gallery{grid-template-columns:1fr 1fr}}
