@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:300;
  font-display:swap;
  src:url("../fonts/SpaceGrotesk-Light.woff2") format("woff2");
}
@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:400;
  font-display:swap;
  src:url("../fonts/SpaceGrotesk-Regular.woff2") format("woff2");
}
@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:500;
  font-display:swap;
  src:url("../fonts/SpaceGrotesk-Medium.woff2") format("woff2");
}
@font-face{
  font-family:"Space Grotesk";
  font-style:normal;
  font-weight:700;
  font-display:swap;
  src:url("../fonts/SpaceGrotesk-Bold.woff2") format("woff2");
}

/* ===== Reset / Base ===== */
*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html, body{
  min-height:100%;
  width:100%;
  margin:0;
  padding:0;
  overflow-x:hidden;
  overflow-y:auto;
  font-family:"Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background:#0b0b0b;
  color:#ffffff;
}

/* Links */
a{
  color:#d0d0d0;
  text-decoration:underline;
  transition:color 0.2s;
}
a:hover, a:focus{
  color:#ffffff;
}

/* ===== Layout ===== */
.wrapper{
  min-height:100vh;
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:20px;
  position:relative;
  z-index:1;
}

/* Particles */
#particles-js{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  width:100%;
  height:100vh;
  z-index:0;
  pointer-events:none;
}

/* ===== Animations ===== */
@keyframes gradient{
  0%{ background-position:0% 50%; }
  50%{ background-position:100% 50%; }
  100%{ background-position:0% 50%; }
}
@keyframes float{
  0%{ transform:translateY(0px); }
  50%{ transform:translateY(-10px); }
  100%{ transform:translateY(0px); }
}

/* ===== Card / Holder ===== */
.holder{
  background:rgba(255, 255, 255, 0.05);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-radius:24px;
  padding:44px 34px 34px 34px;
  box-shadow:0 8px 32px rgba(0, 0, 0, 0.15);
  display:flex;
  flex-direction:column;
  align-items:center;
  max-width:800px;
  width:100%;
  color:white;
  position:relative;
  border:1px solid rgba(255, 255, 255, 0.1);
  animation:float 6s ease-in-out infinite;
}

.holder::before{
  content:'';
  position:absolute;
  top:-2px;
  left:-2px;
  right:-2px;
  bottom:-2px;
  background:linear-gradient(45deg, rgba(255,255,255,0.12), rgba(200,200,200,0.06), rgba(255,255,255,0.12));
  border-radius:24px;
  z-index:-1;
  animation:gradient 14s ease infinite;
  background-size:200% 200%;
  filter:blur(12px);
  opacity:0.45;
}

/* Avatar */
.circle{
  width:140px;
  height:140px;
  border-radius:50%;
  position:relative;
  margin-bottom:12px;
  display:flex;
  justify-content:center;
  align-items:center;
  overflow:hidden;
}

.circle::before{
  content:'';
  position:absolute;
  inset:-2px;
  background:linear-gradient(45deg, rgba(255,255,255,0.95), rgba(200,200,200,0.9));
  border-radius:50%;
  animation:gradient 12s ease infinite;
  background-size:200% 200%;
}

.circle::after{
  content:'';
  position:absolute;
  inset:2px;
  background:#0a0a12;
  border-radius:50%;
  z-index:0;
}

.circle img{
  width:calc(100% - 6px);
  height:calc(100% - 6px);
  object-fit:cover;
  border-radius:50%;
  position:relative;
  z-index:1;
  pointer-events:none;
  user-select:none;
}

/* Title */
.holder h1{
  font-size:clamp(2.1rem, 6vw, 2.7rem);
  margin:6px 0 10px 0;
  text-align:center;
  letter-spacing:2px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0.2em;
  word-break:keep-all;
  flex-wrap:wrap;
}

.tag{
  font-size:0.45em;
  padding:0.3em 0.6em;
  margin-left:0.4em;
  vertical-align:middle;
  border:1px solid rgba(255, 255, 255, 0.15);
  border-radius:6px;
  background:rgba(255, 255, 255, 0.06);
  color:#fff;
  font-weight:600;
  letter-spacing:0.05em;
  backdrop-filter:blur(4px);
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  transition:all 0.3s ease;
}
.tag:hover{
  background:rgba(255, 255, 255, 0.1);
  border-color:rgba(255, 255, 255, 0.25);
}

/* Profile info */
.profile-info{
  margin:0 0 24px 0;
  font-size:1.08rem;
  text-align:center;
  color:rgba(255, 255, 255, 0.9);
  line-height:1.8;
}
.profile-info i{
  color:#d0d0d0;
  margin-right:6px;
  font-size:0.9em;
}

/* About & projects */
.about-text{
  margin-bottom:16px;
  text-align:center;
  font-size:1.06rem;
  color:#fff;
  width:100%;
}

.about-text h3{
  margin-bottom:16px;
  font-size:1.2rem;
  color:#e6e6e6;
  letter-spacing:1px;
  width:100%;
}

.projects-container{
  display:flex;
  gap:24px;
  justify-content:center;
  flex-wrap:wrap;
  width:100%;
  margin:0 auto;
}

.project-item{
  background:rgba(255, 255, 255, 0.03);
  border-radius:12px;
  padding:20px;
  border:1px solid rgba(255, 255, 255, 0.05);
  transition:all 0.3s ease;
  flex:1 1 calc(50% - 12px);
  min-width:280px;
  max-width:calc(50% - 12px);
  word-break:break-word;
}

.project-item:hover{
  background:rgba(255, 255, 255, 0.05);
  transform:translateY(-2px);
}

.project-item strong{
  color:#f5f5f5;
  font-size:1.1rem;
  display:block;
  margin-bottom:8px;
  line-height:1.3;
  hyphens:auto;
}

.project-item p{
  color:rgba(255, 255, 255, 0.8);
  font-size:0.95rem;
  margin-bottom:12px;
  line-height:1.5;
}

/* Social buttons */
.social-buttons{
  margin:32px 0 0 0;
  display:flex;
  justify-content:center;
  gap:18px;
  align-items:center;
}

.social-buttons a{
  --size:56px;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:var(--size);
  height:var(--size);
  border-radius:50%;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  color:#fff;
  font-size:1.45em;
  transition:transform 0.28s cubic-bezier(.2,.9,.2,1), box-shadow 0.28s, filter 0.28s;
  text-decoration:none;
  position:relative;
  overflow:visible;
  border:1px solid rgba(255,255,255,0.06);
  backdrop-filter:blur(4px);
}

/* animated gradient ring */
.social-buttons a::before{
  content:'';
  position:absolute;
  inset:-3px;
  background:linear-gradient(45deg, rgba(255,255,255,0.95), rgba(200,200,200,0.9));
  border-radius:50%;
  z-index:0;
  filter:blur(10px);
  opacity:0.45;
  transform:scale(0.98);
  transition:transform 0.5s ease, opacity 0.35s ease;
  background-size:200% 200%;
  pointer-events:none;
}

/* inner glass sheen */
.social-buttons a::after{
  content:'';
  position:absolute;
  inset:2px;
  border-radius:50%;
  background:linear-gradient(180deg, rgba(255,255,255,0.05), transparent 40%);
  z-index:1;
  mix-blend-mode:overlay;
}

.social-buttons a i{
  position:relative;
  z-index:2;
  transition:color 0.2s ease, transform 0.2s ease;
}

.social-buttons a:hover,
.social-buttons a:focus{
  transform:translateY(-6px) scale(1.03);
  box-shadow:0 10px 30px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.03);
}

.social-buttons a:hover::before,
.social-buttons a:focus::before{
  transform:scale(1.06);
  opacity:1;
}

.social-buttons a:active{
  transform:translateY(-2px) scale(0.99);
  box-shadow:0 6px 18px rgba(0,0,0,0.25);
}

.social-buttons a:hover i,
.social-buttons a:focus i{
  color:rgba(10,10,12,0.96);
  filter:drop-shadow(0 1px 0 rgba(255,255,255,0.06));
}

.social-buttons a:focus{
  outline:3px solid rgba(162,89,230,0.18);
  outline-offset:4px;
}

/* Footer links */
.footer-links{
  margin-top:38px;
  padding-top:20px;
  border-top:1px solid rgba(255, 255, 255, 0.1);
  width:100%;
  display:flex;
  justify-content:center;
  gap:24px;
}

.impressum-button{
  font-size:0.9rem;
  color:rgba(255, 255, 255, 0.6);
  text-decoration:none;
  background:rgba(255, 255, 255, 0.03);
  padding:8px 16px;
  border-radius:20px;
  transition:all 0.3s ease;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:6px;
  border:none;
}
.impressum-button:hover{
  color:#fff;
  background:rgba(255, 255, 255, 0.08);
  transform:translateY(-1px);
}

/* Demo button */
.demo-button{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 20px;
  color:#0b0b0b;
  text-decoration:none;
  background:linear-gradient(135deg, #ffffff 0%, #d6d6d6 100%);
  border-radius:12px;
  transition:all 0.3s ease;
  border:none;
  margin-top:12px;
  font-weight:500;
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 18px rgba(0,0,0,0.35);
}
.demo-button::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:linear-gradient(135deg, rgba(255,255,255,0.08) 0%, rgba(0,0,0,0.04) 100%);
  opacity:0;
  transition:opacity 0.3s ease;
}
.demo-button:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 30px rgba(0,0,0,0.45);
}
.demo-button:hover::before{
  opacity:0.2;
}
.demo-button i{
  position:relative;
  z-index:1;
  font-size:0.9em;
}
.demo-button span{
  position:relative;
  z-index:1;
}

/* ===== Responsive ===== */
@media (max-width: 520px){
  .wrapper{ padding:16px; }
  .holder{
    padding:18px 20px 14px;
    width:100%;
    margin:0;
  }
  .circle{ width:84px; height:84px; }
  .holder h1{ font-size:clamp(1.1rem, 7vw, 1.5rem); }
  .about-text{ font-size:0.97rem; }
  .social-buttons a{
    --size:40px;
    width:var(--size);
    height:var(--size);
    font-size:1.05em;
  }
  .projects-container{ flex-direction:column; }
  .project-item{
    max-width:100%;
    margin-bottom:16px;
  }
  .project-item:last-child{ margin-bottom:0; }
}

/* ===== Scrollbar ===== */
/* Chrome, Edge, Safari */
::-webkit-scrollbar{
  width:10px;
  background:#0e0e0e;
}
::-webkit-scrollbar-thumb{
  background:#cfcfcf;
  border-radius:6px;
  border:2px solid #0e0e0e;
  min-height:30px;
  transition:background 0.2s;
}
::-webkit-scrollbar-thumb:hover{
  background:#e9e9e9;
}
::-webkit-scrollbar-corner{
  background:#0e0e0e;
}
/* Firefox */
html{
  scrollbar-width:thin;
  scrollbar-color:#cfcfcf #0e0e0e;
}

/* ===== Modal Styles (FIXED + SCROLLABLE) ===== */
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0, 0, 0, 0.7);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1000;

  opacity:0;
  visibility:hidden;
  transition:opacity 0.25s ease, visibility 0.25s ease;
  padding:18px; /* wichtig: Abstand zum Rand auf kleinen Screens */
}

.modal-overlay.show{
  opacity:1;
  visibility:visible;
}

/* Modal als Flex-Container, damit Header fix bleibt und Body scrollt */
.modal-content{
  background:rgba(30, 30, 40, 0.95);
  border-radius:20px;
  width:100%;
  max-width:600px;

  /* nie größer als Viewport */
  max-height:calc(100vh - 36px);

  display:flex;
  flex-direction:column;

  border:1px solid rgba(255, 255, 255, 0.1);
  box-shadow:0 15px 40px rgba(0, 0, 0, 0.3);

  transform:translateY(-12px);
  transition:transform 0.25s ease;
  overflow:hidden; /* rundungen sauber */
}

.modal-overlay.show .modal-content{
  transform:translateY(0);
}

.modal-header{
  padding:20px 25px;
  border-bottom:1px solid rgba(255, 255, 255, 0.1);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex:0 0 auto;
}

.modal-header h2{
  color:#fff;
  font-size:1.5rem;
  font-weight:600;
  margin:0;
}

.modal-close{
  background:none;
  border:none;
  color:rgba(255, 255, 255, 0.6);
  font-size:1.2rem;
  cursor:pointer;
  padding:5px;
  transition:all 0.3s ease;
  width:32px;
  height:32px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
}

.modal-close:hover{
  background:rgba(255, 255, 255, 0.1);
  color:#fff;
  transform:rotate(90deg);
}

/* HIER ist der Scroll-Container */
.modal-body{
  padding:25px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  flex:1 1 auto;
  overscroll-behavior:contain;
}

.impressum-section{
  margin-bottom:25px;
}
.impressum-section:last-child{
  margin-bottom:0;
}
.impressum-section h3{
  color:#e6e6e6;
  font-size:1.1rem;
  margin-bottom:15px;
  display:flex;
  align-items:center;
  gap:10px;
}
.impressum-section h3 i{
  font-size:0.9em;
  opacity:0.9;
}
.impressum-section p{
  color:rgba(255, 255, 255, 0.8);
  margin:8px 0;
  font-size:1rem;
  line-height:1.5;
}

@media (max-width: 520px){
  .modal-overlay{
    padding:12px;
  }
  .modal-content{
    max-height:calc(100vh - 24px);
    border-radius:18px;
  }
  .modal-header{
    padding:15px 20px;
  }
  .modal-body{
    padding:20px;
  }
  .impressum-section h3{
    font-size:1rem;
  }
  .impressum-section p{
    font-size:0.95rem;
  }
}

/* SweetAlert2 overrides to match monochrome theme */
.swal2-popup{
  background:linear-gradient(180deg, #0f0f12 0%, #18181a 100%) !important;
  color:#eaeaea !important;
  border:1px solid rgba(255,255,255,0.06) !important;
  box-shadow:0 12px 40px rgba(0,0,0,0.6) !important;
}
.swal2-title{ color:#ffffff !important; }
.swal2-content{ color:#dcdcdc !important; }
.swal2-actions .swal2-confirm,
.swal2-actions .swal2-cancel{
  background:#e6e6e6 !important;
  color:#0b0b0b !important;
  border:none !important;
  box-shadow:none !important;
}
.swal2-actions .swal2-cancel{
  background:transparent !important;
  color:#dcdcdc !important;
  border:1px solid rgba(255,255,255,0.06) !important;
}
.swal2-popup .swal2-icon{
  filter:none !important;
}
.swal2-popup button:focus{
  outline:3px solid rgba(255,255,255,0.08) !important;
  outline-offset:3px !important;
}

/* Small / Disclaimer box */
.small{
  font-size:0.88rem;
  line-height:1.6;
  color:rgba(255,255,255,.76);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  padding:10px 12px;
  border-radius:12px;
}
