.navbar{background-color:#000;color:#fff;font-family:sans-serif;left:0;position:fixed;top:0;width:100%;z-index:1000}.navbar-header{justify-content:space-between;padding:8px 18px}.navbar-header,.navbar-logo{align-items:center;display:flex}.navbar-logo{cursor:pointer;gap:8px}.logo-img{border-radius:5px;height:auto;width:60px}.logo-text{color:#fff;font-family:Arial,sans-serif;font-size:22px;font-weight:600}.hamburger-menu{cursor:pointer;display:flex;flex-direction:column;gap:5px}.hamburger-menu div{background-color:#fff;height:3px;transition:transform .3s,opacity .3s;width:25px}.hamburger-menu.open div:first-child{transform:translateY(7px) rotate(45deg)}.hamburger-menu.open div:nth-child(2){opacity:0}.hamburger-menu.open div:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar-menu{align-items:center;display:none;gap:20px;list-style:none}.navbar-menu li{display:inline-block;margin-left:16px}.navbar-menu li a{color:#fff;font-size:1.1rem;padding:8px 12px;text-decoration:none}.navbar-menu li a:hover{background:#333;border-radius:4px}.navbar-menu li a.active{border-bottom:2px solid orange;font-weight:600}.navbar-menu li select{border:none;border-radius:4px;font-size:1rem;padding:4px 8px}.mobile-menu{display:none}.mobile-menu ul{list-style:none;margin:0;padding:0}.mobile-menu.open{background-color:#000;display:block;height:100%;left:0;overflow-y:auto;padding-top:80px;position:fixed;top:0;width:100%;z-index:9999}.mobile-menu ul li{border-bottom:1px solid #333}.mobile-menu ul li a,.mobile-menu ul li select{background:none;border:none;color:#fff;display:block;font-size:1.2rem;outline:none;padding:16px 20px;text-decoration:none;width:100%}.mobile-menu ul li a:hover{background-color:#222}.mobile-menu ul li select{background-color:#fff;color:#000;font-size:1rem;margin:8px 0}@media (min-width:768px){.hamburger-menu{display:none}.navbar-menu{display:flex}.mobile-menu{display:none!important}}.loan-overview{background-color:#fff;color:#333;font-family:Poppins,sans-serif;padding:20px}.loan-overview h2{color:#333;font-size:24px;font-weight:600;margin-bottom:20px}.filter-input{border:1px solid #e0e0e0;color:#333;font-size:14px;margin-bottom:20px;padding:12px;transition:border-color .3s,box-shadow .3s;width:100%}.filter-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.sort-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.sort-controls label{color:#333;font-weight:500;margin-right:5px}.sort-controls select{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;padding:8px 12px;transition:border-color .3s,box-shadow .3s}.sort-controls select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.loan-card{background-color:#fff;border:1px solid #e0e0e0;border-radius:14px;box-shadow:0 2px 6px #0000001a;margin-bottom:20px;padding:20px;transition:transform .3s,box-shadow .3s}.loan-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.loan-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.loan-card-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.loan-remaining-time{background:#f8f9fa;border-radius:20px;color:#666;font-size:14px;padding:4px 12px}.progress-bar-container{background:#e9fdf0;border-radius:4px;height:8px;margin:10px 0;overflow:hidden;width:100%}.progress{background:linear-gradient(90deg,#27ae60,#2ecc71);height:8px;transition:width .3s ease}.loan-card-row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:19px;margin-top:15px}.loan-card-item{display:flex;flex-direction:column;gap:4px;min-width:150px}.loan-card-item label{color:#666;font-size:13px;font-weight:500}.loan-card-item span{color:#333;font-size:15px;font-weight:600}.no-data-message{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;color:#333;margin-bottom:20px;padding:16px}.no-data-message h3{color:#333;font-size:18px;margin-bottom:8px;margin-top:0}.no-data-message p{color:#555;margin-bottom:12px}.no-data-message ul{color:#555;list-style:disc;margin-left:20px}.no-data-message li{margin-bottom:6px}.no-data-message a{color:#007bff;text-decoration:none}.no-data-message a:hover{text-decoration:underline}@media (max-width:768px){.loan-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #e0e0e0;border-radius:14px;box-shadow:0 2px 6px #0000001a;color:#333;margin-bottom:20px;padding:20px;transition:transform .3s,box-shadow .3s}.loan-card:hover{box-shadow:0 8px 16px #0000001a,0 0 6px #27ae604d;transform:translateY(-2px)}.loan-card-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.loan-remaining-time{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:20px;color:#666;font-size:14px;padding:6px 14px}.progress-bar-container{background:#e9fdf0;border-radius:4px;box-shadow:inset 0 0 4px #27ae6033;height:8px;margin:10px 0;overflow:hidden;width:100%}.progress{background:linear-gradient(90deg,#27ae60,#2ecc71);height:8px;transition:width .3s ease}.loan-card-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:15px}.loan-card-item label{color:#666;font-size:13px;font-weight:500}.loan-card-item span{color:#333;font-size:15px;font-weight:600}.sort-controls{align-items:stretch;flex-direction:column;gap:10px}.sort-controls select{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;padding:8px 12px;transition:border-color .3s,box-shadow .3s}.sort-controls select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}}*{box-sizing:border-box;margin:0;padding:0}body,html{font-family:Poppins,sans-serif;height:100%;width:100%}.dashboard-container,body,html{background-color:#fff;color:#333}.dashboard-container{margin-left:auto;margin-right:auto;margin-top:80px;max-width:1400px;min-height:100vh;padding:40px;position:relative}.dashboard-container h1{color:#000;font-size:36px;font-weight:700;margin-bottom:30px;text-align:left}.view-buttons{display:flex;gap:16px;justify-content:flex-end;margin-bottom:30px}.view-button{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:24px;color:#333;cursor:pointer;font-size:14px;padding:12px 20px;transition:background .3s,box-shadow .3s,transform .3s}.view-button:hover{background:#000;color:#fff;transform:translateY(-2px)}.view-button.active{background:#000;border-color:#000;box-shadow:0 0 8px #0003;color:#fff}section h2{color:#000;font-size:24px;margin-bottom:16px;margin-top:30px;text-align:left}.overview-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:36px;margin-top:20px}.overview-card{background:#fff;border:1px solid #e0e0e0;border-radius:14px;box-shadow:0 2px 6px #0000001a;padding:20px;text-align:left;transition:transform .3s,box-shadow .3s}.overview-card:hover{box-shadow:0 8px 16px #0003;transform:translateY(-5px)}.overview-card h3{color:#333;font-size:16px;font-weight:500;margin-bottom:6px}.overview-card p{color:#000;font-size:24px;font-weight:700;margin:0}.card{background:#fff;border:1px solid #e0e0e0;border-radius:14px;box-shadow:0 2px 6px #0000001a;display:flex;flex-direction:column;margin-bottom:24px;padding:20px;transition:transform .3s,box-shadow .3s}.card:hover{box-shadow:0 8px 16px #0003;transform:translateY(-5px)}.card h2{color:#000;font-size:20px;font-weight:600;margin-bottom:10px}.card p{color:#333}.charts-container{align-items:stretch;display:flex;flex-wrap:wrap;gap:24px;margin-top:20px}.chart-left{flex:3 1;min-width:300px}.chart-right{flex:1 1;min-width:300px}.chart-wrapper{flex:1 1;min-height:300px}.property-value-card{align-items:center;background:#fff;border-radius:14px;display:flex;flex:1 1;flex-direction:column;gap:20px;padding:24px}.value-comparison{align-items:center;display:flex;flex-direction:column;gap:16px;margin-top:16px;width:100%}.value-box{background:#f8f9fa;border-radius:12px;padding:16px;position:relative;text-align:center;transition:transform .3s;width:100%}.value-box:hover{transform:translateY(-3px)}.value-box.purchase{border:2px solid #e9ecef}.value-box.current{background:#f8fff9;border:2px solid #28a745}.value-label{color:#6c757d;font-size:14px;margin-bottom:8px}.value-amount{color:#212529;font-size:24px;font-weight:700;margin-bottom:4px}.value-date{color:#6c757d;font-size:13px}.value-change{gap:8px;margin:12px 0;padding:8px;width:100%}.change-arrow,.value-change{align-items:center;display:flex;justify-content:center}.change-arrow{background:#28a745;border-radius:50%;color:#fff;font-size:20px;height:40px;width:40px}.change-percentage{background:#e9f7ec;border-radius:20px;color:#28a745;font-size:16px;font-weight:600;padding:4px 12px}.cashflow-chart{background:#fff;border:1px solid #e0e0e0;border-radius:14px;box-shadow:0 2px 6px #0000001a;padding:20px}select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;outline:none;padding:8px 12px;transition:border-color .3s,box-shadow .3s}select:focus{border-color:#000;box-shadow:0 0 0 2px #0000001a}label{color:#333;font-size:14px;font-weight:500;margin-right:8px}.mobile-dashboard-container{background-color:#fafafa;font-family:Inter,system-ui,-apple-system,sans-serif;margin-top:80px;min-height:100vh;padding:24px 20px}@media (min-width:768px){.mobile-dashboard-container{display:none}}.mobile-view-buttons{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(90deg,#ffffffb3,#ffffffe6);border-radius:16px;box-shadow:0 2px 20px #0000000d;display:flex;flex-wrap:nowrap;gap:12px;justify-content:center;margin:0 auto 32px;max-width:90%;overflow:hidden;padding:8px 12px;position:relative}.mobile-view-buttons:after,.mobile-view-buttons:before{content:none!important}.mobile-view-buttons button{background:none;border:none;border-radius:12px;color:#555;cursor:pointer;font-size:14px;font-weight:600;margin:0;overflow:hidden;padding:8px 16px;position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.mobile-view-buttons button:hover{background-color:#0000000d;color:#000}.mobile-view-buttons button.active{background-color:#000;box-shadow:0 2px 8px #00000026;color:#fff}.mobile-view-buttons button.active:after{content:none!important}.mobile-section{margin-bottom:3rem}.mobile-section+.mobile-section{margin-top:2rem}.mobile-section h2{color:#111;font-size:24px;font-weight:700;letter-spacing:-.5px;margin-bottom:24px}.mobile-overview-cards{grid-column-gap:16px;grid-row-gap:16px;column-gap:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-bottom:24px;row-gap:16px}.mobile-overview-card.bw-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ffffffe6,#ffffffb3);border-radius:16px;box-shadow:0 4px 24px #0000000a,inset 0 0 0 1px #ffffff80;overflow:hidden;padding:16px;position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.mobile-overview-card.bw-card:hover{box-shadow:0 8px 32px #00000014,inset 0 0 0 1px #fff9;transform:translateY(-4px)}.mobile-overview-card .title{word-wrap:break-word;color:#666;font-size:13px;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.mobile-overview-card .value{color:#000;font-size:20px;font-weight:700;letter-spacing:-.5px}.mobile-overview-cards>.mobile-overview-card:first-child{background:linear-gradient(135deg,#000,#222)!important;grid-column:span 2}.mobile-overview-cards>.mobile-overview-card:first-child .title{color:#ffffffb3!important}.mobile-overview-cards>.mobile-overview-card:first-child .value{color:#fff!important}.mobile-card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #0000000f;margin-bottom:24px;padding:20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.mobile-card:hover{box-shadow:0 8px 32px #00000014;transform:translateY(-4px)}.mobile-card.mobile-property-value-card{grid-gap:8px;align-items:center;border:none;border-radius:12px;box-shadow:0 2px 6px #0000001a;display:grid;gap:8px;grid-template-columns:1fr auto 1fr;margin-bottom:32px;padding:8px}.mobile-card.mobile-property-value-card h3{color:#111;font-size:14px;font-weight:600;grid-column:1/-1;margin-bottom:6px;text-align:center}.mobile-card.mobile-property-value-card .mobile-value-box{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000f;padding:6px;text-align:center}.mobile-card.mobile-property-value-card .mobile-value-box.current{border:1px solid #000}.mobile-card.mobile-property-value-card .mobile-value-box .value-label{color:#777;font-size:10px;text-transform:uppercase}.mobile-card.mobile-property-value-card .mobile-value-box .value-amount{color:#000;font-size:16px;font-weight:600;margin:4px 0}.mobile-card.mobile-property-value-card .mobile-value-box .value-date{color:#999;font-size:10px}.mobile-card.mobile-property-value-card .value-change{align-items:center;display:flex;justify-content:center}.mobile-card.mobile-property-value-card .value-change .change-percentage{background:#daf5dc;border-radius:12px;color:#10890b;display:inline-block;font-size:12px;font-weight:600;margin-right:4px;padding:4px 8px}.mobile-card.mobile-property-value-card .value-change .change-arrow{display:none}.property-selector{margin-bottom:24px}.property-selector select{background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 2px 8px #0000000a;color:#000;cursor:pointer;font-size:14px;padding:10px 16px;transition:all .3s ease}.property-selector select:hover{border-color:#000;box-shadow:0 4px 12px #00000014}@media (max-width:375px){.mobile-overview-cards{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.mobile-overview-card .title{word-wrap:break-word;font-size:13px;letter-spacing:normal;white-space:normal}.mobile-overview-card .value{font-size:20px}}.properties-container{background-color:#f9fafb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;margin:6rem auto 0;max-width:1400px;padding:2rem}.properties-container h1{color:#333;font-size:2rem;font-weight:600;margin-bottom:2rem;text-align:center}.view-mode-buttons{display:flex;gap:1rem;justify-content:flex-end;margin-bottom:2rem}.view-mode-buttons button{background-color:#e5e7eb;border:none;border-radius:.5rem;box-shadow:0 2px 4px #0000001a;color:#4b5563;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s ease}.view-mode-buttons button.active{background-color:#000;box-shadow:0 4px 6px #0003;color:#fff}.view-mode-buttons button:hover{background-color:#d1d5db}.view-mode-buttons button:active{transform:scale(.95)}@media (max-width:640px){.view-mode-buttons{justify-content:center}}.search-bar{border:1px solid #e5e7eb;border-radius:.5rem;font-size:1rem;margin-bottom:2rem;outline:none;padding:.75rem 1rem;width:100%}.search-bar:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.properties-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.property-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:1rem;transition:all .2s ease}.property-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.card-header h3{color:#111827;font-size:1.25rem;font-weight:600;margin:0}.status{border-radius:1rem;font-size:.875rem;font-weight:500;padding:.25rem .75rem}.status.vermietet{background-color:#ecfdf5;color:#047857}.status.freistehend{background-color:#fef2f2;color:#dc2626}.address{color:#4b5563;font-size:1rem;margin:0 0 .25rem}.city{margin:0 0 1rem}.city,.type{color:#6b7280;font-size:.875rem}.type{margin:.5rem 0}.property-details{grid-gap:1rem;border-bottom:1px solid #e5e7eb;border-top:1px solid #e5e7eb;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin:.75rem 0;padding:.75rem 0}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item span{color:#6b7280;font-size:.875rem}.detail-item strong{color:#111827;font-size:1rem}.tenant-info{display:flex;flex-direction:column;gap:.25rem;padding-top:1rem}.tenant-info span{color:#6b7280;font-size:.875rem}.tenant-info strong{color:#111827;font-size:1rem}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:7rem 1rem;position:fixed;right:0;top:0;z-index:50}@media (max-width:640px){.modal-overlay{padding:14rem 2rem 10rem}}.modal-content{background:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-height:80vh;max-width:1000px;overflow-y:auto;padding:1.5rem;position:relative;scrollbar-color:#cbd5e1 #f1f5f9;scrollbar-width:thin;width:120%}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:4px}.close-button{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.75rem;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:background-color .2s ease}.close-button:hover{background-color:#f3f4f6;border-radius:50%;color:#111827}.modal-header{border-bottom:1px solid #e5e7eb;margin-bottom:.5rem;padding-bottom:.5rem}.modal-header h2{color:#111827;font-size:1.75rem;font-weight:600;margin:0}.modal-header .address,.modal-header .city{color:#6b7280;font-size:1rem;margin:.25rem 0}.modal-body{padding:.5rem 0}.modal-section{margin-bottom:.75rem}.modal-section h3{color:#111827;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}@media (min-width:641px){.modal-body .details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.modal-body .detail-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:.75rem;transition:transform .2s ease}.modal-body .detail-item:hover{transform:translateY(-2px)}}@media (max-width:640px){.modal-content{border-radius:.5rem;margin:1rem;padding:1rem}.modal-header{border-bottom:none;margin-bottom:1rem;text-align:center}.modal-header h2{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.modal-header .address,.modal-header .city{color:#6b7280;font-size:.875rem;margin-bottom:.25rem}.modal-body{padding:0}.modal-section{border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.modal-section:last-of-type{border-bottom:none;margin-bottom:0}.modal-section h3{color:#111827;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.details-grid{display:flex;flex-direction:column;gap:.75rem}.details-grid .detail-item{background-color:#f9fafb;border-radius:.5rem;padding:.75rem}.details-grid .detail-item strong{color:#111827;font-size:1rem}.details-grid .detail-item span{color:#6b7280;font-size:.875rem}.modal-footer{margin-top:1rem;text-align:center}.close-button{font-size:1.5rem;padding:.25rem .5rem;right:.75rem;top:.75rem}}.modal-footer{margin-top:1rem;text-align:right}.contract-button-small{background-color:#121314;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s ease,transform .2s ease}.contract-button-small:hover{background-color:#312f2f}.contract-button-small:active{transform:scale(.98)}.contact-container{font-family:Arial,sans-serif;margin-top:4rem;padding:20px}.contact-container h1{color:#333;font-size:36px;margin-bottom:15px}.contact-container p{color:#666;margin-bottom:20px}.contact-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.contact-card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;text-align:center;transition:transform .3s,box-shadow .3s}.contact-card h3{color:#333;font-size:20px;margin-bottom:10px}.contact-card p{color:#555;font-size:14px;margin:5px 0}.contact-card button{background-color:#000;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:10px 15px;transition:background .3s,transform .2s}.contact-card button:hover{background-color:#333;transform:translateY(-2px)}.contact-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-5px)}.office-hours{background:#f9f9f9;border:1px solid #ddd;border-radius:8px;margin-top:40px;padding:20px;text-align:left}.office-hours h3{color:#333;font-size:18px;margin-bottom:10px}.office-hours p{color:#555;font-size:14px;margin:5px 0}.auth-container{background:#fff;display:flex;min-height:100vh}.auth-left{flex:1 1;overflow:hidden;position:relative}.auth-left:before{background:url(/static/media/logo.c3739de47d1e957d774e.jpg) no-repeat 50%;background-size:cover;filter:grayscale(100%) contrast(1.2);z-index:0}.auth-left:after,.auth-left:before{bottom:0;content:"";left:0;position:absolute;right:0;top:0}.auth-left:after{background:linear-gradient(135deg,#0009,#000000b3);z-index:1}.auth-right{align-items:center;background-color:#fff;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:2rem;position:relative}.auth-right:before{animation:pulse 15s linear infinite;background:radial-gradient(circle at center,#00000008 0,#0000 70%);content:"";height:300%;left:-100%;position:absolute;top:-100%;width:300%}@keyframes pulse{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.auth-form{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 30px #0000001a,inset 0 0 2px #0000000d;max-width:420px;padding:2.5rem;position:relative;text-align:center;width:100%;z-index:10}.auth-form h2{color:#000;font-size:2rem;font-weight:600;letter-spacing:.5px;margin-bottom:2rem;position:relative}.auth-form h2:after{background:linear-gradient(90deg,#000,#444);border-radius:3px;bottom:-10px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.auth-form input{background:#f5f5f580;border:1px solid #0000001a;border-radius:8px;box-shadow:inset 0 1px 3px #0000000d;color:#000;font-size:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem;transition:all .3s ease;width:100%}.auth-form input:focus{border-color:#000;box-shadow:0 0 0 2px #0000001a,inset 0 1px 3px #0000000d;outline:none}.auth-form input::placeholder{color:#0006}.auth-form button{background:#000;border:none;border-radius:8px;box-shadow:0 4px 15px #0003;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1.5rem;overflow:hidden;padding:1rem;position:relative;transition:transform .2s ease,box-shadow .2s ease;width:100%}.auth-form button:hover{background:#222;box-shadow:0 8px 25px #0000004d;transform:translateY(-2px)}.auth-form button:active{box-shadow:0 2px 10px #0003;transform:translateY(1px)}.auth-form button:before{background:linear-gradient(45deg,#0000,#ffffff1a,#0000);content:"";height:200%;left:-50%;position:absolute;top:-50%;transform:rotate(30deg);transition:all .6s linear;width:200%}.auth-form button:hover:before{left:100%}.auth-form .forgot-password{color:#000000b3;cursor:pointer;display:block;font-size:.875rem;margin-bottom:1.5rem;text-align:right;transition:color .2s ease}.auth-form .forgot-password:hover{color:#000}.auth-form .switch-auth{color:#000000b3;font-size:.9rem;position:relative}.auth-form .switch-auth a{color:#000;font-weight:500;position:relative;text-decoration:none;transition:all .2s ease}.auth-form .switch-auth a:hover{color:#333}.auth-form .switch-auth a:after{background:linear-gradient(90deg,#000,#444);bottom:-2px;content:"";height:1px;left:0;position:absolute;transition:width .3s ease;width:0}.auth-form .switch-auth a:hover:after{width:100%}@media (max-width:768px){.auth-container{flex-direction:column}.auth-left,.auth-right{flex:none;width:100%}.auth-left{min-height:30vh}.auth-right{min-height:70vh}.auth-form{max-width:90%;padding:2rem 1.5rem}}@keyframes glow{0%{box-shadow:0 0 5px #0000001a}50%{box-shadow:0 0 20px #0003}to{box-shadow:0 0 5px #0000001a}}.auth-form{animation:glow 5s infinite alternate}.auth-form:before{background:#0000;border:1px solid #0000000d;border-radius:18px;bottom:-2px;content:"";left:-2px;position:absolute;right:-2px;top:-2px;z-index:-1}.auth-form input:focus~label,.auth-form input:valid~label{color:#000;font-size:.75rem;transform:translateY(-20px)}.settings-container{background-color:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 8px 24px #0000001a;color:#000;font-family:Inter,Roboto,sans-serif;margin:3rem auto 30px;max-width:700px;padding:28px}.settings-title{color:#000;font-size:2.2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:2rem;position:relative;text-align:center}.settings-title:after{background:#000;border-radius:2px;content:"";display:block;height:3px;margin:8px auto 0;width:80px}.section{background-color:#fff;border:1px solid #00000014;border-radius:10px;margin-bottom:1.5rem;padding:20px;position:relative;transition:all .3s ease}.section:hover{background-color:#fafafa;box-shadow:0 5px 15px #0000000d;transform:translateY(-2px)}.section-title{align-items:center;color:#000;display:flex;font-size:1.5rem;font-weight:600;letter-spacing:-.2px;margin-bottom:1.2rem}.section-title:before{background:#000;border-radius:3px;content:"";display:inline-block;height:24px;margin-right:12px;width:4px}.upload-description{color:#333;font-size:.95rem;line-height:1.5;margin-bottom:1rem}.form{gap:1.2rem}.form,.form-group{display:flex;flex-direction:column}.form-group{position:relative}.form-group input[type=file],.form-group input[type=text],.form-group textarea{background-color:#fff;border:1px solid #0003;border-radius:8px;color:#000;font-size:1rem;outline:none;padding:12px 16px;transition:all .2s ease}.form-group input[type=file]:focus,.form-group input[type=text]:focus,.form-group textarea:focus{border-color:#000;box-shadow:0 0 0 2px #0000001a}.form-group label{color:#000;font-size:.95rem;font-weight:500;letter-spacing:.2px;margin-bottom:6px}.btn{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;letter-spacing:.3px;overflow:hidden;padding:12px 24px;position:relative;transition:all .3s ease}.btn:after{background:linear-gradient(90deg,#fff0,#ffffff1a,#fff0);content:"";height:100%;left:0;position:absolute;top:0;transform:translateX(-100%);transition:transform .6s ease;width:100%}.btn:hover:after{transform:translateX(100%)}.btn-primary{background:#000;box-shadow:0 4px 12px #0000001a}.btn-primary:hover{background:#333;box-shadow:0 6px 15px #00000026;transform:translateY(-2px)}.btn-upload{background:#000;box-shadow:0 4px 12px #0000001a}.btn-upload:hover{background:#333;box-shadow:0 6px 15px #00000026;transform:translateY(-2px)}.btn-logout{background:#000;box-shadow:0 4px 12px #0000001a}.btn-logout:hover{background:#333;box-shadow:0 6px 15px #00000026;transform:translateY(-2px)}.message{background-color:#f8f8f8;border-left:4px solid;border-radius:8px;font-size:.95rem;line-height:1.4;margin-top:.8rem;padding:1rem}.message.info{border-color:#000}.message.error{border-color:#666}.message.success{border-color:#333}.logout-section{padding-top:10px;position:relative;text-align:center}.logout-section:before{background:linear-gradient(90deg,#0000,#0003,#0000);content:"";display:block;height:1px;margin:0 auto 20px;width:100px}input[type=file]{position:relative}input[type=file]::file-selector-button{background:#000;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;margin-right:16px;padding:8px 16px;transition:all .3s ease}input[type=file]::file-selector-button:hover{background:#333}.documents-table:not(.admin) .table-header,.documents-table:not(.admin) .table-row{grid-template-columns:minmax(200px,2.5fr) minmax(140px,2fr) minmax(100px,1.5fr) minmax(100px,1fr) minmax(80px,1fr) minmax(140px,1.2fr)}.documents-table.admin .table-header,.documents-table.admin .table-row{grid-template-columns:minmax(200px,2.5fr) minmax(100px,1fr) minmax(140px,2fr) minmax(100px,1.5fr) minmax(100px,1fr) minmax(80px,1fr) minmax(120px,1.2fr)}.documents-container{background-color:#fff;border-radius:16px;box-shadow:0 8px 32px #00000014;color:#111;font-family:Inter,system-ui,-apple-system,sans-serif;margin:4rem auto 0;max-width:1200px;padding:2rem;position:relative}@media (max-width:768px){.documents-container{border-radius:0;box-shadow:none;margin-top:5rem}}.documents-container h1{color:#111;font-size:2rem;font-weight:700;margin-bottom:1.5rem;margin-right:1rem}.loading-hint{align-items:center;background:#fff;border-radius:16px;display:flex;justify-content:center;min-height:200px;overflow:hidden;position:relative}.loading-hint:before{border:3px solid #f5f5f5;border-radius:50%;border-top-color:#111;height:120px;width:120px}.loading-hint:after,.loading-hint:before{animation:pulse-ring 1.5s cubic-bezier(.215,.61,.355,1) infinite;content:"";position:absolute}.loading-hint:after{animation-delay:.3s;border:3px solid #0000;border-radius:50%;border-top-color:#666;height:80px;width:80px}@keyframes pulse-ring{0%{opacity:1;transform:rotate(0deg) scale(1)}50%{opacity:.5;transform:rotate(180deg) scale(1.1)}to{opacity:1;transform:rotate(1turn) scale(1)}}.btn-upload-docs{background-color:#222;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:.8rem;padding:.3rem .75rem;transition:background-color .2s ease}.btn-upload-docs:hover{background-color:#444}@media (min-width:768px){.btn-upload-docs{border-radius:8px;font-size:.9rem;padding:.75rem 1.2rem}}.documents-filters{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:1.5rem}.filter-input{appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg fill='none' stroke='%23666' stroke-width='2' viewBox='0 0 24 24' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:1rem;border:1px solid #e5e5e5;border-radius:8px;cursor:pointer;flex:1 1;font-size:.95rem;min-width:160px;padding:.7rem 2.5rem .7rem 1rem;transition:border-color .2s,box-shadow .2s}.filter-input:hover{border-color:#ccc}.filter-input:focus{border-color:#111;box-shadow:0 0 0 3px #00000012;outline:none}.documents-table{background-color:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 4px 16px #0000000a;margin-bottom:1.5rem;overflow:hidden;width:100%}.table-header,.table-row{grid-gap:1rem;align-items:center;display:grid;gap:1rem;padding:0 1rem}.table-header{background:#f8f8f8;border-bottom:2px solid #e5e5e5;color:#666;font-size:.85rem;font-weight:600;height:50px;letter-spacing:.03em;position:sticky;top:0;z-index:10}.table-header span{padding:1rem .5rem;text-align:left;text-transform:uppercase}.table-row{border-bottom:1px solid #e5e5e5;height:60px;position:relative;transition:background-color .2s}.table-row:last-child{border-bottom:none}.table-row:hover{background-color:#fafafa}.table-row span{color:#111;font-size:.9rem;padding:1rem .5rem;text-align:left}.doc-cards-grid{display:none;gap:1.5rem;margin-top:1rem}.doc-card{background:#fff;border:1px solid #e5e5e5;border-radius:10px;box-shadow:0 1px 4px #0000001a;padding:16px;transition:transform .2s,box-shadow .2s}.doc-card:hover{box-shadow:0 6px 12px #00000014;transform:translateY(-2px)}.doc-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.doc-title{color:#111;font-size:1rem;font-weight:600;margin:0}.doc-badge{background-color:#f5f5f5;border-radius:12px;color:#333;font-size:.8rem;padding:4px 8px}.doc-subinfo{color:#666;font-size:.9rem;margin-bottom:12px}.doc-actions{display:flex;gap:8px;justify-content:flex-end}.doc-actions .icon-button{border-radius:8px;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;height:auto;padding:8px 12px;width:auto}.doc-actions .icon-img{height:18px;opacity:.8;width:18px}.desktop-only{display:block}.mobile-only{display:none}@media (max-width:768px){.desktop-only{display:none}.mobile-only{display:grid}.table-header span,.table-row span{white-space:normal;word-break:break-word}}.preview-overlay{align-items:center;animation:fadeIn .3s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000bf;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:99999}.preview-modal{animation:slideUp .4s;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0006;max-width:1000px;padding:2rem;position:relative;width:90%}.close-preview{background:#f2f2f2;border:none;border-radius:50%;color:#333;cursor:pointer;font-size:1.5rem;height:34px;position:absolute;right:1rem;top:1rem;transition:background-color .3s,transform .3s;width:34px}.close-preview:hover{background-color:#ddd;transform:rotate(90deg)}.preview-content{background:#fafafa;border-radius:8px;height:calc(80vh - 4rem);margin-top:2rem;overflow:hidden}.preview-iframe{background-color:#fff;border:none;height:100%;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.bottom-section{color:#555;font-size:1rem;margin-top:2rem;text-align:center}.upload-link{color:#007bff;cursor:pointer;text-decoration:underline}.upload-link:hover{text-decoration:none}.icon-button{align-items:center;background-color:#f5f5f5;border:none;border-radius:8px;cursor:pointer;display:inline-flex;height:34px;justify-content:center;margin-right:4px;overflow:hidden;position:relative;transition:all .3s;width:34px}.icon-button:hover{background-color:#e8e8e8;transform:translateY(-2px)}.icon-img{display:block;height:18px;opacity:.7;transition:all .2s ease;width:18px;z-index:1}.icon-button:hover .icon-img{opacity:1;transform:scale(1.1)}.upload-modal-overlay{align-items:center;animation:fadeIn .3s;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:999999}.upload-modal{background:#fff;border-radius:12px;box-shadow:0 12px 24px #0003;max-width:500px;padding:2rem;position:relative;width:90%}.close-upload-modal{background:#0000;border:none;color:#333;cursor:pointer;font-size:1.5rem;position:absolute;right:1rem;top:1rem}.upload-modal h2{color:#111;font-size:1.5rem;margin-bottom:1rem;margin-top:0}.upload-form{gap:1rem}.upload-form,.upload-form-group{display:flex;flex-direction:column}.upload-form-group label{color:#444;font-size:.9rem;font-weight:500;margin-bottom:.3rem}.upload-form-group input[type=file],.upload-form-group input[type=text],.upload-form-group textarea{border:1px solid #ccc;border-radius:6px;font-size:.95rem;padding:.6rem .75rem}.upload-message{background:#f0fdf4;border-radius:6px;color:#065f46;font-size:.9rem;padding:.75rem}.btn-submit-upload{background:#000;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;padding:.75rem 1.25rem;transition:background-color .2s ease}.btn-submit-upload:hover{background-color:#333}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table-header .sortable{font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (min-width:1024px){.table-header,.table-row{grid-gap:.75rem;align-items:start;display:grid;gap:.75rem;grid-auto-rows:auto;grid-template-columns:minmax(200px,2.5fr) minmax(100px,1fr) minmax(140px,2fr) minmax(100px,1.5fr) minmax(100px,1fr) minmax(80px,1fr) minmax(120px,1.2fr);padding:.5rem 1rem}.table-header span{line-height:1.2;text-align:center}.table-header span,.table-row span{padding:.75rem .5rem;white-space:normal;word-break:break-word}.table-row span{line-height:1.4}.table-row .icon-button{height:36px;margin-right:.5rem;width:36px}.documents-container{max-width:1560px;padding-right:3rem}.table-header span{text-align:left!important}.table-header span:last-child{white-space:nowrap}}@media (max-width:768px){.documents-table{display:none}.doc-cards-grid{display:grid;grid-template-columns:1fr}.documents-container{overflow-x:hidden}}body,html{overflow-x:hidden}@media (max-width:768px){.documents-container{max-width:100%;padding:1rem}.doc-cards-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}.doc-card{box-sizing:border-box;width:100%}}.footer-container{background-color:#000;color:#fff;font-size:.9rem;padding:.75rem;text-align:center}.footer-links{display:inline-flex;gap:.5rem;margin-bottom:.25rem}.footer-links a{color:#fff;text-decoration:none}.footer-links a:hover{text-decoration:underline}.footer-copy{color:#ccc;font-size:.75rem;margin:0}.agb-container{background-color:#000;color:#fff;font-family:Arial,sans-serif;min-height:100vh;padding:2rem}.agb-title{font-size:2rem;margin-bottom:1rem}.agb-subtitle{color:#ccc;font-size:1rem;margin-bottom:2rem}.agb-section{margin-bottom:1.5rem}.agb-section h2{font-size:1.2rem;margin-bottom:.5rem}.agb-section p{font-size:1rem;line-height:1.6;margin-bottom:1rem}.datenschutz-container{background-color:#000;color:#fff;font-family:Arial,sans-serif;min-height:100vh;padding:2rem}.datenschutz-title{font-size:2rem;margin-bottom:1rem}.datenschutz-subtitle{color:#ccc;font-size:1rem;margin-bottom:2rem}.datenschutz-section{margin-bottom:1.5rem}.datenschutz-section h2{font-size:1.2rem;margin-bottom:.5rem}.datenschutz-section p{font-size:1rem;line-height:1.6;margin-bottom:1rem}.datenschutz-container a{color:#fff;text-decoration:underline}.impressum-container{background-color:#000;color:#fff;font-family:Arial,sans-serif;line-height:1.6;min-height:100vh;padding:2rem}.impressum-title{font-size:2rem;margin-bottom:1rem}.impressum-container a{color:#fff;text-decoration:underline}
/*# sourceMappingURL=main.cb7695ff.css.map*/