*,*: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{font-weight:700;letter-spacing:-.02em;color:#e8f0e8;text-decoration:none}.topbar-brand:hover{color:#c5ead6}.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}.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}
