.elementor-8450 .elementor-element.elementor-element-17cd8fc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:-25px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}@media(max-width:767px){.elementor-8450 .elementor-element.elementor-element-292c8f4 > .elementor-widget-container{margin:-12px -12px -12px -12px;}}/* Start custom CSS for container, class: .elementor-element-17cd8fc *//* ============================ Infokredit Look & Feel – Vars ============================ */
  :root {
    --ik-blue:#004881;
    --ik-blue-dark:#0b3a64;
    --ik-blue-50:#e6eff6;
    --ik-green:#2a8700;
    --ik-green-dark:#1f6d00;
  }

  /* Reset & Grundstruktur */
  .loan-calculator * { margin:0; padding:0; box-sizing:border-box; }
  .loan-calculator {
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    padding:5px; border-radius:24px; max-width:600px; margin:0 auto;
  }
  .calculator-container {
    background:#fff; border-radius:24px; box-shadow:0 20px 60px rgba(0,0,0,.3);
    padding:40px; max-width:600px; margin:0 auto;
  }
  .calculator-header { text-align:center; margin-bottom:35px; }
  .calculator-header h1 {
    font-size:28px; font-weight:700; margin-bottom:8px;
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  }
  .calculator-header p { color:#718096; font-size:15px; }

  .input-group { margin-bottom:32px; position:relative; }
  .input-label { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
  .input-label label { font-size:14px; font-weight:600; color:#2d3748; display:flex; align-items:center; gap:8px; }

  /* Info-Icon */
  .info-icon {
    position:relative; display:inline-flex; align-items:center; justify-content:center;
    width:22px; height:22px; border-radius:50%;
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    color:#fff; font-style:normal; font-weight:900; font-size:13px; line-height:1;
    cursor:help; box-shadow:0 2px 8px rgba(0,72,129,.35); user-select:none;
  }
  .info-icon:hover { filter:brightness(1.05); }
  @media (min-width:769px){
    .info-icon:hover::after{
      content:attr(data-tooltip); position:absolute; top:100%; left:50%; transform:translateX(-50%);
      margin-top:8px; padding:10px 14px; background:var(--ik-blue-dark); color:#fff; border-radius:8px;
      font-size:12px; font-weight:400; white-space:normal; width:240px; text-align:center; z-index:10000;
      box-shadow:0 4px 12px rgba(0,0,0,.3); line-height:1.5; border:1px solid rgba(255,255,255,.12);
    }
    .info-icon:hover::before{
      content:''; position:absolute; top:100%; left:50%; transform:translateX(-50%);
      margin-top:2px; border:6px solid transparent; border-bottom-color:var(--ik-blue-dark);
    }
  }

  /* Mobile Tooltip */
  .info-tooltip-mobile {
    position:fixed; background:linear-gradient(135deg,var(--ik-blue-dark) 0%,var(--ik-blue) 100%);
    color:#fff; padding:14px 18px; border-radius:10px; font-size:12px; max-width:280px;
    box-shadow:0 8px 24px rgba(0,72,129,.5); z-index:10000; opacity:0; pointer-events:none; transition:opacity .3s;
    line-height:1.6; border:1px solid rgba(255,255,255,.1); left:50%; transform:translateX(-50%);
  }
  .info-tooltip-mobile.show { opacity:1; pointer-events:auto; }

  /* Rechner-Selects */
  .dropdown-container { position:relative; margin-top:8px; }
  .loan-dropdown {
    width:100%; padding:18px 24px; text-align:center; text-align-last:center; -webkit-text-align-last:center;
    font-size:28px; font-weight:800; color:#0b3a64; border:3px solid var(--ik-blue); border-radius:12px;
    background:linear-gradient(135deg,#f7fafc 0%,var(--ik-blue-50) 100%); cursor:pointer; transition:all .3s;
    appearance:none; -webkit-appearance:none; -moz-appearance:none;
    background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23004881' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat:no-repeat; background-position:right 20px center; background-size:24px; padding-right:50px;
    white-space:nowrap; box-shadow:0 4px 12px rgba(44,82,130,.15);
  }
  .loan-dropdown option { text-align:center; background:#fff; color:#1a365d; font-size:16px; }
  .loan-dropdown:hover {
    border-color:var(--ik-blue-dark);
    background:linear-gradient(135deg,var(--ik-blue-50) 0%,#e2e8f0 100%);
    box-shadow:0 6px 16px rgba(0,72,129,.25); transform:translateY(-2px);
  }
  .loan-dropdown:focus {
    outline:none; border-color:var(--ik-blue-dark); box-shadow:0 0 0 4px rgba(0,72,129,.2);
    background:linear-gradient(135deg,#edf2f7 0%,#e2e8f0 100%);
  }

  .result-card {
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    border-radius:20px; padding:32px; text-align:center; margin:32px 0; position:relative; overflow:hidden;
    box-shadow:0 8px 32px rgba(0,72,129,.4);
  }
  .result-card::before{
    content:''; position:absolute; top:-50%; right:-50%; width:200%; height:200%;
    background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);
    animation:pulse 3s ease-in-out infinite;
  }
  .result-card::after{
    content:''; position:absolute; bottom:0; left:0; right:0; height:100px;
    background:linear-gradient(to top,rgba(0,0,0,.1),transparent);
  }
  @keyframes pulse {
    0%,100%{ transform:scale(1) rotate(0deg); opacity:.5; }
    50%{ transform:scale(1.1) rotate(180deg); opacity:.3; }
  }
  .result-label {
    color:rgba(255,255,255,.95); font-weight:800; text-transform:uppercase; letter-spacing:.06em;
    margin-bottom:12px; font-size:clamp(12px,3.2vw,14px);
  }
  .result-value {
    color:#fff; font-weight:900; margin-bottom:8px; position:relative; z-index:1;
    text-shadow:0 4px 12px rgba(0,0,0,.2); letter-spacing:-.02em; white-space:nowrap;
    font-size:clamp(28px,6.5vw,48px);
  }
  @media (max-width:768px){ .result-value{ font-size:clamp(22px,8vw,34px); } }

  /* CTA oben */
  #ik-loan-calculator .cta-button {
    width:100%; padding:18px;
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    color:#fff; border:2px solid transparent; border-radius:14px;
    font-size:28px !important; font-weight:800; cursor:pointer; transition:all .25s ease;
    box-shadow:0 6px 20px rgba(0,72,129,.25); text-transform:uppercase; letter-spacing:1px;
    margin-top:2px; position:relative; overflow:hidden; white-space:normal; line-height:1.25;
  }
  #ik-loan-calculator .cta-button::before{
    content:''; position:absolute; top:50%; left:50%; width:0; height:0; border-radius:50%;
    background:rgba(255,255,255,.18); transform:translate(-50%,-50%); transition:width .4s,height .4s;
  }
  #ik-loan-calculator .cta-button:hover::before{ width:280px; height:280px; }
  #ik-loan-calculator .cta-button:hover{
    background:transparent; color:var(--ik-blue-dark); border-color:var(--ik-blue);
    transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,72,129,.35);
  }
  #ik-loan-calculator .cta-button:focus{ outline:none; box-shadow:0 0 0 4px rgba(0,72,129,.25); }
  #ik-loan-calculator .cta-button.hidden{ display:none !important; visibility:hidden; pointer-events:none; }

  .disclaimer { text-align:center; font-size:11px; color:#718096; margin-top:20px; line-height:1.6; font-weight:500; }

  @media (max-width:768px){
    .calculator-container{ padding:30px 20px; }
    .calculator-header h1{ font-size:24px; }
    .calculator-header p { font-size:14px; }
    .loan-dropdown{ font-size:20px; padding:16px 20px; padding-right:45px; background-size:20px; }
    #ik-loan-calculator .cta-button{ font-size:24px !important; }
  }

  /* Formular (versteckt) */
  #bf-ka-container { display:none; opacity:0; transition:opacity .4s ease-in-out; margin-top:40px; }
  #bf-ka-container.show { display:block; opacity:1; }

  .bf-section-header { text-align:center; margin:40px 0 30px; padding-top:40px; border-top:2px solid var(--ik-blue-50); }
  .bf-section-header h2 {
    font-size:26px; font-weight:700;
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:8px;
  }
  .bf-section-header p { color:#718096; font-size:14px; }

  .bf-field { margin-bottom:24px; }
  .bf-label { display:flex; align-items:center; gap:8px; font-size:14px; font-weight:600; color:#2d3748; margin-bottom:10px; }
  .bf-input,.bf-select {
    width:100%; padding:14px 18px; font-size:16px; border:2px solid #e2e8f0; border-radius:10px;
    background:#f7fafc; color:#2d3748; transition:all .3s; font-family:inherit;
  }
  .bf-input:focus,.bf-select:focus{ outline:none; border-color:var(--ik-blue); background:#fff; box-shadow:0 0 0 3px rgba(0,72,129,.1); }
  .bf-input.bf-error,.bf-select.bf-error{ border-color:#e53e3e; background:#fff5f5; }
  .bf-input.bf-disabled{ background:#edf2f7; color:#718096; cursor:not-allowed; }

  /* Grids */
  .bf-dob{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; }
  .bf-address-row{ display:grid; grid-template-columns:85% 15%; gap:10px; }
  .bf-plz-ort-row{ display:grid; grid-template-columns:30% 70%; gap:10px; }
  .bf-residence-row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
  .bf-phone-row{ display:grid; grid-template-columns:100px 1fr; gap:10px; }

  @media (max-width:768px){
    .bf-dob{ grid-template-columns:1fr 1fr 1fr !important; }
    .bf-address-row{ grid-template-columns:85% 15% !important; }
    .bf-plz-ort-row{ grid-template-columns:30% 70% !important; }
    .bf-residence-row{ grid-template-columns:1fr 1fr !important; }
    .bf-phone-row{ grid-template-columns:100px 1fr !important; }
  }

  /* Hausnummer kompakt */
  #ka_nr,#ka_old_nr{ font-size:14px !important; padding:10px 12px !important; }

  /* Country select */
  .bf-country-select {
    display:flex; align-items:center; gap:8px; padding:14px 12px; font-size:16px; border:2px solid #e2e8f0;
    border-radius:10px; background:#f7fafc; color:#2d3748; cursor:pointer; transition:all .3s;
  }
  .bf-country-select:focus{ outline:none; border-color:var(--ik-blue); background:#fff; box-shadow:0 0 0 3px rgba(0,72,129,.1); }

  /* Alte Adresse */
  .bf-old-address-section{ display:none; margin-top:30px; padding-top:30px; border-top:2px solid var(--ik-blue-50); }
  .bf-old-address-section.show{ display:block; }
  .bf-old-address-header{ font-size:18px; font-weight:700; color:#0b3a64; margin-bottom:20px; }

  /* Checkboxen */
  .bf-checkbox-field{ background:#f5f7fa; border:1px solid #e5e7eb; border-radius:12px; padding:14px; margin-bottom:14px; }
  .bf-checkbox-field + .bf-checkbox-field{ margin-top:12px; }
  .bf-checkbox-label{
    display:flex; align-items:flex-start; gap:12px; cursor:pointer; font-size:13px; line-height:1.6; color:#2d3748;
    text-align:left; flex-wrap:wrap; min-width:0;
  }
  .bf-checkbox-input{ margin-top:3px; width:20px; height:20px; cursor:pointer; flex-shrink:0; }
  .bf-checkbox-input.bf-error{ outline:2px solid #e53e3e; }
  .bf-checkbox-text{ flex:1 1 auto; min-width:0; word-break:break-word; overflow-wrap:anywhere; hyphens:auto; }
  .bf-checkbox-text a{ color:var(--ik-blue); text-decoration:underline; font-weight:600; }
  .bf-checkbox-text a:hover{ color:var(--ik-blue-dark); }

  /* Aktionen / Submit-Button */
  .bf-actions{ margin-top:20px; display:flex; flex-direction:column; gap:12px; }
  .bf-btn{
    width:100%; padding:22px 28px;
    background:linear-gradient(135deg,var(--ik-blue) 0%,var(--ik-blue-dark) 100%);
    color:#fff; border:none; border-radius:14px; font-size:17px; font-weight:800; cursor:pointer;
    transition:all .35s cubic-bezier(0.4,0,0.2,1); box-shadow:0 8px 24px rgba(0,72,129,.35);
    text-transform:none; letter-spacing:.3px; position:relative; overflow:hidden; display:flex;
    align-items:center; justify-content:center; gap:12px; flex-wrap:wrap; white-space:normal; line-height:1.25; text-align:center;
  }
  .bf-btn::before{
    content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent); transition:left .5s;
  }
  .bf-btn:hover::before{ left:100%; }
  .bf-btn:hover{ transform:translateY(-3px) scale(1.02); box-shadow:0 12px 32px rgba(0,72,129,.45); }
  .bf-btn:active{ transform:translateY(-1px) scale(1.01); }
  .bf-btn:disabled{
    background:linear-gradient(135deg,#a0aec0 0%,#718096 100%); cursor:not-allowed; transform:none; box-shadow:0 4px 12px rgba(0,0,0,.1);
  }
  .bf-btn-text-desktop{ flex:1 1 auto; white-space:normal; }
  .bf-btn-arrow{ display:inline-block; font-size:22px; font-weight:900; transition:transform .35s; flex:0 0 auto; }
  @media (max-width:480px){
    .bf-btn{ padding:18px 16px; }
    .bf-btn-arrow{ font-size:20px; margin-left:6px; }
  }

  .bf-msg{ text-align:center; font-size:13px; font-weight:600; padding:10px; border-radius:8px; }
  .bf-muted{ color:#718096; }
  .bf-ok{ color:#2f855a; background:#f0fff4; border:1px solid #9ae6b4; }
  .bf-err{ color:#c53030; background:#fff5f5; border:1px solid #fc8181; }

  /* ============================ MODAL / POPUP ============================ */
  .ik-modal{ display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:99999; }
  .ik-modal.is-open{ display:block; }
  .ik-modal__dialog{
    position:relative; width:min(760px,92vw); margin:6vh auto; background:#fff; border-radius:16px;
    box-shadow:0 20px 60px rgba(0,0,0,.35); max-height:88vh; display:flex; flex-direction:column; overflow:hidden;
  }
  .ik-modal__header{ position:sticky; top:0; background:#fff; border-bottom:1px solid #e5e7eb; padding:14px 56px 14px 18px; }
  .ik-modal__title{ font-size:18px; font-weight:800; color:#0b3a64; margin:0; }
  .ik-modal__close{
    position:absolute; top:10px; right:10px; width:36px; height:36px; border-radius:8px; border:1px solid #e5e7eb;
    background:#ffffff; color:#1f2937; display:flex; align-items:center; justify-content:center; cursor:pointer;
    opacity:1; transition:background .2s,color .2s,transform .1s;
  }
  .ik-modal__close:hover{ background:#f3f4f6; color:#0b3a64; }
  .ik-modal__close:active{ transform:scale(.98); }
  .ik-modal__body{ padding:18px; overflow:auto; }
  .ik-legal-frame{ width:100%; height:72vh; border:0; border-radius:8px; background:#fff; }
  .ik-legal-loader{ display:block; text-align:center; font-size:14px; color:#374151; padding:8px 0 12px; }
  .ik-legal-loader.is-hidden{ display:none; }
  .ik-legal-fallback{ margin-top:10px; font-size:12px; color:#6b7280; }
  .ik-legal-fallback a{ color:#004881; text-decoration:underline; }
  body.ik-no-scroll{ overflow:hidden; }

  /* ========= Zusätzliche Layouts: Einkommen, Kinder ========= */
  .bf-income-row{ display:grid; grid-template-columns:1fr auto; gap:10px; align-items:center; }
  .bf-income-radios{ display:flex; flex-direction:column; align-items:flex-end; gap:8px; min-width:110px; }
  .bf-income-caption{ font-size:12px; color:#4a5568; font-weight:600; text-transform:uppercase; letter-spacing:.02em; }
  .bf-income-radio-row{ display:flex; gap:10px; }
  .bf-radio{ display:flex; align-items:center; gap:6px; padding:10px 12px; border:1px solid #e5e7eb; border-radius:10px; background:#f7fafc; }
  .bf-radio input{ width:18px; height:18px; }
  .bf-job-row{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
  .bf-yn-row{ display:flex; gap:10px; }
  .bf-yn{ display:flex; align-items:center; gap:8px; padding:10px 14px; border:1px solid #e5e7eb; border-radius:10px; background:#f7fafc; }
  .bf-yn input{ width:18px; height:18px; }
  .bf-more-income-row{ display:grid; grid-template-columns:1fr 140px; gap:10px; align-items:center; }
  .bf-mini-select{ padding:12px 14px; font-size:15px; }
  .partner-wrap{ border-top:2px solid var(--ik-blue-50); padding-top:24px; margin-top:16px; }

  /* Income Cards */
  .bf-card{
    background:linear-gradient(180deg,#f8fafc 0%,#eef5fb 100%);
    border:1px solid #e5e7eb; border-left:4px solid var(--ik-blue); border-radius:16px; padding:16px;
    box-shadow:0 6px 14px rgba(0,72,129,.06); margin:12px 0 24px;
  }
  .bf-card--income .bf-field{ margin-bottom:16px; }

  /* MODAL FIX */
  .ik-modal__body{ position:relative; }
  .ik-modal__header{ position:sticky; top:0; z-index:2; }
  .ik-modal__close{ z-index:3; }
  .ik-legal-frame{ position:relative; z-index:1; }

  @media (max-width:768px){
    .ik-modal__title{ display:none; }
    .ik-modal__header{ padding-right:54px; }
    .ik-modal__close{ width:44px; height:44px; top:8px; right:8px; }
  }/* End custom CSS */