/*
Theme Name: MIM 2026
Theme URI: https://www.mibiax.fr
Author: Molecular Intelligent Machinery
Description: Premium multilingual theme for MIM — biaxial film stretching lines. Brand navy + scarce red, technical mono figures, authentic machinery imagery.
Version: 1.0.0
Requires at least: 6.4
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: mim
*/

/* ============================ Design tokens ============================ */
:root{
  --navy:#004ea1;            /* MIM primary */
  --navy-deep:#042c54;       /* hero / stats background */
  --navy-700:#0c3b6b;
  --red:#da251d;             /* scarce accent */
  --ink:#0c2745;             /* primary text */
  --gray:#5b6878;            /* secondary text */
  --gray-2:#8a97a6;
  --line:#e6e8ec;            /* borders */
  --bg:#ffffff;
  --bg-alt:#f6f7f9;
  --on-navy:#ffffff;
  --on-navy-soft:#aebfd4;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"PingFang SC","Hiragino Sans GB","Microsoft YaHei","Noto Sans SC","Noto Sans JP","Noto Sans KR",sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SFMono-Regular","Roboto Mono",Menlo,Consolas,monospace;
  --wrap:1200px;
  --pad:clamp(20px,5vw,40px);
}

/* ============================ Base ============================ */
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--red)}
h1,h2,h3{line-height:1.18;font-weight:600;color:var(--ink);margin:0}
p{margin:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--navy);margin:0 0 12px}
.section{padding:clamp(56px,8vw,104px) 0}
.btn{display:inline-block;font-size:14px;font-weight:500;padding:12px 22px;border-radius:6px;border:1px solid var(--navy);color:var(--navy);background:transparent;transition:.2s}
.btn:hover{background:var(--navy);color:#fff}
.btn--solid{background:var(--navy);color:#fff}
.btn--solid:hover{background:var(--red);border-color:var(--red);color:#fff}
.btn--ghost{border-color:#fff;color:#fff}
.btn--ghost:hover{background:#fff;color:var(--navy-deep)}

/* ============================ Header ============================ */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink)}
.brand__mark{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--navy);color:#fff;font-weight:600;font-size:14px;border-radius:5px;letter-spacing:.5px}
.brand__name{font-size:19px;font-weight:600;letter-spacing:.4px}
.brand__name .dot{color:var(--red)}
.brand__logo{height:38px;width:auto;display:block}
.site-footer .brand__logo{height:34px}
.nav{display:flex;align-items:center;gap:26px}
.nav a{color:var(--ink);font-size:14.5px;font-weight:500;position:relative}
.nav a:hover{color:var(--red)}
.nav a.active{color:var(--navy)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;background:var(--red);border-radius:2px}
.site-header{transition:box-shadow .25s,background .25s}
.site-header.scrolled{box-shadow:0 6px 22px rgba(12,39,69,.09)}
.lang{position:relative}
.lang__btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--ink);border:1px solid var(--line);border-radius:6px;padding:7px 11px;cursor:pointer;background:#fff}
.lang__menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px;min-width:148px;box-shadow:0 12px 30px rgba(12,39,69,.12);display:none}
.lang.open .lang__menu{display:block}
.lang__menu a{display:block;font-size:13.5px;color:var(--ink);padding:8px 12px;border-radius:5px}
.lang__menu a:hover{background:var(--bg-alt);color:var(--navy)}
.lang__menu a.current{color:var(--navy);font-weight:600}
.nav-toggle{display:none;background:none;border:0;font-size:24px;color:var(--ink);cursor:pointer}
.header-actions{display:flex;align-items:center;gap:14px}

/* ============================ Entry (inner pages) ============================ */
.entry{font-size:17px;color:var(--ink)}
.entry p{margin:0 0 1.1em}
.entry h2{font-size:25px;margin:1.5em 0 .5em}
.entry h3{font-size:19px;margin:1.3em 0 .4em}
.entry ul,.entry ol{margin:0 0 1.1em;padding-left:1.3em}
.entry li{margin:.3em 0}
.entry img{border-radius:8px;margin:1.2em 0}

/* ============================ Hero ============================ */
.hero{background:var(--navy-deep);color:var(--on-navy);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 85% 10%,rgba(12,59,107,.55),transparent 60%);pointer-events:none}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding-top:clamp(64px,9vw,120px);padding-bottom:clamp(64px,9vw,120px)}
.hero .eyebrow{color:#5f9fe0}
.hero h1{font-size:clamp(30px,4.6vw,52px);font-weight:600;color:#fff;letter-spacing:-.5px}
.hero__rule{width:56px;height:3px;background:var(--red);margin:22px 0}
.hero__lead{font-size:clamp(15px,1.6vw,18px);color:var(--on-navy-soft);max-width:480px}
.hero__cta{margin-top:30px;display:flex;gap:12px;flex-wrap:wrap}
.hero__media{aspect-ratio:4/3;border-radius:10px;border:1px solid #1c4a78;background:var(--navy-700) center/cover no-repeat;background-blend-mode:luminosity;position:relative;display:flex;align-items:flex-end;padding:14px;min-height:240px}
.hero__media span{font-family:var(--mono);font-size:11px;color:#7aa6d6}

/* ============================ Products ============================ */
.products .head{max-width:680px;margin-bottom:40px}
.products h2{font-size:clamp(23px,3vw,34px)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;transition:.25s;display:flex;flex-direction:column}
.card:hover{border-color:#c7d2df;transform:translateY(-3px)}
.card__img{aspect-ratio:4/3;background:#eef1f5 center/cover no-repeat}
.card__body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__body h3{font-size:17px;font-weight:600}
.card__body p{font-size:14px;color:var(--gray)}
.card__more{margin-top:auto;font-size:13px;font-weight:500;color:var(--red);background:none;border:0;padding:0;cursor:pointer;text-align:left;font-family:inherit}
.card__more:hover{color:var(--navy)}
.card__more[aria-expanded="true"] span{display:inline-block;transform:rotate(90deg)}
.card__detail{margin-top:10px;font-size:13px;color:var(--gray);line-height:1.6}

/* ============================ Technology ============================ */
.tech{background:var(--bg-alt)}
.tech .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.tech h2{font-size:clamp(23px,3vw,34px);margin-bottom:16px}
.tech p{color:var(--gray)}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.spec{background:#fff;padding:22px}
.spec b{display:block;font-family:var(--mono);font-size:26px;font-weight:500;color:var(--navy)}
.spec span{font-size:13px;color:var(--gray)}

/* ============================ Stats ============================ */
.stats{background:var(--navy-deep);color:#fff}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.stat b{font-family:var(--mono);font-size:clamp(34px,5vw,52px);font-weight:500;color:#fff;line-height:1;display:block}
.stat b i{color:var(--red);font-style:normal}
.stat span{display:block;margin-top:10px;font-size:14px;color:var(--on-navy-soft)}

/* ============================ Team ============================ */
.team h2{font-size:clamp(23px,3vw,34px);margin-bottom:40px}
.team .grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.member{display:grid;grid-template-columns:140px 1fr;gap:22px;border:1px solid var(--line);border-radius:12px;padding:24px;background:#fff}
.member__photo{width:140px;height:160px;border-radius:8px;background:#eef1f5 center/cover no-repeat}
.member h3{font-size:18px}
.member .role{font-family:var(--mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--navy);margin:4px 0 12px}
.member p{font-size:14px;color:var(--gray);line-height:1.65}

/* ============================ References ============================ */
.refs{background:var(--bg-alt);text-align:center}
.sustain{text-align:center}
.sustain h2{max-width:18ch;margin-left:auto;margin-right:auto}
.sustain__lead{max-width:760px;margin:18px auto 0;color:var(--gray);font-size:17px;line-height:1.85}
.about__lead{max-width:840px;margin-top:14px;color:var(--gray);font-size:16.5px;line-height:1.9}
.service__lead{max-width:760px;margin:14px 0 0;color:var(--gray);font-size:16px;line-height:1.8}
.service__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:30px}
.service__item{border:1px solid var(--line);border-radius:10px;padding:22px;background:#fff}
.service__item h3{font-size:16px;font-weight:600;margin:0 0 8px;color:var(--ink)}
.service__item p{margin:0;font-size:13.5px;line-height:1.65;color:var(--gray)}
@media(max-width:900px){.service__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.service__grid{grid-template-columns:1fr}}
.refs h2{font-size:clamp(20px,2.6vw,28px);margin-bottom:8px}
.refs .sub{color:var(--gray);margin-bottom:34px}
.logos{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.logos div{height:60px;border:1px solid var(--line);border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--gray-2);font-size:12px;font-family:var(--mono)}

/* ============================ CTA / contact ============================ */
.cta{background:var(--navy);color:#fff;text-align:center}
.cta h2{font-size:clamp(22px,3vw,32px);color:#fff;max-width:760px;margin:0 auto 24px}

/* ============================ Footer ============================ */
.site-footer{background:var(--bg-alt);border-top:3px solid var(--red);padding:48px 0 28px;color:var(--gray)}
.site-footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
.site-footer h4{font-size:14px;font-weight:600;color:var(--ink);margin:0 0 14px}
.site-footer a{color:var(--gray);font-size:14px;line-height:2}
.site-footer a:hover{color:var(--navy)}
.site-footer .about{max-width:280px;font-size:14px;line-height:1.7}
.site-footer .legal{margin-top:36px;padding-top:20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:16px;font-size:13px;color:var(--gray-2);flex-wrap:wrap}

/* ============================ Responsive ============================ */
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:32px}
  .hero__media{order:-1}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .tech .wrap{grid-template-columns:1fr}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:32px}
  .team .grid{grid-template-columns:1fr}
  .logos{grid-template-columns:repeat(3,1fr)}
  .site-footer .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .nav{display:none}
  .nav.is-open{display:flex;flex-direction:column;align-items:flex-start;gap:4px;position:absolute;left:0;right:0;top:72px;background:#fff;border-bottom:1px solid var(--line);padding:14px var(--pad)}
  .nav.is-open a{padding:8px 0;width:100%}
  .nav-toggle{display:block}
  .grid-4{grid-template-columns:1fr}
  .member{grid-template-columns:1fr}
  .member__photo{width:120px;height:140px}
  .site-footer .cols{grid-template-columns:1fr}
  .brand__logo{height:30px}
  .header-actions{gap:10px}
}

/* ============================ News + offices ============================ */
.news .news-list{border-top:1px solid var(--line);margin-top:28px}
.news-link{display:grid;grid-template-columns:118px 1fr auto;gap:20px;align-items:baseline;padding:22px 6px;border-bottom:1px solid var(--line);color:var(--ink);transition:background .18s,color .18s}
.news-link:hover{background:#fafbfc}
.news-link .date{font-family:var(--mono);font-size:13px;color:var(--navy)}
.news-link__title{font-size:18px;font-weight:600;line-height:1.45}
.news-link:hover .news-link__title{color:var(--navy)}
.news-link__arrow{color:var(--red);font-size:16px}
.news-link:hover .news-link__arrow{transform:translateX(3px)}
/* Single article page */
.wrap--narrow{max-width:780px}
.article__back{display:inline-block;font-size:13px;font-weight:600;color:var(--navy);letter-spacing:.2px}
.article__back:hover{color:var(--red)}
.article__back--bottom{margin-top:34px;padding-top:22px;border-top:1px solid var(--line);width:100%}
.article__title{font-size:34px;line-height:1.2;font-weight:700;letter-spacing:-.01em;margin:14px 0 10px;color:var(--ink)}
.article__date{font-family:var(--mono);font-size:13px;color:var(--gray);margin:0}
.article__hero{width:100%;aspect-ratio:16/9;background:#0c3b6b center/cover no-repeat;border-radius:12px;margin:24px 0 6px}
.article__rule{width:54px;height:3px;background:var(--red);margin:22px 0 26px}
.article__body{font-size:16.5px;line-height:1.85;color:#2b3138}
.article__body p{margin:0 0 18px}
@media(max-width:700px){
  .article__title{font-size:27px}
}
.offices{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:34px;text-align:left}
.office{border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:24px}
.office h3{color:#fff;font-size:17px;margin:0 0 12px}
.office p{color:var(--on-navy-soft);font-size:14px;line-height:1.7;margin:5px 0}
.office a{color:#fff}
.office a:hover{color:#ffd2cf}
.office .contacts{font-size:13px;margin-top:14px;line-height:1.9}
.office .contacts strong{color:#fff;font-weight:500}
.li-icon{width:24px;height:24px;display:block}
.li-link{display:inline-flex;align-items:center;line-height:0;transition:opacity .15s,transform .15s}
.li-link:hover{opacity:.85;transform:translateY(-1px)}
.office .li-link{color:#fff}
.office .li-link:hover{color:#fff}
.site-footer .li-link{color:var(--navy)}
.foot-c{margin:0 0 14px;line-height:1.7;font-size:14px}
.foot-c strong{color:var(--ink);font-weight:600}
.foot-c .li-link{vertical-align:middle;margin-left:6px}
.foot-c .li-icon{width:18px;height:18px}
.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:560px;margin:0 auto;background:var(--navy);color:#fff;border-radius:12px;padding:16px 18px;display:flex;gap:14px;align-items:center;box-shadow:0 14px 40px rgba(12,39,69,.28)}
.cookie-bar__txt{margin:0;font-size:13px;line-height:1.55;color:var(--on-navy-soft)}
.cookie-bar__ok{flex:0 0 auto;background:#fff;color:var(--navy);border:0;border-radius:8px;padding:9px 16px;font-weight:600;font-size:13px;cursor:pointer;font-family:inherit}
.cookie-bar__ok:hover{background:#eaf1fb}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.to-top{position:fixed;right:20px;bottom:20px;z-index:120;width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s;box-shadow:0 10px 26px rgba(12,39,69,.25)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:#003d80}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--red);z-index:60;transition:width .08s linear;pointer-events:none}
.stat b{transition:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
@media(max-width:560px){.cookie-bar{flex-direction:column;align-items:flex-start;left:10px;right:10px;bottom:10px}}
/* ============================ RTL (Arabic, Persian) ============================ */
[dir="rtl"] .offices,[dir="rtl"] .card__more,[dir="rtl"] .article__body{text-align:right}
[dir="rtl"] .lang__menu{right:auto;left:0}
[dir="rtl"] .entry ul,[dir="rtl"] .entry ol{padding-left:0;padding-right:1.3em}
[dir="rtl"] .article__rule{margin-right:0}
[dir="rtl"] .news-link__arrow,[dir="rtl"] .card__more span,[dir="rtl"] .article__back{display:inline-block;transform:scaleX(-1)}
@media(max-width:700px){
  .news-link{grid-template-columns:1fr auto;gap:4px 12px;padding:18px 4px}
  .news-link .date{grid-column:1 / -1;order:-1}
  .offices{grid-template-columns:1fr}
}

/* Hide the TurnKey appliance credit injected outside WordPress */
#turnkey-credit{display:none !important}
