/* =========================================================
   MPIS Reloaded OÜ — Technology & Business consulting
   EU-First. Design system: Sovereign blue + EU star gold.
   ========================================================= */

:root{
  /* Palette */
  --ink:        #0A1428;   /* darkest navy — header / hero / footer */
  --navy:       #0E2148;   /* deep sovereign blue */
  --navy-2:     #13315C;   /* lifted navy */
  --gold:       #C9A24B;   /* EU star gold — the single accent */
  --gold-bright:#E0BE6A;
  --mist:       #F3F6FB;   /* cool light section */
  --paper:      #FFFFFF;
  --text:       #182338;   /* body text on light */
  --slate:      #586588;   /* muted text */
  --line:       #E3E8F1;   /* hairline on light */
  --line-dark:  rgba(255,255,255,.12);
  --gold-soft:  rgba(201,162,75,.16);

  --maxw: 1160px;
  --gutter: clamp(20px, 5vw, 56px);

  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  --radius: 14px;
  --shadow: 0 1px 2px rgba(13,28,58,.05), 0 12px 34px -20px rgba(13,28,58,.28);
  --shadow-lg: 0 30px 60px -30px rgba(10,20,40,.45);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--paper);
  line-height:1.65;
  font-size:clamp(15.5px, 1.1vw, 17px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--gold); color:var(--ink); padding:.7rem 1.1rem; font-weight:600;
  border-radius:0 0 8px 0;
}
.skip-link:focus{ left:0; }

/* ---------- Eyebrow / labels (mono signature) ---------- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.6em;
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:22px; height:1px; background:var(--gold); display:inline-block;
}
.on-dark .eyebrow{ color:var(--gold-bright); }

/* ---------- Headings ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.08; color:var(--ink); letter-spacing:-.01em; }
h2{ font-size:clamp(1.55rem, 3.2vw, 2.3rem); margin:0 0 .5em; }
h3{ font-size:1.18rem; margin:0 0 .4em; letter-spacing:-.005em; }
.on-dark h1,.on-dark h2,.on-dark h3{ color:#fff; }
p{ margin:0 0 1.1rem; }
strong{ font-weight:600; color:var(--ink); }
.on-dark strong{ color:#fff; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.header-inner{ display:flex; align-items:center; gap:1.2rem; height:72px; }

/* Logo (reconstructed wordmark) */
.logo{ display:inline-flex; align-items:center; gap:.62rem; color:var(--ink); white-space:nowrap; }
.logo-mark{ width:230px; height:auto; flex:none; display:block; object-fit:contain; }
.logo-mark path{ transition:fill .3s; }
.logo-text{ font-family:var(--font-display); font-size:1.12rem; letter-spacing:-.01em; line-height:1; }
.logo-text b{ font-weight:700; }
.logo-text .reload{ font-weight:400; color:var(--slate); }
.logo-text .ou{ color:var(--gold); font-weight:600; }

/* Primary nav */
.nav{ margin-left:auto; }
.nav-list{ display:flex; align-items:center; gap:.2rem; list-style:none; margin:0; padding:0; }
.nav-list a{
  display:block; padding:.55rem .72rem; border-radius:8px;
  font-size:.9rem; font-weight:500; color:var(--ink);
  transition:color .2s, background .2s;
}
.nav-list a:hover{ color:var(--navy); background:var(--line); }
.nav-list a[aria-current="page"]{ color:var(--navy); }
.nav-list a[aria-current="page"]::after{
  content:""; display:block; height:2px; margin-top:5px;
  background:var(--gold); border-radius:2px;
}

/* Language switcher */
.lang{ position:relative; flex:none; }
.lang-toggle{
  display:inline-flex; align-items:center; gap:.5rem;
  background:transparent; border:1px solid var(--line);
  color:var(--ink); padding:.42rem .6rem; border-radius:9px; cursor:pointer;
  font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em;
  transition:border-color .2s, background .2s;
}
.lang-toggle:hover{ border-color:var(--gold); }
.lang-toggle .chev{ width:11px; height:11px; transition:transform .25s; opacity:.7; }
.lang[data-open="true"] .chev{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; right:0; top:calc(100% + 10px); min-width:182px;
  background:#0d1b36; border:1px solid var(--line-dark); border-radius:12px;
  padding:.4rem; box-shadow:var(--shadow-lg);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .2s, transform .2s, visibility .2s; list-style:none; margin:0;
}
.lang[data-open="true"] .lang-menu{ opacity:1; visibility:visible; transform:translateY(0); }
.lang-menu a{
  display:flex; align-items:center; gap:.65rem;
  padding:.55rem .6rem; border-radius:8px; color:#d8e0f0; font-size:.88rem;
}
.lang-menu a:hover{ background:rgba(255,255,255,.06); color:#fff; }
.lang-menu a[aria-current="true"]{ color:#fff; }
.lang-menu a[aria-current="true"] .tick{ margin-left:auto; color:var(--gold); }
.tick{ width:14px; height:14px; opacity:0; }
.lang-menu a[aria-current="true"] .tick{ opacity:1; }

.flag{ display:inline-block; width:22px; height:14px; flex:none; border-radius:2px; overflow:hidden; box-shadow:0 0 0 1px rgba(255,255,255,.14) inset; }
.flag svg{ display:block; width:100%; height:100%; }

/* Hamburger */
.burger{
  display:none; flex:none; width:42px; height:42px; border-radius:9px;
  background:transparent; border:1px solid var(--line);
  cursor:pointer; padding:0; position:relative;
}
.burger span, .burger::before, .burger::after{
  content:""; position:absolute; left:11px; right:11px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .28s, opacity .2s, top .28s;
}
.burger span{ top:20px; }
.burger::before{ top:14px; }
.burger::after{ top:26px; }
.burger[aria-expanded="true"]::before{ top:20px; transform:rotate(45deg); }
.burger[aria-expanded="true"]::after{ top:20px; transform:rotate(-45deg); }
.burger[aria-expanded="true"] span{ opacity:0; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(201,162,75,.20), transparent 55%),
    radial-gradient(100% 100% at 8% 0%, #16305f 0%, transparent 60%),
    linear-gradient(180deg, var(--ink), #0b1830);
  color:#fff;
}
.hero::before{ /* fine grid watermark */
  content:""; position:absolute; inset:0; opacity:.5;
  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:46px 46px; mask-image:radial-gradient(120% 90% at 70% 0%, #000 30%, transparent 78%);
  -webkit-mask-image:radial-gradient(120% 90% at 70% 0%, #000 30%, transparent 78%);
  pointer-events:none;
}
.hero-inner{ position:relative; padding:clamp(3.4rem, 9vw, 6.6rem) 0 clamp(3rem, 7vw, 5rem); max-width:52rem; }
.hero h1{ font-size:clamp(2.1rem, 5.6vw, 3.7rem); color:#fff; margin:0 0 1rem; }
.hero .lead{ font-size:clamp(1.05rem, 1.7vw, 1.25rem); color:#c8d2e6; max-width:42ch; margin-bottom:1.8rem; }
.hero .lead strong{ color:#fff; }

/* a thin gold scan rule under hero content */
.scanline{ height:2px; width:min(220px, 50%); background:linear-gradient(90deg, var(--gold), transparent); border-radius:2px; }

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-body); font-weight:600; font-size:.95rem;
  padding:.82rem 1.4rem; border-radius:10px; cursor:pointer; border:1px solid transparent;
  transition:transform .15s, box-shadow .2s, background .2s, border-color .2s, color .2s;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--gold); color:var(--ink); box-shadow:0 10px 24px -12px rgba(201,162,75,.7); }
.btn-primary:hover{ background:var(--gold-bright); }
.btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.28); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-bright); }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-outline:hover{ border-color:var(--gold); color:#8a6d20; }
.btn .arr{ transition:transform .2s; }
.btn:hover .arr{ transform:translateX(3px); }

/* =========================================================
   SECTIONS
   ========================================================= */
.section{ padding:clamp(3rem, 7vw, 5.2rem) 0; }
.section.mist{ background:var(--mist); }
.section.dark{ background:var(--ink); color:#e7ecf6; }
.section.dark p{ color:#bcc7dd; }
.section-head{ max-width:46rem; margin-bottom:2.4rem; }
.section-head p{ color:var(--slate); font-size:1.06rem; }
.prose{ max-width:46rem; }
.prose p{ color:#3a455f; }
.lede{ font-size:1.18rem; color:var(--text); }

/* Two-column intro / generic split */
.split{ display:grid; grid-template-columns:1fr; gap:clamp(1.4rem,3vw,2.4rem); align-items:start; }
@media(min-width:860px){ .split{ grid-template-columns:1.1fr .9fr; } }

/* =========================================================
   TILES / CARDS
   ========================================================= */
.tiles{ display:grid; grid-template-columns:repeat(auto-fit, minmax(min(100%, 300px), 1fr)); gap:1.1rem; }
.tile{
  position:relative; background:var(--paper); border:1px solid var(--line);
  border-radius:var(--radius); padding:1.6rem 1.5rem; box-shadow:var(--shadow);
  transition:transform .22s, box-shadow .22s, border-color .22s;
  overflow:hidden;
}
.tile::before{
  content:""; position:absolute; left:0; top:0; height:3px; width:100%;
  background:linear-gradient(90deg, var(--gold), transparent);
  transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.tile:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:#d7deec; }
.tile:hover::before{ transform:scaleX(1); }
.tile .tile-kicker{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; color:var(--gold); text-transform:uppercase; display:block; margin-bottom:.7rem; }
.tile h3{ color:var(--ink); }
.tile p{ color:var(--slate); font-size:.96rem; margin-bottom:0; }
.tile p + p{ margin-top:.7rem; }
.mist .tile{ background:#fff; }

/* Feature list (icon + text rows) */
.feature-list{ list-style:none; margin:0; padding:0; display:grid; gap:1rem; grid-template-columns:repeat(auto-fit, minmax(min(100%,320px),1fr)); }
.feature-list li{
  position:relative; padding:1.15rem 1.25rem 1.15rem 3rem;
  background:#fff; border:1px solid var(--line); border-radius:12px;
}
.feature-list li::before{
  content:""; position:absolute; left:1.1rem; top:1.45rem; width:10px; height:10px;
  border-radius:3px; background:var(--gold-soft); box-shadow:inset 0 0 0 2px var(--gold);
}
.feature-list strong{ display:block; margin-bottom:.25rem; font-family:var(--font-display); font-weight:600; font-size:1.02rem; }
.feature-list span{ color:var(--slate); font-size:.95rem; }

/* simple bullet list */
.check-list{ list-style:none; margin:1.2rem 0; padding:0; display:grid; gap:.65rem; }
.check-list li{ position:relative; padding-left:1.9rem; color:#3a455f; }
.check-list li::before{
  content:""; position:absolute; left:0; top:.55em; width:9px; height:9px;
  background:var(--gold); border-radius:2px; transform:rotate(45deg);
}

/* callout / quote band */
.band{
  background:linear-gradient(120deg, var(--navy), var(--ink));
  color:#fff; border-radius:18px; padding:clamp(1.8rem,4vw,2.8rem);
  position:relative; overflow:hidden;
}
.band::after{
  content:""; position:absolute; right:-40px; top:-40px; width:200px; height:200px;
  background:radial-gradient(circle, rgba(201,162,75,.3), transparent 70%);
}
.band .eyebrow{ color:var(--gold-bright); }
.band h2,.band h3{ color:#fff; }
.band p{ color:#c7d1e6; }

/* partner badge (Stormwall reconstruction) */
.partner{
  display:inline-flex; align-items:center; margin:.4rem 0 1.6rem;
  background:transparent; border:none; border-radius:0; padding:0;
}
.partner .partner-logo{ width:280px; height:auto; flex:none; }
.partner .pname{ display:none; }
.partner .ptag{ display:none; }

/* CTA strip */
.cta-strip{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1.4rem;
  background:linear-gradient(120deg,var(--navy),var(--ink)); color:#fff;
  border-radius:18px; padding:clamp(1.8rem,4vw,2.6rem); margin-top:1rem; position:relative; overflow:hidden;
}
.cta-strip::before{
  content:""; position:absolute; inset:0; opacity:.5;
  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:38px 38px; mask-image:linear-gradient(90deg,transparent,#000);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000);
}
.cta-strip > *{ position:relative; }
.cta-strip h2{ color:#fff; margin:0; font-size:clamp(1.4rem,3vw,2rem); }
.cta-strip p{ color:#c0cbe2; margin:.4rem 0 0; max-width:46ch; }

/* =========================================================
   CONTACT FORM
   ========================================================= */
.form-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:clamp(1.6rem,4vw,2.6rem); box-shadow:var(--shadow); }
.field{ margin-bottom:1.15rem; }
.field label{ display:block; font-size:.82rem; font-weight:600; letter-spacing:.02em; color:var(--ink); margin-bottom:.4rem; }
.field input, .field textarea{
  width:100%; font-family:inherit; font-size:1rem; color:var(--text);
  background:var(--mist); border:1px solid var(--line); border-radius:10px; padding:.85rem .95rem;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.field textarea{ min-height:150px; resize:vertical; }
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--gold); background:#fff; box-shadow:0 0 0 3px var(--gold-soft);
}
.contact-grid{ display:grid; gap:clamp(1.6rem,4vw,3rem); grid-template-columns:1fr; }
@media(min-width:880px){ .contact-grid{ grid-template-columns:1.2fr .8fr; } }
.contact-aside .info-row{ display:flex; gap:.8rem; align-items:flex-start; padding:1rem 0; border-bottom:1px solid var(--line); }
.contact-aside .info-row:last-child{ border-bottom:0; }
.contact-aside .ico{ width:20px; height:20px; color:var(--gold); flex:none; margin-top:3px; }
.contact-aside .k{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--slate); }
.contact-aside .v{ font-weight:500; color:var(--ink); }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--ink); color:#aebbd4; padding:clamp(2.6rem,5vw,3.6rem) 0 1.6rem; border-top:1px solid var(--line-dark); }
.footer-top{ display:grid; gap:2rem; grid-template-columns:1fr; }
@media(min-width:760px){ .footer-top{ grid-template-columns:1.4fr 1fr; align-items:start; } }
.footer-brand .logo{ margin-bottom:1rem; }
.footer-brand p{ color:#8693b0; max-width:36ch; font-size:.95rem; }
.footer-nav h4{ font-family:var(--font-mono); font-weight:500; font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin:0 0 1rem; }
.footer-nav ul{ list-style:none; margin:0; padding:0; columns:2; gap:1.2rem; }
.footer-nav a{ display:inline-block; padding:.32rem 0; color:#b3bed6; font-size:.92rem; }
.footer-nav a:hover{ color:#fff; }
.footer-bottom{
  margin-top:2.4rem; padding-top:1.4rem; border-top:1px solid var(--line-dark);
  display:flex; flex-wrap:wrap; gap:.8rem 1.4rem; align-items:center; justify-content:space-between;
  font-size:.84rem; color:#7e8cab;
}
.footer-bottom .eu{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-mono); letter-spacing:.06em; }

/* =========================================================
   COOKIE BANNER
   ========================================================= */
.cookie{
  position:fixed; left:50%; transform:translateX(-50%); bottom:18px; z-index:150;
  width:min(680px, calc(100% - 32px));
  background:#0d1b36; border:1px solid var(--line-dark); border-radius:14px;
  box-shadow:var(--shadow-lg); padding:1.1rem 1.2rem;
  display:flex; flex-wrap:wrap; gap:.9rem 1.2rem; align-items:center; justify-content:space-between;
}
.cookie[hidden]{ display:none; }
.cookie p{ margin:0; color:#bcc7dd; font-size:.86rem; flex:1 1 280px; }
.cookie .cookie-actions{ display:flex; gap:.6rem; }
.cookie .btn{ padding:.55rem 1rem; font-size:.86rem; }

/* =========================================================
   RESPONSIVE NAV
   ========================================================= */
@media (max-width: 940px){
  .burger{ display:block; order:3; }
  .nav{
    position:fixed; inset:72px 0 auto 0; margin:0;
    background:var(--paper); border-bottom:1px solid var(--line);
    transform:translateY(-120%); transition:transform .32s ease; will-change:transform;
    max-height:calc(100dvh - 72px); overflow:auto;
  }
  .nav[data-open="true"]{ transform:translateY(0); box-shadow:var(--shadow-lg); }
  .nav-list{ flex-direction:column; align-items:stretch; gap:.1rem; padding:.8rem var(--gutter) 1.4rem; }
  .nav-list a{ padding:.85rem .4rem; font-size:1.02rem; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-list a[aria-current="page"]::after{ display:none; }
  .nav-list a[aria-current="page"]{ color:var(--navy); }
}

/* =========================================================
   A11y / motion
   ========================================================= */
:focus-visible{ outline:2px solid var(--gold); outline-offset:2px; border-radius:4px; }
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

/* reveal on load */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(14px); }
  .reveal.in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
}
