/* PROFIX – KOMPONENTEN */

/* SECTION LABELS */
.sec-label { display:inline-block; font-size:.68rem; font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--red); margin-bottom:.6rem; }
.sec-title  { font-family:var(--font-display); font-size:clamp(2.2rem,5vw,3.8rem); letter-spacing:2px; line-height:1; color:#fff; margin-bottom:.8rem; }
.sec-desc   { color:var(--gray); font-size:.95rem; line-height:1.75; max-width:500px; }

/* BUTTONS */
.btn-p {
  background:var(--red); color:#fff;
  padding:.82rem 1.8rem;
  font-family:var(--font-condensed); font-size:.95rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  border-radius:var(--radius); border:none; cursor:pointer;
  transition:var(--transition); box-shadow:var(--shadow-red); display:inline-block;
}
.btn-p:hover { background:var(--red-dark); transform:translateY(-2px); box-shadow:0 8px 28px var(--red-glow); }

.btn-s {
  background:transparent; color:#fff;
  padding:.82rem 1.8rem;
  font-family:var(--font-condensed); font-size:.95rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  border-radius:var(--radius); border:1px solid rgba(255,255,255,.18);
  transition:var(--transition); display:inline-block; cursor:pointer;
}
.btn-s:hover { border-color:var(--red); color:var(--red); }

.btn-white { background:#fff; color:var(--red); padding:.82rem 1.8rem; font-family:var(--font-condensed); font-size:.95rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; border-radius:var(--radius); transition:var(--transition); display:inline-block; }
.btn-white:hover { background:rgba(255,255,255,.88); }

/* DER NEUE RIESEN-BUTTON FÜR DEN CTA UNTEN */
.btn-white-huge {
  background:#fff; color:var(--red);
  padding: 1.2rem 2.5rem;
  font-family:var(--font-condensed); font-size: 1.2rem; font-weight:800; letter-spacing:2px; text-transform:uppercase;
  border-radius:var(--radius-md); transition:var(--transition); display:inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
  text-decoration: none;
}
.btn-white-huge:hover { background:var(--light); transform:translateY(-3px); box-shadow: 0 15px 40px rgba(0,0,0,0.25); }

.btn-outline-white { background:transparent; color:#fff; padding:.82rem 1.8rem; font-family:var(--font-condensed); font-size:.95rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; border-radius:var(--radius); border:2px solid rgba(255,255,255,.6); transition:var(--transition); display:inline-block; }
.btn-outline-white:hover { border-color:#fff; background:rgba(255,255,255,.1); }

/* HERO BADGE */
.hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(224,26,26,.12); border:1px solid rgba(224,26,26,.35);
  padding:.32rem .9rem; border-radius:var(--radius);
  font-size:.7rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--red);
  margin-bottom:1.4rem; animation:fadeUp .5s ease both;
}
.badge-dot { width:6px; height:6px; background:var(--red); border-radius:50%; animation:pulse 1.5s infinite; flex-shrink:0; }

.hero-title { font-family:var(--font-display); font-size:clamp(3.5rem,8.5vw,7rem); line-height:.9; letter-spacing:3px; color:#fff; animation:fadeUp .5s .08s ease both; }
.hero-title .r { color:var(--red); }
.hero-title .b { color:var(--blue); } 
.hero-title .o { -webkit-text-stroke:1px rgba(255,255,255,.22); color:transparent; }
.hero-sub  { font-family:var(--font-condensed); font-size:clamp(.95rem,2.2vw,1.4rem); font-weight:700; letter-spacing:4px; text-transform:uppercase; color:var(--gray); margin:.5rem 0 1.2rem; animation:fadeUp .5s .14s ease both; }
.hero-desc { color:#aaa; font-size:.95rem; line-height:1.75; max-width:440px; margin-bottom:1.2rem; animation:fadeUp .5s .2s ease both; }
.hero-note { background:rgba(255,255,255,.04); border-left:3px solid var(--red); padding:.5rem .9rem; font-size:.8rem; color:#aaa; margin-bottom:1.6rem; border-radius:0 var(--radius) var(--radius) 0; line-height:1.65; animation:fadeUp .5s .26s ease both; }
.hero-btns { display:flex; gap:.9rem; flex-wrap:wrap; animation:fadeUp .5s .32s ease both; }

/* SERVICES (Modernisiert) */
#services { background:var(--dark); }
.svc-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:3rem; flex-wrap:wrap; gap:1rem; }
.svc-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:25px; }
.svc-card { background:var(--dark2); padding:2.5rem 2rem; border-radius:var(--radius-md); border:1px solid var(--border); position:relative; overflow:hidden; transition:var(--transition); box-shadow: 0 4px 20px rgba(0,0,0,0.2); }
.svc-card::after { content:''; position:absolute; bottom:0; left:0; width:0; height:3px; background:var(--red); transition:width .35s; }
.svc-card:hover { background:var(--dark3); border-color:var(--border-red); transform:translateY(-6px); box-shadow: 0 10px 30px rgba(0,0,0,0.4); }
.svc-card:hover::after { width:100%; }
.svc-icon { font-size:2.2rem; margin-bottom:1.2rem; }
.svc-name { font-family:var(--font-condensed); font-size:1.3rem; font-weight:800; letter-spacing:1px; text-transform:uppercase; color:#fff; margin-bottom:.6rem; }
.svc-text { color:var(--gray); font-size:.88rem; line-height:1.65; }
.svc-tag  { display:inline-block; margin-top:1rem; font-size:.65rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--red); font-weight:700; background:rgba(224,26,26,.1); padding:.3rem .7rem; border-radius:4px; }

/* HINWEIS */
#hinweis { background:var(--black); }
.hinweis-box { background:rgba(224,26,26,.06); border:1px solid rgba(224,26,26,.2); border-left:4px solid var(--red); padding:1.8rem 2rem; border-radius:var(--radius-md); display:flex; gap:1.2rem; align-items:flex-start; max-width:820px; }
.h-icon  { font-size:1.8rem; flex-shrink:0; }
.h-title { font-family:var(--font-condensed); font-size:1.05rem; font-weight:800; letter-spacing:1px; text-transform:uppercase; color:var(--red); margin-bottom:.4rem; }
.h-text  { color:#aaa; font-size:.88rem; line-height:1.75; }
.h-text strong { color:#ddd; }

/* TEAM (Modernisiert) */
#team { background:var(--dark); }
.team-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:25px; margin-top:2.5rem; }
.tcard { background:var(--dark2); border:1px solid var(--border); padding:2.5rem 2rem; text-align:center; transition:var(--transition); border-radius:var(--radius-md); box-shadow: 0 4px 20px rgba(0,0,0,0.2); display:flex; flex-direction:column; align-items:center; }
.tcard-info { display:contents; }
.tcard:hover { border-color:var(--border-red); transform:translateY(-6px); box-shadow: 0 10px 30px rgba(0,0,0,0.4); }
.tavatar { width:70px; height:70px; background:linear-gradient(135deg, var(--red-dark), var(--red)); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:1.6rem; color:#fff; margin:0 auto 1.2rem; box-shadow:0 4px 18px var(--red-glow); }
.tname  { font-family:var(--font-condensed); font-size:1.2rem; font-weight:800; text-transform:uppercase; letter-spacing:1px; color:#fff; margin-bottom:.3rem; }
.trole  { color:var(--gray); font-size:.75rem; text-transform:uppercase; letter-spacing:1.2px; margin-bottom:.8rem; }
.tphone { display:inline-flex; align-items:center; gap:.5rem; color:var(--red); font-weight:700; font-size:1rem; transition:opacity .2s; }
.tphone:hover { opacity:.7; }

/* STANDORT */
#standort { background:var(--black); }

/* FAQ */
#faq { background:var(--black); }
.faq-list { margin-top:2.5rem; display:flex; flex-direction:column; gap:.8rem; max-width:820px; }
.faq-item { background:var(--dark2); border:1px solid var(--border); border-radius:var(--radius-md); overflow:hidden; transition:border-color .2s; }
.faq-item.open { border-color:var(--border-red); }
.faq-q { display:flex; justify-content:space-between; align-items:center; padding:1.2rem 1.5rem; cursor:pointer; font-family:var(--font-condensed); font-size:1.05rem; font-weight:700; color:#fff; transition:color .2s; user-select:none; gap:1rem; }
.faq-item.open .faq-q { color:var(--red); }
.faq-icon { width:24px; height:24px; border-radius:50%; background:var(--dark3); display:flex; align-items:center; justify-content:center; color:var(--red); font-size:.9rem; flex-shrink:0; transition:transform .3s, background .2s; }
.faq-item.open .faq-icon { transform:rotate(45deg); background:var(--red); color:#fff; }
.faq-a { max-height:0; overflow:hidden; transition:max-height .35s ease, padding .3s ease; padding:0 1.5rem; color:var(--gray-light); font-size:.92rem; line-height:1.75; }
.faq-item.open .faq-a { max-height:250px; padding:0 1.5rem 1.2rem; }

/* FORMULARE */
#termin { background:var(--dark); }
.form-wrap { display:grid; grid-template-columns:1fr 1.2fr; gap:4rem; align-items:start; }
.form-info-contact { display:flex; flex-direction:column; gap:1rem; margin-top:1.8rem; }
.fic-item  { display:flex; align-items:flex-start; gap:.8rem; }
.fic-icon  { font-size:1.2rem; flex-shrink:0; margin-top:.1rem; }
.fic-label { font-size:.65rem; text-transform:uppercase; letter-spacing:1px; color:var(--gray); margin-bottom:.15rem; }
.fic-val   { color:#ddd; font-size:.88rem; }
.fic-val a { color:var(--red); }

.profix-form  { display:flex; flex-direction:column; gap:1.1rem; }
.form-row     { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group   { display:flex; flex-direction:column; gap:.35rem; }
.form-group label { font-size:.72rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:#ccc; }
.req { color:var(--red); margin-left:2px; }
.form-group input,
.form-group select,
.form-group textarea { background:var(--dark3); border:1px solid var(--border); color:#fff; padding:.8rem 1rem; border-radius:var(--radius-md); font-size:.95rem; transition:border-color .2s, box-shadow .2s; outline:none; width:100%; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--red); box-shadow:0 0 0 3px rgba(224,26,26,.1); }
.form-group select option { background:var(--dark3); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-submit { background:var(--red); color:#fff; padding:1rem 2.5rem; font-family:var(--font-condensed); font-size:1.05rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; border:none; border-radius:var(--radius-md); cursor:pointer; transition:var(--transition); box-shadow:var(--shadow-red); align-self:flex-start; }
.form-submit:hover { background:var(--red-dark); transform:translateY(-2px); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.form-msg { padding:.8rem 1.2rem; border-radius:var(--radius-md); font-size:.9rem; font-weight:600; display:none; }
.form-msg.success { background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.3); color:#4ade80; display:block; }
.form-msg.error   { background:rgba(224,26,26,.1); border:1px solid rgba(224,26,26,.3); color:#f87171; display:block; }
.form-check { display:flex; align-items:flex-start; gap:.6rem; cursor:pointer; }
.form-check input[type=checkbox] { width:18px; height:18px; accent-color:var(--red); flex-shrink:0; margin-top:2px; cursor:pointer; }
.form-check span { color:#999; font-size:.85rem; line-height:1.55; }
.form-check a { color:var(--red); }

/* NAV TEXT LOGO */
.nav-logo-text { font-family: var(--font-display); font-size: 1.7rem; letter-spacing: 2px; color: #fff; }
.nav-logo-text span { color: var(--red); }

/* ── HERO RECHTS ── */
.hero-right {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 45vw;
  animation: fadeIn 1s .3s ease both;
}

.hero-logo-wrap {
  position: relative;
  width: 100%;
  text-align: center;
}

.logo-backglow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 75%;
  height: 75%;
  background: var(--blue);
  filter: blur(120px);
  opacity: 0.12;
  border-radius: 50%;
  z-index: -1;
}

.hero-logo-img { 
  width: 100%; 
  max-width: 520px; 
  height: auto; 
  display: block; 
  margin: 0 auto;
  filter: drop-shadow(0 0 40px rgba(0, 0, 0, 0.7)) drop-shadow(0 0 20px rgba(224,26,26,0.15));
  position: relative;
  z-index: 2;
}

.hero-logo-text {
  color: var(--gray-light);
  font-size: 0.95rem;
  line-height: 1.8;
  margin: 2.5rem auto 0 auto;
  font-family: var(--font-body);
  letter-spacing: 0.8px;
  max-width: 80%; 
  font-style: italic; 
  position: relative;
}

.hero-logo-text::before {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--blue);
  margin: 0 auto 1.2rem auto;
  opacity: 0.8;
}

@media (max-width: 960px) {
  .hero-right { display: none; }
  .hero-inner { justify-content: center; }
  .hero-watermark { font-size: clamp(6rem, 15vw, 10rem); }
}

/* --- GOOGLE & INSTAGRAM INTEGRATION --- */
#bewertungen { background: var(--dark); }
#instagram { background: var(--black); }

.google-widget-placeholder { margin-top: 2.5rem; max-width: 600px; }
.mock-google-review { background: var(--dark2); border: 1px solid var(--border); border-left: 4px solid #4285F4; padding: 2rem; border-radius: var(--radius-md); }

.insta-widget-placeholder { margin-top: 2.5rem; }
.insta-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.insta-post { width: 100%; aspect-ratio: 1 / 1; background-size: cover; background-position: center; border-radius: var(--radius-md); transition: transform 0.3s; cursor: pointer; border: 1px solid var(--border); }
.insta-post:hover { transform: scale(1.03); box-shadow: var(--shadow-dark); border-color: var(--border-red); }

@media (max-width: 768px) {
  .insta-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── BEWERTUNGEN GRID ── */
.bewertungen-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.bcard { background:var(--dark2); border:1px solid var(--border); padding:1.8rem; border-radius:var(--radius-md); transition:var(--transition); position:relative; }
.bcard:hover { border-color:var(--border-red); transform:translateY(-3px); box-shadow:var(--shadow-dark); }
.bcard::before { content:'"'; position:absolute; top:.8rem; right:1.2rem; font-size:3.5rem; font-family:Georgia,serif; color:var(--red); opacity:.2; line-height:1; }
.bstars { color:#f59e0b; font-size:1rem; margin-bottom:.7rem; letter-spacing:2px; }
.btext  { color:#ccc; font-size:.88rem; line-height:1.7; margin-bottom:.9rem; font-style:italic; }
.bname  { font-family:var(--font-condensed); font-size:.88rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--red); }
.bdate  { color:var(--gray); font-size:.72rem; margin-top:.15rem; }

/* ── INSTAGRAM CTA BLOCK ── */
.insta-cta-block { margin-top:2.5rem; }
.insta-cta-inner {
  display:flex;
  align-items:center;
  gap:2rem;
  background:var(--dark2);
  border:1px solid var(--border);
  border-left:4px solid #e1306c;
  padding:2rem 2.5rem;
  border-radius:var(--radius-md);
  flex-wrap:wrap;
}
.insta-icon-wrap { width:64px; height:64px; background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:1.8rem; flex-shrink:0; }
.insta-icon { line-height:1; }
.insta-cta-text { flex:1; min-width:200px; }
.insta-handle { font-family:var(--font-condensed); font-size:1.4rem; font-weight:800; letter-spacing:1px; color:#fff; margin-bottom:.4rem; }
.insta-cta-text p { color:var(--gray); font-size:.88rem; line-height:1.6; margin:0; }
.insta-btn { flex-shrink:0; }

@media (max-width:768px) {
  .bewertungen-grid { grid-template-columns:1fr; }
  .insta-cta-inner { flex-direction:column; text-align:center; padding:1.5rem; }
  .insta-btn { width:100%; text-align:center; }
}


/* ── MOBILE LOGO IM HERO ── */
.hero-logo-mobile {
  display: none; /* nur Mobile */
  width: 200px;
  margin: 1.4rem auto 0;
}
.hero-logo-mobile-img {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 0 20px rgba(0,0,0,0.7));
}

@media (max-width: 960px) {
  .hero-logo-mobile { display: block; }
}
@media (max-width: 480px) {
  .hero-logo-mobile { width: 170px; }
}
