*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background-color:#e7d6ce;min-height:100vh;font-family:Arial,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}.sm-container{flex-direction:column;max-width:1200px;min-height:100vh;margin:0 auto;padding:30px 20px 60px;display:flex;position:relative}.sm-title{text-align:center;margin-bottom:10px}.sm-title h1{margin-bottom:5px;font-size:42px}.sm-title p{color:#5a4a3a;font-size:18px}.sm-error-banner{color:#7d1414;text-align:center;background:#f8dede;border:1px solid #b02a2a;border-radius:8px;max-width:720px;margin:16px auto 0;padding:12px 16px}.sm-tabs{flex-wrap:wrap;justify-content:center;gap:10px;margin:20px 0;display:flex}.sm-tab-btn{color:#5a4a3a;cursor:pointer;background:0 0;border:2px solid #5a4a3a;border-radius:6px;flex:180px;max-width:240px;padding:10px 30px;font-size:16px;transition:all .3s}.sm-tab-btn.active,.sm-tab-btn:hover{color:#e7d6ce;background:#5a4a3a}.sm-tab-content{display:none}.sm-tab-content.active{display:block}.sm-form{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:10px;margin:20px 0;display:flex}.sm-form-group{flex-direction:column;gap:4px;display:flex}.sm-form-group label{color:#5a4a3a;font-size:14px;font-weight:700}.sm-form input[type=text]{color:#333;background:#fff;border:2px solid #c4a882;border-radius:6px;width:200px;min-width:0;padding:12px 16px;font-size:16px}.sm-form input[type=password],.auth-form input,.admin-pdf-form input,.admin-create-form input,.admin-create-form select,.admin-table input,.admin-table select{color:#333;background:#fff;border:2px solid #c4a882;border-radius:6px;min-width:0;padding:12px 16px;font-size:16px}.sm-form input[type=text]::placeholder{color:#aaa}.sm-form-btn{color:#fff;cursor:pointer;background:#a5978c;border:none;border-radius:6px;padding:12px 30px;font-size:16px;transition:background .3s}.sm-form-btn:hover{background:#8f8177}.sm-form-btn:disabled,.secondary-btn:disabled,.danger-btn:disabled{cursor:not-allowed;opacity:.6}.sm-results{display:none}.sm-results.visible{width:100%;display:block}.sm-chart-single{flex-direction:column;align-items:center;width:100%;display:flex}.sm-chart-single canvas{width:100%;max-width:540px;height:auto}.sm-soul-chart{margin-top:30px}.sm-matrix-host{width:100%;max-width:842px}.sm-matrix-host svg{width:100%;height:auto;display:block}.sm-matrix-heading{color:#333;text-align:center;margin:12px 0 26px}.sm-matrix-heading h3{margin:0;font:500 22px Georgia,serif}.sm-matrix-heading p{margin:6px 0 0;font:18px Georgia,serif}.sm-jahresenergie{color:#333;text-align:center;margin:4px 0;font-size:18px;line-height:1.2}#sm-jahresenergie-aktuell{margin-top:12px}.sm-komp-grid{grid-template-columns:1fr 1fr;gap:20px;margin-top:20px;display:grid}.sm-komp-full{flex-direction:column;grid-column:1/-1;align-items:center;display:flex}.sm-komp-label{color:#5a4a3a;text-align:center;margin-bottom:10px;font-size:16px;font-weight:500}.auth-shell{grid-template-rows:1fr auto;justify-items:center;gap:18px;min-height:100vh;padding:24px;display:grid}.auth-card,.admin-card{background:#f3e8e2;border:1px solid #c4a882;border-radius:12px;box-shadow:0 12px 24px #5a4a3a14}.auth-card{text-align:center;width:100%;max-width:440px;padding:28px}.auth-card h1{margin-bottom:8px;font-size:34px}.auth-card p{color:#5a4a3a;margin-bottom:18px}.auth-form,.admin-pdf-form,.admin-create-form{gap:14px;display:grid}.admin-pdf-form{grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) auto auto;align-items:center;margin-top:18px}.admin-pdf-logo-option{color:#5a4a3a;white-space:nowrap;align-items:center;gap:8px;font-size:15px;font-weight:700;display:inline-flex}.admin-pdf-logo-option input{accent-color:#a5978c;width:18px;min-width:18px;height:18px;padding:0}.admin-card-copy{color:#5a4a3a;margin:0}.pdf-progress{background:#5a4a3a24;border-radius:999px;width:min(100%,420px);height:8px;margin-top:18px;position:relative;overflow:hidden}.pdf-progress-fill{border-radius:inherit;background:#5a4a3a;height:100%;transition:width .42s}.pdf-progress:after{content:"";background:linear-gradient(90deg,#0000,#ffffff6b,#0000);animation:1.35s ease-in-out infinite pdf-progress-shine;position:absolute;inset:0;transform:translate(-100%)}@keyframes pdf-progress-shine{to{transform:translate(100%)}}.auth-form label{text-align:left;color:#5a4a3a;gap:6px;font-weight:700;display:grid}.password-field{gap:6px;display:grid}.password-field label{text-align:left;color:#5a4a3a;font-weight:700}.password-field-control{position:relative}.password-field input{width:100%;padding-right:48px}.password-toggle{color:#5a4a3a;cursor:pointer;background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;transition:background-color .2s,color .2s;display:inline-flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle:hover{color:#333;background:#5a4a3a14}.password-toggle:focus-visible{outline-offset:2px;outline:2px solid #5a4a3a}.password-toggle svg{width:18px;height:18px}.form-error{color:#9a1b1b;text-wrap:balance;font-size:14px}.form-success{color:#356b3d;font-size:14px}.icon-btn{color:#5a4a3a;cursor:pointer;background:#fff9f5;border:1px solid #b79f8f;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:17px;line-height:1;transition:background .2s,transform .2s;display:inline-flex}.icon-btn:hover{background:#f3e8e2;transform:rotate(12deg)}.app-toolbar{z-index:2;position:absolute;top:30px;right:20px}.app-toolbar-actions{align-items:center;gap:10px;display:flex}.page-topbar{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:22px;display:flex}.page-topbar h1{color:#333;margin:0;font-size:42px}.page-topbar p{color:#5a4a3a;margin:8px 0 0;font-size:18px}.page-topbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-left:auto;display:flex}.secondary-btn,.danger-btn{color:#5a4a3a;cursor:pointer;background:#fff;border:1px solid #5a4a3a;border-radius:6px;justify-content:center;align-items:center;padding:10px 18px;font-size:14px;transition:all .2s;display:inline-flex}.secondary-btn:hover{background:#f3e8e2}.danger-btn{color:#9a1b1b;border-color:#9a1b1b}.danger-btn:hover{background:#fde8e8}.admin-shell{gap:24px;display:grid}.admin-card{padding:24px}.admin-section-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:6px;display:flex}.admin-card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.checkbox-row{align-items:center;gap:8px;display:inline-flex}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table th,.admin-table td{text-align:left;vertical-align:top;border-bottom:1px solid #dcc8bc;padding:12px 8px}.admin-table th{color:#5a4a3a;font-weight:700}.admin-table input,.admin-table select{width:100%}.admin-row-actions{gap:8px;display:grid}.admin-empty-state{color:#5a4a3a}.admin-empty-state-card,.admin-create-panel{background:#fff9f5;border:1px solid #d8c1b3;border-radius:10px;padding:18px}.admin-empty-state-card{justify-items:flex-start;gap:12px;display:grid}.admin-empty-state-card h3,.admin-create-panel h3{color:#333;margin:0;font-size:18px}.admin-empty-state-card p{padding:0}.admin-create-panel{gap:14px;margin-top:18px;display:grid}.pdf-content-editor{background:#fff9f5;border:1px solid #d8c1b3;border-radius:10px;gap:18px;margin-top:20px;padding:20px;display:grid}.pdf-content-editor-head{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.pdf-content-editor h3{color:#333;margin:0 0 6px;font-size:20px}.pdf-editor-status{color:#5a4a3a;font-size:13px}.pdf-content-form{gap:16px;display:grid}.pdf-energy-select-label{color:#5a4a3a;gap:7px;font-weight:700;display:grid}.pdf-energy-select,.pdf-content-form textarea{color:#333;width:100%;min-width:0;font:inherit;background:#fff;border:2px solid #c4a882;border-radius:8px}.pdf-energy-select{appearance:none;cursor:pointer;background-image:linear-gradient(45deg,#0000 50%,#5a4a3a 50%),linear-gradient(135deg,#5a4a3a 50%,#0000 50%);background-position:calc(100% - 22px) 20px,calc(100% - 16px) 20px;background-repeat:no-repeat;background-size:6px 6px,6px 6px;min-height:48px;padding:0 42px 0 16px;font-size:16px}.pdf-content-form textarea{resize:vertical;min-height:360px;padding:14px 16px;font-size:15px;line-height:1.5}.pdf-content-sections{gap:12px;display:grid}.pdf-content-section{background:#fff;border:1px solid #d8c1b3;border-radius:8px;overflow:hidden}.pdf-content-section.is-expanded{box-shadow:0 10px 24px #5a4a3a14}.pdf-content-section-toggle{color:#5a4a3a;cursor:pointer;width:100%;font:inherit;text-align:left;background:#fff;border:0;justify-content:space-between;align-items:center;padding:15px 16px;font-weight:700;display:flex}.pdf-content-section-toggle:hover{background:#fff9f5}.pdf-content-section-icon{color:#5a4a3a;background:#f3e8e2;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:18px;line-height:1;display:inline-flex}.pdf-content-section-body{gap:12px;padding:0 16px 16px;display:grid}.pdf-content-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.admin-user-list{gap:14px;display:grid}.admin-user-card{background:#fff9f5;border:1px solid #d8c1b3;border-radius:10px;justify-content:space-between;align-items:center;gap:16px;padding:18px;display:flex}.admin-user-card h3{word-break:break-word;margin-bottom:4px;font-size:18px}.admin-user-permission{color:#5a4a3a;white-space:nowrap;align-items:center;gap:8px;font-size:14px;display:inline-flex}.admin-user-permission input{accent-color:#8f4d2f;width:18px;height:18px}.admin-user-card p{color:#5a4a3a}.app-shell{gap:10px;display:grid}.site-footer{border-top:1px solid #d8c1b3;margin-top:24px;padding-top:18px}.site-footer-nav{color:#5a4a3a;white-space:nowrap;flex-wrap:nowrap;justify-content:center;gap:18px;font-size:12px;line-height:1;display:flex}.site-footer-nav a{color:#5a4a3a}.site-footer-nav a:hover{text-decoration:underline}.auth-footer{border-top:none;width:100%;max-width:440px;margin-top:auto;padding-top:0}.legal-shell{min-height:100vh;padding:24px}.legal-container{flex-direction:column;max-width:920px;min-height:calc(100vh - 48px);margin:0 auto;display:flex}.legal-card{background:#f3e8e2;border:1px solid #c4a882;border-radius:16px;padding:28px;box-shadow:0 12px 24px #5a4a3a14}.legal-page-head{gap:16px;margin-bottom:28px;display:grid}.legal-backlink{color:#5a4a3a;background:#fff7f1;border:1px solid #5a4a3a;border-radius:999px;justify-content:center;align-items:center;width:fit-content;padding:9px 14px;font-size:14px;display:inline-flex}.legal-backlink:hover{background:#fff}.legal-page-head h1{margin-bottom:8px;font-size:36px}.legal-page-head p,.legal-content p,.legal-content li,.legal-content address{color:#4f4338;line-height:1.7}.legal-content{gap:28px;display:grid}.legal-content section{gap:12px;display:grid}.legal-content h2{color:#333;font-size:22px}.legal-content ul{gap:8px;padding-left:20px;display:grid}.legal-content address{font-style:normal}.legal-meta{color:#5a4a3a;font-size:14px}.sm-container>.site-footer,.legal-container>.site-footer{margin-top:auto}@media (max-width:768px){.sm-container{padding:20px 16px 40px}.app-shell{gap:18px}.legal-shell{padding:16px}.legal-card{padding:20px}.legal-page-head h1{font-size:30px}.sm-title{margin-bottom:18px}.sm-komp-grid{grid-template-columns:1fr;gap:36px}.sm-title h1{font-size:28px}.sm-tabs{gap:12px;margin:24px 0 28px}.sm-tab-btn{max-width:none;padding:12px 16px}.sm-form{flex-direction:column;align-items:stretch;gap:16px;margin:0 0 28px}.sm-form-group{gap:10px;width:100%;max-width:none}.sm-results.visible{gap:28px;display:grid}.sm-chart-single{gap:12px}.sm-soul-chart{margin-top:8px}.sm-matrix-heading{margin:8px 0 20px}.sm-jahresenergie{margin:0;line-height:1.35}.sm-form input[type=text],.sm-form input[type=password],.auth-form input,.admin-pdf-form input,.admin-create-form input,.password-field input,.sm-form-btn,.secondary-btn,.danger-btn{width:100%;max-width:none}.admin-pdf-logo-option input{width:18px;max-width:18px}.app-toolbar{margin-bottom:16px;position:static}.app-toolbar-actions{flex-wrap:wrap;justify-content:stretch}.page-topbar{flex-direction:column;gap:14px;margin-bottom:20px}.auth-shell{padding:16px}.auth-card,.admin-card{padding:18px}.page-topbar h1,.auth-card h1{font-size:28px}.page-topbar-actions{width:100%}.page-topbar-actions .secondary-btn,.page-topbar-actions .danger-btn,.page-topbar-actions .sm-form-btn{flex:1 1 0}.admin-user-card{flex-direction:column;align-items:stretch;gap:12px}.admin-section-head{flex-direction:column;gap:12px;margin-bottom:0}.admin-users-head{gap:18px;margin-bottom:0}.admin-users-card{display:block}.admin-shell{gap:18px}.admin-pdf-form{grid-template-columns:1fr}.pdf-content-editor,.pdf-content-editor-head,.pdf-content-actions{align-items:stretch}.pdf-content-editor-head,.pdf-content-actions{flex-direction:column}.admin-card{padding:18px}.admin-empty-state-card,.admin-create-panel,.admin-user-card{padding:16px}}@media (max-width:480px){.sm-container{padding:16px 12px 32px}.app-shell{gap:20px}.sm-title h1{font-size:24px}.sm-title p,.page-topbar p,.app-intro p,.admin-card-copy,.sm-jahresenergie{font-size:15px}.sm-form input[type=text],.sm-form input[type=password],.auth-form input,.admin-pdf-form input,.admin-create-form input,.password-field input{padding:13px 14px}.admin-pdf-logo-option input{padding:0}.password-field input{padding-right:44px}.sm-tabs{margin:20px 0 24px}.sm-form{gap:18px;margin-bottom:24px}.sm-form-group{gap:12px}.sm-results.visible{gap:24px}.sm-komp-grid{gap:28px}.page-topbar h1,.auth-card h1{font-size:24px}.admin-card,.auth-card,.legal-card{padding:16px}.legal-page-head h1{font-size:26px}.admin-empty-state-card,.admin-create-panel,.admin-user-card{padding:14px}.admin-empty-state-card h3,.admin-create-panel h3,.admin-user-card h3{font-size:17px}.sm-form-btn,.secondary-btn,.danger-btn{min-height:44px;padding:10px 14px}}
