.btn{height:48px!important;padding:12px 24px!important}.btn:disabled{cursor:not-allowed;filter:grayscale(60%);opacity:1;pointer-events:none}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#c8a2c8,#9c27b0);box-shadow:0 8px 24px 0 #b57edc8c;transform:translateY(-1px)}.btn-primary:active:not(:disabled){background:linear-gradient(135deg,#a66cc9,#7b1fa2);box-shadow:0 2px 10px #b57edc66;transform:translateY(0)}.btn-primary:focus:not(:disabled){box-shadow:0 0 0 3px #b57edc4d,0 4px 15px #b57edc66;outline:none}.btn-secondary{background-color:initial;border:2px solid #b57edc;border-radius:8px;color:#b57edc;font-weight:600;overflow:hidden;position:relative}.btn-secondary:before{background:linear-gradient(90deg,#0000,#b57edc33,#0000);content:"";left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.btn-secondary:hover:not(:disabled){background-color:initial;border:2px solid #b57edc;border-radius:8px;box-shadow:0 0 12px #c8a2c826;color:#b57edc;transform:translateY(-1px)}.btn-secondary:hover:not(:disabled):before{left:100%}.btn-secondary:active:not(:disabled){background-color:#a66cc9;border-color:#a66cc9;height:48px!important;transform:translateY(0)}.btn-secondary:focus:not(:disabled){box-shadow:0 0 0 3px #b57edc33;height:48px!important;outline:none}.btn-outlined{background-color:#e6daf5;border:2px solid #0000;border-radius:8px;color:#6a1b9a;font-weight:500;height:48px!important}.btn-outlined:hover:not(:disabled){background-color:#d1c4e9;color:#6a1b9a;height:48px!important;transform:translateY(-1px)}.btn-outlined:active:not(:disabled){background-color:#c8a2c8;height:48px!important;transform:translateY(0)}.btn-outlined:focus:not(:disabled){box-shadow:0 0 0 3px #e6daf580;outline:none}.btn-ghost{background-color:initial;border:2px solid #0000;border-radius:8px;color:#b57edc;font-weight:400;text-decoration:underline;text-decoration-color:#0000;text-underline-offset:4px}.btn-ghost:hover:not(:disabled){background-color:#b57edc0d;border-color:#b57edc33;color:#8e24aa;text-decoration-color:#b57edc;transform:translateY(-1px)}.btn-ghost:active:not(:disabled){background-color:#b57edc1a;color:#7b1fa2;transform:translateY(0)}.btn-ghost:focus:not(:disabled){background-color:#b57edc0d;box-shadow:0 0 0 2px #b57edc33;outline:none}.btn-sm{font-size:14px;padding:8px 16px!important}.btn-lg{font-size:18px;padding:16px 48px!important}.btn-xl{font-size:20px;padding:20px 64px!important}.btn-block{display:flex;width:100%!important}.btn-icon-only{aspect-ratio:1;padding:12px;width:48px}.btn-icon-only.btn-sm{padding:8px;width:48px}.btn-icon-only.btn-lg{padding:16px;width:48px}.btn-loading{color:#0000!important;position:relative}.btn-loading:after{animation:btn-spin 1s linear infinite;border:2px solid #e6daf5;border-radius:50%;border-top-color:#b57edc;box-sizing:border-box;color:#b57edc;content:"";height:20px;left:50%;opacity:1!important;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.btn-ghost.btn-loading:after,.btn-outlined.btn-loading:after{color:#b57edc}@keyframes btn-spin{to{transform:translate(-50%,-50%) rotate(1turn)}}.btn-group{border-radius:8px;box-shadow:0 2px 8px #b57edc26;display:inline-flex;overflow:hidden}.btn-group .btn{border-radius:0;border-right-width:1px}.btn-group .btn:first-child{border-bottom-left-radius:8px;border-top-left-radius:8px}.btn-group .btn:last-child{border-bottom-right-radius:8px;border-right-width:2px;border-top-right-radius:8px}.btn-group .btn:not(:last-child){margin-right:-1px}.btn-success{background-color:#c5e1a5;border-color:#c5e1a5;color:#2e7d32}.btn-success:hover:not(:disabled){background-color:#aed581;border-color:#aed581;transform:translateY(-1px)}.btn-warning{background-color:#fff9c4;border-color:#fff9c4;color:#f57f17}.btn-warning:hover:not(:disabled){background-color:#fff59d;border-color:#fff59d;transform:translateY(-1px)}.btn-error{background-color:#f8bbd0;border-color:#f8bbd0;color:#c2185b}.btn-error:hover:not(:disabled){background-color:#f48fb1;border-color:#f48fb1;transform:translateY(-1px)}@media (max-width:768px){.btn{font-size:15px;padding:10px 20px}.btn,.btn-sm{height:48px!important}.btn-sm{font-size:13px;padding:6px 12px}.btn-lg{font-size:17px;padding:14px 28px}.btn-lg,.btn-xl{height:48px!important}.btn-xl{font-size:19px;padding:18px 36px}}@media (max-width:480px){.btn{font-size:14px;height:48px!important;padding:8px 16px}.btn-group{flex-direction:column}.btn-group .btn{border-bottom-width:1px;border-radius:0;border-right-width:2px}.btn-group .btn:first-child{border-bottom-left-radius:0;border-top-left-radius:8px;border-top-right-radius:8px}.btn-group .btn:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px;border-bottom-width:2px;border-top-right-radius:0}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.d-none{display:none!important}.d-flex{display:flex}.d-block{display:block}.d-inline{display:inline}.d-inline-block{display:inline-block}.m-0{margin:0}.p-0{padding:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.pt-1{padding-top:8px}.pt-2{padding-top:16px}.pt-3{padding-top:24px}.pt-4{padding-top:32px}.pb-1{padding-bottom:8px}.pb-2{padding-bottom:16px}.pb-3{padding-bottom:24px}.pb-4{padding-bottom:32px}.text-primary{color:#b57edc}.text-secondary{color:#c8a2c8}.text-muted{color:#6c757d}.text-white{color:#fff}.bg-primary{background-color:#b57edc}.bg-secondary{background-color:#c8a2c8}.bg-light{background-color:#e6daf5}.bg-white{background-color:#fff}.border{border:1px solid #d8bfd8}.border-primary{border-color:#b57edc}.border-secondary{border-color:#c8a2c8}.rounded{border-radius:8px}.rounded-lg{border-radius:12px}.input{background-color:#fff;border:2px solid #d8bfd8!important;border-radius:8px;box-sizing:border-box;font-family:Poppins;font-size:16px;height:48px;min-height:48px;padding:12px 15px;transition:border-color .3s ease;width:100%}.input:focus{border-color:#b57edc;box-shadow:0 0 0 3px #b57edc33;outline:none}.custom-checkbox-group{align-items:start;display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.custom-checkbox-label{align-items:center;cursor:pointer;display:inline-flex;font-size:15px;gap:4px;margin:0;position:relative}.custom-checkbox-label input[type=checkbox]{height:0;opacity:0;position:absolute;width:0}.custom-checkbox{align-items:center;background:#fff;border:2px solid #d8bfd8;border-radius:4px;box-sizing:border-box;display:flex;height:20px;justify-content:center;max-height:20px;max-width:20px;min-height:20px;min-width:20px;position:relative;transition:border-color .2s,background .2s;vertical-align:middle;width:20px}.custom-checkbox-label input[type=checkbox]:checked+.custom-checkbox{background:#b57edc;border-color:#b57edc}.custom-checkbox-label input[type=checkbox]:checked+.custom-checkbox:after{border:solid #fff;border-radius:1px;border-width:0 3px 3px 0;content:"";display:block;height:14px;left:50%;position:absolute;top:50%;transform:rotate(45deg) scale(.8);translate:-50% calc(-50% - 2px);width:8px}.custom-checkbox-label span.label-text{display:inline-block;margin:0;-webkit-user-select:none;user-select:none}.shared-btn{background:#b57edc;border:none;border-radius:12px;box-shadow:0 4px 15px #b57edc66;color:#fff;cursor:pointer;font-family:Poppins,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:16px;font-weight:600;padding:16px;transition:all .3s ease;width:100%}.shared-btn:hover:not(:disabled){background:#c8a2c8;box-shadow:0 6px 20px #b57edc80;transform:translateY(-2px)}.shared-btn:active{transform:translateY(0)}.ciclii-modal-body{max-height:60vh;min-height:0;overflow-x:hidden;overflow-y:auto;padding-bottom:8px}@media (max-width:480px){.ciclii-modal-body{max-height:70vh;overflow-x:hidden}}@media (max-width:768px){.calendar-day-modal-actions,.calendar-day-modal-actions .btn,.calendar-day-modal-actions .btn-block,.calendar-day-modal-actions button{box-sizing:border-box;display:block!important;max-width:100%!important;width:100%!important}.calendar-day-modal-actions{align-items:stretch!important;display:flex!important;flex-direction:column!important;gap:10px!important;width:100%!important}}.ciclii-modal-footer{display:flex;gap:18px;justify-content:center;margin-top:32px}.ciclii-modal-overlay{align-items:center;background:#00000047;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;transition:background .2s;z-index:1000}.ciclii-modal-content{background:#fff;border-radius:20px;box-shadow:0 8px 32px #b57edc2e,0 1.5px 8px #00000014;color:#3a2d4d;font-family:inherit;font-size:1.08rem;max-width:600px;min-width:200px;outline:none;padding:36px 28px 28px;position:relative;text-align:center;transition:box-shadow .2s,border .2s;width:80%!important}.ciclii-modal-content button[aria-label=Cerrar]{background:none;border:none;color:#b57edc;cursor:pointer;font-size:2rem;position:absolute;right:18px;top:14px;transition:color .15s}.ciclii-modal-content button[aria-label=Cerrar]:hover{color:#a06cd5}.ciclii-modal-content .success-message{color:#38b000;font-size:1.18rem;font-weight:600;margin-bottom:12px}.ciclii-modal-content .error-message{color:#dc2626;font-size:1.18rem;font-weight:600;margin-bottom:12px}@media (max-width:480px){.ciclii-modal-content{font-size:.98rem;min-width:0;padding:18px 6vw}}@media (min-width:1280px){.ciclii-modal-content{max-width:33vw!important}}.floating-alert--danger .floating-alert__title{font-size:20px;font-weight:700;margin-bottom:10px;margin-top:0}.floating-alert__close{align-self:flex-start;background:none;border:none;color:#6a1b9a;cursor:pointer;font-size:1.7em;line-height:1;margin-left:16px;padding:0;transition:color .2s;z-index:1}.floating-alert__row{align-items:flex-start;display:flex;flex-direction:row;justify-content:space-between;width:100%}.floating-alert__content{flex:1 1;min-width:0}.floating-alert__close:hover{color:#b57edc}.floating-alert--warning .floating-alert__title{color:#6a1b9a;font-size:20px;font-weight:700;margin-bottom:10px;margin-top:0}.floating-alert-container{display:flex;flex-direction:column;position:fixed;right:32px;top:32px;z-index:9999}@media (max-width:768px){.floating-alert{box-sizing:border-box;font-size:14px!important;margin:0 auto 20px;max-width:500px;min-width:0;padding:16px;width:100%}.floating-alert__title{font-size:17px!important}}.floating-alert{align-items:flex-start;animation:floating-alert-in .3s;border-radius:12px;box-shadow:0 2px 6px #0000001a;box-sizing:border-box;display:flex;flex-direction:column;font-family:Poppins,sans-serif;font-size:16px;margin:0 auto 20px;max-width:500px;min-width:0;padding:20px;position:relative;width:100%}.floating-alert--success{background-color:#c5e1a5;border-left:8px solid #8bc34a;color:#33691e}.floating-alert--warning{background-color:#fff9c4;border-left:8px solid #b57edc;box-shadow:0 4px 8px #b57edc4d;color:#4a148c}.floating-alert--danger{background-color:#f8bbd0;border-left:8px solid #b57edc;color:#6a1b9a}.floating-alert--info{background-color:#c7f6ff;border-left:8px solid #9575cd;color:#4a148c}.floating-alert--info .floating-alert__title,.floating-alert--success .floating-alert__title{font-size:20px;font-weight:700;margin-bottom:10px;margin-top:0}@keyframes floating-alert-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.day-detail-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;margin:20px auto;max-width:700px;padding:20px;width:100%;@media (max-width:560px){margin-bottom:10px;margin-left:10px;margin-right:10px;margin-top:10px;padding-bottom:8px;padding-left:8px;padding-right:8px;padding-top:8px;width:calc(100% - 20px)}}.day-detail h3{color:#333;font-size:1.2rem;margin:0 0 15px;text-transform:capitalize}.events-list{margin-bottom:20px}.event-detail{align-items:center;background:#f8f9fa;border-left:4px solid #4caf50;border-radius:5px;display:flex;justify-content:space-between;margin:8px 0;padding:10px}.event-title{color:#333;font-weight:500}.delete-btn-detail{background:#f44;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:5px 10px;transition:background-color .3s}.delete-btn-detail:hover{background:#c33}.symptoms-button-container{display:flex;flex-direction:row;gap:10px;justify-content:space-between;padding-bottom:30px;text-align:center}.add-event-btn{background:#4caf50;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;max-width:160px;padding:10px 20px;transition:background-color .3s;width:100%}.add-event-btn:hover{background:#45a049}.no-events{background:#f8f9fa;border-radius:5px;font-style:italic;padding:20px}.no-day-selected,.no-events{color:#666;text-align:center}.no-day-selected{padding:40px}.no-day-selected p{font-size:1.1rem;margin:0}.landing-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.landing-content{grid-gap:60px;align-items:center;display:grid;gap:60px;grid-template-columns:1fr 1fr;max-width:1200px;width:100%}.landing-hero{align-items:center;display:flex;flex-direction:column;gap:16px;text-align:center}.landing-hero h1{color:#fff;font-size:3rem;font-style:italic;font-weight:700;margin-bottom:20px}.landing-hero p{color:#ffffffe6;font-size:1.25rem;font-style:italic;line-height:1.6}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px}.login-card h2{color:#333;font-size:1.75rem;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#555;font-size:.9rem}.form-group input{border:2px solid #e1e8ed;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{border-radius:8px;color:#c33;font-size:.9rem;margin-bottom:20px;padding:12px;text-align:start}.btn-login{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px;transition:transform .2s,box-shadow .2s;width:100%}.btn-login:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-login:disabled{cursor:not-allowed;opacity:.6}.signup-link{color:#666;font-size:.9rem;margin-top:20px;text-align:center}.signup-link button{background:none;border:none;color:#667eea;cursor:pointer;font-size:inherit;font-weight:600;padding:0;text-decoration:underline}.signup-link button:hover{color:#764ba2}.activation-card{margin:0 auto;max-width:520px;text-align:center;width:100%}.activation-card h1{color:#333;font-size:1.9rem;margin-bottom:16px}.activation-summary{background:#f7f5ff;border-radius:12px;color:#5d5774;font-size:.95rem;line-height:1.6;margin:24px 0;padding:16px;word-break:break-word}.activation-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.activation-actions .btn{font-size:1rem;min-height:48px}@media (min-width:576px){.activation-actions{flex-direction:row;justify-content:center}.activation-actions .btn{min-width:200px}}.activation-feedback{color:#2f855a;font-weight:600;margin-top:16px}.activation-error{color:#c53030;font-weight:600;margin:16px 0 0}@media (max-width:768px){.landing-container{padding:32px 10px!important}.landing-content{gap:40px;grid-template-columns:1fr}.landing-hero h1{font-size:2rem}.landing-hero p{font-size:1rem}.login-card{padding:30px 20px}}.nav-submenu-fade-exit{animation:submenuFadeOut .3s forwards;opacity:1;transform:translateY(0)}@keyframes submenuFadeOut{to{opacity:0;transform:translateY(-8px)}}.nav-submenu-fade{animation:submenuFadeIn .3s forwards;opacity:0;transform:translateY(-8px)}@keyframes submenuFadeIn{to{opacity:1;transform:translateY(0)}}.nav-parent-open{background-color:#ffffff1a;color:#fff}.nav-subitem.nav-item-active{background:#6b3fa0;box-shadow:0 2px 8px #6b3fa014;font-weight:600}.nav-group{margin-bottom:1rem}.nav-parent{align-items:center;color:#6b3fa0;cursor:pointer;display:flex;font-size:1rem;font-weight:600;padding:.5rem 1rem;-webkit-user-select:none;user-select:none}.nav-submenu{margin-top:.25rem;padding-left:3rem}.nav-subitem{background:#0000;border-radius:6px;color:#5a3670;font-size:.85rem;font-weight:400;margin-bottom:.25rem;padding:.5rem 1rem;transition:background .2s,color .2s}.nav-subitem.nav-item-active{background:linear-gradient(135deg,#b57edc,#f8bbd0);box-shadow:0 2px 4px #0000001a;color:#fff;font-weight:500}.nav-subitem .nav-icon{font-size:1rem;margin-right:.5rem}.dashboard-layout{background-color:#f5f7fa;display:flex;min-height:100vh}.dashboard-sidebar{background:linear-gradient(135deg,#b57edc,#d8bfd8 50%,#d1c4e9);box-shadow:2px 0 10px #0000001a;color:#fff;display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;visibility:visible;width:300px;z-index:1000}.sidebar-header{align-items:center;border-bottom:1px solid #fff3;display:flex;justify-content:space-between;padding:24px}.sidebar-header-content{align-items:center;display:flex;gap:15px}.sidebar-close-btn{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;display:none;font-size:1rem;padding:8px;transition:all .3s ease}.sidebar-close-btn:hover{background:#ffffff4d}.logo-icon{color:gold;font-size:2rem}.logo-text{font-size:1.5rem;font-weight:700;letter-spacing:1px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px}.nav-item{align-items:center;border:none;border-radius:8px;color:#fff;display:flex;gap:12px;margin-bottom:8px;padding:12px 16px;text-decoration:none;transition:all .3s ease}.nav-item:hover{background-color:#ffffff1a;color:#fff}.nav-item-active{background:linear-gradient(135deg,#b57edc,#f8bbd0);box-shadow:0 2px 4px #0000001a;color:#fff;font-weight:500}.nav-icon{font-size:1.25rem}.sidebar-footer{border-top:1px solid #fff3;padding:16px}.user-info{align-items:center;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:flex;font-weight:500;margin-bottom:12px;padding:12px 16px;position:relative;transition:all .3s ease}.user-info,.user-info:hover{background:linear-gradient(135deg,#c8aec8,#f0d8f0)}.user-info:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.user-icon{color:#fff;font-size:1.5rem;left:calc(50% - 50px);position:absolute}.user-details{display:flex;flex-direction:column;gap:4px;text-align:center;width:100%}.user-name{font-size:.95rem;font-weight:600}.user-email{color:#ffffffb3;font-size:.8rem}.btn-logout{align-items:center;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:10px;justify-content:center;padding:12px;transition:all .3s ease;width:100%}.btn-logout,.btn-logout:hover{background:linear-gradient(135deg,#c8aec8,#f0d8f0)}.btn-logout:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.dashboard-main{background-color:#f9fafb;flex:1 1;margin-left:300px;min-height:100vh;overflow:hidden!important;padding:0}.mobile-header-bar{align-items:center;border-bottom:none;box-shadow:0 2px 10px #b57edc4d;cursor:pointer;display:none;height:60px;justify-content:space-between;left:0;padding:0 20px;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1001}.mobile-header-bar,.mobile-header-bar.menu-open{background:linear-gradient(135deg,#b57edc,#d8bfd8)}.mobile-header-bar.menu-open{box-shadow:0 4px 15px #b57edc66}.mobile-header-bar,.mobile-header-bar.menu-open{transition:background .3s ease,box-shadow .3s ease}.mobile-header-content{align-items:center;color:#fff;display:flex}.mobile-logo-icon{color:gold;font-size:24px;margin-right:12px}.mobile-logo-text{font-size:20px;font-weight:700;letter-spacing:.5px}.mobile-menu-icon{color:#fff;font-size:22px;transition:transform .3s ease}.mobile-header-bar:hover .mobile-menu-icon{transform:scale(1.1)}.sidebar-overlay{background-color:#00000080;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:999}@media (max-width:1024px){.dashboard-sidebar{width:240px}.dashboard-main{margin-left:240px;padding:0}.sidebar-header{padding:20px 15px}.nav-item{padding:10px 15px}.user-info{padding:12px 15px}}@media (max-width:768px){.mobile-header-bar{display:flex}.dashboard-sidebar{background:linear-gradient(135deg,#b57edc,#d8bfd8 50%,#d1c4e9);box-shadow:none;clip-path:inset(0 0 100% 0);height:auto;left:0;max-height:calc(100vh - 60px);overflow:hidden;top:60px;transform:translateY(0);transition:clip-path .4s ease-out;width:100%;z-index:1002}.dashboard-sidebar.sidebar-open{clip-path:inset(0 0 0 0);transition:clip-path .4s ease}.sidebar-header{display:none}.sidebar-nav{padding:20px 16px 100px}.nav-item{border-bottom:none;border-radius:8px;margin-bottom:8px;padding:16px 20px}.nav-item:hover{background-color:#ffffff2e;box-shadow:0 2px 8px #0000001a;transform:translateX(4px)}.nav-item-active{background:linear-gradient(135deg,#8e24aa66,#ffffff59);box-shadow:0 2px 8px #8e24aa33;font-weight:600;transform:translateX(4px)}.sidebar-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#0000001a,#0000000d);border-top:1.5px solid #ffffff4d;padding:20px}.user-info{box-shadow:0 2px 8px #c8aec866;font-weight:600;margin-bottom:12px;transform:translateX(4px)}.user-info,.user-info:hover{background:linear-gradient(135deg,#c8aec8b3,#f0d8f099)}.user-info:hover{box-shadow:0 3px 10px #c8aec866;transform:translateX(6px)}.btn-logout{border:none;box-shadow:0 2px 8px #c8aec866;font-weight:600}.btn-logout,.btn-logout:hover{background:linear-gradient(135deg,#c8aec8b3,#f0d8f099)}.btn-logout:hover{box-shadow:0 4px 12px #c8aec880;transform:translateY(-2px)}.sidebar-overlay.overlay-active{display:block}.dashboard-main{margin-left:0;margin-right:0;margin-top:60px;padding:0;width:100%}.sidebar-header{padding:20px 15px}.logo-text{font-size:1.3rem}.nav-item{font-size:.95rem;padding:14px 20px}.nav-icon{font-size:1.1rem}.user-name{font-size:.9rem}.user-email{font-size:.75rem}}@media (max-width:480px){.dashboard-sidebar{width:100%}.dashboard-main{margin-top:60px;padding:0}.sidebar-header{padding:15px 12px}.logo-icon{font-size:1.7rem}.logo-text{font-size:1.2rem}.nav-item{font-size:.9rem;padding:12px 15px}.nav-icon{font-size:1rem}.user-info{margin-bottom:12px;padding:8px}.user-icon{font-size:1.3rem}.user-name{font-size:.85rem}.user-email{font-size:.7rem}.btn-logout{font-size:.9rem;padding:10px}}@media (max-width:320px){.dashboard-sidebar{width:100%}.dashboard-main{margin-top:60px;padding:0}.sidebar-header{padding:12px 10px}.logo-text{font-size:1.1rem}.nav-item{font-size:.85rem;padding:10px 12px}.user-info{flex-direction:column;gap:8px;text-align:center}.user-details{align-items:center}}.menstruating-checkbox{align-items:center;cursor:pointer;display:inline-flex;font-size:15px;gap:4px;margin:0;position:relative}.menstruating-checkbox input[type=checkbox]{height:0;opacity:0;position:absolute;width:0}.menstruating-checkbox .custom-checkbox{align-items:center;background:#fff;border:2px solid #d8bfd8;border-radius:4px;box-sizing:border-box;display:flex;height:20px;justify-content:center;max-height:20px;max-width:20px;min-height:20px;min-width:20px;position:relative;transition:border-color .2s,background .2s;vertical-align:middle;width:20px}.menstruating-checkbox input[type=checkbox]:checked+.custom-checkbox{background:#b57edc;border-color:#b57edc}.menstruating-checkbox input[type=checkbox]:checked+.custom-checkbox:after{border:solid #fff;border-radius:1px;border-width:0 3px 3px 0;content:"";display:block;height:14px;left:50%;position:absolute;top:50%;transform:rotate(45deg) scale(.8);translate:-50% calc(-50% - 2px);width:8px}.menstruating-checkbox span.label-text{display:inline-block;margin:0;-webkit-user-select:none;user-select:none}.first-time-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:600px;padding:20px}.progress-container{margin-bottom:30px;padding:0 5px}.progress-bar{background-color:#e6daf5;border-radius:10px;height:8px;margin-bottom:15px;overflow:hidden;width:100%}.progress-fill{background:#b57edc;border-radius:10px;height:100%;transition:width .3s ease}.progress-text{color:#b57edc;font-size:14px;font-weight:500;text-align:center}.step-container{min-height:400px;transition:opacity .3s ease}.step-header{border-bottom:2px solid #e6daf5;margin-bottom:30px;padding-bottom:20px;text-align:center}.step-number{background:#b57edc;border-radius:50%;color:#fff;display:inline-block;font-weight:600;height:40px;line-height:40px;margin-bottom:10px;width:40px}.step-title{color:#b57edc;font-size:1.5rem;font-weight:600;margin:0}.step-navigation{align-items:center;justify-content:end;margin-top:40px;padding-top:10px}.nav-buttons,.step-navigation{display:flex;gap:15px}.btn-nav{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:8px;min-width:120px;padding:12px 25px;transition:all .3s ease}.btn-nav:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.btn-nav:disabled:hover{box-shadow:none!important;transform:none!important}.btn-back{background:#f8f9fa;border:2px solid #e1e5e9;color:#6c757d}.btn-back:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd}.btn-next{background:#b57edc;color:#fff}.btn-next:hover:not(:disabled){background:#c8a2c8;box-shadow:0 5px 15px #b57edc66;transform:translateY(-2px)}.btn-submit{background:#b57edc;color:#fff}.btn-submit:hover:not(:disabled){background:#c8a2c8;box-shadow:0 5px 15px #b57edc66;transform:translateY(-2px)}.step-content{animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.flow-selector{flex-wrap:wrap;gap:10px;margin:30px 0}.droplet,.flow-selector{align-items:center;display:flex;justify-content:center}.droplet{cursor:pointer;height:60px;position:relative;transition:all .3s ease;width:50px}.droplet:before{background:#bbb;box-shadow:0 2px 4px #0003;clip-path:polygon(50% 0,35% 25%,20% 50%,10% 70%,15% 85%,30% 95%,50% 100%,70% 95%,85% 85%,90% 70%,80% 50%,65% 25%);content:"";height:28px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:20px}.droplet.active:before,.droplet.selected:before{background:#dc3545;box-shadow:0 3px 8px #dc354566;transform:translate(-50%,-50%) scale(1.1)}.droplet:hover:before{background:#dc3545;box-shadow:0 4px 12px #dc354580;transform:translate(-50%,-50%) scale(1.15)}.droplet.active:before{animation:dropletPulse .3s ease-out}@keyframes dropletPulse{0%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.3)}to{transform:translate(-50%,-50%) scale(1.1)}}.flow-level-text{color:#555;font-size:16px;font-weight:500;margin-top:20px;min-height:24px;text-align:center}.flow-description{color:#6c757d;font-size:14px;font-style:italic;margin-top:10px;min-height:20px;text-align:center}.first-time-question{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;margin-bottom:20px;padding:40px 20px;text-align:center}.first-time-question h2{font-size:2rem;font-weight:600;margin-bottom:20px}.question-text{font-size:1.2rem;font-weight:400;margin-bottom:30px}.checkbox-options{display:flex;flex-wrap:wrap;gap:30px;justify-content:center}.checkbox-option{align-items:center;background:#ffffff1a;border:2px solid #0000;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:500;padding:15px 25px;transition:all .3s ease}.checkbox-option:hover{background:#fff3;transform:translateY(-2px)}.checkbox-option input[type=radio]{margin-right:10px;transform:scale(1.2)}.checkbox-option input[type=radio]:checked+.checkmark{background:#4caf50}.first-time-form{background:#fff;border-radius:15px;box-shadow:0 10px 30px #b57edc26;padding:30px}.first-time-form h2{color:#b57edc;font-size:1.8rem;font-weight:600;margin-bottom:30px;text-align:center}.form-group{margin-bottom:25px}.form-group label{color:#b57edc;display:block;font-size:1rem;font-weight:500;margin-bottom:8px}.form-group input[type=date],.form-group select{background-color:#fff;border:2px solid #d8bfd8;border-radius:8px;font-size:16px;padding:12px 15px;transition:border-color .3s ease;width:100%}.form-group input[type=date]:focus,.form-group select:focus{border-color:#b57edc;box-shadow:0 0 0 3px #b57edc33;outline:none}.button-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:10px}.option-button{background:#fff;border:2px solid #d8bfd8;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 16px;text-align:center;transition:all .3s ease}.option-button:hover{background:#b57edc1a;border-color:#b57edc}.option-button.selected{background:#b57edc;border-color:#b57edc;color:#fff}.form-actions{border-top:1px solid #e1e5e9;display:flex;gap:15px;justify-content:space-between;margin-top:30px;padding-top:20px}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 25px;transition:all .3s ease}.btn-primary{background:#b57edc}.btn-primary:hover{background:#c8a2c8;box-shadow:0 5px 15px #b57edc66}.btn-secondary{background:#f8f9fa;border:2px solid #e1e5e9;color:#6c757d}.btn-secondary:hover{background:#e9ecef;border-color:#adb5bd}@media (max-width:768px){.first-time-container{padding:15px}.first-time-form{padding:20px}.checkbox-options{flex-direction:column;gap:15px}.button-grid{gap:8px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.step-navigation{flex-direction:column;gap:15px}.nav-buttons{justify-content:space-between;width:100%}.btn-nav{flex:1 1;max-width:45%}.step-container{min-height:350px}.step-title{font-size:1.3rem}.flow-selector{gap:5px;margin:20px 0}.droplet{height:50px;width:40px}.droplet:before{height:22px;width:16px}}@media (max-width:480px){.first-time-question h2{font-size:1.5rem}.question-text{font-size:1rem}.button-grid{grid-template-columns:1fr}.option-button{font-size:13px;padding:10px 12px}.btn-nav{font-size:14px;min-width:100px;padding:10px 15px}.step-number{font-size:14px;height:35px;line-height:35px;width:35px}.step-title{font-size:1.2rem}.progress-container{margin-bottom:20px}.droplet{height:45px;width:35px}.droplet:before{height:20px;width:14px}.flow-level-text{font-size:14px}.flow-description{font-size:12px}}.home-container{background-color:#f9fafb;min-height:100vh}.welcome-section{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:32px}.welcome-title{color:#1f2937;font-size:1.875rem;font-weight:700;margin-bottom:8px;margin-top:0}.welcome-subtitle{color:#6b7280;font-size:1rem;margin:0}.period-banner{padding:48px;text-align:center}.period-banner,.period-info-banner{background:linear-gradient(135deg,#e6daf5,#d1c4e9);border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;color:#4a4a4a;margin:24px 32px}.period-info-banner{padding:32px}.period-info-content{align-items:center;display:flex;gap:32px;justify-content:space-between}.last-period-section{flex:1 1}.period-section-title{font-size:1.5rem;font-weight:700;margin-bottom:16px;margin-top:0}.period-dates{display:flex;flex-direction:column;gap:8px}.period-date-item{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.date-label{font-weight:600;margin-right:8px;min-width:140px}.date-value{background-color:#ffffff80;border-radius:8px;font-weight:500;padding:8px 12px}.next-period-section{flex:1 1;text-align:center}.next-period-info{margin-bottom:24px}.next-period-title{font-size:1.125rem;font-weight:600;margin-bottom:8px;margin-top:0}.countdown-box{background-color:#ffffffb3;border-radius:8px;box-sizing:border-box;display:block;margin-bottom:16px;padding:16px 24px;width:100%}.countdown-number{color:#b57edc;font-size:1.875rem;font-weight:700;margin-bottom:4px}.countdown-label{font-size:.875rem;opacity:.8}.banner-title{font-size:1.5rem;font-weight:700;margin-bottom:16px;margin-top:0}.banner-subtitle{font-size:1rem;margin-bottom:24px;margin-top:0;opacity:.8}.btn{align-items:center;border:2px solid #0000;border-radius:8px;box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:16px;font-weight:500;gap:8px;height:48px;justify-content:center;line-height:1.2;padding:12px 24px;text-decoration:none;transition:all .3s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#b57edc,#8e24aa);border:none;border-radius:8px;box-shadow:0 4px 15px #b57edc66;color:#fff;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.btn-primary:hover{box-shadow:0 6px 20px #b57edc80;transform:translateY(-2px)}.content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;padding:32px}@media (min-width:768px){.content-grid{grid-template-columns:repeat(3,1fr)}}.content-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:24px}.card-icon{font-size:2.5rem;margin-bottom:16px}.card-title{color:#1f2937;font-size:1.25rem;font-weight:700;margin-bottom:12px;margin-top:0}.card-description{color:#6b7280;font-size:.875rem;line-height:1.5;margin-bottom:16px}.card-tips{background:linear-gradient(135deg,#b57edc1a,#e6daf54d);border-radius:8px;padding:16px}.tip-item{align-items:center;color:#374151;display:flex;font-size:.875rem;margin-bottom:8px}.tip-item:last-child{margin-bottom:0}.tip-icon{font-size:1.125rem;margin-right:8px}.myth-truth-container{display:flex;flex-direction:column;gap:8px}.truth-item{background-color:#f0fdf4;border-radius:6px;font-size:.875rem;padding:12px}.truth-label{color:#166534;font-weight:600;margin-bottom:4px}.truth-text{color:#6b7280}.myth-item{background-color:#fef2f2;border-radius:6px;font-size:.875rem;padding:12px}.myth-label{color:#dc2626;font-weight:600;margin-bottom:4px}.myth-text{color:#6b7280}.wellbeing-buttons{display:flex;flex-direction:column;gap:8px}.wellbeing-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .3s ease;width:100%}.wellbeing-btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.wellbeing-btn-primary{background:linear-gradient(135deg,#b57edc,#d8bfd8)}.wellbeing-btn-secondary{background:linear-gradient(135deg,#d1c4e9,#f8bbd0)}@media (max-width:480px){.home-container{padding:0}.welcome-section{padding:16px 18px}.welcome-title{font-size:1.375rem;line-height:1.3}.welcome-subtitle{font-size:.875rem;line-height:1.4}.period-banner,.period-info-banner{border-radius:6px;margin:12px 20px;padding:20px 16px}.banner-title{font-size:1.125rem;margin-bottom:12px}.banner-subtitle{font-size:.875rem;margin-bottom:20px}.period-info-content{flex-direction:column;gap:16px;text-align:center}.period-section-title{font-size:1.125rem;margin-bottom:12px}.period-date-item{align-items:center;flex-direction:column;gap:6px;text-align:center}.date-label{font-size:.875rem;margin-right:0;min-width:auto}.date-value{font-size:.875rem;max-width:280px;padding:6px 10px;text-align:center;width:100%}.next-period-title{font-size:1rem}.countdown-box{margin-bottom:12px;padding:12px 16px}.countdown-number{font-size:1.5rem}.countdown-label{font-size:.8rem}.btn{font-size:14px;height:44px;max-width:280px;padding:10px 20px;width:100%}.content-grid{gap:16px;padding:12px 20px}.content-card{padding:16px}.card-icon{font-size:2rem;margin-bottom:12px}.card-title{font-size:1.125rem;margin-bottom:10px}.card-description{font-size:.8rem;margin-bottom:12px}.card-tips{padding:12px}.tip-item{font-size:.8rem;margin-bottom:6px}.tip-icon{font-size:1rem;margin-right:6px}.myth-item,.truth-item{font-size:.8rem;padding:10px}.wellbeing-btn{font-size:.8rem;padding:10px 14px}}@media (min-width:481px) and (max-width:768px){.welcome-section{padding:24px 20px}.welcome-title{font-size:1.5rem}.period-banner,.period-info-banner{margin:20px;padding:28px 24px}.period-info-content{flex-direction:column;gap:24px;text-align:center}.date-label{margin-right:4px;min-width:auto}.period-date-item{align-items:center;flex-direction:column;gap:8px;text-align:center}.date-value{max-width:320px;text-align:center;width:100%}.content-grid{gap:20px;grid-template-columns:1fr;padding:20px}.banner-title,.period-section-title{font-size:1.25rem}.btn{max-width:320px}}@media (min-width:769px) and (max-width:1024px){.welcome-section{padding:28px 24px}.period-banner,.period-info-banner{margin:24px;padding:36px 28px}.period-info-content{align-items:flex-start;flex-direction:row;gap:28px}.last-period-section{flex:1.2 1}.next-period-section{flex:0.8 1;text-align:center}.date-label{min-width:120px}.period-date-item{align-items:center;flex-direction:row;gap:8px}.content-grid{gap:20px;grid-template-columns:repeat(2,1fr);padding:24px}.content-card:last-child{grid-column:1/-1;margin:0 auto;max-width:500px}}@media (min-width:1025px) and (max-width:1200px){.welcome-section{padding:32px}.period-banner,.period-info-banner{margin:24px 32px;padding:40px 32px}.period-info-content{gap:32px}.content-grid{gap:24px;grid-template-columns:repeat(3,1fr);padding:32px}.date-label{min-width:140px}}@media (min-width:1201px){.home-container{margin:0 auto;max-width:1400px}.welcome-section{padding:40px 48px}.welcome-title{font-size:2.25rem}.welcome-subtitle{font-size:1.125rem}.period-banner,.period-info-banner{margin:32px 48px;padding:48px 40px}.banner-title{font-size:1.75rem}.period-section-title{font-size:1.625rem}.content-grid{gap:32px;grid-template-columns:repeat(3,1fr);padding:40px 48px}.content-card{padding:28px}.card-title{font-size:1.375rem}.card-description{font-size:1rem}}@media (max-height:768px){.welcome-section{padding:16px 20px}.welcome-title{font-size:1.375rem;margin-bottom:4px}.welcome-subtitle{font-size:.875rem}.period-banner,.period-info-banner{margin:16px 20px;padding:20px 24px}.period-info-content{gap:20px}.content-grid{gap:16px;padding:16px 20px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.card-icon{font-size:2.25rem}.tip-icon{font-size:1rem}.countdown-number{font-weight:800}}.container{background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:480px;padding:48px;width:100%}.header{margin-bottom:40px;text-align:center}.header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:700;margin:0 0 12px}.header p{color:#6b7280;font-size:16px;margin:0}.form-group{margin-bottom:24px}label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.success-message{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:none;font-weight:500;margin-top:20px;padding:20px;text-align:center}@media (max-width:768px){.container{padding:32px 14px}.header h1{font-size:28px}}.user-profile-container{grid-gap:2rem;box-sizing:border-box;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin:0 auto;max-width:1280px;padding:2rem 1rem;width:100%}@media (max-width:1280px){.user-profile-container{gap:1.5rem;grid-template-columns:1fr}}.user-profile-container>*,.user-profile-container>form{align-items:stretch;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000021;display:flex;flex-direction:column;padding:2rem}.terms-main-wrapper{background:linear-gradient(135deg,#667eea,#764ba2);box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:60px 20px;width:100%}.terms-container{background:#fffffffa;border-radius:20px;box-shadow:0 20px 60px #0000004d;margin:0 auto;max-width:900px;overflow:hidden}.terms-header{background:linear-gradient(135deg,#6f7be7,#5a6fd8 50%,#6a4190);color:#fff;padding:50px 40px;text-align:center}.terms-header h1{font-size:42px;font-weight:700;letter-spacing:-.5px;margin:0 0 15px}.terms-header p{font-size:16px;margin:0;opacity:.95}.terms-content{padding:50px 40px}.terms-intro{border-bottom:2px solid #f0f0f0;margin-bottom:40px;padding-bottom:30px}.terms-intro p{color:#4a5568;font-size:16px;line-height:1.8;margin:0}.terms-section{margin-bottom:40px}.terms-section h2{align-items:center;color:#667eea;display:flex;font-size:24px;font-weight:600;gap:12px;margin:0 0 20px}.terms-section-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-size:16px;font-weight:700;height:36px;justify-content:center;width:36px}.terms-section p{color:#4a5568;font-size:15px;line-height:1.8;margin:0 0 15px 48px}.terms-section ul{margin:15px 0 15px 48px;padding-left:20px}.terms-section li{color:#4a5568;font-size:15px;line-height:1.8;margin-bottom:10px}.terms-highlight-box{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-left:4px solid #667eea;border-radius:8px;margin:30px 0;padding:20px 25px}.terms-highlight-box p{color:#2d3748;font-weight:500;margin:0}.terms-footer{background:linear-gradient(135deg,#5a6fd8,#6a4190);color:#fff;padding:30px 40px;text-align:center}.terms-footer p{font-size:14px;margin:0;opacity:.95}@media (max-width:768px){.terms-main-wrapper{padding:30px 15px}.terms-header{padding:40px 25px}.terms-header h1{font-size:32px}.terms-content{padding:35px 25px}.terms-section h2{font-size:20px}.terms-section p,.terms-section ul{margin-left:0}.terms-footer{padding:25px}}.educative-info-section{align-items:center;background:linear-gradient(135deg,#e6daf5,#d8bfd8 25%,#d1c4e9 50%,#f8bbd0 75%,#b57edc);box-sizing:border-box;display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;min-height:100vh;padding:4rem 2rem;width:100%}.educative-container{max-width:1200px;width:100%}.educative-header{margin-bottom:3rem;text-align:center}.educative-main-title{color:#6b3fa0;font-size:3rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px #0000001a}.educative-subtitle{color:#8b4fb8;font-size:1.5rem;font-weight:500}.educative-text-box-container{margin:2rem auto 0;max-width:800px}.educative-info-textarea{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-sizing:border-box;color:#5a3670;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1.125rem;height:auto;line-height:1.8;max-width:100%;min-height:120px;overflow-y:hidden;padding:24px;resize:none;transition:all .3s ease;width:100%}.educative-info-textarea:focus{border-color:#b57edc;box-shadow:0 12px 40px #b57edc4d;outline:none}.educative-info-textarea::placeholder{color:#a88bb8}@media (max-width:768px){.educative-main-title{font-size:2rem}.educative-subtitle{font-size:1.25rem}.educative-info-section{padding:1.5rem .5rem}.educative-container{max-width:100vw;padding:0 .5rem;width:100%}.educative-header{margin-bottom:2rem}.educative-text-box-container{margin-top:1rem;max-width:100vw;padding:0}.educative-info-textarea{border-radius:12px;box-shadow:0 4px 16px #b57edc26;box-sizing:border-box;font-size:.95rem;max-width:100%;padding:1rem}}@media (max-width:480px){.educative-main-title{font-size:1.3rem}.educative-subtitle{font-size:1rem}.educative-header{margin-bottom:1rem}.educative-info-section{padding:1rem .2rem}.educative-container{padding:0 .2rem}.educative-text-box-container{margin-top:.5rem;padding:0}.educative-info-textarea{border-radius:8px;box-shadow:0 2px 8px #b57edc1f;box-sizing:border-box;font-size:.85rem;max-width:100%;padding:.5rem}}.ciclii-loader-container{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:80px;width:100%}.ciclii-loader-spinner{animation:ciclii-spin 1s linear infinite;border:6px solid #e9d5ff;border-radius:50%;border-top-color:#a21caf;height:48px;margin-bottom:10px;width:48px}.ciclii-loader-text{color:#a21caf;font-size:1.1rem;font-weight:500;text-align:center}@keyframes ciclii-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (min-width:993px){.calendar-pin-icon{font-size:1.7em!important}}.calendar-day-number{left:10px!important;position:absolute;top:10px!important}@media (max-width:576px){.calendar-day-number{left:2px!important;top:2px!important}}@media (max-width:820px){.calendar-days-grid{grid-template-columns:repeat(7,minmax(0,1fr))}.calendar-day{aspect-ratio:1/1;aspect-ratio:unset;min-width:0;width:100%}}@media (max-width:400px){.calendar-container{max-width:100%;width:100%}.calendar-container,.calendar-days-grid{box-sizing:border-box;margin:0;padding:0}.calendar-days-grid{grid-gap:.5px;display:grid;gap:.5px;grid-template-columns:repeat(7,minmax(0,1fr))}.calendar-day{border-radius:1px;min-width:0;padding:0;width:100%}}@media (max-width:360px){.calendar-container{box-sizing:border-box;max-width:100vw;padding-left:0;padding-right:0}.calendar-days-grid{box-sizing:border-box;gap:.5px;grid-template-columns:repeat(7,minmax(0,1fr));max-width:100vw;width:100%}.calendar-day{border-radius:1px;font-size:.35em;min-height:8px;min-width:8px;padding:0}.calendar-day-icons{gap:.05px;min-height:1.5px;padding:0}.calendar-day-icons>span{font-size:.15em!important;height:2px;margin:0;width:2px}.calendar-days-grid{gap:1px;margin-bottom:10px;padding:0}.calendar-day{border-radius:1px;font-size:.5em;min-height:12px;min-width:12px;padding:0}.calendar-day-icons{gap:.1px;min-height:3px;padding:0}.calendar-day-icons>span{font-size:.3em!important;height:3px;margin:0;width:3px}}.calendar-container{background:#fff;border-radius:24px;box-shadow:0 20px 60px #b57edc4d;margin:20px auto;max-width:900px;padding:40px;width:100%}.calendar-day-icons{align-items:center;box-sizing:border-box;display:flex;gap:0;height:auto;justify-content:center;left:50%;padding:0;pointer-events:none;position:absolute;top:60%;transform:translate(-50%,-50%);width:auto;z-index:1}.calendar-day-icons>span{box-sizing:initial;font-size:1.15em!important;height:18px;width:18px}@media (max-width:600px){.calendar-day{border-radius:6px;font-size:.8em;min-height:28px;min-width:28px}.calendar-day-icons{gap:1px;min-height:12px;padding:0 .5px .5px}.calendar-day-icons>span{font-size:.8em!important;height:11px;margin:0 .5px;width:11px}}@media (max-width:400px){.calendar-day{border-radius:4px;font-size:.7em;min-height:22px;min-width:22px}.calendar-day-icons{gap:.5px;min-height:8px;padding:0 .2px .2px}.calendar-day-icons>span{font-size:.65em!important;height:8px;margin:0 .2px;width:8px}}@media (max-width:350px){.calendar-day{border-radius:2px;font-size:.6em;min-height:16px;min-width:16px}.calendar-day-icons{gap:.2px;min-height:5px;padding:0 .1px .1px}.calendar-day-icons>span{font-size:.45em!important;height:5px;margin:0 .1px;width:5px}}.calendar-info-section{background:linear-gradient(135deg,#e6daf5,#d1c4e9);border-radius:16px;margin-bottom:30px;padding:24px}.calendar-info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.calendar-info-card{background:#fff;border-radius:12px;padding:16px;text-align:center}.calendar-info-card label{color:#b57edc;display:block;font-size:.9em;font-weight:600;margin-bottom:8px}.calendar-info-card input{border:2px solid #d8bfd8;border-radius:8px;box-sizing:border-box;font-size:1em;padding:10px;text-align:center;width:100%}.calendar-info-card input:focus{border-color:#b57edc;outline:none}.calendar-info-display{background:#fff;border-radius:12px;padding:16px;text-align:center}.calendar-info-display h3{color:#b57edc;font-size:.9em;font-weight:600;margin:0 0 8px}.calendar-info-display p{color:#666;font-size:1.1em;font-weight:500;margin:0}.calendar-header{align-items:center;display:flex;gap:16px;justify-content:center;margin-bottom:24px}.calendar-nav-buttons-mobile{align-items:center;display:none;gap:16px}.calendar-nav-buttons{align-items:center;display:flex;gap:16px}.calendar-nav-button{background:#b57edc;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.2em;height:40px;transition:all .3s ease;width:40px}.calendar-nav-button:hover{background:#9b5fc4;transform:scale(1.1)}.calendar-month-title{color:#b57edc;font-size:1.5em;margin:0}.calendar-days-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);margin-bottom:30px}.calendar-day-header{color:#b57edc;font-size:.9em;font-weight:600;padding:12px;text-align:center}.calendar-day{align-items:center;aspect-ratio:1;background:#f8f8f8;border-radius:12px;color:#666;cursor:pointer;display:flex;flex-direction:column;font-weight:500;justify-content:center;min-height:50px;position:relative;transition:all .3s ease}@media (max-width:820px){.calendar-days-grid{grid-template-columns:repeat(7,minmax(0,1fr))}.calendar-day{aspect-ratio:1/1;min-width:0;width:100%}}.calendar-day:hover{box-shadow:0 4px 12px #b57edc4d;transform:scale(1.05)}.calendar-day.other-month{opacity:.3}.calendar-day.today{border:3px solid #b57edc;font-weight:700}.calendar-day.period{background:#b57edc;color:#fff}.calendar-day.fertile{background:#d1c4e9;color:#5e35b1}.calendar-day.ovulation{background:#f8bbd0;color:#c2185b}.calendar-day-number{font-size:1em;margin-bottom:2px}.calendar-event{align-items:center;background:#b57edce6;border-radius:4px;color:#fff;display:flex;font-size:.7em;justify-content:space-between;margin-top:2px;max-width:100%;overflow:hidden;padding:2px 6px;position:relative;text-overflow:ellipsis;white-space:nowrap}.calendar-event-delete{align-items:center;background:#fffc;border:none;border-radius:50%;color:#b57edc;cursor:pointer;display:flex;flex-shrink:0;font-size:10px;height:14px;justify-content:center;margin-left:4px;width:14px}.calendar-event-delete:hover{background:#fff}.calendar-legend{display:flex;flex-wrap:wrap;gap:24px;justify-content:center}.calendar-legend-item{align-items:center;display:flex;gap:8px}.calendar-legend-color{border-radius:6px;height:24px;width:24px}.calendar-legend-text{color:#666;font-size:.9em}.legend-period{background:#b57edc}.legend-fertile{background:#d1c4e9}.legend-ovulation{background:#f8bbd0}.legend-today{background:#f8f8f8;border:2px solid #b57edc}@media (max-width:768px){.calendar-container{border-radius:16px;margin:10px;padding:20px}.calendar-title{font-size:1.8em;text-align:center}.calendar-info-grid{grid-template-columns:1fr}.calendar-month-title{font-size:1.2em}.calendar-day-header{font-size:.8em;padding:8px}.calendar-day{min-height:40px}.calendar-day.today{box-sizing:border-box;min-height:34px;min-width:34px}.calendar-legend{gap:12px}.calendar-legend-item{gap:6px}.calendar-legend-text{font-size:.8em}}@media (max-width:480px){.calendar-container{margin:8px;padding:16px}.calendar-title{font-size:1.5em;text-align:center}.calendar-nav-button{font-size:1em;height:35px;width:35px}.calendar-month-title{font-size:1.1em}.calendar-days-grid{gap:3px;margin-bottom:25px}.calendar-day{border-radius:8px;min-height:35px}.calendar-day-header{font-size:.8em;padding:8px 4px}.calendar-day-number{font-size:.9em}.calendar-event{font-size:.6em;padding:1px 4px}.calendar-event-delete{font-size:8px;height:12px;width:12px}.calendar-legend{flex-direction:column;gap:8px}.calendar-legend-color{height:18px;width:18px}.calendar-header{gap:14px;margin-bottom:18px}}@media (max-width:400px){.calendar-container{border-radius:12px;box-sizing:border-box;margin:0;max-width:calc(100vw - 10px);padding:12px;width:100%}.calendar-title{font-size:1.3em;margin-bottom:8px;text-align:center}.calendar-nav-button{font-size:.9em;height:32px;width:32px}.calendar-nav-buttons{gap:12px}.calendar-month-title{font-size:1em}.calendar-header{gap:12px;margin-bottom:16px}.calendar-days-grid{gap:2px;margin-bottom:20px}.calendar-day{border-radius:6px;font-size:.85em;min-height:30px}.calendar-day-header{font-size:.7em;padding:6px 2px}.calendar-day-number{font-size:.85em}.calendar-legend{gap:6px;margin-top:16px}.calendar-legend-color{border-radius:4px;height:16px;width:16px}.calendar-legend-text{font-size:.7em}}@media (max-width:350px){.calendar-container{border-radius:10px;box-sizing:border-box;margin:0;max-width:calc(100vw - 6px);padding:10px;width:100%}.calendar-title{font-size:1.2em;margin-bottom:6px;text-align:center}.calendar-nav-button{font-size:.8em;height:28px;width:28px}.calendar-nav-buttons{gap:10px}.calendar-month-title{font-size:.95em}.calendar-header{gap:10px;margin-bottom:14px}.calendar-days-grid{gap:1px;margin-bottom:18px}.calendar-day{border-radius:5px;font-size:.8em;min-height:28px}.calendar-day-header{font-size:.65em;padding:5px 1px}.calendar-day-number{font-size:.75em}.calendar-legend{gap:4px;margin-top:14px}.calendar-legend-color{border-radius:3px;height:14px;width:14px}.calendar-legend-text{font-size:.65em}}.calendar-banner{align-items:center;display:flex;justify-content:center;text-align:center;width:100%}@media (max-width:300px){.calendar-container{border-radius:8px;box-sizing:border-box;margin:0;max-width:calc(100vw - 4px);padding:8px;width:100%}.calendar-title{font-size:1em;margin-bottom:4px;text-align:center}.calendar-banner-info{border-radius:6px;padding:4px 8px}.calendar-banner-info span{font-size:.7em}.calendar-info-section{border-radius:6px;margin-bottom:12px;padding:8px}.calendar-info-grid{gap:6px;margin-bottom:8px}.calendar-info-card{border-radius:4px;padding:6px}.calendar-info-card label{font-size:.7em;margin-bottom:4px}.calendar-info-display{border-radius:4px;padding:6px}.calendar-info-display h3{font-size:.7em;margin-bottom:4px}.calendar-info-display p{font-size:.9em}.calendar-nav-button{font-size:.7em;height:24px;width:24px}.calendar-nav-buttons{gap:8px}.calendar-month-title{font-size:.9em}.calendar-header{gap:8px;margin-bottom:8px}.calendar-days-grid{gap:.5px;margin-bottom:14px}.calendar-day{border-radius:3px;font-size:.7em;min-height:22px}.calendar-day-header{font-size:.6em;padding:3px .5px}.calendar-day-number{font-size:.7em}.calendar-legend{flex-direction:column;gap:3px;margin-top:12px}.calendar-legend-item{gap:2px;justify-content:center}.calendar-legend-color{border-radius:2px;height:12px;width:12px}.calendar-legend-text{font-size:.6em}}@media (max-width:768px){.calendar-container{border-radius:16px;margin:10px;padding:20px}.calendar-title{font-size:1.8em}.calendar-info-grid{grid-template-columns:1fr}.calendar-month-title{font-size:1.2em}.calendar-day-header{font-size:.8em;padding:8px}.calendar-day{min-height:40px}.calendar-legend{gap:12px}.calendar-legend-item{gap:6px}.calendar-legend-text{font-size:.8em}}@media (max-width:575px){.calendar-header{align-items:center;flex-direction:column;gap:16px;margin-bottom:20px}.calendar-month-title{margin:0;order:-1;text-align:center}.calendar-header>.calendar-nav-button{display:none}.calendar-nav-buttons-mobile{display:flex;gap:12px;order:1}}@keyframes dayPulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.calendar-day.clicked{animation:dayPulse .3s ease-in-out}.calendar-day:focus,.calendar-nav-button:focus{outline:2px solid #b57edc;outline-offset:2px}.calendar-event-delete:focus{outline:1px solid #b57edc;outline-offset:1px}.calendar-day,.calendar-event,.calendar-nav-button{transition:all .3s ease}.calendar-legend-item:hover .calendar-legend-color{transform:scale(1.1);transition:transform .2s ease}.calendar-day-icons>span{align-items:flex-end;background:none;box-sizing:border-box;display:flex;font-size:1.25em!important;height:22px;justify-content:center;margin:0 2px;max-height:22px;max-width:22px;width:22px}@media (max-width:600px){.calendar-day-icons{gap:3px;padding-bottom:3px}.calendar-day-icons>span{font-size:1em!important;height:16px;margin:0 1px;max-height:16px;max-width:16px;width:16px}}@media (max-width:400px){.calendar-day-icons{gap:2px;padding-bottom:2px}.calendar-day-icons>span{font-size:.9em!important;height:13px;margin:0 .5px;max-height:13px;max-width:13px;width:13px}}@media (max-width:600px){.calendar-days-grid{gap:3px}.calendar-day{border-radius:7px;font-size:.85em;min-height:32px}.calendar-day-icons>span{font-size:.95em!important;margin:0 1px;max-height:14px;max-width:14px}}.calendar-page{align-items:flex-start;background:linear-gradient(135deg,#e6daf5,#f8bbd0);box-sizing:border-box!important;display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;margin:0;min-height:100vh;padding:20px;width:100%}@media (max-width:768px){.calendar-page{align-items:flex-start;padding:10px!important;width:100%}}@media (max-width:480px){.calendar-page{padding:12px!important;width:100%}}@media (max-width:450px){.calendar-page{overflow-x:visible;padding:5px;width:100%}}@media (max-width:350px){.calendar-page{overflow-x:visible;padding:3px;width:100%}}@media (max-width:300px){.calendar-page{font-size:14px;overflow-x:visible;padding:2px;width:100%}}body,html{margin:0;padding:0}.calendar-page.fullscreen{bottom:0;left:0;overflow-y:auto;position:fixed;right:0;top:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Poppins;margin:0}
/*# sourceMappingURL=main.6d05260a.css.map*/