:root{--bg: #0d1117;--bg2: #161b22;--bg3: #21262d;--border: #30363d;--text: #e6edf3;--text-muted: #7d8590;--text-dim: #484f58;--accent: #2f81f7;--accent-glow: rgba(47, 129, 247, .15);--green: #3fb950;--yellow: #d29922;--red: #f85149;--purple: #bc8cff;--radius: 6px;--transition: all .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;scroll-behavior:smooth}body{background-color:var(--bg);color:var(--text);font-family:DM Sans,system-ui,sans-serif;line-height:1.5;min-width:320px;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{border:none;background:none;cursor:pointer;font:inherit}ul,ol{list-style:none}img,svg{display:block;max-width:100%}input,textarea,select{font:inherit}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}h1,h2,h3,h4,h5,h6{font-family:DM Sans,system-ui,sans-serif;font-weight:600;line-height:1.25;color:var(--text)}h1.hero{font-family:"Instrument Serif",Georgia,serif;font-size:3rem;font-weight:400}h1.hero em{font-style:italic;color:var(--accent)}code,pre,.mono{font-family:IBM Plex Mono,Courier New,monospace}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-accent{color:var(--accent)}.text-green{color:var(--green)}.text-yellow{color:var(--yellow)}.text-red{color:var(--red)}.text-purple{color:var(--purple)}.page{display:flex;flex-direction:column;gap:20px}.page--narrow{max-width:720px;margin:0 auto;width:100%}.page__heading{display:flex;flex-direction:column;gap:4px}.page__title{font-family:"Instrument Serif",Georgia,serif;font-size:32px;font-weight:400;line-height:1.15;color:var(--text);margin:0}.page__title--sm{font-size:28px}.page__sub{font-size:13px;color:var(--text-muted);line-height:1.5;margin:0;max-width:640px}.page__heading-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.page__actions{display:flex;align-items:center;gap:8px}.section{display:flex;flex-direction:column;gap:12px}.section__title{font-family:"Instrument Serif",Georgia,serif;font-size:22px;font-weight:400;color:var(--text);margin:0}.section__title--mono{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:500;letter-spacing:.077em;text-transform:uppercase;color:var(--text-muted)}.section__heading-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.section__sub{font-size:12px;color:var(--text-muted);margin:0}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.card--flat{background:transparent;border:none}.card--accent{border-color:var(--accent)}.card--danger{border-color:#f8514966}.card__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px 9px;border-bottom:1px solid var(--border);flex-shrink:0}.card__title{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.card__count{font-family:IBM Plex Mono,monospace;font-size:11px;color:var(--accent);background:var(--accent-glow);border-radius:20px;padding:2px 8px}.card__action{font-family:inherit;font-size:12px;font-weight:500;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;transition:var(--transition)}.card__action:hover:not(:disabled){opacity:.75}.card__action:disabled{opacity:.5;cursor:not-allowed}.card__body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:12px}.card__body--lg{padding:20px 16px;gap:16px}.card__body--flush{padding:0}.card__footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:10px 14px;border-top:1px solid var(--border)}.card__empty{padding:20px 14px;font-size:12px;color:var(--text-dim);text-align:center}.card__skeleton{padding:12px 14px;display:flex;flex-direction:column;gap:8px}.card__form{padding:12px 14px 14px;border-top:1px solid var(--border);background:var(--bg);display:flex;flex-direction:column;gap:6px}.card-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--bg3);transition:background .15s ease}.card-row:last-child{border-bottom:none}.card-row:hover{background:#ffffff05}.card-row--unread{background:#2f81f70a}.card-row--mine{background:#2f81f708}.card-row__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.card-row__title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-row__sub{font-family:IBM Plex Mono,monospace;font-size:11px;color:var(--text-muted)}.card-row__meta{font-family:IBM Plex Mono,monospace;font-size:11px;color:var(--text-dim);white-space:nowrap;flex-shrink:0}.card-row__actions{display:flex;gap:4px;flex-shrink:0}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:13px;font-weight:500;color:var(--text)}.field__label--mono{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.field__label--checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.field__label--checkbox input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.field__input,.field__select,.field__textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:0 12px;color:var(--text);font-family:inherit;font-size:13px;line-height:1.4;outline:none;width:100%;transition:var(--transition)}.field__input::placeholder,.field__select::placeholder,.field__textarea::placeholder{color:var(--text-dim)}.field__input:focus,.field__select:focus,.field__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.field__input[type=date],.field__select[type=date],.field__textarea[type=date]{color-scheme:dark}.field__input,.field__select{height:40px}.field__textarea{height:auto;padding:10px 12px;min-height:64px;resize:vertical}.field__select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237d8590' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.field__select option{background:var(--bg3);color:var(--text)}.field__input--sm,.field__select--sm{height:36px;padding:0 10px}.field__input--error,.field__select--error,.field__textarea--error{border-color:var(--red)}.field__hint{font-size:12px;color:var(--text-dim)}.field__hint--error{color:var(--red)}.field__hint--inline{font-size:11px;font-weight:400;color:var(--text-dim);margin-left:6px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 767px){.field-grid{grid-template-columns:1fr}}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 0}.toggle-row--bordered{padding:10px 0;border-top:1px solid var(--border)}.toggle-row--bordered:first-child{border-top:none;padding-top:0}.toggle-row__info{display:flex;flex-direction:column;gap:2px;min-width:0}.toggle-row__label{font-size:13px;font-weight:500;color:var(--text)}.toggle-row__sub{font-size:12px;color:var(--text-muted)}.toggle{flex-shrink:0;width:36px;height:20px;border-radius:999px;background:var(--bg3);border:1px solid var(--border);cursor:pointer;position:relative;padding:0;transition:var(--transition)}.toggle__thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-muted);transition:var(--transition)}.toggle--on{background:var(--accent);border-color:var(--accent)}.toggle--on .toggle__thumb{left:18px;background:#fff}.btn{height:32px;padding:0 14px;border-radius:var(--radius);font-family:inherit;font-size:13px;font-weight:500;line-height:1;cursor:pointer;transition:var(--transition);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;white-space:nowrap;background:transparent;color:var(--text);-webkit-user-select:none;user-select:none}.btn:disabled,.btn[disabled]{opacity:.55;cursor:not-allowed}.btn--sm{height:28px;padding:0 10px;font-size:12px}.btn--lg{height:40px;padding:0 18px;font-size:14px}.btn--xs{height:24px;padding:0 10px;font-size:11px}.btn--block{display:flex;width:100%}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){opacity:.88}.btn--ghost{background:transparent;border-color:var(--border);color:var(--text-muted)}.btn--ghost:hover:not(:disabled){color:var(--text);border-color:var(--text-dim)}.btn--ghost-accent{background:transparent;border-color:var(--border);color:var(--accent)}.btn--ghost-accent:hover:not(:disabled){background:var(--accent-glow);border-color:var(--accent)}.btn--danger{background:var(--red);border-color:var(--red);color:#fff}.btn--danger:hover:not(:disabled){opacity:.88}.btn--danger-soft{background:#f851491a;border-color:#f851494d;color:var(--red)}.btn--danger-soft:hover:not(:disabled){background:#f851492e}.btn--success-soft{background:#3fb9501f;border-color:#3fb9504d;color:var(--green)}.btn--success-soft:hover:not(:disabled){background:#3fb95033;border-color:#3fb95080}.btn--text{height:auto;padding:0;background:none;border:none;color:var(--accent)}.btn--text:hover:not(:disabled){opacity:.75}.btn--icon{width:24px;height:24px;padding:0;border-radius:4px;background:transparent;border:none;color:var(--text-muted);font-size:13px}.btn--icon:hover:not(:disabled){background:var(--bg3);color:var(--text)}.btn--icon.btn--danger-hover:hover:not(:disabled){background:#f851491a;color:var(--red)}.chips{display:flex;flex-wrap:wrap;gap:6px}.chips--compact{gap:4px;margin-top:2px}.chip{font-family:inherit;padding:4px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.chip:hover:not(:disabled){color:var(--text)}.chip:disabled{opacity:.5;cursor:not-allowed}.chip--sm{padding:3px 8px;font-size:11px}.chip--lg{padding:7px 14px;font-size:13px}.chip--pill{border-radius:999px}.chip--active{background:var(--accent-glow);border-color:#2f81f74d;color:var(--accent)}.chip--green{color:var(--green);border-color:#3fb9504d;background:#3fb9501f}.chip--yellow{color:var(--yellow);border-color:#d299224d;background:#d299221f}.chip--red{color:var(--red);border-color:#f851494d;background:#f851491a}.chip--purple{color:var(--purple);border-color:#bc8cff4d;background:#bc8cff1f}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid var(--border);border-radius:20px;background:var(--bg3);color:var(--text-muted);font-size:11px;font-weight:500;white-space:nowrap;line-height:1.3}.badge--mono{font-family:IBM Plex Mono,monospace}.badge--accent{background:var(--accent-glow);border-color:#2f81f74d;color:var(--accent)}.badge--green{background:#3fb9501f;border-color:#3fb9504d;color:var(--green)}.badge--yellow{background:#d299221f;border-color:#d299224d;color:var(--yellow)}.badge--red{background:#f851491a;border-color:#f851494d;color:var(--red)}.badge--purple{background:#bc8cff1f;border-color:#bc8cff4d;color:var(--purple)}.badge--dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:48px 24px;text-align:center}.empty-state--card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius)}.empty-state--compact{padding:24px 16px}.empty-state__icon{font-size:28px;margin-bottom:4px;opacity:.7}.empty-state__title{font-size:14px;font-weight:500;color:var(--text-muted);margin:0}.empty-state__sub{font-size:12px;color:var(--text-dim);max-width:360px;margin:0 0 4px;line-height:1.5}.toast{border-radius:var(--radius);padding:10px 14px;font-size:13px;line-height:1.5;animation:fadeIn .2s ease}.toast--success{background:#3fb9501f;border:1px solid rgba(63,185,80,.3);color:var(--green)}.toast--error{background:#f851491a;border:1px solid rgba(248,81,73,.3);color:var(--red)}.toast--warning{background:#d299221a;border:1px solid rgba(210,153,34,.3);color:var(--yellow)}.toast--info{background:var(--accent-glow);border:1px solid rgba(47,129,247,.3);color:var(--accent)}.modal-backdrop{position:fixed;inset:0;background:#00000080;z-index:99;animation:fadeIn .15s ease}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(560px,100vw - 32px);max-height:calc(100vh - 64px);overflow-y:auto;background:var(--bg2);border:1px solid var(--border);border-radius:8px;z-index:100;display:flex;flex-direction:column;animation:fadeIn .15s ease}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.modal__title{font-size:14px;font-weight:600;color:var(--text)}.modal__close{width:28px;height:28px;background:transparent;border:none;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;border-radius:4px}.modal__close:hover{color:var(--text);background:var(--bg3)}.modal__body{padding:16px;display:flex;flex-direction:column;gap:14px}.modal__actions{display:flex;justify-content:flex-end;gap:8px;padding-top:4px}.auth-page{display:flex;flex-direction:column;align-items:center;min-height:calc(100vh - 119px)}.auth-page__center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;flex:1;width:400px;padding:40px 0}@media (max-width: 767px){.auth-page__center{width:100%;padding:24px 16px}}.auth-page--wide .auth-page__center{width:480px}.auth-heading{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.auth-heading__title{font-family:"Instrument Serif",Georgia,serif;font-size:32px;font-weight:400;color:var(--text);margin:0}.auth-heading__sub{font-size:14px;color:var(--text-muted);max-width:360px;margin:0}.auth-card{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:32px;display:flex;flex-direction:column;gap:20px}.auth-card form{display:flex;flex-direction:column;gap:20px}.auth-verify{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;padding:8px 0}.auth-verify__icon{font-size:36px;line-height:1}.auth-verify__title{font-size:16px;font-weight:600;color:var(--text);margin:0}.auth-verify__sub{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0}.auth-verify__sub strong{color:var(--text);font-weight:500}.auth-verify__back{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;padding:0;transition:var(--transition)}.auth-verify__back:hover{color:var(--text)}.auth-oauth{display:flex;flex-direction:column;gap:8px}.auth-oauth__btn{height:40px;width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:0 12px}.auth-oauth__btn:hover:not(:disabled){border-color:var(--text-muted)}.auth-oauth__btn:disabled{opacity:.5;cursor:not-allowed}.auth-oauth__logo{width:16px;height:16px;flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:12px;color:var(--text-dim);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-footer-link{font-size:13px;color:var(--text-muted);text-decoration:none;text-align:center}.auth-footer-link span{color:var(--accent)}.auth-footer-link:hover span{text-decoration:underline}.auth-role-chips{display:flex;gap:8px;flex-wrap:wrap}.auth-consents{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.auth-consents__header{display:flex;align-items:center;gap:8px}.auth-consents__title{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex-shrink:0}.auth-consents__line{flex:1;height:1px;background:var(--border)}.auth-consent-row{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-muted);line-height:1.5;cursor:pointer}.auth-consent-row__check{margin-top:2px;width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.auth-consent-row__label{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.auth-consent-row__link{color:var(--text);text-decoration:none}.auth-consent-row__link:hover{color:var(--accent);text-decoration:underline}.auth-consent-row__badge{font-family:IBM Plex Mono,monospace;font-size:10px;padding:1px 6px;border-radius:10px;background:#f851491a;border:1px solid rgba(248,81,73,.25);color:var(--red)}.auth-consent-row__badge--optional{background:var(--bg3);border-color:var(--border);color:var(--text-dim)}router-outlet+*{flex:1;min-height:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
