/* =====================================================================
   ANGATEC — TEC800
   Design system: Tactical Industrial / Fire-Defense
   Author: rebuild 2026
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* ---------------------------------------------------------------------
   Tokens
--------------------------------------------------------------------- */
:root{
  /* surfaces */
  --bg-0:#08090b;
  --bg-1:#0d0f13;
  --bg-2:#13161c;
  --bg-3:#1a1e26;
  --bg-4:#222732;
  --line:#252b35;
  --line-2:#333b48;

  /* ink */
  --ink:#eef1f5;
  --ink-soft:#a9b1bd;
  --ink-faint:#6c7585;
  --ink-dim:#4d5562;

  /* accent — fire / ember */
  --ember:#ff3b1d;
  --ember-2:#ff6a36;
  --ember-deep:#cc2410;
  --amber:#ffb020;
  --amber-2:#ffd166;

  /* effects */
  --thermal:linear-gradient(90deg,#0a0a12 0%,#2a0a55 14%,#9a1a6a 36%,#ff3b1d 58%,#ff9e1b 78%,#ffe14d 92%,#ffffff 100%);
  --glow:0 0 0 1px rgba(255,59,29,.18), 0 18px 50px -20px rgba(255,59,29,.45);
  --shadow-1:0 10px 30px -12px rgba(0,0,0,.7);
  --shadow-2:0 30px 80px -28px rgba(0,0,0,.85);

  /* type */
  --f-display:"Archivo",system-ui,-apple-system,sans-serif;
  --f-cond:"Archivo",system-ui,sans-serif;
  --f-body:"IBM Plex Sans",system-ui,-apple-system,sans-serif;
  --f-mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  /* metrics */
  --maxw:1280px;
  --gutter:clamp(20px,5vw,64px);
  --radius:3px;
  --radius-lg:6px;
  --header-h:74px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------------------------------------------------------------------
   Reset / base
--------------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--f-body);
  background:var(--bg-1);
  color:var(--ink);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* grain + ambient backdrop */
body::before{
  content:"";
  position:fixed;inset:0;
  z-index:0;pointer-events:none;
  background:
    radial-gradient(1100px 720px at 84% -14%,rgba(255,59,29,.055),transparent 62%),
    radial-gradient(900px 650px at -12% 16%,rgba(120,140,170,.035),transparent 58%);
}
body::after{
  content:"";
  position:fixed;inset:0;
  z-index:0;pointer-events:none;opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
:focus-visible{outline:2px solid var(--ember);outline-offset:3px}
::selection{background:var(--ember);color:#fff}

/* ---------------------------------------------------------------------
   Layout helpers
--------------------------------------------------------------------- */
.container{
  width:100%;max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
  position:relative;z-index:1;
}
.section{padding-block:clamp(72px,10vw,140px);position:relative;z-index:1}
.section--tight{padding-block:clamp(48px,6vw,80px)}

.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--ember-2);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{
  content:"";width:28px;height:2px;background:var(--ember);
}
.eyebrow--center{justify-content:center}

h1,h2,h3,h4{font-family:var(--f-display);font-weight:700;line-height:1.04;letter-spacing:-.01em}
.h-xl{font-size:clamp(2.6rem,7vw,5.4rem);font-weight:800;letter-spacing:-.02em;line-height:.98}
.h-lg{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:700}
.h-md{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-soft);max-width:62ch;line-height:1.6}
.muted{color:var(--ink-soft)}
.accent{color:var(--ember-2)}
strong{font-weight:600;color:#fff}

.section-head{max-width:760px;margin-bottom:clamp(40px,5vw,64px)}
.section-head .h-lg{margin-top:18px}
.section-head .lead{margin-top:20px}
.section-head--center{margin-inline:auto;text-align:center}
.section-head--center .lead{margin-inline:auto}

/* HUD corner-bracket frame */
.framed{position:relative}
.framed::before,.framed::after{
  content:"";position:absolute;width:18px;height:18px;
  border:1px solid var(--line-2);pointer-events:none;
}
.framed::before{top:0;left:0;border-right:none;border-bottom:none}
.framed::after{bottom:0;right:0;border-left:none;border-top:none}

/* ---------------------------------------------------------------------
   Buttons
--------------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.65em;
  font-family:var(--f-display);font-weight:600;
  font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;
  padding:14px 26px;border-radius:var(--radius);
  border:1px solid transparent;position:relative;
  transition:transform .25s var(--ease),background .25s,border-color .25s,color .25s,box-shadow .25s;
  will-change:transform;
}
.btn svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.btn--primary{
  background:var(--ember);color:#fff;
  box-shadow:0 6px 20px -14px rgba(255,59,29,.55);
}
.btn--primary:hover{background:var(--ember-2);transform:translateY(-1px);box-shadow:0 10px 26px -14px rgba(255,59,29,.6)}
.btn--primary:hover svg{transform:translateX(4px)}
.btn--ghost{
  border-color:var(--line-2);color:var(--ink);background:rgba(255,255,255,.015);
}
.btn--ghost:hover{border-color:var(--ember);color:#fff;transform:translateY(-2px);background:rgba(255,59,29,.06)}
.btn--lg{padding:17px 32px;font-size:1rem}
.btn--sm{padding:10px 18px;font-size:.84rem}
.nav-config{display:none}

/* ---------------------------------------------------------------------
   Header / nav
--------------------------------------------------------------------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--header-h);
  display:flex;align-items:center;
  border-bottom:1px solid transparent;
  transition:background .3s,border-color .3s,height .3s,backdrop-filter .3s;
}
.site-header.scrolled{
  height:64px;
  background:rgba(10,12,15,.82);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:24px}

.brand{display:inline-flex;align-items:center;gap:12px;flex-shrink:0}
.brand__mark{height:30px;width:auto}
.brand__txt{font-family:var(--f-display);font-weight:800;font-size:1.35rem;letter-spacing:.06em}
.brand__txt b{color:var(--ember)}

.nav{display:flex;align-items:center;gap:6px}
.nav a{
  font-family:var(--f-display);font-weight:500;font-size:.92rem;
  letter-spacing:.03em;color:var(--ink-soft);
  padding:9px 14px;border-radius:var(--radius);position:relative;
  transition:color .2s;
}
.nav a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1px;
  background:var(--ember);transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease);
}
.nav a:hover,.nav a.active{color:#fff}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}

.header-actions{display:flex;align-items:center;gap:14px}

.lang{display:inline-flex;align-items:center;font-family:var(--f-mono);font-size:.8rem;border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden}
.nav>.lang{display:none}
.lang a{padding:7px 11px;color:var(--ink-faint);letter-spacing:.05em;transition:background .2s,color .2s}
.lang a.is-active{background:var(--ember);color:#fff}
.lang a:not(.is-active):hover{color:var(--ink);background:rgba(255,255,255,.04)}

.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line-2);border-radius:var(--radius);align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";display:block;width:20px;height:2px;background:var(--ink);transition:transform .3s,opacity .3s;position:relative;
}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}
.nav-toggle[aria-expanded="true"] span{background:transparent}
.nav-toggle[aria-expanded="true"] span::before{transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span::after{transform:translateY(-6px) rotate(-45deg)}

/* ---------------------------------------------------------------------
   Hero
--------------------------------------------------------------------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding-top:var(--header-h);padding-bottom:clamp(40px,7vw,90px);
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(8,9,11,.55) 0%,rgba(8,9,11,.2) 30%,rgba(8,9,11,.78) 72%,var(--bg-1) 100%),
    linear-gradient(95deg,rgba(8,9,11,.85) 0%,rgba(8,9,11,.35) 45%,transparent 75%);
}
/* fallback look before image exists */
.hero__bg{background:radial-gradient(120% 90% at 75% 0%,#241109 0%,#0c0e12 55%,#08090b 100%)}

.hero__scan{display:none}
.hero__grid{
  position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.12;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 100% at 80% 0%,#000,transparent 70%);
}
.hero__inner{position:relative;z-index:2;width:100%}

.hero__tag{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.tag-chip{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);border:1px solid var(--line-2);background:rgba(13,15,19,.5);
  padding:6px 11px;border-radius:var(--radius);backdrop-filter:blur(4px);
  display:inline-flex;align-items:center;gap:.6em;
}
.tag-chip b{color:var(--ember-2);font-weight:600}
.tag-chip::before{content:"";width:5px;height:5px;background:var(--ember);border-radius:50%}

.hero h1{margin-bottom:22px}
.hero h1 .sup{
  display:block;font-family:var(--f-mono);font-weight:500;
  font-size:clamp(.8rem,1.4vw,.95rem);letter-spacing:.34em;text-transform:uppercase;
  color:var(--ember-2);margin-bottom:18px;
}
.hero h1 .main{display:block;font-family:var(--f-display);font-weight:800;font-size:clamp(3rem,8.4vw,6.6rem);line-height:.94;letter-spacing:-.025em}
.hero h1 .sub2{display:block;font-family:var(--f-display);font-weight:600;font-size:clamp(1.2rem,2.6vw,2rem);color:var(--ink);margin-top:10px;letter-spacing:0}
.hero__lead{max-width:54ch;margin-bottom:34px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}

.hero__meter{
  position:absolute;right:var(--gutter);bottom:clamp(40px,7vw,90px);z-index:2;
  display:flex;flex-direction:column;gap:14px;align-items:flex-end;
}
.meter-row{display:flex;align-items:baseline;gap:12px;font-family:var(--f-mono);text-align:right}
.meter-row b{font-family:var(--f-cond);font-weight:800;font-size:2rem;color:#fff;line-height:1}
.meter-row span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}

.scroll-cue{
  position:absolute;left:var(--gutter);bottom:24px;z-index:2;
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);
  display:flex;align-items:center;gap:10px;
}
.scroll-cue i{display:block;width:1px;height:34px;background:linear-gradient(var(--ember),transparent);position:relative;overflow:hidden}
.scroll-cue i::after{content:"";position:absolute;top:0;left:0;width:100%;height:10px;background:var(--ember);animation:scrolldot 2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-12px)}100%{transform:translateY(40px)}}

/* ---------------------------------------------------------------------
   Marquee / trust ticker
--------------------------------------------------------------------- */
.ticker{border-block:1px solid var(--line);background:var(--bg-0);overflow:hidden;position:relative;z-index:1}
.ticker__track{display:flex;width:max-content;animation:marquee 60s linear infinite}
.ticker:hover .ticker__track{animation-play-state:paused}
.ticker__item{
  display:inline-flex;align-items:center;gap:16px;
  padding:16px 30px;font-family:var(--f-mono);font-weight:500;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;
}
.ticker__item::after{content:"";width:4px;height:4px;background:var(--ink-dim);transform:rotate(45deg)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------------------------------------------------------------------
   About / domains
--------------------------------------------------------------------- */
.about{position:relative}
.about__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center}
.about__stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;margin-top:34px}
.stat{background:var(--bg-2);padding:26px 24px}
.stat b{display:block;font-family:var(--f-cond);font-weight:800;font-size:clamp(2rem,4vw,2.8rem);color:#fff;line-height:1}
.stat>span{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px;display:block}

.domains{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.domain{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:24px 22px;position:relative;overflow:hidden;
  transition:border-color .3s,transform .3s,background .3s;
}
.domain::before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:var(--ember);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.domain:hover{border-color:var(--line-2);transform:translateY(-3px);background:var(--bg-3)}
.domain:hover::before{transform:scaleX(1)}
.domain__ico{width:40px;height:40px;color:var(--ember-2);margin-bottom:16px}
.domain h3{font-size:1.15rem;font-weight:700;margin-bottom:8px;letter-spacing:0}
.domain p{font-size:.92rem;color:var(--ink-soft);line-height:1.55}
.domain__num{position:absolute;top:18px;right:20px;font-family:var(--f-mono);font-size:.72rem;color:var(--ink-dim)}

/* ---------------------------------------------------------------------
   TEC800 showcase
--------------------------------------------------------------------- */
.showcase{background:var(--bg-0);border-block:1px solid var(--line);position:relative}
.showcase__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,70px);align-items:center}
.showcase__media{position:relative}
.showcase__media .media-frame{aspect-ratio:4/3}
.showcase__media .spec-pin{
  position:absolute;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  background:rgba(8,9,11,.85);border:1px solid var(--line-2);padding:7px 11px;border-radius:var(--radius);
  color:var(--ink);backdrop-filter:blur(6px);display:flex;align-items:center;gap:8px;
}
.spec-pin b{color:var(--ember-2);font-family:var(--f-cond);font-weight:700;font-size:1rem}
.spec-pin--1{top:14%;left:-14px}
.spec-pin--2{bottom:16%;right:-14px}
.showcase ul.ticks{margin-top:26px;display:grid;gap:13px}
.showcase ul.ticks li{position:relative;padding-left:30px;color:var(--ink-soft);font-size:1rem}
.showcase ul.ticks li::before{
  content:"";position:absolute;left:0;top:.5em;width:13px;height:13px;
  border:1px solid var(--ember);border-radius:50%;
}
.showcase ul.ticks li::after{content:"";position:absolute;left:4px;top:calc(.5em + 4px);width:5px;height:5px;background:var(--ember);border-radius:50%;box-shadow:0 0 8px var(--ember)}
.showcase ul.ticks li b{color:#fff}

/* generic media frame w/ placeholder */
.media-frame{
  position:relative;border:1px solid var(--line-2);border-radius:var(--radius-lg);overflow:hidden;
  background:
    linear-gradient(135deg,#15191f,#0b0d10),
    repeating-linear-gradient(45deg,transparent 0 12px,rgba(255,255,255,.012) 12px 13px);
  box-shadow:var(--shadow-2);
}
.media-frame img{width:100%;height:100%;object-fit:cover;display:block}
.js-fade{opacity:0;transition:opacity .8s var(--ease)}
.js-fade.loaded{opacity:1}
.media-frame__ph{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:var(--ink-dim);text-align:center;padding:24px;
}
.media-frame__ph svg{width:40px;height:40px;opacity:.5}
.media-frame__ph .lbl{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase}
.media-frame__ph .dim{font-family:var(--f-mono);font-size:.7rem;color:var(--ink-faint)}
.media-frame.has-img .media-frame__ph{display:none}
.media-frame::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.03);pointer-events:none;border-radius:inherit}
/* corner ticks on frames */
.media-frame .corner{position:absolute;width:16px;height:16px;border:1.5px solid var(--ember);z-index:2;pointer-events:none}
.media-frame .corner.tl{top:10px;left:10px;border-right:none;border-bottom:none}
.media-frame .corner.tr{top:10px;right:10px;border-left:none;border-bottom:none}
.media-frame .corner.bl{bottom:10px;left:10px;border-right:none;border-top:none}
.media-frame .corner.br{bottom:10px;right:10px;border-left:none;border-top:none}

/* ---------------------------------------------------------------------
   Modularity
--------------------------------------------------------------------- */
.modular{background:var(--bg-0);border-block:1px solid var(--line)}
.modular__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,84px);align-items:center}
.modules-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--bg-2),var(--bg-1));padding:24px;box-shadow:var(--shadow-1)}
.modules-panel__core{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border:1px solid var(--line-2);border-left:3px solid var(--ember);border-radius:var(--radius);background:var(--bg-3);margin-bottom:20px}
.modules-panel__core b{display:block;font-family:var(--f-display);font-weight:800;font-size:1.3rem;letter-spacing:-.01em}
.modules-panel__core small{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.modules-panel__hint{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ember-2);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.modules-panel__hint::before,.modules-panel__hint::after{content:"";height:1px;flex:1;background:var(--line)}
.modules-list{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mod-chip{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-1);transition:border-color .25s var(--ease),transform .25s var(--ease),background .25s}
.mod-chip:hover{border-color:var(--ember);transform:translateY(-2px);background:var(--bg-2)}
.mod-chip svg{width:21px;height:21px;color:var(--ember-2);flex-shrink:0}
.mod-chip span{font-size:.88rem;color:var(--ink);line-height:1.25}

/* ---------------------------------------------------------------------
   Applications
--------------------------------------------------------------------- */
.apps__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.app-card{
  position:relative;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  background:var(--bg-2);min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .4s var(--ease),border-color .4s;
}
.app-card:hover{transform:translateY(-4px);border-color:var(--line-2)}
.app-card__media{position:absolute;inset:0;z-index:0}
.app-card__media .media-frame{height:100%;border:none;border-radius:0;box-shadow:none}
.app-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,11,.1) 0%,rgba(8,9,11,.55) 55%,rgba(8,9,11,.96) 100%)}
.app-card__body{position:relative;z-index:1;padding:28px 26px}
.app-card__no{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.16em;color:var(--ember-2);margin-bottom:12px;display:block}
.app-card h3{font-size:1.5rem;font-weight:700;margin-bottom:10px;letter-spacing:0}
.app-card p{font-size:.95rem;color:var(--ink-soft);max-width:42ch;line-height:1.55}
.app-card__ico{position:absolute;top:24px;right:24px;width:34px;height:34px;color:var(--ink);opacity:.6;z-index:1}

/* ---------------------------------------------------------------------
   Specs — data panel
--------------------------------------------------------------------- */
.specs{background:var(--bg-0);border-block:1px solid var(--line)}
.specs__top{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:50px}
.spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.spec{background:var(--bg-1);padding:30px 26px;position:relative;transition:background .3s}
.spec:hover{background:var(--bg-2)}
.spec__k{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);display:flex;align-items:center;gap:8px;margin-bottom:14px}
.spec__k::before{content:"";width:6px;height:6px;background:var(--ember);transform:rotate(45deg)}
.spec__v{font-family:var(--f-cond);font-weight:800;font-size:clamp(2.4rem,4.4vw,3.4rem);color:#fff;line-height:.95;letter-spacing:.01em}
.spec__v u{text-decoration:none;font-family:var(--f-display);font-weight:600;font-size:1.1rem;color:var(--ink-soft);margin-left:6px}

.equip{margin-top:50px;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(36px,5vw,70px);align-items:start}
.equip__list{display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.equip__list li{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--ink-soft)}
.equip__list li svg{width:18px;height:18px;color:var(--ember-2);flex-shrink:0;margin-top:3px}
.equip__note{background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--ember);border-radius:var(--radius);padding:24px;font-size:.95rem;color:var(--ink-soft)}
.equip__note h4{font-family:var(--f-display);font-size:1.1rem;color:#fff;margin-bottom:12px}

/* ---------------------------------------------------------------------
   Technology
--------------------------------------------------------------------- */
.tech__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.tech-card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 24px;transition:transform .3s,border-color .3s}
.tech-card:hover{transform:translateY(-3px);border-color:var(--line-2)}
.tech-card__ico{width:38px;height:38px;color:var(--ember-2);margin-bottom:18px}
.tech-card h3{font-size:1.2rem;font-weight:700;margin-bottom:10px;letter-spacing:0}
.tech-card p{font-size:.93rem;color:var(--ink-soft);line-height:1.55}

/* ---------------------------------------------------------------------
   References / distinctions
--------------------------------------------------------------------- */
.refs{background:var(--bg-0);border-block:1px solid var(--line)}
.timeline{display:grid;gap:0;margin-top:10px}
.tl-item{
  display:grid;grid-template-columns:130px 1fr;gap:28px;
  padding:26px 0;border-top:1px solid var(--line);position:relative;
  transition:background .3s;
}
.tl-item:hover{background:linear-gradient(90deg,rgba(255,59,29,.04),transparent 40%)}
.tl-item:last-child{border-bottom:1px solid var(--line)}
.tl-date{font-family:var(--f-mono);font-size:.82rem;letter-spacing:.06em;color:var(--ember-2);padding-top:3px}
.tl-body h3{font-size:1.25rem;font-weight:700;margin-bottom:7px;letter-spacing:0}
.tl-body p{color:var(--ink-soft);font-size:.96rem;max-width:62ch}
.tl-tag{display:inline-block;margin-top:12px;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--amber-2);border:1px solid rgba(255,209,102,.25);padding:4px 10px;border-radius:var(--radius)}

.award{
  display:flex;gap:22px;align-items:center;background:linear-gradient(120deg,rgba(255,59,29,.08),transparent 60%);
  border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:28px 30px;margin-bottom:40px;
}
.award__medal{flex-shrink:0;width:60px;height:60px;color:var(--amber)}
.award h3{font-family:var(--f-cond);font-weight:800;font-size:clamp(1.5rem,3vw,2.1rem);color:#fff;letter-spacing:.01em}
.award p{color:var(--ink-soft);font-size:.96rem;margin-top:4px}

/* ---------------------------------------------------------------------
   Subpage (mentions légales / legal)
--------------------------------------------------------------------- */
.site-header--solid{position:fixed;background:rgba(10,12,15,.92);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}
.subpage{padding-top:var(--header-h)}
.page-hero{padding:clamp(48px,8vw,96px) 0 clamp(26px,4vw,44px);border-bottom:1px solid var(--line);background:var(--bg-0);position:relative;z-index:1}
.page-hero .eyebrow{margin-bottom:16px}
.legal{padding-block:clamp(40px,6vw,72px);max-width:860px;position:relative;z-index:1}
.legal h2{font-family:var(--f-display);font-weight:700;font-size:clamp(1.25rem,2.4vw,1.65rem);margin:40px 0 14px;color:#fff;display:flex;align-items:baseline;gap:12px;letter-spacing:0}
.legal h2 .n{font-family:var(--f-mono);font-size:.85rem;color:var(--ember-2);flex:0 0 auto}
.legal h2:first-of-type{margin-top:0}
.legal p{color:var(--ink-soft);margin-bottom:14px;line-height:1.75}
.legal a{color:var(--ember-2)}
.legal a:hover{text-decoration:underline}
.legal strong{color:#fff;font-weight:600}
.legal .dl{display:grid;grid-template-columns:max-content 1fr;gap:8px 26px;margin:16px 0 20px;padding:22px 24px;background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--ember);border-radius:var(--radius)}
.legal .dl dt{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);padding-top:3px}
.legal .dl dd{color:var(--ink)}
.legal .todo{color:var(--amber-2);border-bottom:1px dotted var(--amber);font-style:italic}
.legal__back{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-display);font-weight:600;font-size:.95rem;color:var(--ink-soft);margin-top:36px;border:1px solid var(--line-2);padding:12px 22px;border-radius:var(--radius);transition:all .25s}
.legal__back:hover{color:#fff;border-color:var(--ember);background:rgba(255,59,29,.06)}
@media (max-width:560px){.legal .dl{grid-template-columns:1fr;gap:2px 0}.legal .dl dd{margin-bottom:10px}}

/* clients / trust logos */
.clients{margin-top:clamp(40px,5vw,60px)}
.clients__title{
  display:flex;align-items:center;justify-content:center;gap:16px;
  font-family:var(--f-mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:30px;
}
.clients__title::before,.clients__title::after{content:"";height:1px;width:min(80px,11vw);background:var(--line-2)}
.clients__grid{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.client{
  flex:0 0 auto;width:clamp(128px,15vw,172px);height:86px;
  background:#f3f4f6;border:1px solid #e4e7eb;border-radius:8px;
  display:flex;align-items:center;justify-content:center;padding:15px 22px;
  transition:transform .3s var(--ease),box-shadow .3s;
  box-shadow:0 6px 18px -10px rgba(0,0,0,.7);
}
.client:hover{transform:translateY(-4px);box-shadow:0 16px 34px -14px rgba(0,0,0,.85)}
.client img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}
.client--text{font-family:var(--f-display);font-weight:700;font-size:1.04rem;line-height:1.06;color:#1b2029;text-align:center;letter-spacing:.01em}
@media (max-width:520px){.client{width:calc(50% - 7px);height:78px}}

/* ---------------------------------------------------------------------
   Values
--------------------------------------------------------------------- */
.values__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.value{background:var(--bg-2);padding:30px 26px;transition:background .3s}
.value:hover{background:var(--bg-3)}
.value__no{font-family:var(--f-mono);font-size:.74rem;color:var(--ember-2);letter-spacing:.14em}
.value h3{font-family:var(--f-cond);font-weight:700;font-size:1.6rem;margin:14px 0 8px;letter-spacing:.01em}
.value p{font-size:.9rem;color:var(--ink-soft);line-height:1.5}

/* ---------------------------------------------------------------------
   Configurator
--------------------------------------------------------------------- */
.config-band{
  position:relative;overflow:hidden;border:1px solid var(--line-2);border-radius:var(--radius-lg);
  background:linear-gradient(120deg,#16110d,#0c0e12 64%);padding:clamp(34px,5vw,60px);
}
.config-band::before{content:"";position:absolute;inset:0;background:radial-gradient(72% 120% at 93% 6%,rgba(255,59,29,.15),transparent 60%);pointer-events:none}
.config-band__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,5vw,64px);align-items:center}
.config-feats{display:flex;flex-wrap:wrap;gap:11px 24px;margin:22px 0 30px}
.config-feats li{position:relative;padding-left:27px;color:var(--ink-soft);font-size:.95rem}
.config-feats li::before{content:"";position:absolute;left:0;top:.42em;width:14px;height:14px;border:1px solid var(--ember);border-radius:50%}
.config-feats li::after{content:"";position:absolute;left:4px;top:calc(.42em + 4px);width:6px;height:6px;background:var(--ember);border-radius:50%}
.config-preview{border:1px solid var(--line-2);border-radius:var(--radius);background:rgba(8,9,11,.62);backdrop-filter:blur(4px);padding:20px 22px;box-shadow:var(--shadow-2)}
.config-preview__head{display:flex;align-items:center;justify-content:space-between;font-family:var(--f-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);padding-bottom:14px;margin-bottom:6px;border-bottom:1px solid var(--line)}
.config-preview__head b{color:var(--ember-2);font-weight:500}
.config-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);font-size:.9rem;color:var(--ink)}
.config-row:last-child{border-bottom:none}
.config-row .opt{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.08em;color:var(--ember-2);white-space:nowrap}
.config-row .opt.off{color:var(--ink-dim)}

/* ---------------------------------------------------------------------
   Contact / CTA
--------------------------------------------------------------------- */
.cta-band{
  position:relative;overflow:hidden;border:1px solid var(--line-2);border-radius:var(--radius-lg);
  background:linear-gradient(120deg,#1a0d09,#0c0e12 60%);padding:clamp(40px,6vw,72px);
}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 90% 10%,rgba(255,59,29,.22),transparent 60%);pointer-events:none}
.cta-band__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center}
.cta-band h2{margin-bottom:16px}

.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,64px);margin-top:60px}
.contact-info{display:grid;gap:2px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;height:max-content}
.ci-row{background:var(--bg-2);padding:22px 24px;display:flex;gap:16px;align-items:flex-start;transition:background .3s}
.ci-row:hover{background:var(--bg-3)}
.ci-row svg{width:22px;height:22px;color:var(--ember-2);flex-shrink:0;margin-top:2px}
.ci-row .k{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:5px}
.ci-row .v{font-size:1.02rem;color:var(--ink)}
.ci-row a.v:hover{color:var(--ember-2)}

.form{display:grid;gap:16px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.field input,.field textarea{
  font-family:var(--f-body);font-size:.96rem;color:var(--ink);
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:13px 15px;transition:border-color .25s,background .25s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ember);background:var(--bg-3)}
.field textarea{resize:vertical;min-height:120px}
.form__note{font-size:.8rem;color:var(--ink-faint)}

/* ---------------------------------------------------------------------
   Footer
--------------------------------------------------------------------- */
.site-footer{background:var(--bg-0);border-top:1px solid var(--line);padding-block:60px 30px;position:relative;z-index:1}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--line)}
.footer__brand .brand{margin-bottom:18px}
.footer__brand p{color:var(--ink-faint);font-size:.92rem;max-width:34ch}
.footer-col h4{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:18px}
.footer-col a{display:block;color:var(--ink-soft);font-size:.94rem;padding:6px 0;transition:color .2s,transform .2s}
.footer-col a:hover{color:var(--ember-2);transform:translateX(3px)}
.socials{display:flex;gap:10px;margin-top:6px}
.socials a{width:40px;height:40px;border:1px solid var(--line-2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:all .25s}
.socials a:hover{border-color:var(--ember);color:#fff;background:rgba(255,59,29,.08);transform:translateY(-2px)}
.socials svg{width:18px;height:18px}
.footer__bottom{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding-top:26px;color:var(--ink-dim);font-size:.84rem;font-family:var(--f-mono)}
.footer__bottom a{color:var(--ink-faint)}
.footer__bottom a:hover{color:var(--ember-2)}
.made-fr{display:inline-flex;align-items:center;gap:8px}
.made-fr i{width:22px;height:14px;border-radius:2px;background:linear-gradient(90deg,#0055A4 33.33%,#fff 33.33% 66.66%,#EF4135 66.66%);display:inline-block}

/* ---------------------------------------------------------------------
   Reveal animations
--------------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .scroll-cue i::after,.ticker__track{animation:none}
}

/* hero entrance */
.hero .anim{opacity:0;transform:translateY(30px);animation:heroIn .9s var(--ease) forwards}
.hero .anim.d1{animation-delay:.1s}
.hero .anim.d2{animation-delay:.24s}
.hero .anim.d3{animation-delay:.38s}
.hero .anim.d4{animation-delay:.52s}
.hero .anim.d5{animation-delay:.66s}
@keyframes heroIn{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.hero .anim{opacity:1;transform:none;animation:none}}

/* ---------------------------------------------------------------------
   Responsive
--------------------------------------------------------------------- */
@media (max-width:1080px){
  .footer__top{grid-template-columns:1fr 1fr 1fr;gap:32px}
  .footer__brand{grid-column:1/-1}
  .spec-grid{grid-template-columns:repeat(2,1fr)}
  .tech__grid{grid-template-columns:1fr 1fr}
  .hero__meter{display:none}
}
@media (max-width:900px){
  :root{--header-h:64px}
  .nav,.lang-desktop,.cta-config{display:none}
  .nav-toggle{display:flex}
  .about__grid,.showcase__grid,.modular__grid,.equip,.cta-band__inner,.config-band__inner,.contact__grid{grid-template-columns:1fr;gap:40px}
  .showcase__media{order:-1}

  /* mobile drawer */
  .nav{
    position:fixed;inset:var(--header-h) 0 auto 0;display:flex;flex-direction:column;gap:0;
    background:rgba(10,12,15,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);
    padding:14px var(--gutter) 26px;transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity .3s,transform .3s;
  }
  .nav.open{opacity:1;transform:none;pointer-events:auto}
  .nav a{padding:15px 4px;font-size:1.15rem;border-bottom:1px solid var(--line);width:100%}
  .nav a::after{display:none}
  .nav>.lang{display:inline-flex;margin-top:18px;align-self:flex-start}
  .nav .nav-config{display:block;color:var(--ember-2)}
}
@media (max-width:640px){
  .apps__grid,.values__grid,.domains,.about__stats,.equip__list{grid-template-columns:1fr}
  .spec-grid{grid-template-columns:1fr 1fr}
  .tech__grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr}
  .form .row{grid-template-columns:1fr}
  .tl-item{grid-template-columns:1fr;gap:8px}
  .award{flex-direction:column;text-align:center}
  .spec-pin{display:none}
  .hero h1 .main{font-size:clamp(3rem,16vw,5rem)}
}
@media (max-width:420px){
  .spec-grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
}
