:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f1419;background-color:#e9edf2;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-size:16px}input,textarea,select,button{font-size:16px}#root{height:100vh}.app-root{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;background:linear-gradient(180deg,#f5f7fb,#dde3ee);border-left:1px solid #d0d7e2;border-right:1px solid #d0d7e2}.field__input{background:#fff;color:#0f1419;caret-color:#08c}.field__input::placeholder{color:#6c7988;opacity:1}input,textarea,select,button{color-scheme:light}.app-content{flex:1;padding:16px;overflow-y:auto;padding-top:calc(20px + 20mm)}.page{display:flex;flex-direction:column;gap:12px}.page__header{padding:4px 2px}.page__title{margin:0;font-size:20px;font-weight:600}.page__subtitle{margin:4px 0 0;font-size:13px;color:#6c7988}.page__content{display:flex;flex-direction:column;gap:12px}.card{background:#fff;border-radius:16px;padding:12px 14px;box-shadow:0 8px 18px #0f141e0f}.card__title{margin:0 0 8px;font-size:15px;font-weight:600}.card__body{font-size:14px}.card__footer{margin-top:10px;padding-top:8px;border-top:1px solid #edf0f5;font-size:12px;color:#6c7988}.card__footer-hint{margin-top:8px;font-size:12px;color:#6c7988}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:none;font-size:14px;padding:10px 16px;cursor:pointer;transition:transform .08s ease-out,box-shadow .08s ease-out,background-color .12s ease-out}.btn:active{transform:scale(.97)}.btn--primary{background:#2aabee;color:#fff;box-shadow:0 6px 14px #0088cc59}.btn--primary:hover{background:#1d9edb}.btn--ghost{background:transparent;color:#0f1419;border:1px solid #c5d0dd}.btn--outline{background:#fff;color:#0f1419;border:1px solid #d0d7e2}.bottom-nav{display:flex;border-top:1px solid #d0d7e2;background-color:#fff}.bottom-nav__item{flex:1;padding:6px 2px 8px;border:none;background:none;cursor:pointer;font-size:11px;display:flex;flex-direction:column;align-items:center;gap:2px;color:#6c7988}.bottom-nav__icon{font-size:18px}.bottom-nav__item--active{color:#08c;font-weight:600}.bottom-nav__item--active .bottom-nav__icon{transform:translateY(-1px)}.home-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}.home-header__avatar{width:60px;height:60px;border-radius:999px;background:linear-gradient(135deg,#08c,#37bff0);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;font-weight:600}.home-header__info{display:flex;flex-direction:column}.home-header__name{font-size:20px;font-weight:600}.home-header__role{font-size:15px;color:#6c7988}.metric{display:flex;flex-direction:column;gap:8px}.metric__value{font-size:30px;font-weight:700;text-align:center}.metric__bar{position:relative;height:8px;border-radius:999px;background:#e0e6f0;overflow:hidden}.metric__bar-fill{position:absolute;inset:0;border-radius:inherit;background:linear-gradient(90deg,#26c281,#f2c94c,#eb5757)}.metric__hint{font-size:12px;color:#6c7988}.home-actions{display:flex;flex-direction:column;gap:8px}.photo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:4px}.photo-hint{margin-top:10px;font-size:12px;color:#6c7988}.photo-block{display:flex;flex-direction:column;gap:10px}.photo-block__header{display:flex;gap:10px}.photo-block__icon{flex:0 0 40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff}.photo-block__icon--fif{background:linear-gradient(135deg,#2aabee,#37bff0)}.photo-block__icon--report{background:linear-gradient(135deg,#f2c94c,#f2994a)}.photo-block__icon--knp{background:linear-gradient(135deg,#9b51e0,#bb6bd9)}.photo-block__text p{margin:0;font-size:13px;color:#0f1419}.photo-block__hint{margin-top:4px;font-size:12px;color:#6c7988}.photo-block__actions{display:flex;justify-content:flex-end}.form-grid{display:grid;grid-template-columns:1fr;gap:10px}.field{display:flex;flex-direction:column;gap:4px}.field__label{font-size:12px;color:#6c7988}.field__input{border-radius:10px;border:1px solid #c5d0dd;padding:8px 10px;font-size:16px;width:100%;box-sizing:border-box}.list{list-style:none;margin:0;padding:0}.list__item{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;border-bottom:1px solid #edf0f5}.list__item:last-child{border-bottom:none}.text-muted{color:#6c7988}.weekly-chart{display:flex;flex-direction:column;gap:8px}.weekly-chart__header{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#6c7988}.weekly-chart__center{display:flex;flex-direction:column;align-items:center;gap:2px}.weekly-chart__title{font-weight:500}.weekly-chart__legend{display:flex;gap:10px;font-size:11px}.weekly-chart__legend-item{display:inline-flex;align-items:center;gap:4px}.weekly-chart__legend-dot{width:8px;height:8px;border-radius:50%}.weekly-chart__legend-dot--day{background-color:#2aabee}.weekly-chart__legend-dot--month{background-color:#9b51e0}.weekly-chart__nav-btn{border:none;background:#f1f4fa;border-radius:999px;width:28px;height:28px;cursor:pointer;font-size:14px;color:#4a5a70;display:flex;align-items:center;justify-content:center}.weekly-chart__nav-btn:disabled{opacity:.35;cursor:default}.weekly-chart__chart{width:100%;height:120px}.weekly-chart__svg{width:100%;height:100%}.weekly-chart__axis{stroke:#d0d7e2;stroke-width:.5}.weekly-chart__line{fill:none;stroke-width:1.2}.weekly-chart__line--day{stroke:#2aabee}.weekly-chart__line--month{stroke:#9b51e0;stroke-dasharray:2 2}.weekly-chart__point{stroke-width:.8}.weekly-chart__point--day{fill:#fff;stroke:#2aabee}.weekly-chart__point--month{fill:#fff;stroke:#9b51e0}.weekly-chart__labels{display:flex;justify-content:space-between;gap:4px}.weekly-chart__labels-item{flex:1;text-align:center;font-size:10px}.weekly-chart__labels-value{line-height:1.2}.weekly-chart__labels-value--day{color:#2aabee;font-weight:500}.weekly-chart__labels-value--month{color:#9b51e0}.weekly-chart__labels-day{color:#6c7988;margin-top:2px}.defect-slider{display:flex;flex-direction:column;align-items:stretch;gap:8px}.defect-slider__percent{font-size:26px;font-weight:700;text-align:center}.defect-slider__sum-pill{align-self:center;padding:4px 10px;border-radius:999px;background:#0088cc14;color:#0f1419;font-size:13px}.defect-slider__range-wrapper{margin-top:4px}.defect-slider__range{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:999px;background:linear-gradient(90deg,#26c281,#f2c94c,#eb5757);outline:none;margin:0;cursor:pointer;position:relative}.defect-slider__range::-webkit-slider-runnable-track{height:8px;border-radius:999px;background:transparent}.defect-slider__range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #2aabee;box-shadow:0 0 0 3px #2aabee40;margin-top:-5px}.defect-slider__range::-moz-range-track{height:8px;border-radius:999px;background:linear-gradient(90deg,#26c281,#f2c94c,#eb5757)}.defect-slider__range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #2aabee;box-shadow:0 0 0 3px #2aabee40}.defect-slider__marks{display:flex;justify-content:space-between;font-size:11px;color:#6c7988;margin-top:2px}.akb-form{display:flex;flex-direction:column;gap:12px}.akb-form__top-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.akb-form__back-btn{border:none;background:#f1f4fa;border-radius:999px;padding:6px 10px;font-size:12px;color:#4a5a70;cursor:pointer}.akb-form__title{margin:0;font-size:18px;font-weight:600}.akb-form__errors{background:#ffecec;border-radius:10px;padding:8px 10px;font-size:12px;color:#b3261e}.akb-form__section{display:flex;flex-direction:column;gap:6px}.akb-form__grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:480px){.akb-form__grid-2{grid-template-columns:1fr}}.field__input--multiline{min-height:60px;resize:vertical}.field__input[readonly]{background:#f5f7fb}.akb-form__photos-hint{margin-top:4px;font-size:11px;color:#6c7988}.akb-form__photos-list{margin:6px 0 0;padding-left:18px;font-size:12px;color:#4a5a70}.akb-form__submit{width:100%;margin-top:4px}.akb-form__photo-buttons{display:flex;gap:8px;margin:4px 0 6px}.akb-form__photo-buttons .btn{flex:1}.akb-form__file-input{display:none}.akb-form__photos-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.akb-form__photo-item{width:72px;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:10px;color:#6c7988}.akb-form__photo-thumb-wrapper{position:relative;width:72px;height:72px;border-radius:12px;overflow:hidden;background:#eef2f8}.akb-form__photo-thumb{width:100%;height:100%;object-fit:cover}.akb-form__photo-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;border:none;background:#0f1419bf;color:#fff;font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.akb-form__photo-label{margin-top:2px}.home-header__avatar{width:60px;height:60px;border-radius:999px;background:linear-gradient(135deg,#08c,#37bff0);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;font-weight:600;overflow:hidden}.home-header__avatar-img{width:100%;height:100%;object-fit:cover;display:block}.motivation-banner{margin-top:8px;padding:10px 12px;border-radius:12px;background:linear-gradient(135deg,#e3f5ff,#f2fbff);border:1px solid #c5e4ff}.motivation-banner__label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:#3182ce;margin-bottom:4px}.motivation-banner__text{font-size:13px;color:#0f1419;line-height:1.35}.auth-spinner{width:44px;height:44px;border-radius:999px;border:4px solid rgba(0,0,0,.1);border-top-color:#2aabee;animation:authspin .9s linear infinite}@keyframes authspin{to{transform:rotate(360deg)}}.auth-card-center{display:flex;flex-direction:column;align-items:center;gap:10px}.auth-hint{font-size:12px;text-align:center}.auth-center{display:grid;place-items:center;min-height:100%}.auth-card{width:100%;max-width:420px;text-align:center;padding:18px 16px}.auth-badge{width:62px;height:62px;border-radius:999px;margin:0 auto 12px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:22px;background:linear-gradient(135deg,#08c,#37bff0);box-shadow:0 10px 20px #0088cc2e}.auth-badge--danger{background:linear-gradient(135deg,#eb5757,#f2994a);box-shadow:0 10px 20px #eb57572e}.auth-title{font-size:18px;font-weight:700;margin-bottom:6px}.auth-subtitle{font-size:13px;color:#6c7988;margin-bottom:14px}.auth-loader{display:grid;justify-items:center;gap:10px;margin:6px 0 10px}.auth-progress{width:220px;height:8px;border-radius:999px;background:#e0e6f0;overflow:hidden}.auth-progress__bar{height:100%;width:45%;border-radius:inherit;background:linear-gradient(90deg,#2aabee,#37bff0);animation:authbar 1.2s ease-in-out infinite}@keyframes authbar{0%{transform:translate(-60%)}50%{transform:translate(80%)}to{transform:translate(-60%)}}.auth-hint{margin-top:6px;font-size:12px;color:#6c7988}.auth-btn{width:100%;margin-top:12px}.auth-banner{text-align:left;margin-top:10px}.auth-fade{animation:authfade .16s ease-out}@keyframes authfade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.field__input[type=date]{width:100%;max-width:100%;min-width:0}.field{min-width:0}.form-grid>*{min-width:0}.field__input[type=date]{appearance:none;-webkit-appearance:none;background-clip:padding-box}.field__input--danger{border-color:#ff3b30f2;box-shadow:0 0 0 2px #ff3b3026}.field__hint--danger{margin-top:6px;font-size:12px;color:#ff3b30f2}.photo-block__actions--split{display:flex;justify-content:space-between;gap:10px;align-items:center}.btn.btn--secondary{appearance:none;border:1px solid rgba(0,0,0,.18);background:#0000000a;padding:10px 14px;border-radius:12px;font-weight:600;cursor:pointer}.btn.btn--secondary:active{transform:translateY(1px)}.registry-card{border:1px solid rgba(0,0,0,.1);border-radius:14px;padding:12px;background:#00000005}.registry-card__top{display:flex;justify-content:space-between;gap:10px}.registry-card__title{font-weight:700}.registry-card__status{font-weight:800}.thumb-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.thumb{position:relative;border:0;padding:0;background:transparent;border-radius:12px;overflow:hidden;cursor:pointer;aspect-ratio:1 / 1}.thumb--empty{cursor:default;background:#0000000a;border:1px dashed rgba(0,0,0,.15)}.thumb__img{width:100%;height:100%;object-fit:cover;display:block}.thumb__more{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#fff;background:#00000073}.lightbox{position:fixed;inset:0;z-index:9999}.lightbox__backdrop{position:absolute;inset:0;background:#000000a6}.lightbox__panel{position:absolute;inset:12px;background:#000000eb;border-radius:16px;overflow:hidden;display:flex;flex-direction:column}.lightbox__close{position:absolute;top:10px;right:10px;border:0;background:#ffffff1f;color:#fff;width:38px;height:38px;border-radius:12px;cursor:pointer;font-size:18px}.lightbox__counter{color:#ffffffd9;font-weight:700;padding:12px 14px}.lightbox__content{flex:1;display:grid;grid-template-columns:56px 1fr 56px;align-items:center;gap:8px;padding:12px}.lightbox__img{width:100%;height:100%;object-fit:contain;border-radius:12px;background:#ffffff0f}.lightbox__nav{border:0;background:#ffffff1f;color:#fff;height:64px;border-radius:14px;cursor:pointer;font-size:32px;line-height:1}.lightbox__nav:disabled{opacity:.35;cursor:default}.lb{position:fixed;inset:0;background:#000000d1;z-index:9999;display:flex;align-items:center;justify-content:center;padding:14px}.lb__content{position:relative;width:min(96vw,720px);height:min(86vh,760px);border-radius:18px;overflow:hidden;background:#0f0f0ff2}.lb__imgWrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.lb__img{max-width:100%;max-height:100%;object-fit:contain}.lb__close{position:absolute;top:10px;right:10px;z-index:2;width:40px;height:40px;border-radius:12px;border:0;background:#ffffff1f;color:#fff;font-size:18px}.lb__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:44px;height:64px;border:0;border-radius:14px;background:#ffffff1f;color:#fff;font-size:34px;line-height:1}.lb__nav--left{left:10px}.lb__nav--right{right:10px}.lb__nav:disabled{opacity:.35}.lb__counter{position:absolute;bottom:10px;left:50%;transform:translate(-50%);z-index:2;font-size:12px;color:#fffc;background:#ffffff1f;padding:6px 10px;border-radius:999px}.fif-card{background:#fff!important;color:#0f1419!important;border-radius:16px;padding:14px;margin-bottom:12px;border:1px solid rgba(0,0,0,.08);box-shadow:0 6px 18px #0000000f}.fif-card--ok{box-shadow:inset 4px 0 #46aa78d9,0 6px 18px #0000000f}.fif-card--bad{box-shadow:inset 4px 0 #dc5a5ad9,0 6px 18px #0000000f}.fif-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.btn--sm{padding:8px 10px;font-size:12px}.fif-card__status{font-weight:700;font-size:12px;padding:6px 10px;border-radius:999px;background:#7878781f;border:1px solid rgba(0,0,0,.1);color:#0f1419}.fif-card__status.is-ok{color:#46aa78f2}.fif-card__status.is-bad{color:#dc5a5af2}.photo-grid-4{margin-top:10px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.photo-grid-4__item{border:0;padding:0;background:transparent;border-radius:12px;overflow:hidden;cursor:pointer}.photo-grid-4__img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}.fif-edit{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:14px;box-shadow:0 6px 18px #0000000f}.fif-edit__top{display:flex;justify-content:space-between;align-items:center;gap:10px}.fif-edit__title{font-weight:700}.btn--sm{padding:6px 10px;font-size:12px}.fif-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.fif-card__actions{display:flex;gap:8px}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:14px;z-index:9999}.modal-card{width:min(520px,96vw);background:#fff;color:#0f1419;border-radius:16px;padding:14px;box-shadow:0 18px 40px #00000038}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.modal-title{font-weight:800;font-size:14px}.modal-actions{display:flex;gap:10px;margin-top:12px}.dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:8px}.dot--online{background:#2ecc71}.dot--offline{background:#e74c3c;opacity:.75}.akb-form__upload-status{background:#e3f2fd;border:1px solid #BBDEFB;border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:14px}.akb-form__upload-success{background:#e8f5e9;border:1px solid #C8E6C9;border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:14px;color:#2e7d32}.akb-form__upload-text{display:flex;align-items:center;gap:8px}.akb-form__photo-uploaded{font-size:10px;color:#34c759;margin-top:2px}.photo-thumb-container{position:relative;width:100%;height:100%;overflow:hidden;border-radius:4px;background:#f5f5f5}.photo-thumb-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#f5f5f5cc}.photo-thumb-spinner{width:20px;height:20px;border:2px solid #ddd;border-top-color:#007aff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.photo-thumb-error{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;background:#ffebee;color:#c62828;font-size:11px;text-align:center}.photo-thumb-error-icon{font-size:16px;margin-bottom:4px}.photo-thumb-error-text{margin-bottom:2px}.photo-thumb-error-hint{font-size:9px;color:#666}.photo-grid-4__img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.photo-grid-4__item:hover .photo-grid-4__img{transform:scale(1.05)}.fif-card__photo-source{margin:8px 0;display:flex;gap:8px}.photo-source-badge{background:#e3f2fd;color:#1565c0;padding:2px 8px;border-radius:12px;font-size:11px;display:inline-flex;align-items:center;gap:4px}.fif-card__gpn14{font-size:12px;color:#666;margin-left:8px}.fif-card__more{margin-top:8px;font-size:12px;color:#666;text-align:center}
