
/* === assets/style.css === */
:root{--bg:#f6f2ea;--ink:#171512;--muted:#6f6a62;--card:#fffdf8;--gold:#b89255;--line:rgba(20,18,15,.12);--dark:#161513}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;line-height:1.65}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:20px;padding:16px 24px;background:rgba(246,242,234,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{font-family:Georgia,serif;font-size:20px;color:var(--ink);text-decoration:none;white-space:nowrap}nav{display:flex;gap:18px;flex:1;justify-content:center;flex-wrap:wrap}nav a{color:var(--muted);text-decoration:none;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.langs{display:flex;gap:6px}.langs button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 10px;cursor:pointer}.langs button.active{background:var(--dark);color:#fff}
.loading{padding:120px 24px;text-align:center}.section{padding:90px 0}.hero{padding-top:90px;padding-bottom:80px}.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}.eyebrow,.label{color:var(--gold);font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:800}
h1,h2,h3{font-family:Georgia,serif;line-height:1.1}h1{font-size:clamp(42px,6vw,76px);margin:18px 0}h2{font-size:clamp(30px,4vw,50px);margin:10px 0 22px}.lead,.hero p{font-size:19px;color:var(--muted);max-width:760px}
.actions,.socials{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.btn,.submit{display:inline-block;border:1px solid var(--ink);border-radius:999px;padding:12px 18px;text-decoration:none;color:var(--ink);background:transparent;font-weight:800;cursor:pointer}.btn.primary,.submit{background:var(--ink);color:#fff}.portrait{border-radius:34px;overflow:hidden;background:#ddd;box-shadow:0 30px 80px rgba(0,0,0,.18)}.portrait img{width:100%;height:520px;object-fit:cover;object-position:50% 20%;display:block}
.grid2{display:grid;grid-template-columns:.8fr 1.2fr;gap:70px}.quote{border-left:4px solid var(--gold);padding-left:22px;font-family:Georgia,serif;font-size:24px;color:#3a342c}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}.card{background:var(--card);border:1px solid var(--line);border-radius:26px;padding:24px;box-shadow:0 14px 50px rgba(0,0,0,.05)}.icon{font-size:32px;color:var(--gold)}
.dark{background:var(--dark);color:#fff}.dark .lead,.dark p,.dark .company{color:rgba(255,255,255,.68)}.timeline{margin-top:36px}.job{display:grid;grid-template-columns:170px 1fr;gap:26px;border-top:1px solid rgba(255,255,255,.14);padding:26px 0}.job time{color:var(--gold);font-weight:800}.company{font-weight:800;margin:4px 0 10px}
.skillsbox{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:34px}.tags{display:flex;flex-wrap:wrap;gap:10px}.tag,.qual{background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 14px}.qual{border-radius:18px;margin-bottom:10px}
.contactgrid{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px}.form-status{margin-bottom:12px;font-weight:800}.form-status.ok{color:#178a42}.form-status.err{color:#b42318}form{display:grid;gap:12px}input,textarea{width:100%;border:1px solid var(--line);border-radius:18px;padding:14px 16px;font:inherit;background:#fff}textarea{min-height:160px}.honeypot{display:none!important}
footer{text-align:center;color:rgba(26,24,20,.65);padding:50px 20px 90px;border-top:1px solid var(--line)}.legal-links{display:flex;justify-content:center;gap:20px;margin-top:16px;flex-wrap:wrap}.legal-links a{color:#777;text-decoration:none;font-size:14px}.legal-links a:hover{color:#000}
.admin-login{min-height:100vh;display:grid;place-items:center;padding:30px}.loginbox{background:white;border:1px solid var(--line);border-radius:28px;padding:34px;max-width:420px;width:100%;box-shadow:0 30px 70px rgba(0,0,0,.12)}.adminbar{position:fixed;left:16px;right:16px;bottom:16px;z-index:99;background:#151513;color:white;border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:12px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;box-shadow:0 20px 60px rgba(0,0,0,.28)}.adminbar button{border:0;border-radius:999px;padding:11px 16px;font-weight:800;cursor:pointer}.adminbar .save{background:var(--gold);color:white}.adminbar .ghost{background:rgba(255,255,255,.12);color:white}.adminpanel{position:fixed;right:16px;top:86px;bottom:92px;z-index:98;width:min(560px,calc(100vw - 32px));background:white;border:1px solid var(--line);border-radius:24px;box-shadow:0 25px 80px rgba(0,0,0,.22);display:none;overflow:auto}.adminpanel.open{display:block}.adminpanel header{position:sticky;top:0;background:white;border-bottom:1px solid var(--line);padding:16px 18px;display:flex;justify-content:space-between;align-items:center}.adminpanel .body{padding:18px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#777;margin-bottom:6px}.field input,.field textarea{border-radius:14px;padding:12px}.itembox{border:1px solid var(--line);border-radius:16px;padding:12px;margin:12px 0;background:#fafafa}.smallbtn{border:1px solid var(--line);background:white;border-radius:999px;padding:8px 12px;font-weight:700;cursor:pointer}.danger{color:#b42318}.status{margin-left:auto;color:var(--gold);font-weight:800}
@media(max-width:800px){.topbar{align-items:flex-start;flex-wrap:wrap}nav{order:3;width:100%;justify-content:flex-start}.hero-grid,.grid2,.contactgrid,.skillsbox{grid-template-columns:1fr}.cards{grid-template-columns:1fr}.job{grid-template-columns:1fr}.portrait img{height:auto;max-height:520px;object-fit:contain;background:#ddd}footer{padding-bottom:120px}}


/* === assets/language-manager.css === */
.lang-select{position:relative;min-width:150px}
.lang-current{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid rgba(0,0,0,.14);background:#fff;color:#171512;border-radius:999px;padding:8px 12px;font-weight:800;cursor:pointer;box-shadow:0 8px 30px rgba(0,0,0,.04)}
.lang-arrow{display:none !important;width:0 !important;overflow:hidden !important;}
.lang-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:190px;background:#fff;border:1px solid rgba(0,0,0,.12);border-radius:18px;padding:8px;box-shadow:0 18px 50px rgba(0,0,0,.16);display:none;z-index:100}
.lang-select.open .lang-menu{display:grid;gap:4px}
.lang-menu button{display:flex;align-items:center;gap:10px;width:100%;border:0;background:transparent;border-radius:12px;padding:10px 12px;cursor:pointer;font-weight:700;text-align:left}
.lang-menu button:hover,.lang-menu button.active{background:#f3eee5}
@media(max-width:700px){.lang-select{min-width:130px}.lang-menu{right:auto;left:0}}


/* === assets/css/mobile-burger-nav.css === */
/* Mobile Burger Navigation – Premium Standard */
/* Desktop bleibt unverändert. Mobile wird sauber und modern. */

.mobile-menu-toggle,
.mobile-menu-overlay{
  display:none;
}

@media(max-width: 820px){

  .topbar{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto auto;
    align-items:center;
    gap:10px;
    padding:12px 14px;
    left:10px;
    right:10px;
    top:10px;
    border-radius:22px;
    background:rgba(255,255,255,.78);
    border:1px solid rgba(0,0,0,.08);
    box-shadow:0 18px 55px rgba(0,0,0,.10);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
  }

  .brand{
    min-width:0;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    font-weight:900;
  }

  .topbar > #nav{
    display:none !important;
  }

  .langs{
    justify-self:end;
  }

  .lang-select{
    min-width:118px;
  }

  .lang-current{
    padding:8px 10px;
    font-size:13px;
  }

  .mobile-menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    border:1px solid rgba(0,0,0,.10);
    border-radius:999px;
    background:#171512;
    color:#fff;
    font-size:22px;
    font-weight:900;
    line-height:1;
    cursor:pointer;
    box-shadow:0 12px 32px rgba(0,0,0,.16);
  }

  .mobile-menu-overlay{
    position:fixed;
    inset:0;
    z-index:9998;
    background:rgba(23,21,18,.42);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    padding:86px 14px 20px;
  }

  .mobile-menu-overlay.open{
    display:block;
  }

  .mobile-menu-panel{
    max-width:420px;
    margin:0 auto;
    background:#fffdf8;
    border:1px solid rgba(0,0,0,.10);
    border-radius:28px;
    padding:18px;
    box-shadow:0 30px 90px rgba(0,0,0,.26);
  }

  .mobile-menu-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:4px 4px 14px;
    border-bottom:1px solid rgba(0,0,0,.08);
    margin-bottom:10px;
  }

  .mobile-menu-title{
    font-weight:900;
    color:#171512;
  }

  .mobile-menu-close{
    width:38px;
    height:38px;
    border:0;
    border-radius:999px;
    background:#171512;
    color:#fff;
    font-size:24px;
    line-height:1;
    cursor:pointer;
  }

  .mobile-menu-links{
    display:grid;
    gap:8px;
  }

  .mobile-menu-links a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    text-decoration:none;
    color:#171512;
    font-weight:900;
    padding:15px 16px;
    border-radius:18px;
    background:#f6efe2;
    border:1px solid rgba(0,0,0,.06);
  }

  .mobile-menu-links a::after{
    content:"→";
    color:#c9a34a;
    font-weight:900;
  }

  .mobile-menu-links a:active{
    transform:scale(.985);
  }

  body.mobile-menu-open{
    overflow:hidden;
  }

  .hero{
    padding-top:132px;
  }
}

@media(max-width:430px){
  .topbar{
    left:8px;
    right:8px;
    top:8px;
    padding:10px 12px;
  }

  .mobile-menu-toggle{
    width:40px;
    height:40px;
  }

  .brand{
    font-size:15px;
  }

  .lang-current{
    font-size:12.5px;
  }

  .hero{
    padding-top:136px;
  }
}


/* === assets/css/premium-shared.css === */
:root{
  --premium-dark:#07111d;
  --premium-gold:#c9a34a;
  --premium-beige:#f4ecdc;
  --premium-text:#171512;
}

.topbar{
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  background: rgba(7,17,29,.92) !important;
  border-bottom: 1px solid rgba(201,163,74,.22) !important;
}

.topbar .brand{
  color:#fff !important;
  letter-spacing:.02em;
}

.topbar nav a{
  color:rgba(255,255,255,.86) !important;
}

.topbar nav a:hover{
  color:var(--premium-gold) !important;
}

.lang-current{
  background:rgba(255,255,255,.08) !important;
  color:#fff !important;
  border-color:rgba(201,163,74,.45) !important;
}

.hero,
#app .hero,
main#app .hero,
body .hero{
  max-width:none !important;
  padding:0 !important;
  margin:0 !important;
  background:
    radial-gradient(circle at 72% 38%, rgba(201,163,74,.22), transparent 24%),
    linear-gradient(90deg, rgba(7,17,29,.98) 0%, rgba(7,17,29,.92) 42%, rgba(7,17,29,.72) 68%, rgba(7,17,29,.56) 100%),
    linear-gradient(135deg, #07111d, #111f2f) !important;
  color:#fff !important;
  min-height:680px !important;
  display:flex !important;
  align-items:center !important;
  overflow:hidden !important;
  position:relative !important;
}

.hero::before,
#app .hero::before,
main#app .hero::before,
body .hero::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:
    linear-gradient(90deg, rgba(7,17,29,.05), rgba(7,17,29,.25)),
    radial-gradient(circle at 90% 70%, rgba(244,236,220,.10), transparent 22%) !important;
  pointer-events:none !important;
}

.hero .hero-grid,
#app .hero .hero-grid,
main#app .hero .hero-grid,
body .hero .hero-grid{
  width:min(1180px, calc(100% - 48px)) !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:1.05fr .95fr !important;
  gap:52px !important;
  align-items:center !important;
  position:relative !important;
  z-index:2 !important;
  padding:92px 0 72px !important;
}

.hero .eyebrow,
#app .hero .eyebrow,
body .hero .eyebrow{
  color:var(--premium-gold) !important;
  font-weight:900 !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  margin-bottom:18px !important;
}

.hero h1,
#app .hero h1,
body .hero h1{
  color:#fff !important;
  font-size:clamp(48px, 7vw, 88px) !important;
  line-height:.95 !important;
  letter-spacing:-.055em !important;
  margin:0 0 18px !important;
  max-width:720px !important;
}

.hero .lead,
#app .hero .lead,
body .hero .lead{
  color:rgba(255,255,255,.88) !important;
  font-size:clamp(18px, 2vw, 23px) !important;
  line-height:1.55 !important;
  max-width:620px !important;
  margin-top:28px !important;
  position:relative !important;
}

.hero .lead::before,
#app .hero .lead::before,
body .hero .lead::before{
  content:"" !important;
  display:block !important;
  width:74px !important;
  height:3px !important;
  background:var(--premium-gold) !important;
  border-radius:99px !important;
  margin-bottom:24px !important;
}

.hero .actions,
#app .hero .actions,
body .hero .actions{
  margin-top:36px !important;
  display:flex !important;
  gap:16px !important;
  flex-wrap:wrap !important;
}

.hero .btn,
#app .hero .btn,
body .hero .btn{
  border-radius:999px !important;
  padding:15px 24px !important;
  font-weight:900 !important;
  border:1px solid rgba(201,163,74,.55) !important;
  color:#fff !important;
  background:rgba(255,255,255,.05) !important;
  box-shadow:0 18px 50px rgba(0,0,0,.20) !important;
}

.hero .btn.primary,
#app .hero .btn.primary,
body .hero .btn.primary{
  background:linear-gradient(135deg, #d7b568, #b78d3d) !important;
  color:#171512 !important;
  border-color:transparent !important;
}

.hero .portrait,
#app .hero .portrait,
body .hero .portrait{
  justify-self:end !important;
  width:min(430px, 100%) !important;
  aspect-ratio:4 / 5 !important;
  border-radius:34px !important;
  overflow:hidden !important;
  background:linear-gradient(135deg, rgba(244,236,220,.16), rgba(201,163,74,.16)) !important;
  border:1px solid rgba(201,163,74,.26) !important;
  box-shadow:0 34px 90px rgba(0,0,0,.42) !important;
  position:relative !important;
}

.hero .portrait img,
#app .hero .portrait img,
body .hero .portrait img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center top !important;
  display:block !important;
  transform:scale(1.02) !important;
}

.adminbar{
  z-index:10000 !important;
}

@media(max-width:900px){
  .hero,
  #app .hero,
  body .hero{
    min-height:auto !important;
  }

  .hero .hero-grid,
  #app .hero .hero-grid,
  body .hero .hero-grid{
    grid-template-columns:1fr !important;
    gap:34px !important;
    width:min(100% - 32px, 620px) !important;
    padding:78px 0 52px !important;
  }

  .hero .portrait,
  #app .hero .portrait,
  body .hero .portrait{
    justify-self:center !important;
    width:min(320px, 88vw) !important;
    order:-1 !important;
    border-radius:28px !important;
  }

  .hero h1,
  #app .hero h1,
  body .hero h1{
    font-size:clamp(42px, 13vw, 64px) !important;
  }

  .hero .lead,
  #app .hero .lead,
  body .hero .lead{
    font-size:17px !important;
  }
}


/* === assets/css/vm-brand.css === */
.topbar .brand{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  text-decoration:none !important;
}

.topbar .brand::before{
  content:"";
  width:40px;
  height:40px;
  flex:0 0 40px;
  display:inline-block;
  background-image:url("img/vm-logo-192.png");
  background-size:cover;
  background-position:center;
  border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.22);
}

@media(max-width:700px){
  .topbar .brand::before{
    width:34px;
    height:34px;
    flex-basis:34px;
    border-radius:8px;
  }
}


/* === assets/css/no-flags-language.css === */
/* Premium kompakter Sprachschalter ohne Pfeil/Flaggen */

.lang-flag,
.lang-current img,
.lang-menu img,
.langs img{
  display:none !important;
}

/* Sprachbutton klein und hochwertig */
.lang-current{
  width:auto !important;
  min-width:64px !important;
  max-width:86px !important;
  height:42px !important;
  padding:0 18px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:0 !important;
  border-radius:999px !important;
  border:1px solid rgba(201,163,74,.55) !important;
  background:rgba(255,255,255,.06) !important;
  color:#fff !important;
  font-weight:900 !important;
  letter-spacing:.04em !important;
  line-height:1 !important;
  box-shadow:none !important;
}

/* Pfeil/Chevron entfernen */
.lang-current::after,
.lang-current .chevron,
.lang-current .arrow,
.lang-current svg,
.lang-current [aria-hidden="true"]{
  display:none !important;
  content:none !important;
}

/* Emoji-Flaggen im Text ausblenden ist per JS geregelt; hier optisch sauber halten */
.lang-current{
  overflow:hidden !important;
  white-space:nowrap !important;
}

/* Dropdown passend schmaler und edler */
.lang-menu{
  min-width:150px !important;
  border-radius:18px !important;
  border:1px solid rgba(201,163,74,.22) !important;
  overflow:hidden !important;
}

.lang-menu button,
.langs button{
  display:flex !important;
  align-items:center !important;
  gap:0 !important;
  font-weight:800 !important;
}

/* Mobile etwas kleiner */
@media(max-width:700px){
  .lang-current{
    min-width:58px !important;
    height:40px !important;
    padding:0 15px !important;
    font-size:14px !important;
  }
}


/* === FINAL OVERRIDES: clean production === */

/* Sprachbutton ohne sichtbaren Pfeil */
.lang-arrow,
.lang-current .lang-arrow,
.lang-current::after,
.lang-current::before,
.langs button::after,
.langs button::before{
  display:none !important;
  content:none !important;
  width:0 !important;
  height:0 !important;
  overflow:hidden !important;
}

/* Auf Mobil: normale Navigation ausblenden, Burger sichtbar */
@media(max-width:900px){
  .topbar nav#nav,
  .topbar nav{
    display:none !important;
  }

  .mobile-burger,
  .burger,
  .burger-btn,
  .menu-toggle{
    display:flex !important;
  }
}

/* Sicherer Mobile-Hero: Foto oben, Text darunter */
@media(max-width:900px){
  .hero,
  #app .hero,
  main#app .hero,
  body .hero{
    min-height:auto !important;
    overflow:hidden !important;
  }

  .hero .hero-grid,
  #app .hero .hero-grid,
  main#app .hero .hero-grid,
  body .hero .hero-grid{
    grid-template-columns:1fr !important;
    gap:34px !important;
    width:min(100% - 32px, 620px) !important;
    padding:78px 0 52px !important;
  }

  .hero .portrait,
  #app .hero .portrait,
  main#app .hero .portrait,
  body .hero .portrait{
    justify-self:center !important;
    width:min(320px, 88vw) !important;
    order:-1 !important;
  }

  .hero h1,
  #app .hero h1,
  main#app .hero h1,
  body .hero h1{
    font-size:clamp(40px, 9.8vw, 52px) !important;
    line-height:1.05 !important;
    max-width:100% !important;
  }

  .hero .lead,
  #app .hero .lead,
  main#app .hero .lead,
  body .hero .lead{
    font-size:17px !important;
    max-width:100% !important;
  }
}

@media(max-width:430px){
  .hero h1,
  #app .hero h1,
  main#app .hero h1,
  body .hero h1{
    font-size:clamp(36px, 10.5vw, 48px) !important;
  }
}
