body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{background:#f8f9fa;display:flex;flex-direction:column;min-height:100vh;padding:20px 0;position:relative}.lang-toggle-floating{background:#007fffe6;border:none;border-radius:25px;box-shadow:0 4px 12px #007fff4d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;min-height:48px;min-width:48px;padding:12px 18px;position:absolute;right:20px;top:20px;transition:all .2s;z-index:100}.lang-toggle-floating:hover{background:#007fff;transform:scale(1.05)}.login-form{display:flex;flex:1 1;flex-direction:column;justify-content:center;margin:0 auto;max-width:400px;padding:24px;width:100%}.brand-logo{margin-bottom:40px;text-align:center}.brand-logo h1{color:#007fff;font-size:32px;font-weight:800;margin-bottom:8px}.brand-logo p{color:#6c757d;font-size:16px;margin:0}.logo-container{align-items:center;background:#fff;border:3px solid #f8f9fa;border-radius:50%;box-shadow:0 8px 24px #0000001a;display:flex;height:120px;justify-content:center;margin:0 auto 30px;padding:15px;width:120px}.logo-image{display:block;max-height:100%;max-width:100%;object-fit:contain}.form-group{margin-bottom:20px}.form-group label{font-size:16px;font-weight:600;margin-bottom:8px}.form-group input{border:2px solid #e9ecef;border-radius:12px;box-sizing:border-box;font-size:16px;min-height:56px;padding:16px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#007fff;box-shadow:0 0 0 3px #007fff1a;outline:none}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.btn-primary{border:none;border-radius:12px;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:20px;min-height:56px;padding:18px 24px;transition:all .2s;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #007fff4d;transform:translateY(-1px)}.btn-primary:disabled{box-shadow:none;transform:none}.help-text{text-align:center}.help-text p{color:#6c757d;font-size:14px;margin:0}.whatsapp-float{align-items:center;background:#25d366;border-radius:50%;bottom:30px;box-shadow:0 8px 20px #25d3664d;color:#fff;cursor:pointer;display:flex;font-size:28px;height:60px;justify-content:center;position:fixed;right:30px;transition:transform .2s;width:60px;z-index:1000}.whatsapp-float:hover{transform:scale(1.1)}@media (max-width:480px){.login-container{padding:10px 0}.login-form{padding:16px}.brand-logo h1{font-size:28px}.logo-container{height:100px;padding:12px;width:100px}.lang-toggle-floating{font-size:13px;padding:10px 14px;right:15px;top:15px}.whatsapp-float{bottom:20px;font-size:24px;height:56px;right:20px;width:56px}}.btn-primary:focus,.form-group input:focus,.lang-toggle-floating:focus{box-shadow:0 0 0 3px #007fff40}@media (max-width:360px){.logo-container{height:90px;padding:10px;width:90px}}.form-group input::placeholder{color:#9ca3af;opacity:.7}.form-group input::-webkit-input-placeholder{color:#9ca3af;opacity:.6}.daily-plan-container{background:#fff;box-shadow:0 0 20px #0000001a;margin:0 auto;max-width:400px;min-height:100vh;position:relative}.training-day{background:#28a745;border:2px solid #ffffff4d;border-radius:20px;color:#fff;font-size:px!important;font-weight:700;padding:10px 20px}@media (max-width:480px){.daily-plan-container{box-shadow:none;margin:0}.header{padding:16px}.header-top{margin-bottom:12px}.user-name{font-size:16px}.training-day{font-size:14px;padding:6px 12px}.task-list{padding:16px 16px 100px}.task-card{padding:16px}.task-name{font-size:16px}.task-description{font-size:13px}.progress-tracker{bottom:20px;height:60px;right:16px;width:60px}.progress-text{font-size:12px}.camera-content{padding:16px}.exercise-title{font-size:20px}.camera-message{font-size:16px}}.camera-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f8fafcfa;display:block;height:100%;left:0;overflow-y:auto;padding:20px;position:fixed;top:0;width:100%;z-index:1500}.camera-container{background:#fff;border:2px solid #e2e8f0;border-radius:25px;box-shadow:0 20px 40px #0000001a;margin:20px auto;max-width:900px;padding:30px;position:relative;text-align:center}.camera-close{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:35px;justify-content:center;padding:8px 12px;position:absolute;right:15px;top:15px;transition:all .3s ease;width:35px}.camera-close:hover{background:#dc2626;transform:scale(1.1)}.camera-close:active{transform:scale(.95)}h2#exerciseTitle{color:#3b82f6;font-size:28px;font-weight:700;margin:20px 0;text-align:center}.exercise-demo{margin-bottom:20px}.exercise-demo p{color:#64748b;font-size:16px;font-weight:500}.demo-video{border:2px solid #3b82f6;border-radius:15px;height:200px;margin:0 10px;width:300px}.exercise-counter{animation:pulse-counter .3s ease-in-out;color:#3b82f6;font-size:56px;font-weight:700;margin:20px 0;text-shadow:0 0 10px #3b82f64d}@keyframes pulse-counter{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.set-info{color:#10b981;font-size:24px;font-weight:600;margin-bottom:10px}.target-info{color:#1e293b;font-size:28px;font-weight:600;margin-bottom:20px}.exercise-status{background:#64748b1a;border-radius:10px;color:#64748b;font-size:20px;font-weight:500;margin-bottom:20px;min-height:30px;padding:10px;transition:all .3s ease}.exercise-status.perfect{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.exercise-status.completed{animation:celebration .6s ease-in-out;background:linear-gradient(135deg,#10b9811a,#10b98133);color:#10b981;font-size:22px;font-weight:700}.exercise-status.warning{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}@keyframes celebration{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.rest-timer{animation:pulse-rest 1s infinite;color:#ef4444;font-size:48px;font-weight:700;margin:20px 0;text-shadow:0 0 10px #ef44444d}@keyframes pulse-rest{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}#videoElement{background:#000;border:4px solid #3b82f6;border-radius:15px;max-width:640px;width:100%}.video-container{display:inline-block;margin:25px 0;position:relative}#canvas{border-radius:11px;left:50%;pointer-events:none;position:absolute;top:4px;transform:translateX(-50%)}.whatsapp-support-btn{background:#25d366;border:none;border-radius:25px;box-shadow:0 4px 12px #25d3664d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:15px 25px;transition:all .2s}.whatsapp-support-btn:hover{background:#128c7e;box-shadow:0 6px 16px #25d36666;transform:translateY(-1px)}.whatsapp-support-btn:active{transform:scale(.95)}.loading-overlay{align-items:center;background:#ffffffe6;border-radius:25px;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.loading-spinner{border:4px solid #e2e8f0;border-top-color:#3b82f6;margin-bottom:15px}.completion-message{animation:slideIn .5s ease-out;background:linear-gradient(135deg,#10b981,#059669);border-radius:15px;color:#fff;display:none;font-size:24px;font-weight:700;margin:20px 0;padding:20px}.completion-message.show{display:block}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.camera-container{margin:10px;padding:20px}.exercise-counter{font-size:48px}.target-info{font-size:24px}.set-info{font-size:20px}.exercise-status{font-size:18px}.rest-timer{font-size:40px}h2#exerciseTitle{font-size:24px}.demo-video{height:150px;width:250px}}@media (max-width:480px){.camera-section{padding:10px}.camera-container{border-radius:15px;margin:5px;padding:15px}.exercise-counter{font-size:40px}.target-info{font-size:20px}.set-info{font-size:18px}.exercise-status{font-size:16px;padding:8px}.rest-timer{font-size:36px}h2#exerciseTitle{font-size:20px}#videoElement{border-radius:10px;border-width:2px}#canvas{border-radius:8px;top:2px}.whatsapp-support-btn{font-size:13px;padding:12px 20px}.demo-video{height:130px;margin:0 5px;width:220px}.exercise-demo p{font-size:14px}}.exercise-counter.increment{animation:counter-increment .4s ease-out}@keyframes counter-increment{0%{color:#3b82f6;transform:scale(1)}50%{color:#10b981;transform:scale(1.2)}to{color:#3b82f6;transform:scale(1)}}.camera-status{background:#000000b3;border-radius:20px;color:#fff;font-size:12px;font-weight:600;left:20px;padding:8px 12px;position:absolute;top:20px}.camera-status.active{background:#10b981cc}.camera-status.error{background:#ef4444cc}.pose-overlay{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.success-burst{animation:success-burst .6s ease-out}@keyframes success-burst{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.camp-plan-container{background:#fff;box-shadow:0 0 20px #0000001a;margin:0 auto;max-width:400px;min-height:100vh;position:relative}.header{background:#007fff;color:#fff;padding:20px}.header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.back-btn,.language-toggle{background:#fff3;border:none;border-radius:20px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s}.back-btn:hover,.language-toggle:hover{background:#ffffff4d;transform:scale(1.05)}.user-info{justify-content:space-between;margin-bottom:8px}.user-name{color:#fff!important;font-size:24px!important;font-weight:600}.camp-title{background:#28a745;border:2px solid #ffffff4d;border-radius:20px;color:#fff;font-size:16px!important;font-weight:700;padding:10px 20px}.date-info{font-size:14px;font-weight:500;opacity:.9}.progress-tracker{align-items:center;background:#fff;border-radius:50%;bottom:30px;box-shadow:0 4px 20px #00000026;cursor:pointer;display:flex;height:65px;justify-content:center;position:fixed;right:20px;transition:transform .3s ease;width:65px;z-index:100}.progress-tracker:hover{transform:scale(1.05)}.progress-text{color:#28a745;font-size:13px;font-weight:700}.task-list{padding:20px 20px 100px}.task-group{margin-bottom:30px}.group-title{color:#007fff;font-size:16px;font-weight:700;letter-spacing:.5px;margin-bottom:15px;text-transform:uppercase}.task-card{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-bottom:15px;padding:20px;position:relative;transition:all .3s ease}.task-card:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.task-card.completed{background:#28a745;color:#fff;transform:scale(.98)}.task-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:12px}.task-icon{align-items:center;display:flex;flex-shrink:0;font-size:18px;height:32px;justify-content:center;width:32px}.task-info{min-width:0}.task-name{color:#333;font-size:17px;font-weight:700;margin-bottom:6px}.task-card.completed .task-name{color:#fff}.task-description{color:#666;font-size:14px;line-height:1.4}.task-card.completed .task-description{color:#ffffffe6}.task-controls{gap:12px;justify-content:space-between;margin-top:16px}.audio-btn,.task-controls{align-items:center;display:flex}.audio-btn{background:#f8f9fa;border:2px solid #007fff;border-radius:10px;color:#007fff;cursor:pointer;font-size:16px;height:46px;justify-content:center;min-width:46px;padding:10px;transition:all .2s}.audio-btn:hover{background:#007fff;color:#fff;transform:scale(1.05)}.task-card.completed .audio-btn{background:#fff3;border-color:#fff;color:#fff}.start-btn{background:#007fff;border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;max-width:180px;min-height:46px;padding:12px 24px;transition:all .2s}.start-btn:hover{background:#0056cc;transform:translateY(-1px)}.celebration-overlay{align-items:center;animation:fadeIn .3s ease-in;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1001}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.celebration-content{animation:celebrateIn .8s ease-out;background:#fff;border-radius:20px;margin:20px;max-width:320px;padding:40px 30px;text-align:center}@keyframes celebrateIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.celebration-icon{animation:bounce 2s infinite;font-size:60px;margin-bottom:20px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.celebration-title{color:#28a745;font-size:24px;font-weight:700;margin-bottom:10px}.celebration-message{color:#333;font-size:16px;margin-bottom:8px}.celebration-submessage{color:#666;font-size:14px;margin-bottom:25px}.celebration-btn{background:#007fff;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 30px;transition:all .2s}.celebration-btn:hover{background:#0056cc;transform:translateY(-1px)}.day-locked-message{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 20px;text-align:center}.lock-icon{font-size:60px;margin-bottom:20px;opacity:.7}.lock-title{color:#666;font-size:20px;font-weight:700;margin-bottom:10px}.lock-message{color:#999;font-size:16px;max-width:280px}.completed-indicator{align-items:center;color:#fff;display:flex;flex:1 1;font-size:15px;font-weight:600;gap:8px}.undo-btn{background:#fff3;border:1px solid #fff6;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;position:absolute;right:16px;top:16px;transition:all .2s}.undo-btn:hover{background:#ffffff4d;transform:scale(1.05)}.camera-overlay{background:#000;bottom:0;color:#fff;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:1000}.camera-header{left:20px;position:absolute;top:20px;z-index:10}.camera-back-btn{align-items:center;background:#fff3;border:2px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:44px;justify-content:center;padding:8px;transition:all .2s;width:44px}.camera-back-btn:hover{background:#ffffff4d}.camera-content{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:20px;text-align:center}.exercise-title{color:#fff;font-size:24px;font-weight:700;margin-bottom:20px}.camera-message{color:#fffc;font-size:18px;margin-bottom:30px}.complete-exercise-btn{background:#28a745;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px 30px;transition:all .2s}.complete-exercise-btn:hover{background:#218838;transform:translateY(-1px)}@media (max-width:480px){.camp-plan-container{box-shadow:none;margin:0}.header{padding:16px}.header-top{margin-bottom:12px}.user-name{font-size:16px}.camp-title{font-size:14px;padding:6px 12px}.task-list{padding:16px 16px 100px}.task-card{padding:16px}.task-name{font-size:16px}.task-description{font-size:13px}.progress-tracker{bottom:20px;height:60px;right:16px;width:60px}.progress-text{font-size:12px}.camera-content{padding:16px}.exercise-title{font-size:20px}.camera-message{font-size:16px}}@media (hover:none){.task-card:hover{box-shadow:0 4px 16px #0000001a;transform:none}.audio-btn:hover,.complete-exercise-btn:hover,.progress-tracker:hover,.start-btn:hover{transform:none}.audio-btn:active,.back-btn:active,.complete-exercise-btn:active,.language-toggle:active,.progress-tracker:active,.start-btn:active,.undo-btn:active{transform:scale(.95)}}.homepage-container{background:#f8f9fa;display:flex;flex-direction:column;max-width:100vw;min-height:100vh;overflow-x:hidden;width:100%}.homepage-header{align-items:center;background:#007fff;box-sizing:border-box;color:#fff;display:flex;justify-content:space-between;padding:20px;width:100%}.header-info h1{font-size:22px;font-weight:700;margin:0 0 4px}.village-info{font-size:14px;opacity:.9}.lang-toggle{background:#fff3;border:none;border-radius:25px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;min-height:48px;min-width:48px;padding:12px 18px;transition:all .2s}.lang-toggle:active{background:#fff6;transform:scale(.95)}.homepage-content{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;gap:20px;margin:0 auto;max-width:400px;padding:20px;width:100%}.stats-row{width:100%}.stat-box,.stats-row{display:flex;gap:12px}.stat-box{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:12px;flex:1 1;min-width:0;padding:16px}.stat-box.streak{background:linear-gradient(135deg,#fff8f0,#fff);border-color:#fd7e14}.stat-box.points{background:linear-gradient(135deg,#f0f8ff,#fff);border-color:#007fff}.stat-icon{flex-shrink:0;font-size:28px}.stat-content{min-width:0;text-align:left}.stat-number{font-size:24px;font-weight:800;line-height:1}.stat-box.streak .stat-number{color:#fd7e14}.stat-label{font-size:12px;margin-top:2px}.training-path{flex:1 1;min-height:200px;overflow:hidden;width:100%}.path-container{display:flex;gap:15px;overflow-x:auto;padding:20px 0;scroll-behavior:smooth;width:100%}.path-container::-webkit-scrollbar{display:none}.path-container{-ms-overflow-style:none;scrollbar-width:none}.day-card{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;justify-content:space-between;min-height:180px;padding:20px;transition:all .3s;width:160px}.day-card.completed{background:linear-gradient(135deg,#f8fff8,#fff);border-color:#28a745}.day-card.current{animation:pulse-card 2s infinite;background:linear-gradient(135deg,#f0f8ff,#fff);border-color:#007fff;min-height:200px;transform:scale(1.05);width:180px}.day-card.locked{background:#f8f9fa;cursor:not-allowed;opacity:.6}@keyframes pulse-card{0%,to{box-shadow:0 4px 16px #007fff33;transform:scale(1.05)}50%{box-shadow:0 8px 24px #007fff66;transform:scale(1.1)}}.day-circle{align-items:center;border-radius:50%;display:flex;font-size:14px;font-weight:700;height:85px;justify-content:center;line-height:1.1;margin-bottom:12px;text-align:center;transition:all .3s;width:85px}.day-card.current .day-circle{font-size:18px!important;height:95px;width:95px}.day-card.completed .day-circle{background:#28a745;color:#fff}.day-card.current .day-circle{background:#007fff;color:#fff}.day-card.locked .day-circle{background:#e9ecef;color:#6c757d}.action-button,.day-card.completed-today .day-circle{background:#007fff;color:#fff}.action-button{border:none;border-radius:20px;cursor:pointer;font-size:14px!important;font-weight:600;margin-top:auto;padding:10px 16px;text-align:center;transition:all .2s;width:85%}.action-button:active{background:#06c;transform:scale(.95)}.status-text{border-radius:12px;font-size:12px;font-weight:500;margin-top:auto;padding:6px 12px;text-align:center;width:85%}.status-text.completed{background:#e8f5e8;color:#28a745}.status-text.locked{background:#f8f9fa;color:#6c757d}.status-text.completed-today{background:#fcfdfe;border:1px solid #f5c2c7;color:#d63384}.camp-pathway{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-sizing:border-box;padding:16px;width:100%}.camp-container{gap:10px;justify-content:space-between}.camp-circle,.camp-container{align-items:center;display:flex}.camp-circle{border-radius:50%;cursor:pointer;font-size:14px;font-weight:700;height:68px;justify-content:center;line-height:1.2;text-align:center;transition:all .3s;width:68px}.camp-circle.completed{background:#28a745;color:#fff}.camp-circle.current{animation:pulse-camp 2s infinite;background:#007fff;color:#fff}@keyframes pulse-camp{0%,to{box-shadow:0 4px 16px #007fff4d;transform:scale(1)}50%{box-shadow:0 8px 24px #007fff80;transform:scale(1.05)}}.camp-circle.locked{background:#e9ecef;color:#6c757d;cursor:not-allowed}.village-section{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-sizing:border-box;overflow-x:hidden;padding:12px;width:100%}.village-section h3{color:#4d4d4d;font-size:16px;font-weight:700;margin:0 0 12px}.rankings-compact{box-sizing:border-box;display:flex;flex-direction:column;gap:8px;max-height:240px;overflow-x:hidden;overflow-y:auto;scroll-behavior:smooth;width:100%}.rankings-compact::-webkit-scrollbar{width:4px}.rankings-compact::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.rankings-compact::-webkit-scrollbar-thumb{background:#007fff;border-radius:2px}.rankings-compact::-webkit-scrollbar-thumb:hover{background:#0056b3}.ranking-row{min-height:44px;overflow:hidden;padding:8px 0;width:100%}.rank,.ranking-row{align-items:center;display:flex}.rank{background:#f8f9fa;border-radius:50%;flex-shrink:0;font-size:14px;font-weight:700;height:28px;justify-content:center;margin-right:8px;width:28px}.village-name{color:#4d4d4d;flex-grow:1;font-weight:600;margin-right:38px!important;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.village-points{color:#6c757d;flex-shrink:0;font-size:14px;font-weight:500;white-space:nowrap}.ranking-row.user-village{background:#f0f8ff;border:1px solid #007fff;border-radius:8px;padding:8px 12px}.ranking-row:first-child .rank{background:gold;color:#333}.ranking-row:nth-child(2) .rank{background:silver;color:#333}.ranking-row:nth-child(3) .rank{background:#cd7f32;color:#fff}.logout-btn{background:#fff!important;border:2px solid #fd7e14!important;border-radius:12px;box-shadow:0 4px 12px #fff3;box-sizing:border-box;color:#4d4d4d!important;font-size:16px;font-weight:700;letter-spacing:.5px;margin-top:auto;min-height:56px;padding:16px;text-transform:capitalize;width:100%}.logout-btn:active{background:#f8f9fa;border-color:#c82333;box-shadow:0 2px 8px #dc35454d;transform:scale(.98)}@media (max-width:480px){.homepage-container{max-width:100vw;overflow-x:hidden}.homepage-header{padding:16px}.header-info h1{font-size:20px}.homepage-content{gap:16px;max-width:100%;padding:16px}.stats-row{gap:10px}.stat-box{min-width:0;padding:14px}.day-card{padding:12px;width:120px}.day-card.current{width:140px}.day-circle{font-size:10px;height:60px;width:60px}.day-card.current .day-circle{font-size:11px;height:70px;width:70px}.action-button{font-size:10px;padding:5px 10px}.village-section{padding:12px}.camp-circle{font-size:13px;height:64px;width:64px}}.path-container{scroll-snap-type:x mandatory}.day-card{scroll-snap-align:center}.day-card:active{transform:scale(.95)}.day-card.current:active{transform:scale(1)}.stat-box:active{transform:scale(.98)}.camp-circle:active{transform:scale(.95)}.admin-dashboard{background:#f8f9fa;display:flex;flex-direction:column;max-width:100vw;min-height:100vh;overflow-x:hidden;width:100%}.admin-header{align-items:center;background:#007fff;box-sizing:border-box;color:#fff;display:flex;justify-content:space-between;padding:20px 24px;width:100%}.admin-header h1{font-size:20px;font-weight:700;margin:0}.admin-info{font-size:14px;margin-top:2px;opacity:.9}.logout-btn{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;padding:8px 16px;transition:all .2s}.logout-btn:hover{background:#ffffff4d}.admin-nav{background:#f8f9fa;border-bottom:1px solid #e9ecef;box-sizing:border-box;overflow-x:auto;padding:16px 24px;width:100%}.nav-tabs{display:flex;gap:8px;min-width:-webkit-max-content;min-width:max-content}.nav-tab{background:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s;white-space:nowrap}.nav-tab.active{background:#007fff;border-color:#007fff;color:#fff}.nav-tab:hover:not(.active){background:#f8f9fa}.admin-content{box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;padding:24px;width:100%}.stats-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:20px;text-align:center}.stat-number{color:#007fff;font-size:28px;font-weight:700;margin-bottom:4px}.stat-label{color:#6c757d;font-size:14px;font-weight:500}.data-table{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:24px;overflow:hidden;width:100%}.table-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:16px 20px}.table-title{color:#4d4d4d;font-size:16px;font-weight:600}.table-row{grid-gap:12px;align-items:center;border-bottom:1px solid #f8f9fa;display:grid;font-size:14px;gap:12px;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1.5fr .8fr;justify-items:start!important;padding:12px 20px}.table-row.header,.table-row:hover:not(.header){background:#f8f9fa}.table-row.header{border-bottom:1px solid #e9ecef;color:#4d4d4d;font-weight:600}.user-info{gap:12px}.user-avatar{flex-shrink:0;font-size:14px;font-weight:600}.admin-dashboard .user-name{color:#007fff!important;font-weight:500;text-align:left!important}.user-phone{color:#6c757d;font-size:12px}.badge{background:#e8f5e8;border-radius:12px;color:#28a745;font-size:12px;font-weight:500;padding:4px 8px}.sortable-header{align-items:center;cursor:pointer;display:flex;gap:4px;transition:color .2s;-webkit-user-select:none;user-select:none}.sort-arrow,.sortable-header:hover{color:#007fff}.sort-arrow{font-size:12px;opacity:.7}.village-input-container{align-items:center;display:flex;gap:8px}.village-add-btn{align-items:center;background:#007fff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:24px;justify-content:center;transition:background .2s;width:24px}.village-add-btn:hover{background:#0056b3}.village-input-row{align-items:center;display:flex;gap:8px;margin-top:8px}.village-input-row input{border:1px solid #e9ecef;border-radius:4px;flex:1 1;font-size:14px;min-height:20px;padding:10px 12px}.village-input-row .btn{flex-shrink:0!important;font-size:12px!important;height:auto!important;margin:0;max-width:60px!important;min-height:32px!important;min-width:50px!important;padding:6px 10px!important;width:auto!important}.form-section{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-sizing:border-box;margin-bottom:24px;padding:24px;width:100%}.form-section h3{color:#4d4d4d;font-size:16px;font-weight:600;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group input,.form-group select,.form-group textarea{-webkit-appearance:none;-moz-appearance:textfield;border:1px solid #e9ecef;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007fff;box-shadow:0 0 0 2px #007fff1a;outline:none}.form-group input[type=number]::-webkit-inner-spin-button,.form-group input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.form-group input[type=number]{-moz-appearance:textfield}.day-schedule-section{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:24px;padding:24px}.day-dropdown{margin-bottom:20px}.day-dropdown select{background:#fff;border:2px solid #e9ecef;border-radius:8px;color:#4d4d4d;cursor:pointer;font-size:16px;font-weight:600;max-width:300px;padding:12px 16px;transition:all .2s;width:100%}.day-dropdown select:focus{border-color:#007fff;outline:none}.tasks-for-day{margin-top:24px}.tasks-for-day h4{color:#007fff;font-size:18px;font-weight:700;margin-bottom:16px}.task-list-container{background:#f8f9fa;border:2px dashed #e9ecef;border-radius:8px;min-height:200px;padding:16px}.task-item{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:move;display:flex;justify-content:space-between;margin-bottom:8px;padding:12px 16px;transition:all .2s;-webkit-user-select:none;user-select:none}.task-item:hover{border-color:#007fff;box-shadow:0 2px 8px #007fff1a}.task-item.dragging{opacity:.5;transform:rotate(5deg)}.task-item.drag-over{background:#f8fff8;border-color:#28a745}.task-info{flex:1 1}.task-name{color:#4d4d4d;font-weight:600;margin-bottom:4px}.task-type{color:#6c757d;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.drag-handle{color:#6c757d;cursor:move;font-size:18px;padding:4px}.available-tasks{margin-top:24px}.available-tasks h4{color:#6c757d;font-size:16px;font-weight:600;margin-bottom:16px}.available-tasks-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.available-task-item{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.available-task-item:hover{background:#f0f8ff;border-color:#007fff}.available-task-item.selected{background:#f8fff8;border-color:#28a745}.task-checkbox{cursor:pointer;height:20px;width:20px}.plan-creation-section{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:24px;padding:24px}.plan-preview{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-top:16px;padding:16px}.plan-preview h4{color:#007fff;font-size:16px;font-weight:600;margin-bottom:12px}.btn{border-radius:4px;margin-bottom:4px;margin-right:8px;padding:8px 12px}.btn-primary{padding:12px 24px}.btn-secondary{background:#fff;border:1px solid #e9ecef;color:#6c757d;font-size:12px;padding:6px 10px}.btn-secondary:hover{background:#f8f9fa;border-color:#007fff;color:#007fff}.btn-warning{padding:6px 10px}.btn-success{padding:12px 24px}.loading-container{align-items:center;background:#f8f9fa;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{border:4px solid #e9ecef;border-left-color:#007fff;margin-bottom:16px}.empty-state{color:#6c757d;padding:40px 20px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:16px;margin-bottom:8px}.empty-state-subtext{font-size:14px;opacity:.7}@media (max-width:768px){.admin-dashboard{overflow-x:hidden}.admin-content{padding:16px}.stats-row{gap:12px;grid-template-columns:repeat(2,1fr)}.form-row,.table-row{grid-template-columns:1fr}.table-row{gap:8px;padding:16px}.table-row>div{align-items:center;display:flex;justify-content:space-between}.table-row>div:before{color:#6c757d;content:attr(data-label);font-size:12px;font-weight:600}.nav-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.nav-tab{flex-shrink:0;font-size:12px;padding:10px 16px}.available-tasks-grid,.config-inputs,.task-config-grid{grid-template-columns:1fr}.modal-content{margin:16px;padding:24px}.modal-buttons{flex-direction:column}.modal-btn{width:100%}}@media (max-width:480px){.admin-header{align-items:stretch;flex-direction:column;gap:12px;padding:16px}.admin-nav{padding:12px 16px}.day-schedule-section,.form-section,.plan-creation-section{padding:16px}}.available-task-item:focus,.btn:focus,.form-group input:focus,.form-group select:focus,.nav-tab:focus,.task-item:focus{outline:2px solid #007fff80;outline-offset:2px}.drag-over-zone{background:#f8fff8!important;border-color:#28a745!important}.drag-placeholder{align-items:center;background:#e9ecef;border:2px dashed #6c757d;border-radius:6px;color:#6c757d;display:flex;font-size:14px;height:60px;justify-content:center;margin-bottom:8px}.camp-management{width:100%}.camp-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.camp-nav-btn{background:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s}.camp-nav-btn.active{background:#007fff;border-color:#007fff;color:#fff}.camp-nav-btn:hover:not(.active){background:#f8f9fa}.camp-section{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px}.camp-section h3{color:#4d4d4d;font-size:18px;font-weight:600;margin-bottom:20px}.camp-section h4{color:#007fff;font-size:16px;font-weight:600}.camp-section h4,.form-group{margin-bottom:16px}.form-group label{color:#4d4d4d;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.form-group input,.form-group select{border:1px solid #e9ecef;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px 12px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#007fff;box-shadow:0 0 0 2px #007fff1a;outline:none}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:16px}.tasks-config{margin-top:20px}.task-config-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr;margin-top:16px}.task-config-item{background:#fff;border:1px solid #e9ecef;border-radius:6px;padding:16px}.task-config-item h5{color:#4d4d4d;font-size:14px;font-weight:600;margin:0 0 12px}.config-inputs{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.config-input{display:flex;flex-direction:column;gap:4px}.config-input label{color:#6c757d;font-size:12px;font-weight:500}.config-input input{appearance:none;-webkit-appearance:none;-moz-appearance:textfield;border:1px solid #e9ecef;border-radius:4px;font-size:14px;padding:8px 10px;text-align:center}.config-input input::-webkit-inner-spin-button,.config-input input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.unlock-section{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:20px}.unlock-section h3{color:#4d4d4d;font-size:16px;font-weight:600;margin-bottom:16px;margin-top:0}.users-selection{margin:16px 0}.users-selection label{color:#4d4d4d;display:block;font-size:14px;font-weight:500;margin-bottom:12px}.users-grid{background:#fff;border:1px solid #e9ecef;border-radius:6px;max-height:300px;overflow-y:auto;padding:12px}.user-checkbox{align-items:center;border-radius:4px;cursor:pointer;display:flex;padding:8px;transition:background .2s}.user-checkbox:hover{background:#f8f9fa}.user-checkbox input{cursor:pointer;height:18px;margin-right:10px;width:18px}.user-checkbox span{color:#4d4d4d;font-size:14px}.summary-table{margin-top:16px;overflow-x:auto}.summary-table table{border-collapse:collapse;min-width:800px;width:100%}.summary-table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;font-weight:600;text-align:left;white-space:nowrap}.summary-table td,.summary-table th{color:#4d4d4d;font-size:14px;padding:12px}.summary-table td{border-bottom:1px solid #f8f9fa}.summary-table td.completed{color:#28a745;font-weight:600}.summary-table tbody tr:hover{background:#f8f9fa}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.btn-primary{background:#007fff;color:#fff}.btn-primary:hover:not(:disabled){background:#06c}.btn-primary:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.btn-success{background:#28a745;color:#fff;font-size:12px;padding:6px 12px}.btn-success:hover{background:#218838}.btn-warning{background:#fd7e14;color:#fff;font-size:12px;padding:6px 12px}.btn-warning:hover{background:#e96b00}@media (max-width:768px){.camp-section{padding:16px}.config-inputs,.form-row{grid-template-columns:1fr}.summary-table{overflow-x:scroll}.camp-nav{flex-direction:column}.camp-nav-btn{width:100%}}@media (max-width:480px){.unlock-section{padding:16px}.users-grid{max-height:200px}}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;margin:20px;max-width:400px;padding:32px;text-align:center}.modal-title{color:#fd7e14;font-size:20px;font-weight:700;margin-bottom:16px}.modal-message{color:#4d4d4d;font-size:16px;line-height:1.5;margin-bottom:24px}.modal-buttons{display:flex;gap:12px;justify-content:center}.modal-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.modal-btn.cancel{background:#6c757d;color:#fff}.modal-btn.cancel:hover{background:#5a6268}.modal-btn.replace{background:#fd7e14;color:#fff}.modal-btn.replace:hover{background:#e96b00}.analytics-dashboard{margin:0 auto;max-width:1400px;padding:20px}.analytics-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007fff;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.analytics-header{margin-bottom:30px}.analytics-header h2{color:#333;margin:0 0 20px}.analytics-controls{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-wrap:wrap;gap:20px;padding:15px}.period-selector{display:flex;gap:10px}.period-selector button{background:#fff;border:2px solid #e9ecef;border-radius:6px;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.period-selector button:hover{border-color:#007fff;color:#007fff}.period-selector button.active{background:#007fff;border-color:#007fff;color:#fff}.custom-range-selector{align-items:center;border-left:2px solid #e9ecef;display:flex;gap:10px;padding-left:20px}.custom-range-selector input[type=date]{border:1px solid #e9ecef;border-radius:6px;font-size:14px;padding:8px}.custom-range-selector span{color:#666;font-weight:500}.btn-load-custom{background:#6f42c1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.btn-load-custom:hover{background:#5a32a3}.inactive-days-selector{align-items:center;border-left:2px solid #e9ecef;display:flex;gap:8px;padding-left:20px}.inactive-days-selector label{color:#666;font-size:14px;font-weight:500}.inactive-days-selector input{border:1px solid #e9ecef;border-radius:6px;font-size:14px;font-weight:600;padding:8px;text-align:center}.metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.metric-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.metric-label{color:#666;font-size:14px;font-weight:500;margin-bottom:8px}.metric-value{align-items:center;display:flex;font-size:36px;font-weight:700;margin-bottom:4px}.metric-subtitle{color:#999;font-size:12px}.export-section{margin-bottom:20px;text-align:right}.btn-export{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-export:hover{background:#218838}.btn-export-small{background:#007fff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s}.btn-export-small:hover{background:#0056b3}.chart-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.chart-section h3{color:#333;font-size:18px;margin:0 0 20px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h3{margin:0}.village-details{border-top:1px solid #e9ecef;margin-top:20px;padding-top:15px}.village-row{align-items:center;border-bottom:1px solid #f8f9fa;display:grid;grid-template-columns:50px 1fr 200px 80px;padding:12px}.village-row:hover{background:#f8f9fa}.village-rank{color:#666;font-weight:700}.village-name{font-weight:500}.village-stats{color:#666;font-size:14px}.village-rate{font-size:18px;font-weight:700;text-align:right}.data-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.data-section h3{color:#dc3545;font-size:18px;margin:0 0 20px}.at-risk-table{border:1px solid #e9ecef;border-radius:8px;max-height:600px;overflow:hidden;overflow-y:auto}.at-risk-table .table-header{background:#f8f9fa;border-bottom:2px solid #e9ecef;display:grid;font-weight:600;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr;padding:12px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.at-risk-table .table-header div{cursor:pointer;-webkit-user-select:none;user-select:none}.at-risk-table .table-header div:hover{color:#007fff}.at-risk-table .table-row{align-items:center;border-bottom:1px solid #f8f9fa;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr;padding:12px}.at-risk-table .table-row:hover{background:#fff3cd}.at-risk-table .table-row.at-risk{border-left:4px solid #dc3545}.user-info{gap:10px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:#007fff;border-radius:50%;color:#fff;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.user-name{font-weight:500}.last-active-warning{color:#dc3545;font-weight:600}@media (max-width:1024px){.analytics-controls{align-items:stretch;flex-direction:column}.custom-range-selector,.inactive-days-selector{border-left:none;border-top:2px solid #e9ecef;padding-left:0;padding-top:15px}}@media (max-width:768px){.metrics-grid{grid-template-columns:1fr}.village-row{font-size:14px;grid-template-columns:40px 1fr 100px 60px}.at-risk-table .table-header,.at-risk-table .table-row{font-size:13px;grid-template-columns:1.5fr 1fr .8fr 1fr 1fr}.period-selector{flex-direction:column}.custom-range-selector{flex-wrap:wrap}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.90b3fd73.css.map*/