/* ═══════════════════════════════════════════════════
   DLS SALONJA — shared.css v1 (Royal Navy · Chrome)
   Design-System für Portal + Fachbereiche
═══════════════════════════════════════════════════ */

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --chrome:#b8cce0;
  --chrome2:#d4e6f8;
  --chrome3:#6a8aaa;
  --champ:#c8daf0;
  --bone:#dcedf8;
  --bg:#010912;
  --bg2:#020d1e;
  --bg3:#030f28;
  --text:#d8eaf8;
  --dim:#5a7898;
  --dim2:#344e68;
  --accent:#a8c4dc;
  --shadow:0 24px 80px rgba(0,4,20,.9);
}

html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Josefin Sans',sans-serif;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -webkit-tap-highlight-color:rgba(0,0,0,0);
}

::selection{background:rgba(168,196,220,.25);}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--dim2);border-radius:3px;}

/* ═══ LOADING SCREEN ═══ */
@keyframes fu{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes chromePulse{0%,100%{filter:drop-shadow(0 2px 18px rgba(160,210,255,.45));}50%{filter:drop-shadow(0 2px 36px rgba(160,210,255,.85));}}

#LS{
  position:fixed;inset:0;z-index:1000;
  background:radial-gradient(ellipse at 50% 40%,var(--bg3) 0%,var(--bg) 70%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.4rem;transition:opacity .9s ease,visibility .9s;
}
#LS.done{opacity:0;visibility:hidden;pointer-events:none;}
#LS .ll{
  font-family:'Cinzel',serif;font-size:clamp(1.6rem,4vw,2.6rem);font-weight:700;
  letter-spacing:.35em;padding-left:.35em;
  background:linear-gradient(120deg,var(--chrome3),var(--chrome2) 40%,#fff 50%,var(--chrome2) 60%,var(--chrome3));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:fu .9s ease both,chromePulse 3s ease-in-out infinite;
}
#LS .ls{font-size:.72rem;letter-spacing:.5em;padding-left:.5em;color:var(--dim);text-transform:uppercase;animation:fu .9s .2s ease both;}
#LS .lb{width:min(280px,60vw);height:1px;background:var(--dim2);overflow:hidden;animation:fu .9s .35s ease both;}
#LS .lf{height:100%;width:0%;background:linear-gradient(90deg,var(--chrome3),var(--chrome2));transition:width .3s ease;box-shadow:0 0 12px rgba(180,210,240,.8);}
#LS .lp{font-size:.65rem;letter-spacing:.3em;color:var(--dim2);animation:fu .9s .45s ease both;}

/* ═══ NAV ═══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.3rem 4vw;
  transition:background .4s,backdrop-filter .4s,padding .4s;
}
nav.scrolled{background:rgba(1,9,18,.82);backdrop-filter:blur(18px);padding:.85rem 4vw;border-bottom:1px solid rgba(106,138,170,.12);}
.nlogo{
  font-family:'Cinzel',serif;font-weight:700;font-size:1.05rem;letter-spacing:.22em;
  color:var(--chrome2);text-decoration:none;white-space:nowrap;
  filter:drop-shadow(0 0 14px rgba(160,210,255,.35));
}
.nlogo span{color:var(--dim);font-weight:400;}
.nl{display:flex;gap:2.4rem;list-style:none;}
.nl a{
  color:var(--dim);text-decoration:none;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  transition:color .3s;position:relative;padding-bottom:4px;
}
.nl a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--chrome2);transition:width .35s;box-shadow:0 0 8px rgba(180,210,240,.7);}
.nl a:hover{color:var(--chrome2);}
.nl a:hover::after{width:100%;}
.nl a.active{color:var(--chrome2);}
.nl a.active::after{width:100%;}
.lang-toggle{display:flex;align-items:center;gap:.5rem;margin-left:2rem;}
.lb-btn{background:none;border:none;color:var(--dim2);font-family:inherit;font-size:.75rem;letter-spacing:.15em;cursor:pointer;transition:color .3s;padding:.2rem;}
.lb-btn.active{color:var(--chrome2);}
.lb-sep{color:var(--dim2);font-size:.7rem;}
.nav-mobile{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;z-index:300;}
.nav-mobile span{display:block;width:22px;height:1.5px;background:var(--chrome);transition:all .3s;}

/* ═══ TYPO / GENERICS ═══ */
.tag{
  font-size:.7rem;letter-spacing:.45em;text-transform:uppercase;color:var(--dim);
  display:flex;align-items:center;gap:1rem;
}
.tag::before{content:'';width:38px;height:1px;background:var(--chrome3);box-shadow:0 0 8px rgba(160,200,240,.5);}
h1,h2,h3{font-family:'Cinzel',serif;font-weight:400;color:var(--bone);}
h2 em,h1 em{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;
  background:linear-gradient(120deg,var(--chrome3),var(--chrome2) 50%,var(--chrome3));
  -webkit-background-clip:text;background-clip:text;color:transparent;}
.lead{color:var(--dim);font-size:.95rem;line-height:1.9;max-width:54ch;}

.btn{
  display:inline-block;padding:1rem 2.6rem;border:1px solid var(--chrome3);
  color:var(--chrome2);text-decoration:none;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;
  background:linear-gradient(120deg,rgba(168,196,220,.06),rgba(168,196,220,.02));
  transition:all .4s;cursor:pointer;font-family:inherit;position:relative;overflow:hidden;
}
.btn:hover{border-color:var(--chrome2);box-shadow:0 0 30px rgba(160,200,240,.25),inset 0 0 20px rgba(160,200,240,.08);transform:translateY(-2px);}

/* ═══ 3D SCROLL SCENES ═══ */
.scene-wrap{position:relative;}
.stick{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;background:var(--bg);}
canvas.tc{position:absolute;inset:0;width:100%;height:100%;display:block;}
.scene-ov{
  position:absolute;inset:0;display:flex;align-items:center;pointer-events:none;
  padding:0 6vw;z-index:5;
}
.scene-panel{
  width:min(460px,38vw);max-width:480px;pointer-events:auto;
  opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease;
}
.scene-panel.vis{opacity:1;transform:none;}
.scene-panel.right{margin-left:auto;}
.scene-panel.abs{position:absolute;}
.scene-panel.abs.right{right:6vw;}
.scene-panel.abs.left{left:6vw;}
.scene-panel h2{font-size:clamp(1.35rem,2.9vw,2.7rem);line-height:1.2;margin:clamp(.7rem,1.4vw,1.2rem) 0;}
.scene-panel .lead{font-size:clamp(.8rem,1vw,.95rem);}
.scene-panel .glass{
  background:rgba(2,13,30,.55);backdrop-filter:blur(14px);
  border:1px solid rgba(106,138,170,.18);padding:clamp(1.2rem,2.4vw,2.2rem);
  box-shadow:var(--shadow);
}
/* Weiche Blende am Ende der 3D-Szene → Übergang zur Übersicht */
.scene-blend{
  position:absolute;left:0;right:0;bottom:0;height:36vh;z-index:7;pointer-events:none;
  background:linear-gradient(180deg,rgba(1,9,18,0) 0%,rgba(1,9,18,.85) 62%,var(--bg) 100%);
  opacity:0;
}
.scroll-hint{
  position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.7rem;z-index:6;
  color:var(--dim);font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;
  transition:opacity .5s;
}
@keyframes sdrop{0%{transform:translateY(0);opacity:0;}30%{opacity:1;}100%{transform:translateY(14px);opacity:0;}}
.scroll-hint .sb{width:1px;height:34px;background:var(--dim2);position:relative;overflow:hidden;}
.scroll-hint .sb::after{content:'';position:absolute;top:0;left:0;width:100%;height:10px;background:var(--chrome2);animation:sdrop 1.8s ease infinite;box-shadow:0 0 6px rgba(180,210,240,.8);}

/* 3D-Labels */
.labels{position:absolute;inset:0;pointer-events:none;z-index:4;}
.lbl{
  position:absolute;
  display:flex;flex-direction:column;align-items:center;
  opacity:0;transform:translate(-50%,-94%) scale(.9);
  transition:opacity .45s ease,transform .45s ease;will-change:left,top;
}
.lbl.on{opacity:1;transform:translate(-50%,-100%) scale(1);}
.lbl .lt{
  display:flex;flex-direction:column;align-items:center;gap:.2rem;
  background:linear-gradient(165deg,rgba(10,26,50,.92),rgba(2,10,24,.86));
  backdrop-filter:blur(10px);
  border:1px solid rgba(172,210,246,.5);
  padding:.6rem 1.15rem .55rem;
  box-shadow:0 0 26px rgba(120,180,240,.28),0 14px 36px rgba(0,4,20,.8),inset 0 0 18px rgba(140,190,240,.07);
}
.lbl .lk{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--dim);white-space:nowrap;}
.lbl .lp2{
  font-family:'Cinzel',serif;font-weight:700;font-size:clamp(1rem,1.4vw,1.3rem);letter-spacing:.06em;white-space:nowrap;
  background:linear-gradient(120deg,var(--chrome2),#fff 50%,var(--chrome2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 10px rgba(170,215,255,.55));
}
.lbl .ll2{
  width:1px;height:46px;position:relative;
  background:linear-gradient(180deg,rgba(190,222,250,.85),rgba(190,222,250,0));
  box-shadow:0 0 8px rgba(160,200,240,.5);
}
.lbl .ll2::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translate(-50%,50%);
  width:7px;height:7px;border-radius:50%;background:var(--chrome2);
  box-shadow:0 0 12px rgba(180,215,250,.95);
}

/* ═══ CONTENT SECTIONS ═══ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease;}
.reveal.vis{opacity:1;transform:none;}
.svc{padding:8rem 8vw;background:linear-gradient(180deg,var(--bg),var(--bg2));position:relative;}
.svc h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin:1.2rem 0 1rem;}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem;margin-top:3.2rem;}
.card{
  border:1px solid rgba(106,138,170,.16);padding:2.2rem;position:relative;
  background:linear-gradient(160deg,rgba(168,196,220,.045),rgba(168,196,220,.012));
  transition:transform .45s,border-color .45s,box-shadow .45s;overflow:hidden;
  opacity:0;transform:translateY(30px);
}
.card.vis{opacity:1;transform:none;transition:opacity .7s ease,transform .7s ease,border-color .45s,box-shadow .45s;}
.card:hover{border-color:rgba(180,210,240,.45);box-shadow:0 18px 50px rgba(0,4,20,.65),0 0 26px rgba(160,200,240,.1);transform:translateY(-5px);}
.card .cnum{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-style:italic;color:var(--dim2);line-height:1;}
.card h3{font-size:1.02rem;letter-spacing:.1em;margin:1rem 0 .8rem;color:var(--bone);}
.card p{color:var(--dim);font-size:.86rem;line-height:1.8;}
.card .cfeat{margin-top:1.2rem;list-style:none;}
.card .cfeat li{color:var(--dim);font-size:.8rem;line-height:2;padding-left:1.2rem;position:relative;}
.card .cfeat li::before{content:'—';position:absolute;left:0;color:var(--chrome3);}

/* ═══ CONTACT ═══ */
#kontakt{padding:7rem 8vw;background:var(--bg2);position:relative;}
.cg{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;max-width:1200px;margin:0 auto;}
.ch{font-size:clamp(1.8rem,3.2vw,2.5rem);margin:1.4rem 0 1.4rem;}
.cd{display:flex;gap:1.1rem;align-items:flex-start;margin-bottom:1.6rem;}
.ci{
  width:42px;height:42px;flex:none;border:1px solid rgba(106,138,170,.3);
  display:flex;align-items:center;justify-content:center;
}
.ci svg{width:17px;height:17px;stroke:var(--chrome);fill:none;stroke-width:1.5;}
.cx{font-size:.88rem;color:var(--dim);line-height:1.6;}
.cx strong{display:block;color:var(--bone);font-weight:400;letter-spacing:.14em;font-size:.74rem;text-transform:uppercase;margin-bottom:.25rem;}
.cf{display:flex;flex-direction:column;gap:1.15rem;}
.fi{position:relative;}
.fi input,.fi textarea,.fi select{
  width:100%;background:rgba(1,9,18,.5);border:1px solid rgba(106,138,170,.25);
  padding:1rem 1.1rem;color:var(--text);font-family:inherit;font-size:.92rem;
  transition:border-color .3s,box-shadow .3s;border-radius:0;appearance:none;-webkit-appearance:none;
}
.fi input:focus,.fi textarea:focus,.fi select:focus{outline:none;border-color:var(--chrome3);box-shadow:0 0 18px rgba(160,200,240,.12);}
.fi select option{background:var(--bg);color:var(--text);}
.fi label{
  position:absolute;left:1.1rem;top:1rem;font-size:.78rem;letter-spacing:.1em;color:var(--dim2);
  pointer-events:none;transition:all .25s ease;background:var(--bg2);padding:0 .4rem;
}
.fi input:focus+label,.fi input:not(:placeholder-shown)+label,
.fi textarea:focus+label,.fi textarea:not(:placeholder-shown)+label{
  top:-.55rem;font-size:.65rem;color:var(--chrome);
}
.hp-field{position:absolute;left:-9999px;}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.74rem;color:var(--dim);line-height:1.6;cursor:pointer;}
.consent input{margin-top:.2rem;accent-color:var(--chrome3);}
.consent a{color:var(--chrome);}
.form-btn{margin-top:.4rem;}
.form-success{display:none;text-align:center;padding:2rem;color:var(--chrome2);}
.form-success svg{stroke:var(--chrome2);margin-bottom:.8rem;}
.cf.sent .form-success{display:block;}
.cf.sent .fi,.cf.sent .consent,.cf.sent .form-btn{display:none;}

/* ═══ FOOTER ═══ */
footer{background:var(--bg);border-top:1px solid rgba(106,138,170,.1);padding:3.2rem 8vw 2.4rem;}
.foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.6rem;max-width:1200px;margin:0 auto;}
.flogo{font-family:'Cinzel',serif;letter-spacing:.22em;color:var(--chrome2);font-size:.95rem;}
.flogo span{color:var(--dim);}
.fsub{color:var(--dim2);font-size:.72rem;letter-spacing:.2em;margin-top:.4rem;}
.flinks{display:flex;gap:2rem;}
.flinks a{color:var(--dim);text-decoration:none;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;transition:color .3s;}
.flinks a:hover{color:var(--chrome2);}
.fcopy{width:100%;text-align:center;color:var(--dim2);font-size:.7rem;letter-spacing:.12em;margin-top:1.4rem;}

/* ═══ BREADCRUMB BACK ═══ */
.back-portal{
  position:fixed;bottom:1.6rem;right:1.6rem;z-index:150;
  display:flex;align-items:center;gap:.6rem;
  background:rgba(2,13,30,.7);backdrop-filter:blur(12px);
  border:1px solid rgba(106,138,170,.25);color:var(--dim);
  padding:.7rem 1.2rem;text-decoration:none;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  transition:all .35s;
}
.back-portal:hover{color:var(--chrome2);border-color:var(--chrome3);box-shadow:0 0 22px rgba(160,200,240,.15);}

/* ═══ RESPONSIVE ═══ */
@media(max-width:880px){
  .nl{
    position:fixed;inset:0;background:rgba(1,9,18,.97);backdrop-filter:blur(20px);
    flex-direction:column;align-items:center;justify-content:center;gap:2.4rem;
    opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;z-index:250;
  }
  .nl.open{opacity:1;visibility:visible;}
  .nl a{font-size:1rem;}
  .nav-mobile{display:flex;}
  .nav-mobile.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  .nav-mobile.open span:nth-child(2){opacity:0;}
  .nav-mobile.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
  .lang-toggle{margin-left:auto;margin-right:1rem;}
  .cg{grid-template-columns:1fr;gap:3rem;}
  .scene-ov{padding:0 4vw;align-items:flex-end;padding-bottom:9vh;}
  .scene-panel,.scene-panel.abs{
    position:absolute;left:4vw;right:4vw;bottom:8vh;
    width:auto;max-width:none;margin:0;
  }
  .scene-panel h2{font-size:clamp(1.15rem,4.6vw,1.6rem);margin:.7rem 0;}
  .scene-panel .lead{
    font-size:.8rem;line-height:1.65;
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  }
  .scene-panel .glass{padding:1.1rem 1.25rem;background:rgba(2,13,30,.72);}
  .lbl .lp2{font-size:.95rem;}
  .lbl .lk{font-size:.52rem;}
  .lbl .ll2{height:30px;}
  .scroll-hint{bottom:.8rem;font-size:.55rem;gap:.45rem;}
  .scroll-hint .sb{height:22px;}
  .svc{padding:5.5rem 6vw;}
}
/* Sehr niedrige Fenster: Text darf die Szene nie verdecken */
@media(max-height:560px){
  .scene-panel .lead{display:none;}
  .scene-panel h2{font-size:1.05rem;margin:.5rem 0;}
  .scene-panel .glass{padding:.9rem 1.1rem;}
  .scroll-hint{display:none;}
}
