
    /* ====== THEME ====== */
    :root {
      --emk-bg: #0c0f13;
      --emk-card: rgba(16, 20, 26, 0.7);
      --emk-card-solid: #141922;
      --emk-text: #e8edf5;
      --emk-sub: #aab6c7;
      --emk-gold: #d6b46b;   /* Elif gold accent */
      --emk-gold-2: #f3d496;
      --emk-teal: #1f3a44;   /* deep teal shadow */
      --emk-accent: #88e0d9; /* soft highlight */
      --emk-error: #ff6b6b;
      --emk-ok: #4cd79a;
      --emk-radius: 18px;
      --emk-shadow-3d: 0 20px 60px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.04);
      --emk-shadow-hover: 0 30px 80px rgba(0,0,0,0.5);
    }

    #kontakt-pro {
      color: var(--emk-text);
      background:
        radial-gradient(1200px 600px at 10% -10%, rgba(214,180,107,0.08), transparent 60%),
        radial-gradient(1000px 600px at 110% 10%, rgba(136,224,217,0.06), transparent 60%),
        linear-gradient(180deg, #0b0f14, #0b0f14 100%);
      padding: clamp(22px, 4vw, 48px) 0;
      overflow: clip;
      perspective: 1000px;
    }

    .emk-container { width: min(1100px, 92vw); margin: 0 auto; }

    .emk-head {
      display: grid; gap: 10px; margin-bottom: 22px; text-align: center;
    }
    .emk-head h1 { font-size: clamp(28px, 3.6vw, 46px); letter-spacing: .3px; }
    .emk-head p { color: var(--emk-sub); font-size: clamp(14px, 1.7vw, 16px); }

    /* ====== CARD WRAPPER (glass / 3D) ====== */
    .emk-card {
      position: relative; border-radius: var(--emk-radius);
      background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
      box-shadow: var(--emk-shadow-3d);
      border: 1px solid rgba(255,255,255,0.08);
      overflow: hidden; transform-style: preserve-3d;
      will-change: transform;
    }
    .emk-card::before, .emk-card::after {
      content: ""; position: absolute; inset: -1px; pointer-events: none; border-radius: inherit;
    }
    /* Animated gradient border */
    .emk-card::before {
      background: conic-gradient(from 180deg,
        rgba(214,180,107,0.0), rgba(214,180,107,0.35) 20%, rgba(136,224,217,0.35) 55%, rgba(214,180,107,0.35) 80%, rgba(214,180,107,0.0));
      mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor; mask-composite: exclude;
      padding: 1px; filter: blur(0.2px); opacity: .5; animation: spin 12s linear infinite;
    }
    @keyframes spin { to { transform: rotate(1turn); } }

    .emk-grid {
      display: grid; gap: 22px; grid-template-columns: 1fr; align-items: start;
    }
    @media (min-width: 900px) {
      .emk-grid { grid-template-columns: 1.1fr .9fr; }
    }

    .emk-form { padding: clamp(18px, 3.5vw, 32px); }
    .emk-side { padding: clamp(18px, 3.5vw, 28px); background: var(--emk-card-solid); }

    /* ====== INPUTS (floating labels) ====== */
    .row { display: grid; grid-template-columns: 1fr; gap: 14px; }
    @media (min-width: 680px) { .row.two { grid-template-columns: 1fr 1fr; } }

    .field { position: relative; }
    .field input, .field select, .field textarea {
      width: 100%; background: #0f141c; min-height: 56px; box-sizing: border-box; color: var(--emk-text);
      border: 1px solid rgba(255,255,255,0.08); border-radius: 14px;
      padding: 16px 16px 16px 16px; font: 500 15px/1.25 system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial;
      outline: none; transition: border-color .2s ease, box-shadow .2s ease, transform .12s ease;
    }
    .field textarea { min-height: 110px; resize: vertical; }

    .field label {
      position: absolute; left: 12px; top: 50%; translate: 0 -50%; padding: 0 6px;
      font-size: 14px; color: var(--emk-sub); background: #0f141c;
      pointer-events: none; transition: all .18s ease;
    }
    
    .field:has(textarea) label {
  top: 80px;
  translate: 0 0;
  font-size: 14px;
  transition: all .18s ease;
}
.field:has(textarea:focus, textarea:not(:placeholder-shown)) label {
  top: 0;
  translate: 0 -50%;
  font-size: 12px;
  color: var(--emk-gold);
}
.field textarea::placeholder {
  color: var(--emk-sub);
  opacity: 0.7;
}

    .field.focused label, .field.filled label { top: 0; translate: 0 -50%; font-size: 12px; color: var(--emk-gold); }
    .field:has(input:focus, textarea:focus, select:focus) input,
    .field:has(input:focus, textarea:focus, select:focus) textarea,
    .field:has(input:focus, textarea:focus, select:focus) select {
      border-color: rgba(214,180,107,0.6);
      box-shadow: 0 0 0 6px rgba(214,180,107,0.08);
    }
    

    /* ====== PRODUCT CHIPS (3D hover tilt) ====== */
    .products {
      display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin: 4px 0 2px;
    }
    @media (min-width: 580px) { .products { grid-template-columns: repeat(3, 1fr); } }

    .prod {
      --tilt: 0; position: relative; display: grid; place-items: center; text-align: center;
      background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
      border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; padding: 16px 12px; cursor: pointer; touch-action: manipulation;
      transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
      box-shadow: var(--emk-shadow-3d);
      transform: perspective(600px) rotateX(calc(var(--rx, 0) * 1deg)) rotateY(calc(var(--ry, 0) * 1deg)) translateY(0);
    }
    .prod:hover { box-shadow: var(--emk-shadow-hover); border-color: rgba(214,180,107,0.5); }
    .prod input { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; touch-action: auto; z-index: 1; }
    .prod span { font-weight: 600; letter-spacing: .2px; pointer-events: none; }
    .prod.active { background: linear-gradient(180deg, rgba(214,180,107,0.18), rgba(214,180,107,0.08)); border-color: var(--emk-gold); }
    .prod:active {
      transform: scale(0.97);
      filter: brightness(1.1);
    }
    /* subtle 3D shine */
    .prod::after {
      content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
      background: radial-gradient(600px 100px at var(--mx, 50%) -10%, rgba(255,255,255,0.18), transparent 40%);
      opacity: 0; transition: opacity .2s ease;
    }
    .prod:hover::after { opacity: .9; }

    /* ====== CHECKS / CONSENT ====== */
    .checks { display: grid; gap: 10px; margin-top: 6px; }
    .check {
      display: grid; grid-template-columns: 22px 1fr; gap: 10px; align-items: start; font-size: 14px; color: var(--emk-sub);
    }
    .check input { accent-color: var(--emk-gold); translate: 0 3px; }

    /* ====== SUBMIT BUTTON ====== */
    .actions { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
    .btn {
      position: relative; border: 0; border-radius: 14px; padding: 14px 18px; font-weight: 700; letter-spacing: .3px; cursor: pointer;
      color: #0b0f14; background: linear-gradient(135deg, var(--emk-gold), var(--emk-gold-2));
      box-shadow: 0 8px 30px rgba(214,180,107,0.35);
      transition: transform .12s ease, box-shadow .2s ease, filter .2s ease;
    }
    .btn:hover { transform: translateY(-1px); box-shadow: 0 12px 40px rgba(214,180,107,0.45); }
    .btn:active { transform: translateY(0); filter: brightness(.98); }
    .hint { color: var(--emk-sub); font-size: 12px; }

    /* ====== SIDE PANE ====== */
    .emk-side h3 { margin: 0 0 8px; font-size: 18px; }
    .emk-side p { margin: 0 0 12px; color: var(--emk-sub); font-size: 14px; }
    .emk-steps { display: grid; gap: 12px; }
    .step { display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: start; }
    .bullet {
      width: 28px; height: 28px; display: grid; place-items: center; border-radius: 50%;
      background: radial-gradient(180px 80px at 50% -10%, rgba(214,180,107,0.45), rgba(214,180,107,0.18));
      box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2);
      color: #0b0f14; font-weight: 800;
    }

    /* ====== TOAST ====== */
    .toast {
      position: fixed; left: 50%; bottom: 24px; translate: -50% 120%; z-index: 9999;
      background: #0f141c; border: 1px solid rgba(255,255,255,0.12); color: var(--emk-text);
      padding: 12px 16px; border-radius: 12px; box-shadow: var(--emk-shadow-3d);
      display: flex; gap: 10px; align-items: center; min-width: min(90vw, 420px);
      transition: translate .28s ease;
    }
    .toast.show { translate: -50% 0; }
    .toast .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--emk-ok); box-shadow: 0 0 18px rgba(76,215,154,.6); }

    /* ====== A11Y ERR ====== */
    .err { border-color: rgba(255,107,107,.7) !important; box-shadow: 0 0 0 6px rgba(255,107,107,.12) !important; }
    .err-text { color: var(--emk-error); font-size: 12px; margin-top: -6px; }

    /* ====== SMALL PRINT ====== */
    .smallprint { font-size: 12px; color: var(--emk-sub); margin-top: 8px; }

  /* Mobile: gleiche Abstände für alle Eingabefelder */
@media (max-width: 679px) {
  .row,
  .row.two {
    display: grid;
    grid-template-columns: 1fr; /* alles untereinander */
    gap: 1px;                  /* überall exakt derselbe Abstand */
  }

  /* gleiche Höhe & Padding für Inputs, Selects und Textareas */
  .field input,
  .field select,
  .field textarea {
    padding: 16px;
    font-size: 15px;
    line-height: 1.4;
  }
}

/* Spezifische Anpassungen für Mobilgeräte */
@media (max-width: 768px) {
  .prod {
    min-height: 50px; /* Stelle sicher, dass die Box groß genug für Touch ist (falls nötig) */
    touch-action: manipulation; /* Behalte es hier für die Box, aber nicht für das Input */
  }
  .prod input {
    touch-action: auto; /* Erlaube normale Touch-Events für das Input */
  }
    .field select {
    height: 56px; /* Erzwinge gleiche Höhe wie Inputs */
    -webkit-appearance: none; /* Entferne native Pfeil-Icons, die Höhe beeinflussen könnten */
    -moz-appearance: none;
    appearance: none;
    background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6,9 12,15 18,9"></polyline></svg>'); /* Optional: Eigener Dropdown-Pfeil */
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 16px;
    padding-right: 40px; /* Platz für den Pfeil */
  }
  .field:has(textarea) label {
    top: 70px; /* Tiefer auf Mobil */
  }
}