/* ==========================================================
   VoltSecure - SHARED nav + footer + mobile menu
   Load this FIRST (before page-specific <style>) so page CSS
   can still override if needed.
   ========================================================== */

:root{
  --vs-bg:#0a0a0a;
  --vs-panel:#131210;
  --vs-line:rgba(201,169,97,0.18);
  --vs-line-soft:rgba(255,255,255,0.06);
  --vs-gold:#c9a961;
  --vs-gold-deep:#8f7640;
  --vs-cream:#f4efe6;
  --vs-mute:#8a8275;
  --vs-fdisplay:'Tenor Sans','Optima',serif;
  --vs-fbody:'Inter',system-ui,sans-serif;
  --vs-fmono:'JetBrains Mono',ui-monospace,monospace;
  --vs-max:1200px;
}

/* ====== GLOBAL BASE + CONTAINER + OVERFLOW GUARD ======
   Dark background and cream text applied at html/body so pages that
   don't redeclare them (deutschland, ireland, etc.) still render on
   brand instead of falling back to browser white.
   .wrap is the shared max-width container used inside every section.
   overflow-x:hidden on body prevents stray transforms / oversized
   SVGs from forcing a horizontal scrollbar. */
html,body{overflow-x:hidden;background:var(--vs-bg);color:var(--vs-cream);font-family:var(--vs-fbody);margin:0;padding:0}
.wrap{max-width:var(--vs-max);margin:0 auto;padding:0 32px;box-sizing:border-box}
@media(max-width:720px){.wrap{padding:0 20px}}
@media(max-width:480px){.wrap{padding:0 16px}}

/* ====== NAV ====== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:14px 0;background:rgba(10,10,10,0.94);border-bottom:1px solid var(--vs-line)}
.nav::before{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--vs-gold),transparent);opacity:.6}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:1200px;margin:0 auto;padding:0 32px}
.brand{display:inline-flex;align-items:center;flex-shrink:0}
.brand img{height:72px;width:auto;display:block;transition:height .25s}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links>a{font-size:13px;letter-spacing:0.04em;opacity:.78;transition:opacity .2s,color .2s;color:var(--vs-cream);font-family:var(--vs-fbody);font-weight:400}
.nav-links>a:hover{opacity:1;color:var(--vs-gold)}
.nav-links>a.current{color:var(--vs-gold);opacity:1}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-cta{padding:10px 20px;border:1px solid var(--vs-gold);color:var(--vs-gold);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;transition:all .25s;font-family:var(--vs-fmono);display:inline-flex;align-items:center;gap:10px}
.nav-cta:hover{background:var(--vs-gold);color:#0a0a0a}
.burger{display:none;flex-direction:column;gap:4px;padding:8px;background:none;border:none;cursor:pointer}
.burger span{width:22px;height:1px;background:var(--vs-gold);display:block}

/* lang toggle button - shown on desktop in nav, also shown in mobile overlay */
.lang-toggle{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--vs-line);background:transparent;color:var(--vs-cream);font-family:var(--vs-fmono);font-size:11px;letter-spacing:0.14em;cursor:pointer;transition:all .2s}
.lang-toggle:hover{border-color:var(--vs-gold);color:var(--vs-gold)}
.lang-toggle svg{border:1px solid var(--vs-line-soft);display:block}
.lang-toggle .lt-label{color:var(--vs-mute);transition:color .2s}
.lang-toggle:hover .lt-label{color:var(--vs-gold)}

/* mobile extras inside overlay - hidden on desktop */
.nav-mobile-extras{display:none}

/* ====== MOBILE MENU ====== */
@media(max-width:960px){
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:#0a0a0a;padding:14px 0}
  .nav-inner{padding:0 18px;gap:12px}
  .brand img{height:60px}
  .nav-right{gap:10px}
  .nav-right .lang-toggle{display:inline-flex;padding:7px 10px;font-size:10.5px;gap:6px}
  .nav-right .lang-toggle svg{width:20px;height:13px}
  .nav-right .nav-cta{display:inline-flex;padding:9px 14px;font-size:10.5px;letter-spacing:0.1em;gap:6px}

  .nav-links{
    display:none;position:fixed;inset:0;background:#0a0a0a;
    flex-direction:column;align-items:center;justify-content:flex-start;
    gap:28px;z-index:999;padding:180px 20px 40px;overflow-y:auto;
  }
  .nav-links.open{display:flex}
  /* big logo at top of overlay */
  .nav-links::before{
    content:"";position:absolute;top:40px;left:50%;transform:translateX(-50%);
    width:240px;height:150px;
    background:url('/assets/logo-gold.png') center/contain no-repeat;
  }
  .nav-links>a{
    font-size:30px;letter-spacing:0.03em;opacity:1;color:var(--vs-cream);
    font-family:var(--vs-fdisplay);font-weight:400;padding:6px 16px;
    transition:color .2s;
  }
  .nav-links>a:hover,.nav-links>a:active,.nav-links>a.current{color:var(--vs-gold)}

  /* show CTA + flag at bottom of overlay */
  .nav-mobile-extras{
    display:flex;flex-direction:column;align-items:center;gap:20px;
    margin-top:24px;padding-top:32px;width:100%;
    border-top:1px solid rgba(201,169,97,0.2);
  }
  .nav-mobile-extras .lang-toggle{padding:10px 20px;font-size:13px}
  .mobile-cta{
    display:inline-flex;align-items:center;gap:12px;padding:16px 36px;
    background:var(--vs-gold);color:#0a0a0a;
    font-family:var(--vs-fmono);font-size:13px;letter-spacing:0.2em;
    text-transform:uppercase;font-weight:500;transition:all .2s;
  }
  .mobile-cta:hover,.mobile-cta:active{background:var(--vs-cream);transform:translateY(-2px)}

  .burger{display:flex;z-index:1001;position:relative}
}
@media(max-width:560px){
  .nav{padding:12px 0}
  .brand img{height:56px}
  .nav-right .lang-toggle .lt-label{display:none}
  .nav-right .lang-toggle{padding:6px 8px;gap:0}
  /* hide the top-bar CTA entirely on phones - burger menu carries its own .mobile-cta */
  .nav-right .nav-cta{display:none}
  .nav-inner{padding:0 14px;gap:8px}
  .nav-right{gap:8px}
}
@media(max-width:420px){
  .brand img{height:50px}
  .nav-right{gap:6px}
  .nav-inner{padding:0 12px;gap:6px}
  .nav-links>a{font-size:26px}
  .nav-links::before{width:200px;height:125px;top:50px}
  .nav-links{padding:190px 20px 32px}
}
/* by default: desktop shows long label, short hidden */
.nav-cta .cta-full{display:inline}
.nav-cta .cta-short{display:none}

/* ====== FOOTER (canonical) ====== */
.vs-footer{background:#070707;color:var(--vs-cream);padding:80px 0 28px;border-top:1px solid var(--vs-line);font-family:var(--vs-fbody)}
.vs-footer::before{content:"";display:block;height:1px;background:linear-gradient(90deg,transparent,var(--vs-gold),transparent);opacity:.5;margin-bottom:80px;margin-top:-81px}
.vs-footer .wrap{max-width:1280px;margin:0 auto;padding:0 32px}
@media(max-width:720px){.vs-footer .wrap{padding:0 20px}}
.vs-footer-grid{display:grid;grid-template-columns:1.4fr 0.9fr 0.9fr 0.9fr 0.9fr;gap:48px;margin-bottom:56px}
@media(max-width:1080px){.vs-footer-grid{grid-template-columns:1fr 1fr 1fr;gap:36px}}
@media(max-width:640px){.vs-footer-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:420px){.vs-footer-grid{grid-template-columns:1fr}}
.vs-footer-brand{grid-column:span 1}
@media(max-width:1080px){.vs-footer-brand{grid-column:1 / -1;display:flex;gap:24px;align-items:flex-start;margin-bottom:4px;flex-wrap:wrap}}
@media(max-width:640px){.vs-footer-brand{flex-direction:column;gap:14px}}
.vs-footer-brand img{height:56px;margin-bottom:18px}
@media(max-width:1080px){.vs-footer-brand img{margin-bottom:0;flex-shrink:0}}
.vs-footer-brand p{font-size:13px;color:var(--vs-mute);max-width:36ch;line-height:1.6}
.vs-footer-brand .bafe{display:inline-flex;align-items:center;gap:10px;margin-top:14px;font-family:var(--vs-fmono);font-size:10px;color:var(--vs-gold);letter-spacing:0.14em;text-transform:uppercase;padding:6px 12px;border:1px solid var(--vs-line)}

.vs-footer-col h4{font-family:var(--vs-fmono);font-size:11px;color:var(--vs-gold);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:18px;font-weight:500}
.vs-footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;padding:0;margin:0}
.vs-footer-col a{font-size:14px;color:var(--vs-mute);transition:color .2s;text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.vs-footer-col a:hover{color:var(--vs-gold)}
.vs-footer-col a .ext{color:var(--vs-gold);font-size:10px;display:inline-block;transform:translateY(-1px)}
.vs-footer-col li{color:var(--vs-mute);font-size:14px;line-height:1.5}
.vs-footer-col li.tel,.vs-footer-col li.em{font-family:var(--vs-fmono);font-size:12.5px;letter-spacing:0.04em}

.vs-footer-bot{border-top:1px solid var(--vs-line-soft);padding-top:28px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:var(--vs-fmono);font-size:11px;color:var(--vs-mute);letter-spacing:0.08em;line-height:1.8}
.vs-footer-bot a{color:var(--vs-mute);text-decoration:none}
.vs-footer-bot a:hover{color:var(--vs-gold)}
.vs-footer-policy{display:flex;gap:20px;flex-wrap:wrap}
@media(max-width:640px){.vs-footer-bot{flex-direction:column;gap:14px}.vs-footer-policy{gap:14px}}

/* ====== FOOTER social icon row ====== */
.vs-footer-social{list-style:none;display:flex;gap:12px;padding:0;margin:0}
.vs-footer-social li{margin:0;line-height:1}
.vs-footer-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;color:var(--vs-mute);border:1px solid var(--vs-line);background:transparent;transition:color .25s,border-color .25s,transform .25s,background .25s;text-decoration:none}
.vs-footer-social a:hover,.vs-footer-social a:focus-visible{color:var(--vs-gold);border-color:var(--vs-gold);transform:translateY(-2px);background:rgba(201,169,97,.06);outline:none}
.vs-footer-social a svg{width:18px;height:18px;display:block;fill:currentColor}
@media(max-width:640px){.vs-footer-social{justify-content:center}}

/* ====== FOOTER mobile centring - keep desktop unchanged ======
   At <=640 the grid stacks into 1-2 cols and content was hugging the left
   edge, leaving a visibly empty right side. Centring the stack here
   balances the column visually without changing typography or colours. */
@media(max-width:640px){
  .vs-footer{text-align:center}
  /* brand block: inner div holds img + p + bafe pill; flex-centre them */
  .vs-footer-brand{align-items:center;text-align:center}
  .vs-footer-brand > div{display:flex;flex-direction:column;align-items:center;width:100%}
  .vs-footer-brand img{margin:0 0 14px}
  .vs-footer-brand p{max-width:34ch;margin:0 auto}
  .vs-footer-brand .bafe{align-self:center}
  /* link lists: centre the column of links and the h4 heading */
  .vs-footer-col{text-align:center}
  .vs-footer-col ul{align-items:center}
  .vs-footer-col a{justify-content:center}
  /* increase tap target without changing visual rhythm too much */
  .vs-footer-col ul{gap:14px}
  .vs-footer-col a{padding:4px 0;min-height:32px}
  /* bottom strip: copyright + policy links both centred */
  .vs-footer-bot{text-align:center;align-items:center}
  .vs-footer-policy{justify-content:center}
}
@media(max-width:420px){
  /* one column at smallest widths - keep the centred treatment, just
     consistent spacing between groups since gap:28px from <=640 still
     applies via the grid rule */
  .vs-footer-grid{gap:32px}
}


/* ---- projects.html - service filter (added in checklist pass 1) ---- */
.proj-filter{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 28px;padding:0;}
.pf-btn{
  appearance:none;border:1px solid rgba(201,169,97,.32);background:transparent;
  color:#d8d4cc;font:500 12px/1 'Inter',sans-serif;letter-spacing:.06em;text-transform:uppercase;
  padding:9px 14px;border-radius:999px;cursor:pointer;transition:all .18s ease;
}
.pf-btn:hover{border-color:#c9a961;color:#fff;}
.pf-btn.is-active{background:#c9a961;border-color:#c9a961;color:#0a0a0a;}
.pf-btn:focus-visible{outline:2px solid #c9a961;outline-offset:2px;}
.lead-hint{display:inline-block;margin-left:6px;color:#c9a961;font-style:normal;}


/* ---- about.html - team grid + testimonials (added in checklist pass 1) ---- */
.team-section{padding:96px 0;border-top:1px solid rgba(201,169,97,.12);}
.team-section .lead{color:#b8b3a8;}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media(max-width:860px){.team-grid{grid-template-columns:1fr;}}
.tm-card{padding:24px 22px;border:1px solid rgba(201,169,97,.18);background:#0d0c0a;display:flex;flex-direction:column;gap:8px;}
.tm-photo{aspect-ratio:1/1;background:#14120e;display:flex;align-items:center;justify-content:center;border:1px solid rgba(201,169,97,.18);margin-bottom:12px;}
.tm-ph{font:500 11px/1 'JetBrains Mono',monospace;letter-spacing:.18em;color:#8a8275;text-transform:uppercase;}
.tm-card h3{font-family:'Tenor Sans',serif;font-size:20px;color:#f5f1e6;margin:0;}
.tm-card .tm-role{font:500 11px/1 'JetBrains Mono',monospace;letter-spacing:.14em;color:#c9a961;text-transform:uppercase;}
.tm-card p{color:#b8b3a8;font-size:14px;line-height:1.6;margin:0;}

.about-testimonials{padding:96px 0;border-top:1px solid rgba(201,169,97,.12);background:#0d0c0a;}
.at-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px;}
@media(max-width:860px){.at-grid{grid-template-columns:1fr;}}
.at-card{padding:28px 24px;border:1px solid rgba(201,169,97,.18);background:#0a0a0a;display:flex;flex-direction:column;gap:14px;margin:0;}
.at-card .testimonial-stars{color:#c9a961;letter-spacing:6px;font-size:14px;}
.at-card blockquote{margin:0;color:#e9e3d4;font-style:italic;font-size:15px;line-height:1.6;}
.at-card figcaption{padding-top:14px;border-top:1px solid rgba(201,169,97,.16);display:flex;flex-direction:column;gap:3px;}
.at-card figcaption strong{font-family:'Tenor Sans',serif;color:#f5f1e6;font-weight:400;font-size:15px;}
.at-card figcaption span{font:500 10px/1 'JetBrains Mono',monospace;letter-spacing:.14em;color:#c9a961;text-transform:uppercase;}


/* ---- accreditations.html - group split (added in checklist pass 1) ---- */
.acc-group-title{
  font-family:'Tenor Sans',serif;font-size:18px;color:#c9a961;
  margin:32px 0 4px;padding:0 4px;letter-spacing:.02em;
}
.acc-group-title:first-child{margin-top:0;}
.acc-group-sub{
  color:#8a8275;font-size:13px;line-height:1.6;margin:0 0 18px;padding:0 4px;
}
.acc-logo--text{
  display:flex;align-items:center;justify-content:center;
  font-family:'Tenor Sans',serif;color:#c9a961;font-size:14px;
  letter-spacing:.06em;
}
[data-vendor-todo] .acc-name::after{
  content:'· TODO';color:#8a8275;font-size:10px;font-family:'JetBrains Mono',monospace;
  letter-spacing:.16em;margin-left:8px;vertical-align:middle;
}
