:root{--primary-bg: #f8f9fa;--secondary-bg: #ffffff;--primary-text: #212529;--secondary-text: #6c757d;--accent-color: #00cc99;--accent-hover: #00b386;--border-color: #dee2e6;--shadow: 0 4px 6px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04)}body,html{margin:0;padding:0;background-color:var(--primary-bg)}.login-container{display:flex;min-height:100vh;font-family:Poppins,sans-serif;background-color:var(--primary-bg)}.login-left-panel{flex:1;background:linear-gradient(160deg,#0c9,#00957a 60%,#007a64);display:flex;flex-direction:column;gap:1.5rem;padding:2.5rem;color:#fff;position:relative;overflow-y:auto;border-radius:12px;scrollbar-width:none}.login-left-panel::-webkit-scrollbar{display:none}.login-left-panel:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><g fill="%23ffffff" fill-opacity="0.05"><circle cx="36" cy="24" r="5"/></g></svg>');pointer-events:none}.login-branding{position:relative;z-index:2;display:flex;flex-direction:column;gap:.4rem}.login-logo-badge{width:48px;height:48px;background:#fff3;border:2px solid rgba(255,255,255,.35);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-title{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;background:linear-gradient(45deg,#fff,#fffc);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 2px 4px rgba(0,0,0,.1)}.login-subtitle{font-size:1.1rem;font-weight:400;margin:0;opacity:.9;color:#ffffffd9}.login-section{position:relative;z-index:2;display:flex;flex-direction:column;gap:.65rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.15)}.login-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#ffffff80;margin:0}.login-steps{display:flex;flex-direction:column;gap:.5rem}.login-step{display:flex;align-items:center;gap:.75rem;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.65rem .85rem}.login-step-badge{width:22px;height:22px;min-width:22px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;color:#fff;flex-shrink:0}.login-step-icon{font-size:1rem;color:#ffffffd9;flex-shrink:0}.login-feature-title{font-size:.82rem;font-weight:600;color:#fff;margin:0 0 .1rem;line-height:1.3}.login-feature-desc{font-size:.73rem;color:#ffffffa6;margin:0;line-height:1.35}.login-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.login-feature-card{background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:.75rem .6rem;display:flex;flex-direction:column;align-items:flex-start;gap:.3rem}.login-feature-card-icon{font-size:1.1rem;color:#ffffffe6;margin-bottom:.1rem}.login-feature-card-title{font-size:.75rem;font-weight:700;color:#fff;margin:0;line-height:1.2}.login-feature-card-desc{font-size:.68rem;color:#fff9;margin:0;line-height:1.3}.login-quote{position:relative;z-index:2;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.15)}.motivational-carousel{position:relative;z-index:2;flex:1;display:flex;align-items:center;justify-content:center;margin:2rem 0}.phrase-container{text-align:center;max-width:500px;height:120px;display:flex;align-items:center;justify-content:center}.motivational-phrase{font-size:1.5rem;font-weight:600;line-height:1.4;margin:0;opacity:0;transform:translateY(20px);animation:fadeInUp .8s ease-out forwards,fadeOut .8s ease-out 3.2s forwards;color:#fffffff2;text-shadow:0 2px 8px rgba(0,0,0,.15)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{to{opacity:0;transform:translateY(-20px)}}.login-footer-actions{display:flex;align-items:center;justify-content:space-between;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-color);gap:.5rem;flex-wrap:wrap}.login-status-badge{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--secondary-text);font-weight:500}.login-status-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e40;flex-shrink:0}.login-support-link{font-size:.78rem;color:var(--accent-color);font-weight:500;text-decoration:none;transition:color .2s;white-space:nowrap}.login-support-link:hover{color:var(--accent-hover);text-decoration:underline}.password-toggle{position:absolute;right:.85rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--secondary-text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;padding:.2rem;border-radius:4px;transition:color .2s;-webkit-tap-highlight-color:transparent}.password-toggle:hover{color:var(--accent-color)}.input-wrapper input[type=password],.input-wrapper input[type=text]{padding-right:2.8rem}.login-right-panel{flex:1;background-color:var(--primary-bg);display:flex;align-items:center;justify-content:center;padding:2rem}.login-form-container{width:100%;max-width:420px;background-color:var(--secondary-bg);padding:3rem;border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.login-header{text-align:center;margin-bottom:2.5rem}.login-header h2{font-size:2rem;font-weight:700;color:var(--primary-text);margin:0 0 .5rem}.login-header p{font-size:1rem;color:var(--secondary-text);margin:0;font-weight:400}.login-form{display:flex;flex-direction:column;gap:1.5rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.9rem;font-weight:600;color:var(--primary-text);margin-left:4px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--secondary-text);font-size:1.1rem;z-index:1}.input-wrapper input{width:100%;padding:1rem 1rem 1rem 2.8rem;border:2px solid var(--border-color);border-radius:12px;font-size:1rem;font-family:inherit;background-color:var(--secondary-bg);color:var(--primary-text);transition:all .2s ease-in-out;box-sizing:border-box}.input-wrapper input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #00cc991a}.input-wrapper input::placeholder{color:var(--secondary-text);opacity:.7}.error-message{background-color:#fee2e2;color:#dc2626;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;border:1px solid #fecaca}.login-button{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--accent-color) 0%,var(--accent-hover) 100%);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease-in-out;margin-top:.5rem;box-shadow:0 4px 14px #00cc9940}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #00cc9959}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.button-icon{font-size:1.1rem}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.social-divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0}.social-divider:before,.social-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.social-divider span{padding:0 1rem;color:var(--secondary-text);font-size:.85rem;font-weight:500}.social-buttons{display:flex;gap:1rem}.social-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;border-radius:12px;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease-in-out;border:2px solid var(--border-color);background-color:var(--secondary-bg);color:var(--primary-text)}.social-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow)}.social-button:active:not(:disabled){transform:translateY(0)}.social-button:disabled{opacity:.6;cursor:not-allowed}.social-icon{font-size:1.25rem}.google-button:hover:not(:disabled){border-color:#4285f4;background-color:#f8faff}.apple-button:hover:not(:disabled){border-color:#000;background-color:#f5f5f5}@media (max-width: 1024px){.login-container{min-height:100vh}.login-left-panel{padding:2.5rem}.login-right-panel{padding:1.5rem}.login-form-container{max-width:380px;padding:2.5rem}}@media (max-width: 768px){.login-container{flex-direction:column;min-height:100vh}.login-left-panel{min-height:35vh;max-height:35vh;padding:2rem;flex:none}.login-section,.login-quote{display:none}.login-footer-actions{flex-direction:column;align-items:flex-start;gap:.35rem}.login-logo-badge{width:36px;height:36px;font-size:1.1rem;border-radius:10px;margin-bottom:.25rem}.motivational-carousel{margin:.5rem 0 0}.login-right-panel{flex:1;min-height:65vh;padding:1rem}.login-title{font-size:2rem;margin-bottom:.3rem}.login-subtitle{font-size:1rem}.motivational-phrase{font-size:1.2rem;line-height:1.3}.login-form-container{padding:2rem;margin:0;max-width:100%;width:100%;max-width:420px;border-radius:16px}.phrase-container{height:70px;max-width:400px}.login-header h2{font-size:1.8rem}.login-header{margin-bottom:2rem}}@media (max-width: 480px){.login-left-panel{min-height:30vh;max-height:30vh;padding:1.5rem}.login-right-panel{min-height:70vh;padding:.5rem}.login-form-container{padding:1.5rem;border-radius:12px;box-shadow:var(--shadow)}.login-title{font-size:1.7rem}.login-subtitle{font-size:.9rem}.motivational-phrase{font-size:1rem;line-height:1.2}.phrase-container{height:60px;max-width:300px}.login-header h2{font-size:1.6rem}.login-header p{font-size:.9rem}.login-header{margin-bottom:1.5rem}.login-form{gap:1.2rem}.input-wrapper input{padding:.9rem .9rem .9rem 2.5rem;font-size:.95rem}.input-icon{left:.8rem;font-size:1rem}.login-button{padding:.9rem 1.2rem;font-size:.95rem}.login-footer p{font-size:.85rem}}@media (max-width: 360px){.login-left-panel{padding:1rem}.login-form-container{padding:1.2rem}.login-title{font-size:1.5rem}.motivational-phrase{font-size:.95rem}.phrase-container{height:50px}.login-header h2{font-size:1.4rem}}.custom-dropdown.compact .custom-dropdown-trigger{padding:.6rem .85rem;min-height:unset;border-radius:9px;border:1.5px solid #dee2e6;box-shadow:none;background:#f8f9fa;font-size:.88rem;font-family:Poppins,sans-serif}.custom-dropdown.compact .custom-dropdown-trigger:hover{border-color:#00cc9980;transform:none}.custom-dropdown.compact.open .custom-dropdown-trigger{border-color:#0c9;box-shadow:0 0 0 3px #00cc991f;background:#fff;border-bottom-left-radius:0;border-bottom-right-radius:0}.custom-dropdown.compact:focus .custom-dropdown-trigger{border-color:#0c9;box-shadow:0 0 0 3px #00cc991f}.custom-dropdown.compact .custom-dropdown-value{font-size:.88rem;font-weight:400}.custom-dropdown.compact .custom-dropdown-arrow{width:16px;height:16px;margin-left:8px}.custom-dropdown.compact .custom-dropdown-menu{border-radius:0 0 9px 9px;border:1.5px solid #00cc99;border-top:none;font-size:.88rem;font-family:Poppins,sans-serif}.custom-dropdown.compact .custom-dropdown-option{padding:.6rem .85rem;font-size:.88rem}.custom-dropdown.compact.disabled .custom-dropdown-trigger{opacity:.45;background:#f8f9fa;border-color:#dee2e6}.custom-dropdown{position:relative;width:100%;font-size:16px;-webkit-user-select:none;user-select:none;z-index:1}.custom-dropdown.open{z-index:100}.custom-dropdown:focus{outline:none}.custom-dropdown:focus .custom-dropdown-trigger{border-color:#0c9;box-shadow:0 0 0 4px #00cc9926,0 4px 12px #0c93}.custom-dropdown.disabled{opacity:.6;cursor:not-allowed}.custom-dropdown.disabled .custom-dropdown-trigger{background-color:#f3f4f6;border-color:#e5e7eb;cursor:not-allowed}.custom-dropdown-trigger{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#fff;border:2px solid rgba(0,204,153,.3);border-radius:12px;cursor:pointer;transition:all .3s ease;min-height:48px;box-shadow:0 2px 8px #0000000d}.custom-dropdown-trigger:hover{border-color:#00cc9980;transform:translateY(-1px)}.custom-dropdown.open .custom-dropdown-trigger{border-color:#0c9;box-shadow:0 0 0 4px #00cc9926,0 4px 12px #0c93;border-bottom-left-radius:0;border-bottom-right-radius:0}.custom-dropdown-value{flex:1;color:#1a202c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.custom-dropdown-value.placeholder{color:#9ca3af;font-weight:400;font-style:italic}.custom-dropdown-arrow{width:20px;height:20px;color:#0c9;transition:transform .3s ease;flex-shrink:0;margin-left:12px}.custom-dropdown-arrow.rotated{transform:rotate(180deg)}.custom-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin:0;padding:8px 0;list-style:none;background:#fff;border:2px solid #00cc99;border-top:none;border-bottom-left-radius:12px;border-bottom-right-radius:12px;box-shadow:0 8px 24px #00cc9926,0 4px 12px #0000001a;max-height:240px;overflow-y:auto;z-index:9999;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.custom-dropdown-option{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;cursor:pointer;transition:all .2s ease;color:#374151;font-weight:500}.custom-dropdown-option:hover,.custom-dropdown-option.highlighted{background:linear-gradient(135deg,#00cc9914,#00cc990a);color:#008060}.custom-dropdown-option.selected{background:linear-gradient(135deg,#00cc9926,#00cc991a);color:#008060;font-weight:600}.custom-dropdown-option.selected:hover,.custom-dropdown-option.selected.highlighted{background:linear-gradient(135deg,#0c93,#00cc9926)}.custom-dropdown-check{width:18px;height:18px;color:#0c9;flex-shrink:0;margin-left:12px}@media (max-width: 640px){.custom-dropdown.compact .custom-dropdown-trigger{padding:.75rem .9rem;font-size:1rem;min-height:48px}.custom-dropdown.compact .custom-dropdown-value{font-size:1rem}.custom-dropdown.compact .custom-dropdown-option{padding:.75rem .9rem;font-size:1rem}.custom-dropdown-menu{max-height:180px}}.custom-dropdown-menu::-webkit-scrollbar{width:6px}.custom-dropdown-menu::-webkit-scrollbar-track{background:#00cc990d;border-radius:3px}.custom-dropdown-menu::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#0c9,#00b386);border-radius:3px}.custom-dropdown-menu::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#00e0ad,#0c9)}.modal-overlay{position:fixed;inset:0;background:#21252973;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;font-family:Poppins,sans-serif;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:580px;max-height:88vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000002e;scrollbar-width:thin;scrollbar-color:#e9ecef transparent}.modal-content::-webkit-scrollbar{width:4px}.modal-content::-webkit-scrollbar-thumb{background:#dee2e6;border-radius:4px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 0;position:sticky;top:0;background:#fff;z-index:2;border-bottom:1px solid transparent}.modal-header h2{display:flex;align-items:center;gap:.6rem;color:#212529;font-size:1.2rem;font-weight:700;margin:0}.modal-header h2 svg{color:#0c9;font-size:1.3rem}.modal-close-button{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#6c757d;font-size:1rem;cursor:pointer;padding:.4rem;display:flex;align-items:center;transition:background .2s,color .2s;flex-shrink:0}.modal-close-button:hover{background:#e9ecef;color:#212529}.modal-body{padding:1.25rem 1.75rem 1.75rem;display:flex;flex-direction:column;gap:.75rem}.block-warning{display:flex;align-items:center;gap:.75rem;background:#fff5f5;border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:10px;padding:.9rem 1rem;color:#dc2626;font-size:.87rem}.block-warning svg{flex-shrink:0;font-size:1.1rem}.block-warning p{margin:0}.seats-info{display:flex;align-items:center;gap:.5rem;background:#f0fdf9;border:1px solid #a7f3d0;border-left:4px solid #00cc99;border-radius:10px;padding:.75rem 1rem;font-size:.87rem}.seats-badge{color:#00b386;font-weight:700}.seats-remaining{color:#6c757d}.form-error{display:flex;align-items:center;gap:.5rem;background:#fff5f5;border:1px solid #fecaca;border-radius:10px;padding:.75rem 1rem;color:#dc2626;font-size:.85rem}.form-error svg{flex-shrink:0}.form-error p{margin:0}.form-section{display:flex;flex-direction:column;gap:.85rem}.section-title{color:#00b386;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;margin:0;padding-bottom:.5rem;border-bottom:2px solid #e9ecef}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-row.three-col{grid-template-columns:1fr 1fr 1fr}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field label{color:#495057;font-size:.8rem;font-weight:500}.form-field input{background:#f8f9fa;border:1.5px solid #dee2e6;border-radius:9px;padding:.6rem .85rem;color:#212529;font-size:.88rem;font-family:Poppins,sans-serif;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;width:100%;box-sizing:border-box}.form-field input:focus{border-color:#0c9;box-shadow:0 0 0 3px #00cc991f;background:#fff}.form-field input:disabled{opacity:.45;cursor:not-allowed}.form-field .select-wrapper{position:relative}.form-field .select-wrapper:after{content:"";position:absolute;right:.85rem;top:50%;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #6c757d;pointer-events:none;transition:border-top-color .2s}.form-field .select-wrapper:focus-within:after{border-top-color:#0c9}.form-field select{appearance:none;-webkit-appearance:none;background:#f8f9fa;border:1.5px solid #dee2e6;border-radius:9px;padding:.6rem 2.2rem .6rem .85rem;color:#212529;font-size:.88rem;font-family:Poppins,sans-serif;outline:none;cursor:pointer;width:100%;box-sizing:border-box;transition:border-color .2s,box-shadow .2s,background .2s}.form-field select:focus{border-color:#0c9;box-shadow:0 0 0 3px #00cc991f;background:#fff}.form-field select:disabled{opacity:.45;cursor:not-allowed}.form-field select option{color:#212529;background:#fff}.creating-state{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2.5rem 1rem}.creating-spinner{width:44px;height:44px;border:3px solid #e9ecef;border-top-color:#0c9;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.creating-steps{display:flex;flex-direction:column;gap:.55rem;width:100%;max-width:320px}.creating-step{display:flex;align-items:center;gap:.6rem;font-size:.88rem;transition:all .3s ease}.creating-step.pending{color:#ced4da}.creating-step.active{color:#212529;font-weight:600}.creating-step.done{color:#0c9}.step-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background .3s ease}.creating-step.pending .step-dot{background:#dee2e6}.creating-step.active .step-dot{background:#0c9;box-shadow:0 0 0 3px #0c93;animation:pulse-dot 1s ease infinite}.creating-step.done .step-dot{background:#0c9}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 3px #0c93}50%{box-shadow:0 0 0 6px #00cc9914}}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.75rem;border-top:1px solid #e9ecef;margin-top:.25rem}.cancel-button{background:#fff;border:1.5px solid #dee2e6;border-radius:10px;padding:.65rem 1.25rem;color:#6c757d;cursor:pointer;font-size:.88rem;font-weight:500;font-family:Poppins,sans-serif;transition:border-color .2s,color .2s}.cancel-button:hover{border-color:#adb5bd;color:#212529}.create-button{background:linear-gradient(135deg,#0c9,#00b386);border:none;border-radius:10px;padding:.65rem 1.5rem;color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;font-family:Poppins,sans-serif;box-shadow:0 4px 14px #00cc9959;transition:opacity .2s,transform .1s,box-shadow .2s}.create-button:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 18px #0c96}.create-button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.success-modal{max-width:460px}.success-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1.75rem 1rem;text-align:center}.success-icon{width:60px;height:60px;background:linear-gradient(135deg,#0c9,#00b386);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.8rem}.success-header h2{color:#212529;font-size:1.15rem;font-weight:700;margin:0}.success-body{padding:0 1.75rem 1.75rem;display:flex;flex-direction:column;gap:1rem}.credentials-box{background:#f8f9fa;border:1.5px solid #e9ecef;border-radius:12px;padding:1.1rem 1.25rem}.credentials-intro{color:#6c757d;font-size:.83rem;margin:0 0 .85rem;line-height:1.5}.credential-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e9ecef;gap:.5rem}.credential-item:last-of-type{border-bottom:none}.credential-item label{color:#6c757d;font-size:.8rem;font-weight:500;flex-shrink:0}.credential-item span{color:#212529;font-size:.88rem;font-weight:500;text-align:right}.temp-password{font-family:Courier New,monospace!important;background:#e9ecef;padding:.2rem .6rem;border-radius:6px;color:#00b386!important;font-weight:700!important;letter-spacing:.07em;font-size:.9rem!important}.copy-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:.85rem;background:#fff;border:1.5px solid #dee2e6;border-radius:9px;padding:.65rem 1rem;color:#495057;cursor:pointer;font-size:.86rem;font-weight:500;font-family:Poppins,sans-serif;transition:background .2s,border-color .2s,color .2s}.copy-button:hover{background:#f8f9fa;border-color:#adb5bd}.copy-button.copied{background:#f0fdf9;border-color:#a7f3d0;color:#00b386}.next-steps{background:#f0fdf9;border:1.5px solid #a7f3d0;border-radius:10px;padding:1rem 1.25rem}.next-steps h4{color:#00b386;margin:0 0 .6rem;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.next-steps ol{color:#495057;font-size:.83rem;padding-left:1.2rem;margin:0;display:flex;flex-direction:column;gap:.3rem;line-height:1.5}.close-success-button{width:100%;background:#f8f9fa;border:1.5px solid #dee2e6;border-radius:10px;padding:.75rem;color:#495057;cursor:pointer;font-size:.88rem;font-weight:500;font-family:Poppins,sans-serif;transition:background .2s,border-color .2s}.close-success-button:hover{background:#e9ecef;border-color:#adb5bd;color:#212529}@media (max-width: 640px){.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:20px 20px 0 0;max-width:100%;height:100dvh;max-height:100dvh;width:100%;padding-bottom:env(safe-area-inset-bottom)}.modal-content:before{content:"";display:block;width:40px;height:4px;background:#dee2e6;border-radius:4px;margin:.75rem auto 0}.modal-header{padding:.75rem 1.25rem}.modal-header h2{font-size:1rem}.modal-body{padding:1rem 1.25rem 1.25rem}.form-row,.form-row.three-col{grid-template-columns:1fr;gap:.65rem}.form-field input,.form-field select{padding:.75rem .9rem;font-size:1rem;border-radius:10px}.form-actions{flex-direction:column-reverse;gap:.6rem;padding-top:1rem}.cancel-button,.create-button{width:100%;padding:.85rem 1rem;font-size:.95rem;border-radius:12px;text-align:center;justify-content:center}.success-modal{max-width:100%}.success-header{padding:1.25rem 1.25rem .75rem}.success-body{padding:0 1.25rem 1.25rem}.close-success-button{padding:.85rem;font-size:.95rem;border-radius:12px}.credential-item{flex-direction:column;align-items:flex-start;gap:.2rem}.credential-item span{text-align:left;word-break:break-all}}.subs-panel-overlay{position:fixed;inset:0;background:#21252959;z-index:900;display:flex;justify-content:flex-end}.subs-panel{width:380px;max-width:100vw;height:100vh;background:#fff;border-left:1px solid #e9ecef;display:flex;flex-direction:column;overflow:hidden;box-shadow:-8px 0 24px #0000001a;animation:slideIn .25s ease;font-family:Poppins,sans-serif}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.subs-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#0c9,#00b386);flex-shrink:0}.subs-panel-header h2{display:flex;align-items:center;gap:.5rem;color:#fff;font-size:1.1rem;font-weight:700;margin:0}.subs-close-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:1.1rem;cursor:pointer;padding:.35rem;display:flex;align-items:center;transition:background .2s}.subs-close-btn:hover{background:#ffffff59}.subs-tabs{display:flex;border-bottom:1px solid #e9ecef;flex-shrink:0;background:#f8f9fa}.subs-tab{flex:1;padding:.75rem .5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:#6c757d;font-size:.83rem;font-weight:500;cursor:pointer;font-family:Poppins,sans-serif;transition:color .2s,border-color .2s}.subs-tab.active{color:#0c9;border-bottom-color:#0c9;background:#fff}.subs-tab:hover:not(.active){color:#212529}.subs-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem;color:#6c757d;font-size:.9rem}.subs-spinner{width:32px;height:32px;border:3px solid #e9ecef;border-top-color:#0c9;border-radius:50%;animation:spin .8s linear infinite}.subs-content{flex:1;overflow-y:auto;padding:1.25rem;background:#f8f9fa}.tab-resumen{display:flex;flex-direction:column;gap:1rem}.resumen-status-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1px solid #e9ecef;border-left-width:4px;border-radius:10px;box-shadow:0 2px 8px #0000000a}.resumen-status-icon{font-size:1.4rem;flex-shrink:0}.resumen-status-label{color:#6c757d;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;margin:0}.resumen-status-value{font-size:1rem;font-weight:700;margin:.1rem 0 0}.resumen-expiry{display:flex;align-items:center;gap:.35rem;color:#6c757d;font-size:.78rem;margin-left:auto;white-space:nowrap}.resumen-cupos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.cupo-card{background:#fff;border:1px solid #e9ecef;border-radius:10px;padding:1rem .75rem;text-align:center;box-shadow:0 2px 8px #0000000a}.cupo-number{font-size:2rem;font-weight:800;color:#212529;margin:0;line-height:1}.cupo-label{font-size:.7rem;color:#6c757d;margin:.35rem 0 0;font-weight:500}.cupo-used .cupo-number{color:#f59e0b}.cupo-available .cupo-number{color:#0c9}.cupo-zero .cupo-number{color:#ef4444}.cupos-bar-container{display:flex;align-items:center;gap:.75rem}.cupos-bar-track{flex:1;height:7px;background:#e9ecef;border-radius:4px;overflow:hidden}.cupos-bar-fill{height:100%;background:linear-gradient(90deg,#0c9,#00b386);border-radius:4px;transition:width .5s ease}.cupos-bar-label{font-size:.75rem;color:#6c757d;white-space:nowrap}.subs-create-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.8rem;background:linear-gradient(135deg,#0c9,#00b386);border:none;border-radius:10px;color:#fff;font-size:.9rem;font-weight:600;font-family:Poppins,sans-serif;cursor:pointer;box-shadow:0 4px 12px #00cc994d;transition:opacity .2s,transform .1s}.subs-create-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.subs-create-btn:disabled{background:#e9ecef;color:#adb5bd;box-shadow:none;cursor:not-allowed}.tab-alumnos{display:flex;flex-direction:column;gap:1rem}.alumnos-header{display:flex;align-items:center;justify-content:space-between}.alumnos-count{color:#6c757d;font-size:.83rem}.subs-create-btn-sm{display:flex;align-items:center;gap:.35rem;padding:.4rem .85rem;background:#0c9;border:none;border-radius:7px;color:#fff;font-size:.78rem;font-weight:600;font-family:Poppins,sans-serif;cursor:pointer;transition:background .2s}.subs-create-btn-sm:hover:not(:disabled){background:#00b386}.subs-create-btn-sm:disabled{background:#e9ecef;color:#adb5bd;cursor:not-allowed}.empty-alumnos{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem 0;color:#adb5bd;font-size:.9rem}.empty-alumnos svg{font-size:2.5rem}.alumnos-list{display:flex;flex-direction:column;gap:.5rem}.alumno-row{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 2px 6px #0000000a;transition:box-shadow .2s}.alumno-row:hover{box-shadow:0 4px 12px #00000014}.alumno-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#0c9,#00b386);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.95rem;flex-shrink:0}.alumno-info{flex:1;min-width:0}.alumno-name{color:#212529;font-size:.9rem;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alumno-meta{display:flex;align-items:center;gap:.4rem;color:#6c757d;font-size:.76rem;margin:.2rem 0 0}.alumno-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.alumno-delete-btn{background:transparent;border:none;color:#adb5bd;font-size:.95rem;cursor:pointer;padding:.3rem;border-radius:6px;display:flex;align-items:center;transition:color .2s,background .2s}.alumno-delete-btn:hover{color:#ef4444;background:#ef444414}.alumno-confirm-delete{display:flex;gap:.35rem;flex-shrink:0}.alumno-confirm-yes{background:#ef4444;border:none;border-radius:6px;color:#fff;font-size:.75rem;font-weight:600;padding:.3rem .6rem;cursor:pointer;font-family:Poppins,sans-serif;transition:background .2s}.alumno-confirm-yes:hover:not(:disabled){background:#dc2626}.alumno-confirm-yes:disabled{opacity:.6;cursor:not-allowed}.alumno-confirm-no{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#6c757d;font-size:.75rem;font-weight:600;padding:.3rem .6rem;cursor:pointer;font-family:Poppins,sans-serif;transition:background .2s}.alumno-confirm-no:hover{background:#e9ecef;color:#212529}.tab-pagos{display:flex;flex-direction:column;gap:.75rem}.empty-pagos{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem 0;color:#adb5bd;text-align:center}.empty-pagos svg{font-size:2.5rem}.empty-pagos p{margin:0;font-size:.9rem;color:#6c757d}.empty-pagos span{font-size:.8rem}.pagos-list{display:flex;flex-direction:column;gap:.75rem}.pago-card{background:#fff;border:1px solid #e9ecef;border-radius:10px;padding:1rem 1.1rem;box-shadow:0 2px 6px #0000000a}.pago-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.pago-type{color:#212529;font-weight:600;font-size:.88rem}.pago-status{font-size:.72rem;padding:.2rem .65rem;border-radius:99px;font-weight:600}.pago-details{display:flex;flex-direction:column;gap:.4rem}.pago-detail-row{display:flex;align-items:center;gap:.5rem;color:#6c757d;font-size:.81rem}.pago-detail-row svg{color:#adb5bd;flex-shrink:0}.pago-renew{color:#0c9}.pago-renew svg{color:#0c9}*,*:before,*:after{box-sizing:border-box}.client-detail-container{padding:2.5rem;width:100%;max-width:100vw;overflow-x:hidden}.back-button{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--accent-color);font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:2rem}.client-detail-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background-color:var(--secondary-bg);border-radius:12px;box-shadow:var(--shadow);width:100%;box-sizing:border-box;overflow:hidden}.client-detail-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;transition:all .2s ease-in-out;border:3px solid var(--border-color)}.client-detail-avatar.clickable{cursor:pointer}.client-detail-avatar.clickable:hover{transform:scale(1.1);border-color:var(--accent-color);box-shadow:0 4px 16px #0c96}.client-detail-header h2{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;max-width:500px;margin:0 auto}.header-info{flex:1;text-align:center}.header-title-row{display:flex;align-items:center;justify-content:center;gap:.75rem;position:relative;flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.nudge-button-header{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;font-size:.875rem;font-weight:600;background:linear-gradient(135deg,#00e0ad,#0c9);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.nudge-button-header:hover{background:linear-gradient(135deg,#0c9,#00b386);transform:scale(1.02)}.nudge-button-header:active{transform:scale(.98)}.stats-button-header{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;min-height:36px;background-color:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.stats-button-header:hover{background-color:#059669;transform:scale(1.05)}.stats-button-header:active{transform:scale(.98)}.stats-button-header svg{font-size:1.25rem;color:#fff!important;flex-shrink:0}.header-stats{display:flex;gap:2rem;align-items:center;justify-content:center;margin-top:.3rem}.header-stat{font-size:.9rem;color:var(--secondary-text)}.header-stat strong{color:var(--accent-color);font-weight:700}.routine-section{margin-bottom:2rem;padding:1.25rem 1.5rem;background-color:var(--secondary-bg);border-radius:12px;box-shadow:var(--shadow)}.routine-section h3{margin:0 0 1rem;font-size:1.125rem;color:var(--primary-text)}.routine-times{display:flex;flex-wrap:wrap;gap:1rem 1.5rem;margin-bottom:1rem}.routine-time-row{display:flex;align-items:center;gap:.75rem}.routine-label{font-size:.9rem;font-weight:500;color:var(--secondary-text);min-width:5rem}.routine-time-input{padding:.5rem .75rem;font-size:1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--primary-bg, #fff);color:var(--primary-text)}.routine-save-button{padding:.5rem 1rem;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#0c9,#00b386);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.routine-save-button:hover:not(:disabled){background:linear-gradient(135deg,#00b386,#008060)}.routine-save-button:disabled{opacity:.7;cursor:not-allowed}.nudge-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.nudge-modal-content{background:var(--secondary-bg, #fff);border-radius:16px;padding:1.5rem;max-width:420px;width:100%;box-shadow:var(--shadow),0 20px 60px #0003}.nudge-modal-content h3{margin:0 0 1.25rem;font-size:1.25rem;color:var(--primary-text)}.nudge-modal-fields{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.25rem}.nudge-modal-fields label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:500;color:var(--secondary-text)}.nudge-input,.nudge-textarea{padding:.6rem .75rem;font-size:1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--primary-bg, #fff);color:var(--primary-text);font-family:inherit}.nudge-textarea{resize:vertical;min-height:80px}.nudge-error{margin:0 0 1rem;font-size:.875rem;color:#e11}.nudge-modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.nudge-modal-cancel{padding:.5rem 1rem;font-size:.9rem;background:transparent;color:var(--secondary-text);border:1px solid var(--border-color);border-radius:8px;cursor:pointer}.nudge-modal-cancel:hover:not(:disabled){background:#0000000d}.nudge-modal-send{padding:.5rem 1.25rem;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#0c9,#00b386);color:#fff;border:none;border-radius:8px;cursor:pointer}.nudge-modal-send:hover:not(:disabled){background:linear-gradient(135deg,#00b386,#008060)}.nudge-modal-send:disabled,.nudge-modal-cancel:disabled{opacity:.7;cursor:not-allowed}.scan-details-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"image feedback" "image macros";gap:.5rem;background-color:var(--secondary-bg);padding:2rem;border-radius:12px;box-shadow:var(--shadow)}.scan-image-container{grid-area:image}.scan-image{width:100%;max-width:100%;height:auto;border-radius:8px;object-fit:cover;box-sizing:border-box;margin-bottom:.75rem}.scan-timestamp{text-align:center;font-size:.85rem;color:var(--secondary-text);padding:.5rem;background:#00cc990d;border-radius:6px;margin-bottom:1rem;font-weight:500}.scan-macros,.scan-feedback,.scan-ingredients{padding:1rem}.scan-macros{grid-area:macros}.scan-feedback{grid-area:feedback}.scan-ingredients{grid-area:ingredients}.scan-details-grid h3{font-size:1.25rem;margin-top:0;margin-bottom:1rem;color:var(--primary-text)}.scan-details-grid p{line-height:1.6;color:var(--secondary-text)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.meal-indicator-dot{position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;background-color:var(--accent-color);border-radius:50%}.day-button.active .meal-indicator-dot{background-color:#fff}.day-button.has-meals{border-color:#0c96}.daily-totals-summary{background-color:var(--secondary-bg);border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow)}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.daily-totals-summary h3{margin:0;color:var(--primary-text);font-size:1.25rem;font-weight:600}.meals-count{background:linear-gradient(135deg,var(--accent-color),#00b88a);color:#fff;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600}.progress-macros-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.progress-macro-item{background-color:var(--primary-bg);border:2px solid var(--border-color);border-radius:10px;padding:1rem;transition:all .2s ease}.progress-macro-item.compliance-good{border-color:#10b981;background:linear-gradient(135deg,#10b9810d,#10b98105)}.progress-macro-item.compliance-warning{border-color:#f59e0b;background:linear-gradient(135deg,#f59e0b0d,#f59e0b05)}.progress-macro-item.compliance-over{border-color:#ef4444;background:linear-gradient(135deg,#ef44440d,#ef444405)}.progress-macro-item.compliance-low{border-color:#6b7280;background:linear-gradient(135deg,#6b72800d,#6b728005)}.progress-macro-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progress-macro-label{font-size:.85rem;font-weight:600;color:var(--secondary-text);text-transform:uppercase;letter-spacing:.5px}.progress-macro-values{font-size:.9rem;color:var(--secondary-text)}.progress-macro-values strong{color:var(--primary-text);font-weight:700}.progress-bar-container{height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:.4rem}.progress-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.compliance-good .progress-bar-fill{background:linear-gradient(90deg,#10b981,#34d399)}.compliance-warning .progress-bar-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.compliance-over .progress-bar-fill{background:linear-gradient(90deg,#ef4444,#f87171)}.compliance-low .progress-bar-fill{background:linear-gradient(90deg,#6b7280,#9ca3af)}.progress-percentage{font-size:.8rem;font-weight:600;color:var(--secondary-text)}.meals-thumbnails-container{background-color:var(--secondary-bg);border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow)}.meals-thumbnails-container h3{margin:0 0 1rem;font-size:1.1rem;color:var(--primary-text)}.meals-thumbnails-grid{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.5rem}.meal-thumbnail{position:relative;min-width:120px;height:100px;border-radius:10px;overflow:hidden;border:3px solid transparent;cursor:pointer;transition:all .2s ease;padding:0;background:none}.meal-thumbnail img{width:100%;height:100%;object-fit:cover}.meal-thumbnail:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.meal-thumbnail.active{border-color:var(--accent-color);box-shadow:0 4px 16px #0c96}.meal-thumbnail-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:.5rem;display:flex;flex-direction:column;gap:.15rem}.meal-thumbnail-time{display:flex;align-items:center;gap:.25rem;font-size:.7rem;color:#fff;opacity:.9}.meal-thumbnail-calories{font-size:.75rem;font-weight:600;color:#fff}.meal-detail-card{background-color:var(--secondary-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow);width:100%;box-sizing:border-box;overflow:hidden}.meal-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.meal-detail-header h3{margin:0;font-size:1.1rem;color:var(--primary-text)}.meal-nav-buttons{display:flex;gap:.5rem}.meal-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background-color:var(--accent-color);color:#fff;cursor:pointer;transition:all .2s ease}.meal-nav-btn:hover:not(:disabled){background-color:#00b88a;transform:scale(1.05)}.meal-nav-btn svg{color:inherit;flex-shrink:0}.meal-nav-btn:disabled{opacity:.4;cursor:not-allowed;background-color:var(--accent-color)}.meal-detail-content{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.meal-image-section{position:relative}.meal-detail-image{width:100%;border-radius:10px;object-fit:cover;max-height:300px}.meal-time-badge{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:.35rem;background:#000000b3;color:#fff;padding:.4rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.meal-info-section{display:flex;flex-direction:column;gap:1.25rem}.meal-macros-row{display:flex;gap:.5rem;flex-wrap:wrap}.meal-macro{flex:1;min-width:70px;background:linear-gradient(135deg,var(--primary-bg),#f8fafc);border:1px solid var(--border-color);border-radius:8px;padding:.6rem;text-align:center}.meal-macro-value{display:block;font-size:1.1rem;font-weight:700;color:var(--accent-color)}.meal-macro-label{display:block;font-size:.7rem;font-weight:600;color:var(--secondary-text);text-transform:uppercase;letter-spacing:.3px}.meal-ingredients,.meal-feedback{background:var(--primary-bg);border-radius:8px;padding:1rem;border:1px solid var(--border-color)}.meal-ingredients h4,.meal-feedback h4{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:var(--primary-text)}.meal-ingredients p,.meal-feedback p{margin:0;font-size:.9rem;line-height:1.5;color:var(--secondary-text)}.macros-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}.macro-item{background-color:var(--primary-bg);border:2px solid var(--border-color);border-radius:8px;padding:1rem;text-align:center;transition:all .2s ease-in-out}.macro-item:hover{border-color:var(--accent-color);transform:translateY(-2px);box-shadow:0 4px 12px #00cc991a}.macro-value{font-size:1.5rem;font-weight:700;color:var(--accent-color);margin-bottom:.3rem}.macro-label{font-size:.85rem;font-weight:600;color:var(--secondary-text);text-transform:uppercase;letter-spacing:.5px}.scan-profile-info{grid-area:profile-info;background-color:var(--primary-bg);border:2px solid var(--accent-color);border-radius:8px;padding:1.5rem}.scan-profile-info h3{margin:0 0 1rem;font-size:1.25rem;color:var(--primary-text)}.profile-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.profile-stat{text-align:center}.profile-stat-value{font-size:1.2rem;font-weight:700;color:var(--accent-color);margin-bottom:.2rem}.profile-stat-label{font-size:.8rem;font-weight:600;color:var(--secondary-text);text-transform:uppercase;letter-spacing:.5px}.profile-goal{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);text-align:center}.profile-goal-label{font-size:.8rem;font-weight:600;color:var(--secondary-text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.3rem}.profile-goal-value{font-size:1rem;font-weight:600;color:var(--primary-text)}.profile-goal-value.day-number{font-size:1.2rem;font-weight:700;color:#1f2937}.day-button.future{background:linear-gradient(135deg,#fef7f7,#fef2f2);border:2px solid #fecaca;cursor:not-allowed;opacity:.7;position:relative;overflow:hidden}.day-button.future:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#f871711a,#ef44440d);pointer-events:none}.day-button.future .day-name{color:#dc2626;opacity:.8}.day-button.future .day-number{color:#b91c1c;opacity:.9}.day-selector{background:linear-gradient(135deg,#fff,#f8fafc);padding:2rem;border-radius:16px;margin-bottom:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.day-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.day-selector h3{margin:0;font-size:1.25rem;color:var(--primary-text)}.week-navigation{display:flex;align-items:center;gap:.8rem}.week-nav-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:2px solid #e5e7eb;border-radius:8px;background:linear-gradient(135deg,#fff,#f8fafc);color:#374151;cursor:pointer;transition:all .3s ease;font-size:1.1rem;box-shadow:0 2px 4px #0000000d}.week-nav-button:hover:not(.disabled){border-color:#0c9;color:#0c9;transform:translateY(-1px);box-shadow:0 4px 12px #00cc9940;background:linear-gradient(135deg,#fff,#f0fdfa)}.week-nav-button svg{color:inherit;flex-shrink:0}.week-nav-button.disabled{opacity:.4;cursor:not-allowed;background:#f3f4f6;border-color:#d1d5db;color:#9ca3af}.week-indicator{font-size:.95rem;font-weight:600;color:#1f2937;min-width:140px;text-align:center;padding:.5rem 1rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:8px;border:1px solid #e5e7eb}.days-container{display:flex;gap:.5rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:var(--accent-color) transparent}.day-button{display:flex;flex-direction:column;align-items:center;min-width:65px;padding:.9rem .6rem;border:2px solid #e5e7eb;border-radius:12px;background:linear-gradient(135deg,#fff,#f8fafc);cursor:pointer;transition:all .3s ease;font-family:inherit;box-shadow:0 2px 4px #0000000d;position:relative;overflow:hidden}.day-button:hover:not(:disabled){border-color:#0c9;transform:translateY(-3px);box-shadow:0 6px 20px #00cc9940;background:linear-gradient(135deg,#fff,#f0fdfa)}.day-button:hover:not(:disabled):before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#00cc990d,#00cc9905);pointer-events:none}.day-button.active{border-color:#0c9;background:linear-gradient(135deg,#0c9,#00b88a);color:#fff;box-shadow:0 6px 20px #0c96;transform:translateY(-2px)}.day-button.active:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#fff3,#ffffff0d);pointer-events:none}.day-name{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;margin-bottom:.3rem;letter-spacing:.5px}.day-button.active .day-name{color:#ffffffe6}.day-number{font-size:1.1rem;font-weight:700;color:#6b7280}.day-button.active .day-number{color:#fff}.no-meals-message{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:16px;border:2px dashed #cbd5e1;margin:2rem 0}.no-meals-message h3{color:#64748b;font-size:1.5rem;margin-bottom:1rem;font-weight:600}.no-meals-message p{color:#475569;font-size:1rem;line-height:1.6;max-width:500px;margin:0 auto}.meals-slider{margin:2rem 0;background-color:var(--secondary-bg);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow)}.meals-slider h3{margin:0 0 1rem;font-size:1.25rem;color:var(--primary-text)}.slider-controls{display:flex;align-items:center;justify-content:center;gap:1rem}.slider-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid var(--accent-color);border-radius:50%;background-color:var(--secondary-bg);color:var(--accent-color);cursor:pointer;transition:all .2s ease-in-out;font-size:1.2rem}.slider-button:hover:not(:disabled){background-color:var(--accent-color);color:#fff;transform:scale(1.1)}.slider-button:disabled{opacity:.3;cursor:not-allowed}.meal-indicator{font-weight:600;font-size:1rem;color:var(--primary-text);min-width:100px;text-align:center}.scan-image-container{grid-area:image;display:flex;flex-direction:column;gap:1rem}@media (max-width: 768px){.client-detail-container{padding:.8rem;max-width:100vw;overflow-x:hidden}.client-detail-header{flex-direction:column;text-align:center;gap:1rem;width:100%}.header-stats{flex-direction:column;gap:.5rem;align-items:center;width:100%}.day-selector{padding:1.2rem;margin-bottom:1.5rem;width:100%;box-sizing:border-box}.day-selector-header{flex-direction:column;gap:1rem;align-items:center;text-align:center;width:100%}.week-navigation{width:100%;justify-content:space-between;align-items:center;gap:.5rem}.week-indicator{flex:1;max-width:180px;font-size:.8rem;padding:.4rem .6rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.week-nav-button{width:32px;height:32px;font-size:1rem;flex-shrink:0}.days-container{display:flex;gap:.25rem;padding:.8rem 0;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;width:100%;box-sizing:border-box;scrollbar-width:none}.days-container::-webkit-scrollbar{display:none}.day-button{min-width:40px;max-width:40px;padding:.4rem .15rem;border-radius:8px;flex-shrink:0}.day-name{font-size:.65rem;margin-bottom:.2rem}.day-number{font-size:.95rem}.scan-details-grid{grid-template-columns:1fr;grid-template-areas:"image" "feedback" "macros";gap:1rem;padding:1.5rem}.macros-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}.macro-item{padding:.8rem}.macro-value{font-size:1.3rem}.macro-label{font-size:.8rem}.meals-slider{padding:1.2rem;margin:1.5rem 0}.slider-controls{gap:.8rem}.slider-button{width:38px;height:38px;font-size:1.1rem}.no-meals-message{padding:2rem 1.5rem;margin:1.5rem 0}.no-meals-message h3{font-size:1.3rem}.no-meals-message p{font-size:.9rem}.progress-macros-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.progress-macro-item{padding:.8rem}.progress-macro-label{font-size:.75rem}.progress-macro-values{font-size:.8rem}.meal-detail-content{grid-template-columns:1fr;gap:1rem}.meal-detail-image{max-height:250px;width:100%}.meal-info-section{width:100%}.meal-ingredients,.meal-feedback{width:100%;box-sizing:border-box}.meal-ingredients p,.meal-feedback p{word-wrap:break-word;overflow-wrap:break-word}.meals-thumbnails-grid{gap:.5rem}.meal-thumbnail{min-width:100px;height:85px}.meal-indicator-dot{width:5px;height:5px;bottom:3px}}@media (max-width: 480px){.client-detail-container{padding:.5rem;max-width:100vw;overflow-x:hidden}.client-detail-header{padding:0}.client-detail-header h2{font-size:1.3rem;margin:0;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%}.header-stat{font-size:.75rem}.day-selector{padding:1rem;margin-bottom:1rem;width:100%;box-sizing:border-box}.day-selector-header h3{font-size:1rem;margin:0}.week-navigation{gap:.3rem;width:100%}.week-indicator{font-size:.7rem;padding:.3rem .4rem;max-width:120px;min-width:80px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.week-nav-button{width:28px;height:28px;font-size:.8rem;flex-shrink:0}.days-container{gap:.15rem;overflow-x:auto;overflow-y:hidden;padding:.6rem 0;width:100%;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;box-sizing:border-box;scrollbar-width:none}.days-container::-webkit-scrollbar{display:none}.day-button{min-width:34px;max-width:34px;padding:.35rem .1rem;flex-shrink:0;border-radius:6px}.day-name{font-size:.55rem;margin-bottom:.1rem;letter-spacing:.2px}.day-number{font-size:.8rem}.scan-details-grid{padding:1rem;gap:.8rem;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.macros-grid{grid-template-columns:1fr 1fr;gap:.5rem}.macro-item{padding:.5rem;box-sizing:border-box}.macro-value{font-size:1.1rem}.macro-label{font-size:.7rem}.meals-slider{padding:.8rem;margin:1rem 0;width:100%;box-sizing:border-box}.meals-slider h3{font-size:1rem;margin:0 0 .8rem}.slider-controls{width:100%;justify-content:space-between;align-items:center}.slider-button{width:32px;height:32px;font-size:.9rem;flex-shrink:0}.meal-indicator{font-size:.85rem;flex:1;text-align:center}.no-meals-message{padding:1.2rem .8rem;margin:1rem 0;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.no-meals-message p{font-size:.8rem;line-height:1.4;margin:0;word-wrap:break-word;overflow-wrap:break-word}.no-meals-message h3{font-size:1.1rem;margin:0 0 .8rem}.no-meals-message p{font-size:.8rem;line-height:1.4;margin:0}.progress-macros-grid{grid-template-columns:1fr;gap:.6rem}.progress-macro-item{padding:.7rem}.progress-macro-header{flex-direction:column;align-items:flex-start;gap:.25rem}.progress-macro-label{font-size:.7rem}.progress-macro-values{font-size:.75rem}.progress-bar-container{height:6px}.progress-percentage{font-size:.7rem}.meals-thumbnails-container{padding:1rem}.meals-thumbnails-container h3{font-size:.95rem}.meal-thumbnail{min-width:85px;height:70px}.meal-thumbnail-time{font-size:.6rem}.meal-thumbnail-calories{font-size:.65rem}.meal-detail-card{padding:1rem}.meal-detail-header{margin-bottom:1rem;padding-bottom:.75rem}.meal-detail-header h3{font-size:.95rem}.meal-nav-btn{width:28px;height:28px}.meal-detail-image{max-height:200px}.meal-time-badge{padding:.3rem .6rem;font-size:.75rem}.meal-macros-row{gap:.35rem}.meal-macro{min-width:60px;padding:.5rem .3rem}.meal-macro-value{font-size:.95rem}.meal-macro-label{font-size:.6rem}.meal-info-section{width:100%;gap:1rem}.meal-ingredients,.meal-feedback{padding:.75rem;width:100%;box-sizing:border-box}.meal-ingredients h4,.meal-feedback h4{font-size:.8rem;margin-bottom:.4rem}.meal-ingredients p,.meal-feedback p{font-size:.8rem;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.meal-indicator-dot{width:4px;height:4px;bottom:2px}.summary-header{flex-direction:column;align-items:flex-start;gap:.5rem}.meals-count{font-size:.75rem;padding:.25rem .6rem}}.stats-summary-cards-container{width:100%;max-width:100%;margin-bottom:1rem;box-sizing:border-box;overflow-x:hidden}.stats-summary-cards-scroll{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem;width:100%;box-sizing:border-box}.stats-summary-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.875rem .5rem;background-color:var(--secondary-bg);border-radius:12px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000a;transition:all .2s ease}.stats-summary-card:hover{box-shadow:0 4px 12px #00000014;border-color:var(--accent-color)}.stats-card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem;flex-shrink:0}.stats-card-icon svg{font-size:1.25rem}.stats-card-content{text-align:center;width:100%}.stats-card-value{font-size:1.25rem;font-weight:800;color:var(--primary-text);margin-bottom:.125rem;line-height:1.2}.stats-card-label{font-size:.7rem;font-weight:600;color:var(--primary-text);margin-bottom:0}.stats-card-subtitle{font-size:.6rem;color:var(--secondary-text);font-weight:500}@media (min-width: 768px){.stats-summary-cards-container{margin-bottom:1.5rem}.stats-summary-cards-scroll{gap:1rem}.stats-summary-card{padding:1.25rem 1rem;border-radius:14px}.stats-card-icon{width:48px;height:48px}.stats-card-icon svg{font-size:1.5rem}.stats-card-value{font-size:1.75rem}.stats-card-label{font-size:.85rem}.stats-card-subtitle{font-size:.7rem}}@media (min-width: 1024px){.stats-summary-cards-scroll{grid-template-columns:repeat(4,1fr);gap:1.25rem}.stats-summary-card{padding:1.5rem 1.25rem;border-radius:16px}.stats-card-icon{width:56px;height:56px;margin-bottom:.75rem}.stats-card-icon svg{font-size:1.75rem}.stats-card-value{font-size:2rem}.stats-card-label{font-size:.9rem}.stats-card-subtitle{font-size:.75rem}}.compliance-calendar-container{width:100%;max-width:100%;background-color:var(--secondary-bg);border-radius:16px;padding:1rem;border:2px solid var(--border-color);box-sizing:border-box;overflow-x:hidden}.calendar-header{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem;gap:.5rem}.calendar-title{font-size:1rem;font-weight:700;color:var(--primary-text);margin:0;text-align:center}.calendar-navigation{display:flex;align-items:center;justify-content:center;gap:.5rem;background-color:var(--primary-bg);padding:6px 10px;border-radius:8px;border:1px solid var(--border-color)}.calendar-nav-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background-color:var(--accent-color);color:#fff;font-size:1.25rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .15s ease}.calendar-nav-button:hover:not(:disabled){background-color:#00b88a;transform:scale(1.05)}.calendar-nav-button:disabled{opacity:.4;cursor:not-allowed;background-color:var(--accent-color)}.calendar-month-display{font-size:.875rem;font-weight:600;color:var(--primary-text);min-width:120px;text-align:center}.calendar-legend{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.65rem}.legend-item{display:flex;align-items:center;gap:.25rem;color:var(--secondary-text)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.calendar-grid{width:100%}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.5rem}.calendar-weekday{text-align:center;font-size:.65rem;font-weight:600;color:var(--secondary-text);padding:.125rem}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-bottom:.25rem}.calendar-day{aspect-ratio:1;min-height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:transparent;border:1px solid var(--border-color);border-radius:6px;cursor:default;transition:all .15s ease;position:relative;padding:.125rem}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{transform:scale(1.08);z-index:1;box-shadow:0 2px 8px #00000026}.calendar-day.future{cursor:not-allowed;opacity:.35;background-color:var(--border-color)!important;border-color:var(--border-color)!important}.calendar-day.future:hover{transform:none;box-shadow:none}.calendar-day.future .calendar-day-number{color:var(--secondary-text)}.calendar-day.other-month{opacity:.4}.calendar-day.other-month .calendar-day-number{color:var(--secondary-text)}.calendar-day.selected{box-shadow:0 0 0 3px var(--accent-color);border-color:var(--accent-color)}.calendar-day.today{font-weight:700;box-shadow:inset 0 0 0 2px var(--accent-color)}.calendar-day.today .calendar-day-number{color:var(--accent-color);font-weight:800}.calendar-day-number{font-size:.75rem;color:var(--primary-text);font-weight:500}.calendar-day-indicator{width:5px;height:5px;border-radius:50%;margin-top:.0625rem;flex-shrink:0}.calendar-summary{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:.875rem;border-top:1px solid var(--border-color)}.summary-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem}.summary-label{color:var(--secondary-text)}.summary-value{font-weight:700;color:var(--primary-text)}@media (min-width: 768px){.compliance-calendar-container{padding:1.5rem}.calendar-title{font-size:1.25rem}.calendar-day{min-height:48px}.calendar-day-number{font-size:1rem}}@media (min-width: 1024px){.calendar-day{min-height:52px}}.compliance-chart-container{width:100%;max-width:100%;background-color:var(--secondary-bg);border-radius:16px;padding:1rem;border:2px solid var(--border-color);box-sizing:border-box;overflow-x:hidden}.compliance-chart-empty{text-align:center;padding:2rem 1rem;color:var(--secondary-text)}.chart-header{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem;gap:.75rem}.chart-title{font-size:1rem;font-weight:700;color:var(--primary-text);margin:0;text-align:center}.chart-navigation{display:flex;align-items:center;justify-content:center;gap:.5rem;background-color:var(--primary-bg);padding:6px 10px;border-radius:8px;border:1px solid var(--border-color)}.nav-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background-color:var(--accent-color);color:#fff;cursor:pointer;border-radius:6px;transition:all .2s;padding:0}.nav-button:hover:not(.disabled){background-color:#00b88a;transform:scale(1.05)}.nav-button.disabled{opacity:.4;cursor:not-allowed;background-color:var(--accent-color)}.nav-date-range{font-size:.8rem;font-weight:600;color:var(--primary-text);padding:0 .5rem;min-width:90px;text-align:center;white-space:nowrap}.days-list{display:flex;flex-direction:column;gap:.5rem}.days-list.month{gap:.375rem}.day-row{background:var(--primary-bg);border-radius:10px;border:1px solid var(--border-color);overflow:hidden;transition:all .2s ease}.day-row:hover{border-color:var(--primary-color, #10B981)}.day-row.expanded{border-color:var(--primary-color, #10B981);box-shadow:0 2px 8px #0000000f}.day-row.no-data{opacity:.5}.day-row.no-data:hover{border-color:var(--border-color)}.day-main{display:flex;align-items:center;gap:.5rem;padding:.75rem .875rem;cursor:pointer;min-height:48px}.day-row.no-data .day-main{cursor:default}.day-info{min-width:55px;display:flex;flex-direction:column;gap:.125rem;align-items:center;text-align:center}.day-date{font-size:.8rem;font-weight:600;color:var(--primary-text);text-transform:capitalize}.no-log-badge{font-size:.6rem;color:var(--secondary-text);font-weight:400}.day-bar-container{flex:1;height:10px;background:var(--border-color);border-radius:5px;overflow:hidden;min-width:60px}.day-bar-container.empty{background:var(--secondary-bg)}.day-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.day-bar-empty{height:100%;background:repeating-linear-gradient(45deg,var(--border-color),var(--border-color) 2px,transparent 2px,transparent 6px)}.day-percentage{min-width:38px;font-size:.8rem;font-weight:700;text-align:center}.day-status{display:flex;align-items:center;justify-content:center;width:20px}.status-icon{width:16px;height:16px}.status-icon.success{color:#10b981}.status-icon.warning{color:#f59e0b}.status-icon.danger{color:#ef4444}.day-expand{display:flex;align-items:center;color:var(--secondary-text)}.day-detail{padding:0 .875rem .875rem;border-top:1px solid var(--border-color);margin-top:0;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 0;gap:.5rem}.detail-meals{font-size:.75rem;color:var(--secondary-text);font-weight:500}.view-day-button{background-color:var(--accent-color);color:#fff;border:none;border-radius:6px;padding:.375rem .75rem;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.view-day-button:hover{background-color:#059669;transform:translateY(-1px)}.macros-breakdown{display:flex;flex-direction:column;gap:.5rem}.macro-bar-row{display:flex;align-items:center;gap:.5rem}.macro-label{min-width:90px;display:flex;align-items:center;gap:.375rem}.macro-emoji{font-size:.75rem}.macro-name{font-size:.75rem;font-weight:500;color:var(--primary-text)}.macro-bar-container{flex:1;height:6px;background:var(--border-color);border-radius:3px;overflow:hidden;min-width:40px}.macro-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.macro-values{min-width:55px;display:flex;align-items:center;gap:.125rem;font-size:.7rem;justify-content:center}.macro-current{font-weight:600;color:var(--primary-text)}.macro-separator{color:var(--secondary-text);font-size:.6rem}.macro-goal{color:var(--secondary-text)}.chart-legend{display:flex;justify-content:center;gap:.75rem;margin-top:1rem;padding-top:.875rem;border-top:1px solid var(--border-color);flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:var(--secondary-text)}.legend-dot{width:8px;height:8px;border-radius:50%}@media (min-width: 768px){.day-info{min-width:90px}.day-bar-container{height:10px}.macro-bar-container{height:8px}.macro-label{min-width:130px}.macro-values{min-width:80px;font-size:.8rem}}@media (min-width: 1024px){.days-list.month{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.day-row{border-radius:10px}.day-main{padding:.75rem 1rem}.chart-legend{gap:2rem}}.changes-timeline-container{width:100%}.changes-timeline-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;background:var(--secondary-bg);border-radius:12px;border:2px dashed var(--border-color)}.changes-timeline-empty .empty-icon{width:48px;height:48px;border-radius:50%;background:var(--primary-bg);display:flex;align-items:center;justify-content:center;margin-bottom:.75rem;color:var(--secondary-text)}.changes-timeline-empty h4{font-size:.9rem;font-weight:600;color:var(--primary-text);margin:0 0 .375rem}.changes-timeline-empty p{font-size:.8rem;color:var(--secondary-text);margin:0}.timeline-list{display:flex;flex-direction:column;gap:.75rem}.timeline-card{background:var(--primary-bg);border-radius:12px;padding:1rem;border:1px solid var(--border-color);box-shadow:0 1px 4px #0000000a;transition:all .2s ease}.timeline-card:hover{box-shadow:0 2px 8px #0000000f}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.5rem}.card-type{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border-radius:100px}.type-emoji{font-size:.875rem}.type-label{font-size:.7rem;font-weight:600;letter-spacing:.1px}.card-time{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:var(--secondary-text);font-weight:500;flex-shrink:0}.card-time svg{opacity:.7;width:10px;height:10px}.card-date{font-size:.75rem;color:var(--secondary-text);margin-bottom:.75rem;text-transform:capitalize}.card-fields{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.field-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:var(--secondary-bg);border:1px solid;border-radius:100px;font-size:.8rem;font-weight:500;color:var(--primary-text);transition:all .15s ease}.field-pill:hover{background:var(--primary-bg)}.card-fields-detailed{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.875rem;background:var(--secondary-bg);padding:.75rem;border-radius:10px}.field-change-row{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.field-change-row:last-child{padding-bottom:0;border-bottom:none}.field-label{font-size:.75rem;font-weight:500;color:var(--primary-text)}.field-values{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.value-old{color:var(--secondary-text);text-decoration:line-through;font-size:.7rem}.value-arrow{color:var(--secondary-text);opacity:.5;font-size:.65rem}.value-new{font-weight:600;font-size:.8rem}.card-footer{padding-top:.75rem;border-top:1px solid var(--border-color)}.coach-info{display:flex;align-items:center;gap:.5rem}.coach-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}.coach-name{font-size:.75rem;font-weight:500;color:var(--primary-text)}@media (min-width: 768px){.timeline-list{gap:1.25rem}.timeline-card{padding:1.5rem}.card-type{padding:.5rem 1rem}.type-label{font-size:.85rem}}@media (min-width: 1024px){.timeline-card:hover{transform:translateY(-2px)}}.client-stats-container{width:100%;max-width:100vw;min-height:100vh;background-color:var(--primary-bg);padding:.75rem .75rem 1.5rem;box-sizing:border-box;overflow-x:hidden}.stats-header{margin-bottom:.875rem}.stats-back-button{display:flex;align-items:center;gap:.375rem;background:none;border:none;color:var(--accent-color);font-size:.8rem;font-weight:600;cursor:pointer;margin-bottom:.5rem;padding:.375rem 0;transition:opacity .2s}.stats-back-button:hover{opacity:.8}.stats-header-info{display:flex;align-items:center;gap:.75rem}.stats-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color);flex-shrink:0}.stats-header-text{flex:1;min-width:0}.stats-title{font-size:1.125rem;font-weight:800;color:var(--primary-text);margin:0 0 .125rem}.stats-subtitle{font-size:.75rem;color:var(--secondary-text);margin:0}.stats-edit-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--secondary-text);cursor:pointer;transition:all .15s ease;flex-shrink:0}.stats-edit-button:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.stats-edit-button svg{font-size:1rem}.stats-tabs-container{margin-bottom:.875rem}.stats-tabs-container::-webkit-scrollbar{display:none}.stats-tabs-scroll{display:flex;gap:.375rem;width:100%}.stats-tab{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem .875rem;background-color:var(--secondary-bg);border:1px solid var(--border-color);border-radius:10px;color:var(--secondary-text);font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s ease;flex:1;min-height:40px}.stats-tab:hover{border-color:var(--accent-color);color:var(--accent-color)}.stats-tab.active{background:var(--gradient-primary);border-color:var(--accent-color);color:#fff;box-shadow:0 4px 12px #00cc9940}.stats-tab svg{font-size:.9rem;flex-shrink:0}.stats-content{width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.stats-tab-content{width:100%;max-width:100%;min-height:200px;box-sizing:border-box;overflow-x:hidden}.stats-loading,.stats-empty,.stats-placeholder{text-align:center;padding:3rem 1rem;color:var(--secondary-text);font-size:.95rem}.stats-placeholder{background-color:var(--secondary-bg);border-radius:12px;border:2px dashed var(--border-color);padding:2rem 1rem}.stats-placeholder small{display:block;margin-top:.5rem;font-size:.85rem;opacity:.7}.compliance-content,.compliance-details,.weight-content{width:100%}.weight-chart-container{background-color:var(--secondary-bg);border-radius:16px;padding:1.25rem;border:2px solid var(--border-color)}.weight-chart-title{font-size:1.125rem;font-weight:700;color:var(--primary-text);margin:0 0 1rem}.weight-chart{display:flex;flex-direction:column;gap:.75rem}.weight-entry{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:var(--primary-bg);border-radius:12px;border:1px solid var(--border-color);gap:1rem}.weight-date{font-size:.875rem;color:var(--secondary-text);min-width:80px}.weight-value{font-size:1rem;font-weight:700;color:var(--primary-text);flex:1;text-align:center}.weight-change{font-size:.875rem;font-weight:600;padding:.25rem .5rem;border-radius:6px;min-width:70px;text-align:center}.weight-change.increase{background-color:#ef44441a;color:#ef4444}.weight-change.decrease{background-color:#10b9811a;color:#10b981}.weight-change.stable{background-color:#9ca3af1a;color:#9ca3af}@media (min-width: 768px){.client-stats-container{padding:2rem;max-width:1200px;margin:0 auto}.stats-header{margin-bottom:2rem}.stats-title{font-size:2rem}.stats-tabs-scroll{gap:1rem}.stats-tab{padding:.875rem 1.5rem;font-size:1rem}}@media (min-width: 1024px){.client-stats-container{padding:2.5rem}.stats-tabs-container{overflow-x:visible}.stats-tabs-scroll{justify-content:center;flex-wrap:wrap}.stats-tab{min-width:160px}}.client-info-modal-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#00cc9926,#667eea26,#764ba226);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.client-info-modal-content{background:#fffffff2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(0,204,153,.2);border-radius:24px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 8px 32px #0c93,0 20px 60px #00000026;animation:modalSlideIn .3s ease-out}.client-info-modal-close{position:absolute;top:20px;right:20px;background:#ffffff4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.4);border-radius:50%;width:40px;height:40px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:#ffffffe6;z-index:10;box-shadow:0 4px 12px #0000001a}.client-info-modal-close:hover{background:#ffffff80;border-color:#fff9;transform:rotate(90deg) scale(1.1);box-shadow:0 6px 20px #00000026}.client-info-header{background:linear-gradient(135deg,#00e0ad,#0c9 35%,#00b386 65%,#008060);padding:40px 20px 30px;display:flex;align-items:center;gap:24px;color:#fff;border-radius:24px 24px 0 0;position:relative;overflow:hidden}.client-info-header:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.client-info-avatar{width:120px;height:120px;border-radius:50%;border:4px solid rgba(255,255,255,.9);object-fit:cover;margin-bottom:16px;box-shadow:0 8px 24px #0003,0 0 0 8px #fff3;position:relative;z-index:1;transition:all .3s ease}.client-info-avatar:hover{transform:scale(1.05);box-shadow:0 12px 32px #00cc994d,0 0 0 8px #ffffff4d}.header-content{flex:1;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}.header-text{text-align:left}.client-info-header h2{margin:0 0 8px;font-size:32px;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.15)}.client-username{margin:0;opacity:.95;font-size:17px;font-weight:500;text-shadow:0 1px 4px rgba(0,0,0,.1)}.client-edit-button{display:flex;align-items:center;gap:8px;background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:10px 16px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.1)}.client-edit-button:hover{background:#ffffff4d;border-color:#fff6;transform:translateY(-2px);box-shadow:0 6px 20px #0003}.client-edit-button svg{font-size:16px}.client-info-body{padding:30px}.info-section{margin-bottom:28px;padding:20px;background:#fff9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(0,204,153,.1);border-radius:16px;box-shadow:0 4px 16px #0000000a;transition:all .3s ease}.info-section:hover{background:#fffc;border-color:#00cc9940;box-shadow:0 6px 24px #00cc9914;transform:translateY(-2px)}.info-section:last-child{margin-bottom:0}.info-section h3{margin:0 0 20px;font-size:20px;font-weight:700;background:linear-gradient(135deg,#0c9,#008060);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;gap:12px}.section-icon{font-size:24px;color:#0c9;background:#00cc9926;padding:8px;border-radius:12px;box-shadow:0 2px 8px #0c93;transition:all .3s ease;flex-shrink:0}.info-section:hover .section-icon{transform:scale(1.1) rotate(5deg);background:#00cc9940;box-shadow:0 4px 16px #00cc994d}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item-full{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.info-label{font-size:13px;font-weight:700;color:#0c9;text-transform:uppercase;letter-spacing:.8px}.info-value{font-size:16px;color:#2d3748;font-weight:500;padding:8px 12px;background:#00cc990d;border-radius:8px;border-left:3px solid #00cc99;transition:all .2s ease}.info-value:hover{background:#00cc991a;border-left-color:#00e0ad}.info-value.success{color:#0c9;font-weight:700;background:#00cc9926;border-left-color:#0c9}.info-value.warning{color:#f59e0b;font-weight:700;background:#f59e0b26;border-left-color:#f59e0b}.client-info-modal-content::-webkit-scrollbar{width:10px}.client-info-modal-content::-webkit-scrollbar-track{background:#00cc990d;border-radius:10px;border:1px solid rgba(0,204,153,.1)}.client-info-modal-content::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#0c9,#00b386);border-radius:10px;box-shadow:inset 0 0 6px #0003}.client-info-modal-content::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#00e0ad,#0c9);box-shadow:inset 0 0 6px #0000004d}@media (max-width: 768px){.client-info-modal-content{max-width:100%;max-height:100vh;border-radius:0}.client-info-body{padding:20px}.info-grid{grid-template-columns:1fr;gap:12px}.client-info-header{padding:30px 20px 20px}.client-info-avatar{width:80px;height:80px}.client-info-header h2{font-size:24px}}.edit-modal-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#00cc9926,#00806026);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;overflow-y:auto}.edit-modal-content{background:#fffffff2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(0,204,153,.2);border-radius:24px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0c93,0 20px 60px #00000026;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 30px;background:linear-gradient(135deg,#00e0ad,#0c9 35%,#00b386 65%,#008060);border-radius:24px 24px 0 0;color:#fff}.edit-modal-header h2{margin:0;font-size:24px;font-weight:700}.edit-modal-close{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#fff;font-size:20px}.edit-modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.edit-info-alert{display:flex;align-items:center;gap:12px;padding:16px 30px;background:#00cc991a;border-left:4px solid #00cc99;margin:0 30px;border-radius:8px;color:#008060;font-size:14px}.edit-info-alert svg{font-size:20px;flex-shrink:0}.edit-error-alert{display:flex;align-items:center;gap:12px;padding:16px 30px;background:#ef44441a;border-left:4px solid #ef4444;margin:0 30px;border-radius:8px;color:#dc2626;font-size:14px}.edit-error-alert svg{font-size:20px;flex-shrink:0}.edit-tabs{display:flex;gap:8px;padding:20px 30px 0;border-bottom:2px solid rgba(0,204,153,.1)}.edit-tab{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:16px;font-weight:600;color:#6b7280;transition:all .3s ease}.edit-tab:hover{color:#0c9;background:#00cc990d;border-radius:8px 8px 0 0}.edit-tab.active{color:#0c9;border-bottom-color:#0c9}.edit-modal-body{flex:1;overflow-y:auto;padding:30px}.edit-tab-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.edit-section{margin-bottom:32px;padding:24px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(0,204,153,.25);border-radius:18px;box-shadow:0 8px 24px #00cc991f,0 2px 8px #00000014,inset 0 1px #ffffffe6;transition:all .3s ease;overflow:visible;position:relative}.edit-section:hover{border-color:#00cc9959;box-shadow:0 12px 32px #00cc9926,0 4px 12px #0000001a,inset 0 1px #ffffffe6}.edit-section:has(.custom-dropdown.open){z-index:100}.edit-section h3{margin:0 0 24px;font-size:20px;font-weight:800;color:#008060;display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:3px solid rgba(0,204,153,.2);text-transform:uppercase;letter-spacing:.5px}.edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.edit-field{display:flex;flex-direction:column;gap:8px}.edit-field label{font-size:14px;font-weight:700;color:#008060;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;display:block}.checkbox-label span{text-transform:none;font-weight:600;letter-spacing:normal}.edit-field input,.edit-field select,.edit-field textarea{padding:14px 18px;border:2px solid rgba(0,204,153,.3);border-radius:12px;font-size:16px;color:#1a202c;background:#fff;transition:all .3s ease;font-family:inherit;box-shadow:0 2px 8px #0000000d}.edit-field input:focus,.edit-field select:focus,.edit-field textarea:focus{outline:none;border-color:#0c9;box-shadow:0 0 0 4px #00cc9926,0 4px 12px #0c93;transform:translateY(-1px)}.edit-field input:hover,.edit-field select:hover,.edit-field textarea:hover{border-color:#0c96}.edit-field textarea{resize:vertical;min-height:100px;line-height:1.6}.edit-field textarea::placeholder{color:#9ca3af;font-style:italic}.edit-field.disabled{opacity:.6}.edit-field.disabled input{background:#f3f4f6;border-color:#e5e7eb;cursor:not-allowed;color:#9ca3af}.edit-hint{font-size:14px;color:#6b7280;font-style:italic;margin:0;line-height:1.6}.edit-modal-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:20px 30px;border-top:2px solid rgba(0,204,153,.1);background:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.edit-footer-actions{display:flex;gap:12px}.edit-button-secondary{padding:12px 24px;background:transparent;border:2px solid #d1d5db;border-radius:12px;font-size:16px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .3s ease}.edit-button-secondary:hover:not(:disabled){border-color:#9ca3af;background:#9ca3af0d}.edit-button-secondary:disabled{opacity:.5;cursor:not-allowed}.edit-button-primary{padding:12px 24px;background:linear-gradient(135deg,#0c9,#00b386);border:none;border-radius:12px;font-size:16px;font-weight:600;color:#fff;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00cc994d;display:flex;align-items:center;gap:8px}.edit-button-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0c96}.edit-button-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.edit-button-delete{padding:12px 24px;background:transparent;border:2px solid #ff4757;border-radius:12px;font-size:16px;font-weight:600;color:#ff4757;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.edit-button-delete:hover:not(:disabled){background:#ff47571a;border-color:#ff3742;color:#ff3742;transform:translateY(-1px)}.edit-button-delete:disabled{opacity:.5;cursor:not-allowed;transform:none}.edit-modal-body::-webkit-scrollbar{width:8px}.edit-modal-body::-webkit-scrollbar-track{background:#00cc990d;border-radius:10px}.edit-modal-body::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#0c9,#00b386);border-radius:10px}.edit-modal-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#00e0ad,#0c9)}@media (max-width: 768px){.edit-modal-overlay{padding:0;align-items:stretch}.edit-modal-content{max-width:100%;max-height:100vh;height:100vh;border-radius:0}.edit-modal-header{padding:16px 20px;border-radius:0}.edit-modal-header h2{font-size:18px}.edit-modal-body,.edit-modal-footer{padding:16px}.edit-info-alert,.edit-error-alert{margin:12px 16px 0;padding:12px 16px;font-size:13px}.edit-tabs{padding:12px 16px 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:4px}.edit-tabs::-webkit-scrollbar{display:none}.edit-tab{padding:10px 16px;font-size:14px;white-space:nowrap;flex-shrink:0}.edit-section{padding:16px;margin-bottom:16px;border-radius:14px}.edit-section h3{font-size:16px;margin-bottom:16px;padding-bottom:10px}.edit-grid{grid-template-columns:1fr;gap:12px}.edit-field label{font-size:12px}.edit-field input,.edit-field select,.edit-field textarea{padding:12px 14px;font-size:16px}.checkbox-group{grid-template-columns:1fr;gap:8px}.checkbox-label{padding:10px 12px;font-size:14px}.edit-modal-footer{flex-direction:column;gap:10px}.edit-button-delete{width:100%;justify-content:center;order:3;padding:14px 20px}.edit-footer-actions{width:100%;display:flex;gap:10px}.edit-button-secondary,.edit-button-primary{flex:1;padding:14px 16px;font-size:15px;justify-content:center}}@media (max-width: 480px){.edit-modal-header h2{font-size:16px}.edit-modal-close{width:36px;height:36px;font-size:18px}.edit-section{padding:14px;border-radius:12px}.edit-section h3{font-size:14px;gap:8px}.edit-field label{font-size:11px;letter-spacing:.5px}.edit-tab{padding:8px 12px;font-size:13px}.checkbox-label{padding:8px 10px;font-size:13px;gap:10px}.checkbox-label input[type=checkbox]{width:18px;height:18px}.edit-button-secondary,.edit-button-primary,.edit-button-delete{padding:12px 14px;font-size:14px}.edit-hint{font-size:12px}}.edit-tab-content .edit-section:first-child{animation:slideInUp .4s ease-out}.edit-tab-content .edit-section:nth-child(2){animation:slideInUp .5s ease-out}.edit-tab-content .edit-section:nth-child(3){animation:slideInUp .6s ease-out}.edit-tab-content .edit-section:nth-child(4){animation:slideInUp .7s ease-out}.edit-tab-content .edit-section:nth-child(5){animation:slideInUp .8s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.edit-section .edit-field{margin-bottom:20px}.edit-section .edit-field:last-child{margin-bottom:0}.edit-field .checkbox-label{padding:12px 16px;font-size:15px;background:linear-gradient(135deg,#00cc990d,#fffffff2);border:2px solid rgba(0,204,153,.3)}.edit-field .checkbox-label input[type=checkbox]{width:18px;height:18px}.edit-section input[type=text]{font-weight:500}.edit-section input[type=text]::placeholder{color:#9ca3af;font-weight:400;font-style:italic}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:12px;padding:8px 0}.checkbox-label{display:flex;align-items:center;gap:14px;padding:10px 12px;background:#fff;border:2px solid rgba(0,204,153,.4);border-radius:8px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;font-size:14px;font-weight:600;color:#374151;box-shadow:0 1px 3px #00000014;-webkit-user-select:none;user-select:none;position:relative}.checkbox-label span{pointer-events:none;flex:1}.checkbox-label:hover{background:#00cc9914;border-color:#0c99;transform:translateY(-1px);box-shadow:0 2px 6px #00cc9926}.checkbox-label input[type=checkbox]:hover{border-color:#0c9c;transform:scale(1.05)}.checkbox-label input[type=checkbox]:checked:hover{background-color:#00b386;border-color:#00b386;box-shadow:0 0 0 3px #00cc994d}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;margin:0;border-radius:5px;transition:all .2s ease;border:2px solid rgba(0,204,153,.5);background-color:#fff;appearance:none;-webkit-appearance:none;-moz-appearance:none;position:relative;z-index:10;pointer-events:auto;flex-shrink:0}.checkbox-label input[type=checkbox]:not(:checked){background-color:#fff;border-color:#00cc9980}.checkbox-label input[type=checkbox]:checked{background-color:#0c9;border-color:#0c9;box-shadow:0 0 0 3px #0c93}.checkbox-label input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:900;line-height:1;pointer-events:none;z-index:11}.checkbox-label input[type=checkbox]:checked+span{color:#008060;font-weight:700}.checkbox-label:has(input[type=checkbox]:checked){background:linear-gradient(135deg,#00cc991f,#00cc9914);border-color:#0c9;border-width:2px;box-shadow:0 2px 8px #0c93}.checkbox-label:has(input[type=checkbox]:checked):hover{background:linear-gradient(135deg,#00cc992e,#00cc991f);border-color:#00b386}.student-card-v2{background:#fff;border:1px solid #e9ecef;border-radius:14px;padding:1.1rem 1.15rem .9rem;cursor:pointer;position:relative;display:flex;flex-direction:column;gap:.85rem;transition:box-shadow .18s,border-color .18s,transform .12s;font-family:Poppins,sans-serif}.student-card-v2:hover{box-shadow:0 6px 20px #00000014;border-color:#dee2e6;transform:translateY(-2px)}.student-card-v2.unviewed{border-color:#0c96;box-shadow:0 0 0 3px #00cc9914}.scv2-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.scv2-name-wrap{display:flex;flex-direction:column;gap:.15rem;min-width:0}.scv2-name{font-size:.9rem;font-weight:600;color:#212529;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scv2-goal{font-size:.72rem;color:#adb5bd;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scv2-menu-wrap{position:relative;flex-shrink:0}.scv2-menu-btn{background:transparent;border:none;color:#adb5bd;cursor:pointer;padding:.2rem .3rem;border-radius:6px;font-size:1rem;display:flex;align-items:center;transition:background .15s,color .15s}.scv2-menu-btn:hover{background:#f8f9fa;color:#495057}.scv2-menu-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid #e9ecef;border-radius:10px;box-shadow:0 8px 24px #0000001f;min-width:140px;z-index:50;overflow:hidden;animation:dropIn .12s ease-out}@keyframes dropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.scv2-menu-dropdown button{display:block;width:100%;padding:.6rem .9rem;background:none;border:none;text-align:left;font-size:.82rem;font-family:Poppins,sans-serif;color:#495057;cursor:pointer;transition:background .12s}.scv2-menu-dropdown button:hover{background:#f8f9fa;color:#00b386}.scv2-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.scv2-stat{display:flex;flex-direction:column;gap:.25rem}.scv2-stat-label{font-size:.62rem;color:#adb5bd;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.scv2-stat-value{display:flex;align-items:center;gap:.2rem;font-size:1rem;font-weight:700;line-height:1.1}.scv2-trend-icon{font-size:.85rem}.scv2-state-badge{display:inline-flex;align-items:center;font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:20px;white-space:nowrap}.scv2-cal-bar{display:flex;flex-direction:column;gap:.3rem}.scv2-cal-bar-track{height:4px;background:#f0f0f0;border-radius:4px;overflow:hidden}.scv2-cal-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.scv2-cal-label{font-size:.7rem;color:#adb5bd;font-weight:500}.scv2-unviewed-dot{position:absolute;top:.75rem;right:2.2rem;width:7px;height:7px;background:#0c9;border-radius:50%}@media (max-width: 768px){.student-card-v2{padding:1rem;gap:.75rem;transition:box-shadow .18s}.student-card-v2:hover{transform:none}.student-card-v2:active{background:#f8f9fa}.scv2-name{font-size:.95rem}.scv2-goal{font-size:.75rem}.scv2-stats{grid-template-columns:1fr 1fr 1fr;gap:.75rem}.scv2-stat-label{font-size:.6rem}.scv2-stat-value{font-size:.95rem}.scv2-state-badge{font-size:.68rem;padding:.18rem .45rem}.scv2-menu-btn{padding:.35rem .45rem;font-size:1.1rem}}.filter-bar-container{display:flex;flex-direction:column;gap:16px;margin-bottom:24px;background-color:#fff;padding:16px;border-radius:12px;border:1px solid var(--border-color, #e9ecef);box-shadow:0 2px 4px #00000005}.search-container{position:relative;width:100%}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--secondary-text, #6c757d);font-size:1.2rem}.search-input{width:100%;padding:12px 12px 12px 40px;border:1px solid var(--border-color, #e9ecef);border-radius:8px;font-size:.95rem;transition:all .2s ease;background-color:var(--primary-bg, #f8f9fa);color:var(--primary-text, #212529)}.search-input:focus{outline:none;border-color:var(--accent-color, #00cc99);box-shadow:0 0 0 3px #00cc991a;background-color:#fff}.filter-chips{display:flex;gap:8px;flex-wrap:wrap}.filter-chip{padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid transparent;background-color:var(--primary-bg, #f8f9fa);color:var(--secondary-text, #6c757d);transition:all .2s ease;display:flex;align-items:center;gap:6px}.filter-chip:hover{background-color:#e9ecef}.filter-chip.active{background-color:var(--accent-color, #00cc99);color:#fff;border-color:var(--accent-color, #00cc99)}.filter-chip-critical{color:#ef4444;background-color:#fef2f2;border-color:#fee2e2}.filter-chip-critical.active{background-color:#ef4444;color:#fff;border-color:#ef4444}.filter-chip-inactive{color:#6b7280;background-color:#f3f4f6;border-color:#e5e7eb}.filter-chip-inactive.active{background-color:#6b7280;color:#fff;border-color:#6b7280}@media (max-width: 767px){.filter-bar-container{padding:12px;gap:10px;margin-bottom:16px}.filter-chips{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.filter-chips::-webkit-scrollbar{display:none}.filter-chip{flex-shrink:0;font-size:.8rem;padding:5px 12px}.search-input{font-size:.875rem;padding:10px 10px 10px 36px}}@media (min-width: 768px){.filter-bar-container{flex-direction:row;align-items:center;justify-content:space-between}.search-container{max-width:300px}}.sidebar{width:220px;min-width:220px;background:#fff;border-right:1px solid #e9ecef;display:flex;flex-direction:column;height:100vh;position:fixed;top:0;left:0;overflow-y:auto;font-family:Poppins,sans-serif;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:.6rem;padding:1.5rem 1.25rem 1.25rem;border-bottom:1px solid #f0f0f0}.sidebar-logo-mark{width:32px;height:32px;background:linear-gradient(135deg,#0c9,#00b386);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1rem;flex-shrink:0}.sidebar-logo-text{font-size:1rem;font-weight:700;color:#212529;letter-spacing:-.01em}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.15rem;padding:1rem .75rem}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;border:none;background:transparent;border-radius:10px;color:#6c757d;font-size:.875rem;font-weight:500;font-family:Poppins,sans-serif;cursor:pointer;text-align:left;width:100%;transition:background .15s,color .15s}.sidebar-nav-item svg{font-size:1.05rem;flex-shrink:0}.sidebar-nav-item:hover{background:#f8f9fa;color:#212529}.sidebar-nav-item.active{background:#00cc991a;color:#00b386;font-weight:600}.sidebar-nav-item.active svg{color:#0c9}.sidebar-footer{display:flex;align-items:center;gap:.5rem;padding:1rem .75rem;border-top:1px solid #e9ecef}.sidebar-profile{display:flex;align-items:center;gap:.65rem;flex:1;min-width:0}.sidebar-avatar{width:34px;height:34px;min-width:34px;background:linear-gradient(135deg,#0c9,#00b386);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700}.sidebar-profile-info{display:flex;flex-direction:column;min-width:0}.sidebar-profile-name{font-size:.78rem;font-weight:600;color:#212529;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-profile-role{font-size:.7rem;color:#adb5bd}.sidebar-logout{background:transparent;border:1px solid #e9ecef;border-radius:8px;color:#adb5bd;padding:.4rem;cursor:pointer;display:flex;align-items:center;font-size:.95rem;flex-shrink:0;transition:color .15s,border-color .15s,background .15s}.sidebar-logout:hover{color:#ef4444;border-color:#fecaca;background:#fff5f5}@media (max-width: 1024px) and (min-width: 769px){.sidebar{width:64px;min-width:64px}.sidebar-logo-text,.sidebar-nav-item span,.sidebar-profile-info{display:none}.sidebar-logo{justify-content:center;padding:1.25rem 0}.sidebar-nav{padding:1rem .5rem;align-items:center}.sidebar-nav-item{justify-content:center;padding:.75rem;border-radius:12px}.sidebar-nav-item svg{font-size:1.2rem}.sidebar-footer{justify-content:center;padding:.75rem .5rem}.sidebar-logout{width:100%;justify-content:center}}@media (max-width: 1024px) and (min-width: 769px){.dashboard-content{margin-left:64px}}@media (max-width: 768px){.sidebar{display:none}}.bottom-nav{display:none}@media (max-width: 768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:60px;background:#fff;border-top:1px solid #e9ecef;box-shadow:0 -4px 16px #0000000f;z-index:200;padding:0 .5rem;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;background:none;border:none;color:#adb5bd;font-size:.65rem;font-weight:500;font-family:Poppins,sans-serif;cursor:pointer;padding:.4rem 0;transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav-item svg{font-size:1.25rem}.bottom-nav-item.active{color:#0c9}.bottom-nav-item.active svg{stroke-width:2.5}}.dashboard-widgets{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.widget{background:#fff;border:1px solid #e9ecef;border-radius:14px;padding:1.1rem 1.25rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:0 2px 8px #0000000a;transition:box-shadow .2s}.widget.widget-clickable{cursor:pointer}.widget.widget-clickable:hover{box-shadow:0 4px 16px #00000014}.widget-icon-wrap{width:40px;height:40px;min-width:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem}.widget-body{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.widget-label{font-size:.75rem;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.widget-value-row{display:flex;align-items:baseline;gap:.35rem}.widget-value{font-size:1.6rem;font-weight:700;line-height:1}.widget-value-sub{font-size:.82rem;color:#adb5bd;font-weight:500}.widget-bar-track{height:4px;background:#f0f0f0;border-radius:4px;margin-top:.4rem;overflow:hidden}.widget-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.widget-cta{font-size:.75rem;color:#f59e0b;font-weight:600;margin-top:.15rem}@media (max-width: 900px){.dashboard-widgets{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.dashboard-widgets{grid-template-columns:1fr 1fr 1fr;gap:.6rem}.widget{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.85rem .75rem}.widget-icon-wrap{width:32px;height:32px;min-width:32px;font-size:.95rem}.widget-label{font-size:.62rem}.widget-value{font-size:1.25rem}.widget-value-sub{font-size:.72rem}.widget-bar-track{display:none}.widget-cta{font-size:.65rem}}:root{--primary-bg: #f4f5f7;--secondary-bg: #ffffff;--primary-text: #212529;--secondary-text: #6c757d;--accent-color: #00cc99;--accent-hover: #00b386;--border-color: #e9ecef;--shadow: 0 2px 8px rgba(0, 0, 0, .05);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--gradient-primary: linear-gradient(135deg, #00cc99 0%, #00b386 100%)}body,html{margin:0;padding:0;background-color:var(--primary-bg);font-family:Poppins,sans-serif}.dashboard-root{display:flex;min-height:100vh;background:var(--primary-bg)}.dashboard-content{flex:1;min-width:0;margin-left:220px;padding:2rem;min-height:100vh;box-sizing:border-box;overflow-y:auto}.content-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem}.content-header-left{display:flex;flex-direction:column;gap:.15rem}.content-title{font-size:1.5rem;font-weight:700;color:var(--primary-text);margin:0}.content-subtitle{font-size:.82rem;color:var(--secondary-text);text-transform:capitalize}.content-create-btn{display:flex;align-items:center;gap:.45rem;background:var(--gradient-primary);border:none;border-radius:10px;padding:.65rem 1.25rem;color:#fff;font-size:.875rem;font-weight:600;font-family:Poppins,sans-serif;cursor:pointer;box-shadow:0 4px 14px #00cc994d;transition:opacity .2s,transform .1s;white-space:nowrap;flex-shrink:0}.content-create-btn:hover{opacity:.92;transform:translateY(-1px)}.content-alert{display:flex;align-items:center;gap:.6rem;background:#fff8e1;border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:10px;padding:.75rem 1rem;color:#92400e;font-size:.85rem;margin-bottom:1rem}.content-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 0;color:var(--secondary-text);font-size:.9rem}.content-spinner{width:36px;height:36px;border:3px solid #e9ecef;border-top-color:#0c9;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.client-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media (max-width: 1100px){.client-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard-content{margin-left:0;padding:1rem 1rem 80px}.content-header{flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.content-title{font-size:1.25rem}.content-create-btn span{display:none}.content-create-btn{padding:.65rem .85rem;border-radius:50%;min-width:42px;min-height:42px;justify-content:center}.client-grid{grid-template-columns:1fr;gap:.75rem}.content-alert{font-size:.8rem;padding:.65rem .85rem}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:5rem 0;color:var(--secondary-text);font-size:.9rem;text-align:center}.empty-filter-state{grid-column:1 / -1;text-align:center;padding:3rem 0;color:var(--secondary-text);font-size:.9rem}.filter-bar-container{margin-bottom:1rem}#root{width:100%;max-width:100vw;min-height:100vh;margin:0;padding:0;text-align:left;box-sizing:border-box;overflow-x:hidden;background-color:var(--primary-bg, #f8fafc)}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;flex-direction:column;min-width:320px;min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
