:root{--synapse-primary:#0d9488;--synapse-primary-hover:#0f766e;--synapse-primary-muted:#0d948824;--synapse-accent:#7fc2b5;--synapse-hero-bg:#9cb;--synapse-bg:#ecebea;--synapse-login-page-bg:#fff;--synapse-login-card-bg:#eef7f4;--synapse-register-page-bg:#f8f9fa;--synapse-register-card-bg:#fff;--synapse-white:#fff;--synapse-text:#1a202c;--synapse-text-muted:#5c5c5c;--synapse-text-subtle:#8a8987;--synapse-border:#d4d2cf;--synapse-toggle-inactive:#e8e7e5;--synapse-reject:#94a3b8;--synapse-input-bg:#fff;--synapse-input-bg-muted:#f1f5f4;--synapse-input-border:#e2e8e0;--synapse-auth-ink:#0f172a;--synapse-radius:14px;--synapse-radius-sm:10px;--synapse-radius-xs:6px;--synapse-shadow:0 4px 20px #1a202c0f;--synapse-shadow-card:0 8px 30px #1a202c12;--synapse-space-xs:.35rem;--synapse-space-sm:.75rem;--synapse-space-md:1.25rem;--synapse-space-lg:2rem;--synapse-transition:.18s ease;--font-sans:"Inter", system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased}body{width:100%;min-height:100dvh;font-family:var(--font-sans);color:var(--synapse-text);background:var(--synapse-white);margin:0;line-height:1.5}::selection{background:var(--synapse-primary-muted);color:var(--synapse-text)}:focus-visible{outline:2px solid var(--synapse-accent);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}#root{width:100%;min-height:100dvh}a{color:var(--synapse-primary);font-weight:600;text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,button{font-size:1rem}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:root{--primary-dark:#0f172a;--secondary-slate:#94a3b8;--bg-main:#f1f5f9;--border-color:#e2e8f0;--text-muted:#64748b;--white:#fff;--teal-main:#20917b;--teal-light:#20917b1a;--table-header:#f8fafc;--danger:#ef4444}.brand-logo{align-items:center;display:flex}.brand-logo__text{letter-spacing:-.02em;font-size:1.35rem;font-weight:700}.btn{border-radius:var(--synapse-radius-sm);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-weight:600;transition:background .15s,color .15s,box-shadow .15s;display:inline-flex}.btn--block{width:100%}.btn--lg{padding:.85rem 1.5rem;font-size:1rem}.btn--pill{border-radius:999px}.btn--primary{background:var(--synapse-primary);color:#fff}.btn--primary:hover{background:var(--synapse-primary-hover)}.btn--primary:focus-visible{outline:none;box-shadow:0 0 0 3px #7fc2b5a6}.btn--primary:disabled{opacity:.5;cursor:not-allowed;background:var(--synapse-primary);color:#fff}.btn--outline{color:var(--synapse-primary);border:2px solid var(--synapse-primary);background:0 0}.btn--outline:hover{background:#20917b14}.btn--outline:focus-visible{outline:none;box-shadow:0 0 0 3px #20917b40}.btn--ghost{color:var(--synapse-primary);border:1px solid var(--synapse-border);background:0 0}.btn--ghost:hover{background:#20917b0f}.btn--secondary{background:var(--synapse-reject);color:#fff}.btn--secondary:hover{filter:brightness(1.05)}.btn__arrow{margin-left:.15rem}.btn__icon{display:inline-flex}.btn--busy{opacity:.92;pointer-events:none}.btn-spinner{align-items:center;margin-right:.35rem;display:inline-flex}.btn-spinner__svg{width:1.15rem;height:1.15rem;animation:.7s linear infinite btn-spin}.btn-spinner__track{stroke:#ffffff59}.btn-spinner__arc{stroke:#fff;stroke-dasharray:42 62;stroke-dashoffset:0}.btn--icon{cursor:pointer;background:0 0;border:none;font-size:1.2rem}.btn--large{background-color:var(--synapse-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.8rem 2.5rem;font-size:1rem;font-weight:600;transition:background-color .2s}.btn--large:hover{background-color:#0d7367}.btn--notif{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;transition:background .2s;display:flex;position:relative}.btn--notif:hover{background-color:#f8fafc}.btn--notif__dot{background-color:#ef4444;border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.topbar-actions{align-items:center;gap:1.5rem;display:flex}.topbar{justify-content:space-between;align-items:center;width:100%;margin-bottom:2.5rem;display:flex}.topbar-menu-anchor{position:relative}.topbar-icon-btn{min-width:44px;min-height:44px;color:var(--secondary-slate);cursor:pointer;touch-action:manipulation;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;padding:.35rem;display:inline-flex;position:relative}.topbar-icon-btn:hover{color:var(--primary-dark);background:#94a3b824}.topbar-icon-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #20917b59}.topbar-icon-btn__dot{background-color:#ef4444;border-radius:50%;width:8px;height:8px;position:absolute;top:2px;right:2px}.topbar-popover{z-index:1100;background:linear-gradient(#fff 0%,#fafbfc 100%);border:1px solid #e2e8f0f2;border-radius:14px;margin-top:10px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 0 0 1px #0f172a0f,0 4px 8px -2px #0f172a14,0 16px 40px -8px #0f172a29}.topbar-popover--notifications{width:min(288px,100vw - 2rem)}.topbar-popover--profile{width:min(220px,100vw - 2rem);padding:0}.topbar-popover__title{letter-spacing:-.02em;color:var(--primary-dark);background:linear-gradient(#20917b12 0%,#ffffff80 100%);border-bottom:1px solid #e2e8f0e6;align-items:center;gap:.6rem;padding:.85rem 1rem .85rem .95rem;font-size:.875rem;font-weight:700;display:flex}.topbar-popover__title-text{line-height:1.2}.topbar-popover__title-leading{width:2rem;height:2rem;color:var(--teal-main);background:#20917b1f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.topbar-popover__title-leading svg{display:block}.topbar-popover__body{text-align:center;color:var(--primary-dark);background:#fff;padding:1.15rem 1.15rem 1.25rem;font-size:.94rem;line-height:1.55}.topbar-popover__body--message{font-weight:500}.topbar-popover__stat{font-variant-numeric:tabular-nums;color:var(--teal-main);background:#20917b24;border-radius:8px;margin:0 .12em;padding:.12em .45em;font-size:1.08em;font-weight:800;line-height:1.2;display:inline-block;box-shadow:inset 0 0 0 1px #20917b33}.topbar-popover__muted{color:var(--text-muted);font-weight:500}.topbar-popover__menu{background:#fff;padding:.35rem 0}.topbar-popover__item{text-align:left;cursor:pointer;width:100%;color:var(--primary-dark);background:0 0;border:none;align-items:center;padding:.7rem 1rem;font-size:.9rem;font-weight:500;transition:background .12s,color .12s;display:flex}.topbar-popover__item:hover{background:#f1f5f9f2}.topbar-popover__item--danger{color:#dc2626;font-weight:600}.topbar-popover__item--danger:hover{color:#b91c1c;background:#fef2f2f2}.topbar-popover-overlay{z-index:8;appearance:none;cursor:pointer;touch-action:manipulation;background:#0f172a24;border:none;width:100%;height:100%;margin:0;padding:0;display:block;position:fixed;inset:0}.topbar--menu-open{z-index:12;position:relative}.dash-views{z-index:1;flex:1;min-width:0;position:relative}.terms-modal .btn--secondary .btn-spinner__track{stroke:#ffffff40}.terms-modal .btn--secondary .btn-spinner__arc{stroke:#ffffffe6}@keyframes btn-spin{to{transform:rotate(360deg)}}.error-callout{border-radius:var(--synapse-radius-sm);text-align:left;background:snow;border:1px solid #f1aeae;border-left:3px solid #c53030;margin-bottom:1rem;padding:.75rem .9rem}.error-callout__title{color:#742a2a;margin:0 0 .3rem;font-size:.8125rem;font-weight:600}.error-callout__msg{color:#9b2c2c;margin:0;font-size:.875rem;line-height:1.5}.role-toggle{background:var(--synapse-toggle-inactive);border-radius:var(--synapse-radius-sm);gap:4px;margin-bottom:1.25rem;padding:4px;display:flex}.role-toggle__btn{color:var(--synapse-text-muted);background:0 0;border:none;border-radius:6px;flex:1;padding:.55rem .75rem;font-size:.9rem;font-weight:600}.role-toggle__btn--active{background:var(--synapse-white);color:var(--synapse-primary);box-shadow:0 1px 3px #0000000f}.field{margin-bottom:1rem}.field__label{color:var(--synapse-text-muted);margin-bottom:.35rem;font-size:.8rem;font-weight:600;display:block}.field__optional{color:var(--synapse-text-subtle);font-size:.72rem;font-weight:500}.field__label-row{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.35rem;display:flex}.field__label-row .field__label{flex:1;min-width:0;margin-bottom:0}.field__label-extra{flex-shrink:0;font-size:.8125rem}.field__input{border:1px solid var(--synapse-border);border-radius:var(--synapse-radius-sm);background:var(--synapse-input-bg);width:100%;color:var(--synapse-text);transition:border-color var(--synapse-transition), box-shadow var(--synapse-transition);padding:.65rem .85rem}.field__input:focus{outline:2px solid var(--synapse-accent);outline-offset:1px;border-color:var(--synapse-primary)}.field__input--muted{background:var(--synapse-input-bg-muted);border-color:var(--synapse-input-border)}.field__input-wrap{position:relative}.field__input-wrap--password .field__input{padding-right:2.75rem}.field__eye{color:var(--synapse-text-muted);background:0 0;border:none;padding:.25rem;line-height:0;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.field__eye:hover{color:var(--synapse-primary)}.auth-top{flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.auth-top--home{justify-content:flex-start}.auth-top__link{color:var(--synapse-text-subtle);border-radius:var(--synapse-radius-xs);transition:color var(--synapse-transition), background var(--synapse-transition);padding:.35rem .5rem;font-size:.875rem;font-weight:600;text-decoration:none}.auth-top__link:hover{color:var(--synapse-primary);background:var(--synapse-primary-muted);text-decoration:none}.auth-card__center{flex:1;justify-content:center;align-items:center;min-height:0;padding:.35rem 0 1rem;display:flex}.auth-card__center--scroll{-webkit-overflow-scrolling:touch;justify-content:flex-start;align-items:flex-start;padding:.5rem 0 1.25rem;overflow-y:auto}.auth-footer-wrap{flex-shrink:0;width:100%;margin-top:auto;padding-top:.75rem}.assignments-section{padding:0 1rem}.login-card.welcome-card{flex:0 auto;justify-content:flex-start;width:100%;max-width:400px;margin:0;padding:1.35rem 1.5rem 1.25rem}.welcome-card__eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--synapse-primary);margin:0 0 .35rem;font-size:.68rem;font-weight:700}.welcome-card .login-card__title--hero{font-size:clamp(1.75rem,3.5vw,2.15rem)}.welcome-card__subtitle{max-width:34ch;font-size:.9rem;line-height:1.5;margin-bottom:1.1rem!important}.welcome-card__actions{flex-direction:column;gap:.6rem;margin-top:0;display:flex}.welcome-card__actions .btn{padding:.72rem 1rem;font-size:.95rem}.welcome-card__chev{font-size:1.05rem;font-weight:400}.welcome-card__headline{margin-bottom:.5rem}.welcome-line{background-color:var(--synapse-primary);border-radius:2px;width:4px;height:45px}.welcome-text{flex-direction:column;display:flex}.welcome-title{color:#1a202c;margin:0;font-size:1.8rem;font-weight:700}.welcome-subtitle{color:#718096;margin:.2rem 0 0;font-size:1rem}.login-layout{grid-template-rows:1fr;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:stretch;width:100%;max-width:none;min-height:100dvh;margin:0;display:grid}@media (width<=960px){.login-layout{grid-template-rows:auto auto;grid-template-columns:1fr}}.login-layout__form-side{box-sizing:border-box;background:var(--synapse-bg);flex-direction:column;min-height:100dvh;padding:1.25rem clamp(1.25rem,5vw,3rem) 1.5rem;display:flex}.login-layout__form-side--auth{min-height:100dvh}.login-layout__form-side--login{background:var(--synapse-login-page-bg)}.login-layout__form-side--register{background:var(--synapse-register-page-bg)}.auth-form-shell{width:100%;max-width:480px;margin:0 auto}.auth-form-shell--register{max-width:560px}.auth-top--login{margin-bottom:.25rem}.login-layout__top{margin-bottom:1rem}.login-card{background:var(--synapse-login-card-bg);border-radius:var(--synapse-radius);width:100%;max-width:420px;box-shadow:var(--synapse-shadow-card);border:1px solid #d0e4dce6;flex-direction:column;flex:0 auto;justify-content:flex-start;margin:0 auto;padding:1.5rem 1.5rem 1.35rem;display:flex}.login-card.login-card--surface{background:var(--synapse-white);border:1px solid #e5e9ef;box-shadow:0 12px 42px #0f172a12}.login-card .field__input{background:var(--synapse-input-bg);border-color:var(--synapse-input-border)}.login-card .field__input.field__input--muted{background:var(--synapse-input-bg-muted)}.login-card.register-card .field__input{background:var(--synapse-input-bg)}.auth-inline-cta{color:var(--synapse-primary);font-weight:700;text-decoration:none}.auth-inline-cta:hover{color:var(--synapse-primary-hover);text-decoration:underline}.login-card--auth{max-width:min(440px,100%)}.login-card.register-card{background:var(--synapse-register-card-bg);border:1px solid var(--synapse-border);max-width:min(540px,100%);padding:1.35rem 1.5rem 1.15rem}.login-card.register-card.login-card--surface{background:var(--synapse-white);border:1px solid #e5e9ef}.register-card__eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--synapse-primary);margin:0 0 .35rem;font-size:.68rem;font-weight:700}.register-card .login-card__title.register-card__title{margin-bottom:.35rem;font-size:clamp(1.45rem,2.5vw,1.7rem)}.login-card__title{color:var(--synapse-text);letter-spacing:-.02em;margin:0 0 .35rem;font-size:1.75rem;font-weight:700}.login-card--auth .field__label{color:var(--synapse-text);font-weight:600}.login-card.login-card--surface .field__label{color:#475569;font-weight:600}.login-card__subtitle{color:var(--synapse-text-muted);margin:0 0 1.25rem;font-size:.95rem}.login-card__title--hero{color:var(--synapse-auth-ink);letter-spacing:-.03em;font-size:clamp(1.65rem,3.2vw,2rem);line-height:1.15}.login-card__subtitle--hero{color:#64748b;max-width:36ch;margin-bottom:1.35rem;font-size:.9375rem;line-height:1.55}.login-form__row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;font-size:.875rem;display:flex}.checkbox{cursor:pointer;color:var(--synapse-text-muted);align-items:center;gap:.4rem;display:flex}.card-body{max-width:65%}.card-title{color:#1a202c;margin:0 0 .5rem;font-size:1.3rem;font-weight:700}.card-text{color:#718096;margin:0;font-size:.95rem;line-height:1.5}.content-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;padding:2rem;box-shadow:0 1px 3px #0000000d}.login-form__forgot{color:var(--synapse-primary);font-size:.875rem;font-weight:600;text-decoration:none}.login-form__forgot:hover{color:var(--synapse-primary-hover);text-decoration:underline}.login-form__row--remember{justify-content:flex-start;margin-bottom:1.35rem}.login-layout__footer-text{text-align:center;color:var(--synapse-text-muted);margin-top:auto;padding-top:2rem;font-size:.95rem}.login-layout__footer-text--auth{margin-top:1.75rem;padding-top:0;font-size:.9rem}.login-brand{background:var(--synapse-hero-bg);color:#fff;text-align:center;box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:clamp(1.5rem,4vw,2.5rem);display:flex}@media (width<=960px){.login-brand{min-height:min(320px,42vh);padding:1.75rem 1.25rem}.login-layout__form-side{min-height:0}}.login-brand__circle{background:#20917b;border:1px solid #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;margin-bottom:1.5rem;display:flex}.login-brand__brain{color:#fff;opacity:.95;width:72px;height:72px}.login-brand__headline{max-width:22ch;margin:0 0 .75rem;font-size:clamp(1.5rem,3vw,2rem);font-weight:700}.login-brand__text{opacity:.98;max-width:36ch;margin:0;font-size:.95rem;line-height:1.55}.login-brand__dots{align-items:center;gap:.5rem;margin-top:2rem;display:flex}.login-brand__dot{cursor:pointer;background:#ffffff73;border:none;border-radius:999px;width:8px;height:8px;padding:0;transition:width .2s,background .2s}.login-brand__dot--active{background:#fff;width:28px}.register-form .field:last-of-type{margin-bottom:.75rem}.register-form__grid2{grid-template-columns:1fr 1fr;gap:0 1rem;display:grid}@media (width<=520px){.register-form__grid2{grid-template-columns:1fr}}.register-form__policy-hint{color:var(--synapse-text-muted);margin:-.25rem 0 1rem;font-size:.75rem;line-height:1.4}.register-card__switch{text-align:center;color:var(--synapse-text-muted);border-top:1px solid #d4d2cf80;margin:1.25rem 0 0;padding-top:1rem;font-size:.9rem}.auth-footer{margin-top:auto;padding:1rem}.auth-footer__nav{color:var(--synapse-text-muted);flex-wrap:wrap;justify-content:center;gap:.35rem .75rem;font-size:.8rem;display:flex}.auth-footer__nav a{color:var(--synapse-text-muted);font-weight:400}.auth-footer__nav a:hover{color:var(--synapse-primary);text-decoration:underline}.auth-footer__sep{opacity:.5}.auth-legal-notice{color:var(--synapse-text-muted);text-align:center;margin:1.25rem 0 0;font-size:.75rem;line-height:1.5}.auth-legal-notice__link{color:inherit;text-underline-offset:2px;font-weight:500;text-decoration:underline}.auth-legal-notice__link:hover{color:var(--synapse-primary)}.legal-spa{background:var(--synapse-bg);flex-direction:column;height:100dvh;margin:0;display:flex}.legal-spa__bar{border-bottom:1px solid var(--synapse-border);background:var(--synapse-white);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1rem;display:flex}.legal-spa__back{font:inherit;color:var(--synapse-primary);cursor:pointer;background:0 0;border:none;border-radius:8px;margin:-.35rem;padding:.35rem .5rem;font-size:.9rem;font-weight:600}.legal-spa__back:hover{text-decoration:underline}.legal-spa__home{color:var(--synapse-text-muted);font-size:.875rem;font-weight:500;text-decoration:none}.legal-spa__home:hover{color:var(--synapse-primary);text-decoration:underline}.legal-spa__iframe{background:#f8fafc;border:0;flex:1;width:100%;min-height:0}.terms-modal-overlay{z-index:1000;background:#1e232873;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.terms-modal{background:var(--synapse-white);border-radius:var(--synapse-radius);box-shadow:var(--synapse-shadow-card);flex-direction:column;width:100%;max-width:520px;max-height:min(90vh,640px);padding:1.75rem clamp(1rem,3vw,1.75rem);display:flex}.terms-modal__header{margin-bottom:.75rem}.terms-modal__rule{background:var(--synapse-border);border:none;height:1px;margin:0 0 1rem}.terms-modal__brand{align-items:center;gap:.65rem;margin-bottom:1rem;display:flex}.terms-modal__brand-name{font-size:1.2rem;font-weight:700}.terms-modal__title{letter-spacing:-.02em;margin:0;font-size:1.35rem}.terms-modal__doc-link{text-align:center;margin:0 0 1rem;font-size:.85rem}.terms-modal__doc-link a{color:var(--synapse-primary);text-underline-offset:2px;font-weight:600;text-decoration:underline}.terms-modal__scroll{border:1px solid var(--synapse-border);border-radius:var(--synapse-radius-sm);flex:1;margin-bottom:1.25rem;padding:1rem;overflow-y:auto}.terms-modal__scroll::-webkit-scrollbar{width:8px}.terms-modal__scroll::-webkit-scrollbar-thumb{background:var(--synapse-primary);border-radius:4px}.terms-modal__list{color:var(--synapse-text-muted);margin:0;padding-left:1.25rem;font-size:.9rem;line-height:1.65}.terms-modal__date{color:var(--synapse-text-muted);margin:1rem 0 0;font-size:.85rem}.terms-modal__actions{gap:.75rem;margin-bottom:1rem;display:flex}.terms-modal__actions .btn{flex:1}.terms-modal__contact{text-align:center;color:var(--synapse-text-muted);margin:0;font-size:.9rem}.terms-modal__error-wrap{border-radius:var(--synapse-radius-sm);background:snow;border:1px solid #f1aeae;border-left:3px solid #c53030;margin:0 0 .75rem;padding:.75rem .9rem}.terms-modal__error-title{color:#742a2a;margin:0 0 .3rem;font-size:.8125rem;font-weight:600}.terms-modal__error{color:#9b2c2c;margin:0;font-size:.875rem;line-height:1.5}.form-alert{border-radius:var(--synapse-radius-sm);margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.form-alert--error{color:#b42318;background:#fef3f2;border:1px solid #fecdca}.dash{background:var(--synapse-bg);min-height:100vh;padding:0}.dashboard-container{background-color:var(--bg-main);width:100%;max-width:100vw;min-height:100vh;color:var(--primary-dark);display:flex}@media (width<=640px){.dashboard-container{overflow-x:clip}}.dash--with-sidebar{background-color:#f8fafc;width:100%;min-height:100vh;display:flex}.dash__content-area{background-color:#f7fafc;border-radius:8px;padding:1rem 0}.dash__shell{max-width:880px;margin:0 auto;padding:1.25rem clamp(1rem,4vw,2rem) 2.5rem}.dash__shell--fluid{background-color:#f8fafc}.dash__header{background-color:#fff;border-bottom:1px solid #e2e8f0;justify-content:center;width:100%;padding:.6rem 2rem;display:flex}.dash__header-brand{align-items:center;gap:.75rem;min-width:0;display:flex}.dash__subtitle{color:#64748b;margin:0;font-size:.8rem}.dash__main-card{background:var(--synapse-white);border-radius:var(--synapse-radius);border:1px solid var(--synapse-border);box-shadow:var(--synapse-shadow);padding:1.35rem 1.35rem 1.5rem}.dash__main-card--expanded{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex:1;width:100%;padding:2rem;box-shadow:0 4px 6px -1px #0000000d}.dash__lead{color:var(--synapse-text-muted);margin:0 0 1rem;font-size:.95rem;line-height:1.65}.dash__list{color:var(--synapse-text);margin:0;padding-left:1.2rem;font-size:.92rem;line-height:1.75}.dash__list li{margin-bottom:.35rem}.dash__note{color:var(--synapse-text-muted);border-radius:var(--synapse-radius-sm);border-left:3px solid var(--synapse-primary);background:#7fc2b524;margin-top:1.35rem;padding:.85rem 1rem;font-size:.82rem;line-height:1.45}.dash__header-container{justify-content:space-between;align-items:center;width:100%;max-width:1400px;display:flex}.dash__header-left{align-items:center;gap:1.5rem;display:flex}.dash__header-welcome{flex-direction:column;display:flex}.dash__header-right{align-items:center;gap:1.2rem;display:flex}.dash__header-sep{background-color:#e2e8f0;width:1px;height:28px}.dash__header-profile{align-items:center;gap:.8rem;display:flex}.dash__welcome-block{align-items:flex-start;gap:1rem;margin:2.5rem 0 1.5rem;display:flex}.user-details{text-align:right;flex-direction:column;display:flex}.user-profile-group{align-items:center;gap:1.5rem;display:flex}.user-badge{border-left:1px solid var(--border-color);align-items:center;gap:10px;padding-left:1rem;display:flex}button.user-badge--trigger{appearance:none;font:inherit;text-align:left;cursor:pointer;border:none;border-left:1px solid var(--border-color);background:0 0;border-radius:0;margin:0;padding-left:1rem}button.user-badge--trigger:focus-visible{border-radius:8px;outline:none;box-shadow:inset 0 0 0 2px #20917b73}.user-badge__text{text-align:left;flex-direction:column;gap:.1rem;min-width:0;line-height:1.2;display:flex}.user-badge__text .user-name{font-size:.875rem;font-weight:700;display:block}.user-badge__text .user-role{display:block}.user-name{font-size:.85rem;font-weight:600}.user-role{color:#94a3b8;font-size:.7rem}.user-avatar{border:1px solid var(--synapse-primary);background-color:#dcfce7;border-radius:50%;width:36px;height:36px}.avatar-circle{background-color:var(--teal-light);width:35px;height:35px;color:var(--teal-main);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.section-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.section-title{color:#2d3748;margin:0;font-size:1.1rem;font-weight:600}.search-group{flex:1;max-width:600px;position:relative}.search-group__icon{color:#94a3b8;pointer-events:none;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.search-group__input{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:12px 16px 12px 48px;font-size:14px;transition:all .2s}.search-group__input:focus{border-color:#4f46e5;outline:none;box-shadow:0 0 0 3px #4f46e51a}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.stat-card__label{color:#64748b;font-size:.875rem;font-weight:500}.stat-card__value{color:#1e293b;margin-top:.5rem;font-size:1.875rem;font-weight:700}.icon-assignments{color:var(--synapse-primary);font-size:1.3rem}.highlight-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;justify-content:space-between;align-items:center;padding:2.5rem;display:flex;box-shadow:0 2px 4px #0000000a}.prof-sidebar{background-color:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:280px;height:100vh;padding:2rem 1rem;display:flex;position:sticky;top:0}.prof-sidebar__nav{flex-direction:column;gap:.5rem;margin-top:2rem;display:flex}.prof-sidebar__footer{border-top:1px solid #f1f5f9;margin-top:auto;padding:1rem}.prof-content__topbar{justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2rem;display:flex}.nav-btn{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;padding:.875rem 1rem;font-weight:500;transition:all .2s;display:flex}.nav-btn:hover{color:#1e293b;background-color:#f1f5f9}.nav-btn--active{color:#4f46e5;background-color:#eef2ff}.nav-btn__icon{font-size:1.25rem}.main-content{isolation:isolate;flex-direction:column;flex:1;min-width:0;padding:2rem 4rem;display:flex}@media (width<=768px){.main-content{padding:1.25rem max(1rem, env(safe-area-inset-left,0px)) 1.25rem max(1rem, env(safe-area-inset-right,0px));padding-bottom:max(1.25rem, env(safe-area-inset-bottom,0px))}}@media (width<=480px){.main-content{padding:1.1rem max(.85rem, env(safe-area-inset-left,0px)) 1rem max(.85rem, env(safe-area-inset-right,0px));padding-bottom:max(1rem, env(safe-area-inset-bottom,0px))}}.metrics-grid{grid-template-columns:1fr;gap:2rem;width:100%;margin-bottom:3rem;display:grid}@media (width<=640px){.metrics-grid{gap:1rem;margin-bottom:1.5rem}}.metric-card{background:var(--white);border:1px solid var(--border-color);box-sizing:border-box;border-radius:20px;flex-direction:column;gap:.35rem;width:100%;padding:2rem;display:flex}.data-card{background:var(--white);border:1px solid var(--border-color);border-radius:24px;padding:2.5rem;box-shadow:0 4px 6px -1px #0000000d}.data-card__title{color:var(--primary-dark);margin:0 0 1.25rem;font-size:clamp(1.05rem,3.2vw,1.25rem);font-weight:700;line-height:1.3}@media (width<=480px){.data-card__title{margin-bottom:1rem}}.metric-card__meta{color:var(--text-muted);font-size:.85rem;font-weight:600;display:block}@media (width<=640px){.data-card{border-radius:18px;padding:1.25rem 1rem}.metric-card{border-radius:16px;padding:1.35rem 1.15rem}.metric-card__meta{letter-spacing:.02em;font-size:.8rem}}.dash-filter-row{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.dash-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.dash-toolbar .btn{flex-shrink:0}.dash-page-head{margin-bottom:2rem}@media (width<=640px){.dash-page-head{margin-bottom:1.35rem}}.dash-page-title{word-wrap:break-word;margin:0;font-size:clamp(1.35rem,4.2vw,2rem);font-weight:800;line-height:1.2}.dash-page-lead{color:var(--text-muted);max-width:65ch;margin:.35rem 0 0;font-size:clamp(.875rem,2.8vw,1rem);line-height:1.45}.dash-stat-xl{font-size:clamp(1.5rem,6vw,2.5rem);font-weight:800}.time-interval-row{flex-wrap:nowrap;align-items:center;gap:12px;display:flex}.time-interval-inputs{grid-template-columns:minmax(2.4rem,1fr) auto minmax(2.4rem,1fr) auto minmax(2.4rem,1fr);align-items:center;gap:6px;width:100%;max-width:min(280px,100%);display:grid}.time-interval-digit{box-sizing:border-box;text-align:center;border:1px solid var(--border-color,#e2e8f0);background:#fff;border-radius:10px;width:100%;min-width:0;padding:.65rem .35rem;font-family:ui-monospace,monospace;font-size:clamp(.95rem,3.2vw,1.25rem);font-weight:600}.time-interval-sep{color:#94a3b8;-webkit-user-select:none;user-select:none;padding:0 1px;font-size:clamp(1.05rem,3.5vw,1.5rem);line-height:1}@media (width<=380px){.time-interval-row{flex-direction:column;align-items:stretch;gap:10px}.time-interval-row>div:first-child{align-self:center}.time-interval-inputs{justify-content:center;max-width:100%}}.custom-table{border-collapse:collapse;width:100%}@media (width<=768px){.custom-table--min-wide{min-width:520px}.custom-table--min-xwide{min-width:720px}}.custom-table thead tr{text-align:left;background-color:var(--table-header);border-bottom:2px solid var(--border-color)}.custom-table th{color:var(--text-muted);text-transform:uppercase;padding:1rem;font-size:.85rem}.custom-table td{border-bottom:1px solid var(--bg-main);padding:1.25rem 1rem}@media (width<=480px){.custom-table th,.custom-table td{padding:.65rem .45rem;font-size:.8125rem}.custom-table th{font-size:.7rem}}.btn-teal{background-color:var(--teal-main);color:var(--white);cursor:pointer;border:none;border-radius:12px;padding:12px 24px;font-weight:700}.btn-logout{color:var(--danger);cursor:pointer;background:0 0;border:none;font-size:.9rem;font-weight:600}.btn-back{color:var(--teal-main);cursor:pointer;touch-action:manipulation;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:2rem;font-weight:700;display:flex}@media (width<=640px){.btn-back{margin-bottom:1.25rem;font-size:.9rem}}@media (width<=768px){.topbar{flex-wrap:nowrap;align-items:center;gap:.5rem;margin-bottom:1.35rem}.brand-logo__text{letter-spacing:-.03em;font-size:clamp(1.05rem,4vw,1.3rem)}.user-profile-group{flex-wrap:nowrap;flex:1;justify-content:flex-end;gap:.35rem;width:auto;min-width:0;max-width:100%}.user-badge{gap:8px;min-width:0;padding-left:.65rem}button.user-badge--trigger{border-radius:10px;min-height:44px;padding-left:.65rem}.avatar-circle{width:32px;height:32px;font-size:.9rem}.user-badge__text .user-name,.user-name{text-overflow:ellipsis;white-space:nowrap;max-width:min(140px,38vw);overflow:hidden}}@media (width<=380px){.user-badge__text .user-name,.user-name{max-width:min(100px,32vw)}}@media (width<=640px){.topbar-popover{left:max(.75rem, env(safe-area-inset-left,0px));right:max(.75rem, env(safe-area-inset-right,0px));top:calc(env(safe-area-inset-top,0px) + 4.1rem);z-index:9999;border-radius:16px;max-width:none;margin-top:0;position:fixed;box-shadow:0 0 0 1px #0f172a0f,0 8px 24px -4px #0f172a1f,0 20px 48px -12px #0f172a2e;width:auto!important}.topbar-popover--notifications,.topbar-popover--profile{width:auto!important}.topbar-popover__title{padding:.9rem 1rem;font-size:.9rem}.topbar-popover__body{text-align:center;padding:1.15rem 1.1rem 1.3rem;font-size:.94rem}.topbar-popover__item{align-items:center;min-height:48px;padding:.85rem 1rem;display:flex}}.summary-grid{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem;display:grid}.summary-grid--3{grid-template-columns:repeat(3,1fr)}@media (width<=900px){.summary-grid--3{grid-template-columns:1fr 1fr}}@media (width<=480px){.summary-grid,.summary-grid--3{grid-template-columns:1fr}}.dash-entity-card{border:1px solid var(--border-color,#e2e8f0);background-color:#f8fafc;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;transition:border-color .15s,background-color .15s;display:flex}.dash-entity-card__main{flex:12rem;min-width:0}.dash-entity-card--clickable{cursor:pointer}.dash-entity-card--clickable:hover{border-color:var(--teal-main);background-color:#00b4a008}.dash-entity-card__title{color:var(--primary-dark);margin:0;font-size:.95rem;font-weight:700}.dash-entity-card__subtitle{color:var(--text-muted);margin:.25rem 0 0;font-size:.8rem}.dash-entity-card__id{color:var(--teal-main);font-family:ui-monospace,monospace;font-size:.85rem;font-weight:700}.dash-entity-card__meta{color:var(--teal-main);align-items:center;gap:5px;margin:.35rem 0 0;font-size:.78rem;font-weight:600;display:flex}.dash-entity-card__side{flex-shrink:0;align-items:center;gap:.75rem;display:flex}@media (width<=640px){.dash-entity-card{align-items:stretch}.dash-entity-card__main{flex:100%;width:100%}.dash-entity-card__side{flex:100%;justify-content:space-between;width:100%}}.dash-entity-card__badge{color:var(--teal-main);background-color:#00b4a014;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.dash-entity-card__icon-btn{min-width:44px;min-height:44px;color:var(--secondary-slate);cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;margin:-.35rem;padding:.35rem;transition:background .15s,color .15s;display:inline-flex}.dash-entity-card__icon-btn:hover{color:var(--teal-main);background:#94a3b826}.badge{border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600;line-height:1.25;display:inline-block}.dash-pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;display:flex}.metrics-grid--3col{grid-template-columns:repeat(3,1fr)}@media (width<=640px){.metrics-grid--3col{grid-template-columns:1fr}}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-scroll-wrap{margin-bottom:.25rem;position:relative}.table-scroll--affordance{scrollbar-width:thin;scrollbar-color:#94a3b8a6 transparent;background:#fff;border:1px solid #e2e8f0f2;border-radius:12px}.table-scroll--affordance::-webkit-scrollbar{height:7px}.table-scroll--affordance::-webkit-scrollbar-thumb{background:#94a3b88c;border-radius:99px}.table-scroll--affordance::-webkit-scrollbar-track{background:#f1f5f9cc;border-radius:99px}@media (width<=640px){.table-scroll--affordance{box-shadow:inset -36px 0 28px -28px #f8fafcf7}}.table-scroll-hint{color:var(--text-muted);background:#20917b14;border:1px solid #20917b2e;border-radius:10px;align-items:center;gap:.45rem;margin:.55rem 0 0;padding:.45rem .65rem;font-size:.78rem;font-weight:600;line-height:1.35;display:none}.table-scroll-hint__icon{width:1.65rem;height:1.65rem;color:var(--teal-main);background:#ffffffd9;border:1px solid #20917b33;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:800;display:inline-flex}@media (width<=768px){.table-scroll-hint{display:flex}}.assign-config-card{background:linear-gradient(#fff 0%,#f8fafc 100%);border:1px solid #e2e8f0f2;box-shadow:0 1px 3px #0f172a0d}.assign-config__field-label{letter-spacing:.06em;color:var(--text-muted);margin-bottom:.55rem;font-size:.72rem;font-weight:700;display:block}.assign-config__field-label span{letter-spacing:normal;text-transform:none;font-weight:500}.assign-config__datetime{border:1px solid var(--border-color,#e2e8f0);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;width:100%;padding:.8rem 1rem;font-size:.95rem;box-shadow:inset 0 1px 2px #0f172a0a}.assign-config__datetime:focus{border-color:var(--teal-main);box-shadow:inset 0 1px 2px #0f172a0a,0 0 0 3px #20917b33}.assign-config__hint{color:var(--text-muted);margin:.5rem 0 0;font-size:.75rem;line-height:1.45}.assign-config__actions{border-top:1px solid #e2e8f0f2;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;display:flex}@media (width<=480px){.assign-config__actions{flex-direction:column-reverse;align-items:stretch}.assign-config__actions .btn{justify-content:center;width:100%}}.tpl-option-row{border:1px solid var(--border-color,#e2e8f0);background-color:#f8fafc;border-radius:10px;grid-template-columns:1fr 2fr auto;align-items:end;gap:.75rem;padding:1rem;display:grid}@media (width<=640px){.tpl-option-row{grid-template-columns:1fr}.tpl-option-row__delete{justify-self:end}}.config-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}@media (width<=520px){.config-grid{grid-template-columns:1fr}.highlight-card{flex-wrap:wrap;gap:1rem}.card-body{max-width:100%}}
