/* ============================================================
   HHP PAPER — Section styles
   ============================================================ */

/* ---------- ribbon / motif band ---------- */
.ribbon{position:relative;background:var(--bg-alt)}
.ribbon--blue{background:linear-gradient(160deg,var(--blue-700),var(--blue-600));color:#fff}

/* ============================================================
   ECOSYSTEM — connected GO GREEN journey (flow + detail)
   ============================================================ */
.eco{background:var(--paper-50);position:relative;overflow:hidden}
.eco .wrap{position:relative;z-index:2}
.eco-head{text-align:center;max-width:62ch;margin:0 auto 3.2rem}
.eco-head .section-title,.eco-head .section-intro{margin-inline:auto}
@keyframes flowdash{to{stroke-dashoffset:-32}}

.eco-flow{position:relative;margin-top:2.4rem;padding:18px 0}
.eco-track{position:absolute;inset:0;width:100%;height:100%;overflow:visible;z-index:1;pointer-events:none}
.eco-track path{fill:none}
.eco-track path.base{stroke:var(--blue-200);stroke-width:2.5;
  stroke-dasharray:var(--len);stroke-dashoffset:var(--len);
  transition:stroke-dashoffset calc(1.6s * var(--motion) + .01s) var(--ease-soft)}
.eco-flow.in .eco-track path.base{stroke-dashoffset:0}
.eco-track path.flow{stroke:var(--blue-400);stroke-width:3;stroke-dasharray:2 14;
  animation:flowdash 1.1s linear infinite;opacity:0;transition:opacity .6s}
.eco-flow.in .eco-track path.flow{opacity:.85}
:root[data-motion="off"] .eco-track path.flow{animation:none}

.eco-nodes{position:relative;z-index:2;display:flex;gap:16px;align-items:flex-start}
.eco-node2{flex:1;min-width:0;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-lg);
  padding:20px 14px;text-align:center;cursor:pointer;font-family:inherit;color:var(--text);
  transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1),border-color var(--dur-1);
  box-shadow:var(--sh-sm);position:relative}
.eco-node2:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.eco-node2 .mark{width:44px;height:44px;margin:0 auto 10px;transition:transform var(--dur-1) var(--ease-out)}
.eco-node2:hover .mark{transform:scale(1.08)}
.eco-node2 h4{font-size:1.02rem;letter-spacing:-.01em}
.eco-node2 h4 b{color:var(--accent)}
.eco-node2 .tag{font-size:.74rem;color:var(--text-soft);margin-top:.3em;line-height:1.35}
.eco-node2.active{border-color:var(--primary);box-shadow:var(--sh-blue)}
.eco-node2.is-paper{border-color:var(--accent)}
.eco-node2.is-paper.active{box-shadow:0 18px 44px -16px rgba(245,116,69,.55)}
.eco-node2.is-paper::after{content:attr(data-flag);position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;font-size:.6rem;font-weight:var(--fw-bold);letter-spacing:.1em;
  padding:.32em .8em;border-radius:var(--r-pill);white-space:nowrap;text-transform:uppercase}
.eco-node2.is-hub{background:linear-gradient(150deg,var(--green-700),var(--green-500));color:#fff;border-color:transparent}
.eco-node2.is-hub .tag{color:rgba(255,255,255,.85)}
.eco-node2.is-hub .go{font-weight:var(--fw-black);font-size:1.12rem;letter-spacing:-.01em}
.eco-node2.is-hub .go b{color:#fff}
.eco-node2.is-hub.active{box-shadow:0 18px 44px -16px rgba(31,143,77,.6)}
/* zigzag offsets on desktop */
@media (min-width:761px){
  .eco-nodes{align-items:center}
  .eco-node2{margin-top:-46px}
  .eco-node2:nth-child(even){margin-top:46px}
}

/* detail panel */
.eco-detail{margin-top:clamp(40px,5vw,64px);display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,3vw,32px);
  align-items:center;background:#fff;border:1px solid var(--line);border-left:5px solid var(--accent);
  border-radius:var(--r-xl);padding:clamp(22px,3vw,32px) clamp(24px,4vw,40px);box-shadow:var(--sh-md);
  transition:border-color .35s,opacity .3s,transform .3s}
.eco-detail.swap{opacity:0;transform:translateY(8px)}
.eco-detail .d-ic{width:80px;height:80px;border-radius:20px;display:grid;place-items:center;
  background:var(--blue-050);flex:none;transition:background .35s}
.eco-detail .d-ic .mark{width:50px;height:50px}
.eco-detail .d-flag{display:inline-block;font-size:.66rem;font-weight:var(--fw-bold);letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent);margin-bottom:.4em}
.eco-detail h3{font-size:var(--t-h3)}
.eco-detail h3 b{color:var(--accent)}
.eco-detail p{color:var(--text-soft);margin-top:.5em;max-width:64ch;font-size:.98rem}
.eco-detail .d-cta{white-space:nowrap}
@media (max-width:860px){
  .eco-detail{grid-template-columns:auto 1fr;gap:20px}
  .eco-detail .d-cta{display:none}
}
@media (max-width:760px){
  .eco-nodes{flex-direction:column;gap:12px}
  .eco-node2{display:flex;align-items:center;gap:14px;text-align:left;padding:14px 16px}
  .eco-node2 .mark{margin:0;width:40px;height:40px;flex:none}
  .eco-node2.is-paper::after{left:auto;right:14px;top:50%;transform:translateY(-50%)}
  .eco-track{display:none}
  .eco-detail{grid-template-columns:1fr;text-align:left}
  .eco-detail .d-ic{display:none}
}

/* ============================================================
   CAPACITY — factories + VN map
   ============================================================ */
.cap{background:#fff}
.cap-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(32px,5vw,72px);align-items:center;margin-top:3rem}
.cap-map{position:relative}
.cap-map .cap-img{display:block;width:100%;max-width:430px;height:auto;margin:0 auto;
  filter:drop-shadow(0 24px 44px rgba(1,103,177,.22));
  transition:transform var(--dur-2) var(--ease-out),opacity var(--dur-2);}
.cap-stage.reveal .cap-img{transform:translateY(calc(20px * var(--motion))) scale(.98)}
.cap-stage.reveal.in .cap-img{transform:none}
.cap-map svg{width:100%;height:auto;filter:drop-shadow(0 20px 40px rgba(1,103,177,.18))}
.cap-map .land{fill:var(--blue-050);stroke:var(--blue-200);stroke-width:1.5}
.pin{cursor:pointer}
.pin .ring{fill:none;stroke:var(--accent);stroke-width:2;transform-origin:center;transform-box:fill-box}
.pin .core{fill:var(--accent)}
.cap-stage.in .pin .ring{animation:ping 2.2s var(--ease-out) infinite}
@keyframes ping{0%{transform:scale(.4);opacity:1}80%,100%{transform:scale(2.6);opacity:0}}
.pin-label{font-size:13px;font-weight:var(--fw-bold);fill:var(--ink-900)}
.pin-label tspan.sub{font-size:10px;font-weight:var(--fw-med);fill:var(--text-soft)}
.cap-map .islands circle{fill:var(--blue-300)}
.isl-label{font-size:9.5px;font-weight:var(--fw-semi);letter-spacing:.08em;fill:var(--ink-300)}

.cap-cards{display:flex;flex-direction:column;gap:18px}
.fac{display:grid;grid-template-columns:auto 1fr;gap:20px;background:var(--paper-50);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:22px;align-items:center;transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1)}
.fac:hover{transform:translateX(6px);box-shadow:var(--sh-md)}
.fac__media{width:120px;height:120px;border-radius:var(--r-md);overflow:hidden;flex:none;background:var(--blue-100)}
.fac__media image-slot{width:100%;height:100%}
.fac__no{font-size:.7rem;font-weight:var(--fw-bold);letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.fac h4{font-size:var(--t-h3);margin-top:.2em}
.fac .cap-n{font-size:clamp(1.6rem,1.1rem+1.2vw,2.2rem);font-weight:var(--fw-black);color:var(--primary);letter-spacing:-.02em;line-height:1.1;margin-top:.4em}
.fac .cap-n b{font-size:.55em;color:var(--text-soft);font-weight:var(--fw-semi)}
.fac .meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:.5em;font-size:.82rem;color:var(--text-soft)}
.cap-total{display:flex;align-items:baseline;gap:14px;margin-top:6px;padding:18px 22px;border-radius:var(--r-lg);
  background:linear-gradient(120deg,var(--blue-700),var(--blue-500));color:#fff;box-shadow:var(--sh-blue)}
.cap-total .n{font-size:clamp(1.8rem,1.2rem+1.6vw,2.6rem);font-weight:var(--fw-black);letter-spacing:-.02em}
.cap-total .l{font-size:.85rem;opacity:.9}

/* ============================================================
   ESG — mindmap + roadmap
   ============================================================ */
.esg{background:linear-gradient(180deg,#06203a,#0a2d4f);color:#fff;position:relative;overflow:hidden}
.esg .eyebrow{color:var(--green-300)}
.esg .eyebrow::before{background:var(--green-500)}
.esg .section-intro{color:rgba(255,255,255,.78)}
.esg-pills{display:flex;gap:12px;flex-wrap:wrap;margin-top:1.6rem}
.esg-pill{display:inline-flex;align-items:center;gap:.5em;border:1px solid rgba(255,255,255,.2);
  border-radius:var(--r-pill);padding:.5em 1.1em;font-weight:var(--fw-semi);font-size:.9rem;background:rgba(255,255,255,.05)}
.esg-pill .d{width:10px;height:10px;border-radius:3px}

/* process mindmap */
.mindmap{margin-top:3.5rem;position:relative}
.mindmap-track{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;position:relative;z-index:2}
.mm-node{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);
  padding:20px 16px;text-align:center;position:relative;backdrop-filter:blur(4px);
  transition:transform var(--dur-1) var(--ease-out),background var(--dur-1),border-color var(--dur-1)}
.mm-node:hover{transform:translateY(-6px);background:rgba(255,255,255,.12);border-color:var(--green-300)}
.mm-ic{width:56px;height:56px;border-radius:14px;margin:0 auto 12px;display:grid;place-items:center;
  background:linear-gradient(140deg,var(--green-500),var(--blue-400));color:#fff}
.mm-ic svg{width:28px;height:28px}
.mm-node .step{position:absolute;top:10px;right:12px;font-size:.7rem;font-weight:var(--fw-black);color:rgba(255,255,255,.3)}
.mm-node h4{font-size:1rem}
.mm-node p{font-size:.78rem;color:rgba(255,255,255,.66);margin-top:.4em;line-height:1.4}
.mindmap-arrows{position:absolute;inset:0;z-index:1;pointer-events:none}
.mindmap-arrows svg{width:100%;height:100%}
.mindmap-arrows path{fill:none;stroke:var(--green-300);stroke-width:2;stroke-dasharray:6 8;opacity:.45;
  animation:flowdash2 1.4s linear infinite}
:root[data-motion="off"] .mindmap-arrows path{animation:none}
@keyframes flowdash2{to{stroke-dashoffset:-28}}
.mm-loop{display:inline-flex;align-items:center;gap:.6em;margin-top:1.8rem;font-size:.85rem;color:var(--green-300);font-weight:var(--fw-semi)}

/* netzero roadmap */
.roadmap{margin-top:4.5rem}
.roadmap-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:2rem}
.netzero-badge{display:inline-flex;flex-direction:column;align-items:flex-end}
.netzero-badge .y{font-size:clamp(2.4rem,1.4rem+3vw,4rem);font-weight:var(--fw-black);line-height:.9;
  background:linear-gradient(100deg,var(--green-300),var(--blue-200));-webkit-background-clip:text;background-clip:text;color:transparent}
.netzero-badge .t{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.rm-line{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:34px}
.rm-line::before{content:"";position:absolute;top:42px;left:5%;right:5%;height:3px;
  background:linear-gradient(90deg,var(--blue-400),var(--green-500));border-radius:3px;opacity:.5}
.rm-step{position:relative}
.rm-step .dot{width:18px;height:18px;border-radius:50%;background:var(--green-500);border:4px solid #0a2d4f;
  position:absolute;top:-34px;left:0;box-shadow:0 0 0 3px var(--green-500)}
.rm-step.done .dot{background:var(--blue-400);box-shadow:0 0 0 3px var(--blue-400)}
.rm-step .yr{font-size:1.4rem;font-weight:var(--fw-black);color:#fff}
.rm-step h4{font-size:.96rem;margin-top:.2em;color:var(--green-300)}
.rm-step p{font-size:.8rem;color:rgba(255,255,255,.66);margin-top:.4em}
.esg-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:3.5rem}
.metric{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:22px}
.metric .n{font-size:clamp(1.8rem,1.2rem+1.6vw,2.6rem);font-weight:var(--fw-black);letter-spacing:-.02em;
  background:linear-gradient(120deg,#fff,var(--green-300));-webkit-background-clip:text;background-clip:text;color:transparent}
.metric .l{font-size:.82rem;color:rgba(255,255,255,.7);margin-top:.3em}

/* ============================================================
   PRODUCTS
   ============================================================ */
.prod{background:#fff}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:3rem}
.pcard{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:var(--sh-sm);
  transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1);display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--sh-lg)}
.pcard__media{aspect-ratio:4/3;background:var(--blue-100);position:relative;overflow:hidden}
.pcard__media image-slot{width:100%;height:100%}
.pcard__media .badge{position:absolute;top:14px;left:14px;background:var(--primary);color:#fff;font-size:.72rem;
  font-weight:var(--fw-bold);padding:.4em .8em;border-radius:var(--r-pill);z-index:3}
.pcard__body{padding:22px;display:flex;flex-direction:column;flex:1}
.pcard h4{font-size:var(--t-h3)}
.pcard .gsm{font-size:.8rem;color:var(--accent);font-weight:var(--fw-bold);margin-top:.2em;letter-spacing:.04em}
.pcard p{font-size:.9rem;color:var(--text-soft);margin-top:.7em;flex:1}
.pcard .specs{display:flex;gap:8px;flex-wrap:wrap;margin-top:1rem}
.pcard-link{margin-top:1.1rem;display:inline-flex;align-items:center;gap:.45em;font-weight:var(--fw-semi);color:var(--primary);font-size:.9rem}
.pcard-link svg{width:1.05em;height:1.05em;transition:transform .2s}
.pcard:hover .pcard-link{color:var(--accent)}
.pcard:hover .pcard-link svg{transform:translateX(3px)}
.spec{font-size:.74rem;font-weight:var(--fw-semi);color:var(--ink-700);background:var(--paper-100);padding:.35em .7em;border-radius:var(--r-sm)}
.prod-extra{margin-top:22px;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  background:var(--green-050);border:1px solid var(--green-300);border-radius:var(--r-lg);padding:24px 28px}
.prod-extra .ic{width:56px;height:56px;border-radius:14px;background:var(--green-500);color:#fff;display:grid;place-items:center;flex:none}
.prod-extra h4{font-size:var(--t-h3);color:var(--green-700)}
.prod-extra p{font-size:.9rem;color:var(--ink-700);margin-top:.3em;max-width:60ch}

/* ============================================================
   INVESTORS / PARTNERS
   ============================================================ */
.inv{background:var(--paper-50)}
.inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);align-items:center;margin-top:2.5rem}
.inv-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.inv-stat{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-sm)}
.inv-stat .n{font-size:clamp(1.6rem,1.1rem+1.4vw,2.4rem);font-weight:var(--fw-black);color:var(--primary);letter-spacing:-.02em}
.inv-stat .n b{color:var(--accent)}
.inv-stat .l{font-size:.84rem;color:var(--text-soft);margin-top:.3em}
.partners{margin-top:3.4rem}
.partners .pt-label{text-align:center;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-soft);font-weight:var(--fw-semi)}
.partner-row{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:1.4rem}
.partner-logo{height:74px;border:1px dashed var(--line-strong);border-radius:var(--r-md);display:grid;place-items:center;
  color:var(--ink-300);font-weight:var(--fw-bold);font-size:.78rem;background:#fff;transition:.3s}
.partner-logo:hover{border-style:solid;border-color:var(--blue-200);color:var(--primary)}

/* ============================================================
   NEWS + STOCK
   ============================================================ */
.news{background:#fff}
.news-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,52px);margin-top:3rem;align-items:start}
.stock{background:linear-gradient(165deg,#06203a,#0c3358);color:#fff;border-radius:var(--r-xl);padding:26px;box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.stock__top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.stock__sym{display:flex;align-items:center;gap:12px}
.stock__sym .badge{width:46px;height:46px;border-radius:12px;background:#fff;display:grid;place-items:center}
.stock__sym .badge .mark{width:30px;height:30px}
.stock__sym .t{font-weight:var(--fw-black);font-size:1.3rem;letter-spacing:-.01em}
.stock__sym .e{font-size:.74rem;color:rgba(255,255,255,.6);letter-spacing:.1em}
.stock__price{text-align:right}
.stock__price .p{font-size:2rem;font-weight:var(--fw-black);letter-spacing:-.02em;line-height:1}
.stock__price .chg{font-size:.86rem;font-weight:var(--fw-bold);margin-top:.3em;display:inline-flex;align-items:center;gap:.3em}
.chg.up{color:#46d98a}.chg.down{color:#ff7a6b}
.stock__chart{margin-top:20px;position:relative;height:140px}
.stock__chart svg{width:100%;height:100%;overflow:visible}
.stock__chart .area{fill:url(#stockgrad)}
.stock__chart .line{fill:none;stroke:#46d98a;stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}
.stock__chart .cursor{fill:#fff}
.stock__row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:18px;border-top:1px solid rgba(255,255,255,.12);padding-top:16px}
.stock__cell .k{font-size:.7rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em}
.stock__cell .v{font-size:1rem;font-weight:var(--fw-bold);margin-top:.2em}
.stock__note{margin-top:16px;font-size:.7rem;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:.5em}
.stock__live{display:inline-flex;align-items:center;gap:.4em;font-size:.72rem;font-weight:var(--fw-bold);color:#46d98a}
.stock__live .ld{width:7px;height:7px;border-radius:50%;background:#46d98a;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.news-list{display:flex;flex-direction:column;gap:16px}
.ncard{display:grid;grid-template-columns:120px 1fr;gap:18px;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;background:#fff;transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1)}
.ncard:hover{transform:translateX(5px);box-shadow:var(--sh-md)}
.ncard__media{background:var(--blue-100);position:relative}
.ncard__media image-slot{width:100%;height:100%}
.ncard__body{padding:16px 18px 16px 0;display:flex;flex-direction:column;gap:.4em}
.ncard .cat{font-size:.7rem;font-weight:var(--fw-bold);letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.ncard h4{font-size:1.02rem;line-height:1.3}
.ncard .date{font-size:.78rem;color:var(--text-soft);margin-top:auto}

/* ============================================================
   CTA + FORM
   ============================================================ */
.cta{background:linear-gradient(150deg,var(--blue-700),var(--blue-600) 60%,var(--blue-500));color:#fff;position:relative;overflow:hidden}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;position:relative;z-index:2}
.cta h2{font-size:var(--t-h1);font-weight:var(--fw-black)}
.cta-lead{font-size:var(--t-lead);color:rgba(255,255,255,.85);margin-top:1.2rem;max-width:46ch}
.cta-points{margin-top:1.8rem;display:flex;flex-direction:column;gap:12px}
.cta-points li{display:flex;align-items:center;gap:.8em;font-weight:var(--fw-med)}
.cta-points .ck{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.15);display:grid;place-items:center;flex:none}
.cta-points .ck svg{width:14px;height:14px}
.form-card{background:#fff;color:var(--ink-900);border-radius:var(--r-xl);padding:clamp(24px,3vw,38px);box-shadow:var(--sh-lg)}
.form-card h3{font-size:var(--t-h3)}
.form-card .fc-sub{font-size:.9rem;color:var(--text-soft);margin-top:.3em}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:1.4rem}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:.78rem;font-weight:var(--fw-semi);color:var(--ink-700)}
.field input,.field textarea,.field select{
  font-family:inherit;font-size:.95rem;padding:.8em .9em;border:1.5px solid var(--line-strong);
  border-radius:var(--r-md);background:var(--paper-50);color:var(--ink-900);transition:border-color .2s,box-shadow .2s;width:100%}
.field textarea{resize:vertical;min-height:84px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--blue-050);background:#fff}
.field.invalid input,.field.invalid textarea{border-color:var(--orange-500);box-shadow:0 0 0 4px var(--orange-100)}
.field .err{font-size:.72rem;color:var(--orange-600);display:none}
.field.invalid .err{display:block}
.form-submit{margin-top:1.2rem}
.form-success{display:none;text-align:center;padding:30px 10px}
.form-success.show{display:block}
.form-success .ck{width:64px;height:64px;border-radius:50%;background:var(--green-050);color:var(--green-700);display:grid;place-items:center;margin:0 auto 16px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#06203a;color:rgba(255,255,255,.72);padding-block:clamp(48px,6vw,80px) 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(24px,4vw,56px)}
.footer .brand__name span{color:#fff}
.footer .brand__sub{color:rgba(255,255,255,.5)}
.footer-about{font-size:.88rem;line-height:1.6;margin-top:1.2rem;max-width:34ch}
.footer h5{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem;font-weight:var(--fw-bold)}
.footer-links{display:flex;flex-direction:column;gap:.7em;font-size:.9rem}
.footer-links a:hover{color:#fff}
.footer-contact{display:flex;flex-direction:column;gap:.8em;font-size:.9rem}
.footer-contact .ln{display:flex;gap:.7em;align-items:flex-start}
.footer-contact svg{width:18px;height:18px;flex:none;color:var(--blue-200);margin-top:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:clamp(32px,4vw,56px);padding-top:24px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.8rem;color:rgba(255,255,255,.5)}
.footer-social{display:flex;gap:10px}
.footer-social a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;transition:.3s}
.footer-social a:hover{background:#fff;color:var(--blue-700)}
.footer-social svg{width:18px;height:18px}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero[data-variant="a"] .hero-visual{max-width:420px}
  .cap-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .cta-grid,.inv-grid{grid-template-columns:1fr}
  .rm-line,.esg-metrics{grid-template-columns:repeat(2,1fr)}
  .partner-row{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  .nav,.header .btn--accent{display:none}
  .menu-toggle{display:grid;place-items:center}
  .header.menu-open .nav{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:#fff;padding:16px;gap:4px;box-shadow:var(--sh-lg);border-top:1px solid var(--line)}
  .header.menu-open .nav a{padding:.8em 1em}
  .prod-grid{grid-template-columns:1fr;gap:16px}
  .mindmap-track{grid-template-columns:1fr 1fr}
  .mindmap-arrows{display:none}
  .prod-extra{grid-template-columns:1fr;text-align:center;justify-items:center}
  .footer-grid{grid-template-columns:1fr 1fr}
  /* ecosystem -> stacked list on small screens */
  .eco-stage{display:none}
  .eco-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:2rem}
  .fac{grid-template-columns:1fr}
  .fac__media{width:100%;height:160px}
}
@media (max-width:480px){
  .form-grid{grid-template-columns:1fr}
  .rm-line,.esg-metrics,.mindmap-track,.eco-list,.footer-grid,.inv-stats{grid-template-columns:1fr}
  .hero-stats{gap:18px}
}
