.settings-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;animation:.2s settings-fade-in;display:flex;position:fixed;inset:0}@keyframes settings-fade-in{0%{opacity:0}to{opacity:1}}.settings-modal{background:var(--color-surface);border-radius:16px;flex-direction:column;width:720px;max-width:95vw;height:520px;max-height:90vh;animation:.25s settings-slide-up;display:flex;box-shadow:0 24px 80px #0000002e,0 8px 24px #00000014}@keyframes settings-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.settings-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.settings-header h2{color:var(--color-text);font-size:18px;font-weight:600}.settings-close{width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.settings-close:hover{background:var(--color-bg);color:var(--color-text)}.settings-body{flex:1 1 0;min-height:0;display:flex;overflow:hidden}.settings-sidebar{border-right:1px solid var(--color-border);flex-direction:column;gap:2px;width:200px;min-width:200px;padding:12px;display:flex}.settings-tab{color:var(--color-text-secondary);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.settings-tab:hover{background:var(--color-bg);color:var(--color-text)}.settings-tab--active,.settings-tab--active:hover{background:var(--color-primary-light);color:var(--color-primary)}.settings-content{flex:1;padding:24px 28px;overflow-y:auto}.settings-section h3{color:var(--color-text);margin-bottom:4px;font-size:16px;font-weight:600}.settings-section-desc{color:var(--color-text-secondary);margin-bottom:24px;font-size:13px}.settings-field{margin-bottom:20px}.settings-field label{color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.settings-field input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);width:100%;color:var(--color-text);padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.settings-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.settings-field input::placeholder{color:var(--color-text-secondary);opacity:.6}.settings-field input:disabled{background:var(--color-border);color:var(--color-text-secondary);cursor:not-allowed;opacity:.7}.settings-field-hint{color:var(--color-text-secondary);margin-bottom:10px;font-size:13px;line-height:1.5}.settings-input-row{gap:10px;display:flex}.settings-input-row input{flex:1}.settings-divider{background:var(--color-border);height:1px;margin:24px 0}.settings-btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.settings-btn--primary{background:var(--color-primary);color:var(--color-primary-text)}.settings-btn--primary:hover{background:var(--color-primary-hover)}.settings-btn--secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.settings-btn--secondary:hover{background:var(--color-border)}.settings-btn--primary:disabled{opacity:.45;cursor:not-allowed}.settings-textarea{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);width:100%;color:var(--color-text);resize:vertical;min-height:100px;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.5;transition:border-color .15s}.settings-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.settings-textarea::placeholder{color:var(--color-text-secondary);opacity:.6}.settings-submit-btn{margin-top:12px}.settings-field-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.settings-field-header label{margin-bottom:0}.settings-status{margin-top:8px;font-size:13px;line-height:1.4}.settings-status--success{color:var(--color-success,#16a34a)}.settings-status--error{color:var(--color-danger,#dc2626)}.settings-toast{z-index:1100;background:var(--color-surface);border:1px solid var(--color-success,#16a34a);color:var(--color-text);border-radius:12px;align-items:center;gap:10px;padding:14px 20px;font-size:14px;font-weight:500;animation:.25s toast-slide-in;display:flex;position:fixed;top:24px;left:24px;box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f}.settings-toast--success svg{color:var(--color-success,#16a34a)}.settings-toast--success{border-color:var(--color-success,#16a34a)}.settings-toast--error svg{color:var(--color-danger,#dc2626)}.settings-toast--error{border-color:var(--color-danger,#dc2626)}.settings-toast svg{flex-shrink:0}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@media (width<=600px){.settings-modal{border-radius:12px;max-height:95vh}.settings-body{flex-direction:column}.settings-sidebar{border-right:none;border-bottom:1px solid var(--color-border);flex-direction:row;gap:4px;width:100%;min-width:0;padding:8px;overflow-x:auto}.settings-tab{padding:8px 12px;font-size:13px}.settings-content{padding:20px 16px}.settings-input-row{flex-direction:column}}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);z-index:100;position:sticky;top:0}.navbar-inner{align-items:center;height:60px;padding:0 5vw;display:flex}.navbar-brand{align-items:center;display:flex}.navbar-logo{object-fit:contain;width:auto;height:32px}.navbar-links{flex:1;justify-content:center;gap:4px;display:flex}.navbar-link{color:var(--color-text-secondary);border-radius:var(--radius);white-space:nowrap;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s}.navbar-link:hover:not(.navbar-link--active){color:var(--color-text);background:var(--color-bg)}.navbar-link--active{color:var(--color-primary-text);background:var(--color-primary);cursor:default}.navbar-user{position:relative}.user-avatar{border:1px solid var(--color-border);background:var(--color-bg);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.user-avatar:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.user-dropdown{background:var(--color-surface);border:1px solid var(--color-border);z-index:200;border-radius:16px;min-width:180px;padding:6px;animation:.15s dropdown-fade-in;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 12px 40px #0000001f,0 4px 12px #0000000f}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;color:var(--color-text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;padding:10px 14px;font-size:14px;font-weight:500;transition:all .15s;display:block}.dropdown-item:hover{background:var(--color-bg)}.dropdown-item--danger{color:var(--color-danger)}.dropdown-item--danger:hover{background:#fef2f2}@media (width<=768px){.navbar-inner{flex-wrap:wrap;gap:8px;height:auto;padding:10px 4vw}.navbar-brand{order:1}.navbar-user{order:2;margin-left:auto}.navbar-links{-webkit-overflow-scrolling:touch;scrollbar-width:none;order:3;justify-content:flex-start;gap:2px;width:100%;overflow-x:auto}.navbar-links::-webkit-scrollbar{display:none}.navbar-link{padding:6px 12px;font-size:13px}.navbar-logo{height:26px}}@media (width<=480px){.navbar-inner{padding:8px 3vw}.navbar-link{padding:6px 10px;font-size:12px}}.auth-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--color-surface);width:100%;max-width:420px;box-shadow:var(--shadow-md);border-radius:12px;padding:40px 36px}.auth-header{text-align:center;margin-bottom:28px}.auth-header h1{color:var(--color-primary);margin-bottom:6px;font-size:1.75rem;font-weight:700}.auth-header p{color:var(--color-text-secondary);font-size:.95rem}.auth-error{color:var(--color-danger);border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:10px 14px;font-size:.875rem}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--color-text);font-size:.875rem;font-weight:500}.auth-field input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;color:var(--color-text);background:var(--color-surface);padding:10px 14px;font-family:inherit;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.auth-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.auth-field input::placeholder{color:var(--color-text-secondary);opacity:.6}.auth-btn{background:var(--color-primary);width:100%;color:var(--color-primary-text);border-radius:var(--radius);cursor:pointer;border:none;margin-top:4px;padding:11px 20px;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .15s}.auth-btn:hover:not(:disabled){background:var(--color-primary-hover)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-links{border-top:1px solid var(--color-border);justify-content:space-between;margin-top:20px;padding-top:18px;display:flex}.auth-links a{color:var(--color-primary);font-size:.875rem;font-weight:500;text-decoration:none;transition:opacity .15s}.auth-links a:hover{opacity:.7}.auth-links a:only-child{margin:0 auto}.dashboard{flex-direction:column;gap:24px;display:flex}.view-toggle{border:1px solid var(--color-border);border-radius:var(--radius);width:fit-content;display:inline-flex;overflow:hidden}.toggle-btn{background:var(--color-surface);color:var(--color-text);cursor:pointer;border:none;padding:8px 20px;font-size:14px;font-weight:500;transition:all .15s}.toggle-btn:hover{background:var(--color-primary-light)}.toggle-btn--active{background:var(--color-primary);color:var(--color-primary-text)}.toggle-btn--active:hover{background:var(--color-primary-hover)}.month-selector{color:var(--color-text);align-items:center;gap:4px;font-size:18px;display:flex;position:relative}.month-selector-wrapper{position:relative}.month-selector-btn{color:var(--color-text);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:18px;display:inline-flex}.month-selector-btn:hover{opacity:.7}.month-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:50;min-width:180px;margin-top:6px;padding:4px;position:absolute;top:100%;left:0}.month-option{text-align:left;width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:8px 14px;font-size:14px;display:block}.month-option:hover{background:var(--color-primary-light)}.month-option--active{background:var(--color-primary);color:var(--color-primary-text)}.month-option--active:hover{background:var(--color-primary-hover)}.stat-cards{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;flex:1 1 0;gap:6px;min-width:120px;padding:14px 12px;display:flex}.stat-card--highlight{background:#fdf6e8;border-color:#f0ddb8}.stat-card--highlight .stat-card-label{color:#0e2641b3}.stat-card--highlight .stat-card-value{color:var(--color-primary)}.stat-card-label{color:var(--color-text-secondary);font-size:12px;font-weight:500;line-height:1.3}.stat-card-value{color:var(--color-text);font-size:22px;font-weight:700;line-height:1.2}.stat-card-sub{opacity:.7;font-size:14px;font-weight:500}.charts-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.chart-header h3{color:var(--color-text);font-size:15px;font-weight:600}.chart-subtitle{color:var(--color-text-secondary);font-size:13px}.chart-toggle{border:1px solid var(--color-border);border-radius:6px;display:inline-flex;overflow:hidden}.chart-toggle-btn{background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;border:none;padding:5px 14px;font-size:12px;font-weight:500;transition:all .15s}.chart-toggle-btn:hover{background:var(--color-primary-light)}.chart-toggle-btn--active{background:var(--color-primary);color:var(--color-primary-text)}.chart-toggle-btn--active:hover{background:var(--color-primary-hover)}.trend-nav{justify-content:center;align-items:center;gap:12px;margin-bottom:8px;display:flex}.trend-nav-btn{border:1px solid var(--color-border);background:var(--color-surface);width:28px;height:28px;color:var(--color-text);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.trend-nav-btn:hover:not(:disabled){background:var(--color-primary-light)}.trend-nav-btn:disabled{opacity:.3;cursor:not-allowed}.trend-nav-label{color:var(--color-text-secondary);text-align:center;min-width:130px;font-size:13px;font-weight:500}@media (width<=1024px){.stat-card{flex:0 160px}.charts-row{grid-template-columns:1fr}}@media (width<=640px){.stat-card{flex:0 140px}.stat-card-value{font-size:18px}.chart-header{flex-direction:column;align-items:flex-start}}:root{--react-pdf-annotation-layer:1;--annotation-unfocused-field-background:url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color:Highlight;--input-focus-outline:1px solid Canvas;--input-unfocused-border-color:transparent;--input-disabled-border-color:transparent;--input-hover-border-color:black;--link-outline:none}@media screen and (forced-colors:active){:root{--input-focus-border-color:CanvasText;--input-unfocused-border-color:ActiveText;--input-disabled-border-color:GrayText;--input-hover-border-color:Highlight;--link-outline:1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selecteditem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert();backdrop-filter:invert()}}.annotationLayer{pointer-events:none;transform-origin:0 0;z-index:3;position:absolute;top:0;left:0}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg)translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg)translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg)translateY(-100%)}.annotationLayer canvas{width:100%;height:100%;position:absolute}.annotationLayer section{text-align:initial;pointer-events:auto;box-sizing:border-box;transform-origin:0 0;margin:0;position:absolute}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{width:100%;height:100%;font-size:1em;position:absolute;top:0;left:0}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;vertical-align:top;width:100%;height:100%;margin:0}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{border:2px solid var(--input-disabled-border-color);cursor:not-allowed;background:0 0}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline);background:0 0;border-radius:2px}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-color:#0000;background-image:none}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline);border-radius:2px}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{content:"";background-color:canvastext;display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{width:1px;height:80%;left:45%}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;width:50%;height:50%;top:20%;left:30%}.annotationLayer .textWidgetAnnotation input.comb{padding-left:2px;padding-right:0;font-family:monospace}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{width:100%;height:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none;position:absolute}.annotationLayer .popup{max-width:calc(180px * var(--total-scale-factor));box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto;background-color:#ff9;position:absolute}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{margin-left:calc(5px * var(--total-scale-factor));display:inline-block}.annotationLayer .popupContent{margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor));border-top:1px solid #333}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{width:100%;height:100%;position:absolute;top:0;left:0}.annotationLayer .annotationTextContent{opacity:0;color:#0000;-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:100%;position:absolute}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer:1;--highlight-bg-color:#b400aa;--highlight-selected-bg-color:#006400}@media screen and (forced-colors:active){:root{--highlight-bg-color:Highlight;--highlight-selected-bg-color:ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg)translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg)translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg)translate(-100%)}.textLayer{text-align:initial;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2;line-height:1;position:absolute;inset:0;overflow:hidden}.textLayer :is(span,br){color:#0000;white-space:pre;cursor:text;transform-origin:0 0;margin:0;position:absolute}.textLayer span.markedContent{height:0;top:0}.textLayer .highlight{background-color:var(--highlight-bg-color);border-radius:4px;margin:-1px;padding:1px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:0 0}.textLayer .endOfContent{z-index:-1;cursor:default;-webkit-user-select:none;user-select:none;display:block;position:absolute;inset:100% 0 0}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{width:0;height:0;display:none;position:absolute;top:0;left:0}.report-page{flex-direction:column;height:calc(100vh - 128px);display:flex}.report-body{border:1px solid var(--color-border);border-radius:var(--radius);min-height:0;box-shadow:var(--shadow-sm);background:var(--color-surface);flex:1;gap:0;display:flex;overflow:hidden}.report-sidebar{border-right:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;flex-shrink:0;width:260px;display:flex}.sidebar-header{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;padding:14px 16px;font-size:.8rem;font-weight:600;display:flex}.report-list{flex:1;padding:6px;list-style:none;overflow-y:auto}.report-list-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:flex-start;gap:10px;width:100%;padding:10px;font-family:inherit;transition:background .15s;display:flex}.report-list-item:hover{background:var(--color-bg)}.report-list-item--active,.report-list-item--active:hover{background:var(--color-primary-light)}.report-list-icon{background:var(--color-bg);width:32px;height:32px;color:var(--color-primary);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.report-list-item--active .report-list-icon{background:var(--color-primary);color:#fff}.report-list-info{flex-direction:column;gap:2px;min-width:0;display:flex}.report-list-name{color:var(--color-text);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.825rem;font-weight:500;line-height:1.35;display:-webkit-box;overflow:hidden}.report-list-meta{color:var(--color-text-secondary);font-size:.725rem}.pdf-viewer-container{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.pdf-toolbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:4px;padding:8px 12px;display:flex}.pdf-toolbar-group{align-items:center;gap:2px;display:flex}.pdf-toolbar-divider{background:var(--color-border);width:1px;height:20px;margin:0 8px}.pdf-toolbar-spacer{flex:1}.pdf-toolbar-btn{width:32px;height:32px;color:var(--color-text);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.pdf-toolbar-btn:hover:not(:disabled){background:var(--color-primary-light)}.pdf-toolbar-btn:active:not(:disabled){background:#0e264124}.pdf-toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.pdf-toolbar-btn.pdf-zoom-label{width:auto;color:var(--color-text-secondary);min-width:48px;padding:0 8px;font-family:inherit;font-size:.8rem;font-weight:500}.pdf-page-info{color:var(--color-text-secondary);align-items:center;gap:4px;font-size:.8rem;display:flex}.pdf-page-input{border:1px solid var(--color-border);text-align:center;width:36px;height:28px;color:var(--color-text);background:var(--color-bg);border-radius:5px;outline:none;font-family:inherit;font-size:.8rem;transition:border-color .15s}.pdf-page-input:focus{border-color:var(--color-primary)}.pdf-page-input:disabled{opacity:.5}.pdf-page-total{white-space:nowrap}.pdf-document-wrapper{background:#e8ecf1;flex:1;justify-content:center;min-height:0;display:flex;position:relative;overflow:auto}.pdf-document{flex-direction:column;align-items:center;gap:16px;padding:24px 0;display:flex}.pdf-page-wrapper{scroll-margin-top:12px}.pdf-page{border-radius:2px;box-shadow:0 2px 12px #0000001f}.pdf-page canvas{display:block}.pdf-status{color:var(--color-text-secondary);z-index:2;background:#e8ecf1;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:.9rem;display:flex;position:absolute;inset:0}.pdf-status--error{color:var(--color-danger)}.pdf-error-detail{color:var(--color-text-secondary);text-align:center;max-width:400px;font-size:.8rem}.pdf-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite pdf-spin}@keyframes pdf-spin{to{transform:rotate(360deg)}}.datepicker{width:100%;position:relative}.datepicker-trigger{border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);cursor:pointer;text-align:left;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-size:14px;transition:all .2s;display:flex}.datepicker-trigger:hover{border-color:#b0bec5}.datepicker-trigger--open{border-color:#007aff;box-shadow:0 0 0 3px #007aff1f}.datepicker-trigger svg{color:#94a3b8;flex-shrink:0}.datepicker-placeholder{color:#94a3b8}.datepicker-dropdown{z-index:500;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;width:300px;padding:16px;animation:.15s datepicker-fade-in;position:absolute;bottom:calc(100% + 6px);left:0;box-shadow:0 12px 40px #0000001f,0 4px 12px #0000000f}@keyframes datepicker-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.datepicker-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.datepicker-month-label{color:var(--color-text);font-size:15px;font-weight:600}.datepicker-nav{cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.datepicker-nav:hover{background:var(--color-bg);color:var(--color-text)}.datepicker-weekdays{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.datepicker-weekdays span{text-align:center;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;padding:4px 0;font-size:11px;font-weight:600}.datepicker-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.datepicker-day{aspect-ratio:1;cursor:pointer;width:100%;color:var(--color-text);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;font-size:13px;font-weight:400;transition:all .15s;display:flex}.datepicker-day:hover:not(:disabled):not(.datepicker-day--selected){background:var(--color-bg)}.datepicker-day--outside{color:#cbd5e1;cursor:default}.datepicker-day:disabled{color:#cbd5e1;cursor:not-allowed}.datepicker-day--today{color:#007aff;font-weight:600}.datepicker-day--selected{color:#fff;background:#007aff;font-weight:600}.datepicker-day--selected:hover{background:#0066d6}.dropdown-custom{width:100%;position:relative}.dropdown-trigger{border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);cursor:pointer;text-align:left;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-size:14px;transition:all .2s;display:flex;overflow:hidden}.dropdown-trigger span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dropdown-trigger:hover:not(:disabled){border-color:#b0bec5}.dropdown-trigger--open{border-color:#007aff;box-shadow:0 0 0 3px #007aff1f}.dropdown-trigger--disabled{color:#94a3b8;cursor:not-allowed;background:#f1f5f9}.dropdown-trigger svg{color:#94a3b8;flex-shrink:0;transition:transform .2s}.dropdown-trigger--open svg{transform:rotate(180deg)}.dropdown-placeholder{color:#94a3b8}.dropdown-menu{z-index:500;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;max-height:240px;padding:6px;animation:.15s dropdown-menu-in;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto;box-shadow:0 12px 40px #0000001f,0 4px 12px #0000000f}@keyframes dropdown-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu--upward{animation:.15s dropdown-menu-in-up;top:auto;bottom:calc(100% + 6px)}@keyframes dropdown-menu-in-up{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu::-webkit-scrollbar{width:6px}.dropdown-menu::-webkit-scrollbar-track{background:0 0}.dropdown-menu::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.dropdown-option{width:100%;color:var(--color-text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;justify-content:space-between;align-items:center;padding:9px 12px;font-size:14px;font-weight:400;transition:all .12s;display:flex}.dropdown-option:hover:not(:disabled){background:var(--color-bg)}.dropdown-option--active{color:#007aff;font-weight:500}.dropdown-option--active:hover{background:#007aff0f}.dropdown-option--disabled{color:#cbd5e1;cursor:not-allowed}.page{padding-bottom:72px}.page-header{margin-bottom:32px}.page-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.page-header-title{align-items:center;gap:12px;display:flex}.page-header h1{font-size:28px;font-weight:700}.page-description{color:var(--color-text-secondary);margin-top:6px;font-size:15px}.btn-help{width:28px;height:28px;color:var(--color-text-secondary);box-sizing:border-box;background:0 0;border:1px solid #ece3d1;border-radius:50%;flex-shrink:0;font-size:15px;font-weight:700}.btn-help:hover{background:var(--color-primary);color:var(--color-primary-text)}.btn-help-sm{width:22px;height:22px;font-size:12px}.btn-details{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;margin-left:8px;padding:0;font-size:13px;font-weight:500;text-decoration:underline}.btn-details:hover{color:var(--color-text)}.card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:12px;margin-bottom:24px;padding:24px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-header-left{align-items:center;gap:16px;display:flex}.card-header h2{font-size:18px;font-weight:600}.toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.toggle input{display:none}.toggle-slider{background:#cbd5e1;border-radius:12px;flex-shrink:0;width:40px;height:24px;transition:background .2s;position:relative}.toggle-slider:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.toggle input:checked+.toggle-slider{background:var(--color-primary)}.toggle input:checked+.toggle-slider:after{transform:translate(16px)}.toggle-label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.card-description{color:var(--color-text-secondary);margin-bottom:16px;font-size:14px}.cycle-summary{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.cycle-summary-item{flex-direction:column;flex:1;gap:2px;min-width:120px;display:flex}.cycle-summary-label{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-secondary);font-size:11px;font-weight:600}.cycle-summary-value{color:var(--color-text);font-size:14px;font-weight:600}.cycle-over{color:var(--color-danger)}.cycle-note{color:var(--color-text-secondary);margin-top:-8px;margin-bottom:16px;font-size:12px}.cycle-calendar-row{gap:16px;margin-bottom:20px;display:flex;overflow-x:auto}.cycle-calendar{flex:1;min-width:260px}.cycle-calendar+.cycle-calendar{border-left:1px solid var(--color-border);padding-left:16px}.cycle-calendar-title{color:var(--color-text);text-align:center;margin-bottom:8px;font-size:13px;font-weight:600}.cycle-calendar-grid{-webkit-user-select:none;user-select:none;grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cycle-cal-header{text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-secondary);text-align:center;padding:4px 0;font-size:10px;font-weight:600}.cycle-cal-cell{color:#94a3b8;background:0 0;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;min-height:42px;padding:4px 2px;font-size:12px;display:flex;position:relative}.cycle-cal-empty{min-height:0}.cycle-cal-in{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;transition:background .1s,border-color .1s}.cycle-cal-in:hover{background:#3b82f60f;border-color:#3b82f6}.cycle-cal-has-hours{background:var(--color-primary-light);border-color:var(--color-primary)}.cycle-cal-today{box-shadow:inset 0 0 0 2px #3b82f6}.cycle-cal-selected{background:#3b82f626!important;border-color:#3b82f6!important}.cycle-cal-day{font-size:11px;font-weight:600;line-height:1}.cycle-cal-hrs{color:#fff;background:var(--color-primary);border-radius:8px;margin-top:3px;padding:2px 5px;font-size:9px;font-weight:700;line-height:1}.entries-header{justify-content:flex-end;margin-bottom:12px;display:flex}.entries{flex-direction:column;gap:12px;display:flex}.entry-group{background:var(--color-bg);border-radius:var(--radius);border:1px solid var(--color-border)}.entry-row{flex-wrap:wrap;align-items:flex-end;gap:12px;padding:16px;display:flex}.entry-group>.entry-row{background:0 0;border:none}.entry-row--special{background:var(--color-bg);border-radius:var(--radius);border:1px solid var(--color-border);flex-wrap:wrap}.field{flex-direction:column;flex:1;gap:4px;min-width:120px;display:flex}.field label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.field .required{color:var(--color-danger);font-weight:600}.field .optional{opacity:.7;font-size:11px;font-weight:400}.field select,.field input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);width:100%;padding:10px 12px;font-size:14px;transition:border-color .15s}.field select:focus,.field input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.field input:disabled{color:#94a3b8;cursor:not-allowed;background:#f1f5f9}.field input.input-error{border-color:var(--color-danger)}.field input.input-error:focus{box-shadow:0 0 0 3px #ef44441a}.field select option:disabled{color:#cbd5e1}.field-total{flex:none;min-width:70px}.total-value{border-radius:var(--radius);background:var(--color-primary-light);color:var(--color-primary);text-align:center;padding:10px 12px;font-size:14px;font-weight:600}.validation-errors{flex-direction:column;gap:4px;padding:8px 16px 12px;display:flex}.validation-error{color:var(--color-danger);font-size:12px;font-weight:500}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-save{background:var(--color-primary);color:var(--color-primary-text)}.btn-save:hover:not(:disabled){background:var(--color-primary-hover)}.btn-danger{color:var(--color-danger);border:1px solid var(--color-danger);background:0 0}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:#fff}.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:12px 32px;font-size:15px}.btn-icon{flex-shrink:0;width:40px;height:40px;padding:0;font-size:20px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:16px;width:100%;max-width:560px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-size:18px;font-weight:600}.modal-close{color:var(--color-text-secondary);background:0 0;width:32px;height:32px;font-size:24px}.modal-close:hover{color:var(--color-text)}.modal-body{color:var(--color-text);padding:24px;font-size:14px;line-height:1.7}.modal-body h3{border-top:1px solid var(--color-border);margin-top:24px;margin-bottom:8px;padding-top:20px;font-size:15px;font-weight:600}.modal-body h3:first-child{border-top:none;margin-top:0;padding-top:0}.modal-body ul{margin-bottom:8px;padding-left:20px}.modal-body li{margin-bottom:6px}.formula-block{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:6px;margin-top:8px;padding:16px;display:flex}.formula-block code{color:var(--color-primary);font-family:SF Mono,Fira Code,monospace;font-size:13px}.log-presets{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.btn-preset{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:20px;padding:6px 14px;font-size:13px}.btn-preset:hover{color:#3b82f6;background:#3b82f60d;border-color:#3b82f6}.btn-preset--active{color:#fff;background:#3b82f6;border-color:#3b82f6}.btn-preset--active:hover{color:#fff;background:#2563eb;border-color:#2563eb}.log-controls{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:20px;display:flex}.log-controls .field{flex:1;min-width:180px}.log-output{border:1px solid var(--color-border);border-radius:var(--radius);margin-top:4px;overflow:hidden}.log-output-header{background:var(--color-bg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.copy-wrapper{align-items:center;gap:8px;display:flex}.copy-toast{color:var(--color-success);font-size:12px;font-weight:500;animation:2s forwards toast-fade}@keyframes toast-fade{0%{opacity:0;transform:translate(4px)}10%{opacity:1;transform:translate(0)}80%{opacity:1}to{opacity:0}}.log-output-title{color:var(--color-text-secondary);font-size:13px;font-weight:600}.log-text{white-space:pre-wrap;word-break:break-word;width:100%;color:var(--color-text);resize:vertical;box-sizing:border-box;background:0 0;border:none;outline:none;min-height:400px;max-height:800px;margin:0;padding:16px;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;line-height:1.8;display:block;overflow-y:auto}@media (width<=768px){.page-header h1{font-size:22px}.card{padding:16px}.entry-row{gap:10px;padding:12px}.field{min-width:calc(50% - 8px)}.field-total{flex:calc(50% - 8px);min-width:auto}.btn-icon{align-self:flex-end;width:36px;height:36px;font-size:18px}}@media (width<=480px){.main-content{padding:16px 3vw}.field,.field-total{min-width:100%}.btn-icon{align-self:flex-end}.log-controls{flex-direction:column}.log-controls .field{min-width:100%}}.fho-toast{z-index:9999;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--color-text);background:#fff6;border:1px solid #ffffff4d;border-radius:10px;align-items:center;gap:10px;padding:12px 20px;font-size:14px;font-weight:500;animation:.25s fho-toast-slide-in;display:flex;position:fixed;top:24px;left:24px;box-shadow:0 4px 24px #00000014}.fho-toast--success svg{color:var(--color-success,#16a34a)}.fho-toast--success{border-color:var(--color-success,#16a34a)}.fho-toast--error svg{color:var(--color-danger,#dc2626)}.fho-toast--error{border-color:var(--color-danger,#dc2626)}.fho-toast svg{flex-shrink:0}@keyframes fho-toast-slide-in{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}.sticky-save-bar{z-index:90;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff80;border-top:1px solid #ffffff80;justify-content:flex-end;padding:12px 5vw;animation:.2s sticky-bar-in;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 30px #0000000f}@keyframes sticky-bar-in{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.cal-popup{z-index:510;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;width:280px;padding:16px;animation:.15s cal-popup-in;position:fixed;box-shadow:0 12px 40px #00000026,0 4px 12px #0000000f}@keyframes cal-popup-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.cal-popup-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.cal-popup-title{color:var(--color-text);font-size:14px;font-weight:600}.cal-popup-remove{color:var(--color-danger);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;font-size:12px;font-weight:500;transition:opacity .15s}.cal-popup-remove:hover{opacity:1;text-decoration:underline}.cal-popup-fields{flex-direction:column;gap:10px;display:flex}.cal-popup-field label{color:var(--color-text-secondary);margin-bottom:4px;font-size:12px;font-weight:500;display:block}.cal-popup-field input{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);width:100%;color:var(--color-text);padding:8px 10px;font-size:13px}.cal-popup-field input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4f46e51a}.cal-popup-field input:disabled{color:#94a3b8;cursor:not-allowed;background:#f1f5f9}.cal-popup-actions{align-items:center;gap:8px;margin-top:14px;display:flex}.cal-popup-actions .btn{padding:7px 14px;font-size:13px}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;padding:32px 5vw}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f5f7fa;--color-surface:#fff;--color-primary:#0e2641;--color-primary-hover:#0a1c32;--color-primary-light:#0e264114;--color-primary-text:#f4d09e;--color-text:#1e293b;--color-text-secondary:#64748b;--color-border:#e2e8f0;--color-danger:#ef4444;--color-danger-hover:#dc2626;--color-success:#22c55e;--radius:8px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}h1,h2,h3{line-height:1.3}
