*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{color:#0f172a;background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.auth-loading{background-color:#fff;justify-content:center;align-items:center;min-height:100vh;display:flex}.app-root{background-color:#f8fafc;flex-direction:row;min-height:100vh;display:flex}.main-content{box-sizing:border-box;flex-direction:column;width:100%;min-height:100vh;margin-left:240px;padding:40px;display:flex}.main-content--tablet{margin-left:160px}.main-content--mobile{margin-left:0;padding:76px 20px 32px}.main-inner{flex:1;width:100%;max-width:900px;margin:0 auto}.auth-page{box-sizing:border-box;background-color:#0f172a;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;display:flex}.auth-brand{text-align:center;margin-bottom:32px}.auth-brand-title{color:#fff;letter-spacing:-.03em;margin:0;font-size:1.6rem;font-weight:700}.auth-brand-sub{color:#94a3b8;margin:6px 0 0;font-size:.85rem;font-weight:500}.auth-card{box-sizing:border-box;background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:400px;padding:36px;box-shadow:0 4px 16px #0000000f}.auth-card--signup{max-width:520px}.auth-card-head{margin-bottom:24px}.auth-card-title{color:#0f172a;margin:0;font-size:1.25rem;font-weight:700}.auth-card-sub{color:#64748b;margin:4px 0 0;font-size:.85rem}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-signup-extra{border-top:1px solid #f1f5f9;flex-direction:column;gap:16px;margin-top:4px;padding-top:20px;display:flex}.auth-footer{text-align:center;border-top:1px solid #f1f5f9;margin-top:20px;padding-top:16px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.form-label-lg{color:#1e293b;letter-spacing:-.01em;font-size:.85rem;font-weight:600}.form-input{color:#0f172a;box-sizing:border-box;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;padding:11px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:#0f172a;box-shadow:0 0 0 3px #0f172a14}.form-input--readonly{color:#64748b;cursor:not-allowed;background-color:#f8fafc;border-color:#e2e8f0}.form-select{color:#0f172a;cursor:pointer;box-sizing:border-box;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;height:44px;padding:11px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-select:focus{border-color:#0f172a;box-shadow:0 0 0 3px #0f172a14}.form-textarea{resize:vertical;box-sizing:border-box;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;padding:12px;font-family:inherit;font-size:.85rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}.form-textarea:focus{border-color:#0f172a;box-shadow:0 0 0 3px #0f172a14}.form-grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-grid-2--gap-lg{gap:20px}.form-error{color:#ef4444;margin:0;font-size:.8rem;font-weight:500}.form-divider{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:10px;margin-top:4px;padding-top:18px;display:flex}.btn{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:6px;font-family:inherit;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background-color:#0f172a;border:none;padding:10px 18px;font-size:.85rem}.btn-primary:hover:not(:disabled){opacity:.9}.btn-primary:disabled{opacity:.7}.btn-primary--sm{padding:4px 12px;font-size:.75rem}.btn-primary--md{padding:8px 18px;font-size:.8rem}.btn-primary--lg{padding:11px 24px;font-size:.85rem}.btn-primary--full{width:100%;padding:12px;font-size:.9rem}.btn-secondary{color:#475569;background:0 0;border:1px solid #cbd5e1;padding:9px 16px;font-size:.8rem}.btn-secondary--sm{padding:4px 10px;font-size:.75rem}.btn-secondary--md{padding:8px 14px;font-size:.8rem}.btn-secondary--lg{padding:10px 20px;font-size:.9rem}.btn-danger{color:#fff;background-color:#ef4444;border:none;padding:10px 20px;font-size:.85rem}.btn-danger:disabled{opacity:.7}.btn-ghost-delete{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.75rem;font-weight:500}.btn-icon{cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex}.btn-link{color:#64748b;cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.85rem;font-weight:500;text-decoration:underline}.btn-link-blue{color:#3b82f6;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.75rem;font-weight:500;text-decoration:underline}.btn-back{cursor:pointer;color:#475569;background-color:#f1f5f9;border:none;border-radius:6px;align-items:center;gap:6px;margin-bottom:16px;padding:8px 14px;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .15s;display:flex}.btn-back:hover{background-color:#e2e8f0}.form-char-count{color:#94a3b8;text-align:right;margin-top:-2px;font-size:.72rem;display:block}.sidebar{color:#94a3b8;box-sizing:border-box;z-index:90;background-color:#0f172a;flex-direction:column;width:240px;height:100vh;padding:40px 16px;display:flex;position:fixed;top:0;left:0}.sidebar--tablet{width:160px}.sidebar-inner{flex-direction:column;flex:1;gap:40px;width:100%;display:flex}.sidebar-brand{padding:0 8px}.sidebar-logo{border-radius:12px;width:100%;max-width:200px;display:block}.sidebar-logo--tablet{max-width:140px}.auth-logo{border-radius:16px;width:280px;margin:0 auto;display:block}.sidebar-nav{flex-direction:column;gap:6px;width:100%;display:flex}.nav-btn{text-align:left;color:#94a3b8;cursor:pointer;background-color:#0000;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 14px;font-family:inherit;font-size:.85rem;font-weight:400;transition:all .2s;display:flex}.nav-btn.active{color:#0f172a;background-color:#fff;font-weight:600}.sidebar-bottom{flex-direction:column;gap:8px;padding:0 12px;display:flex}.logout-btn{color:#f87171;cursor:pointer;background-color:#0000;border:1px solid #334155;border-radius:8px;width:100%;padding:10px;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .2s}.mobile-topbar{z-index:200;background-color:#0f172a;border-bottom:1px solid #1e293b;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex;position:fixed;top:0;left:0;right:0}.mobile-topbar-logo{width:auto;height:28px}.mobile-hamburger{cursor:pointer;color:#fff;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:flex}.mobile-hamburger:hover{background:#1e293b}.mobile-drawer-overlay{z-index:300;background:#00000080;display:flex;position:fixed;inset:0}.mobile-drawer{background:#fff;flex-direction:column;width:280px;max-width:85vw;height:100%;display:flex;box-shadow:4px 0 24px #00000026}.mobile-drawer-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:20px 16px 16px;display:flex}.mobile-drawer-logo{width:auto;height:28px}.mobile-drawer-close{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;display:flex}.mobile-drawer-close:hover{background:#f1f5f9}.mobile-drawer-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.mobile-drawer-btn{cursor:pointer;color:#475569;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;font-family:inherit;font-size:.95rem;font-weight:500;transition:background .15s;display:flex}.mobile-drawer-btn:hover{color:#0f172a;background:#f8fafc}.mobile-drawer-btn.active{color:#0f172a;background:#f1f5f9;font-weight:600}.mobile-drawer-bottom{border-top:1px solid #f1f5f9;padding:16px}.mobile-drawer-logout{color:#b91c1c;cursor:pointer;background:#fff1f2;border:1px solid #fee2e2;border-radius:10px;width:100%;padding:12px;font-family:inherit;font-size:.9rem;font-weight:700}.page-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;display:flex}.section-title{color:#0f172a;letter-spacing:-.02em;margin:0;font-size:1.6rem;font-weight:700}.section-subtitle{color:#64748b;margin:8px 0 0;font-size:.9rem;line-height:1.6}.card{background-color:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:24px;box-shadow:0 4px 12px #00000005}.date-selector{background-color:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:8px;padding:6px 12px;display:flex}.date-nav-btn{cursor:pointer;color:#64748b;background:0 0;border:none;font-size:.8rem}.date-input{color:#0f172a;cursor:pointer;border:none;outline:none;font-family:inherit;font-size:.85rem;font-weight:600}.cat-btn-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px;display:grid}.cat-add-btn{color:#fff;cursor:pointer;text-align:center;border:none;border-radius:12px;padding:16px 14px;font-family:inherit;font-size:.85rem;font-weight:600;transition:transform .15s,opacity .15s;box-shadow:0 4px 10px #0000000a}.cat-add-btn:hover{opacity:.9}.schedule-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:24px;box-shadow:0 4px 12px #00000005}.schedule-title{color:#475569;margin:0 0 18px;font-size:.95rem;font-weight:600}.schedule-empty{text-align:center;color:#94a3b8;padding:40px 0;font-size:.85rem}.schedule-body{flex-direction:column;gap:24px;display:flex}.category-group{flex-direction:column;gap:10px;display:flex}.category-group-label{text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-size:.75rem;font-weight:700}.activity-list{flex-direction:column;gap:10px;display:flex}.activity-item{background-color:#fff;border:1px solid #e2e8f0;border-left-width:4px;border-radius:10px;flex-direction:column;gap:10px;padding:14px 16px;transition:all .2s;display:flex}.activity-item--completed{opacity:.65;background-color:#f8fafc;border-style:dashed;border-color:#cbd5e1;border-left-width:1px}.activity-top{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.activity-left{flex-direction:column;flex:1;min-width:0;display:flex}.activity-name-row{align-items:center;gap:8px;min-width:0;display:flex}.drill-item{background-color:#fff;border:1px solid #e2e8f0;border-left-width:4px;border-radius:10px;justify-content:space-between;align-items:center;padding:14px 16px;transition:all .2s;display:flex}.drill-item--completed{opacity:.65;background-color:#f8fafc;border-style:dashed;border-color:#cbd5e1;border-left-width:1px}.drill-left{flex:1;min-width:0}.drill-right{align-items:center;gap:12px;display:flex}.activity-test-badge{text-transform:uppercase;border:1px solid;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:.65rem;font-weight:600}.activity-name{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:600;overflow:hidden}.activity-name--done{color:#64748b;font-weight:500;text-decoration:line-through}.activity-notes-done{color:#64748b;text-overflow:ellipsis;white-space:nowrap;margin-top:6px;font-size:.8rem;font-style:italic;display:block;overflow:hidden}.score-badge{color:#0f766e;text-transform:uppercase;letter-spacing:.02em;background-color:#e2f5ea;border-radius:6px;margin-top:6px;padding:3px 8px;font-size:.75rem;font-weight:700;display:inline-block}.activity-actions{align-items:center;gap:12px;display:flex}.log-score-btn{cursor:pointer;border:1px solid;border-radius:6px;padding:6px 14px;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .15s}.log-score-btn--done{color:#0f172a;box-shadow:none;background-color:#fff;border-color:#cbd5e1}.drill-meta{align-items:center;gap:8px;min-width:0;margin-top:4px;display:flex}.drill-meta-text{color:#64748b;flex-shrink:0;font-size:.75rem;font-weight:500}.drill-meta-note{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.check-icon-wrap{background-color:#e2f5ea;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:inline-flex}.complete-btn{cursor:pointer;color:#475569;background:0 0;border:1px solid #cbd5e1;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .15s}.complete-btn--done{color:#10b981;background-color:#fff}.inline-score-form{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:8px;padding:12px;display:flex}.score-input{box-sizing:border-box;border:1px solid #e2e8f0;border-radius:6px;outline:none;width:100%;padding:8px;font-family:inherit;font-size:.85rem}.score-time-row{gap:6px;display:flex}.score-time-field{flex-direction:column;flex:1;gap:2px;display:flex}.score-time-label{color:#94a3b8;font-size:.6rem;font-weight:400}.score-notes{resize:vertical;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:6px;outline:none;width:100%;padding:8px;font-family:inherit;font-size:.8rem}.score-form-actions{justify-content:flex-end;gap:6px;display:flex}.library-toolbar{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:row;align-items:center;gap:12px;padding:16px;display:flex;box-shadow:0 2px 8px #00000003}.search-wrap{flex:2;align-items:center;display:flex;position:relative}.search-icon-pos{pointer-events:none;align-items:center;display:flex;position:absolute;left:12px}.search-input{color:#0f172a;box-sizing:border-box;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;padding:10px 10px 10px 36px;font-family:inherit;font-size:.85rem}.filter-select-wrap{flex:1}.filter-select{color:#0f172a;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;padding:10px;font-family:inherit;font-size:.85rem}.template-list{flex-direction:column;gap:10px;display:flex}.template-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;gap:14px;padding:16px;display:flex;box-shadow:0 2px 4px #00000003}.template-card-left{flex-wrap:wrap;flex:1;align-items:center;gap:12px;min-width:0;display:flex}.template-name{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.92rem;font-weight:600;display:block;overflow:hidden}.template-cat-tag{text-transform:uppercase;letter-spacing:.02em;border:1px solid;border-radius:6px;padding:3px 8px;font-size:.68rem;font-weight:700}.template-metric-tag{color:#64748b;align-items:center;gap:4px;font-size:.78rem;font-weight:500;display:inline-flex}.template-actions{align-items:center;gap:8px;display:flex}.edit-btn{color:#475569;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .15s}.empty-state{text-align:center;color:#94a3b8;background-color:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:40px;font-size:.85rem}.create-form-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:28px;box-shadow:0 4px 12px #00000003}.create-form{flex-direction:column;gap:22px;display:flex}.cat-selector-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.cat-selector-btn{color:#475569;cursor:pointer;text-align:center;background-color:#fff;border:2px solid #0000;border-radius:10px;padding:12px 10px;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .15s}.scoring-method-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;display:grid}.scoring-card{cursor:pointer;text-align:center;background-color:#fff;border:2px solid #0000;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:16px 12px;transition:all .15s ease-in-out;display:flex;position:relative}.scoring-card--selected{background-color:#f8fafc;border-color:#0f172a}.scoring-card-icon{justify-content:center;align-items:center;padding:4px;display:flex}.scoring-card-label{color:#475569;font-size:.8rem;font-weight:600}.scoring-card--selected .scoring-card-label{color:#0f172a}.scoring-info-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:2px;display:flex;position:absolute;top:8px;right:8px}.info-box{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;align-items:flex-start;gap:10px;margin-top:6px;padding:12px 16px;display:flex}.info-box-icon{margin-top:2px}.info-box-content{flex-direction:column;gap:2px;display:flex}.info-box-title{color:#1e40af;font-size:.8rem;font-weight:700}.info-box-desc{color:#1e3a8a;font-size:.78rem;line-height:1.4}.share-list{border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.share-list--scroll{max-height:240px;overflow-y:auto}.share-list-row{cursor:pointer;background-color:#fff;border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;padding:11px 14px;transition:background-color .1s;display:flex}.share-list-row:last-child{border-bottom:none}.share-list-row:hover,.share-list-row--checked{background-color:#f8fafc}.share-checkbox{cursor:pointer;accent-color:#0f172a;flex-shrink:0;width:16px;height:16px}.share-list-name{color:#0f172a;font-size:.88rem;font-weight:500}.stat-page{flex-direction:column;gap:24px;padding-bottom:40px;display:flex}.stat-landing{flex-direction:column;gap:28px;display:flex}.stat-charts-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.donut-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:24px;padding:20px;display:flex}.donut-svg-wrap{flex-shrink:0;width:120px;height:120px;position:relative}.donut-overlay{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-count{color:#0f172a;font-size:1.4rem;font-weight:700}.donut-sub{color:#64748b;text-transform:uppercase;font-size:.62rem;font-weight:700}.donut-legend{flex-direction:column;gap:8px;width:100%;display:flex}.donut-legend-title{color:#0f172a;margin:0 0 4px;font-size:.9rem;font-weight:700}.donut-legend-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.legend-row{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.legend-label{color:#334155;font-size:.75rem;font-weight:500}.stat-list-section{flex-direction:column;gap:16px;margin-top:8px;display:flex}.stat-list-title{color:#0f172a;margin:0 0 4px;font-size:1.15rem;font-weight:700}.stat-list-sub{color:#64748b;margin:0;font-size:.82rem}.stat-filter-bar{flex-direction:row;align-items:center;gap:12px;width:100%;display:flex}.filter-pills-row{gap:6px;display:flex;overflow-x:auto}.filter-pill{color:#475569;cursor:pointer;white-space:nowrap;background-color:#fff;border:1px solid #cbd5e1;border-radius:20px;padding:8px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .1s}.filter-pill.active{color:#fff;background-color:#0f172a;border-color:#0f172a}.stat-items-list{flex-direction:column;gap:10px;display:flex}.stat-item-row{cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;padding:16px;transition:all .15s;display:flex;box-shadow:0 1px 2px #00000003}.stat-item-row:hover{border-color:#94a3b8;box-shadow:0 4px 12px #00000008}.stat-item-left{flex-direction:column;flex:1;gap:4px;padding-right:12px;display:flex}.stat-item-title{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.95rem;font-weight:600;overflow:hidden}.stat-item-desc{color:#64748b;-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;margin:0;font-size:.82rem;display:-webkit-box;overflow:hidden}.stat-item-tags{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.stat-item-cat-badge{color:#fff;border-radius:12px;padding:3px 9px;font-size:.72rem;font-weight:700}.stat-item-metric-badge{color:#475569;text-transform:capitalize;background-color:#f1f5f9;border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.stat-item-right{text-align:right;flex-shrink:0;align-items:center;gap:12px;display:flex}.stat-attempts-col{flex-direction:column;align-items:flex-end;display:flex}.stat-attempts-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.02em;font-size:.65rem;font-weight:700}.stat-attempts-count{font-size:1.1rem;font-weight:700}.stat-attempts-count--active{color:#0f172a}.stat-attempts-count--empty{color:#94a3b8}.stat-arrow{color:#cbd5e1;font-size:.9rem}.drilldown-wrap{flex-direction:column;gap:24px;display:flex}.drilldown-header-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.drilldown-info-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.drilldown-title{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;margin:0 0 6px;font-size:1.4rem;overflow:hidden}.drilldown-desc{color:#64748b;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:.9rem;display:-webkit-box;overflow:hidden}.drilldown-cat-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.drilldown-cat-label{color:#475569;font-size:.85rem;font-weight:600}.drilldown-cat-badge{border-radius:999px;padding:6px 10px;font-size:.8rem;font-weight:700}.range-pills-row{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.range-pill{color:#475569;cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:999px;padding:10px 14px;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .1s}.range-pill.active{color:#fff;background-color:#0f172a;border-color:#0f172a}.custom-date-row{flex-wrap:wrap;align-items:center;gap:14px;margin-top:12px;display:flex}.custom-date-label{color:#475569;flex-direction:column;gap:6px;font-size:.8rem;display:flex}.custom-date-input{border:1px solid #e2e8f0;border-radius:8px;outline:none;min-width:160px;padding:10px;font-family:inherit}.chart-stats-grid{grid-template-columns:1.6fr 1fr;gap:20px;display:grid}.chart-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:20px}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.chart-title-sub{color:#64748b;margin:0;font-size:.85rem;font-weight:600}.chart-title-main{color:#0f172a;margin:6px 0 0;font-size:1rem}.chart-count-label{color:#94a3b8;text-align:right;font-size:.8rem;display:block}.chart-count-value{color:#0f172a;font-size:1.35rem;font-weight:700}.chart-scroll{width:100%;overflow-x:auto}.chart-dates-row{color:#64748b;justify-content:space-between;margin-top:12px;font-size:.75rem;display:flex}.kpi-cards{gap:14px;display:grid}.kpi-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:18px}.kpi-label{color:#64748b;margin-bottom:8px;font-size:.8rem;font-weight:600;display:block}.kpi-value{color:#0f172a;font-size:1.4rem;font-weight:700}.result-log-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:20px}.result-log-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.result-log-sub{color:#64748b;margin:0;font-size:.85rem;font-weight:600}.result-log-title{color:#0f172a;margin:6px 0 0;font-size:1rem}.result-log-count{color:#64748b;font-size:.85rem}.result-log-empty{color:#64748b;text-align:center;background-color:#f8fafc;border-radius:12px;padding:30px}.result-log-entries{gap:16px;display:grid}.result-item{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.result-fields-row{flex-wrap:wrap;justify-content:space-between;gap:12px;display:flex}.result-field{min-width:140px}.result-field-label{color:#64748b;margin:0;font-size:.8rem;font-weight:600}.result-field-value{color:#0f172a;margin:6px 0 0;font-weight:700}.result-status-done{color:#16a34a}.result-status-pending{color:#f59e0b}.result-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;display:flex}.result-edit-btn{color:#0f172a;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:.8rem}.result-delete-btn{color:#b91c1c;cursor:pointer;background-color:#fff1f2;border:1px solid #fee2e2;border-radius:8px;padding:8px 12px;font-family:inherit;font-size:.8rem}.result-notes-box{color:#475569;-webkit-line-clamp:4;line-clamp:4;background-color:#f8fafc;border-radius:12px;-webkit-box-orient:vertical;margin-top:16px;padding:14px;font-size:.85rem;display:-webkit-box;overflow:hidden}.result-edit-form{gap:12px;margin-top:16px;display:grid}.result-edit-field{flex-direction:column;gap:6px;display:flex}.result-edit-label{color:#475569;font-size:.8rem;font-weight:600}.result-edit-input{box-sizing:border-box;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:10px;font-family:inherit;font-size:.9rem}.result-edit-time-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.result-edit-time-field{flex-direction:column;gap:2px;display:flex}.result-edit-time-label{color:#94a3b8;font-size:.65rem;font-weight:400}.result-edit-notes{resize:vertical;box-sizing:border-box;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;min-height:88px;padding:10px;font-family:inherit;font-size:.9rem}.result-edit-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.settings-header{border-bottom:1px solid #e2e8f0;margin-bottom:30px;padding-bottom:20px}.settings-header-title{color:#0f172a;margin:0;font-size:1.5rem;font-weight:700}.settings-header-sub{color:#64748b;margin:4px 0 0;font-size:.85rem}.settings-panels{flex-direction:column;gap:32px;width:100%;max-width:800px;display:flex}.settings-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:32px;box-shadow:0 1px 3px #00000005}.settings-panel-title{color:#0f172a;margin:0 0 24px;font-size:1.1rem;font-weight:700}.skill-level-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.skill-level-card{cursor:pointer;text-align:center;background-color:#fff;border:2px solid #e2e8f0;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;padding:16px 12px;transition:all .15s;display:flex}.skill-level-card.selected{background-color:#f8fafc;border-color:#0f172a}.skill-level-label{color:#475569;font-size:.85rem;font-weight:700}.skill-level-card.selected .skill-level-label{color:#0f172a}.settings-form-actions{justify-content:flex-end;margin-top:8px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;background-color:#0f172a26;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-overlay--dark{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1001;background-color:#0f172a66}.modal{box-sizing:border-box;background-color:#fff;border:1px solid #e2e8f0;border-radius:14px;width:100%;max-width:390px;padding:24px;box-shadow:0 10px 25px -5px #0000000d}.modal--confirm{max-width:420px;padding:28px;box-shadow:0 20px 40px -10px #00000014}.modal-header{margin-bottom:16px}.modal-title{color:#0f172a;margin:0 0 6px;font-size:1.15rem;font-weight:600}.modal-cat-badge{color:#fff;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:700;display:inline-block}.modal-confirm-head{margin-bottom:20px}.modal-confirm-title{color:#0f172a;letter-spacing:-.01em;margin:0 0 8px;font-size:1.2rem;font-weight:700}.modal-confirm-desc{color:#64748b;margin:0;font-size:.9rem;line-height:1.5}.modal-form{box-sizing:border-box;flex-direction:column;gap:14px;width:100%;display:flex}.modal-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:8px;width:100%;margin-top:10px;padding-top:14px;display:flex}.modal-confirm-footer{justify-content:flex-end;gap:12px;display:flex}.modal-tab-switcher{box-sizing:border-box;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:3px;display:flex}.modal-tab-btn{color:#475569;cursor:pointer;text-align:center;background-color:#0000;border:none;border-radius:6px;flex:1;padding:6px 0;font-family:inherit;font-size:.75rem;font-weight:500;transition:all .1s}.modal-tab-btn.active{color:#fff;background-color:#0f172a}.line-input{color:#0f172a;box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.line-input:focus{border-color:#0f172a;box-shadow:0 0 0 3px #0f172a14}.line-input[readonly],.line-input[disabled]{color:#64748b;cursor:not-allowed;background:#f8fafc}.app-footer{border-top:1px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:60px;padding:24px 0 20px;display:flex}.footer-logo{border-radius:10px;width:140px;display:block}.footer-meta{align-items:center;gap:10px;display:flex}.footer-tagline{color:#64748b;letter-spacing:.04em;font-size:.78rem;font-weight:500}.footer-sep{color:#cbd5e1;font-size:.75rem}.footer-copy{color:#94a3b8;font-size:.75rem}@media (width>=768px) and (width<=1120px){.main-content{padding:28px}.settings-panel{padding:24px}.create-form-card{padding:22px}.stat-charts-row,.chart-stats-grid{gap:14px}}@media (width<=767px){.section-title{font-size:1.3rem}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px;padding-bottom:14px}.modal-overlay{box-sizing:border-box;padding:16px}.modal{max-width:100%}.modal--confirm{max-width:100%;padding:24px}.auth-card{padding:24px}.auth-form .form-grid-2{grid-template-columns:1fr 1fr}.form-grid-2,.form-grid-2--gap-lg{grid-template-columns:1fr}.library-toolbar{flex-direction:column}.stat-filter-bar{flex-direction:column;align-items:stretch}.cat-btn-grid{grid-template-columns:1fr 1fr}.schedule-card{padding:16px}.activity-item{padding:12px}.drill-item{flex-direction:column;align-items:stretch;gap:10px;padding:12px 14px}.drill-right{border-top:1px solid #f1f5f9;justify-content:flex-start;padding-top:10px}.activity-name{white-space:normal;word-break:break-word}.drill-meta{flex-wrap:wrap}.drill-meta-note{white-space:normal;overflow:visible}.library-toolbar{align-items:stretch}.cat-selector-grid,.scoring-method-grid{grid-template-columns:1fr 1fr}.template-card{flex-direction:column;align-items:stretch;gap:0}.template-card-left{padding-bottom:10px}.template-actions{border-top:1px solid #f1f5f9;justify-content:flex-end;padding-top:10px}.stat-charts-row{grid-template-columns:1fr}.donut-card{flex-wrap:wrap}.donut-legend-grid{grid-template-columns:1fr 1fr}.chart-stats-grid{grid-template-columns:1fr}.drilldown-info-row{flex-direction:column;align-items:flex-start}.drilldown-title{font-size:1.15rem}.kpi-cards{grid-template-columns:repeat(3,1fr)}.result-fields-row{flex-direction:column;gap:8px}.result-field{min-width:auto}.result-actions{flex-flow:wrap;justify-content:flex-end;width:100%}.settings-panel{padding:20px}.skill-level-grid{grid-template-columns:1fr 1fr}}.plan-list{flex-direction:column;gap:12px;display:flex}.plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:12px;padding:16px 20px;transition:box-shadow .15s;display:flex}.plan-card:hover{box-shadow:0 2px 12px #00000012}.plan-card-body{flex:1;min-width:0}.plan-card-name{color:#0f172a;margin-bottom:2px;font-size:1rem;font-weight:700}.plan-card-desc{color:#64748b;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.83rem;overflow:hidden}.plan-card-meta{color:#94a3b8;font-size:.75rem;font-weight:500}.plan-card-cats{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.plan-cat-pill{border:1px solid;border-radius:99px;align-items:center;gap:5px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.plan-cat-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.plan-card-actions{flex-shrink:0;gap:8px;display:flex}.btn-danger--sm{color:#b91c1c;cursor:pointer;background:#fff1f2;border:1px solid #fee2e2;border-radius:8px;padding:6px 10px;font-family:inherit;font-size:.8rem;font-weight:600;transition:background .15s}.btn-danger--sm:hover{background:#fee2e2}.plan-items-list{flex-direction:column;gap:8px;display:flex}.plan-item-row{background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;display:flex}.plan-item-badge{color:#fff;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:.72rem;font-weight:700}.plan-item-badge--test{background-color:#6366f1}.plan-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.plan-item-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.plan-item-meta{color:#94a3b8;font-size:.75rem}.plan-item-remove{cursor:pointer;color:#cbd5e1;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:.9rem;transition:color .15s,background .15s}.plan-item-remove:hover{color:#ef4444;background:#fff1f2}.plan-select-btn{cursor:pointer;text-align:left;background:#fff;border:2px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.plan-select-btn:hover{background:#f8fafc;border-color:#94a3b8}.plan-select-btn.active{background:#f8fafc;border-color:#0f172a}.plan-select-name{color:#1e293b;font-size:.9rem;font-weight:600}.plan-select-meta{color:#94a3b8;font-size:.78rem}@media (width<=480px){.section-title{font-size:1.2rem}.auth-card{padding:20px 16px}.kpi-cards{grid-template-columns:1fr}.stat-item-row{flex-direction:column;align-items:flex-start;gap:8px}.stat-item-right{border-top:1px solid #f1f5f9;justify-content:flex-start;width:100%;padding-top:8px}.stat-arrow{display:none}.donut-legend-grid,.scoring-method-grid{grid-template-columns:1fr}.settings-panel{padding:16px}.modal-tab-btn{padding:6px 2px;font-size:.7rem}}
