.rof-modal__overlay{align-items:center;animation:rof-fade-in var(--rof-transition-base);background-color:var(--rof-color-bg-overlay);display:flex;justify-content:center;inset:0;position:fixed;z-index:var(--rof-z-modal-backdrop)}@keyframes rof-fade-in{0%{opacity:0}to{opacity:1}}.rof-modal__container{animation:rof-slide-up var(--rof-transition-base);background-color:var(--rof-color-bg);border-radius:var(--rof-radius-md);box-shadow:var(--rof-shadow-modal);margin:0 var(--rof-spacing-lg);max-height:90vh;max-width:450px;overflow-y:auto;padding:var(--rof-spacing-xl);position:relative;width:100%;z-index:var(--rof-z-modal)}@keyframes rof-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.rof-modal--small .rof-modal__container{max-width:350px}.rof-modal--medium .rof-modal__container{max-width:450px}.rof-modal--large .rof-modal__container{max-width:650px}.rof-modal--xlarge .rof-modal__container{max-width:900px}.rof-modal--fullscreen .rof-modal__container{height:calc(100% - var(--rof-spacing-xl)*2);max-height:calc(100% - var(--rof-spacing-xl)*2);max-width:none;width:calc(100% - var(--rof-spacing-xl)*2)}.rof-modal__close{background:transparent;border:none;color:var(--rof-color-gray-600);cursor:pointer;font-size:var(--rof-font-size-xl);line-height:1;padding:var(--rof-spacing-xs);position:absolute;right:var(--rof-spacing-lg);top:var(--rof-spacing-lg);transition:color var(--rof-transition-fast);z-index:1}.rof-modal__close:hover{color:var(--rof-color-gray-800)}.rof-modal__close:focus{border-radius:var(--rof-radius-sm);outline:2px solid var(--rof-color-primary);outline-offset:2px}@media(max-width:640px){.rof-modal__container{border-radius:0;margin:0;max-height:100vh;max-width:none;width:100%}.rof-modal--large .rof-modal__container,.rof-modal--medium .rof-modal__container,.rof-modal--small .rof-modal__container{max-width:none}}@media(prefers-reduced-motion:reduce){.rof-modal__container,.rof-modal__overlay{animation:none}}.rof-form{width:100%}.rof-form__header{border-bottom:1px solid var(--rof-color-border-light);margin-bottom:var(--rof-spacing-xl);padding-bottom:var(--rof-spacing-lg)}.rof-form__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-xl);font-weight:var(--rof-font-weight-semibold);line-height:var(--rof-line-height-tight);margin:0 0 var(--rof-spacing-xs) 0}.rof-form__subtitle{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-normal);margin:0}.rof-form__content{display:flex;flex-direction:column;gap:var(--rof-spacing-lg)}.rof-form__group{display:flex;flex-direction:column;gap:var(--rof-spacing-xs)}.rof-form__group--inline{align-items:center;flex-direction:row;gap:var(--rof-spacing-md)}.rof-form__group--required .rof-form__label:after{color:var(--rof-color-danger);content:" *"}.rof-form__label{color:var(--rof-color-gray-700);display:block;font-size:var(--rof-font-size-sm);font-weight:var(--rof-font-weight-medium);line-height:var(--rof-line-height-normal)}.rof-form__label--disabled{cursor:not-allowed;opacity:.6}.rof-form__help{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-xs);line-height:var(--rof-line-height-normal);margin-top:var(--rof-spacing-xs)}.rof-form__input,.rof-form__select,.rof-form__textarea{background-color:var(--rof-color-bg);border:1px solid var(--rof-color-border-medium);border-radius:var(--rof-radius-sm);box-sizing:border-box;color:var(--rof-color-gray-800);font-family:inherit;font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-normal);padding:var(--rof-spacing-sm) var(--rof-spacing-md);transition:border-color var(--rof-transition-fast),box-shadow var(--rof-transition-fast);width:100%}.rof-form__input::placeholder,.rof-form__textarea::placeholder{color:var(--rof-color-gray-500)}.rof-form__input:focus,.rof-form__select:focus,.rof-form__textarea:focus{border-color:var(--rof-color-primary);box-shadow:0 0 0 3px var(--rof-color-primary-light);outline:none}.rof-form__input--error,.rof-form__select--error,.rof-form__textarea--error{border-color:var(--rof-color-error)}.rof-form__input--error:focus,.rof-form__select--error:focus,.rof-form__textarea--error:focus{box-shadow:0 0 0 3px var(--rof-color-error-bg)}.rof-form__input:disabled,.rof-form__select:disabled,.rof-form__textarea:disabled{background-color:var(--rof-color-gray-100);cursor:not-allowed;opacity:.6}.rof-form__textarea{min-height:100px;resize:vertical}.rof-form__select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23333' d='M10.293 3.293 6 7.586 1.707 3.293A1 1 0 0 0 .293 4.707l5 5a1 1 0 0 0 1.414 0l5-5a1 1 0 1 0-1.414-1.414z'/%3E%3C/svg%3E");background-position:right var(--rof-spacing-md) center;background-repeat:no-repeat;padding-right:var(--rof-spacing-2xl)}.rof-form__checkbox,.rof-form__radio{cursor:pointer;margin-right:var(--rof-spacing-sm);width:auto}.rof-form__checkbox:disabled,.rof-form__radio:disabled{cursor:not-allowed}.rof-form__footer{align-items:center;border-top:1px solid var(--rof-color-border-light);display:flex;gap:var(--rof-spacing-sm);justify-content:flex-end;margin-top:var(--rof-spacing-xl);padding-top:var(--rof-spacing-lg)}.rof-form__footer--spread{justify-content:space-between}.rof-form__footer--center{justify-content:center}@media(max-width:640px){.rof-form__footer{flex-direction:column-reverse;gap:var(--rof-spacing-md)}.rof-form__footer .rof-btn{width:100%}.rof-form__group--inline{align-items:flex-start;flex-direction:column}}.rof-form__input-group{display:flex;width:100%}.rof-form__input-group .rof-form__input{border-radius:0;border-right:none}.rof-form__input-group .rof-form__input:first-child{border-bottom-left-radius:var(--rof-radius-sm);border-top-left-radius:var(--rof-radius-sm)}.rof-form__input-group .rof-form__input:last-child{border-bottom-right-radius:var(--rof-radius-sm);border-right:1px solid var(--rof-color-border-medium);border-top-right-radius:var(--rof-radius-sm)}.rof-form__input-addon{align-items:center;background-color:var(--rof-color-gray-100);border:1px solid var(--rof-color-border-medium);color:var(--rof-color-gray-700);display:flex;font-size:var(--rof-font-size-sm);padding:var(--rof-spacing-sm) var(--rof-spacing-md);white-space:nowrap}.rof-form__input-addon:first-child{border-bottom-left-radius:var(--rof-radius-sm);border-right:none;border-top-left-radius:var(--rof-radius-sm)}.rof-form__input-addon:last-child{border-bottom-right-radius:var(--rof-radius-sm);border-left:none;border-top-right-radius:var(--rof-radius-sm)}.rof-btn{align-items:center;border:none;border-radius:4px;box-sizing:border-box;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:400;gap:var(--rof-spacing-sm);height:36px;justify-content:center;line-height:20px;padding:8px 16px;text-align:center;text-decoration:none;transition:background-color .2s,opacity .2s;-webkit-user-select:none;user-select:none;white-space:nowrap}.rof-btn:focus{outline:2px solid var(--rof-color-primary);outline-offset:2px}.rof-btn:focus:not(:focus-visible){outline:none}.rof-btn:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.rof-btn--primary{background-color:var(--rof-color-primary);color:var(--rof-color-white)}.rof-btn--primary:hover:not(:disabled){background-color:var(--rof-color-primary-hover)}.rof-btn--secondary{background-color:var(--rof-color-secondary);border:1px solid var(--rof-color-border-medium);color:var(--rof-color-secondary-foreground)}.rof-btn--secondary:hover:not(:disabled){background-color:var(--rof-color-secondary-hover);color:var(--rof-color-black)}.rof-btn--danger{background-color:var(--rof-color-danger);color:var(--rof-color-white)}.rof-btn--danger:hover:not(:disabled){background-color:var(--rof-color-danger-hover)}.rof-btn--success{background-color:var(--rof-color-success);color:var(--rof-color-white)}.rof-btn--success:hover:not(:disabled){background-color:var(--rof-color-success-hover)}.rof-btn--ghost{background-color:transparent;border-color:transparent;color:var(--rof-color-primary)}.rof-btn--ghost:hover:not(:disabled){background-color:var(--rof-color-primary-light)}.rof-btn--sm{font-size:var(--rof-font-size-xs);padding:6px var(--rof-spacing-md)}.rof-btn--lg{font-size:var(--rof-font-size-base);padding:var(--rof-spacing-md) var(--rof-spacing-xl)}.rof-btn--icon{aspect-ratio:1;padding:var(--rof-spacing-sm)}.rof-btn--loading{color:transparent;pointer-events:none;position:relative}.rof-btn--loading:after{animation:rof-spin .6s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid transparent;content:"";height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}.rof-btn--block{display:flex;width:100%}.rof-error--field{align-items:flex-start;color:var(--rof-color-error);display:flex;font-size:var(--rof-font-size-xs);gap:var(--rof-spacing-xs);line-height:var(--rof-line-height-tight);margin-top:var(--rof-spacing-xs);padding:var(--rof-spacing-xs) 0}.rof-error--field:before{content:"⚠";flex-shrink:0;font-size:var(--rof-font-size-sm)}.rof-error--banner{align-items:flex-start;background-color:var(--rof-color-error-bg);border:1px solid var(--rof-color-error-border);border-left:4px solid var(--rof-color-error);border-radius:var(--rof-radius-sm);color:var(--rof-color-error);display:flex;gap:var(--rof-spacing-md);margin-bottom:var(--rof-spacing-lg);padding:var(--rof-spacing-md) var(--rof-spacing-lg)}.rof-error--banner:before{content:"⚠";flex-shrink:0;font-size:var(--rof-font-size-xl);line-height:1}.rof-error--inline{align-items:center;background-color:var(--rof-color-error-bg);border-radius:var(--rof-radius-sm);color:var(--rof-color-error);display:inline-flex;font-size:var(--rof-font-size-sm);gap:var(--rof-spacing-xs);padding:var(--rof-spacing-xs) var(--rof-spacing-sm)}.rof-error-container{align-items:center;display:flex;flex-direction:column;justify-content:center;margin:var(--rof-spacing-xl) 0;padding:var(--rof-spacing-3xl) var(--rof-spacing-xl);text-align:center}.rof-error__icon{color:var(--rof-color-error);font-size:64px;height:64px;line-height:1;margin-bottom:var(--rof-spacing-lg);width:64px}.rof-error__title{color:var(--rof-color-error);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-sm) 0}.rof-error__message{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-normal);margin:0 0 var(--rof-spacing-xl) 0;max-width:400px}.rof-error__actions{display:flex;flex-wrap:wrap;gap:var(--rof-spacing-sm);justify-content:center}.rof-error--toast{align-items:center;animation:rof-slide-in-right var(--rof-transition-base);background-color:var(--rof-color-bg);border:1px solid var(--rof-color-error-border);border-left:4px solid var(--rof-color-error);border-radius:var(--rof-radius-sm);box-shadow:var(--rof-shadow-lg);display:flex;gap:var(--rof-spacing-md);max-width:400px;padding:var(--rof-spacing-md) var(--rof-spacing-lg);position:fixed;right:var(--rof-spacing-xl);top:var(--rof-spacing-xl);z-index:var(--rof-z-tooltip)}@keyframes rof-slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.rof-error--toast .rof-error__message{color:var(--rof-color-error);margin:0}.rof-error--warning{background-color:#fffbeb;border-color:#fde68a;color:var(--rof-color-warning)}.rof-error--info{background-color:#eff6ff;border-color:#bfdbfe;color:var(--rof-color-info)}.rof-error--success{background-color:#f0fdf4;border-color:#bbf7d0;color:var(--rof-color-success)}@media(max-width:640px){.rof-error--toast{left:var(--rof-spacing-sm);max-width:none;right:var(--rof-spacing-sm)}}.rof-patient-form__age-help{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-xs);margin-top:var(--rof-spacing-xs)}.rof-patient-form__age-help:before{content:"ℹ️ "}.rof-table{background-color:var(--rof-color-bg);border-collapse:collapse;margin-top:var(--rof-spacing-xl);width:100%}.rof-table__header{border-bottom:2px solid var(--rof-color-border-dark);text-align:left}.rof-table__header-cell{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-sm);font-weight:var(--rof-font-weight-semibold);letter-spacing:.025em;padding:var(--rof-spacing-md) var(--rof-spacing-sm);white-space:nowrap}.rof-table__body{background-color:var(--rof-color-bg)}.rof-table__row{border-bottom:1px solid var(--rof-color-border-light);transition:background-color var(--rof-transition-fast)}.rof-table__row--clickable{cursor:pointer}.rof-table__row--clickable:hover{background-color:transparent}.rof-table__row--selected{background-color:var(--rof-color-primary-light)}.rof-table__row--disabled{opacity:.5;pointer-events:none}.rof-table__cell{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-sm);padding:var(--rof-spacing-md) var(--rof-spacing-sm);vertical-align:middle}.rof-table__cell--actions{align-items:center;display:flex;flex-wrap:nowrap;gap:var(--rof-spacing-sm)}.rof-table__cell--numeric{font-variant-numeric:tabular-nums;text-align:right}.rof-table__cell--center{text-align:center}.rof-table__empty{padding:var(--rof-spacing-3xl) var(--rof-spacing-xl);text-align:center}.rof-table__empty-message{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm)}@media(max-width:768px){.rof-table{font-size:var(--rof-font-size-xs)}.rof-table__cell,.rof-table__header-cell{padding:var(--rof-spacing-sm) var(--rof-spacing-xs)}.rof-table__cell--actions{align-items:stretch;flex-direction:column}}.rof-table--striped .rof-table__row:nth-child(2n){background-color:var(--rof-color-gray-50)}.rof-table--bordered{border:1px solid var(--rof-color-border-medium);border-radius:var(--rof-radius-sm);overflow:hidden}.rof-table--bordered .rof-table__cell,.rof-table--bordered .rof-table__header-cell{border-right:1px solid var(--rof-color-border-light)}.rof-table--bordered .rof-table__cell:last-child,.rof-table--bordered .rof-table__header-cell:last-child{border-right:none}.rof-table--compact .rof-table__cell,.rof-table--compact .rof-table__header-cell{padding:var(--rof-spacing-xs) var(--rof-spacing-sm)}.rof-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;margin:var(--rof-spacing-xl) 0;padding:var(--rof-spacing-3xl) var(--rof-spacing-xl);text-align:center}.rof-empty-state__icon{color:var(--rof-color-gray-400);font-size:64px;height:64px;line-height:1;margin-bottom:var(--rof-spacing-lg);width:64px}.rof-empty-state__icon svg{height:100%;width:100%}.rof-empty-state__title{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-semibold);line-height:var(--rof-line-height-tight);margin:0 0 var(--rof-spacing-sm) 0}.rof-empty-state__message{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-normal);margin:0 0 var(--rof-spacing-xl) 0;max-width:400px}.rof-empty-state__action{margin-top:var(--rof-spacing-md)}.rof-empty-state--small{padding:var(--rof-spacing-xl) var(--rof-spacing-lg)}.rof-empty-state--small .rof-empty-state__icon{font-size:48px;height:48px;margin-bottom:var(--rof-spacing-md);width:48px}.rof-empty-state--small .rof-empty-state__title{font-size:var(--rof-font-size-base)}.rof-empty-state--small .rof-empty-state__message{font-size:var(--rof-font-size-xs)}.rof-empty-state--large{padding:var(--rof-spacing-3xl) var(--rof-spacing-2xl)}.rof-empty-state--large .rof-empty-state__icon{font-size:96px;height:96px;margin-bottom:var(--rof-spacing-xl);width:96px}.rof-empty-state--large .rof-empty-state__title{font-size:var(--rof-font-size-2xl)}.rof-empty-state--subtle{background-color:var(--rof-color-gray-50);border-radius:var(--rof-radius-md)}.rof-empty-state--bordered{border:2px dashed var(--rof-color-border-medium);border-radius:var(--rof-radius-md)}@media(max-width:640px){.rof-empty-state{padding:var(--rof-spacing-xl) var(--rof-spacing-lg)}.rof-empty-state__icon{font-size:48px;height:48px;width:48px}.rof-empty-state__title{font-size:var(--rof-font-size-base)}.rof-empty-state__message{font-size:var(--rof-font-size-xs)}}.rof-patient-list{width:100%}.rof-patient-list__header{margin-bottom:var(--rof-spacing-lg)}.rof-patient-list__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-2xl);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-lg) 0}.rof-patient-list__actions{align-items:center;display:flex;gap:var(--rof-spacing-sm);margin-bottom:var(--rof-spacing-lg)}.rof-patient-list--loading{opacity:.6;pointer-events:none}.rof-patient-list__loading{align-items:center;color:var(--rof-color-gray-600);display:flex;flex-direction:column;justify-content:center;padding:var(--rof-spacing-3xl)}.rof-patient-list__loading-spinner{animation:rof-spin .8s linear infinite;border:3px solid var(--rof-color-border-light);border-radius:50%;border-top-color:var(--rof-color-primary);height:40px;margin-bottom:var(--rof-spacing-md);width:40px}@media(max-width:640px){.rof-patient-list__header{align-items:flex-start;flex-direction:column;gap:var(--rof-spacing-md)}.rof-patient-list__actions{width:100%}.rof-patient-list__actions .rof-btn{flex:1}}.rof-questionnaire{background-color:var(--rof-color-bg);border-radius:var(--rof-radius-md);box-shadow:0 2px 8px #0000001a;padding:var(--rof-spacing-2xl)}.rof-questionnaire__header{margin-bottom:var(--rof-spacing-2xl)}.rof-questionnaire__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-2xl);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-sm) 0}.rof-questionnaire__description{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-base);line-height:var(--rof-line-height-relaxed);margin:0}.rof-questionnaire__question-group{border-bottom:1px solid var(--rof-color-border-light);margin-bottom:var(--rof-spacing-2xl);padding-bottom:var(--rof-spacing-xl)}.rof-questionnaire__question-group:last-of-type{border-bottom:none}.rof-questionnaire__question{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-base);font-weight:var(--rof-font-weight-medium);margin-bottom:var(--rof-spacing-md)}.rof-questionnaire__answer-options{display:flex;gap:var(--rof-spacing-2xl)}.rof-questionnaire__answer-option{align-items:center;cursor:pointer;display:flex;transition:opacity var(--rof-transition-fast)}.rof-questionnaire__answer-option:hover{opacity:.8}.rof-questionnaire__answer-option input{cursor:pointer;margin-right:var(--rof-spacing-sm)}.rof-questionnaire__answer-option input:disabled{cursor:not-allowed}.rof-questionnaire__answer-option span{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-sm)}.rof-questionnaire__scale-options{display:flex;flex-direction:column;gap:var(--rof-spacing-md)}.rof-questionnaire__scale-option{align-items:center;border-radius:var(--rof-radius-sm);cursor:pointer;display:flex;padding:var(--rof-spacing-sm);transition:background-color var(--rof-transition-fast)}.rof-questionnaire__scale-option:hover{background-color:var(--rof-color-bg-hover)}.rof-questionnaire__scale-option input{cursor:pointer;margin-right:var(--rof-spacing-sm)}.rof-questionnaire__scale-option input:disabled{cursor:not-allowed}.rof-questionnaire__scale-option span{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-sm)}.rof-questionnaire__actions{display:flex;gap:var(--rof-spacing-md);justify-content:space-between;margin-top:var(--rof-spacing-3xl)}.rof-questionnaire__deprecation-banner{align-items:center;background-color:#fff3cd;border:1px solid #ffc107;border-radius:var(--rof-radius-sm);display:flex;gap:var(--rof-spacing-md);margin-bottom:var(--rof-spacing-xl);padding:var(--rof-spacing-md) var(--rof-spacing-lg)}.rof-questionnaire__deprecation-icon{flex-shrink:0;font-size:20px}.rof-questionnaire__deprecation-text{color:#856404;flex:1;font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-relaxed)}.rof-questionnaire__deprecation-text strong{font-weight:var(--rof-font-weight-semibold)}@media(max-width:640px){.rof-questionnaire{padding:var(--rof-spacing-lg)}.rof-questionnaire__answer-options{flex-direction:column;gap:var(--rof-spacing-md)}.rof-questionnaire__actions{flex-direction:column-reverse}.rof-questionnaire__actions .rof-btn{width:100%}}.rof-test{padding:var(--rof-spacing-xl)}.rof-test__header{margin-bottom:var(--rof-spacing-xl)}.rof-test__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-2xl);font-weight:var(--rof-font-weight-semibold);margin-bottom:var(--rof-spacing-xs)}.rof-test__subtitle{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm)}.rof-test__content{background-color:var(--rof-color-bg);border-radius:var(--rof-radius-md);box-shadow:0 2px 6px #0000001a;margin-bottom:var(--rof-spacing-xl);padding:var(--rof-spacing-xl)}.rof-test__interactive-container{background-color:var(--rof-color-bg-secondary);border:1px solid var(--rof-color-border-light);border-radius:var(--rof-radius-md);margin:var(--rof-spacing-xl) 0;min-height:480px;overflow:hidden;position:relative;width:100%}.rof-test__interactive-container--visible{display:block!important;visibility:visible!important}.rof-test__interactive-container--hidden{display:none!important}.rof-test__instructions{margin-bottom:var(--rof-spacing-xl)}.rof-test__instructions-title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-medium);margin-bottom:var(--rof-spacing-md)}.rof-test__instructions-list{margin:var(--rof-spacing-md) 0;padding-left:var(--rof-spacing-xl)}.rof-test__instructions-item{color:var(--rof-color-gray-700);line-height:var(--rof-line-height-relaxed);margin-bottom:var(--rof-spacing-sm)}.rof-test__panel{border-left:4px solid;border-radius:var(--rof-radius-sm);margin-bottom:var(--rof-spacing-xl);padding:var(--rof-spacing-lg)}.rof-test__panel--running{background-color:#f8f9fa;border-color:#17a2b8}.rof-test__panel--success{background-color:#d4edda;border-color:#28a745;color:#155724}.rof-test__panel--error{background-color:#f8d7da;border-color:#dc3545;color:#721c24}.rof-test__panel--info{background-color:#f8f9fa;border-color:#17a2b8;color:var(--rof-color-gray-800)}.rof-test__panel-title{font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-sm) 0}.rof-test__panel-text{line-height:var(--rof-line-height-relaxed);margin:var(--rof-spacing-sm) 0}.rof-test__actions{align-items:center;display:flex;gap:var(--rof-spacing-md);justify-content:space-between;margin-top:var(--rof-spacing-xl)}.rof-test__loading{padding:var(--rof-spacing-2xl);text-align:center}.rof-test__spinner{animation:rof-spin 1s linear infinite;border:4px solid var(--rof-color-border-light);border-radius:50%;border-top-color:var(--rof-color-primary);height:40px;margin:0 auto var(--rof-spacing-md);width:40px}.rof-test__loading-message{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm)}.rof-test__placeholder{padding:var(--rof-spacing-3xl) var(--rof-spacing-xl);text-align:center}.rof-test__placeholder-title{color:#2c4f7c;font-size:var(--rof-font-size-xl);font-weight:var(--rof-font-weight-medium);margin-bottom:var(--rof-spacing-sm)}.rof-test__placeholder-text{color:var(--rof-color-gray-600)}.rof-test__weight-input{background-color:#f8f9fa;border-left:4px solid #17a2b8;border-radius:var(--rof-radius-sm);margin-bottom:var(--rof-spacing-xl);padding:var(--rof-spacing-lg)}.rof-test__weight-form{margin:var(--rof-spacing-xl) 0}.rof-test__form-group{margin-bottom:var(--rof-spacing-lg)}.rof-test__form-label{color:var(--rof-color-gray-800);display:block;font-weight:var(--rof-font-weight-medium);margin-bottom:var(--rof-spacing-xs)}.rof-test__form-input{border:1px solid var(--rof-color-border);border-radius:var(--rof-radius-sm);font-size:var(--rof-font-size-base);max-width:200px;padding:var(--rof-spacing-sm);transition:border-color var(--rof-transition-fast);width:100%}.rof-test__form-input:focus{border-color:var(--rof-color-primary);outline:none}.rof-test__form-input--error{border-color:var(--rof-color-danger)}.rof-test__form-error{color:var(--rof-color-danger);font-size:var(--rof-font-size-sm);margin-top:var(--rof-spacing-xs)}.rof-test__submission-message{animation:rof-fadeIn .3s ease-in-out;border-radius:var(--rof-radius-sm);margin:var(--rof-spacing-lg) 0;padding:var(--rof-spacing-md) var(--rof-spacing-lg)}.rof-test__submission-message--success{background-color:#d4edda;border-left:4px solid #28a745;color:#155724}.rof-test__submission-message--error{background-color:#f8d7da;border-left:4px solid #dc3545;color:#721c24}@keyframes rof-fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rof-test__result-group{margin-bottom:var(--rof-spacing-lg)}.rof-test__result-label{color:var(--rof-color-gray-700);font-weight:var(--rof-font-weight-semibold);margin-bottom:var(--rof-spacing-xs)}.rof-test__result-value{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-lg)}@media(max-width:640px){.rof-test{padding:var(--rof-spacing-lg)}.rof-test__actions{flex-direction:column-reverse}.rof-test__actions .rof-btn{width:100%}.rof-test__interactive-container{min-height:360px}}#sts-interactive-container{border-radius:var(--rof-radius-md)}#sts-interactive-container,#tug-interactive-container{background-color:var(--rof-color-bg-secondary);border:1px solid var(--rof-color-border-light);margin:var(--rof-spacing-xl) 0;min-height:480px;overflow:hidden}#tug-interactive-container{border-radius:var(--rof-radius-md);position:relative;width:100%}#tug-interactive-container.visible{display:block!important;visibility:visible!important}#tug-interactive-container.hidden{display:none!important}.rof-assessment-list{width:100%}.rof-assessment-list__header{margin-bottom:var(--rof-spacing-lg)}.rof-assessment-list__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-2xl);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-lg) 0}.rof-assessment-list__patient-info{background-color:var(--rof-color-bg-secondary);border:1px solid var(--rof-color-border-light);border-radius:var(--rof-radius-sm);margin-bottom:var(--rof-spacing-xl);padding:var(--rof-spacing-lg)}.rof-assessment-list__patient-info-title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-medium);margin:0 0 var(--rof-spacing-md) 0}.rof-assessment-list__patient-info-content{display:flex;flex-wrap:wrap;gap:var(--rof-spacing-lg)}.rof-assessment-list__patient-info-item{display:flex;gap:var(--rof-spacing-xs)}.rof-assessment-list__patient-info-label{color:var(--rof-color-gray-700);font-weight:var(--rof-font-weight-semibold)}.rof-assessment-list__actions{align-items:center;display:flex;gap:var(--rof-spacing-sm);margin-bottom:var(--rof-spacing-lg)}.rof-assessment-list__loading{color:var(--rof-color-gray-600);font-style:italic;margin:var(--rof-spacing-md) 0}.assessment-score{display:flex}.score-badge{align-items:center;border-radius:var(--rof-radius-sm);color:var(--rof-color-white);display:flex;flex-direction:column;min-width:60px;padding:var(--rof-spacing-xs) var(--rof-spacing-sm)}.score-value{font-size:var(--rof-font-size-sm);font-weight:var(--rof-font-weight-bold)}.score-text{text-transform:capitalize}.score-loading,.score-text{font-size:var(--rof-font-size-xs)}.score-loading{color:var(--rof-color-gray-600);font-style:italic}.score-error{color:var(--rof-color-danger)}.score-error,.score-na{font-size:var(--rof-font-size-xs)}.score-na{color:var(--rof-color-gray-500);font-style:italic}.rof-assessment-steps{margin:0 auto}.rof-assessment-steps__warning{align-items:flex-start;background-color:#fff3cd;border:1px solid #ffc107;border-radius:var(--rof-radius-md);box-shadow:0 2px 4px #0000000d;display:flex;gap:var(--rof-spacing-md);margin-bottom:var(--rof-spacing-2xl);padding:var(--rof-spacing-lg)}.rof-assessment-steps__warning-icon{flex-shrink:0;font-size:24px}.rof-assessment-steps__warning-content{flex:1}.rof-assessment-steps__warning-title{color:#856404;font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-sm) 0}.rof-assessment-steps__warning-text{color:#856404;font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-relaxed);margin:0 0 var(--rof-spacing-md) 0}.rof-assessment-steps__header{border-bottom:1px solid var(--rof-color-border-light);margin-bottom:var(--rof-spacing-2xl);padding-bottom:var(--rof-spacing-lg)}.rof-assessment-steps__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-2xl);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-sm) 0}.rof-assessment-steps__date{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);margin:var(--rof-spacing-xs) 0}.rof-assessment-steps__list{display:flex;flex-direction:column;gap:var(--rof-spacing-lg);margin-bottom:var(--rof-spacing-2xl)}.rof-assessment-steps__item{align-items:center;background-color:var(--rof-color-white);border:1px solid var(--rof-color-border-light);border-radius:var(--rof-radius-sm);box-shadow:0 1px 3px #0000000d;cursor:pointer;display:flex;padding:var(--rof-spacing-xl);transition:all var(--rof-transition-base)}.rof-assessment-steps__item:hover:not(.rof-assessment-steps__item--disabled){border-color:var(--rof-color-border-medium);box-shadow:0 2px 8px #00000014}.rof-assessment-steps__item--completed{background-color:var(--rof-color-bg-secondary);border-color:var(--rof-color-border-medium)}.rof-assessment-steps__item--disabled{cursor:not-allowed;opacity:.6}.rof-assessment-steps__item--attempted{background-color:#fff3cd;border-color:#ffeeba}.rof-assessment-steps__item--attempted .rof-assessment-steps__item-icon{background-color:#ffc107}.rof-assessment-steps__item-icon{align-items:center;background-color:var(--rof-color-bg-secondary);border-radius:50%;display:flex;flex-shrink:0;height:36px;justify-content:center;margin-right:var(--rof-spacing-lg);width:36px}.rof-assessment-steps__step-number{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-semibold)}.rof-assessment-steps__completed-icon{color:var(--rof-color-primary);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-bold)}.rof-assessment-steps__attempted-icon{color:#856404;font-size:18px;font-weight:var(--rof-font-weight-bold)}.rof-assessment-steps__item-content{flex:1}.rof-assessment-steps__item-header{align-items:center;display:flex;gap:var(--rof-spacing-lg)}.rof-assessment-steps__item-text{flex:1;max-width:350px;min-width:0}.rof-assessment-steps__item-title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-medium);margin:0 0 var(--rof-spacing-xs) 0}.rof-assessment-steps__item-description{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);margin:0 0 var(--rof-spacing-sm) 0}.rof-assessment-steps__item-status{align-items:center;display:flex;flex-wrap:wrap;font-size:var(--rof-font-size-xs);gap:var(--rof-spacing-xs)}.rof-assessment-steps__status-complete{color:var(--rof-color-primary);font-weight:var(--rof-font-weight-medium);margin-right:var(--rof-spacing-xs)}.rof-assessment-steps__status-incomplete{color:var(--rof-color-gray-600);font-weight:var(--rof-font-weight-medium);margin-right:var(--rof-spacing-xs)}.rof-assessment-steps__status-attempted{color:#856404;font-weight:var(--rof-font-weight-medium);margin-right:var(--rof-spacing-xs)}.rof-assessment-steps__status-coming-soon{color:var(--rof-color-gray-500);font-style:italic}.rof-assessment-steps__status-action{color:var(--rof-color-gray-500);font-size:var(--rof-font-size-xs);margin-right:var(--rof-spacing-xs)}.rof-assessment-steps__status-outcome{color:#856404;display:block;font-size:var(--rof-font-size-xs);font-style:italic;margin-top:var(--rof-spacing-xs);width:100%}.rof-assessment-steps__item-action{margin-left:var(--rof-spacing-sm)}.rof-assessment-steps__action-arrow{color:var(--rof-color-gray-500);font-size:20px}.rof-assessment-steps__actions{display:flex;gap:var(--rof-spacing-md);justify-content:space-between;margin-top:var(--rof-spacing-2xl)}.rof-assessment-steps__loading-spinner{animation:rof-assessment-steps-spin .8s linear infinite;border:2px solid rgba(0,0,0,.1);border-radius:50%;border-top:2px solid var(--rof-color-primary);height:18px;width:18px}@keyframes rof-assessment-steps-spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.test-results-container{display:flex;flex-direction:column;flex-shrink:0;font-size:var(--rof-font-size-xs);gap:var(--rof-spacing-xs);min-width:280px}.results-header{color:var(--rof-color-gray-700);font-weight:var(--rof-font-weight-semibold);margin-bottom:2px}.results-row{align-items:center;display:flex;gap:var(--rof-spacing-sm)}.results-label{color:var(--rof-color-gray-600);font-weight:var(--rof-font-weight-medium);min-width:110px}.results-value{color:var(--rof-color-gray-800);min-width:60px}.results-value,.score-chip{font-weight:var(--rof-font-weight-semibold)}.score-chip{align-items:center;border-radius:12px;box-shadow:0 1px 2px #0000001a;color:var(--rof-color-white);display:inline-flex;font-size:var(--rof-font-size-xs);justify-content:center;margin-left:2rem;min-width:55px;padding:2px var(--rof-spacing-sm);text-transform:capitalize}.rof-recommendations{margin:0 auto;max-width:1200px;padding:var(--rof-spacing-lg)}.rof-recommendations__header{align-items:flex-start;border-bottom:var(--rof-border-width) solid var(--rof-color-border-light);display:flex;gap:var(--rof-spacing-lg);justify-content:space-between;margin-bottom:var(--rof-spacing-xl);padding-bottom:var(--rof-spacing-md)}.rof-recommendations__header-content{flex:1}.rof-recommendations__title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-2xl);font-weight:var(--rof-font-weight-semibold);margin:0 0 var(--rof-spacing-sm) 0}.rof-recommendations__subtitle{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-base);margin:0}.rof-recommendations__print-action{align-items:flex-end;display:flex;flex-direction:column;gap:var(--rof-spacing-xs);margin-top:var(--rof-spacing-xs)}.rof-recommendations__print-hint{color:var(--rof-color-gray-600);font-size:11px;margin:0;max-width:200px;text-align:right}.rof-recommendations__loading{align-items:center;display:flex;flex-direction:column;gap:var(--rof-spacing-lg);padding:60px var(--rof-spacing-lg);text-align:center}.rof-recommendations__spinner{animation:rof-spin .8s linear infinite;border-top:4px solid var(--rof-color-border-light);border:4px solid var(--rof-color-border-light);border-radius:var(--rof-radius-full);border-top-color:var(--rof-color-primary);height:40px;width:40px}@keyframes rof-spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.rof-recommendations__loading-message{color:var(--rof-color-gray-600);margin:0}.rof-recommendations__info{border-bottom:var(--rof-border-width) solid var(--rof-color-border-light);margin-bottom:var(--rof-spacing-xl);padding-bottom:var(--rof-spacing-lg)}.rof-recommendations__info-row{display:flex;flex-wrap:wrap;gap:40px}.rof-recommendations__info-row:not(:last-child){margin-bottom:var(--rof-spacing-md)}.rof-recommendations__info-item{align-items:baseline;display:flex;gap:var(--rof-spacing-xs)}.rof-recommendations__info-label{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);font-weight:var(--rof-font-weight-medium)}.rof-recommendations__info-value{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-base);font-weight:var(--rof-font-weight-semibold)}.rof-recommendations__info-value--score{font-size:var(--rof-font-size-xl);font-weight:var(--rof-font-weight-bold)}.rof-recommendations__categories{display:flex;flex-direction:column;gap:var(--rof-spacing-xl);margin-bottom:var(--rof-spacing-xl)}.rof-recommendations__category{display:flex;flex-direction:column;gap:var(--rof-spacing-md)}.rof-recommendations__category-header{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:var(--rof-spacing-sm);padding:0;transition:opacity var(--rof-transition-normal)}.rof-recommendations__category-header:hover{opacity:.7}.rof-recommendations__category-toggle{color:var(--rof-color-gray-600);flex-shrink:0;font-size:var(--rof-font-size-sm);transition:transform var(--rof-transition-normal)}.rof-recommendations__category-toggle--expanded{transform:rotate(90deg)}.rof-recommendations__category-header-content{align-items:center;display:flex;gap:var(--rof-spacing-md)}.rof-recommendations__category-name{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-xl);font-weight:var(--rof-font-weight-semibold);margin:0;text-align:left;text-transform:capitalize}.rof-recommendations__category-count{border-radius:var(--rof-radius-full);color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);padding:var(--rof-spacing-xs) var(--rof-spacing-sm)}.rof-recommendations__exercises{display:flex;flex-direction:column;gap:var(--rof-spacing-lg);padding:0}.rof-recommendations__exercise{align-items:flex-start;background-color:transparent;border:none;border-bottom:var(--rof-border-width) solid var(--rof-color-border-light);display:flex;gap:var(--rof-spacing-lg);padding:var(--rof-spacing-lg) 0}.rof-recommendations__exercise:last-child{border-bottom:none}.rof-recommendations__exercise-image{align-items:center;background-color:var(--rof-color-bg-secondary);border-radius:var(--rof-radius-md);display:flex;flex-shrink:0;height:250px;justify-content:center;overflow:hidden;width:250px}.rof-recommendations__exercise-image img{height:100%;object-fit:contain;width:100%}.rof-recommendations__exercise-content{display:flex;flex:1;flex-direction:column;margin-left:2rem;min-width:0}.rof-recommendations__exercise-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:var(--rof-spacing-sm);justify-content:space-between;margin-bottom:var(--rof-spacing-sm)}.rof-recommendations__exercise-title{color:var(--rof-color-gray-800);font-size:var(--rof-font-size-lg);font-weight:var(--rof-font-weight-semibold);margin:0}.rof-recommendations__exercise-description{color:var(--rof-color-gray-700);font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-relaxed);margin-top:var(--rof-spacing-sm)}.rof-recommendations__exercise-description p{margin:var(--rof-spacing-xs) 0}.rof-recommendations__exercise-details{display:flex;flex-wrap:wrap;gap:var(--rof-spacing-lg);margin-bottom:var(--rof-spacing-sm)}.rof-recommendations__exercise-detail{align-items:center;display:flex;gap:var(--rof-spacing-xs)}.rof-recommendations__detail-label{color:var(--rof-color-gray-600);font-size:var(--rof-font-size-sm);font-weight:var(--rof-font-weight-semibold)}.rof-recommendations__detail-value{background-color:var(--rof-color-bg-secondary);border-radius:var(--rof-radius-sm);color:var(--rof-color-gray-800);font-size:var(--rof-font-size-base);font-weight:var(--rof-font-weight-semibold);padding:var(--rof-spacing-xs) var(--rof-spacing-sm)}.rof-recommendations__actions{display:flex;justify-content:flex-start;margin-top:var(--rof-spacing-xl)}@media print{@page{size:A4;margin:1.5cm 1cm}body *{visibility:hidden}.rof-recommendations,.rof-recommendations *{visibility:visible}.rof-recommendations{left:0;margin:0;max-width:100%;padding:0;position:absolute;top:0}.rof-btn,.rof-recommendations__actions,.rof-recommendations__category-toggle,.rof-recommendations__print-action{display:none!important}.rof-recommendations__header{margin-bottom:var(--rof-spacing-md);padding-bottom:var(--rof-spacing-sm)}.rof-recommendations__title{font-size:24px;margin-bottom:var(--rof-spacing-xs)}.rof-recommendations__subtitle{font-size:12px}.rof-recommendations__info{margin-bottom:var(--rof-spacing-md);padding-bottom:var(--rof-spacing-sm);page-break-after:avoid}.rof-recommendations__info-row{font-size:11px;gap:var(--rof-spacing-lg)}.rof-recommendations__info-label{font-size:11px}.rof-recommendations__info-value{font-size:12px}.rof-recommendations__info-value--score{font-size:14px}.rof-recommendations__categories{gap:var(--rof-spacing-lg);margin-bottom:0}.rof-recommendations__category{display:block!important;page-break-inside:avoid}.rof-recommendations__category-header{display:block!important;padding:var(--rof-spacing-xs) 0}.rof-recommendations__category-header-content{gap:var(--rof-spacing-sm)}.rof-recommendations__category-name{font-size:16px}.rof-recommendations__category-count{font-size:11px;padding:2px 8px}.rof-recommendations__exercises{display:block!important;margin-top:var(--rof-spacing-xs)}.rof-recommendations__exercise{align-items:flex-start!important;break-inside:avoid;display:flex!important;flex-direction:row!important;gap:var(--rof-spacing-sm);padding:var(--rof-spacing-sm) 0;page-break-inside:avoid}.rof-recommendations__exercise:last-child{border-bottom:var(--rof-border-width) solid var(--rof-color-border-light)}.rof-recommendations__exercise-image{align-self:flex-start!important;border-radius:var(--rof-radius-sm);display:block!important;flex-shrink:0;float:none!important;height:100px!important;margin-right:0;width:100px!important}.rof-recommendations__exercise-image img{display:block;height:100%;object-fit:contain;-webkit-print-color-adjust:exact;print-color-adjust:exact;width:100%}.rof-recommendations__exercise-content{align-self:flex-start!important;display:block!important;flex:1;margin-left:2rem;min-width:0;overflow:hidden}.rof-recommendations__exercise-header{margin-bottom:var(--rof-spacing-xs)}.rof-recommendations__exercise-title{font-size:13px;font-weight:var(--rof-font-weight-semibold);page-break-after:avoid}.rof-recommendations__exercise-details{display:flex;flex-wrap:wrap;gap:var(--rof-spacing-sm);margin-bottom:var(--rof-spacing-xs)}.rof-recommendations__exercise-detail{display:inline-flex;gap:var(--rof-spacing-xs)}.rof-recommendations__detail-label{font-size:10px}.rof-recommendations__detail-value{background-color:var(--rof-color-bg-secondary)!important;font-size:11px;padding:2px 6px;-webkit-print-color-adjust:exact;print-color-adjust:exact}.rof-recommendations__exercise-description{font-size:10px;line-height:1.3;margin-top:var(--rof-spacing-xs)}.rof-recommendations__exercise-description p{margin:3px 0}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}.rof-recommendations__exercise,.rof-recommendations__info{border-bottom:var(--rof-border-width) solid var(--rof-color-border-light)}}@media(max-width:768px){.rof-recommendations__header{align-items:stretch;flex-direction:column}.rof-recommendations__print-action{align-items:stretch}.rof-recommendations__print-hint{max-width:100%;text-align:center}.rof-recommendations__exercise{flex-direction:column}.rof-recommendations__exercise-image{height:200px;width:100%}.rof-recommendations__exercise-content{margin-left:0}.rof-recommendations__info-row{flex-direction:column;gap:var(--rof-spacing-md)}.rof-recommendations__category-header-content{align-items:flex-start;flex-direction:column;gap:var(--rof-spacing-xs)}}.rof-notification{animation:rof-notification-fade-in var(--rof-transition-normal) ease-out forwards;border-radius:var(--rof-radius-md);bottom:var(--rof-spacing-lg);box-shadow:var(--rof-shadow-lg);left:50%;max-width:90%;opacity:0;padding:var(--rof-spacing-sm) var(--rof-spacing-md);position:fixed;transform:translate(-50%);width:auto;z-index:var(--rof-z-notification)}.rof-notification__content{align-items:center;display:flex;gap:var(--rof-spacing-sm);justify-content:space-between}.rof-notification--success{background-color:#e3f2fd;border:var(--rof-border-width) solid var(--rof-color-primary);color:#0056b3}.rof-notification--error{background-color:#ffebee;border:var(--rof-border-width) solid var(--rof-color-danger);color:#c62828}.rof-notification__message{font-size:var(--rof-font-size-sm);line-height:var(--rof-line-height-normal);max-width:500px;padding-right:var(--rof-spacing-sm);text-align:center}.rof-notification__close{align-items:center;background:transparent;border:none;color:inherit;cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;line-height:1;opacity:.7;padding:0;transition:opacity var(--rof-transition-fast);width:24px}.rof-notification__close:hover{opacity:1}.rof-notification__close:focus-visible{border-radius:var(--rof-radius-sm);outline:2px solid currentColor;outline-offset:2px}@keyframes rof-notification-fade-in{0%{opacity:0;transform:translate(-50%,var(--rof-spacing-lg))}to{opacity:1;transform:translate(-50%)}}.rof-score-header{background-color:#f9f9f9;border:1px solid #eee;border-radius:4px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;margin-bottom:20px;padding:12px 20px}.rof-score-main{align-items:center;display:flex;justify-content:space-between}.rof-score-text{color:#2d3142;font-size:20px;font-weight:600}.rof-tests{align-items:center;display:flex;gap:10px}.rof-tests-label{color:#5b6481;font-size:14px}.rof-ring{height:54px;position:relative;width:54px}.rof-ring svg{height:100%;position:relative;top:-1px;transform:rotate(-90deg);width:100%}.rof-ring circle{fill:none;stroke-width:6}.rof-ring .bg{stroke:#e5e7eb}.rof-ring .fg{stroke:#a2afde;stroke-linecap:round;transition:stroke-dashoffset .4s ease}.rof-ring .txt{color:#27324a;display:grid;font-size:14px;font-weight:500;inset:0;place-items:center;position:absolute}.rof-bar-wrap{margin-top:64px;position:relative}.rof-bar{--height:32px;background:linear-gradient(90deg,#9ddfb8,#e3c07a 50%,#e07a86);height:var(--height);position:relative}.rof-bar,.rof-prob-range{border-radius:1px;box-shadow:inset 0 0 0 1.5px #97989b}.rof-prob-range{background:#ccccd559;height:calc(var(--height)*1.8);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.rof-marker{bottom:0;color:#5b6481;position:absolute;top:0;width:0}.rof-marker:after{border-left:2px dashed #2d3142;content:"";height:calc(var(--height)*2.75);left:-1px;opacity:.75;position:absolute;top:calc(var(--height)*-.875)}.rof-score-wrap{bottom:100%;left:50%;margin-bottom:8px;position:absolute;transform:translate(-50%);white-space:nowrap}.rof-score{color:#5b6481;font-size:28px;font-weight:800;position:relative;top:-22px}.rof-prob-labels{color:#5b6481;display:flex;font-size:14px;justify-content:space-between;left:0;margin-top:6px;position:absolute;right:0;top:100%}.rof-prob-labels span,.rof-prob-labels span:first-child{transform:translate(-50%)}.rof-prob-labels span:last-child{transform:translate(50%)}.rof-score-error,.rof-score-loading{color:#666;font-size:14px}.rof-score-error{color:#dc3545}.rof-score-info{margin-top:2rem;padding-top:1.5rem}.rof-info-text{color:#6c757d;line-height:1.4;margin:0}.rof-info-text-bottom{margin-top:1rem}.rof-info-recommendations{align-items:center;color:#6c757d;display:flex;line-height:1.4;margin-bottom:0;margin-top:1rem}.rof-score-info--no-tests{margin-top:0}.assessment-manager{margin:0 auto;width:100%}.loading{align-items:center;color:#666;display:flex;font-size:16px;height:200px;justify-content:center}.error{background-color:#fff1f0;border:1px solid #ffccc7;border-radius:4px;color:#cf1322;margin-bottom:16px;padding:16px}.error button{background-color:#fff;border:1px solid #ff7875;border-radius:4px;color:#cf1322;cursor:pointer;margin-top:8px;padding:4px 8px}.error button:hover{background-color:#fff7f6}.rof-app{min-height:100vh;width:100%}.rof-app--loading{opacity:.6;pointer-events:none}.rof-app__loading{align-items:center;color:var(--rof-color-gray-600);display:flex;flex-direction:column;font-size:var(--rof-font-size-base);justify-content:center;min-height:400px;padding:var(--rof-spacing-3xl)}:root{--rof-color-primary:#007bff;--rof-color-primary-hover:#0069d9;--rof-color-primary-light:#e7f3ff;--rof-color-secondary:#fff;--rof-color-secondary-hover:#f5f5f5;--rof-color-secondary-foreground:#333;--rof-color-success:#28a745;--rof-color-success-hover:#218838;--rof-color-danger:#dc3545;--rof-color-danger-hover:#c82333;--rof-color-warning:#ffc107;--rof-color-info:#17a2b8;--rof-color-white:#fff;--rof-color-black:#000;--rof-color-gray-50:#f9fafb;--rof-color-gray-100:#f5f5f5;--rof-color-gray-200:#eee;--rof-color-gray-300:#ddd;--rof-color-gray-400:#ccc;--rof-color-gray-500:#999;--rof-color-gray-600:#666;--rof-color-gray-700:#333;--rof-color-gray-800:#1a1a1a;--rof-color-error:#c00;--rof-color-error-bg:#fff5f5;--rof-color-error-border:#feb2b2;--rof-color-border-light:var(--rof-color-gray-200);--rof-color-border-medium:var(--rof-color-gray-300);--rof-color-border-dark:var(--rof-color-gray-400);--rof-color-bg:#fff;--rof-color-bg-overlay:rgba(0,0,0,.5);--rof-color-bg-hover:var(--rof-color-gray-100);--rof-color-bg-secondary:#f9f9f9;--rof-spacing-xs:4px;--rof-spacing-sm:8px;--rof-spacing-md:12px;--rof-spacing-lg:16px;--rof-spacing-xl:24px;--rof-spacing-2xl:32px;--rof-spacing-3xl:48px;--rof-font-size-xs:12px;--rof-font-size-sm:14px;--rof-font-size-base:16px;--rof-font-size-lg:18px;--rof-font-size-xl:20px;--rof-font-size-2xl:24px;--rof-font-weight-normal:400;--rof-font-weight-medium:500;--rof-font-weight-semibold:600;--rof-font-weight-bold:700;--rof-line-height-tight:1.25;--rof-line-height-normal:1.5;--rof-line-height-relaxed:1.75;--rof-radius-xs:1px;--rof-radius-sm:4px;--rof-radius-md:8px;--rof-radius-lg:12px;--rof-radius-full:9999px;--rof-border-width:1px;--rof-shadow-sm:0 1px 2px rgba(0,0,0,.05);--rof-shadow-md:0 4px 6px rgba(0,0,0,.1);--rof-shadow-lg:0 10px 15px rgba(0,0,0,.1);--rof-shadow-xl:0 20px 25px rgba(0,0,0,.15);--rof-shadow-modal:0 4px 12px rgba(0,0,0,.15);--rof-transition-fast:.15s ease-in-out;--rof-transition-normal:.3s ease-out;--rof-transition-base:.2s ease-in-out;--rof-transition-slow:.3s ease-in-out;--rof-z-dropdown:1000;--rof-z-sticky:1020;--rof-z-fixed:1030;--rof-z-modal-backdrop:1040;--rof-z-modal:1050;--rof-z-popover:1060;--rof-z-tooltip:1070;--rof-z-notification:1000}body{font-family:Montserrat,Helvetica,Arial,sans-serif;line-height:1.6;color:#121212;background-color:#fff;margin:0;padding:0}header{background:#157fd9;color:#fff;height:74px;padding:16px;display:flex;box-shadow:0 6px 24px #0006}header h1{font-weight:400;letter-spacing:.5px;max-width:1200px;margin:0 auto 0 100px;font-size:1.5rem}h2{color:#333;font-weight:400;padding-bottom:.5rem;margin-top:.5rem;margin-bottom:.5rem}h3{font-weight:500;margin-top:1.5rem;color:#333}p{margin-bottom:1.5rem;color:#444}button{background-color:#157fd9;color:#fff;border:none;padding:8px 16px;border-radius:4px;height:36px;cursor:pointer;font-weight:400;margin-right:8px;transition:background-color .2s,opacity .2s}button:hover{background-color:#0069d9}button:disabled{opacity:.4;cursor:not-allowed}.info-row{display:flex;margin-bottom:8px}.info-row span:first-child{font-weight:500;margin-right:8px;width:100px}.status-indicator{padding:3px 8px;border-radius:2px;font-size:.85rem;font-weight:400}.status-connected{background-color:#f2f2f2;color:#157fd9;border-bottom:2px solid #157fd9}.status-disconnected{background-color:#f5f5f5;color:#777}.status-connecting{background-color:#f5f5f5;color:#555;border-bottom:2px solid #555}.status-error{background-color:#f5f5f5;color:#000;border-bottom:2px solid #c00}.error-message{border-left:3px solid #c00;padding-left:10px;margin:10px 0;color:#c00}.debug-console{max-height:300px;overflow-y:auto;background-color:#f9f9f9;padding:12px;border-left:3px solid #eee;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:.85rem}.log-entry{margin-bottom:6px;padding:2px 0}.log-info{color:#444}.log-warn{color:#750}.log-error{color:#c00}.log-success{color:#157fd9;font-weight:500}footer{text-align:center;padding:20px;margin-top:40px;background-color:#f7f7f7;border-top:1px solid #eee;color:#777;font-size:.85rem}.content-section{padding:0 20px;max-width:1200px;margin:0 auto}button{font-weight:600}
