*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:linear-gradient(160deg,#0f1419,#1a2332 45%,#0d3d2e);color:#e8f0e8}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;display:flex;flex-direction:column;min-height:0}.missing-oidc-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;min-height:0}.site-footer{margin-top:auto;border-top:1px solid rgba(159,212,184,.2);background:#0f1419bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.site-footer-inner{max-width:56rem;margin:0 auto;padding:1rem 1.25rem 1.35rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem 1.25rem}.site-footer-copy{margin:0;font-size:.85rem;color:#e8f0e8b8}.site-footer-link{font-size:.9rem;color:#9fd4b8;text-decoration:underline;text-underline-offset:3px}.site-footer-link:hover{color:#c5ead6}.topbar{position:sticky;top:0;z-index:20;border-bottom:1px solid rgba(159,212,184,.2);background:#0f1419d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-inner{max-width:56rem;margin:0 auto;padding:.65rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.topbar-brand{display:inline-flex;align-items:center;gap:.65rem;font-weight:700;letter-spacing:-.02em;color:#e8f0e8;text-decoration:none}.topbar-brand:hover{color:#c5ead6}.topbar-logo{flex-shrink:0;width:2.15rem;height:2.15rem;object-fit:contain;border-radius:6px}.topbar-brand-text{line-height:1.2}.topbar-nav{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.topbar-user{font-size:.9rem;color:#c5ead6;max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-hint{font-size:.9rem;color:#e8f0e873;cursor:help}.btn{font:inherit;cursor:pointer;border-radius:8px;padding:.45rem .95rem;border:1px solid transparent;text-decoration:none;color:inherit;display:inline-flex;align-items:center;justify-content:center;font-size:.9rem}.btn--primary{background:linear-gradient(135deg,#2d6a4f,#1b4332);color:#f1fff6;border-color:#9fd4b859}.btn--primary:hover{filter:brightness(1.06)}.btn--ghost{background:transparent;color:#9fd4b8;border-color:#9fd4b873}.btn--ghost:hover{background:#9fd4b81f;color:#c5ead6}.btn--link{background:none;border:none;padding:0;color:#9fd4b8;text-decoration:underline;text-underline-offset:3px;font:inherit;cursor:pointer;display:inline}.btn--link:hover{color:#c5ead6}.btn--secondary{background:#00000040;color:#e8f0e8;border-color:#9fd4b859}.btn--secondary:hover:not(:disabled){background:#9fd4b81a;border-color:#9fd4b880}.btn--danger{background:#7828288c;color:#ffe8e6;border-color:#f0a0a073}.btn--danger:hover:not(:disabled){filter:brightness(1.08)}.btn:disabled{opacity:.55;cursor:not-allowed}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hero--register{max-width:26rem}.register-form{margin-top:1.75rem;width:100%}.register-fieldset{margin:0;padding:0;border:none;min-width:0}.register-method-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}.register-method{width:100%;margin:0;padding:.65rem 1rem;font:inherit;font-size:.95rem;cursor:pointer;border-radius:10px;text-align:center;border:1px solid rgba(159,212,184,.35);transition:background .15s ease,border-color .15s ease,color .15s ease}.register-method--primary{background:linear-gradient(135deg,#2d6a4f,#1b4332);color:#f1fff6;border-color:#9fd4b873}.register-method--primary:hover{filter:brightness(1.06)}.register-method--idp{background:#0003;color:#e8f0e8}.register-method--idp:hover{background:#9fd4b81f;border-color:#9fd4b88c;color:#f1fff6}.register-hint{max-width:28rem;margin:1.5rem auto 0;text-align:center}.page--with-topbar{flex:1;align-items:stretch;justify-content:flex-start;padding-top:0}.hero{width:100%;max-width:42rem;margin:0 auto;padding:2.5rem 1.5rem 2rem;text-align:center}.hero-lead{margin:1rem 0 0;line-height:1.55;color:#e8f0e8e0;font-size:1.05rem}.panel{margin:2rem auto 0;padding:1.25rem 1.35rem;border-radius:12px;text-align:left;background:#00000038;border:1px solid rgba(159,212,184,.2);max-width:36rem}.panel-title{margin:0 0 .75rem;font-size:1.1rem;color:#c5ead6}.panel-muted{margin:0;font-size:.9rem;color:#e8f0e8bf;line-height:1.5}.profile-dl{margin:0;display:grid;grid-template-columns:minmax(6rem,38%) 1fr;gap:.35rem 1rem;font-size:.9rem}.profile-dl dt{margin:0;color:#e8f0e8a6}.profile-dl dd{margin:0;word-break:break-all}.mono{font-family:ui-monospace,Cascadia Code,Segoe UI Mono,monospace;font-size:.82rem}.page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.title{margin:0;font-size:clamp(1.75rem,5vw,2.75rem);font-weight:700;letter-spacing:-.02em;text-align:center;text-shadow:0 2px 24px rgba(0,0,0,.35)}.footer-link{margin:1.5rem 0 0;text-align:center}.footer-link a{color:#9fd4b8;font-size:.95rem;text-decoration:underline;text-underline-offset:3px}.footer-link a:hover{color:#c5ead6}.page--legal{align-items:flex-start;justify-content:flex-start;overflow-y:auto;padding-top:2rem;padding-bottom:2rem}.legal{max-width:42rem;margin:0 auto;text-align:left;color:#e8f0e8}.legal h1{font-size:1.5rem;margin:0 0 .5rem}.legal h2{font-size:1.1rem;margin:1.5rem 0 .5rem;color:#c5ead6}.legal p,.legal li{font-size:.95rem;margin:.5rem 0}.legal ul{padding-left:1.25rem}.legal a{color:#9fd4b8}.legal-muted{font-size:.85rem;opacity:.85}.legal-footer{margin-top:2rem}.legal-back{background:transparent;border:1px solid #9fd4b8;color:#9fd4b8;padding:.5rem 1rem;border-radius:8px;font:inherit;cursor:pointer}.legal-back:hover{background:#9fd4b826}.topbar-user-menu{position:relative}.topbar-avatar-btn{display:flex;align-items:center;justify-content:center;width:2.35rem;height:2.35rem;padding:0;border-radius:50%;border:2px solid rgba(159,212,184,.45);background:#00000040;cursor:pointer;overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease}.topbar-avatar-btn:hover,.topbar-avatar-btn:focus-visible{border-color:#c5ead6bf;box-shadow:0 0 0 3px #9fd4b833;outline:none}.topbar-avatar-img{width:100%;height:100%;object-fit:cover}.topbar-avatar-fallback{font-size:.78rem;font-weight:700;color:#c5ead6;letter-spacing:-.02em}.topbar-dropdown{position:absolute;right:0;top:calc(100% + .35rem);margin:0;padding:.35rem 0;min-width:11rem;list-style:none;border-radius:10px;background:#161e26fa;border:1px solid rgba(159,212,184,.28);box-shadow:0 12px 40px #00000073;z-index:40}.topbar-dropdown-item{display:block;width:100%;text-align:left;padding:.55rem 1rem;font:inherit;font-size:.92rem;color:#e8f0e8;background:transparent;border:none;cursor:pointer}.topbar-dropdown-item:hover{background:#9fd4b81f;color:#f1fff6}.profile-layout{display:grid;grid-template-columns:1fr;width:100%;max-width:72rem;margin:0 auto;min-height:0;flex:1;align-items:stretch;justify-content:flex-start;padding:0 1rem 2rem;gap:1.25rem}@media(min-width:52rem){.profile-layout{grid-template-columns:15.5rem minmax(0,1fr);gap:1.75rem;padding:0 1.5rem 2.5rem}}.profile-sidebar{display:flex;flex-direction:column;align-items:stretch;padding:1.25rem 1.1rem;border-radius:14px;background:#00000038;border:1px solid rgba(159,212,184,.2);height:fit-content}@media(min-width:52rem){.profile-sidebar{position:sticky;top:4.5rem;align-self:start}}.profile-sidebar-avatar-wrap{text-align:center;margin-bottom:1.25rem}.profile-sidebar-avatar{width:5.5rem;height:5.5rem;border-radius:50%;object-fit:cover;border:2px solid rgba(159,212,184,.35)}.profile-sidebar-avatar--fallback{display:inline-flex;align-items:center;justify-content:center;margin:0 auto;font-size:1.35rem;font-weight:700;color:#c5ead6;background:#2d6a4f8c}.profile-sidebar-name{margin:.65rem 0 0;font-size:.95rem;font-weight:600;color:#e8f0e8;word-break:break-word}.profile-sidebar-nav{display:flex;flex-direction:column;gap:.25rem}.profile-sidebar-link{display:block;padding:.55rem .75rem;border-radius:8px;color:#e8f0e8e0;text-decoration:none;font-size:.92rem}.profile-sidebar-link:hover{background:#9fd4b81a;color:#f1fff6}.profile-sidebar-link--active{background:#9fd4b829;color:#c5ead6;font-weight:600}.profile-sidebar-spacer{flex:1;min-height:1.5rem}.profile-sidebar-footer{margin-top:auto;padding-top:1rem;border-top:1px solid rgba(159,212,184,.15)}.profile-sidebar-delete{display:inline-block;font-size:.88rem;color:#f0b0a8;text-decoration:underline;text-underline-offset:3px}.profile-sidebar-delete:hover{color:#ffc9c0}.profile-sidebar-delete--muted{color:#f0b0a88c;text-decoration:none}.profile-sidebar-gdpr-hint{margin:.5rem 0 0;font-size:.75rem;line-height:1.45;color:#e8f0e88c}.profile-sidebar-delete--btn{display:inline-block;width:100%;text-align:left;font:inherit;font-size:.88rem;color:#f0b0a8;text-decoration:underline;text-underline-offset:3px;background:none;border:none;padding:0;cursor:pointer}.profile-sidebar-delete--btn:hover{color:#ffc9c0}.account-delete-dialog{margin:auto;max-width:min(26rem,calc(100vw - 2rem));padding:0;border:none;border-radius:14px;background:#152218;color:#e8f0e8;box-shadow:0 1rem 2.5rem #0000008c}.account-delete-dialog::backdrop{background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.account-delete-dialog-inner{padding:1.35rem 1.35rem 1.2rem}.account-delete-dialog-title{margin:0 0 .75rem;font-size:1.15rem;font-weight:700;color:#f1fff6}.account-delete-dialog-lead{margin:0 0 .5rem;font-size:.92rem;color:#e8f0e8e0}.account-delete-dialog-list{margin:0 0 1rem;padding-left:1.2rem;font-size:.9rem;line-height:1.55;color:#e8f0e8d1}.account-delete-dialog-error{margin:0 0 1rem;padding:.55rem .7rem;border-radius:8px;background:#78282859;border:1px solid rgba(240,160,160,.35);color:#ffc9c0;font-size:.88rem}.account-delete-dialog-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.65rem;margin-top:.25rem}.profile-detail{min-width:0;padding:.25rem 0 1rem}@media(min-width:52rem){.profile-detail{padding:.5rem 0 1rem}}.profile-detail-muted{margin:0;color:#e8f0e8a6}.profile-settings-header{margin-bottom:1.5rem}.profile-settings-title{margin:0;font-size:1.5rem;font-weight:700;color:#e8f0e8;letter-spacing:-.02em}.profile-settings-lead{margin:.45rem 0 0;font-size:.95rem;color:#e8f0e8b8;line-height:1.5}.profile-settings-error{margin:0 0 1rem;padding:.65rem .85rem;border-radius:8px;background:#78282859;border:1px solid rgba(240,160,160,.35);color:#ffc9c0;font-size:.9rem}.profile-settings-success{margin:0 0 1rem;padding:.65rem .85rem;border-radius:8px;background:#2d6a4f59;border:1px solid rgba(159,212,184,.35);color:#c5ead6;font-size:.9rem}.concept-fieldset{margin:0 0 1.75rem;padding:0;border:none;min-width:0}.concept-legend{padding:0;font-size:1.05rem;font-weight:700;color:#c5ead6}.concept-hint{margin:.35rem 0 .85rem;font-size:.88rem;line-height:1.5;color:#e8f0e8b8}.concept-checkboxes{display:flex;flex-direction:column;gap:.5rem}.concept-check-label{display:flex;align-items:flex-start;gap:.65rem;padding:.65rem .75rem;border-radius:10px;background:#0000002e;border:1px solid rgba(159,212,184,.12);cursor:pointer;transition:background .12s ease,border-color .12s ease}.concept-check-label:hover{border-color:#9fd4b847;background:#00000047}.concept-check-label input{margin-top:.2rem;width:1.05rem;height:1.05rem;accent-color:#2d6a4f;flex-shrink:0}.concept-check-text{display:flex;flex-direction:column;gap:.2rem;min-width:0}.concept-check-name{font-weight:600;font-size:.92rem;color:#e8f0e8}.concept-check-cat{display:inline-block;margin-left:.45rem;font-size:.75rem;font-weight:500;color:#9fd4b8d9;vertical-align:middle}.concept-check-desc{font-size:.82rem;line-height:1.45;color:#e8f0e89e}.profile-settings-actions{margin-top:.5rem;padding-top:.25rem}
