@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap);@import url(https://fonts.googleapis.com/icon?family=Material+Icons);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);:root{--pear:#bde524;--dartmouth-green:#00652f;--apple:#94db17}.navbar{align-items:center;animation:slideInTop .6s ease-out;background:linear-gradient(135deg,#94db17,#bde524);background:linear-gradient(135deg,var(--apple) 0,var(--pear) 100%);box-shadow:0 4px 20px #0000001a;display:flex;flex-wrap:wrap;font-size:1rem;justify-content:space-between;padding:1rem 2rem;position:relative}@keyframes slideInTop{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.navbar-logo img{filter:drop-shadow(2px 2px 4px rgba(0,0,0,.1));max-height:140px;padding-left:.5rem;transition:transform .3s ease}.navbar-logo{cursor:pointer;display:inline-block;text-decoration:none}.navbar-logo img:hover{transform:scale(1.05)}.navbar-toggle{background:none;border:none;border-radius:8px;color:#00652f;color:var(--dartmouth-green);cursor:pointer;display:none;font-size:2rem;padding:.5rem;transition:all .3s ease}.navbar-toggle:hover{background:#ffffff4d;transform:scale(1.1)}.navbar-toggle:active{transform:scale(.95)}.navbar-links{align-items:center;display:flex;gap:2.5rem;padding-right:1.5rem}.navbar-links a{color:#00652f;color:var(--dartmouth-green);font-size:1.3rem;font-weight:600;padding:.5rem 0;position:relative;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.navbar-links a:not(.btn-ingresar):after{background:linear-gradient(90deg,#94db17,#00652f);background:linear-gradient(90deg,var(--apple),var(--dartmouth-green));border-radius:2px;bottom:0;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);transition:width .3s ease;width:0}.navbar-links a:not(.btn-ingresar):hover{color:#00652f;color:var(--dartmouth-green);transform:translateY(-2px)}.navbar-links a:not(.btn-ingresar):hover:after{width:100%}.btn-ingresar{align-items:center;background:linear-gradient(135deg,#00652f,#004d24)!important;background:linear-gradient(135deg,var(--dartmouth-green) 0,#004d24 100%)!important;border:none;border-radius:50px!important;box-shadow:0 6px 20px #00652f40!important;color:var(--white)!important;cursor:pointer;display:inline-flex;font-size:1.2rem!important;font-weight:600!important;justify-content:center;letter-spacing:.5px;min-height:3rem;overflow:hidden;padding:.5rem 3.5rem!important;position:relative;text-align:center;text-decoration:none!important;transform:translateY(0)!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;white-space:nowrap}.btn-ingresar:hover{box-shadow:0 8px 30px #00652f59!important;transform:scale(1.05)!important}.btn-ingresar:after{display:none!important}.btn-ingresar:active{box-shadow:0 4px 15px #00652f4d!important;transform:scale(1)!important}@media (max-width:900px) and (min-width:768px){.navbar{padding:1rem 1.5rem}.navbar-toggle{display:block;font-size:2rem;padding:.5rem .8rem}.navbar-logo img{max-height:100px}.navbar-links{animation:slideInMenu .3s ease-out;display:none!important;flex-direction:column;gap:1rem;margin-top:1rem;padding:0 1rem;width:100%}@keyframes slideInMenu{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.navbar-links.active{display:flex!important}.navbar-links a{background:#ffffff26;border-radius:10px;font-size:1.3rem;padding:1rem;text-align:center;transition:all .3s ease;width:100%}.navbar-links a:not(.btn-ingresar):hover{background:#ffffff4d;transform:translateX(5px)}.navbar-links a:not(.btn-ingresar):after{display:none}.btn-ingresar{font-size:1.2rem!important;margin-top:.5rem;padding:1rem 2rem!important;width:100%}}@media (max-width:767px) and (min-width:540px){.navbar{padding:.8rem 1.2rem}.navbar-toggle{display:block;font-size:1.8rem;padding:.4rem .7rem}.navbar-logo{flex:1 1}.navbar-logo img{max-height:85px}.navbar-links{animation:slideInMenu .3s ease-out;display:none!important;flex-direction:column;gap:.9rem;margin-top:1rem;padding:0 .8rem;width:100%}.navbar-links.active{display:flex!important}.navbar-links a{background:#ffffff1f;border-radius:9px;font-size:1.2rem;padding:.9rem;text-align:center;transition:all .3s ease;width:100%}.navbar-links a:not(.btn-ingresar):hover{background:#ffffff4d;transform:translateX(5px)}.navbar-links a:not(.btn-ingresar):after{display:none}.btn-ingresar{font-size:1.15rem!important;margin-top:.5rem;padding:.95rem 1.8rem!important;width:100%}}@media (max-width:767px){.navbar{grid-gap:.3rem;align-items:center;display:grid;gap:.3rem;grid-template-columns:50px 1fr 50px;padding:.5rem .8rem}.navbar-toggle{font-size:1.8rem;grid-column:1;height:50px;padding:0;width:50px}.navbar-logo,.navbar-toggle{align-items:center;display:flex;justify-content:center}.navbar-logo{grid-column:2}.navbar-logo img{max-height:65px;max-width:100%;padding-left:0}.navbar-logo:hover img{transform:scale(1.05)}.navbar-links{animation:slideInMenu .3s ease-out;background:#ffffff0d;border-radius:12px;box-sizing:border-box;display:none!important;flex-direction:column;gap:.6rem;grid-column:1/-1;margin-top:.3rem;padding:.6rem;width:100%}.navbar-links.active{display:flex!important}.navbar-links a{background:#ffffff26;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:.75rem .5rem;text-align:center;transition:all .3s ease;width:100%}.navbar-links a:not(.btn-ingresar):hover{background:#ffffff4d;transform:translateX(5px)}.navbar-links a:not(.btn-ingresar):after{display:none}.btn-ingresar{box-sizing:border-box;font-size:1rem!important;margin-top:.2rem;padding:.75rem 1rem!important;width:100%}}@media (max-width:413px){.navbar{grid-template-columns:46px 1fr 46px;padding:.45rem .7rem}.navbar-toggle{font-size:1.6rem;height:46px;width:46px}.navbar-logo img{max-height:58px}.navbar-links{gap:.55rem;padding:.55rem}.navbar-links a{font-size:.95rem;padding:.7rem .4rem}.btn-ingresar{font-size:.95rem!important;padding:.7rem .9rem!important}}@media (max-width:360px){.navbar{grid-template-columns:42px 1fr 42px;padding:.4rem .6rem}.navbar-toggle{font-size:1.5rem;height:42px;width:42px}.navbar-logo img{max-height:52px}.navbar-links{gap:.5rem;padding:.5rem}.navbar-links a{font-size:.9rem;padding:.65rem .3rem}.btn-ingresar{font-size:.9rem!important;padding:.65rem .8rem!important}}@media (max-height:500px) and (orientation:landscape){.navbar{padding:.4rem .8rem}.navbar-logo img{max-height:45px}.navbar-toggle{font-size:1.3rem;height:36px;width:36px}.navbar-links{gap:.4rem;margin-top:.4rem;padding:.4rem .3rem}.navbar-links a{font-size:.9rem;padding:.6rem}.btn-ingresar{font-size:.9rem!important;padding:.6rem 1rem!important}}:root{--pear:#c0e428;--apple-green:#aad501}.footer{background:linear-gradient(135deg,#aad501,#c0e428);background:linear-gradient(135deg,var(--apple-green) 0,var(--pear) 100%);color:#31822f;color:var(--forest-green);overflow:hidden;padding:2rem 1rem;position:relative;text-align:center}.footer:before{animation:footerWave 3s ease-out forwards;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes footerWave{0%{opacity:1;transform:rotate(0deg)}to{opacity:.3;transform:rotate(180deg)}}.footer-social{font-size:1.1rem;font-weight:700;letter-spacing:1px;margin-bottom:1rem;position:relative;text-transform:uppercase;z-index:1}.footer-icons{display:flex;font-size:2rem;gap:2rem;justify-content:center;margin-bottom:1.5rem;position:relative;z-index:1}.footer-icons a{color:#20910e;color:var(--dartmouth-green);display:inline-block;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.footer-icons a:before{background:#fff;background:var(--white);border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .4s ease;width:0;z-index:-1}.footer-icons a:hover{color:#31822f;color:var(--forest-green);transform:translateY(-8px) scale(1.2) rotate(10deg)}.footer-icons a:hover:before{height:50px;width:50px}.footer-icons a:first-child:hover{color:#1877f2;filter:drop-shadow(0 5px 15px rgba(24,119,242,.5))}.footer-icons a:nth-child(2):hover{color:#000;filter:drop-shadow(0 5px 15px rgba(0,0,0,.5))}.footer-icons a:nth-child(3):hover{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#f09433,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 5px 15px rgba(188,24,136,.5))}.footer-icons a:nth-child(4):hover{color:#25d366;filter:drop-shadow(0 5px 15px rgba(37,211,102,.5))}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.footer-icons a:active{animation:bounce .6s}.footer-copy{color:#1a1a1a;color:var(--text-dark);font-size:.9rem;opacity:.8;position:relative;transition:opacity .3s ease;z-index:1}.footer-copy:hover{opacity:1}@media (max-width:768px){.footer-icons{font-size:1.8rem;gap:1.5rem}}@media (max-width:480px){.footer-icons{font-size:1.6rem;gap:1.2rem}.footer-social{font-size:1rem}}:root{--sb-top:#31822f;--sb-bottom:#00652f;--sb-hover:#ffffff0f;--sb-active:#dbe524}.sl-wrapper{background:linear-gradient(180deg,#31822f,#00652f);background:linear-gradient(180deg,var(--sb-top),var(--sb-bottom));color:#fff;color:var(--paper);display:flex;flex-direction:column;min-height:100dvh;position:-webkit-sticky;position:sticky;top:0;width:270px}.sl-head{border-bottom:1px solid #ffffff14;padding:18px 14px 12px;position:relative;text-align:center}.sl-logo{border-radius:50%;height:86px;object-fit:cover;width:86px}.sl-head h4{color:#fff;color:var(--paper);font-weight:800;margin:.5rem 0 0;opacity:.9}.sl-close{background:#e6f5c9;border:none;border-radius:8px;color:#064e2e;cursor:pointer;display:none;font-size:22px;height:34px;line-height:1;position:absolute;right:10px;top:10px;width:34px}.sl-nav{display:flex;flex-direction:column;gap:6px;padding:8px}.sl-item{align-items:center;border-radius:12px;color:#fff;color:var(--paper);display:flex;font-weight:600;gap:.9rem;padding:.82rem .9rem .82rem 1rem;position:relative;text-decoration:none;transition:background .15s ease,color .15s ease}.sl-item .sl-ico{height:28px;object-fit:contain;width:28px}.sl-item:before{background:#0000;border-radius:4px;content:"";height:calc(100% - 20px);left:8px;position:absolute;top:10px;transition:background .15s ease;width:4px}.sl-item:hover{background:#ffffff0f;background:var(--sb-hover)}.sl-item:hover:before{background:#dbe524;background:var(--pear)}.sl-item.active{background:#dbe524;background:var(--sb-active);box-shadow:inset 0 -2px 0 #b9d585}.sl-item.active,.sl-item.active span{color:#00652f;color:var(--dart)}.sl-item.active:before{background:#dbe524;background:var(--pear)}.sl-item:focus-visible{outline:2px solid #dbe524;outline:2px solid var(--pear);outline-offset:2px}@media (max-width:1024px){.sl-wrapper{inset:0 auto 0 0;position:fixed;transform:translateX(-100%);transition:transform .25s ease;z-index:1000}.sl-wrapper.open{transform:translateX(0)}.sl-close{align-items:center;display:inline-flex;justify-content:center}}@media (min-width:601px) and (max-width:1199px){.sl-nav{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);padding:14px}.sl-item{border-radius:12px;justify-content:center;padding:18px 12px;text-align:center}.sl-item .sl-ico{height:36px;width:36px}.sl-head{padding:14px}}.btn-logout{background-color:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;margin:1rem;padding:.75rem 1.2rem;transition:background-color .3s ease}.btn-logout:hover{background-color:#c82333}:root{--shadow:#0000001f}.tp-wrapper{display:none}@media (max-width:1024px){.tp-wrapper{display:block;inset:0 0 auto 0;position:fixed;z-index:1100}.tp-bar{align-items:center;background:#94bd17;background:var(--apple);box-shadow:0 1px 0 #0000001f;box-shadow:0 1px 0 var(--shadow);display:flex;gap:12px;height:72px;padding:0 14px}.tp-logo{border-radius:50%;height:58px;object-fit:cover;width:58px}.tp-burger{align-items:center;background:#00652f;background:var(--dart);border:none;border-radius:10px;color:#fff;color:var(--paper);cursor:pointer;display:inline-flex;height:44px;justify-content:center;margin-left:auto;width:44px}.tp-burger span{background:#fff;display:block;height:2px;margin:3px 0;transition:transform .2s,opacity .2s;width:22px}.tp-burger.is-open span:first-child{transform:translateY(5px) rotate(45deg)}.tp-burger.is-open span:nth-child(2){opacity:0}.tp-burger.is-open span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}.tp-panel{background:#00652f;background:var(--dart);box-shadow:0 6px 12px #0000001f;box-shadow:0 6px 12px var(--shadow);max-height:0;overflow:hidden;transition:max-height .25s ease}.tp-panel.open{max-height:70vh}.tp-nav{display:flex;flex-direction:column;gap:6px;padding:10px 12px 16px}.tp-item{align-items:center;background:#94bd17;background:var(--apple);border-radius:10px;color:#00652f;color:var(--dart);display:flex;font-weight:700;gap:12px;padding:12px 10px;text-decoration:none}.tp-item img{height:26px;object-fit:contain;width:26px}.tp-item:active{transform:translateY(1px)}.tp-item.active{background:#dbe524;background:var(--pear);box-shadow:inset 0 -2px 0 #b9d585e6;color:#00652f;color:var(--dart)}.tp-item.active img{filter:none}.tp-nav .tp-logout{align-items:center;background:#dc3545;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-weight:800;gap:12px;padding:12px 10px;text-decoration:none;width:100%}.tp-nav .tp-logout svg{flex:0 0 26px;height:26px;width:26px}.tp-nav .tp-logout span{color:#fff;font-weight:800}.tp-nav .tp-logout:active{transform:translateY(1px)}.tp-nav .tp-logout:hover{filter:brightness(.97)}}:root{--sidebar-w:270px}.private-layout{background:#f9f9f6;display:flex;min-height:100dvh}.sl-wrapper{flex:0 0 270px;flex:0 0 var(--sidebar-w);min-width:270px;min-width:var(--sidebar-w)}.private-content{flex:1 1 auto;height:100dvh;min-width:0;overflow:auto}.satl-shell{background:#f8f8f5;display:grid;grid-template-columns:270px 1fr;min-height:100dvh}.satl-aside{min-height:100dvh;position:-webkit-sticky;position:sticky;top:0;z-index:900}.satl-main{padding:24px 32px;position:relative}.satl-main-inner{margin:0 auto;max-width:1320px}.satl-toggle{background:#e7f3c8;border:none;border-radius:10px;box-shadow:0 2px 0 #c6dca3;cursor:pointer;display:none;height:42px;left:12px;position:fixed;top:12px;width:42px;z-index:1100}.satl-toggle span{background:#0a5a34;border-radius:2px;display:block;height:2px;margin:5px auto;width:22px}.satl-dim{display:none}.satl-shell.aside-open .satl-dim{background:#00000059;display:block;inset:0;position:fixed;z-index:950}@media (max-width:1199px){.satl-shell{grid-template-columns:1fr}.sl-wrapper{display:none!important}.private-content{height:calc(100dvh - 72px);overflow:auto;padding-top:72px}.satl-aside{background:#fff;background:var(--bg,#fff);box-shadow:0 6px 32px #0000002e;inset:0 auto 0 0;pointer-events:none;position:fixed;transform:translateX(-100%);transition:transform .26s cubic-bezier(.2,.9,.2,1);visibility:hidden;width:270px;will-change:transform;z-index:900}.satl-shell.aside-open .satl-aside{pointer-events:auto;transform:translateX(0);visibility:visible}.satl-shell.aside-open .satl-dim{background:#00000059;display:block;inset:0;position:fixed;z-index:950}.satl-toggle{z-index:1100}.satl-main{padding:18px 16px}.satl-toggle{display:inline-block}}.reminder-bubble{align-items:center;background:var(--paper);border:1px solid rgba(var(--black-rgb),.12);border-radius:999px;bottom:1.25rem;box-shadow:var(--shadow-hover);color:var(--dart);cursor:pointer;display:inline-flex;gap:.4rem;justify-content:center;padding:.6rem .8rem;position:fixed;right:1.25rem;transition:var(--transition);z-index:1000}.reminder-bubble:hover{border-color:var(--accent);box-shadow:0 .6rem 1.4rem rgba(var(--green-rgb),.16);transform:translateY(-1px)}.reminder-bubble .bell svg path{fill:var(--dart);stroke:none}.reminder-bubble .badge{background:rgba(var(--green-rgb),.35);border:1px solid rgba(var(--green-rgb),.45);border-radius:999px;color:var(--paper);display:inline-grid;font-size:.82rem;font-weight:700;height:1.4rem;min-width:1.4rem;padding:0 .35rem;place-items:center;transition:var(--transition)}.reminder-bubble.active .badge.show{animation:pulse 1.4s ease-in-out infinite;background:var(--dart);border-color:var(--dart)}@media (max-width:480px){.reminder-bubble{bottom:.9rem;padding:.55rem .7rem;right:.9rem}}@font-face{font-family:swiper-icons;font-style:normal;font-weight:400;src:url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA")}:root{--swiper-theme-color:#007aff}:host{display:block;margin-left:auto;margin-right:auto;position:relative;z-index:1}.swiper{display:block;list-style:none;margin-left:auto;margin-right:auto;overflow:hidden;padding:0;position:relative;z-index:1}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{box-sizing:initial;display:flex;height:100%;position:relative;transition-property:transform;transition-timing-function:ease;transition-timing-function:var(--swiper-wrapper-transition-timing-function,initial);width:100%;z-index:1}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{display:block;flex-shrink:0;height:100%;position:relative;transition-property:transform;width:100%}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-cube-shadow,.swiper-3d .swiper-slide{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{-ms-overflow-style:none;overflow:auto;scrollbar-width:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{-webkit-margin-start:var(--swiper-centered-offset-before);margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{-webkit-margin-before:var(--swiper-centered-offset-before);margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{height:var(--swiper-centered-offset-after);min-width:1px;width:100%}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-bottom,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(270deg,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(90deg,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(0deg,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(180deg,#00000080,#0000)}.swiper-lazy-preloader{border:4px solid #007aff;border:4px solid var(--swiper-preloader-color,var(--swiper-theme-color));border-radius:50%;border-top:4px solid #0000;box-sizing:border-box;height:42px;left:50%;margin-left:-21px;margin-top:-21px;position:absolute;top:50%;transform-origin:50%;width:42px;z-index:10}.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader{animation:swiper-preloader-spin 1s linear infinite}.swiper-lazy-preloader-white{--swiper-preloader-color:#fff}.swiper-lazy-preloader-black{--swiper-preloader-color:#000}@keyframes swiper-preloader-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.swiper-container{border-radius:1rem;margin:2rem auto;max-width:1000px;overflow:hidden;padding:0 2rem}.swiper-img{box-shadow:0 4px 12px #0000001a;height:220px;transition:transform .5s ease-in-out}@media (max-width:768px){.swiper-img{height:180px}}@media (max-width:480px){.swiper-img{height:160px}}.home-page{align-items:center;animation:fadeIn .8s ease-in-out;display:flex;flex-direction:column;margin-bottom:2rem;padding:0 .5rem;text-align:center}.bienvenida{animation:slideDown 1s ease-out;background:linear-gradient(135deg,#20910e,#31822f);background:linear-gradient(135deg,var(--dartmouth-green) 0,var(--forest-green) 100%);color:#fff;color:var(--white);overflow:hidden;padding:3rem 1rem;position:relative;width:100%}.bienvenida:before{animation:wave 3s ease-out forwards;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes wave{0%{opacity:1;transform:rotate(0deg)}to{opacity:.3;transform:rotate(180deg)}}.bienvenida h1{animation:textGlow 2s ease-in-out infinite alternate;font-size:3rem;position:relative;text-shadow:2px 2px 8px #0000004d;z-index:1}@keyframes textGlow{0%{text-shadow:2px 2px 8px #0000004d}to{text-shadow:2px 2px 20px #ffffff80}}.bienvenida p{font-size:1.5rem;position:relative;z-index:1}.recuadro-carrusel{animation:slideUp 1s ease-out .3s backwards;background:#fff;background:var(--bgcard);border-radius:1.5rem;box-shadow:0 10px 30px #0000001a,15px 15px 0 #f0ecd0;box-shadow:0 10px 30px #0000001a,15px 15px 0 var(--shadow);margin-bottom:3rem;margin-top:2rem;max-width:1100px;overflow:hidden;padding:2.5rem;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);width:100%}.recuadro-carrusel:before{background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .7s;width:100%}.recuadro-carrusel:hover{box-shadow:0 20px 40px #00000026,20px 20px 0 #f0ecd0;box-shadow:0 20px 40px #00000026,20px 20px 0 var(--shadow);transform:translateY(-10px)}.recuadro-carrusel:hover:before{left:100%}.recuadro-carrusel h2{color:#31822f;color:var(--forest-green);display:inline-block;font-size:2rem;margin-bottom:.5rem;position:relative}.recuadro-carrusel h2:after{background:linear-gradient(90deg,#dbe524,#acd401);background:linear-gradient(90deg,var(--pear),var(--apple-green));border-radius:2px;bottom:-5px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);transition:width .5s ease;width:0}.recuadro-carrusel:hover h2:after{width:100%}.recuadro-carrusel p{animation:fadeIn 1s ease-out .5s backwards;color:#1a1a1a;color:var(--text-dark);font-size:1rem;margin-bottom:1.5rem;padding:0 1rem}.swiper-container{box-sizing:border-box;padding:0 .5rem;width:100%}.swiper-slide{align-items:center;display:flex;justify-content:center}.swiper-img{border-radius:1rem;box-shadow:0 8px 16px #0003;cursor:pointer;height:300px;max-width:300px;object-fit:cover;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);width:100%}.swiper-img:before{background:linear-gradient(135deg,#20910e4d,#31822f4d);border-radius:1rem;content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .4s;width:100%}.swiper-img:hover{box-shadow:0 15px 35px #0000004d;transform:scale(1.08) rotate(2deg)}.swiper-img:hover:before{opacity:1}.swiper-pagination-bullet{background:#1a1a1a;background:var(--text-dark);height:12px;opacity:.5;transition:all .3s ease;width:12px}.swiper-pagination-bullet:hover{opacity:.8;transform:scale(1.2)}.swiper-pagination-bullet-active{background:#31822f;background:var(--forest-green);border-radius:6px;opacity:1;width:30px}.btn-ingresar,.nav-links a:last-child,button{overflow:hidden;position:relative;transition:all .3s ease}.btn-ingresar:before,button:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn-ingresar:hover:before,button:hover:before{height:300px;width:300px}.btn-ingresar:hover,button:hover{box-shadow:0 8px 20px #0003;transform:translateY(-3px)}.btn-ingresar:active,button:active{box-shadow:0 4px 10px #0003;transform:translateY(-1px)}@media (min-width:1920px){.bienvenida h1{font-size:4rem}.bienvenida p{font-size:1.8rem}.recuadro-carrusel{max-width:1400px;padding:3.5rem}.recuadro-carrusel h2{font-size:2.5rem}.recuadro-carrusel p{font-size:1.3rem}.swiper-img{height:400px;max-width:400px}}@media (max-width:1919px) and (min-width:1440px){.bienvenida h1{font-size:3.5rem}.bienvenida p{font-size:1.6rem}.recuadro-carrusel{max-width:1200px;padding:3rem}.recuadro-carrusel h2{font-size:2.2rem}.swiper-img{height:350px;max-width:350px}}@media (max-width:1439px) and (min-width:1024px){.home-page{padding:0 1rem}.bienvenida{padding:2.5rem 1.5rem}.bienvenida h1{font-size:2.8rem}.bienvenida p{font-size:1.4rem}.recuadro-carrusel{margin:2rem auto;max-width:950px;padding:2.5rem 2rem}.recuadro-carrusel h2{font-size:2rem}.recuadro-carrusel p{font-size:1.1rem}.swiper-img{height:300px;max-width:300px}}@media (max-width:1023px) and (min-width:820px){.home-page{padding:0 1rem}.bienvenida{padding:2.5rem 1.5rem}.bienvenida h1{font-size:2.5rem}.bienvenida p{font-size:1.3rem}.recuadro-carrusel{box-shadow:0 8px 25px #0000001a,12px 12px 0 #f0ecd0;box-shadow:0 8px 25px #0000001a,12px 12px 0 var(--shadow);margin:2rem 1rem;max-width:750px;padding:2rem 1.5rem}.recuadro-carrusel h2{font-size:1.8rem}.recuadro-carrusel p{font-size:1rem;padding:0 .5rem}.swiper-img{height:280px;max-width:280px}}@media (max-width:819px) and (min-width:768px){.home-page{padding:0 1rem}.bienvenida{padding:2rem 1.5rem}.bienvenida h1{font-size:2.3rem}.bienvenida p{font-size:1.2rem}.recuadro-carrusel{box-shadow:0 8px 20px #0000001a,10px 10px 0 #f0ecd0;box-shadow:0 8px 20px #0000001a,10px 10px 0 var(--shadow);margin:1.5rem 1rem;max-width:700px;padding:2rem 1.5rem}.recuadro-carrusel h2{font-size:1.7rem}.recuadro-carrusel p{font-size:1rem}.swiper-img{height:260px;max-width:260px}}@media (max-width:767px) and (min-width:540px){.home-page{padding:0 .75rem}.bienvenida{padding:2rem 1rem}.bienvenida h1{font-size:2rem}.bienvenida p{font-size:1.1rem}.recuadro-carrusel{box-shadow:0 6px 18px #0000001a,8px 8px 0 #f0ecd0;box-shadow:0 6px 18px #0000001a,8px 8px 0 var(--shadow);margin:1.5rem .75rem;padding:1.5rem 1rem}.recuadro-carrusel h2{font-size:1.5rem}.recuadro-carrusel p{font-size:.95rem;padding:0 .5rem}.swiper-img{height:240px;max-width:240px}}@media (max-width:539px) and (min-width:414px){.home-page{padding:0 .5rem}.bienvenida{padding:1.8rem 1rem}.bienvenida h1{font-size:1.8rem;line-height:1.3}.bienvenida p{font-size:1rem}.recuadro-carrusel{border-radius:1.2rem;box-shadow:0 5px 15px #0000001a,6px 6px 0 #f0ecd0;box-shadow:0 5px 15px #0000001a,6px 6px 0 var(--shadow);margin:1.3rem .5rem;padding:1.3rem .8rem}.recuadro-carrusel h2{font-size:1.4rem;margin-bottom:.4rem}.recuadro-carrusel p{font-size:.9rem;margin-bottom:1.2rem;padding:0 .3rem}.swiper-img{border-radius:.8rem;height:220px;max-width:220px}.swiper-pagination-bullet{height:10px;width:10px}.swiper-pagination-bullet-active{width:25px}}@media (max-width:413px) and (min-width:390px){.home-page{margin-bottom:1.5rem;padding:0 .5rem}.bienvenida{padding:1.6rem .8rem}.bienvenida h1{font-size:1.7rem;line-height:1.3}.bienvenida p{font-size:.95rem}.recuadro-carrusel{border-radius:1rem;box-shadow:0 4px 12px #0000001a,5px 5px 0 #f0ecd0;box-shadow:0 4px 12px #0000001a,5px 5px 0 var(--shadow);margin:1.2rem .5rem;padding:1.2rem .8rem}.recuadro-carrusel:hover{box-shadow:0 15px 30px #0000001f,8px 8px 0 #f0ecd0;box-shadow:0 15px 30px #0000001f,8px 8px 0 var(--shadow);transform:translateY(-5px)}.recuadro-carrusel h2{font-size:1.35rem;margin-bottom:.4rem}.recuadro-carrusel p{font-size:.88rem;margin-bottom:1rem;padding:0 .3rem}.swiper-img{border-radius:.8rem;height:200px;max-width:200px}}@media (max-width:389px) and (min-width:360px){.home-page{margin-bottom:1.2rem;padding:0 .4rem}.bienvenida{padding:1.5rem .8rem}.bienvenida h1{font-size:1.6rem;line-height:1.2}.bienvenida p{font-size:.9rem}.recuadro-carrusel{border-radius:1rem;box-shadow:0 4px 10px #0000001a,4px 4px 0 #f0ecd0;box-shadow:0 4px 10px #0000001a,4px 4px 0 var(--shadow);margin:1rem .4rem;padding:1rem .7rem}.recuadro-carrusel:hover{box-shadow:0 12px 25px #0000001f,6px 6px 0 #f0ecd0;box-shadow:0 12px 25px #0000001f,6px 6px 0 var(--shadow);transform:translateY(-4px)}.recuadro-carrusel h2{font-size:1.3rem;margin-bottom:.3rem}.recuadro-carrusel p{font-size:.85rem;margin-bottom:1rem;padding:0 .2rem}.swiper-img{border-radius:.7rem;height:190px;max-width:190px}.swiper-pagination-bullet{height:8px;width:8px}.swiper-pagination-bullet-active{width:22px}}@media (max-width:359px){.home-page{margin-bottom:1rem;padding:0 .3rem}.bienvenida{padding:1.2rem .6rem}.bienvenida h1{font-size:1.4rem;line-height:1.2}.bienvenida p{font-size:.85rem}.recuadro-carrusel{border-radius:.8rem;box-shadow:0 3px 8px #0000001a,3px 3px 0 #f0ecd0;box-shadow:0 3px 8px #0000001a,3px 3px 0 var(--shadow);margin:.8rem .3rem;padding:.9rem .6rem}.recuadro-carrusel:hover{box-shadow:0 10px 20px #0000001f,5px 5px 0 #f0ecd0;box-shadow:0 10px 20px #0000001f,5px 5px 0 var(--shadow);transform:translateY(-3px)}.recuadro-carrusel h2{font-size:1.2rem;margin-bottom:.3rem}.recuadro-carrusel p{font-size:.8rem;line-height:1.3;margin-bottom:.8rem;padding:0 .2rem}.swiper-img{border-radius:.6rem;height:170px;max-width:170px}.swiper-pagination-bullet{height:7px;width:7px}.swiper-pagination-bullet-active{width:20px}}@media (max-height:500px) and (orientation:landscape){.bienvenida{padding:1rem}.bienvenida h1{font-size:1.5rem}.bienvenida p{font-size:.9rem}.recuadro-carrusel{margin:1rem .5rem;padding:1rem}.recuadro-carrusel h2{font-size:1.2rem}.recuadro-carrusel p{font-size:.85rem;margin-bottom:.8rem}.swiper-img{height:150px;max-width:200px}}.conocenos-page{animation:fadeIn .8s ease;min-height:100vh;overflow-x:hidden;padding:0}.conocenos-page h1{background-color:#20910e;background-color:var(--dartmouth-green);color:#fff;color:var(--white);font-size:2rem;padding:1rem;text-align:center}.conocenos-grid{flex-direction:column;margin:2rem auto;max-width:1200px;padding:0 2rem 2rem}.conocenos-grid,.seccion{box-sizing:border-box;display:flex;gap:2.5rem;width:100%}.seccion{align-items:center;background-color:var(--bgcard);border-radius:16px;box-shadow:6px 6px 0 #f0ecd0;box-shadow:6px 6px 0 var(--shadow);overflow:visible;padding:2.5rem;position:relative;transition:transform .3s ease,box-shadow .3s ease}.seccion:hover{box-shadow:9px 9px 0 #f0ecd0;box-shadow:9px 9px 0 var(--shadow);transform:translateY(-3px)}.seccion-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.seccion-icon .material-icons{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#acd401,#20910e);background:linear-gradient(135deg,var(--apple-green) 0,var(--dartmouth-green) 100%);-webkit-background-clip:text;background-clip:text;font-size:6rem}.seccion-content{display:flex;flex:1 1;flex-direction:column;gap:1rem;min-width:0}.seccion-header{align-items:center;border-bottom:2px solid #c5e1a5;border-bottom:2px solid var(--bg-card);display:flex;gap:0;margin-bottom:0;padding-bottom:1rem}.seccion-header .material-icons{display:none}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.seccion h2{font-size:2rem;margin:0}.seccion p{word-wrap:break-word;color:#1a1a1a;color:var(--text-dark);font-size:1.1rem;line-height:1.8;margin:0;overflow-wrap:break-word;text-align:justify}@media (max-width:768px){.conocenos-page h1{font-size:1.8rem;margin-bottom:1.5rem;padding:1rem}.conocenos-grid{gap:1.5rem;max-width:100%;padding:0 1rem 2rem}.seccion{align-items:center;flex-direction:column;padding:1.5rem;text-align:center}.seccion-icon .material-icons{font-size:4rem}.seccion-content{width:100%}.seccion-header{justify-content:center}.seccion h2{font-size:1.6rem}.seccion p{font-size:1rem;text-align:center}}:root{--apple-green:##acd401}.sucursal{align-items:center;background-color:#fff;background-color:var(--bgcard);border-radius:12px;box-shadow:10px 10px 0 #f0ecd0;box-shadow:10px 10px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;margin:1rem auto;max-width:600px;padding:1.5rem}.sucursal-img-btn{background:none;border:none;cursor:pointer;outline:none;padding:0}.sucursal img{border:none;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:block;filter:brightness(1) saturate(1.05);transition:all .3s ease;width:200px}.sucursal img:hover{box-shadow:0 6px 16px #00000026;filter:brightness(1.05) saturate(1.1);transform:scale(1.03)}.sucursal a{color:#20910e;color:var(--dartmouth-green);font-weight:700;text-decoration:none}.sucursal a:hover{text-decoration:underline}.establecimiento{align-items:stretch;background-color:#fff;background-color:var(--bgcard);border-radius:16px;box-shadow:0 4px 12px #00000014,6px 6px 0 #f0ecd0;box-shadow:0 4px 12px #00000014,6px 6px 0 var(--shadow);display:flex;gap:1.5rem;justify-content:space-between;margin:1rem auto;max-width:90%;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.establecimiento:before{background:linear-gradient(90deg,#20910e,#dbe524,#20910e);background:linear-gradient(90deg,var(--dartmouth-green),var(--pear),var(--dartmouth-green));content:"";height:4px;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.establecimiento:hover{box-shadow:0 8px 24px #0000001f,8px 8px 0 #f0ecd0;box-shadow:0 8px 24px #0000001f,8px 8px 0 var(--shadow);transform:translateY(-4px)}.establecimiento:hover:before{opacity:1}.establecimiento-info{display:flex;flex-direction:column;justify-content:center;text-align:left;width:60%}.establecimiento-info h2{color:#31822f;color:var(--forest-green);font-size:1.8rem;font-weight:700;margin-bottom:.5rem;margin-top:0}.establecimiento-info p{color:#1a1a1a;color:var(--text-dark);line-height:1.6;margin:.3rem 0}.establecimiento-info strong{color:#20910e;color:var(--dartmouth-green);font-weight:600}.establecimiento-imagen{align-items:center;background:#0000;border-radius:12px;display:flex;justify-content:center;overflow:hidden;padding:0;position:relative;width:35%}.establecimiento-imagen img{border:none;border-radius:12px;box-shadow:0 4px 12px #0000001a;filter:brightness(1) saturate(1.05);height:auto;max-height:200px;min-height:160px;object-fit:cover;transition:all .3s ease;width:100%}.establecimiento-imagen img:hover{box-shadow:0 6px 16px #00000026;filter:brightness(1.05) saturate(1.1);transform:scale(1.03)}.establecimientos-page{text-align:center}.establecimientos-page h1{background-color:#20910e;background-color:var(--dartmouth-green);color:#fff;color:var(--white);font-size:2rem;padding:1rem}.sucursal h2{color:#31822f;color:var(--forest-green);margin-bottom:.5rem;margin-top:0}@media (max-width:768px){.establecimiento{flex-direction:column;gap:1rem;padding:1.2rem}.establecimiento-info{text-align:center;width:100%}.establecimiento-info h2{font-size:1.5rem}.establecimiento-imagen{padding:.3rem;width:100%}.establecimiento-imagen img{max-height:220px;min-height:180px}.sucursal{flex-direction:column;text-align:center}.sucursal img{max-width:300px;width:100%}}@media (max-width:480px){.establecimiento{margin:.8rem auto;padding:1rem}.establecimiento-info h2{font-size:1.3rem}.establecimiento-imagen img{max-height:200px;min-height:160px}.establecimientos-page h1{font-size:1.6rem;padding:.8rem}}.modal-overlay{animation:fadeIn .3s ease;background-color:#000000d9;padding:1rem;z-index:1000}.modal-content{animation:slideUp .3s ease;background:#fff;background:var(--white);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:900px;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{align-items:center;background:#ffffffe6;border:none;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#1a1a1a;color:var(--text-dark);cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:40px;z-index:10}.modal-close:hover{background:#20910e;background:var(--dartmouth-green);box-shadow:0 4px 12px #00000040;color:#fff;color:var(--white);transform:rotate(90deg)}.modal-title{border-bottom:3px solid #dbe524;border-bottom:3px solid var(--pear);color:#31822f;color:var(--forest-green);font-size:2rem;font-weight:700;margin:0;padding:2rem 3rem 1rem;text-align:center}.modal-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));padding:2rem}.modal-grid img{border-radius:12px;box-shadow:0 4px 12px #0000001a;cursor:pointer;height:auto;max-height:400px;min-height:200px;object-fit:cover;transition:all .3s ease;width:100%}.modal-grid img:hover{box-shadow:0 8px 24px #0003;transform:scale(1.05)}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.modal-content::-webkit-scrollbar-thumb{background:#20910e;background:var(--dartmouth-green);border-radius:10px}.modal-content::-webkit-scrollbar-thumb:hover{background:#31822f;background:var(--forest-green)}@media (max-width:768px){.modal-overlay{padding:.5rem}.modal-content{border-radius:12px;max-height:95vh}.modal-title{font-size:1.5rem;padding:1.5rem 1rem .8rem}.modal-grid{gap:1rem;grid-template-columns:1fr;padding:1rem}.modal-grid img{max-height:300px;min-height:180px}.modal-close{font-size:1.3rem;height:36px;right:.5rem;top:.5rem;width:36px}}@media (max-width:480px){.modal-title{font-size:1.3rem;padding:1.2rem .8rem .6rem}.modal-grid{padding:.8rem}.modal-grid img{max-height:250px;min-height:150px}}.login-container{align-items:center;background-color:#cade8b;box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;padding:1rem;width:100%}.login-card{animation:fadeIn .8s ease;background-color:#fff;background-color:var(--white);border-radius:1rem;box-shadow:0 8px 16px #1a1a1a;box-shadow:0 8px 16px var(--text-dark);max-width:400px;padding:2rem;text-align:center;width:100%}.login-logo{height:auto;margin-bottom:.5rem;width:400px}.login-card h2{margin-bottom:1rem}.login-card h2,label{color:#20910e;color:var(--dartmouth-green)}.login-card form{display:flex;flex-direction:column;gap:1rem}.login-card input{border:1px solid #1a1a1a;border:1px solid var(--text-dark);border-radius:.75rem;font-size:1rem;padding:.75rem}.login-card button{background-color:#dbe524;background-color:var(--pear);border:none;border-radius:.75rem;color:#31822f;color:var(--forest-green);cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem;transition:background-color .3s ease}.login-card button:hover{background-color:#20910e;background-color:var(--dartmouth-green);color:#fff;color:var(--white)}@media (max-width:500px){.login-card{padding:1.5rem}.login-logo{max-width:300px}.login-card h2{font-size:1.25rem}}.login-error{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:.5rem;color:#dc3545;padding:.5rem}.error-message,.login-error{font-size:.9rem;margin-top:.5rem}.error-message{color:red}:root{--black-rgb:26 26 26;--navbar-height:4rem;--hero-offset:0.75rem;--accent:var(--apple);--accent-strong:#2f7a2f;--focus-ring:rgba(var(--green-rgb),0.18)}.satl-home{background:linear-gradient(135deg,(var(--bg)) 0,(var(--bg)) 100%);background-attachment:fixed;box-sizing:border-box;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100dvh;padding:clamp(1.5rem,3vw,3rem);position:relative}.satl-home:before{animation:floatBackground 20s ease-in-out infinite;background-image:radial-gradient(circle at 25% 25%,rgba(var(--pear-rgb),.04) 0,#0000 30%),radial-gradient(circle at 75% 75%,rgba(var(--green-rgb),.04) 0,#0000 30%),radial-gradient(circle at 50% 10%,rgba(var(--apple-rgb),.02) 0,#0000 20%);background-position:0 0,100% 100%,50% 0;background-size:50rem 50rem,37.5rem 37.5rem,25rem 25rem;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}@keyframes floatBackground{0%,to{transform:translate(0) rotate(0deg)}33%{transform:translate(.625rem,-.625rem) rotate(1deg)}66%{transform:translate(-.3125rem,.3125rem) rotate(-.5deg)}}.satl-home>*{position:relative;z-index:1}.satl-hero{margin-bottom:clamp(1.25rem,4vw,4rem);margin-left:auto;margin-right:auto;max-width:800px;padding-top:calc(var(--navbar-height) + var(--hero-offset));position:relative;text-align:center}.satl-hero h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--dart) 0,var(--forest) 100%);-webkit-background-clip:text;background-clip:text;color:var(--dart);font-size:clamp(2rem,4vw,3.5rem);font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:0 0 1rem}.satl-hero p{color:var(--forest);font-size:clamp(1.1rem,2vw,1.3rem);font-weight:400;line-height:1.6;margin:0;opacity:.8}.satl-grid{--col:clamp(17.5rem,28vw,22.5rem);--gap:clamp(1.25rem,3vw,2.25rem);grid-gap:var(--gap);align-items:stretch;animation:fadeInUp .6s ease-out,fadeIn .8s ease-out .2s forwards;display:grid;gap:var(--gap);grid-auto-rows:auto;grid-template-columns:repeat(auto-fit,minmax(var(--col),1fr));justify-items:center;margin:0 auto;max-width:1400px;opacity:0;width:100%}.satl-grid .card-mod{align-items:center;display:flex;flex-direction:column;justify-content:center;margin:0 auto;max-width:none;text-align:center;width:100%}.satl-grid .card-mod img,.satl-grid .card-mod span{margin-left:auto;margin-right:auto}.card-mod:first-child{animation-delay:.1s}.card-mod:nth-child(2){animation-delay:.2s}.card-mod:nth-child(3){animation-delay:.3s}.card-mod:nth-child(4){animation-delay:.4s}.card-mod:nth-child(5){animation-delay:.5s}.card-mod:nth-child(6){animation-delay:.6s}.card-mod:nth-child(7){animation-delay:.7s}.card-mod{align-items:center;animation:fadeInUp .6s ease-out both;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card-gradient);border:none;border:1px solid rgba(var(--white-rgb),.2);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;gap:1rem;overflow:hidden;padding:clamp(1.5rem,2.5vw,2rem);position:relative;transition:var(--transition);width:100%}.card-mod:before{background:linear-gradient(90deg,#0000,rgba(var(--white-rgb),.4),#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.card-mod img{filter:drop-shadow(0 .15rem .4rem rgba(var(--green-rgb),.08));height:clamp(2.5rem,4.5vw,3.5rem);max-height:3.5rem;max-width:3.5rem;object-fit:contain;transition:var(--transition);width:clamp(2.5rem,4.5vw,3.5rem)}.card-mod span{color:var(--dart);font-size:clamp(1.1rem,1.3vw,1.4rem);font-weight:600;letter-spacing:-.01em;line-height:1.3;text-align:center;transition:transform .32s cubic-bezier(.2,.8,.2,1),color .25s ease}.card-mod:hover{background:var(--card-hover-gradient);box-shadow:var(--shadow-hover);perspective:50rem;transform:translateY(-.35rem) scale(1.02) rotateX(1.5deg);transform-style:preserve-3d}.card-mod:hover img{transform:translateZ(.6rem) scale(1.06) rotate(-2deg);transition:transform .35s cubic-bezier(.2,.8,.2,1)}.card-mod:active{transform:translateY(-.125rem) scale(1.01) rotateX(1deg);transition:transform .12s ease}.card-mod:focus{box-shadow:var(--shadow-hover),0 0 0 3px rgba(var(--green-rgb),.3);outline:none}@media (max-width:1200px){.satl-grid{--gap:clamp(18px,2.5vw,28px);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (min-width:1200px){.satl-grid{--gap:clamp(1.5rem,2.5vw,3rem);grid-template-columns:repeat(3,minmax(20rem,1fr));max-width:1400px;padding:0 1.5rem;row-gap:clamp(2rem,3vw,3.5rem)}.card-mod{border-radius:1rem;min-height:8.25rem;padding:clamp(2rem,2.2vw,2.6rem)}.card-mod img{height:clamp(3.25rem,4vw,4rem);width:clamp(3.25rem,4vw,4rem)}.card-mod span{font-size:clamp(1.15rem,1.1vw,1.2rem)}}@media (max-width:768px){.satl-grid{--gap:1.25rem;grid-template-columns:1fr;max-width:100%;padding-left:.75rem;padding-right:.75rem}.satl-home{padding:clamp(16px,4vw,24px)}.satl-hero{margin-bottom:clamp(24px,6vw,40px)}.satl-hero h1{font-size:clamp(1.8rem,6vw,2.5rem)}.satl-hero p{font-size:clamp(1rem,3vw,1.2rem)}}@media (max-width:480px){.card-mod{--col:100%;max-width:20rem;padding:clamp(1.2rem,4vw,1.8rem)}.card-mod img{height:clamp(48px,8vw,64px);width:clamp(48px,8vw,64px)}.card-mod span{font-size:clamp(1rem,4vw,1.3rem)}}@media (min-width:601px) and (max-width:1199px){.satl-home{padding:clamp(1rem,3vw,2rem)}.satl-hero{--navbar-height:4.25rem;--hero-offset:1rem;margin-bottom:clamp(1rem,3vw,2.5rem)}.satl-hero h1{font-size:clamp(1.6rem,3.2vw,2.6rem);line-height:1.15;margin-bottom:.6rem}.satl-hero p{font-size:clamp(.95rem,1.6vw,1.05rem);margin:.25rem auto 0;max-width:60ch}.satl-grid{--gap:clamp(1rem,2.2vw,1.5rem);grid-template-columns:repeat(2,minmax(16rem,1fr));max-width:100%;padding:0 .75rem;row-gap:clamp(1.75rem,2.5vw,2.75rem)}.card-mod{border-radius:1rem;max-width:none;min-height:7rem;padding:clamp(1.25rem,2.2vw,1.75rem);width:100%}.card-mod img{height:clamp(2.5rem,3.8vw,3.25rem);width:clamp(2.5rem,3.8vw,3.25rem)}.card-mod span{font-size:clamp(1rem,1.6vw,1.15rem)}.navbar,.topbar{z-index:60}}@media (max-width:600px){.satl-home{padding:clamp(1rem,4vw,1.5rem)}.satl-hero h1{font-size:clamp(1.3rem,6.5vw,1.9rem);line-height:1.15}.satl-hero p{font-size:.95rem}.satl-grid{--gap:0.9rem;grid-template-columns:1fr;max-width:28rem;padding:0}.satl-hero{--navbar-height:3.5rem;--hero-offset:0.8rem;margin-bottom:1rem}.card-mod{align-items:center;border-radius:.9rem;max-width:100%;min-height:64px;padding:1.2rem 1.25rem;text-align:center;width:100%}.card-mod img{height:2.25rem;width:2.25rem}.card-mod span{font-size:1.05rem}.navbar{padding:.35rem .6rem}.navbar-logo img{max-width:40px}.navbar-links{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}}@media (max-width:360px){.satl-hero h1{font-size:clamp(1.1rem,8vw,1.6rem)}.satl-hero p{font-size:.9rem}.card-mod{border-radius:.7rem;padding:.8rem .9rem}.card-mod img{height:1.8rem;width:1.8rem}}@media (min-width:361px) and (max-width:480px){.satl-hero h1{font-size:clamp(1.2rem,7vw,1.8rem)}.card-mod{padding:clamp(.9rem,3vw,1.1rem)}.card-mod img{height:2rem;width:2rem}}@media (min-width:481px) and (max-width:900px) and (orientation:portrait){.satl-grid{--gap:1rem;grid-template-columns:1fr;max-width:36rem}.satl-hero h1{font-size:clamp(1.4rem,5.5vw,2rem)}}@media (min-width:481px) and (max-width:900px) and (orientation:landscape){.satl-grid{--gap:1.25rem;grid-template-columns:repeat(2,minmax(12rem,1fr));max-width:64rem}.satl-hero h1{font-size:clamp(1.6rem,4.5vw,2.2rem)}}@media (min-width:768px) and (max-width:1366px) and (orientation:landscape){.satl-grid{--gap:1.5rem;grid-template-columns:repeat(3,minmax(14rem,1fr))}.satl-hero h1{font-size:clamp(2rem,3.2vw,3rem)}.card-mod{max-width:26rem}}@media (min-width:1025px) and (max-width:1366px){.satl-grid{grid-template-columns:repeat(3,minmax(16rem,1fr))}.satl-hero h1{font-size:clamp(2.2rem,2.6vw,3.2rem)}}@media (hover:none) and (pointer:coarse){.card-mod:hover{background:var(--card);transform:none}.card-mod:active{background:var(--card-hover-gradient);transform:scale(.98)}}.card-mod:focus-visible{box-shadow:var(--shadow-hover),0 0 0 3px rgba(var(--apple-rgb),.3);outline:3px solid var(--apple);outline-offset:2px}@media (prefers-reduced-motion:reduce){.card-mod,.satl-grid,.satl-home:before{animation:none}.card-mod{transition:background .2s ease,box-shadow .2s ease}.card-mod:hover{transform:none}.card-mod img{transition:none}.card-mod:hover img{transform:none}}.card-mod:after{background:rgba(var(--white-rgb),.4);border-radius:50%;content:"";height:0;left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .28s cubic-bezier(.2,.9,.2,1);width:0}.card-mod:active:after{height:120%;opacity:1;transition:all .12s ease;width:120%}.card-mod:hover:before{background-position:20% 0,80% 100%,50% 0;transform:translateZ(10px)}.card-mod:hover span{color:var(--forest);transform:translateY(-4px)}.card-mod:before{transition:background-position .7s cubic-bezier(.2,.8,.2,1),transform .35s ease}.card-mod span{text-shadow:0 1px 2px #0000001a}.card-mod:focus-visible:before{background:linear-gradient(90deg,#0000,rgba(var(--apple-rgb),.6),#0000);height:2px}@media (min-width:1200px){.satl-home .satl-grid{column-gap:var(--gap)!important;gap:var(--gap)!important;row-gap:clamp(2rem,3vw,3.5rem)!important}}@media (min-width:601px) and (max-width:1199px){.satl-home .satl-grid{column-gap:var(--gap)!important;gap:var(--gap)!important;row-gap:clamp(1.5rem,2.5vw,2.5rem)!important}}@media (max-width:600px){.satl-home .satl-grid{gap:var(--gap)!important;row-gap:clamp(1rem,2.5vw,1.25rem)!important}}:root{--card:#cfe9a6;--card-shadow:#b9d585}.mant-wrapper{background:#f9f9f6;background:var(--bg);box-sizing:border-box;min-height:100dvh;padding:clamp(16px,2vw,32px)}.mant-header{margin-bottom:clamp(12px,2vw,24px)}.mant-header h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:.2rem 0 .4rem}.mant-header p{color:#394;margin:0}.mant-search{box-sizing:border-box;margin-bottom:.75rem;max-width:720px;position:relative;width:100%}.mant-search input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.9rem 2.6rem .9rem 1rem;transition:border-color .15s,box-shadow .15s;width:100%}.mant-search input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.mant-clear{-webkit-tap-highlight-color:rgba(0,0,0,0);align-items:center;background:#0000;border:none;border-radius:8px;color:#4f6a3f;cursor:pointer;display:flex;font-size:1.1rem;height:36px;justify-content:center;position:absolute;right:.4rem;top:50%;touch-action:manipulation;transform:translateY(-50%);transition:background-color .2s ease,color .2s ease;width:36px}.mant-clear:hover{background-color:#4f6a3f1a;color:#00652f;color:var(--dart)}.mant-clear:active{background-color:#4f6a3f33;transform:translateY(-50%) scale(.95)}.mant-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}.mant-chip{background:#f3fadf;border:2px solid #cfe3a6;border-radius:999px;color:#274b29;cursor:pointer;font-weight:700;padding:.35rem .75rem}.mant-chip.is-active{background:#dbe524;background:var(--pear);border-color:#94bd17;border-color:var(--apple)}.mant-section{margin-top:.5rem}.mant-subtitle{align-items:center;color:#234124;display:flex;font-weight:800;gap:.5rem;margin:.5rem 0}.mant-count{align-items:center;background:#e8f2d6;border-radius:999px;color:#254325;display:inline-flex;font-size:.9rem;height:1.6rem;justify-content:center;min-width:1.6rem}.mant-grid{--col:clamp(260px,26vw,340px);--gap:clamp(14px,2vw,22px);grid-gap:var(--gap);display:grid;gap:var(--gap);grid-template-columns:repeat(3,var(--col));justify-content:center;justify-items:center;width:100%}.mant-card{align-items:center;background:linear-gradient(135deg,#cfe9a6,#dbe524);border:none;border-radius:22px;box-shadow:0 8px 24px #31822f14;cursor:pointer;display:flex;flex-direction:column;gap:.65rem;overflow:hidden;padding:clamp(.9rem,1.2vw,1.25rem);position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:var(--col);will-change:transform}.mant-card:before{background:linear-gradient(90deg,#0000,#fff6,#0000);height:1px;left:0;right:0;top:0}.mant-card:after,.mant-card:before{content:"";pointer-events:none;position:absolute}.mant-card:after{background:#ffffff59;border-radius:50%;height:0;left:50%;opacity:0;top:50%;transform:translate(-50%,-50%);transition:all .28s cubic-bezier(.2,.9,.2,1);width:0}.mant-card:active:after{height:120%;opacity:1;transition:all .12s ease;width:120%}.mant-card:hover{background:linear-gradient(135deg,#bfe081,#c9d922);box-shadow:0 12px 30px #31822f1f;perspective:50rem;transform:translateY(-6px) scale(1.02) rotateX(1.2deg);transform-style:preserve-3d}.mant-card:active{box-shadow:0 6px 12px #31822f0f;transform:translateY(-1px) scale(.995)}.mant-card-title{font-size:clamp(1rem,1.2vw,1.2rem)}.mant-card-cat,.mant-card-title{transition:transform .32s cubic-bezier(.2,.8,.2,1),color .25s ease}.mant-card:hover .mant-card-title{color:#31822f;color:var(--forest);transform:translateY(-4px)}.mant-card:hover .mant-card-cat{transform:translateY(-2px)}.mant-card-pin{pointer-events:auto;z-index:12}.mant-card-cat,.mant-card-title{pointer-events:none}.mant-card-title{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.1vw,1.2rem);font-weight:800}.mant-card-cat{color:#355a34;font-size:.9rem}.mant-card-pin{color:#3b6a2c;font-size:1.1rem;position:absolute;right:.6rem;top:.4rem;-webkit-user-select:none;user-select:none}@media (max-width:1500px){.mant-grid{grid-template-columns:repeat(2,var(--col))}}@media (max-width:640px){.mant-grid{grid-template-columns:var(--col)}.mant-wrapper{padding:16px}.mant-search input{font-size:16px;padding-right:52px}.mant-clear{font-size:1.1rem;height:36px;right:8px;width:36px}.mant-chips{gap:.4rem}.mant-chip{font-size:.85rem;padding:.4rem .6rem}}@media (max-width:375px){.mant-search input{padding-right:48px}.mant-clear{font-size:1rem;height:32px;right:6px;width:32px}.mant-wrapper{padding:12px}}.roles-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.roles-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.r-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.r-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.r-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.r-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.r-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.r-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.r-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.r-meta{color:#355a34;font-size:.95rem}.r-actions{align-items:center;display:flex;gap:.5rem}.r-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.r-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:700px;padding:clamp(14px,1.8vw,20px)}.r-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:1fr}.r-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.r-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:90%}.r-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.r-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.r-msg{font-weight:700;margin-top:.5rem}.r-msg.ok{color:#2e7d32}.r-msg.err{color:#c62828;color:var(--danger)}.es-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.es-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.es-search{margin:.25rem 0 1rem;max-width:520px}.es-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;outline:none;padding:.75rem 1rem;transition:border-color .15s,box-shadow .15s;width:100%}.es-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.es-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.es-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.es-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.es-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.es-meta{color:#355a34;font-size:.95rem}.es-actions{display:flex;gap:.5rem}.es-subtitle{font-weight:800;margin:1.25rem 0 .75rem}.es-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:700px;padding:clamp(14px,1.8vw,20px)}.es-grid{grid-gap:.85rem;display:grid;gap:.85rem}.es-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.es-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s,box-shadow .15s;width:90%}.es-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.es-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.es-msg{font-weight:700;margin-top:.5rem}.es-msg.ok{color:#2e7d32}.es-msg.err{color:#c62828;color:var(--danger)}.emp-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.emp-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.emp-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.emp-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.emp-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.emp-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:1100px}.emp-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.emp-main{grid-gap:.2rem;display:grid;gap:.2rem}.emp-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.emp-meta{color:#355a34;font-size:.95rem}.emp-actions{align-items:center;display:flex;gap:.5rem}.emp-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:1100px;padding:clamp(14px,1.8vw,20px)}.emp-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(3,minmax(220px,1fr))}@media (max-width:1024px){.emp-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (max-width:640px){.emp-grid{grid-template-columns:1fr}}.col-span-2{grid-column:span 2}.emp-form label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.emp-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:90%}.emp-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.emp-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.emp-msg{font-weight:700;margin-top:.5rem}.emp-msg.ok{color:#2e7d32}.emp-msg.err{color:#c62828;color:var(--danger)}.d-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.d-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.d-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.d-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.d-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.d-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.d-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.d-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.d-actions{align-items:center;display:flex;gap:.5rem}.d-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:700px;padding:clamp(14px,1.8vw,20px)}.d-form label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.d-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:90%}.d-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.d-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.msg{font-weight:700;margin-top:.5rem}.msg.ok{color:#2e7d32}.msg.err{color:#c62828;color:var(--danger)}.ec-search{margin:.25rem 0 1rem;max-width:520px}.ec-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;outline:none;padding:.75rem 1rem;transition:border-color .15s,box-shadow .15s;width:100%}.ec-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.ec-list{max-width:980px}.ec-main{grid-gap:.2rem;display:grid;gap:.2rem}.ec-subtitle{font-weight:800;margin:1.25rem 0 .75rem}.ec-form{max-width:700px}.ec-grid{grid-gap:.85rem;gap:.85rem}.ec-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.ec-input{font-size:1rem;padding:.65rem .75rem;width:90%}.ec-msg{margin-top:.5rem}.tipo-producto-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.tipo-producto-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.tp-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.tp-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.tp-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.tp-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.tp-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.tp-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.tp-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.tp-meta{color:#355a34;font-size:.95rem}.tp-actions{align-items:center;display:flex;gap:.5rem}.tp-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.tipo-descuento-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.tipo-descuento-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.td-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.td-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.td-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.td-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.td-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.td-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.td-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.td-meta{color:#355a34;font-size:.95rem}.td-actions{align-items:center;display:flex;gap:.5rem}.td-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.tipo-archivo-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.tipo-archivo-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.ta-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.ta-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.ta-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.ta-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.ta-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.ta-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.ta-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.ta-meta{color:#355a34;font-size:.95rem}.ta-actions{align-items:center;display:flex;gap:.5rem}.ta-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.u-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}.productos-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.productos-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.p-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.p-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.p-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.p-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.p-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.p-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.p-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.p-meta{color:#355a34;font-size:.95rem}.p-actions{align-items:center;display:flex;gap:.5rem}.p-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.estado-fecha-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.estado-fecha-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.ef-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.ef-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.ef-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.ef-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.ef-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.ef-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.ef-estado{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.ef-meta{color:#355a34;font-size:.95rem}.ef-actions{align-items:center;display:flex;gap:.5rem}.ef-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.ef-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:800px;padding:clamp(14px,1.8vw,20px)}.ef-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(2,minmax(220px,1fr))}@media (max-width:640px){.ef-grid{grid-template-columns:1fr}}.ef-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.ef-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:90%}.ef-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.ef-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.ef-msg{font-weight:700;margin-top:.5rem}.ef-msg.ok{color:#2e7d32}.ef-msg.err{color:#c62828;color:var(--danger)}.grados-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.grados-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.g-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.g-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.g-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.g-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.g-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.g-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.g-title{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.g-meta{color:#355a34;font-size:.95rem}.g-actions{align-items:center;display:flex;gap:.5rem}.g-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.g-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:1100px;padding:clamp(14px,1.8vw,20px)}.g-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(3,minmax(220px,1fr))}@media (max-width:1024px){.g-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (max-width:640px){.g-grid{grid-template-columns:1fr}}.g-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.g-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;resize:vertical;transition:border-color .15s ease,box-shadow .15s ease;width:90%}.g-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.g-textarea{font-family:inherit;min-height:80px}.g-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.g-msg{font-weight:700;margin-top:.5rem}.g-msg.ok{color:#2e7d32}.g-msg.err{color:#c62828;color:var(--danger)}.usuarios-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.usuarios-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.u-search{margin:.25rem 0 1rem;max-width:520px;position:relative}.u-search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.u-search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.u-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.u-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.u-card-main{grid-gap:.2rem;display:grid;gap:.2rem}.u-alias{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.u-meta{color:#355a34;font-size:.95rem}.u-actions{align-items:center;display:flex;gap:.5rem}.u-subtitle{color:#1a1a1a;color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.u-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:1100px;padding:clamp(14px,1.8vw,20px)}.u-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(3,minmax(220px,1fr))}@media (max-width:1024px){.u-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (max-width:640px){.u-grid{grid-template-columns:1fr}}.u-field-area{grid-column:span 1}.u-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.u-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:90%}textarea.u-input{box-sizing:border-box;resize:vertical}.u-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.u-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.u-msg{font-weight:700;margin-top:.5rem}.u-msg.ok{color:#2e7d32}.u-msg.err{color:#c62828;color:var(--danger)}.bank-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.bank-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.bank-toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}.bank-search{flex:1 1}.bank-search,.bank-select{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--field);border-radius:12px;min-width:220px;outline:none;padding:.7rem .9rem;transition:border-color .15s,box-shadow .15s}.bank-search:focus,.bank-select:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.bank-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem}.bank-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.bank-card:hover{background:#e3f2bd;transform:translateY(-1px)}.bank-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.bank-meta{color:#355a34;font-size:.95rem}.bank-actions{display:flex;gap:.5rem}.bank-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border:2px solid var(--line);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:1100px;padding:clamp(14px,1.8vw,20px)}.bank-grid{grid-column-gap:16px;grid-row-gap:14px;align-items:start;column-gap:16px;display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));row-gap:14px}@media (max-width:800px){.bank-grid{grid-template-columns:1fr}}.bank-grid>div{display:flex;flex-direction:column;min-width:0}.bank-form label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.bank-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--field);border-radius:12px;box-sizing:border-box;outline:none;padding:.7rem .9rem;transition:border-color .15s,box-shadow .15s;width:100%}.bank-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.bank-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.bank-msg{font-weight:700;margin:.5rem 0}.bank-msg.ok{color:#2e7d32}.bank-msg.err{color:#c62828;color:var(--danger)}.cli-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.cli-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.cli-toolbar{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}.cli-search{flex:1 1;min-width:260px}.cli-search,.cli-select{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;padding:.7rem .9rem}.cli-select{min-width:220px}.cli-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem}.cli-card{align-items:flex-start;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.cli-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.cli-nit{color:#2a4c2a;font-weight:700}.cli-meta{color:#355a34;flex-wrap:wrap;font-size:.95rem}.cli-actions,.cli-meta{display:flex;gap:.5rem}.btn{transition:transform .12s,box-shadow .12s}.cli-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:980px;padding:clamp(14px,1.8vw,20px)}.cli-grid{grid-column-gap:16px;grid-row-gap:14px;align-items:start;column-gap:16px;display:grid;grid-template-columns:repeat(3,minmax(260px,1fr));row-gap:14px}@media (max-width:1080px){.cli-grid{grid-template-columns:repeat(2,minmax(260px,1fr))}}@media (max-width:720px){.cli-grid{grid-template-columns:1fr}}.cli-grid>div{display:flex;flex-direction:column;min-width:0}.cli-form label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.cli-input{box-sizing:border-box;outline:none;transition:border-color .15s,box-shadow .15s}.cli-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.cli-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;padding:.7rem .9rem;width:100%}.cli-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.cli-msg{font-weight:700;margin:.5rem 0}.cli-msg.ok{color:#2e7d32}.cli-msg.err{color:#c62828;color:var(--danger)}:root{--field:#dde5cc;--line:#e3edd3}.ec-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.ec-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.ec-search{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem;max-width:1100px}.ec-input.ec-searchbox{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--field);border-radius:12px;flex:1 1;min-width:220px;outline:none;padding:.7rem .9rem;transition:border-color .15s,box-shadow .15s}.ec-input.ec-searchbox:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52440}.ec-list{grid-gap:.75rem;display:grid;gap:.75rem;margin-bottom:1.25rem;max-width:1100px}.ec-card{align-items:center;background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.ec-card:hover{background:#e3f2bd;transform:translateY(-1px)}.ec-name{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.ec-meta{color:#355a34;font-size:.95rem}.ec-actions{display:flex;gap:.5rem}.divider{background:var(--line)}.ec-msg{font-weight:700;margin:.5rem 0}.ec-msg.ok{color:#2e7d32}.ec-msg.err{color:#c62828;color:var(--danger)}.btn{transition:transform .12s,box-shadow .12s,opacity .12s}.btn-edit{box-shadow:0 2px 0 #216423}.ec-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border:2px solid var(--line);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:1100px;padding:clamp(14px,1.8vw,20px)}.ec-grid{grid-column-gap:16px;grid-row-gap:14px;align-items:start;column-gap:16px;display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));row-gap:14px}@media (max-width:800px){.ec-grid{grid-template-columns:1fr}}.ec-grid>div{display:flex;flex-direction:column;min-width:0}.ec-form label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.ec-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--field);border-radius:12px;box-sizing:border-box;outline:none;padding:.7rem .9rem;transition:border-color .15s,box-shadow .15s;width:100%}.ec-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.ec-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.header-decoration{background:linear-gradient(90deg,#0000,#94bd17,#00652f,#94bd17,#0000);background:linear-gradient(90deg,#0000,var(--accent),var(--accent-strong),var(--accent),#0000)}.menu-card{transition:transform .3s ease,box-shadow .3s ease,background .3s ease}.menu-card .material-icons{transition:transform .35s cubic-bezier(.2,.8,.2,1),color .25s ease}.menu-card:focus{outline:3px solid #dbe52438;outline:3px solid var(--focus-ring);outline-offset:2px}.menu-card:focus-visible{box-shadow:0 0 0 6px rgba(219 229 36,.15);box-shadow:0 0 0 6px rgba(var(--pear-rgb),.15);outline:3px solid #dbe52438;outline:3px solid var(--focus-ring);outline-offset:4px}@media (max-width:768px){.modulo,.page-container{padding:1rem;padding:var(--space-md)}.modulo h1{font-size:2rem}.module-description{font-size:1rem}.menu-cards{gap:.75rem;gap:var(--space-sm);grid-template-columns:1fr}.menu-card{min-height:140px;padding:1rem;padding:var(--space-md)}.icon-container{height:60px;width:60px}.menu-card .material-icons{font-size:32px}.menu-card span:not(.material-icons){font-size:1rem}}@media (max-width:480px){.modulo,.page-container{padding:.75rem;padding:var(--space-sm)}.modulo h1{font-size:1.75rem}.module-description{font-size:.9rem}.menu-card{min-height:120px;padding:.75rem;padding:var(--space-sm)}.icon-container{height:50px;width:50px}.menu-card .material-icons{font-size:28px}}.nomina-estadisticas{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr));margin-top:2rem;padding:0 1rem}.estadistica{align-items:center;background:#fff;border:2px solid rgba(0 101 47,.1);border:2px solid rgba(var(--green-rgb),.1);border-radius:1.25rem;border-radius:var(--border-radius);box-shadow:var(--shadow-card);display:flex;gap:1rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.estadistica:hover{border-color:var(--apple);box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.estadistica-icono{font-size:2rem;opacity:.8}.estadistica-contenido h4{color:var(--dart);font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.estadistica-contenido p{color:var(--forest);font-size:1.3rem;font-weight:700;margin:0 0 .25rem}.estadistica-contenido span{color:#666;font-size:.8rem;opacity:.9}.ver-boletas-container{margin:0 auto;max-width:1400px;padding:20px}.ver-boletas-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.ver-boletas-header h2{color:#2c3e50;margin:0}.btn-volver{background:linear-gradient(135deg,#6c757d,#5a6268);border:none;border-radius:1.25rem;border-radius:var(--border-radius);box-shadow:var(--shadow-card);color:#fff;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-volver:hover{background:linear-gradient(135deg,#5a6268,#495057);box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.btn-exportar{background:linear-gradient(135deg,var(--apple) 0,var(--pear) 100%);border:none;border-radius:1.25rem;border-radius:var(--border-radius);box-shadow:var(--shadow-card);color:var(--dart);cursor:pointer;font-weight:700;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.btn-exportar:hover{background:linear-gradient(135deg,var(--pear) 0,var(--apple) 100%);box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15);transform:translateY(-2px)}.filtros-container{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.filtros-titulo h3{color:#2c3e50;margin-bottom:20px}.filtros-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filtro-grupo label{color:#495057;font-weight:500;margin-bottom:5px}.filtro-grupo input,.filtro-grupo select{border:1px solid #ced4da;border-radius:5px;font-size:14px;padding:10px;width:100%}.filtro-grupo input:focus,.filtro-grupo select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.empleado-grupo{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:25px;overflow:hidden}.empleado-header{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;display:flex;justify-content:space-between;padding:20px}.empleado-header h4{font-size:1.2rem;margin:0}.empleado-puesto{background:#fff3}.boletas-count,.empleado-puesto{border-radius:15px;font-size:.9rem;padding:5px 10px}.boletas-count{background:#ffffff4d}.boletas-lista{padding:20px}.boleta-card{align-items:center;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:15px;padding:20px;transition:all .3s ease}.boleta-card:hover{box-shadow:0 5px 15px #0000001a;transform:translateY(-2px)}.boleta-card.estado-pendiente{border-left:4px solid #ffc107}.boleta-card.estado-pagada{border-left:4px solid #28a745}.boleta-card.estado-cancelada{border-left:4px solid #dc3545}.boleta-info{flex:1 1}.boleta-periodo{align-items:center;display:flex;gap:10px;margin-bottom:10px}.estado-badge{font-size:.8rem;padding:4px 8px}.estado-badge.estado-pendiente{background:#fff3cd;color:#856404}.estado-badge.estado-pagada{background:#d4edda;color:#155724}.estado-badge.estado-cancelada{background:#f8d7da;color:#721c24}.boleta-fechas{color:#6c757d;display:flex;font-size:.9rem;gap:15px;margin-bottom:10px}.boleta-montos{display:flex;gap:20px}.monto-grupo{align-items:center;display:flex;flex-direction:column}.monto-label{color:#6c757d;font-size:.8rem;margin-bottom:2px}.monto-valor{color:#2c3e50;font-weight:600}.monto-grupo.neto .monto-valor{color:#28a745;font-size:1.1rem}.boleta-acciones{display:flex;gap:10px}.btn-ver-detalle{background:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 12px}.btn-ver-detalle:hover{background:#0056b3}.btn-imprimir{background:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 12px}.btn-imprimir:hover{background:#5a6268}.boleta-detalle-container{margin:0 auto;max-width:1000px;padding:20px}.boleta-detalle-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.boleta-acciones-header{display:flex;gap:10px}.boleta-detalle-content{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px}.boleta-info-empleado{border-bottom:1px solid #e9ecef;margin-bottom:30px;padding-bottom:20px}.boleta-info-empleado h3{color:#2c3e50;margin-bottom:15px}.info-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.boleta-calculos{grid-gap:30px;display:grid;gap:30px}.seccion-descuentos,.seccion-devengado{background:#f8f9fa;border-radius:8px;padding:20px}.seccion-devengado h4{color:#28a745;margin-bottom:15px}.seccion-descuentos h4{color:#dc3545;margin-bottom:15px}.tabla-calculos{border-collapse:collapse;width:100%}.tabla-calculos td{border-bottom:1px solid #dee2e6;padding:10px}.tabla-calculos .total-row{border-top:2px solid #dee2e6;font-weight:700}.seccion-neto{background:linear-gradient(135deg,#28a745,#20c997);border-radius:10px;color:#fff;padding:25px;text-align:center}.monto-neto,.total-neto h4{margin-bottom:10px}.monto-neto{font-size:2rem;font-weight:700}.crear-nomina-container{max-width:1600px}.crear-nomina-header{border-bottom:2px solid #e9ecef;margin-bottom:30px;padding-bottom:20px}.crear-nomina-header h2{color:#2c3e50;margin:10px 0 20px}.pasos-indicador{gap:30px;margin-top:20px}.paso-indicador{align-items:center;display:flex;flex-direction:column;opacity:.5;transition:all .3s ease}.paso-indicador.activo{opacity:1}.paso-indicador.completado{opacity:.8}.paso-numero{align-items:center;background:#e9ecef;border-radius:50%;display:flex;font-weight:700;height:40px;justify-content:center;margin-bottom:8px;transition:all .3s ease;width:40px}.paso-indicador.activo .paso-numero{background:#007bff;color:#fff}.paso-indicador.completado .paso-numero{background:#28a745;color:#fff}.paso-texto{color:#6c757d;font-size:.9rem;font-weight:500}.paso-indicador.activo .paso-texto{color:#007bff}.paso-container{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px}.paso-header{margin-bottom:30px;text-align:center}.paso-header h3{color:#2c3e50;margin-bottom:10px}.paso-header p{color:#6c757d}.periodo-form{background:#f8f9fa;border-radius:8px;margin-bottom:30px;padding:20px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-group label{color:#495057;display:block}.form-group input{border:1px solid #ced4da;border-radius:5px;font-size:14px;padding:10px;width:100%}.empleados-seleccion{margin-bottom:30px}.empleados-seleccion h4{color:#2c3e50;margin-bottom:15px}.empleados-disponibles{grid-gap:15px;gap:15px;margin-bottom:20px}.empleado-disponible{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:15px}.btn-agregar{background:#28a745;border-radius:5px;transition:background .3s ease}.btn-agregar:hover{background:#218838}.btn-agregar.agregado{background:#6c757d;cursor:not-allowed}.empleados-seleccionados{background:#f8f9fa;border-radius:8px;padding:20px}.lista-seleccionados{flex-wrap:wrap;gap:10px}.empleado-seleccionado{background:#007bff;border-radius:20px;color:#fff;font-size:.9rem;gap:8px;padding:8px 12px}.btn-quitar{align-items:center;background:#ffffff4d;border-radius:50%;display:flex;font-size:12px;height:20px;justify-content:center;width:20px}.sin-empleados{color:#6c757d;padding:20px}.formula-info{background:#e3f2fd;border-radius:8px;margin-bottom:30px;padding:20px}.formula-info h4{color:#1976d2;margin-bottom:15px}.formulas-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.formula-item{background:#fff;border-left:4px solid #2196f3;border-radius:5px;padding:15px}.tabla-empleados-container{box-shadow:0 2px 10px #0000001a;margin-bottom:30px}.tabla-nomina{min-width:1400px}.tabla-nomina th{background:#f8f9fa;border-bottom:2px solid #dee2e6;color:#495057;font-size:.9rem;font-weight:600;padding:15px 10px;text-align:left}.tabla-nomina td{border-bottom:1px solid #dee2e6;font-size:.9rem;padding:12px 10px}.empleado-celda{min-width:120px}.empleado-celda strong{color:#2c3e50}.empleado-celda small{color:#6c757d;display:block;margin-top:2px}.input-bonificacion,.input-descuento,.input-dias{border:1px solid #ced4da;border-radius:3px;padding:5px;text-align:center;width:80px}.calculado{background-color:#f8f9fa;color:#495057;font-weight:500}.total-devengado{background-color:#d4edda;color:#155724}.total-descuentos{background-color:#f8d7da;color:#721c24}.total-neto{background-color:#cce7ff;color:#004085;font-weight:600}.btn-quitar-tabla{background:#dc3545;font-size:.8rem;padding:5px}.btn-quitar-tabla:hover{background:#c82333}.totales-fila{background:#343a40;color:#fff}.totales-fila td{border-bottom:none;font-weight:600}.paso-acciones{border-top:1px solid #e9ecef;display:flex;gap:20px;justify-content:space-between;padding-top:30px}.btn-anterior{background:#6c757d;border:none;color:#fff;font-size:1rem;padding:12px 24px}.btn-anterior:hover{background:#5a6268}.btn-siguiente{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px}.btn-siguiente:hover{background:#0056b3}.btn-siguiente:disabled{background:#6c757d;cursor:not-allowed}.btn-guardar{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px}.btn-guardar:hover{background:#218838}.btn-guardar:disabled{background:#6c757d;cursor:not-allowed}.resumen-nomina{grid-gap:30px;display:grid;gap:30px;margin-bottom:30px}.resumen-empleados,.resumen-periodo,.resumen-totales{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:25px}.resumen-empleados h4,.resumen-periodo h4,.resumen-totales h4{color:#2c3e50;margin-bottom:20px}.totales-grid{grid-gap:20px;gap:20px}.total-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:15px}.total-item.total-neto{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.total-label{font-weight:500}.total-valor{font-size:1.1rem;font-weight:600}.lista-resumen{grid-gap:15px;display:grid;gap:15px}.empleado-resumen{align-items:center;background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;display:flex;justify-content:space-between;padding:15px}.empleado-datos{display:flex;flex-direction:column}.empleado-datos strong{color:#2c3e50;margin-bottom:5px}.empleado-datos span{color:#6c757d;font-size:.9rem}.empleado-montos{display:flex;font-size:.9rem;gap:15px}.empleado-montos span{color:#495057}.loading,.no-resultados{color:#6c757d;padding:40px}.no-resultados h3{color:#495057;margin-bottom:10px}@media (max-width:768px){.nomina-menu-opciones{grid-template-columns:1fr}.nomina-opcion{flex-direction:column;text-align:center}.filtros-grid{grid-template-columns:1fr}.boleta-card{align-items:stretch;flex-direction:column;gap:15px}.tabla-empleados-container{font-size:.8rem}.paso-acciones{flex-direction:column}}.tabla-empleados-container{background:#fff;border:2px solid #2c3e50;border-radius:8px;box-shadow:0 4px 12px #00000026;margin:20px 0;overflow-x:auto;width:100%}.tabla-nomina{background:#fff;border-collapse:collapse;border-radius:1.25rem;border-radius:var(--border-radius);box-shadow:var(--shadow-card);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:clamp(10px,1.2vw,12px);min-width:1600px;overflow:hidden;width:100%}.tabla-nomina th{background:linear-gradient(135deg,var(--forest) 0,var(--dart) 100%);border:1px solid #fff3;color:#fff;font-size:clamp(9px,1.1vw,11px);font-weight:700;letter-spacing:.5px;padding:12px 8px;position:-webkit-sticky;position:sticky;text-align:center;text-shadow:0 1px 2px #0000004d;text-transform:uppercase;top:0;z-index:10}.tabla-nomina td{background:#fff;border:1px solid rgba(0 101 47,.1);border:1px solid rgba(var(--green-rgb),.1);font-size:clamp(10px,1.1vw,12px);padding:10px 6px;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);vertical-align:middle}.tabla-nomina tbody tr:nth-child(2n) td{background:linear-gradient(135deg,#f8f9fa,#f1f3f4)}.tabla-nomina tbody tr:hover td{background:linear-gradient(135deg,rgba(148 189 23,.1),rgba(219 229 36,.05));background:linear-gradient(135deg,rgba(var(--apple-rgb),.1) 0,rgba(var(--pear-rgb),.05) 100%);border-color:var(--apple);box-shadow:0 2px 8px rgba(0 101 47,.15);box-shadow:0 2px 8px rgba(var(--green-rgb),.15);transform:scale(1.02)}.numero-empleado{background-color:#ecf0f1!important;font-weight:700;width:40px}.nombre-empleado{padding-left:8px!important;text-align:left!important;width:200px}.nombre-empleado strong{color:#2c3e50;font-size:11px;text-transform:uppercase}.nombre-empleado small{color:#7f8c8d;font-size:9px}.puesto-empleado{font-size:10px;padding-left:8px!important;text-align:left!important;width:150px}.tabla-nomina td:nth-child(5),.tabla-nomina td:nth-child(6),.tabla-nomina td:nth-child(7),.tabla-nomina td:nth-child(8){background-color:#d5f4e6!important}.tabla-nomina td:nth-child(10),.tabla-nomina td:nth-child(11),.tabla-nomina td:nth-child(12),.tabla-nomina td:nth-child(13),.tabla-nomina td:nth-child(14),.tabla-nomina td:nth-child(15),.tabla-nomina td:nth-child(16),.tabla-nomina td:nth-child(9){background-color:#fdeaea!important}.total-liquido{background-color:#e3f2fd!important;color:#1565c0!important;font-size:12px!important;font-weight:700!important}.calculado{background-color:#f0f0f0!important;color:#2e7d32;font-style:italic;font-weight:600}.anticipo-quincena{background-color:#fff9c4!important;color:#f57f17;font-weight:700}.cuota-laboral{background-color:#ffecb3!important;color:#e65100;font-weight:600}.input-bonificacion,.input-descuento,.input-dias,.input-salario{background:#fff;border:1px solid #bdc3c7;border-radius:2px;font-family:inherit;font-size:11px;padding:4px;text-align:center;width:70px}.input-dias{background-color:#fff3e0;width:50px}.input-salario{font-weight:700;width:90px}.input-bonificacion,.input-descuento{width:80px}.input-bonificacion:focus,.input-descuento:focus,.input-dias:focus,.input-salario:focus{background-color:#e3f2fd;border-color:#2196f3;box-shadow:0 0 3px #2196f34d;outline:none}.totales-fila{background:linear-gradient(135deg,#1976d2,#1565c0)!important;color:#fff!important;font-size:12px!important;font-weight:700!important}.totales-fila td{border:1px solid #ffffff4d!important;padding:10px 8px!important;text-align:center!important}.btn-quitar-tabla{background:#f44336;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:10px;padding:4px 6px;transition:all .2s}.btn-quitar-tabla:hover{background:#d32f2f;transform:scale(1.1)}@media (max-width:1400px){.tabla-nomina{min-width:1400px}.tabla-nomina td,.tabla-nomina th{font-size:10px;padding:4px 3px}.input-bonificacion,.input-descuento,.input-dias,.input-salario{font-size:10px;width:60px}}@media (max-width:768px){.nomina-opciones-grid{gap:1rem;grid-template-columns:1fr}.nomina-btn{min-height:100px;padding:1.2rem 1rem}.btn-icono{font-size:2rem}.nomina-estadisticas{grid-template-columns:1fr}.estadistica{flex-direction:column;gap:.5rem;text-align:center}.btn-exportar,.btn-volver{font-size:.9rem;padding:10px 16px}}@media (min-width:1440px){.nomina-opciones-grid{gap:2rem;grid-template-columns:repeat(3,1fr)}.nomina-btn{min-height:140px;padding:2rem 1.5rem}}.nomina-page,.planilla-page{background:var(--bg);box-sizing:border-box;min-height:100vh;padding:clamp(16px,2.4vw,32px)}.nomina-page h1,.planilla-page h1{color:var(--ink);font-size:clamp(1.5rem,2.2vw,2rem);font-weight:800;margin:0 0 .75rem}.pl-search{margin:.25rem 0 1rem;max-width:600px;position:relative}.pl-search-input{background:var(--paper);border:2px solid var(--card);border-radius:12px;box-sizing:border-box;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.pl-search-input:focus{border-color:var(--forest);box-shadow:0 0 0 3px var(--focus-ring)}.pl-list{grid-gap:1rem;display:grid;gap:1rem;margin-bottom:1.5rem;max-width:1200px}.pl-card{align-items:flex-start;background:var(--paper);border-left:8px solid var(--forest);box-shadow:var(--shadow-soft);display:flex;gap:1rem;justify-content:space-between;padding:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.pl-card:hover{box-shadow:var(--shadow-hover)}.pl-main{grid-gap:.5rem;display:grid;flex:1 1;gap:.5rem}.pl-period{color:var(--dart);font-size:clamp(1.1rem,1.3vw,1.3rem);font-weight:800}.pl-meta{align-items:center;color:var(--ink);display:flex;flex-wrap:wrap;font-size:.95rem;gap:.5rem}.pl-status{border-radius:20px;font-size:.8rem;font-weight:700;padding:.2rem .6rem;text-transform:uppercase}.pl-status-borrador,.pl-status-procesada{background:var(--paper);color:var(--forest)}.pl-status-pagada{background:var(--paper);color:var(--success)}.pl-status-cancelada{background:var(--paper);color:var(--danger)}.pl-amounts{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.pl-amount{color:var(--ink);font-size:.9rem}.pl-amount.pl-net{color:var(--dart);font-weight:700}.pl-obs{background:#ffffffb3;border-radius:8px;color:#355a34;font-size:.9rem;font-style:italic;margin-top:.5rem;padding:.5rem}.pl-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.btn{font-size:.85rem;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;white-space:nowrap}.btn-edit{box-shadow:0 2px 0 var(--accent-strong)}.btn-danger{box-shadow:0 2px 0 #8e1e1e}.btn-success{background:var(--success);box-shadow:0 2px 0 #1b5e20}.btn-success:hover{opacity:.95}.btn-info{background:var(--forest);box-shadow:0 2px 0 var(--accent-strong)}.btn-info:hover{opacity:.95}.pl-modal{align-items:center;background:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:1rem;position:fixed;top:0;width:100%;z-index:1000}.pl-modal-content{background:var(--paper);border-radius:16px;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.pl-modal-header{align-items:center;background:var(--card);border-bottom:2px solid #dde5cc;display:flex;justify-content:space-between;padding:1.5rem}.pl-modal-header h3{color:var(--dart);font-weight:800;margin:0}.pl-modal-close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem;padding:.25rem;transition:color .2s ease}.pl-modal-close:hover{color:var(--danger)}.pl-modal-body{flex:1 1;overflow-y:auto;padding:1.5rem}.pl-employees-table{overflow-x:auto}.pl-employees-table table{border-collapse:collapse;font-size:.9rem;width:100%}.pl-employees-table td,.pl-employees-table th{border-bottom:1px solid #e0e0e0;padding:.75rem;text-align:left}.pl-employees-table th{background:var(--card);color:var(--dart);font-weight:700;position:-webkit-sticky;position:sticky;top:0}.pl-employees-table tr:hover{background:var(--card)}.pl-subtitle{color:var(--dart);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.pl-form{background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 var(--shadow);max-width:1200px;padding:clamp(16px,1.8vw,24px)}.pl-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.pl-field{display:flex;flex-direction:column}.pl-field-full{grid-column:1/-1}.pl-field label{color:#355a34;font-size:.9rem;font-weight:700;margin-bottom:.4rem}.pl-input{background:var(--paper);border:2px solid #dde5cc;border-radius:12px;box-sizing:border-box;font-size:1rem;outline:none;padding:.7rem .8rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.pl-input:focus{border-color:var(--forest);box-shadow:0 0 0 3px #31822f26}.pl-readonly{background:#f8f9fa;color:#666;cursor:not-allowed}.pl-textarea{font-family:inherit;min-height:80px;resize:vertical}.pl-actions-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.btn-save{box-shadow:0 2px 0 #064424}.pl-msg{border-radius:8px;font-weight:700;margin:.5rem 0;padding:.75rem}.pl-msg.ok{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.pl-msg.err{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.divider{margin:1.5rem 0}@media (max-width:1024px){.pl-grid{grid-template-columns:repeat(2,1fr)}.pl-card{align-items:stretch;flex-direction:column}.pl-actions{justify-content:flex-start;margin-top:1rem}}@media (max-width:640px){.planilla-page{padding:16px}.pl-grid{grid-template-columns:1fr}.pl-amounts{flex-direction:column;gap:.25rem}.pl-actions{gap:.25rem}.btn{font-size:.8rem;padding:.5rem .7rem}.pl-modal{padding:.5rem}.pl-modal-content{min-height:80vh}.pl-employees-table{font-size:.8rem}.pl-employees-table td,.pl-employees-table th{padding:.5rem .25rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.pl-card{animation:fadeIn .3s ease-out}.pl-modal{animation:fadeIn .2s ease-out}.planilla-empleados-page{background:var(--bg);box-sizing:border-box;min-height:100vh;padding:clamp(16px,2.4vw,32px)}.ple-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.ple-header h1{color:var(--ink);font-size:clamp(1.3rem,2vw,1.8rem);font-weight:800;margin:0}.btn-back{align-items:center;background:var(--forest);box-shadow:0 2px 0 #216423;color:var(--paper);display:inline-flex;gap:.5rem;text-decoration:none}.ple-empty{background:var(--paper);border:2px dashed #ddd;border-radius:12px;color:#666;font-style:italic;padding:2rem;text-align:center}.ple-list{grid-gap:1rem;display:grid;gap:1rem;margin-bottom:1.5rem}.ple-card{align-items:flex-start;background:var(--card);border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:1.25rem}.ple-main{grid-gap:.75rem;display:grid;flex:1 1;gap:.75rem}.ple-name{color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.ple-amounts{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.ple-amount-group{background:var(--paper);border:1px solid #dde5cc;border-radius:8px;padding:.75rem}.ple-amount-group.ple-net{background:var(--card);border:2px solid var(--forest)}.ple-label{color:var(--forest);display:block;font-size:.9rem;font-weight:700;margin-bottom:.5rem}.ple-details{color:#666;display:flex;flex-direction:column;font-size:.85rem;gap:.25rem;margin-bottom:.5rem}.ple-net-amount{color:var(--dart);font-size:1.1rem;font-weight:700}.ple-obs{background:#ffffffb3;border-radius:6px;color:#355a34;font-size:.9rem;font-style:italic;padding:.5rem}.ple-actions{display:flex;flex-direction:column;gap:.5rem}.ple-subtitle{color:var(--ink);font-size:clamp(1.05rem,1.2vw,1.25rem);font-weight:800;margin:1.25rem 0 .75rem}.ple-form{background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 var(--shadow);max-width:1400px;padding:clamp(16px,1.8vw,24px)}.ple-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.ple-section{background:#ffffff80;border:1px solid #e3edd3;border-radius:12px;padding:1rem}.ple-section h3{border-bottom:2px solid var(--forest);color:var(--dart);font-size:1.1rem;font-weight:700;margin:0 0 1rem;padding-bottom:.5rem}.ple-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.ple-field{display:flex;flex-direction:column}.ple-field-full{grid-column:1/-1}.ple-net-input{background:var(--card)!important;border:2px solid var(--forest)!important;color:var(--dart);font-weight:700}.ple-actions-bar{display:flex;gap:.75rem;justify-content:flex-start;margin-top:1.5rem}@media (max-width:1024px){.ple-amounts{grid-template-columns:1fr}.ple-card{align-items:stretch;flex-direction:column}.ple-actions{flex-direction:row;justify-content:flex-start}.ple-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.planilla-empleados-page{padding:16px}.ple-header{align-items:flex-start;flex-direction:column;gap:.75rem}.ple-row{grid-template-columns:1fr}.ple-details{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(2,1fr)}.ple-actions{gap:.25rem}.ple-actions-bar{flex-direction:column}}.nom-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.nom-header h1{color:var(--ink);font-size:clamp(1.3rem,2vw,1.8rem);font-weight:800;margin:0}.nom-add-section{background:var(--paper);border:2px solid #e3edd3;border-radius:12px;margin-bottom:1rem;padding:1rem}.nom-add-section h3{color:var(--dart);font-size:1.1rem;margin:0 0 1rem}.nom-empleados-disponibles{grid-gap:.75rem;display:grid;gap:.75rem}.nom-empleado-card{align-items:center;background:var(--card);border-left:4px solid var(--apple);border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.nom-empleado-card small{color:#666;font-size:.85rem}.btn-sm{font-size:.8rem;padding:.4rem .7rem}.nom-list{grid-gap:1rem;display:grid;gap:1rem}.nom-card{align-items:flex-start;background:var(--card);border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:1.25rem}.nom-main{grid-gap:.75rem;display:grid;flex:1 1;gap:.75rem}.nom-name{color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800}.nom-puesto{color:#666;font-size:.9rem;font-style:italic}.nom-amounts{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.nom-amount-group{background:var(--paper);border:1px solid #dde5cc;border-radius:8px;padding:.75rem}.nom-amount-group.nom-net{background:var(--card);border:2px solid var(--forest)}.nom-label{color:var(--forest);display:block;font-size:.9rem;font-weight:700;margin-bottom:.5rem}.nom-details{color:#666;display:flex;flex-direction:column;font-size:.85rem;gap:.25rem;margin-bottom:.5rem}.nom-net-amount{color:var(--dart);font-size:1.1rem;font-weight:700}.nom-actions{display:flex;flex-direction:column;gap:.5rem}.boleta-container{background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 var(--shadow);margin:0 auto;max-width:800px;overflow:hidden}.boleta-header{background:var(--card);border-bottom:2px solid #e3edd3;padding:1.5rem;text-align:center}.boleta-header h2{color:var(--dart);font-size:1.5rem;font-weight:800;margin:0 0 1rem}.boleta-info{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));text-align:left}.boleta-info p{font-size:.9rem;margin:.25rem 0}.boleta-content{padding:1.5rem}.boleta-section{margin-bottom:1.5rem}.boleta-section h3{border-bottom:2px solid var(--forest);color:var(--dart);font-size:1.1rem;font-weight:700;margin:0 0 .75rem;padding-bottom:.5rem}.boleta-table{border-collapse:collapse;font-size:.9rem;width:100%}.boleta-table td{border-bottom:1px solid #e0e0e0;padding:.5rem}.boleta-table td:first-child{text-align:left}.boleta-table td:last-child{font-weight:600;text-align:right}.boleta-table .total-row td{background:var(--card);border-bottom:2px solid var(--forest);border-top:2px solid var(--forest);color:var(--dart);font-weight:700;padding:.75rem .5rem}.boleta-summary .net-total td{background:var(--card);border:3px solid var(--forest);color:var(--dart);font-size:1.2rem;font-weight:800;padding:1rem .5rem}.boleta-footer{background:#ffffff80;border-top:1px solid #e0e0e0;margin-top:1rem;padding:1rem;text-align:center}.boleta-footer p{font-size:.9rem;margin:.25rem 0}.boleta-date{color:#666;font-style:italic}.boleta-actions{background:var(--card);border-top:2px solid #e3edd3;display:flex;gap:.75rem;justify-content:center;padding:1.5rem}@media (max-width:1024px){.nom-amounts{grid-template-columns:1fr}.nom-card{align-items:stretch;flex-direction:column}.nom-actions{flex-direction:row;justify-content:flex-start}.boleta-info{grid-template-columns:1fr}}@media (max-width:640px){.nom-header{align-items:flex-start;flex-direction:column;gap:.75rem}.nom-empleados-disponibles{gap:.5rem}.nom-empleado-card{align-items:flex-start;flex-direction:column;gap:.5rem}.nom-details{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(2,1fr)}.nom-actions{gap:.25rem}.boleta-actions{flex-direction:column}.boleta-table{font-size:.8rem}.boleta-table td{padding:.4rem .25rem}}.bonificaciones-modal{align-items:center;background:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:1rem;position:fixed;top:0;width:100%;z-index:1000}.bonificaciones-content{background:var(--paper);border-radius:16px;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.bonificaciones-header{align-items:center;background:var(--card);border-bottom:2px solid #dde5cc;display:flex;justify-content:space-between;padding:1.5rem}.bonificaciones-header h2{color:var(--dart);font-weight:800;margin:0}.bonificaciones-body{flex:1 1;overflow-y:auto;padding:1.5rem}.bonif-summary{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.bonif-summary-item{align-items:center;background:var(--card);border-left:4px solid var(--forest);border-radius:8px;display:flex;flex:1 1;justify-content:space-between;min-width:200px;padding:.75rem}.bonif-summary-item strong{color:var(--dart);font-size:1.1rem;font-weight:800}.bonif-section{margin-bottom:1.5rem}.bonif-section h3{border-bottom:2px solid var(--forest);color:var(--dart);font-size:1.1rem;font-weight:700;margin:0 0 1rem;padding-bottom:.5rem}.bonif-empty{background:#ffffff80;border:2px dashed #ddd;border-radius:8px;color:#666;font-style:italic;padding:2rem;text-align:center}.bonif-card{align-items:center;background:var(--paper);border:1px solid #dde5cc;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:1rem}.bonif-main{flex:1 1}.bonif-tipo{color:var(--dart);font-size:1rem}.bonif-monto,.bonif-tipo{font-weight:700;margin-bottom:.25rem}.bonif-monto{color:var(--forest);font-size:1.1rem}.bonif-justificacion{color:#666;font-size:.9rem;font-style:italic;margin-bottom:.25rem}.bonif-fecha{color:#888;font-size:.8rem}.bonif-actions{display:flex;gap:.5rem}.bonif-form{background:#ffffff80;border:2px solid #e3edd3;border-radius:8px;padding:1rem}.bonif-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.bonif-actions-bar{display:flex;gap:.75rem;justify-content:flex-start}.descuentos-modal{align-items:center;background:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:1rem;position:fixed;top:0;width:100%;z-index:1000}.descuentos-content{background:var(--paper);border-radius:16px;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;width:100%}.descuentos-header{align-items:center;background:var(--card);border-bottom:2px solid #dde5cc;display:flex;justify-content:space-between;padding:1.5rem}.descuentos-header h2{color:var(--dart);font-weight:800;margin:0}.descuentos-body{flex:1 1;overflow-y:auto;padding:1.5rem}.desc-summary{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.desc-summary-item{align-items:center;background:var(--card);border-left:4px solid var(--danger);border-radius:8px;display:flex;flex:1 1;justify-content:space-between;min-width:180px;padding:.75rem}.desc-summary-item strong{color:var(--danger);font-size:1.1rem}.desc-tabs{border-bottom:2px solid #e3edd3;display:flex;gap:.25rem;margin-bottom:1.5rem}.desc-tab{background:none;border:none;border-radius:8px 8px 0 0;color:#666;cursor:pointer;font-weight:600;padding:.75rem 1.25rem;transition:all .2s ease}.desc-tab.active{background:var(--forest);color:var(--paper)}.desc-tab:hover:not(.active){background:var(--card);color:var(--dart)}.desc-section{margin-bottom:1.5rem}.desc-section h3{border-bottom:2px solid var(--forest);color:var(--dart);font-size:1.1rem;font-weight:700;margin:0 0 1rem;padding-bottom:.5rem}.desc-empty{background:#ffffff80;border:2px dashed #ddd;border-radius:8px;color:#666;font-style:italic;padding:2rem;text-align:center}.desc-card{align-items:center;background:#ffffffb3;border-left:4px solid var(--danger);border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.75rem;padding:1rem}.desc-card.anticipo-card{border-left-color:var(--warning)}.desc-main{flex:1 1}.desc-tipo{color:var(--dart)}.desc-monto,.desc-tipo{font-weight:700;margin-bottom:.25rem}.desc-monto{color:var(--bg);font-size:1.1rem}.anticipo-card .desc-monto{color:var(--warning)}.anticipo-details{color:#666;display:flex;flex-wrap:wrap;font-size:.85rem;gap:.75rem;margin-bottom:.25rem}.desc-fecha{color:#888;font-size:.8rem}.desc-actions{display:flex;gap:.5rem}.desc-form{background:#ffffff80;border:2px solid #e3edd3;border-radius:8px;padding:1rem}.desc-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1rem}.desc-actions-bar{display:flex;gap:.75rem;justify-content:flex-start}@media (max-width:640px){.bonificaciones-modal,.descuentos-modal{padding:.5rem}.bonif-summary,.desc-summary{flex-direction:column}.bonif-summary-item,.desc-summary-item{min-width:auto}.bonif-card,.desc-card{align-items:flex-start;flex-direction:column;gap:.75rem}.bonif-actions,.desc-actions{align-self:stretch}.desc-tabs{flex-direction:column}.desc-tab{border-radius:8px;margin-bottom:.25rem}.anticipo-details{gap:.25rem}.anticipo-details,.bonif-actions-bar,.desc-actions-bar{flex-direction:column}}.modal-overlay{background-color:#0009;padding:20px}.modal-requisitos{animation:slideIn .3s ease-out;background:var(--paper);border-radius:12px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:2px solid rgba(var(--green-rgb),.15);padding:24px 30px}.modal-header h2{align-items:center;color:var(--dart);display:flex;font-size:24px;font-weight:600;gap:10px;margin:0 0 10px}.modal-header p{color:#666;font-size:14px;margin:0}.modal-body{flex:1 1;overflow-y:auto;padding:20px 30px}.loading-requisitos{color:#666;font-size:16px;padding:40px;text-align:center}.requisitos-lista{display:flex;flex-direction:column;gap:16px}.requisito-item{border:2px solid #0000;border-radius:8px;display:flex;gap:16px;padding:16px;transition:all .2s ease}.requisito-item.cumple{background:linear-gradient(135deg,rgba(var(--apple-rgb),.1) 0,rgba(var(--pear-rgb),.05) 100%);border-color:var(--forest)}.requisito-item.no-cumple{background-color:#ffebee;border-color:#f44336}.requisito-item.no-cumple .btn-accion-requisito{background-color:#f44336}.requisito-item.no-cumple .btn-accion-requisito:hover{background-color:#d32f2f;box-shadow:0 4px 12px #f443364d}.requisito-icono{flex-shrink:0;font-size:28px;line-height:1}.requisito-contenido{flex:1 1}.requisito-contenido h3{color:var(--dart);font-size:16px;font-weight:600;margin:0 0 8px}.requisito-contenido p{color:#555;font-size:14px;margin:0}.btn-accion-requisito{align-items:center;background-color:var(--forest);border:none;border-radius:6px;color:var(--paper);cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;margin-top:12px;padding:10px 20px;transition:var(--transition)}.btn-accion-requisito:hover{background-color:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-accion-requisito:active{transform:translateY(0)}.detalles-lista{color:#666;font-size:13px;margin:12px 0 0;max-height:150px;overflow-y:auto;padding-left:20px}.detalles-lista li{margin-bottom:6px}details{cursor:pointer;margin-top:12px}details summary{color:var(--forest);font-weight:500;padding:4px 0;-webkit-user-select:none;user-select:none}details summary:hover{text-decoration:underline}details[open] summary{margin-bottom:8px}.modal-footer{border-top:2px solid rgba(var(--green-rgb),.15);flex-wrap:wrap;gap:12px;padding:20px 30px}.modal-footer button{align-items:center;border-radius:6px;display:flex;font-size:14px;gap:6px;padding:12px 24px}.btn-cancelar{background-color:#f5f5f5;color:#666}.btn-cancelar:hover{background-color:#e0e0e0}.btn-reverificar{background-color:var(--apple);color:var(--dart)}.btn-reverificar:hover{background-color:var(--pear);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-continuar{background-color:var(--forest);color:var(--paper)}.btn-continuar:hover:not(:disabled){background-color:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-continuar:disabled{background-color:#bdbdbd;cursor:not-allowed;opacity:.6}@media (max-width:768px){.modal-requisitos{max-width:95%}.modal-body,.modal-footer,.modal-header{padding:16px 20px}.modal-header h2{font-size:20px}.requisito-item{flex-direction:column;gap:12px}.requisito-icono{font-size:24px}.modal-footer{flex-direction:column}.modal-footer button{justify-content:center;width:100%}}.crear-nomina-container{background-color:var(--bg);margin:0 auto;max-width:100%;min-height:calc(100vh - var(--navbar-height));padding:20px}.crear-nomina-header{align-items:center;background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:20px}.crear-nomina-header h2{color:var(--dart);font-size:24px;font-weight:600;margin:0}.pasos-indicador{background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);display:flex;gap:16px;justify-content:center;margin-bottom:30px;padding:20px}.paso-item{align-items:center;background:rgba(var(--green-rgb),.05);border-radius:8px;color:#666;display:flex;font-weight:600;gap:8px;padding:12px 20px;transition:var(--transition)}.paso-item.activo{background:var(--forest);color:var(--paper)}.paso-item.completado{background:var(--apple);color:var(--dart)}.periodo-form{background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);margin-bottom:24px;padding:24px}.periodo-form h3{color:var(--dart);font-size:18px;font-weight:600;margin-bottom:20px}.form-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.form-group{gap:8px}.form-group label{color:var(--forest);font-size:14px;font-weight:600}.form-group input,.form-group select{background-color:var(--paper);border:2px solid rgba(var(--green-rgb),.2);border-radius:8px;font-size:14px;padding:12px;transition:var(--transition)}.form-group input:focus,.form-group select:focus{border-color:var(--forest);box-shadow:0 0 0 3px var(--focus-ring);outline:none}.info-box{background:linear-gradient(135deg,rgba(var(--apple-rgb),.1) 0,rgba(var(--pear-rgb),.1) 100%);border-left:4px solid var(--forest);border-radius:8px;margin-bottom:24px;padding:16px 20px}.info-box h4{color:var(--dart);font-size:16px;font-weight:600;margin:0 0 12px}.info-box p{color:#555;font-size:14px;line-height:1.6;margin:6px 0}.info-box strong{color:var(--forest)}.empleados-seleccion{background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);color:var(--dart);margin-bottom:24px;padding:24px}.empleados-seleccion h4{color:var(--dart);font-size:18px;font-weight:600;margin-bottom:20px}.empleados-disponibles{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));max-height:500px;overflow-y:auto;padding:8px}.empleado-disponible{align-items:center;background:var(--paper);border:2px solid rgba(var(--green-rgb),.2);border-radius:12px;display:flex;gap:16px;justify-content:space-between;padding:16px 20px;transition:var(--transition)}.empleado-disponible:hover{border-color:var(--forest);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.empleado-info{flex:1 1}.empleado-info strong{color:var(--dart);display:block;font-size:16px;font-weight:700;line-height:1.3;margin-bottom:4px}.empleado-info small{color:#666;display:block;font-size:13px;line-height:1.5}.btn-agregar{background:var(--forest);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:var(--transition);white-space:nowrap}.btn-agregar:hover:not(:disabled){background:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.btn-agregar:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.btn-agregar.agregado{background:var(--apple);color:var(--dart)}.empleados-seleccionados{background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);margin-bottom:24px;padding:24px}.empleados-seleccionados h4{color:var(--dart);font-size:18px;font-weight:600;margin-bottom:16px}.sin-empleados{color:#999;font-style:italic;padding:32px;text-align:center}.lista-seleccionados{display:flex;flex-direction:column;gap:12px}.empleado-seleccionado{align-items:center;background:var(--card);border:2px solid var(--forest);border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:12px 16px}.empleado-seleccionado .empleado-info strong{color:var(--dart);font-size:15px;font-weight:700}.empleado-seleccionado .empleado-info small{color:#666;font-size:12px}.btn-quitar{background:#dc3545;border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:700;padding:6px 12px;transition:var(--transition)}.btn-quitar:hover{background:#c82333;transform:scale(1.1)}.empleados-seleccion h3{color:var(--dart);font-size:18px;font-weight:600;margin-bottom:20px}.empleados-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));max-height:400px;overflow-y:auto;padding:8px}.empleado-card{background:var(--paper);border:2px solid rgba(var(--green-rgb),.2);border-radius:12px;cursor:pointer;padding:16px;transition:var(--transition)}.empleado-card:hover{border-color:var(--forest);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.empleado-card.seleccionado{background:linear-gradient(135deg,var(--card) 0,var(--pear) 100%);border-color:var(--forest)}.empleado-card h4{color:var(--dart);font-size:15px;font-weight:600;margin:0 0 8px}.empleado-card p{color:#666;font-size:13px;margin:4px 0}.nomina-tabla-container{background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);margin-bottom:24px;overflow:hidden;padding:24px}.nomina-tabla-container h3{color:var(--dart);font-size:18px;font-weight:600;margin-bottom:20px}.tabla-scroll-container{-webkit-overflow-scrolling:touch;margin:0 -24px;overflow-x:auto;overflow-y:visible;padding:0 24px}.nomina-tabla{border-collapse:initial;border-spacing:0;font-size:13px;min-width:1400px;width:100%}.nomina-tabla thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.nomina-tabla th{background:var(--forest);border:1px solid #ffffff1a;color:var(--paper);font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 10px;text-align:center;text-transform:uppercase;white-space:nowrap}.nomina-tabla th[colspan]{background:var(--dart);font-size:13px;padding:12px}.nomina-tabla tbody tr{background:var(--paper);transition:var(--transition)}.nomina-tabla tbody tr:nth-child(2n){background:rgba(var(--apple-rgb),.03)}.nomina-tabla tbody tr:hover{background:rgba(var(--apple-rgb),.1)}.nomina-tabla td{border:1px solid rgba(var(--green-rgb),.1);padding:10px 8px;text-align:center;vertical-align:middle}.nomina-tabla td:nth-child(2){color:var(--dart);font-weight:600;min-width:200px;text-align:left}.nomina-tabla td:nth-child(3){color:#666;min-width:150px;text-align:left}.nomina-tabla input[type=number],.nomina-tabla input[type=text]{background-color:var(--paper);border:2px solid rgba(var(--green-rgb),.2);border-radius:6px;font-size:13px;max-width:90px;padding:6px 8px;text-align:center;transition:var(--transition);width:100%}.nomina-tabla input[type=number]:focus,.nomina-tabla input[type=text]:focus{border-color:var(--forest);box-shadow:0 0 0 2px var(--focus-ring);outline:none}.nomina-tabla input[readonly]{background-color:rgba(var(--green-rgb),.05);border-color:rgba(var(--green-rgb),.1);color:var(--dart);cursor:not-allowed;font-weight:600}.nomina-tabla td.total-devengado{background:rgba(var(--apple-rgb),.1);color:var(--forest);font-weight:700}.nomina-tabla td.total-neto{background:linear-gradient(135deg,rgba(var(--apple-rgb),.15) 0,rgba(var(--pear-rgb),.15) 100%);color:var(--forest);font-size:14px;font-weight:700}.nomina-tabla input.descuento{color:#d84315}.nomina-tabla input.anticipo{color:#f57c00}.nomina-tabla button{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;margin:2px;padding:6px 12px;transition:var(--transition);white-space:nowrap}.btn-bonos{background:var(--apple);color:var(--dart)}.btn-bonos:hover{background:var(--pear);transform:translateY(-1px)}.btn-descuentos{background:#f57c00;color:#fff}.btn-descuentos:hover{background:#e65100;transform:translateY(-1px)}.btn-quitar{background:#d32f2f;color:#fff}.btn-quitar:hover{background:#b71c1c;transform:translateY(-1px)}.totales-nomina{background:linear-gradient(135deg,rgba(var(--apple-rgb),.1) 0,rgba(var(--pear-rgb),.1) 100%);border:2px solid var(--forest);border-radius:var(--border-radius);margin-bottom:24px;padding:24px}.totales-nomina h3{color:var(--dart);font-size:18px;font-weight:600;margin-bottom:20px;text-align:center}.totales-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.total-item{background:var(--paper);border-radius:10px;box-shadow:0 2px 8px rgba(var(--green-rgb),.1);padding:16px;text-align:center}.total-item label{color:#666;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.total-item .monto{color:var(--forest);font-size:24px;font-weight:700}.total-item.neto-total{background:var(--forest);color:var(--paper)}.total-item.neto-total label{color:var(--pear)}.total-item.neto-total .monto{color:var(--pear);font-size:32px}.acciones-container{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.btn-volver{border-radius:8px;padding:14px 28px}.btn-guardar,.btn-siguiente,.btn-volver{align-items:center;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;transition:var(--transition)}.btn-guardar,.btn-siguiente{background:var(--forest);border:none;border-radius:8px;color:var(--paper);padding:14px 32px}.btn-guardar:hover,.btn-siguiente:hover{background:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-guardar:disabled,.btn-siguiente:disabled{background:#999;cursor:not-allowed;opacity:.6}.btn-anterior{background:rgba(var(--green-rgb),.1);border:2px solid rgba(var(--green-rgb),.2);border-radius:8px;color:var(--dart);cursor:pointer;font-size:15px;font-weight:600;padding:14px 28px;transition:var(--transition)}.btn-anterior:hover{background:rgba(var(--green-rgb),.15);border-color:var(--forest)}.loading-container{padding:60px 20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid rgba(var(--green-rgb),.1);border-radius:50%;border-top-color:var(--forest);display:inline-block;height:50px;width:50px}.mensaje{border-radius:8px;font-weight:600;margin-bottom:20px;padding:16px 20px}.mensaje.exito{background:rgba(var(--apple-rgb),.2);border:2px solid var(--forest);color:var(--forest)}.mensaje.error{background:#ffebee;border:2px solid #ef5350;color:#c62828}@media (max-width:1200px){.nomina-tabla{font-size:12px}.nomina-tabla td,.nomina-tabla th{padding:8px 6px}.nomina-tabla input{font-size:12px;max-width:70px;padding:4px 6px}}@media (max-width:768px){.crear-nomina-container{padding:12px}.pasos-indicador{flex-direction:column}.empleados-grid,.form-grid,.totales-grid{grid-template-columns:1fr}.acciones-container{flex-direction:column}.acciones-container button{justify-content:center;width:100%}.tabla-scroll-container{margin:0 -12px;padding:0 12px}.nomina-tabla-container h3{font-size:16px}}.tabla-scroll-container::-webkit-scrollbar{height:10px}.tabla-scroll-container::-webkit-scrollbar-track{background:rgba(var(--green-rgb),.05);border-radius:10px}.tabla-scroll-container::-webkit-scrollbar-thumb{background:var(--forest);border-radius:10px}.tabla-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--dart)}.modulo{max-width:1400px}.module-header{border-bottom:3px solid var(--forest);margin-bottom:2rem;padding-bottom:1.5rem}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.header-actions .btn-exportar,.header-actions .btn-volver{align-items:center;border:none;border-radius:var(--border-radius);cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:var(--transition)}.btn-volver{background:rgba(var(--green-rgb),.1);border:2px solid rgba(var(--green-rgb),.2);color:var(--dart)}.btn-volver:hover{background:rgba(var(--green-rgb),.15);border-color:var(--forest);transform:translateY(-1px)}.btn-exportar{background:var(--forest);color:var(--paper)}.btn-exportar:hover{background:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.module-header h1{font-size:2.5rem;font-weight:700;margin:0;text-align:center}.header-decoration{background:linear-gradient(90deg,var(--apple),var(--pear),var(--forest));border-radius:2px;margin-top:1rem}.module-description{color:var(--ink);font-size:1.1rem;margin-bottom:2rem;text-align:center}.filtros-section{background:linear-gradient(180deg,#fff,#fbfffa);border:2px solid var(--border);border-radius:12px;box-shadow:var(--shadow-soft);margin-bottom:2rem;padding:2rem;transition:border-color .2s ease,transform .08s ease}.filtros-section:hover{border-color:var(--apple);transform:translateY(-1px)}.filtros-header h3{align-items:center;color:var(--dart);display:flex;font-size:1.3rem;font-weight:600;gap:.75rem;margin:0 0 1.5rem}.filtros-header .material-icons{color:var(--forest);font-size:1.5rem}.filtros-grid{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.filtro-grupo{display:flex;flex-direction:column;gap:.5rem;min-height:85px;position:relative}.filtro-grupo label{color:var(--forest);display:block;font-size:.95rem;font-weight:600;margin-bottom:.25rem}.filtro-grupo input,.filtro-grupo select{background:linear-gradient(180deg,#fff,#fbfffa);border:2px solid var(--border);border-radius:12px;box-sizing:border-box;font-size:.9rem;height:44px;padding:.6rem .75rem;transition:background-color .2s ease,border-color .2s ease,transform .08s ease}.filtro-grupo input:hover,.filtro-grupo select:hover{background:linear-gradient(90deg,#f2f7e6,#eef9e6);border-color:var(--apple);transform:translateY(-1px)}.filtro-grupo input:focus,.filtro-grupo select:focus{background:linear-gradient(90deg,var(--pear) 0,#f7fbd8 100%);border-color:var(--forest);box-shadow:0 0 0 3px rgba(var(--forest-rgb),.1);outline:none;transform:translateY(-1px)}.expedientes-content{display:flex;flex-direction:column;gap:2rem}.loading{align-items:center;color:var(--forest);display:flex;font-size:1.1rem;font-weight:500;gap:.75rem;justify-content:center;padding:4rem 2rem}.loading .material-icons{animation:spin 1s linear infinite;font-size:1.5rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cliente-section{background:var(--paper);border:1px solid rgba(var(--green-rgb),.1);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);padding:1.5rem}.cliente-header{background:var(--forest);border-radius:var(--border-radius);color:var(--paper);margin-bottom:1rem;padding:1rem;transition:var(--transition)}.cliente-header.clickable{align-items:center;cursor:pointer;display:flex;justify-content:space-between}.cliente-header.clickable:hover{background:var(--dart);transform:translateY(-1px)}.header-content{flex:1 1}.cliente-header h3{align-items:center;display:flex;font-size:1.3rem;font-weight:600;gap:.75rem;margin:0 0 .75rem}.expand-icon{transition:transform .3s ease}.cliente-header .material-icons,.expand-icon{font-size:1.5rem}.cliente-info{display:flex;flex-wrap:wrap;gap:1.5rem}.boletas-count,.empleado-puesto{align-items:center;border-radius:var(--border-radius);color:var(--dart);display:flex;font-size:.85rem;font-weight:600;gap:.5rem;padding:.5rem 1rem}.boletas-count .material-icons,.empleado-puesto .material-icons{font-size:1rem}.expedientes-grid{grid-gap:1rem;animation:slideDown .3s ease-out;display:grid;gap:1rem;margin-top:1rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.expediente-card{background:var(--paper);border:2px solid rgba(var(--green-rgb),.1);border-radius:var(--border-radius);padding:1.5rem;position:relative;transition:var(--transition)}.expediente-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.expediente-card.estado-pendiente{background:var(--paper);border-left:4px solid #ffc107}.expediente-card.estado-pagada{border-left:4px solid var(--forest)}.expediente-card.estado-cancelada{border-left:4px solid var(--ink)}.boleta-card-header{align-items:flex-start;border-bottom:2px solid rgba(var(--green-rgb),.1);display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.boleta-periodo-info{align-items:flex-start;display:flex;flex:1 1;gap:.75rem}.boleta-periodo-info .material-icons{color:var(--forest);font-size:1.5rem;margin-top:.2rem}.periodo-details h4{color:var(--dart);font-size:1.2rem;font-weight:700;margin:0 0 .5rem}.fechas-compactas{display:flex;flex-wrap:wrap;gap:1rem}.fechas-compactas span{align-items:center;color:var(--ink);display:flex;font-size:.85rem;font-weight:500;gap:.25rem}.fechas-compactas .material-icons{color:var(--forest);font-size:.9rem}.status-badge{border-radius:var(--border-radius);font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:.25rem .75rem;white-space:nowrap}.status-badge.estado-pendiente{background:var(--paper);border:2px solid #ffc107;color:#ffc107}.status-badge.estado-pagada{background:var(--forest);color:var(--paper)}.status-badge.estado-cancelada{background:var(--ink);color:var(--paper)}.expediente-info{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.info-row{align-items:center;display:flex;gap:.75rem}.info-row .material-icons{color:var(--forest);flex-shrink:0;font-size:1.1rem;width:1.1rem}.info-content{align-items:center;display:flex;justify-content:space-between;width:100%}.info-label{color:var(--ink);font-weight:500}.info-value{color:var(--dart);font-size:.9rem;font-weight:600}.boleta-montos-resumen{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.monto-item{align-items:center;background:rgba(var(--green-rgb),.02);border-left:3px solid #0000;border-radius:var(--border-radius);display:flex;justify-content:space-between;padding:.75rem;transition:var(--transition)}.monto-item:hover{background:rgba(var(--green-rgb),.05);transform:translateX(2px)}.monto-item.total{background:linear-gradient(135deg,rgba(var(--forest-rgb),.1),rgba(var(--apple-rgb),.1));border-left-color:var(--forest);font-weight:600}.monto-label{align-items:center;color:var(--ink);display:flex;font-size:.9rem;font-weight:500;gap:.5rem}.monto-label .material-icons,.monto-valor{font-size:1rem}.monto-valor{font-weight:700}.monto-valor.positivo{color:var(--forest)}.monto-valor.negativo{color:#dc3545}.monto-valor.neto{color:var(--dart);font-size:1.1rem}.expediente-actions{display:flex;flex-wrap:wrap;gap:.5rem}.expediente-actions button{align-items:center;border:none;border-radius:var(--border-radius);cursor:pointer;display:flex;flex:1 1;font-size:.8rem;font-weight:600;gap:.5rem;justify-content:center;min-width:auto;padding:.5rem 1rem;transition:var(--transition)}.expediente-actions .material-icons{font-size:1rem}.btn-primary{background:var(--forest)}.btn-primary:hover{background:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-secondary{color:var(--dart)}.btn-secondary:hover{background:var(--pear);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.btn-danger{background:#dc3545}.btn-danger:hover:not(:disabled){background:#c82333;box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.btn-success{background:var(--forest);color:var(--paper)}.btn-success:hover:not(:disabled){background:var(--dart);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.expediente-actions button:disabled{background:#999;cursor:not-allowed;opacity:.6}.no-resultados{align-items:center;background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);color:var(--ink);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.no-resultados .material-icons{color:var(--forest);font-size:4rem;margin-bottom:1rem;opacity:.6}.no-resultados h3{color:var(--dart);font-size:1.3rem;margin-bottom:.5rem}.no-resultados p{color:var(--ink);font-size:1rem;margin:0}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.modal-content{animation:modalFadeIn .3s ease-out;background:var(--paper);border-radius:var(--border-radius);box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{border-bottom:2px solid #dc354533;padding:1.5rem 1.5rem 1rem}.modal-header h3{align-items:center;color:#dc3545;display:flex;font-size:1.25rem;font-weight:600;gap:.75rem;margin:0}.modal-header .material-icons{font-size:1.5rem}.modal-body{padding:1.5rem}.modal-body p{color:var(--dart);font-size:1rem;line-height:1.6;margin:0 0 1rem}.boleta-info-modal{background:rgba(var(--apple-rgb),.08);border-left:4px solid #dc3545;border-radius:var(--border-radius);margin:1rem 0;padding:1rem}.boleta-info-modal p{color:var(--ink);font-size:.9rem;margin:.5rem 0}.boleta-info-modal strong{color:var(--dart);font-weight:600}.advertencia-eliminar{background:#fff3cd;border:1px solid #ffc107;border-radius:var(--border-radius);color:#856404;font-size:.9rem!important;font-weight:600;margin-top:1rem!important;padding:.75rem;text-align:center}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem 1.5rem}.modal-footer button{border:none;border-radius:var(--border-radius);cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:var(--transition)}.btn-cancelar{background:rgba(var(--green-rgb),.1);border:2px solid rgba(var(--green-rgb),.2)!important;color:var(--dart)}.btn-cancelar:hover:not(:disabled){background:rgba(var(--green-rgb),.2);border-color:var(--forest)!important}.btn-confirmar-eliminar{background:#dc3545;color:var(--paper)}.btn-confirmar-eliminar:hover:not(:disabled){background:#c82333;box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.btn-cancelar:disabled,.btn-confirmar-eliminar:disabled{cursor:not-allowed;opacity:.6}.detalle-actions{display:flex;gap:.75rem}.detalle-actions button{align-items:center;border:none;border-radius:var(--border-radius);cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:var(--transition)}.detalle-actions .btn-danger{background:#dc3545;color:var(--paper)}.detalle-actions .btn-danger:hover:not(:disabled){background:#c82333;box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.detalle-actions .btn-danger:disabled{background:#999;cursor:not-allowed;opacity:.6}.detalle-content{display:flex;flex-direction:column;gap:2rem;margin:0 auto;max-width:1200px}.empleado-info-card{background:var(--paper);border:1px solid rgba(var(--green-rgb),.1);border-radius:16px;box-shadow:var(--shadow-soft);padding:2rem}.empleado-info-card .card-header{grid-gap:1.25rem;align-items:center;display:grid;gap:1.25rem;grid-template-columns:auto 1fr auto}.empleado-avatar{align-items:center;background:linear-gradient(135deg,var(--forest),var(--apple));border-radius:50%;color:var(--paper);display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.empleado-avatar .material-icons{font-size:1.8rem}.empleado-data h2{color:var(--dart);font-size:1.6rem;font-weight:700;line-height:1.2;margin:0 0 .75rem}.empleado-detalles{align-items:center;display:flex;gap:1rem;margin-top:.5rem}.empleado-codigo{color:var(--dart);font-size:.9rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.empleado-puesto{align-items:center;color:var(paper);display:flex;font-size:1rem;font-weight:600;gap:.5rem}.empleado-puesto .material-icons{color:var(--forest);font-size:1.1rem}.periodo-info{display:flex;flex-direction:column;gap:1rem;text-align:right}.fecha-pago,.periodo-badge{align-items:center;background:rgba(var(--forest-rgb),.1);border:1px solid rgba(var(--forest-rgb),.2);border-radius:12px;display:flex;gap:.5rem;padding:.75rem 1rem}.fecha-pago .material-icons,.periodo-badge .material-icons{color:var(--forest);font-size:1.2rem}.fecha-pago div,.periodo-badge div{align-items:flex-start;display:flex;flex-direction:column}.fecha-pago strong,.periodo-badge strong{color:var(--forest);font-size:.8rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.fecha-pago span,.periodo-badge span{color:var(--dart);font-size:1rem;font-weight:600}.calculos-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.calculo-card{background:var(--paper);border:1px solid rgba(var(--green-rgb),.1);border-radius:16px;box-shadow:var(--shadow-soft);padding:1.5rem;transition:var(--transition)}.calculo-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.calculo-card.devengado{border-left:4px solid var(--forest)}.calculo-card.descuentos{border-left:4px solid #dc3545}.calculo-card .card-header{border-bottom:2px solid rgba(var(--green-rgb),.1);margin-bottom:1.5rem;padding-bottom:1rem}.calculo-card .card-header h3{align-items:center;color:var(--dart);display:flex;font-size:1.3rem;font-weight:600;gap:.75rem;margin:0}.calculo-card.devengado .card-header .material-icons{color:var(--forest)}.calculo-card.descuentos .card-header .material-icons{color:#dc3545}.card-content{display:flex;flex-direction:column;gap:.75rem}.item-row{align-items:center;border-bottom:1px solid rgba(var(--green-rgb),.05);display:flex;justify-content:space-between;padding:.5rem 0}.item-row:last-of-type{border-bottom:none}.item-label{color:var(--ink);font-size:.95rem;font-weight:500}.item-value{color:var(--dart);font-size:.95rem;font-weight:600}.total-row{align-items:center;background:rgba(var(--forest-rgb),.05);border-radius:12px;display:flex;justify-content:space-between;margin-top:1rem;padding:1rem}.total-label{font-size:1.1rem}.total-label,.total-value{color:var(--forest);font-weight:700}.total-value{font-size:1.2rem}.total-neto-card{background:linear-gradient(135deg,var(--forest) 0,var(--dart) 100%);border-radius:20px;box-shadow:0 8px 32px rgba(var(--forest-rgb),.3);color:var(--paper);overflow:hidden;padding:2rem;position:relative;text-align:center}.total-neto-card:before{background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.neto-header{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.neto-header .material-icons{font-size:2rem}.neto-header h3{font-size:1.5rem;font-weight:600;letter-spacing:1px;margin:0;text-transform:uppercase}.neto-amount{font-size:3rem;font-weight:900;margin:1rem 0;text-shadow:0 2px 4px #0003}.neto-info{margin-top:1.5rem}.dias-trabajados{align-items:center;display:flex;font-size:1.1rem;font-weight:500;gap:.5rem;justify-content:center;opacity:.9}.dias-trabajados .material-icons{font-size:1.3rem}@media (max-width:1200px){.filtros-grid{gap:1rem;grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.filtros-grid{gap:1rem;grid-template-columns:repeat(2,1fr)}.filtro-grupo{min-height:80px}}@media (max-width:1024px){.calculos-grid{gap:1.5rem;grid-template-columns:1fr}.empleado-info-card .card-header{gap:1rem;grid-template-columns:1fr;text-align:center}.periodo-info{text-align:center}}@media (max-width:768px){.modulo{padding:1rem}.module-header h1{font-size:2rem}.header-actions{align-items:stretch;flex-direction:column}.header-actions .btn-exportar,.header-actions .btn-volver{justify-content:center;width:100%}.detalle-actions{flex-direction:column;width:100%}.detalle-actions button{justify-content:center;width:100%}.detalle-content{gap:1.5rem}.calculo-card,.empleado-info-card,.total-neto-card{padding:1.5rem}.neto-amount{font-size:2.5rem}.filtros-grid{gap:1rem;grid-template-columns:1fr}.filtro-grupo{min-height:auto}.cliente-info{flex-direction:column;gap:.75rem}.boleta-card-header{align-items:flex-start;flex-direction:column;gap:1rem}.fechas-compactas{gap:.5rem}.expediente-actions,.fechas-compactas{flex-direction:column}.expediente-actions button{flex:none}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}@media (max-width:480px){.module-header h1{font-size:1.75rem}.cliente-section,.expediente-card,.filtros-section{padding:1rem}.empleado-avatar{height:50px;width:50px}.empleado-avatar .material-icons,.empleado-data h2{font-size:1.5rem}.neto-amount{font-size:2rem}.neto-header h3{font-size:1.2rem}}:root{--accent:var(--apple,#94bd17);--accent-strong:var(--forest,#00652f);--accent-soft:#dbe524;--ink:var(--ink,#1a1a1a);--muted:#6b7280;--accent-hover:#85aa14;--accent-strong-hover:#005225;--accent-light:#e3f0b8;--accent-super-light:#f1f7d8;--card-gradient:linear-gradient(135deg,#cfe9a6,#dbe524);--card-hover-gradient:linear-gradient(135deg,#bfe081,#c9d922);--green-rgb:0 101 47;--pear-rgb:219 229 36;--apple-rgb:148 189 23;--white-rgb:255 255 255;--shadow-soft:0 0.5rem 2rem rgba(var(--green-rgb),0.1);--shadow-hover:0 0.75rem 2.5rem rgba(var(--green-rgb),0.15);--shadow-sm:0 2px 8px #31822f14;--shadow-md:0 4px 12px #31822f1f;--shadow-lg:0 8px 24px #31822f24;--focus-ring:#dbe52438;--radius-sm:6px;--radius-md:12px;--radius-lg:18px;--border-radius:1.25rem;--space-xs:0.5rem;--space-sm:0.75rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-xxl:3rem;--btn-padding-y:0.875rem;--btn-padding-x:1.25rem;--btn-minw:10.5rem;--page-maxw:1300px;--page-padding:clamp(1rem,5vw,2rem);--reportes-bg:#31822f;--reportes-btn-bg:#eaf7c7;--reportes-btn-text:#072b11;--transition-fast:0.15s ease;--transition-normal:0.25s ease;--transition-bounce:0.4s cubic-bezier(0.175,0.885,0.32,1.275);--transition-smooth:0.3s cubic-bezier(0.4,0,0.2,1);--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}.page-container{background-color:#f8faf280;box-sizing:border-box;display:flex;flex-direction:column;font-family:Inter,system-ui,-apple-system,sans-serif;gap:2rem;gap:var(--space-xl);max-width:1300px;max-width:var(--page-maxw);min-height:100vh;padding:clamp(1rem,5vw,2rem);padding:var(--page-padding)}.modulo,.page-container{isolation:isolate;margin:0 auto;position:relative;z-index:0}.modulo{background-color:#fff;border:none;border-radius:18px;border-radius:var(--radius-lg);box-shadow:0 8px 24px rgba(0 101 47,.15);box-shadow:0 8px 24px rgba(var(--green-rgb),.15);max-width:1200px;overflow:hidden;padding:2rem;padding:var(--space-xl);text-align:center}@media (min-width:1200px){.modulo{max-width:1400px;padding:clamp(2rem,3vw,3rem)}.menu-cards{align-items:start;gap:clamp(1.25rem,2.5vw,2.5rem);grid-template-columns:repeat(3,minmax(220px,1fr));justify-items:center;margin:0 auto;max-width:1100px;width:100%}}.module-header{margin-bottom:1.5rem;margin-bottom:var(--space-lg);padding-bottom:.75rem;padding-bottom:var(--space-sm);position:relative}.header-decoration{background:linear-gradient(90deg,#dbe524,#94bd17,#dbe524);background:linear-gradient(90deg,var(--accent-soft),var(--accent),var(--accent-soft));border-radius:4px;bottom:0;height:4px;left:50%;position:absolute;transform:translateX(-50%);width:100%}.footer-decoration{display:flex;gap:1rem;gap:var(--space-md);justify-content:center;margin-top:2rem;margin-top:var(--space-xl)}.dot{background-color:#00652f;background-color:var(--accent-strong);border-radius:50%;height:8px;opacity:.7;width:8px}.modulo h1{color:#1a1a1a;color:var(--ink);font-size:clamp(2rem,4vw,2.75rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:1rem;margin-bottom:var(--space-md)}.module-description{color:#6b7280;color:var(--muted);font-size:1.125rem;line-height:1.6;margin:0 auto 2rem;margin:0 auto var(--space-xl);max-width:800px}.cards-container{grid-gap:2rem;grid-gap:var(--space-xl);gap:2rem;gap:var(--space-xl);grid-template-columns:1fr;isolation:isolate;margin-top:1.5rem;margin-top:var(--space-lg);position:relative;z-index:0}.card-section{background-color:initial;border-radius:12px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--space-lg);position:relative;transition:transform .25s ease;transition:transform var(--transition-normal)}.card-section:hover{transform:translateY(-2px)}.card-section h2{color:#00652f;color:var(--accent-strong);display:inline-block;font-size:1.5rem;font-weight:600;margin-bottom:1rem;margin-bottom:var(--space-md);padding-bottom:.5rem;padding-bottom:var(--space-xs);position:relative}.card-section h2:after{background:#94bd17;background:var(--accent);border-radius:2px;bottom:0;content:"";height:3px;left:0;position:absolute;width:100%}.reportes-section{background-color:initial}.reportes-section h2{color:#00652f;color:var(--accent-strong)}.reportes-section h2:after{background:#00652f;background:var(--accent-strong)}.menu-cards{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));isolation:isolate;justify-content:center;position:relative;z-index:0}.menu-card{-webkit-touch-callout:none;-webkit-tap-highlight-color:rgba(0 101 47,.15);-webkit-tap-highlight-color:rgba(var(--green-rgb),.15);align-items:center;background:linear-gradient(135deg,#cfe9a6,#dbe524);background:var(--card-gradient);border:none;border-radius:18px;border-radius:var(--radius-lg);box-shadow:0 .5rem 2rem rgba(0 101 47,.1);box-shadow:var(--shadow-soft);color:#00652f;color:var(--accent-strong);cursor:pointer;display:flex;flex-direction:column;font-weight:600;gap:.75rem;gap:var(--space-sm);min-height:160px;overflow:visible;padding:1.5rem 1rem;padding:var(--space-lg) var(--space-md);position:relative;text-align:center;touch-action:manipulation;transform-style:flat!important;transition:transform .3s ease,box-shadow .3s ease,background-color .3s ease;user-select:none;-webkit-user-select:none;width:100%;will-change:transform;z-index:10}.menu-card:before{background:linear-gradient(90deg,#0000,rgba(255 255 255,.4),#0000);background:linear-gradient(90deg,#0000,rgba(var(--white-rgb),.4),#0000);content:"";height:1px;left:0;pointer-events:none!important;position:absolute;right:0;top:0;transition:background-position .7s cubic-bezier(.2,.8,.2,1)}.menu-card:hover{background:linear-gradient(135deg,#bfe081,#c9d922);background:var(--card-hover-gradient);box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15);box-shadow:var(--shadow-hover);perspective:50rem;transform:translateY(-2px) scale(1.01);transform-style:preserve-3d}.menu-card:active{box-shadow:0 .5rem 2rem rgba(0 101 47,.1);box-shadow:var(--shadow-soft);transform:translateY(1px);transition:transform .12s ease}.menu-card .material-icons{transition:transform .35s cubic-bezier(.2,.8,.2,1),all .25s ease;transition:transform .35s cubic-bezier(.2,.8,.2,1),all var(--transition-normal)}.menu-card:hover .material-icons{transform:translateZ(.6rem) scale(1.06) rotate(-2deg)}.menu-card:hover span:not(.material-icons){color:var(--forest);transform:translateY(-4px)}@media (prefers-reduced-motion:reduce){.menu-card,.menu-card .material-icons,.menu-card span:not(.material-icons){animation:none!important;transform:none!important;transition:none!important}.menu-card:hover{transform:none!important}}.report-card{background:linear-gradient(135deg,#cfe9a6,#dbe524);background:var(--card-gradient);box-shadow:0 .5rem 2rem rgba(0 101 47,.1);box-shadow:var(--shadow-soft);color:#00652f;color:var(--accent-strong)}.report-card:hover{background:linear-gradient(135deg,#bfe081,#c9d922);background:var(--card-hover-gradient);box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15);box-shadow:var(--shadow-hover)}.icon-container{align-items:center;display:flex;filter:drop-shadow(0 .15rem .4rem rgba(0 101 47,.08));filter:drop-shadow(0 .15rem .4rem rgba(var(--green-rgb),.08));height:70px;justify-content:center;margin-bottom:.75rem;margin-bottom:var(--space-sm);pointer-events:none;position:relative;width:70px}.menu-card .material-icons{font-size:36px;pointer-events:none;transition:all .25s ease;transition:all var(--transition-normal)}.menu-card .material-icons,.menu-card span:not(.material-icons),.report-card .material-icons{color:#00652f;color:var(--accent-strong)}.menu-card span:not(.material-icons){font-size:1.125rem;font-weight:600;letter-spacing:-.01em;line-height:1.3;pointer-events:none;text-shadow:0 1px 2px #0000001a;transition:transform .32s cubic-bezier(.2,.8,.2,1),color .25s ease}.menu-card:hover span:not(.material-icons){color:#00652f;color:var(--accent-strong)}.menu-card{animation:fadeInUp .6s ease-out both}.menu-card:first-child{animation-delay:.1s}.menu-card:nth-child(2){animation-delay:.2s}.menu-card:nth-child(3){animation-delay:.3s}.menu-card:nth-child(4){animation-delay:.4s}.menu-card:after{background:#fff6;border-radius:50%;content:"";height:0;left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .28s cubic-bezier(.2,.9,.2,1);width:0}.menu-card:active:after{height:120%;opacity:1;transition:all .12s ease;width:120%}.timestamp{border-top:1px solid #0000000d;color:#6b7280;color:var(--muted);font-size:.875rem;margin-top:1rem;margin-top:var(--space-md);padding-top:1rem;padding-top:var(--space-md);text-align:center}.menu-card:focus{box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15),0 0 0 3px #00652f4d;box-shadow:var(--shadow-hover),0 0 0 3px #00652f4d;outline:none}.menu-card:focus-visible{box-shadow:0 .75rem 2.5rem rgba(0 101 47,.15),0 0 0 3px #94bd174d;box-shadow:var(--shadow-hover),0 0 0 3px #94bd174d;outline:3px solid #94bd17;outline:3px solid var(--apple,#94bd17);outline-offset:2px}.menu-card:focus-visible:before{background:linear-gradient(90deg,#0000,#94bd1799,#0000);height:2px}@media (hover:none) and (pointer:coarse){.menu-card{-webkit-tap-highlight-color:rgba(0,101,47,.15);-webkit-backdrop-filter:none!important;backdrop-filter:none!important;cursor:pointer;perspective:none!important;pointer-events:auto!important;position:relative;touch-action:manipulation;transform:none!important;transform-style:flat!important;transition:opacity .25s ease!important;user-select:none;-webkit-user-select:none;z-index:5}.menu-card:after,.menu-card:before{display:none!important}.menu-card:hover{background:linear-gradient(135deg,#cfe9a6,#dbe524)!important;background:var(--card-gradient)!important;box-shadow:0 .5rem 2rem rgba(0 101 47,.1)!important;box-shadow:var(--shadow-soft)!important;transform:none!important}.menu-card:active{background:linear-gradient(135deg,#bfe081,#c9d922)!important;background:var(--card-hover-gradient)!important;opacity:.8;transition:opacity .1s ease-out!important}.icon-container,.menu-card .material-icons,.menu-card span:not(.material-icons){animation:none!important;pointer-events:none!important;transform:none!important;transition:none!important}.icon-container,.menu-card span:not(.material-icons){position:relative;z-index:1}}@media (max-width:900px){.menu-card{-webkit-tap-highlight-color:rgba(0,0,0,0);touch-action:manipulation}.cards-container{gap:1.5rem;gap:var(--space-lg);grid-template-columns:1fr}.card-section{margin-bottom:1rem;margin-bottom:var(--space-md)}.menu-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.modulo{border-radius:12px;border-radius:var(--radius-md);margin:0 .5rem;margin:0 var(--space-xs);padding:1.5rem;padding:var(--space-lg);width:calc(100% - 1rem);width:calc(100% - var(--space-xs)*2)}.menu-cards{gap:1rem;gap:var(--space-md);grid-template-columns:repeat(2,1fr)}.menu-card{-webkit-tap-highlight-color:rgba(0,101,47,.15);-webkit-backdrop-filter:none;backdrop-filter:none;margin:8px;min-height:130px;padding:1rem;padding:var(--space-md);position:relative;transform:none!important;transform-style:flat!important;user-select:none;-webkit-user-select:none;will-change:opacity;z-index:10}.icon-container{height:60px;margin-bottom:.5rem;margin-bottom:var(--space-xs);pointer-events:none;position:relative;width:60px}.menu-card .material-icons{font-size:32px;pointer-events:none}.menu-card:after,.menu-card:before{display:none!important}.menu-card:active,.menu-card:hover{box-shadow:0 .5rem 2rem rgba(0 101 47,.1)!important;box-shadow:var(--shadow-soft)!important;transform:none!important}.menu-card:active{background:linear-gradient(135deg,#bfe081,#c9d922)!important;background:var(--card-hover-gradient)!important;opacity:.75}.menu-card span:not(.material-icons){pointer-events:none}}@media (max-width:600px){.menu-cards{gap:.75rem;gap:var(--space-sm);grid-template-columns:1fr}.menu-card{-webkit-tap-highlight-color:rgba(0,101,47,.15);-webkit-touch-callout:none;background:linear-gradient(135deg,#cfe9a6,#dbe524)!important;background:var(--card-gradient)!important;border:none;border-radius:12px;box-shadow:0 4px 12px #00652f1a!important;cursor:pointer;flex-direction:row;gap:1rem;gap:var(--space-md);justify-content:flex-start;margin:8px 0;min-height:80px;padding:12px;position:relative;text-align:left;touch-action:manipulation;transition:background-color .2s ease!important;user-select:none;-webkit-user-select:none;width:100%;z-index:20}.menu-card:focus{box-shadow:0 0 0 3px #94bd17!important;box-shadow:0 0 0 3px var(--accent)!important;outline:none}.icon-container{align-items:center;display:flex;flex:0 0 48px;height:48px!important;justify-content:center;margin:0;pointer-events:none;width:48px!important}.menu-card .material-icons{font-size:28px;pointer-events:none}.menu-card span:not(.material-icons){font-size:1rem;font-weight:600;pointer-events:none;text-shadow:none}.menu-card:after,.menu-card:before{display:none!important}.menu-card:active{background:linear-gradient(135deg,#bfe081,#c9d922)!important;background:var(--card-hover-gradient)!important;opacity:.8;transform:translateY(1px)!important;transition:all .1s ease-out!important}}@media (max-width:480px){.page-container{box-sizing:border-box;padding:.5rem;padding:var(--space-xs);padding-left:max(env(safe-area-inset-left),.5rem);padding-left:max(env(safe-area-inset-left),var(--space-xs));padding-right:max(env(safe-area-inset-right),.5rem);padding-right:max(env(safe-area-inset-right),var(--space-xs))}.modulo{border-radius:12px;border-radius:var(--radius-md);box-sizing:border-box;margin:0 auto;overflow:visible;padding:1rem;padding:calc(var(--space-sm) + .25rem);width:100%}.modulo h1{font-size:1.5rem}.module-description{font-size:.95rem;margin-bottom:1rem;margin-bottom:var(--space-md);padding:0}.module-header{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;gap:.5rem;justify-content:flex-start;margin-bottom:.5rem;margin-bottom:calc(var(--space-sm) - .25rem);padding-bottom:.5rem;padding-top:.25rem;position:relative;width:100%}.module-header h1{font-size:1.4rem;line-height:1.15;margin:0;overflow-wrap:anywhere;padding:0 .5rem;text-align:center;word-break:break-word}.header-decoration{bottom:auto;height:3px;left:50%;margin-top:6px;max-width:220px;position:relative;transform:translateX(-50%);width:min(80%,220px)}.card-section{padding:.75rem;padding:var(--space-sm)}.card-section h2{font-size:1.2rem;margin-bottom:.75rem;margin-bottom:var(--space-sm)}.menu-card{background-color:#e3f0b8!important;background-color:var(--accent-light)!important;background-image:linear-gradient(135deg,#cfe9a6,#dbe524)!important;border-radius:10px;box-shadow:0 4px 8px #00652f1f!important;gap:10px;min-height:70px;padding:10px 12px}.icon-container{flex:0 0 40px;height:40px!important;width:40px!important}.menu-card .material-icons{font-size:22px}.menu-card:focus,.menu-card:hover{box-shadow:0 .5rem 2rem rgba(0 101 47,.1)!important;box-shadow:var(--shadow-soft)!important;transform:none!important}.menu-card:active{background:linear-gradient(135deg,#bfe081,#c9d922)!important;background:var(--card-hover-gradient)!important;opacity:.85;transform:translateY(1px)!important;transition:all .1s ease-out!important}.menu-card:focus-visible{outline:2px solid #00652f;outline:2px solid var(--accent-strong);outline-offset:2px}}@media (max-width:360px){.modulo h1{font-size:clamp(1.1rem,8vw,1.6rem)}.module-description{font-size:.9rem}.menu-card{border-radius:.7rem;padding:.8rem .9rem}.icon-container{height:1.8rem;width:1.8rem}}@media (max-width:1024px){.page-container{box-sizing:border-box;padding-top:calc(72px + .5rem)!important;padding-top:calc(72px + var(--space-xs))!important}.modulo{margin-top:0!important}}.exp-layout{grid-gap:1.5rem;background:var(--bg);box-sizing:border-box;display:grid;gap:1.5rem;grid-template-columns:280px 1fr;max-width:100vw;min-height:100%;overflow-x:hidden;padding:clamp(16px,2vw,24px)}.btn.primary{background:linear-gradient(135deg,var(--forest) 0,var(--dart) 100%);border-radius:10px;display:inline-flex;padding:.7rem 1.2rem}.btn.primary:hover{transform:translateY(-3px)}.table th{background:linear-gradient(90deg,#eaf7c7,#dbe524);box-shadow:inset 0 -2px 0 #00000008}.table tbody tr:focus-within,.table tbody tr:hover{background:linear-gradient(180deg,#fbfff8,#f6fff0);box-shadow:0 6px 0 #31822f0f}@media (max-width:480px){.exp-card .btn{margin:.4rem 0;width:100%}.exp-card{align-items:stretch}}.exp-cta-group{grid-gap:.75rem;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;align-items:center;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));justify-items:center;padding:.5rem 0;width:100%}.table-wrap{box-sizing:border-box;max-height:calc(100vh - 230px);max-height:calc(100vh - var(--navbar-height, 230px));max-width:100%;overflow-y:auto}@media (max-width:479px){.table-wrap{max-width:100%!important;overflow-x:visible!important;width:100%!important}}.exp-title{color:var(--dart);font-size:1.25rem;font-weight:800;margin-bottom:1rem}.exp-list{display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 230px);max-height:calc(100vh - var(--navbar-height, 230px));overflow-y:auto}.exp-item{background:linear-gradient(180deg,#fff,#fbfffa);border:2px solid var(--border);border-radius:12px;cursor:pointer;padding:.65rem .9rem;transition:background-color .2s ease,border-color .2s ease,transform .08s ease}.exp-item:hover{background:linear-gradient(90deg,#f2f7e6,#eef9e6);border-color:var(--apple);transform:translateY(-2px)}.exp-item.active{background:linear-gradient(90deg,var(--pear) 0,#f7fbd8 100%);border-color:var(--forest);box-shadow:0 6px 12px #31822f0f;color:var(--ink);font-weight:700}.exp-item span.small{color:#666;display:block;font-size:.85rem}.exp-tabs{-webkit-overflow-scrolling:touch;align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;overflow-x:auto}.exp-tabs .exp-tab{flex:0 0 auto}.exp-tab{background:linear-gradient(180deg,var(--paper) 0,#fbfffa 100%);border:2px solid var(--border);border-radius:10px;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:transform .12s ease,background .18s ease}.exp-tab:hover{transform:translateY(-2px)}.exp-tab.active{background:linear-gradient(135deg,var(--apple) 0,#dbe524 100%);border-color:var(--forest);box-shadow:0 8px 20px #31822f14;color:var(--paper);transform:translateY(-3px)}.btn{background:linear-gradient(135deg,var(--apple) 0,var(--pear) 100%);color:var(--dart)}.btn span,.btn svg{display:inline-block;vertical-align:middle}.btn.primary{align-items:center;background:#a4ca20;border:none;border-radius:5px;display:flex;font-size:1rem;font-weight:600;justify-content:center;max-width:360px;min-height:40px;padding:.75rem 1.25rem;text-align:center;text-decoration:none;transition:background-color .2s ease,transform .1s ease;width:auto}.btn.primary:hover{background:#8fb61c;transform:translateY(-1px)}.btn.primary:active{transform:translateY(1px)}.btn.primary:focus{box-shadow:0 0 0 3px #a4ca2066;outline:none}.btn svg{flex:0 0 auto;height:1rem;margin-right:.5rem;width:1rem}@media (min-width:1201px){.exp-cta-group .btn{justify-content:center;max-width:18rem;width:100%}}.exp-cta-sticky-wrapper{background:#0000;margin-bottom:.25rem;padding-top:.25rem;position:-webkit-sticky;position:sticky;top:64px;top:calc(var(--navbar-height, 56px) + 8px);z-index:8}.table{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;table-layout:auto}.table td,.table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table th{border:1px solid #ddd;padding:.6rem;text-align:left}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}@media (min-width:601px) and (max-width:768px){.table td,.table th{font-size:.9rem;padding:.45rem .4rem;white-space:normal;word-break:break-word}.table{min-width:0;table-layout:fixed;width:100%}.table td:first-child,.table th:first-child{width:15%}.table td:nth-child(2),.table th:nth-child(2){width:12%}.table td:nth-child(3),.table td:nth-child(4),.table th:nth-child(3),.table th:nth-child(4){width:15%}.table td:nth-child(5),.table th:nth-child(5){width:10%}.table td:nth-child(6),.table th:nth-child(6){width:13%}.table td:nth-child(7),.table th:nth-child(7){width:12%}.table td:nth-child(8),.table th:nth-child(8){width:8%}}@media (min-width:480px) and (max-width:600px){.table{font-size:.85rem;table-layout:fixed;width:100%}.table td,.table th{overflow:hidden;padding:.4rem .3rem;text-overflow:ellipsis;white-space:nowrap}.table td:nth-child(5),.table td:nth-child(6),.table th:nth-child(5),.table th:nth-child(6){display:none}}@media (max-width:479px){.table{border:none;display:block!important;min-width:0!important;table-layout:auto!important;width:100%!important}.table thead{display:none!important}.table tbody,.table tr{display:block!important;width:100%!important}.table tr{background:var(--paper);border:1px solid #0000000a;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:1rem;padding:.75rem}.table td{align-items:flex-start;border:none!important;border-bottom:1px dashed #0000000f!important;box-sizing:border-box;display:flex!important;justify-content:space-between;min-height:32px;overflow:visible!important;padding:.5rem 0;white-space:normal!important;width:100%!important}.table td:last-child{border-bottom:none!important;border-top:1px solid #0000000f!important;justify-content:center;margin-top:.5rem;padding-bottom:0;padding-top:.5rem}.table td:first-child:before{color:var(--dart);content:"Puesto";font-weight:700;margin-right:.5rem}.table td:nth-child(2):before{color:var(--dart);content:"Inicio";font-weight:700;margin-right:.5rem}.table td:nth-child(3):before{color:var(--dart);content:"Salario";font-weight:700;margin-right:.5rem}.table td:nth-child(4):before{color:var(--dart);content:"Jornada";font-weight:700;margin-right:.5rem}.table td:nth-child(5):before{color:var(--dart);content:"Horas";font-weight:700;margin-right:.5rem}.table td:nth-child(6):before{color:var(--dart);content:"Plazo";font-weight:700;margin-right:.5rem}.table td:nth-child(7):before{color:var(--dart);content:"Estado";font-weight:700;margin-right:.5rem}.table td:before{width:35%}.table td span,.table td:before{display:inline-block;white-space:nowrap}.table td span{color:var(--text);overflow:hidden;text-align:right;text-overflow:ellipsis;width:60%}.table td:before{flex:0 0 35%}}@media (min-width:992px){.exp-cta-group{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:0 auto;max-width:1100px;width:90%}.exp-cta-group .btn.primary{font-size:1.05rem;max-width:360px;min-height:45px}}@media (min-width:768px) and (max-width:991px){.exp-cta-group{gap:.875rem;grid-template-columns:repeat(2,minmax(200px,1fr));margin:0 auto;max-width:900px;width:92%}.exp-cta-group .btn.primary{max-width:320px}}@media (min-width:576px) and (max-width:767px){.exp-cta-group{gap:.75rem;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:760px;width:96%}.exp-cta-group .btn.primary{max-width:none;min-height:42px}}@media (max-width:575px){.exp-cta-group{gap:.6rem;grid-template-columns:1fr;margin:0 auto;padding:.5rem 0;width:100%}.exp-cta-group .btn.primary{font-size:1rem;max-width:none;min-height:46px;width:100%}}@media (max-width:375px){.exp-cta-group{gap:.5rem;padding-left:.5rem;padding-right:.5rem}.exp-cta-group .btn.primary{font-size:.95rem;min-height:40px}}@media (hover:none) and (pointer:coarse){.btn.primary:hover{background:#a4ca20;transform:none}.btn.primary:active{background:#8fb61c;transform:scale(.98)}}.table tbody tr{cursor:pointer;position:relative;transition:background-color .12s ease,transform .06s ease,box-shadow .06s ease}.table tbody tr:focus-within,.table tbody tr:hover{background:linear-gradient(90deg,#eaf7c799,#eaf7c740);box-shadow:0 6px 0 var(--shadow);transform:translateY(-1px)}.row-actions{padding:.4rem;vertical-align:middle;white-space:nowrap;width:1%}.row-actions .actions{align-items:center;display:flex;gap:.5rem;opacity:0;pointer-events:none;transform:translateX(6px);transition:opacity .12s ease,transform .12s ease}.table tbody tr:focus-within .row-actions .actions,.table tbody tr:hover .row-actions .actions{opacity:1;pointer-events:auto;transform:translateX(0)}.row-actions .btn{background:var(--accent);border:none;border-radius:10px;color:var(--paper);cursor:pointer;font-weight:700;padding:.45rem .7rem;transition:opacity .08s linear,transform .06s linear}.row-actions .btn:active{transform:translateY(1px)}.row-actions .btn.secondary{background:#0000000f;border-radius:8px;color:var(--text);padding:.4rem .6rem}.row-actions .btn.mintrab{background:var(--accent-strong)}.row-actions .btn[disabled]{cursor:not-allowed;opacity:.45}.row-actions .btn:focus{border-radius:10px;box-shadow:0 0 0 4px var(--focus-ring);outline:none}@media (max-width:640px){.row-actions .btn{font-size:.9rem;padding:.35rem .5rem}}.small{color:#777;font-size:.9rem}.expirado{color:red;font-weight:700}@media (max-width:900px){.exp-card{margin:0 auto;max-width:56rem}.exp-title{text-align:center}.exp-tabs{-webkit-overflow-scrolling:touch;justify-content:center;overflow-x:auto}.exp-tabs .exp-tab{flex:0 0 auto}.btn.cta,.btn.primary{justify-content:center;max-width:none;width:100%}.exp-list{max-height:calc(100vh - 300px)}}@media (max-width:1366px) and (min-width:1025px){.exp-layout{gap:1rem;grid-template-columns:240px 1fr}.exp-card{margin:0 auto;max-width:calc(100% - 40px)}}@media (max-width:1024px) and (min-width:600px){.exp-layout{gap:.75rem;grid-template-columns:1fr}.exp-list{display:flex;flex-direction:row;gap:.5rem;max-height:none;overflow-x:auto;padding:.25rem 0}.exp-item{flex:0 0 auto;min-width:160px;width:auto}.exp-card{padding:.75rem}}@media (max-width:480px){.exp-layout{grid-template-columns:1fr;padding:0;width:100vw}.exp-card,.exp-layout{margin:0;overflow-x:hidden}.exp-card{border-radius:0;box-sizing:border-box;max-width:100%;padding:.9rem .9rem 1.25rem;width:100%}.exp-title{font-size:1.05rem}.exp-item{padding:.5rem}.exp-tabs{gap:.5rem}.row-actions .actions{opacity:1;pointer-events:auto;position:static;transform:none}.btn{width:100%}}@media (max-width:420px){.exp-layout{padding-left:env(safe-area-inset-left,8px);padding-right:env(safe-area-inset-right,8px)}.exp-card{padding-left:12px;padding-right:12px}.exp-cta-group{gap:.5rem}}@media (max-width:360px){.exp-item,.exp-title{font-size:.95rem}.exp-item{padding:.45rem}}@media (min-width:1024px) and (max-height:600px){.exp-layout{gap:.75rem;grid-template-columns:200px 1fr;padding:12px}.exp-list{max-height:400px}.exp-cta-group{gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media (min-width:800px) and (max-width:900px) and (min-height:1600px){.exp-layout{gap:1rem;grid-template-columns:1fr}.exp-list{display:flex;flex-direction:row;max-height:none;overflow-x:auto}.exp-cta-group{grid-template-columns:repeat(2,1fr);max-width:100%}}@media (min-width:540px) and (max-width:720px) and (min-height:700px){.exp-layout{gap:.75rem;grid-template-columns:1fr}.exp-cta-group{grid-template-columns:repeat(2,1fr);width:100%}}@media (min-width:393px) and (max-width:450px) and (min-height:850px){.exp-cta-group .btn.primary{font-size:1rem;min-height:48px}.exp-item{min-height:52px}}@media (min-width:1400px){.exp-layout{grid-template-columns:320px 1fr;margin:0 auto;max-width:1800px}.exp-cta-group{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));max-width:1200px}}@media (min-width:481px) and (max-width:900px) and (orientation:landscape){.exp-layout{gap:1rem;grid-template-columns:200px 1fr}.exp-list{max-height:calc(100vh - 220px)}}@media (hover:none) and (pointer:coarse){.exp-item:hover{box-shadow:none;transform:none}.btn:hover{transform:none}.btn,.exp-item,.exp-tab{min-height:44px}.row-actions .btn{min-height:40px;min-width:40px}}.satl-modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:rgba(var(--black-rgb),.35);display:grid;inset:0;place-items:center;position:fixed;z-index:1000}.satl-modal{animation:satl-pop .18s ease-out;background:var(--paper);border:1px solid rgba(var(--black-rgb),.12);border-radius:var(--border-radius);box-shadow:var(--shadow-hover);max-height:85vh;overflow:auto;width:min(800px,92vw)}@keyframes satl-pop{0%{opacity:.6;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.satl-modal-header{align-items:center;background:var(--card-gradient);border-bottom:1px solid rgba(var(--black-rgb),.08);border-top-left-radius:var(--border-radius);border-top-right-radius:var(--border-radius);display:flex;justify-content:space-between;padding:.85rem 1rem}.satl-modal-header h3{color:var(--dart);margin:0}.satl-modal-close{background:#0000;border:none;color:var(--ink);cursor:pointer;font-size:1.25rem}.satl-modal-content{padding:1rem}.rec-detail{grid-gap:.75rem;display:grid;gap:.75rem}.rec-title{color:var(--forest);margin:0}.rec-sub{color:rgba(var(--black-rgb),.75);display:flex;flex-wrap:wrap;gap:.75rem}.rec-desc{color:rgba(var(--black-rgb),.8)}.rec-items{grid-gap:.5rem;display:grid;gap:.5rem}.rec-item{background:#fff;border:1px solid rgba(var(--black-rgb),.12);border-radius:.75rem;padding:.6rem .8rem}.rec-item .rec-item-line{display:flex;flex-wrap:wrap;gap:.5rem}.rec-detail input,.rec-detail select,.rec-detail textarea{background:var(--paper);border:1px solid rgba(var(--black-rgb),.12);border-radius:.75rem;color:var(--ink);outline:none;padding:.55rem .7rem;transition:var(--transition)}.rec-detail textarea{word-wrap:break-word;box-sizing:border-box;display:block;max-width:80%;min-height:150px;min-width:80%;overflow:auto;resize:horizontal;white-space:pre-wrap;width:80%}.input-titulo{width:60%}.rec-detail input:focus,.rec-detail select:focus,.rec-detail textarea:focus{border-color:var(--accent);box-shadow:0 0 0 .22rem var(--focus-ring)}.rec-der{display:flex;justify-content:flex-end;width:60%}.der{cursor:pointer;padding:.5rem 1rem}.satl-error{color:#b51f1f}.XL{width:min(1200px,92vw)}.chip-warn{background-color:#f443361f;border:1px solid #f443364d;color:#b00020}.doc-page{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.doc-page h1{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 .75rem}.doc-list{grid-gap:.75rem;gap:.75rem;margin-bottom:1.25rem;max-width:980px}.doc-card{background:#eaf7c7;background:var(--card);border-left:8px solid #94bd17;border-left:8px solid var(--apple);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;gap:1rem;justify-content:space-between;padding:.9rem 1rem}.doc-card-main{grid-gap:.2rem;gap:.2rem}.doc-title{color:#00652f;font-size:1.1rem;font-weight:800}.doc-meta{color:#355a34;font-size:.95rem}.doc-actions{display:flex;gap:.5rem}.btn-edit:hover{opacity:.95}.btn-danger{background:#c62828;background:var(--danger);color:var(--paper)}.btn-danger:hover{opacity:.95}.doc-subtitle{color:#1a1a1a;color:var(--ink);font-weight:800;margin:1.25rem 0 .75rem}.doc-form{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);max-width:1100px;padding:clamp(14px,1.8vw,20px)}.doc-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(3,minmax(220px,1fr))}@media(max-width:1024px){.doc-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media(max-width:640px){.doc-grid{grid-template-columns:1fr}}.doc-field label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.doc-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:90%}.doc-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.doc-actions-bar{display:flex;gap:.6rem;margin-top:.9rem}.btn-save{background:#00652f;background:var(--dart);color:#fff;color:var(--paper)}.btn-cancel{background:#e8f2d6;border:2px solid #c7df9b;color:#214b25}.divider{background:#e3edd3;height:1px;margin:1rem 0}.small{color:#555}.doc-field{display:flex;flex-direction:column;margin-bottom:1.5rem}.doc-field label{color:#333;font-weight:600;margin-bottom:.5rem}.doc-field input[type=file]{background-color:#fff;border:1px solid #ccc;border-radius:6px;font-size:.95rem;padding:.6rem;transition:border-color .3s ease}.doc-field input[type=file]:hover{border-color:#007bff}.doc-field input[type=file]:focus{border-color:#0056b3;box-shadow:0 0 0 2px #007bff40;outline:none}.expirado-line{color:red;display:inline;font-weight:700}.mt-container{background:#f9f9f6;background:var(--bg);min-height:100%;padding:clamp(16px,2.4vw,32px)}.mt-container h2{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0 0 1rem}.mt-grid{display:flex;flex-direction:column;gap:2rem;padding:1rem}@media (max-width:1000px){.mt-grid{grid-template-columns:1fr}}.form-card{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:14px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);display:flex;flex-direction:column;gap:.9rem;padding:clamp(14px,1.6vw,20px)}.form-row label{color:#355a34;display:block;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.form-row input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border-radius:12px;font-size:1rem;outline:none;padding:.65rem .75rem;transition:border-color .15s ease,box-shadow .15s ease;width:92%}.form-row input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.form-actions{gap:.6rem;margin-top:.5rem}.btn{padding:.55rem .9rem}.btn.primary{background:#00652f;background:var(--dart);box-shadow:0 2px 0 #064424;color:var(--paper)}.btn:hover{opacity:.95}.small{color:#666;font-size:.85rem}.btn.btn-delete{background:#c62828;background:var(--danger);box-shadow:0 1px 0 #8e1e1e;color:#fff;color:var(--paper)}.btn.btn-delete:hover{opacity:.9}.list-card{background:#fff;background:var(--paper);border:2px solid #e3edd3;border-radius:14px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);padding:.5rem}.list-card-header{align-items:center;display:flex;justify-content:center;margin-bottom:1rem;text-align:center}.list-card-header h3{color:#1a1a1a;color:var(--ink);font-weight:800;margin:0}.table td,.table th{border:1px solid #ddd;padding:.6rem}.table th{background:#f2f7e6;color:#00652f;color:var(--dart);font-weight:700}.table tr:nth-child(2n){background:#fafafa}.actions{display:flex;gap:.5rem}.actas-container{background:#f9f9f6;background:var(--bg);min-height:100vh;padding:clamp(16px,2.4vw,32px)}.actas-container h1{color:#1a1a1a;color:var(--ink);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;margin:0 0 1.5rem}.actas-layout{display:flex;flex-direction:column;gap:2rem}@media (min-width:1200px){.actas-layout{grid-template-columns:1fr 1.8fr}}.form-section{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--border);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);height:-webkit-fit-content;height:fit-content;padding:clamp(16px,2vw,24px)}.form-header{align-items:center;border-bottom:1px solid #dde5cc;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.form-header h3{color:#00652f;color:var(--dart);font-size:clamp(1.1rem,1.4vw,1.3rem);font-weight:800;margin:0}.editing-badge{background:#94bd17;background:var(--apple);border-radius:8px;color:#fff;color:var(--paper);font-size:.8rem;font-weight:700;padding:.3rem .7rem}.message{border-left:4px solid;border-radius:12px;font-weight:600;margin-bottom:1rem;padding:.8rem 1rem}.message.success{background:#e8f5e8;border-color:#2e7d32;border-color:var(--success);color:#2e7d32;color:var(--success)}.message.error{background:#ffebee;border-color:#c62828;border-color:var(--danger);color:#c62828;color:var(--danger)}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}@media (min-width:1400px){.form-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.form-grid{grid-template-columns:1fr}}.form-field{display:flex;flex-direction:column;gap:.4rem}.form-field-full{grid-column:1/-1}.form-field label{color:#31822f;color:var(--forest);font-size:.9rem;font-weight:700;margin-bottom:.2rem}.form-input,.form-textarea{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--border);border-radius:12px;font-family:inherit;font-size:1rem;outline:none;padding:.7rem .8rem;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus,.form-textarea:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.form-input.error,.form-textarea.error{border-color:#c62828;border-color:var(--danger);box-shadow:0 0 0 3px #c6282833}.form-textarea{max-height:200px;min-height:100px}select.form-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23666' d='M6 8 2 4h8z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;cursor:pointer;padding-right:35px}select.form-input:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%2394bd17' d='M6 8 2 4h8z'/%3E%3C/svg%3E")}.char-counter{color:#666;font-size:.8rem;margin-top:.25rem;text-align:right}.field-error{color:#c62828;color:var(--danger);font-size:.85rem;font-weight:600;margin-top:.25rem}.form-actions{border-top:1px solid #dde5cc;border-top:1px solid var(--border);flex-wrap:wrap;gap:.8rem;padding-top:1rem}.btn{-webkit-appearance:none;appearance:none;font-family:inherit;font-size:.95rem;padding:.7rem 1.2rem;transition:transform .12s ease,opacity .12s ease}.btn:active{transform:translateY(1px)}.btn-primary{background:#00652f;background:var(--dart);box-shadow:0 2px 0 #064424;color:var(--paper)}.btn-primary:hover{opacity:.95}.btn-secondary{background:#94bd17;background:var(--apple);box-shadow:0 2px 0 #7da614;color:var(--paper)}.btn-secondary:hover{opacity:.95}.list-section{overflow:hidden}.total-records{padding:.3rem .7rem}.table-container{max-height:calc(100vh - 300px)}.actas-table{background:#fff;background:var(--paper);border-collapse:collapse;font-size:.9rem;width:100%}.actas-table th{background:#eaf7c7;background:var(--card);border-bottom:2px solid #dde5cc;border-bottom:2px solid var(--border);color:#00652f;color:var(--dart);font-size:.85rem;font-weight:700;padding:.8rem .6rem;position:-webkit-sticky;position:sticky;text-align:left;top:0}.actas-table td{border-bottom:1px solid #f0f0f0;padding:.7rem .6rem;vertical-align:top}.actas-table tbody tr:hover{background:#f8fdf4}.actas-table tbody tr:nth-child(2n){background:#fbfcf8}.actas-table tbody tr:nth-child(2n):hover{background:#f8fdf4}.grado-badge,.tipo-badge{font-size:.8rem}.justification-cell{max-width:250px}.actions{text-align:right;white-space:nowrap}.actions .btn{font-size:.8rem;margin-left:.3rem;padding:.4rem .7rem}.btn-edit{background:#31822f;background:var(--forest);box-shadow:0 1px 0 #216423;color:#fff;color:var(--paper)}.btn-edit:hover{opacity:.9}.btn btn-delete{background:#c62828;background:var(--danger);box-shadow:0 1px 0 #8e1e1e;color:#fff;color:var(--paper)}.btn btn-delete:hover{opacity:.9}.loading,.no-records{padding:2rem}.no-records{color:#666;font-style:italic;text-align:center}@media (max-width:1024px){.actas-table{font-size:.8rem}.actas-table td,.actas-table th{padding:.5rem .4rem}.justification-cell{max-width:200px}}@media (max-width:768px){.form-actions{flex-direction:column}.btn{text-align:center}.form-header,.list-header{align-items:flex-start;flex-direction:column;gap:.8rem}.table-container{max-height:calc(100vh - 400px)}.actas-table{min-width:800px}}@media (max-width:640px){.actas-layout{gap:1rem}.actas-table{font-size:.75rem;min-width:900px}.actas-table td,.actas-table th{padding:.4rem .3rem}.actions .btn{font-size:.75rem;padding:.3rem .5rem}}.reportes-page{background:#f9f9f6;min-height:100vh;padding:1.5rem}.reportes-page h1{background-color:#20910e;background-color:var(--dartmouth-green);border-radius:8px;color:#fff;color:var(--white);font-size:1.8rem;font-weight:700;margin-bottom:1.5rem;padding:1rem}.acciones-bar{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.search-input{border-radius:10px;flex:1 1;font-size:1rem;min-width:220px;padding:.6rem 1rem}.search-input:focus{border-color:#acd401;border-color:var(--apple-green);box-shadow:0 0 0 3px #add40133}.btn{padding:.75rem 1.25rem;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease,opacity .2s ease}.seccion{animation:fadeInUp .5s ease both;background-color:#fff;border:1px solid #0000000a;border-radius:14px;box-shadow:0 8px 24px #31822f14;margin:1rem 0 2rem;padding:1.5rem}.seccion h2{color:#31822f;color:var(--forest-green);font-size:1.3rem;font-weight:700;margin-bottom:1rem}.resumen-salarios{grid-gap:.75rem;color:#1a1a1a;color:var(--text-dark);display:grid;font-size:1rem;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.table{border-collapse:collapse;font-size:.95rem;width:100%}.table td,.table th{border:1px solid #e0e0e0;padding:.6rem .75rem;text-align:left}.table tbody tr:nth-child(2n){background:#f9f9f9}.table tbody tr:hover{background:#eef7e6}.btn{border-radius:12px;font-weight:700;padding:.6rem 1.1rem;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .2s ease}.btn:hover{box-shadow:0 14px 30px #31822f1f}.btn.primary{background:linear-gradient(135deg,#31822f,#20910e);color:#fff}.btn.secondary{background:linear-gradient(135deg,#94bd17,#cfe9a6);color:#0b3b12}.reporte-card{background:linear-gradient(180deg,#fff,#fbfffa);border:1px solid #0000000a;border-radius:12px;box-shadow:0 8px 24px #31822f0f;margin-bottom:1rem;padding:1rem}.table thead{background:linear-gradient(90deg,#eaf7c7,#dbe524);box-shadow:inset 0 -2px 0 #00000008;color:#1a1a1a;color:var(--text-dark)}@media (max-width:1024px){.reportes-page{box-sizing:border-box;padding-top:calc(72px + .5rem)}.back-btn-wrap{margin-top:84px;position:relative;z-index:1200}}@media (prefers-reduced-motion:reduce){.btn,.reporte-card,.seccion{animation:none!important;transition:none!important}}.filtros{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1rem}.filtro-btn{background:#fff;border:2px solid #cbe27b;border-radius:8px;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:background .2s ease,color .2s ease}.filtro-btn.active{background:#cbe27b;color:#1a1a1a}.reporte-docs-container{background:#f9f9f6;border-radius:12px;min-height:100vh;padding:20px}.graficos{align-items:flex-start;display:flex;flex-wrap:wrap;justify-content:space-around;margin:20px 0}.grafico{box-sizing:border-box;max-width:100%;min-width:250px;overflow:hidden;width:45%}.tabla-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}.tabla-docs{border-collapse:collapse;margin-top:15px;min-width:520px;width:100%}.tabla-docs td,.tabla-docs th{border:1px solid #ddd;padding:10px;text-align:center}.reporte-docs-container h2{color:#164a18}.reporte-docs-container .page-title,.reporte-docs-container h1{background-color:#20910e;border-radius:8px;color:#fff;font-size:1.6rem;font-weight:700;margin-bottom:1rem;padding:1rem;text-align:left}.graficos{gap:1rem}.back-btn-wrap{margin-bottom:.5rem}@media (max-width:1024px){.back-btn-wrap{margin-top:84px;position:relative;z-index:1200}.back-btn-wrap .btn-save{box-shadow:0 6px 18px #0000001f}}.grafico{background:linear-gradient(180deg,#fff,#fbfffa);border-radius:12px;box-shadow:0 8px 24px #31822f0f;padding:1rem}.tabla-docs thead{background:linear-gradient(90deg,#eaf7c7,#dbe524);box-shadow:inset 0 -2px 0 #00000008;color:#1a1a1a}.btn{background:linear-gradient(135deg,#94bd17,#dbe524);border-radius:10px;box-shadow:0 8px 20px #31822f14;color:#065227;padding:.5rem .85rem;transition:transform .18s ease}.btn:hover{transform:translateY(-3px)}@media (prefers-reduced-motion:reduce){.btn,.grafico{animation:none!important;transition:none!important}}@media (max-width:1024px){.reporte-docs-container{box-sizing:border-box;padding-top:calc(72px + .5rem)}}.chart-container{height:250px;max-width:100%;overflow:hidden;position:relative;width:100%}@media (max-width:900px){.graficos{align-items:stretch;flex-direction:column;gap:1rem;overflow-x:hidden}.grafico{box-sizing:border-box;max-width:100%;min-width:0;overflow:hidden;padding:.85rem;width:100%}.reporte-docs-container .page-title,.reporte-docs-container h1{font-size:1.4rem;padding:.85rem}.chart-container{height:220px}.graficos .grafico canvas{height:auto!important;max-width:100%!important;width:100%!important}}@media (max-width:480px){.reporte-docs-container{box-sizing:border-box;max-width:100vw;overflow-x:hidden;padding:8px}.reporte-docs-container .page-title,.reporte-docs-container h1{word-wrap:break-word;font-size:1.1rem;padding:.5rem}.reporte-docs-container h2{word-wrap:break-word;font-size:1rem}.graficos{gap:.75rem;margin:8px 0}.grafico{border-radius:8px;max-width:100%;min-width:0;padding:.5rem;width:100%}.grafico h4{font-size:.95rem;margin-bottom:.5rem;text-align:center}.chart-container{height:180px}.tabla-wrap{margin:0 -8px;padding:0 8px}.tabla-docs{min-width:300px}.tabla-docs td,.tabla-docs th{font-size:.85rem;padding:.4rem .5rem}.tabla-docs th{white-space:nowrap}}.estado.vigente{color:green;font-weight:700}.estado.próximo-a-vencer{color:orange;font-weight:700}.estado.vencido{color:red;font-weight:700}:root{--apple:#94bd17;--forest:#31822f;--dart:#00652f;--ink:#1a1a1a;--paper:#fff;--bg:#f9f9f6;--card:#eaf7c7;--shadow:#cbd5b7;--danger:#c62828;--info:#1976d2;--warning:#f57c00;--success:#2e7d32;--border:#dde5cc;--chart-1:#94bd17;--chart-2:#31822f;--chart-3:#00652f;--chart-4:#dbe524;--chart-5:#216423}.reporte-actas-container{background:#f9f9f6;background:var(--bg);min-height:100vh;padding:clamp(16px,2.4vw,32px)}.reporte-actas-container h1{color:#1a1a1a;color:var(--ink);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;margin:0 0 1.5rem;text-align:center}.reporte-actas-container .page-title,.reporte-actas-container h1{background-color:#00652f;background-color:var(--dart);border-radius:8px;color:#fff;color:var(--paper);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;margin-bottom:1.5rem;padding:1rem;text-align:left}.reporte-layout{grid-gap:1.5rem;gap:1.5rem}.reporte-layout,.stats-grid{display:grid;margin-bottom:2rem}.stats-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.stat-card{background:linear-gradient(180deg,#fff,#fbfffa);border-radius:16px;box-shadow:0 8px 24px #31822f0f;padding:1.5rem;text-align:center;transition:transform .28s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease}.stat-card:hover{box-shadow:0 18px 36px #31822f1f;transform:translateY(-8px) scale(1.01)}.stat-value{color:#00652f;color:var(--dart);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;margin-bottom:.5rem}.stat-label{color:#31822f;color:var(--forest);font-size:.9rem;font-weight:600}.charts-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:1200px){.charts-section{grid-template-columns:1fr 1fr}}.chart-card{background:linear-gradient(180deg,#fff,#fbfffa);border-radius:16px;box-shadow:0 8px 24px #31822f0f;padding:clamp(16px,2vw,24px)}.chart-header{align-items:center;border-bottom:1px solid #dde5cc;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.chart-header h3{color:#00652f;color:var(--dart);font-size:clamp(1rem,1.2vw,1.2rem);font-weight:800;margin:0}.chart-controls{display:flex;gap:.5rem}.chart-btn{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#94bd17,#dbe524);border:none;border-radius:10px;box-shadow:0 8px 20px #31822f14;color:#0b3b12;cursor:pointer;font-size:.9rem;font-weight:700;padding:.5rem .9rem;transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .18s ease}.chart-btn.active{background:linear-gradient(135deg,#31822f,#20910e);color:#fff}.chart-btn:not(.active){background:linear-gradient(180deg,#f0fbdf,#eaf7c7);color:#214f23}.bar-chart{padding:1rem 0}.bar-item{align-items:center;display:flex;gap:.8rem;margin-bottom:.8rem}.bar-label{color:#31822f;color:var(--forest);flex:0 0 120px;font-size:.85rem;font-weight:600;text-align:right}.bar-visual{background:#f0f4ed;border-radius:12px;flex:1 1;height:24px;position:relative}.bar-fill{background:linear-gradient(90deg,#94bd17,#31822f);border-radius:12px;color:#fff;font-size:.8rem;font-weight:700;height:100%;justify-content:flex-end;padding-right:.5rem;transition:width .8s ease,box-shadow .3s ease}.bar-fill,.pie-chart{align-items:center;display:flex}.pie-chart{flex-direction:column;padding:1rem}.pie-visual{height:200px;margin-bottom:1rem;width:200px}.pie-legend{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}.legend-item{align-items:center;display:flex;font-size:.85rem;gap:.4rem}.legend-color{border-radius:50%;height:12px;width:12px}.legend-label{color:#31822f;color:var(--forest);font-weight:600}.legend-value{color:#00652f;color:var(--dart);font-weight:700}.list-section{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--border);border-radius:16px;box-shadow:6px 6px 0 #cbd5b7;box-shadow:6px 6px 0 var(--shadow);grid-column:1/-1;padding:clamp(16px,2vw,24px)}.list-header{align-items:center;border-bottom:1px solid #dde5cc;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.list-header h3{color:#00652f;color:var(--dart);font-size:clamp(1.1rem,1.4vw,1.3rem);font-weight:800;margin:0}.list-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.search-input{background:#fff;background:var(--paper);border:2px solid #dde5cc;border:2px solid var(--border);border-radius:8px;font-size:.9rem;min-width:200px;outline:none;padding:.5rem .8rem}.search-input:focus{border-color:#94bd17;border-color:var(--apple);box-shadow:0 0 0 3px #dbe52433}.total-records{background:#eaf7c7;background:var(--card);border-radius:8px;color:#31822f;color:var(--forest);font-size:.8rem;font-weight:700;padding:.4rem .8rem}.table-container{border:1px solid #dde5cc;border:1px solid var(--border);border-radius:12px;max-height:calc(100vh - 200px);overflow:auto}.reporte-table{background:#fff;background:var(--paper);border-collapse:collapse;font-size:.85rem;min-width:1200px;width:100%}.reporte-table th{background:#dbe524;background:var(--pear);border-bottom:2px solid #0000000a;box-shadow:inset 0 -2px 0 #00000008;color:#00652f;color:var(--dart);font-size:.8rem;font-weight:700;padding:.8rem .6rem;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.chart-btn,.chart-card,.reporte-card,.stat-card{animation:none!important;transition:none!important}@media (max-width:1024px){.reporte-actas-container{box-sizing:border-box;padding-top:calc(72px + .5rem)}}.back-btn-wrap{margin-bottom:.5rem}@media (max-width:1024px){.back-btn-wrap{margin-top:84px;position:relative;z-index:1200}}}.reporte-table td{border-bottom:1px solid #f0f0f0;padding:.7rem .6rem;vertical-align:top}.reporte-table tbody tr:hover{background:#f8fdf4}.reporte-table tbody tr:nth-child(2n){background:#fbfcf8}.reporte-table tbody tr:nth-child(2n):hover{background:#f8fdf4}.employee-code{color:#00652f;color:var(--dart);font-weight:700;white-space:nowrap}.employee-name{font-weight:600}.date-cell,.employee-name{color:#31822f;color:var(--forest);white-space:nowrap}.tipo-badge{background:#1976d2;background:var(--info)}.grado-badge,.tipo-badge{border-radius:6px;color:#fff;color:var(--paper);display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .5rem;white-space:nowrap}.grado-badge.grado-1{background:#94bd17;background:var(--apple)}.grado-badge.grado-2{background:#f57c00;background:var(--warning)}.grado-badge.grado-3{background:#c62828;background:var(--danger)}.justification-cell{max-width:300px}.justification-text{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#555;display:block;display:-webkit-box;line-height:1.4;text-overflow:ellipsis}.archivo-cell{font-size:.8rem;max-width:200px}.estado-badge{border-radius:6px;display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .5rem;white-space:nowrap}.estado-activo{background:#2e7d32;background:var(--success);color:#fff;color:var(--paper)}.estado-inactivo{background:#c62828;background:var(--danger);color:#fff;color:var(--paper)}.estado-pendiente{background:#f57c00;background:var(--warning);color:#fff;color:var(--paper)}.loading,.no-data{color:#666;font-style:italic;padding:3rem;text-align:center}@media (max-width:1024px){.charts-section{grid-template-columns:1fr}.reporte-table{font-size:.8rem}.reporte-table td,.reporte-table th{padding:.5rem .4rem}.bar-label{flex:0 0 100px;font-size:.8rem}}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.list-header{align-items:stretch;flex-direction:column}.list-controls{justify-content:space-between}.search-input{flex:1 1;min-width:auto}.table-container{max-height:calc(100vh - 300px)}.pie-visual{height:150px;width:150px}.bar-label{flex:0 0 80px;font-size:.75rem}}@media (max-width:640px){.stats-grid{grid-template-columns:1fr}.reporte-table{font-size:.75rem;min-width:1000px}.reporte-table td,.reporte-table th{padding:.4rem .3rem}}.page-container{background:var(--bg);color:var(--ink);min-height:100%}.modulo{background:var(--paper);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);padding:1.25rem}.module-header h1{color:var(--dart);letter-spacing:.2px}.header-decoration{background:var(--card-gradient);border-radius:999px;height:.35rem;margin-top:.25rem;width:6rem}.module-description{color:rgba(var(--black-rgb),.7)}.rem-filters{align-items:center;display:flex;flex-wrap:wrap;gap:.6rem;margin:.75rem 0 1rem}.rem-filters input,.rem-filters select{background:var(--paper);border:1px solid rgba(var(--black-rgb),.12);border-radius:.75rem;color:var(--ink);outline:none;padding:.55rem .7rem;transition:var(--transition)}.rem-filters input:focus,.rem-filters select:focus{border-color:var(--accent);box-shadow:0 0 0 .22rem var(--focus-ring)}.doc-list{grid-gap:.9rem;display:grid;gap:.9rem}.doc-card{grid-gap:.75rem;align-items:center;background:var(--card-gradient);border:1px solid rgba(var(--black-rgb),.12);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);color:var(--ink);display:grid;gap:.75rem;grid-template-columns:1fr auto;padding:.9rem 1.1rem;transition:var(--transition)}.doc-card:hover{background:var(--card-hover-gradient);box-shadow:var(--shadow-hover)}.doc-card-main{grid-gap:.25rem;display:grid;gap:.25rem}.doc-title{color:var(--dart);font-weight:700}.doc-meta{align-items:center;color:rgba(var(--black-rgb),.8);display:flex;flex-wrap:wrap;font-size:.92rem;gap:.5rem}.expirado-badge{background:rgba(var(--pear-rgb),.3);border:1px solid rgba(var(--pear-rgb),.6);border-radius:999px;color:var(--accent-strong);font-weight:700;margin-left:.25rem;padding:.1rem .5rem}.status-chip{border:1px solid #0000;border-radius:999px;font-size:.78rem;font-weight:600;padding:.18rem .6rem}.status-chip.activo{background:rgba(var(--green-rgb),.1);border-color:rgba(var(--green-rgb),.35);color:var(--forest)}.status-chip.no_visto{background:rgba(var(--pear-rgb),.18);border-color:rgba(var(--pear-rgb),.6);color:var(--dart)}.status-chip.visto{background:rgba(var(--green-rgb),.08);border-color:rgba(var(--green-rgb),.28);color:var(--dart)}.status-chip.cancelado{background:rgba(var(--black-rgb),.06);border-color:rgba(var(--black-rgb),.18);color:rgba(var(--black-rgb),.75)}.doc-card.activo{box-shadow:6px 6px 0 rgba(var(--pear-rgb))}.doc-card.no.visto{box-shadow:6px 6px 0 rgba(var(--black-rgb))}.doc-card.visto{box-shadow:6px 6px 0 rgba(var(--green-rgb))}.doc-card.cancelado{box-shadow:6px 6px 0 #c62828}.btn{background:var(--paper);border:1px solid rgba(var(--black-rgb),.14);border-radius:.75rem;box-shadow:0 .05rem .25rem rgba(var(--black-rgb),.05);color:var(--ink);padding:.5rem .8rem;transition:var(--transition)}.btn:hover{border-color:var(--accent);box-shadow:0 .5rem 1.2rem rgba(var(--green-rgb),.14);transform:translateY(-1px)}.btn:focus-visible{box-shadow:0 0 0 .22rem var(--focus-ring);outline:none}.btn.btn-edit{background:rgba(var(--green-rgb),.08);border-color:rgba(var(--green-rgb),.35);color:var(--forest)}.btn.btn-danger{background:rgba(var(--black-rgb),.06);border-color:rgba(var(--black-rgb),.18);color:rgba(var(--black-rgb),.8)}.btn.btn-danger:hover{background:rgba(var(--black-rgb),.08)}.pager{align-content:center;align-items:center;color:rgba(var(--black-rgb),.75);gap:.9rem;margin-top:.9rem}.pager .btn{min-width:8rem}.cards-container{grid-gap:1.25rem;display:grid;gap:1.25rem}.card-section h2{color:var(--forest);margin-bottom:.4rem}.opciones.menu-cards{grid-gap:.9rem;display:grid;gap:.9rem}a,button{-webkit-tap-highlight-color:transparent}.btn-disabled{cursor:not-allowed!important;opacity:.6;pointer-events:none}.fab-plus{align-items:center;background:#2563eb;border:none;border-radius:50%;bottom:24px;box-shadow:0 8px 16px #0003;color:#fff;cursor:pointer;display:flex;font-size:32px;height:56px;justify-content:center;line-height:0;position:fixed;right:150px;transition:transform .15s ease,box-shadow .15s ease;width:56px;z-index:9999}.fab-plus:hover{box-shadow:0 10px 20px #0000003d;transform:translateY(-1px)}.fab-plus:active{transform:translateY(0)}.fab-plus:focus-visible{outline:3px solid #93c5fd;outline-offset:2px}.calendario-page{background:linear-gradient(135deg,#20910e,#31822f);background:linear-gradient(135deg,var(--dartmouth-green) 0,var(--forest-green) 100%);min-height:100vh;padding:20px}.cal-header{background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin-bottom:20px;padding:30px;text-align:center}.cal-header h1{align-items:center;color:#31822f;color:var(--forest-green);display:flex;font-size:2.2em;font-weight:600;gap:10px;justify-content:center;margin-bottom:10px}.cal-header h1 svg{color:#20910e;color:var(--dartmouth-green)}.cal-header p{color:#1a1a1a;color:var(--text-dark);font-size:1.1em;margin:0}.cal-user-bar{align-items:center;background:#20910e1a;border:1px solid #20910e4d;border-radius:8px;display:flex;gap:10px;justify-content:center;margin-top:15px;padding:10px}.cal-user-avatar-small{border:2px solid #20910e;border:2px solid var(--dartmouth-green);border-radius:50%;height:24px;width:24px}.cal-user-bar span{color:#333;font-size:.95em}.cal-loading{align-items:center;background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px}.cal-loading-spinner{animation:cal-spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#20910e;border-top:4px solid var(--dartmouth-green);height:40px;margin-bottom:20px;width:40px}@keyframes cal-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cal-auth-section{align-items:center;display:flex;justify-content:center;min-height:400px}.cal-auth-card{background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:450px;padding:40px;text-align:center;width:100%}.cal-auth-card h2{color:#333;font-size:1.6em;margin-bottom:15px}.cal-auth-card p{color:#666;line-height:1.5;margin-bottom:20px}.cal-auth-actions{margin-top:20px}.btn-google{background:#20910e;background:var(--dartmouth-green);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;margin-bottom:15px;padding:12px 24px;transition:all .3s ease}.btn-google:hover{background:#31822f;background:var(--forest-green);box-shadow:0 4px 12px #20910e4d;transform:translateY(-1px)}.cal-auth-note{background:#dbe5241a;border-left:4px solid #dbe524;border-left:4px solid var(--pear);border-radius:4px;margin-top:20px;padding:15px;text-align:left}.cal-user-info{background:#20910e0d;border:2px solid #20910e;border:2px solid var(--dartmouth-green);border-radius:8px;padding:20px}.cal-user-profile{align-items:center;display:flex;gap:15px;margin-bottom:15px}.cal-user-avatar{border:3px solid #20910e;border:3px solid var(--dartmouth-green);border-radius:50%;height:48px;width:48px}.cal-user-details{flex:1 1;text-align:left}.cal-navigation{background:#fffffff2;border-radius:12px;box-shadow:0 2px 10px #0000001a;gap:20px;margin-bottom:20px;padding:20px}.cal-nav-buttons,.cal-navigation{align-items:center;display:flex;flex-wrap:wrap}.cal-nav-buttons{flex:1 1;gap:15px}.cal-nav-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;display:flex;flex:0 1 auto;font-size:16px;font-weight:500;gap:8px;justify-content:center;min-width:150px;padding:14px 24px;transition:all .3s ease;white-space:nowrap}.cal-nav-btn:hover{box-shadow:0 4px 12px #20910e26;color:#20910e;color:var(--dartmouth-green)}.cal-nav-btn.active,.cal-nav-btn:hover{border-color:#20910e;border-color:var(--dartmouth-green);transform:translateY(-2px)}.cal-nav-btn.active{background:#20910e;background:var(--dartmouth-green);box-shadow:0 4px 12px #20910e4d;color:#fff}.cal-nav-btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.crear-evento-btn{background:#dbe524;background:var(--pear);border-color:#dbe524;border-color:var(--pear);color:#1a1a1a;color:var(--text-dark);font-weight:600}.crear-evento-btn:hover:not(:disabled){background:#c9d322;border-color:#c9d322;box-shadow:0 4px 12px #dbe5244d;transform:translateY(-2px)}.logout-btn{border-color:#f44336;font-weight:600;margin-left:auto!important}.logout-btn:hover:not(:disabled){background:#d32f2f;border-color:#d32f2f;box-shadow:0 4px 12px #f443364d;transform:translateY(-2px)}.cal-content{background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;min-height:500px;padding:25px}.cal-msg{border-radius:6px;font-weight:500;margin-bottom:15px;padding:12px 16px}.cal-msg.success{background:#20910e1a;border:1px solid #20910e4d;color:#155724}.cal-msg.err{background:#f443361a;border:1px solid #f443364d;color:#c62828}.cal-msg.warning{background:#dbe52426;border:1px solid #dbe52466;color:#856404}.cal-msg.info{background:#2196f31a;border:1px solid #2196f34d;color:#1976d2}.cal-config-needed{text-align:left}.cal-config-steps{background:#00000005;border:1px solid #e0e0e0;border-radius:8px;margin:20px 0;padding:20px}.cal-config-steps h3{color:#333;font-size:1.1em;margin-bottom:15px}.cal-config-steps ol{line-height:1.6;padding-left:20px}.cal-config-steps li{color:#555;margin-bottom:10px}.cal-config-steps ul{margin:8px 0;padding-left:20px}.cal-config-steps ul li{margin-bottom:5px}.cal-config-steps code{background:#0000001a;border-radius:3px;font-family:Courier New,monospace;font-size:.9em;padding:2px 6px}.cal-config-steps pre{background:#2d3748;border-radius:6px;color:#e2e8f0;font-family:Courier New,monospace;font-size:.85em;line-height:1.4;margin:10px 0;overflow-x:auto;padding:15px}.cal-config-steps a{color:#20910e;color:var(--dartmouth-green);font-weight:500;text-decoration:none}.cal-config-steps a:hover{text-decoration:underline}.cal-demo-section{background:#20910e0d;border:2px solid #20910e33;border-radius:8px;margin-top:25px;padding:20px;text-align:center}.cal-demo-section h3{color:#333;margin-bottom:10px}.cal-demo-section p{color:#666;margin-bottom:15px}.calendario-demo{width:100%}.demo-header{border-bottom:2px solid #e0e0e0;margin-bottom:25px;padding-bottom:20px;text-align:center}.demo-header h2{color:#333;margin-bottom:10px}.demo-header p{color:#666;margin-bottom:15px}.demo-navigation{display:flex;gap:10px;justify-content:center;margin-bottom:25px}.demo-nav-btn{background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:16px;font-weight:500;padding:12px 20px;transition:all .3s ease}.demo-nav-btn:hover{color:#20910e;color:var(--dartmouth-green);transform:translateY(-1px)}.demo-nav-btn.active,.demo-nav-btn:hover{border-color:#20910e;border-color:var(--dartmouth-green)}.demo-nav-btn.active{background:#20910e;background:var(--dartmouth-green);box-shadow:0 4px 12px #20910e4d;color:#fff}.demo-eventos h3{color:#333;margin-bottom:20px;text-align:center}.demo-card{background:linear-gradient(135deg,#ffffffe6,#20910e0d);border-left:4px solid #20910e;border-left:4px solid var(--dartmouth-green)}.evento-tipo-badge{border-radius:12px;color:#fff;font-size:.75em;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.demo-footer{background:#20910e1a;border-radius:0 0 8px 8px;margin:15px -20px -20px;padding:10px 20px}.demo-crear-evento h3{color:#333;margin-bottom:20px;text-align:center}.demo-form{background:linear-gradient(135deg,#ffffffe6,#20910e05);border:2px dashed #20910e;border:2px dashed var(--dartmouth-green)}.demo-footer-info{margin-top:30px;text-align:center}.btn{border:none;border-radius:6px;cursor:pointer;display:inline-block;font-size:14px;font-weight:500;padding:10px 20px;text-align:center;text-decoration:none;transition:all .3s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#20910e;background:var(--dartmouth-green);color:#fff}.btn-primary:hover:not(:disabled){background:#31822f;background:var(--forest-green);box-shadow:0 4px 12px #20910e4d;transform:translateY(-1px)}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-success{background:#20910e;background:var(--dartmouth-green);color:#fff}.btn-success:hover:not(:disabled){background:#31822f;background:var(--forest-green)}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f}.btn-sm{font-size:12px;padding:6px 12px}.ver-eventos{width:100%}.eventos-header{border-bottom:2px solid #e0e0e0;gap:20px;padding-bottom:15px}.eventos-header h2{color:#333;flex:1 1;margin:0}.calendario-selector,.vista-selector{align-items:center;display:flex;gap:10px}.form-select{background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px}.form-select:focus{border-color:#20910e;border-color:var(--dartmouth-green);outline:none}.btn-vista{background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.btn-vista:hover{color:#20910e;color:var(--dartmouth-green)}.btn-vista.active,.btn-vista:hover{border-color:#20910e;border-color:var(--dartmouth-green)}.btn-vista.active{background:#20910e;background:var(--dartmouth-green);color:#fff}.fecha-navegacion{align-items:center;background:#20910e1a;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px}.fecha-actual{color:#333;flex:1 1;font-size:1.3em;margin:0}.eventos-loading,.fecha-actual,.no-eventos{text-align:center}.no-eventos{color:#666;padding:60px 20px}.no-eventos p{font-size:1.2em;margin-bottom:10px}.eventos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.evento-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.evento-card:hover{border-color:#20910e;border-color:var(--dartmouth-green);box-shadow:0 4px 16px #20910e33}.evento-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.evento-titulo{flex:1 1;margin:0;padding-right:10px}.evento-actions{display:flex;gap:5px}.btn-action{background:none;border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:5px;transition:all .3s ease}.btn-action:hover{background:#0000001a}.btn-action.btn-danger:hover{background:#f443361a;color:#f44336}.evento-details{margin-bottom:15px}.evento-fecha,.evento-hora,.evento-ubicacion{color:#555;margin-bottom:8px}.evento-descripcion{background:#0000000d;border-radius:4px;color:#666;margin:10px 0;padding:10px}.evento-asistentes{margin:10px 0}.evento-asistentes ul{margin:5px 0 0;padding-left:20px}.evento-asistentes li{font-size:.9em;margin-bottom:3px}.evento-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;padding-top:10px}.evento-calendario{color:#666;font-size:.85em}.crear-evento{margin:0 auto;max-width:800px;width:100%}.evento-form-header{margin-bottom:30px;text-align:center}.evento-form-header h2{color:#333;margin-bottom:10px}.evento-form-header p{color:#666;margin:0}.evento-form{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:30px}.form-row{display:flex;gap:20px;margin-bottom:20px}.form-group{display:flex;flex:1 1;flex-direction:column}.form-group.full-width{flex:1 1 100%}.form-group label{align-items:center;color:#333;display:flex;font-weight:500;gap:8px;margin-bottom:5px}.form-input,.form-select,.form-textarea{border:2px solid #e0e0e0;border-radius:6px;font-size:14px;padding:10px 12px;transition:all .3s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#20910e;border-color:var(--dartmouth-green);box-shadow:0 0 0 3px #20910e1a;outline:none}.form-textarea{font-family:inherit;min-height:80px;resize:vertical}.form-group input[type=checkbox]{margin-right:8px;transform:scale(1.2)}.form-actions{border-top:2px solid #e0e0e0;display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px}.form-actions .btn{font-size:16px;padding:12px 24px}@media (max-width:768px){.calendario-page{padding:15px}.cal-header{padding:20px 15px}.cal-header h1{flex-direction:column;font-size:1.8em;gap:8px}.cal-header h1 svg{font-size:1.2em}.cal-navigation{flex-direction:column;gap:12px;padding:15px}.cal-nav-buttons{flex-direction:column;gap:12px;width:100%}.cal-nav-btn{min-width:auto;width:100%}.logout-btn{margin-left:0!important}.cal-content{padding:20px 15px}.cal-auth-card{margin:0 10px;padding:30px 20px}.cal-user-bar{flex-direction:column;gap:8px}.eventos-header{align-items:stretch;flex-direction:column;gap:15px}.calendario-selector,.vista-selector{justify-content:center}.fecha-navegacion{flex-direction:column;gap:10px}.fecha-actual{font-size:1.1em}.eventos-grid{gap:15px;grid-template-columns:1fr}.evento-card{padding:15px}.evento-header{flex-direction:column;gap:10px}.evento-actions{align-self:flex-end}.evento-form{padding:20px 15px}.form-row{gap:15px}.form-actions,.form-row{flex-direction:column}.form-actions .btn{width:100%}}.cal-vista-calendario{background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:20px}.cal-nav-calendario{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.cal-nav-izquierda{align-items:center;display:flex;gap:10px}.cal-titulo-mes h2{color:#333;font-size:1.8em;font-weight:600;margin:0}.cal-btn-hoy,.cal-btn-nav{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.cal-btn-hoy:hover,.cal-btn-nav:hover{background:#f5f5f5;border-color:#bbb}.cal-btn-hoy:disabled,.cal-btn-nav:disabled{cursor:not-allowed;opacity:.5}.cal-selector-vista{display:flex;gap:5px}.cal-btn-vista{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .3s ease}.cal-btn-vista.active{background:#20910e;background:var(--dartmouth-green);border-color:#20910e;border-color:var(--dartmouth-green);color:#fff}.cal-btn-vista:hover:not(.active){background:#f0f0f0}.cal-vista-mes{width:100%}.cal-dias-semana{grid-gap:1px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.cal-dia-semana{background:#f8f9fa;border-radius:4px;color:#666;font-size:14px;font-weight:700;padding:10px;text-align:center}.cal-grid-dias{grid-gap:1px;background:#e0e0e0;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.cal-dia{background:#fff;cursor:pointer;display:flex;flex-direction:column;min-height:120px;padding:8px;position:relative;transition:all .3s ease}.cal-dia:hover{background:#f8f9ff}.cal-dia.cal-dia-otro-mes{background:#f5f5f5;color:#999}.cal-dia.cal-dia-hoy{background:#dbe52433;border:2px solid #dbe524;border:2px solid var(--pear)}.cal-dia.cal-dia-con-eventos{background:#20910e0d}.cal-numero-dia{font-size:14px;font-weight:700;margin-bottom:5px}.cal-eventos-dia{display:flex;flex:1 1;flex-direction:column;gap:2px}.cal-evento-miniatura{border-radius:3px;color:#fff;cursor:pointer;font-size:11px;line-height:1.2;padding:2px 6px;text-shadow:0 1px 1px #0000004d;transition:opacity .2s ease}.cal-evento-miniatura:hover{opacity:.8}.cal-evento-titulo{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-mas-eventos{color:#666;font-size:10px;font-style:italic;margin-top:2px}.cal-leyenda{background:#dbe5240d;border:1px solid #20910e33;border-radius:8px;margin-top:20px;padding:15px}.cal-leyenda-titulo{color:#333;font-size:14px;font-weight:700;margin-bottom:10px}.cal-leyenda-items{display:flex;flex-wrap:wrap;gap:15px}.cal-leyenda-item{align-items:center;display:flex;font-size:12px;gap:5px}.cal-color-muestra{border-radius:2px;height:12px;width:12px}.cal-loading-overlay{align-items:center;background:#fffc;border-radius:8px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.cal-loading-spinner{text-align:center}.cal-loading-spinner .spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#20910e;border-top:4px solid var(--dartmouth-green);height:40px;margin:0 auto 10px;width:40px}.cal-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.cal-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.cal-modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:20px 24px}.cal-modal-header h2{color:#333;font-size:1.5em;margin:0}.cal-modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:24px;line-height:1;padding:5px}.cal-modal-close:hover{color:#333}.cal-form{padding:24px}.cal-form-row{display:flex;gap:15px;margin-bottom:20px}.cal-form-group{display:flex;flex:1 1;flex-direction:column}.cal-form-group label{color:#333;font-size:14px;font-weight:500;margin-bottom:5px}.cal-form-group input,.cal-form-group select,.cal-form-group textarea{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px;transition:border-color .3s ease}.cal-form-group input:focus,.cal-form-group select:focus,.cal-form-group textarea:focus{border-color:#20910e;border-color:var(--dartmouth-green);box-shadow:0 0 0 3px #20910e1a;outline:none}.cal-form-group input.error,.cal-form-group select.error,.cal-form-group textarea.error{border-color:#dc3545}.error-text{color:#dc3545;font-size:12px;margin-top:5px}.cal-checkbox-group{align-items:center;display:flex;gap:8px}.cal-checkbox-group input[type=checkbox]{width:auto}.cal-color-picker{align-items:center;display:flex;gap:10px}.cal-color-picker input[type=color]{border:none;border-radius:6px;cursor:pointer;height:40px;width:50px}.cal-color-preview{border:1px solid #ddd;border-radius:4px;height:30px;width:30px}.cal-form-actions{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;margin-top:30px;padding-top:20px}.cal-btn-cancelar,.cal-btn-guardar{border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.cal-btn-cancelar{background:#f8f9fa;border:1px solid #ddd;color:#333}.cal-btn-cancelar:hover{background:#e9ecef}.cal-btn-guardar{background:#20910e;background:var(--dartmouth-green);border:1px solid #20910e;border:1px solid var(--dartmouth-green);color:#fff}.cal-btn-guardar:hover{background:#31822f;background:var(--forest-green)}.cal-btn-cancelar:disabled,.cal-btn-guardar:disabled{cursor:not-allowed;opacity:.6}.ver-eventos{background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:20px}.eventos-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:20px}.eventos-titulo h2{color:#333;font-size:1.8em;margin:0 0 5px}.eventos-contador{color:#666;font-size:14px;margin:0}.btn-recargar{align-items:center;background:#20910e;background:var(--dartmouth-green);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;gap:5px;padding:8px 16px;transition:all .3s ease}.btn-recargar:hover{background:#31822f;background:var(--forest-green)}.btn-recargar:disabled{cursor:not-allowed;opacity:.6}.eventos-controles{align-items:end;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px}.control-grupo{display:flex;flex-direction:column;gap:5px}.control-grupo label{color:#333;font-size:14px;font-weight:500}.input-busqueda,.select-filtro,.select-ordenamiento{border:1px solid #ddd;border-radius:6px;font-size:14px;min-width:150px;padding:8px 12px}.input-busqueda{min-width:250px}.eventos-contenido{position:relative}.eventos-loading{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:40px}.eventos-vacio{color:#666;padding:40px;text-align:center}.vacio-icono{color:#20910e;color:var(--dartmouth-green);font-size:48px;margin-bottom:15px;opacity:.7}.eventos-vacio h3{color:#333;margin:0 0 10px}.btn-limpiar-filtros{background:#20910e;background:var(--dartmouth-green);border:none;border-radius:6px;color:#fff;cursor:pointer;margin-top:15px;padding:8px 16px}.eventos-lista{display:flex;flex-direction:column;gap:15px}.evento-tarjeta{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;overflow:hidden;position:relative;transition:all .3s ease}.evento-tarjeta:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.evento-color-indicador{flex-shrink:0;width:6px}.evento-contenido{flex:1 1;padding:15px}.evento-cabecera{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:10px}.evento-titulo{color:#333;font-size:1.2em;font-weight:600;margin:0 0 5px}.evento-tipo{align-items:center;display:flex;gap:8px}.tipo-badge{background:#f8f9fa;color:#666;font-size:12px;text-transform:capitalize}.estado-badge,.tipo-badge{border-radius:12px;padding:2px 8px}.estado-badge{font-size:11px;font-weight:500}.estado-badge.actual{background:#d4edda;color:#155724}.estado-badge.pasado{background:#f8d7da;color:#721c24}.evento-acciones{display:flex;gap:5px}.btn-accion{align-items:center;background:none;border:none;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:8px;transition:all .3s ease}.btn-accion.editar:hover{background:#20910e1a;color:#20910e;color:var(--dartmouth-green)}.btn-accion.eliminar:hover{background:#dc35451a;color:#dc3545}.evento-detalles{display:flex;flex-direction:column;gap:8px}.evento-fecha-hora{display:flex;flex-wrap:wrap;gap:15px}.evento-recordatorio,.evento-ubicacion,.fecha-info,.hora-info{align-items:center;color:#666;display:flex;font-size:14px;gap:5px}.evento-descripcion{margin-top:10px}.evento-descripcion p{color:#555;font-size:14px;line-height:1.4;margin:0}.duracion-texto{color:#999;font-size:12px}.evento-tarjeta.pasado{opacity:.7}.evento-tarjeta.actual{border-left:4px solid #20910e;border-left:4px solid var(--dartmouth-green)}@media (max-width:768px){.cal-nav-calendario{align-items:stretch;flex-direction:column;gap:10px}.cal-nav-izquierda{justify-content:center;order:2}.cal-titulo-mes{order:1;text-align:center}.cal-nav-derecha{order:3;text-align:center}.cal-grid-dias{gap:.5px}.cal-dia{min-height:80px;padding:4px}.cal-numero-dia{font-size:12px}.cal-evento-miniatura{font-size:10px;padding:1px 4px}.cal-leyenda-items{justify-content:center}.cal-modal{margin:20px;width:95%}.cal-form-row,.eventos-controles{flex-direction:column}.input-busqueda{min-width:auto;width:100%}.evento-cabecera{flex-direction:column;gap:10px}.evento-acciones{align-self:flex-start}.evento-fecha-hora{flex-direction:column;gap:8px}}.cal-no-auth{align-items:center;display:flex;justify-content:center;min-height:500px;padding:40px 20px}.cal-no-auth-content{background:#fffffffa;border-radius:16px;box-shadow:0 10px 40px #00000026;max-width:600px;padding:50px;text-align:center}.cal-no-auth-icon{animation:pulse 2s infinite;color:#20910e;color:var(--dartmouth-green);font-size:80px;margin-bottom:20px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.cal-no-auth-content h2{color:#333;font-size:2em;font-weight:600;margin-bottom:15px}.cal-no-auth-content>p{color:#666;font-size:1.1em;line-height:1.6;margin-bottom:30px}.cal-btn-login-large{background:linear-gradient(135deg,#20910e,#31822f);background:linear-gradient(135deg,var(--dartmouth-green) 0,var(--forest-green) 100%);border:none;border-radius:50px;box-shadow:0 4px 15px #20910e4d;color:#fff;cursor:pointer;font-size:1.2em;font-weight:600;margin-bottom:30px;padding:16px 40px;transition:all .3s ease}.cal-btn-login-large:hover:not(:disabled){box-shadow:0 6px 20px #20910e66;transform:translateY(-2px)}.cal-btn-login-large:disabled{cursor:not-allowed;opacity:.6}.cal-info-permisos{background:#f8f9fa;border-left:4px solid #20910e;border-left:4px solid var(--dartmouth-green);border-radius:12px;padding:20px;text-align:left}.cal-info-permisos p{color:#333;font-weight:600;margin:0 0 10px}.cal-info-permisos ul{list-style:none;margin:0;padding:0}.cal-info-permisos li{color:#555;font-size:.95em;padding:8px 0}.login-btn,.logout-btn{font-weight:600}.login-btn{background:linear-gradient(135deg,#20910e,#31822f);background:linear-gradient(135deg,var(--dartmouth-green) 0,var(--forest-green) 100%);border:none;box-shadow:0 4px 12px #20910e4d;color:#fff;padding:12px 24px}.login-btn:hover:not(:disabled){box-shadow:0 6px 16px #20910e66;transform:translateY(-2px)}.logout-btn{background:#f44336;border:none;color:#fff}.logout-btn:hover{background:#d32f2f}:root{--pear:#dbe524;--dartmouth-green:#20910e;--forest-green:#31822f;--apple-green:#acd401;--white:#fff;--text-dark:#1a1a1a;--bg-card:#c5e1a5;--shadow:#f0ecd0;--bgcard:#fff}.cotizaciones-container{background:#c5e1a5;background:var(--bg-card);min-height:100vh;padding:2rem 1rem}.cotizaciones-header{align-items:center;background:#fff;background:var(--bgcard);border-radius:1rem;box-shadow:15px 15px 0 #f0ecd0;box-shadow:15px 15px 0 var(--shadow);display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.cotizaciones-header h2{color:#20910e;color:var(--dartmouth-green);font-size:2rem;font-weight:700;margin:0}.cotizaciones-header button{background-color:#31822f;background-color:var(--forest-green);border:none;border-radius:.5rem;color:#fff;color:var(--white);font-weight:600;padding:.8rem 1.5rem;transition:all .3s ease}.cotizaciones-header button:hover{background-color:#20910e;background-color:var(--dartmouth-green);box-shadow:0 4px 12px #20910e4d;transform:translateY(-2px)}.cotizaciones-filtros{background:#fff;background:var(--bgcard);border-radius:1rem;box-shadow:10px 10px 0 #f0ecd0;box-shadow:10px 10px 0 var(--shadow);display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.cotizaciones-filtros .ant-picker,.cotizaciones-filtros .ant-select,.cotizaciones-filtros input{border:2px solid #31822f;border:2px solid var(--forest-green);border-radius:.5rem}.cotizaciones-filtros .ant-picker-focused,.cotizaciones-filtros .ant-select-focused .ant-select-selector,.cotizaciones-filtros input:focus{border-color:#20910e;border-color:var(--dartmouth-green);box-shadow:0 0 0 2px #20910e33}.ant-table-wrapper{background:#fff;background:var(--bgcard);border-radius:1rem;box-shadow:15px 15px 0 #f0ecd0;box-shadow:15px 15px 0 var(--shadow);padding:1.5rem}.ant-table-thead>tr>th{background-color:#31822f;background-color:var(--forest-green);border:none;color:#fff;color:var(--white);font-weight:700}.ant-table-tbody>tr:hover>td{background-color:#c5e1a5;background-color:var(--bg-card)}.ant-table-tbody>tr>td{border-bottom:1px solid #f0ecd0;border-bottom:1px solid var(--shadow)}.ant-tag{border-radius:.5rem;font-weight:600;padding:.3rem .8rem}.ant-btn-primary{background-color:#20910e;background-color:var(--dartmouth-green);border:none;border-radius:.5rem}.ant-btn-primary:hover{background-color:#31822f;background-color:var(--forest-green);transform:translateY(-2px)}.ant-btn-danger{background-color:#d32f2f;border:none;border-radius:.5rem}.ant-btn-danger:hover{background-color:#b71c1c}.detalle-cotizacion{background:#c5e1a5;background:var(--bg-card);min-height:100vh;padding:2rem 1rem}.detalle-header{align-items:center;background:#fff;background:var(--bgcard);border-radius:1rem;box-shadow:15px 15px 0 #f0ecd0;box-shadow:15px 15px 0 var(--shadow);display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.detalle-header h2{color:#20910e;color:var(--dartmouth-green);font-size:2rem;font-weight:700;margin:0}.detalle-seccion{background:#fff;background:var(--bgcard);border-radius:1rem;box-shadow:10px 10px 0 #f0ecd0;box-shadow:10px 10px 0 var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.detalle-seccion h3{border-bottom:3px solid #20910e;border-bottom:3px solid var(--dartmouth-green);color:#31822f;color:var(--forest-green);font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.8rem}.ant-descriptions-bordered .ant-descriptions-item-label{background-color:#c5e1a5;background-color:var(--bg-card);color:#1a1a1a;color:var(--text-dark);font-weight:600}.ant-descriptions-bordered .ant-descriptions-item-content{background-color:#fff;background-color:var(--white)}.info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{background:#fff;background:var(--white);border-left:4px solid #31822f;border-left:4px solid var(--forest-green);border-radius:.5rem;display:flex;flex-direction:column;padding:1rem}.info-label{color:#31822f;color:var(--forest-green);font-size:.9rem;font-weight:700;margin-bottom:.5rem}.info-value{color:#1a1a1a;color:var(--text-dark);font-size:1.1rem;font-weight:500}.pdf-viewer{border:3px solid #31822f;border:3px solid var(--forest-green);border-radius:1rem;box-shadow:0 8px 16px #0000001a;height:800px;width:100%}.reportes-dashboard{background:#c5e1a5;background:var(--bg-card);min-height:100vh;padding:2rem 1rem}.reportes-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.reporte-card{background:#fff;background:var(--bgcard);border-radius:1rem;box-shadow:10px 10px 0 #f0ecd0;box-shadow:10px 10px 0 var(--shadow);padding:1.5rem;transition:transform .3s ease}.reporte-card:hover{box-shadow:15px 15px 0 #f0ecd0;box-shadow:15px 15px 0 var(--shadow);transform:translateY(-5px)}.reporte-card h3{border-bottom:3px solid #31822f;border-bottom:3px solid var(--forest-green);color:#20910e;color:var(--dartmouth-green);font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:.8rem}.estadistica-item{border-bottom:2px solid #f0ecd0;border-bottom:2px solid var(--shadow);display:flex;justify-content:space-between;padding:1rem;transition:background .3s ease}.estadistica-item:hover{background-color:#c5e1a5;background-color:var(--bg-card);border-radius:.5rem}.estadistica-item:last-child{border-bottom:none}.estadistica-label{color:#1a1a1a;color:var(--text-dark);font-weight:600}.estadistica-valor{color:#20910e;color:var(--dartmouth-green);font-size:1.3rem;font-weight:700}.resumen-card{background:linear-gradient(135deg,#31822f,#20910e);background:linear-gradient(135deg,var(--forest-green) 0,var(--dartmouth-green) 100%);border-radius:1rem;box-shadow:10px 10px 0 #f0ecd0;box-shadow:10px 10px 0 var(--shadow);color:#fff;color:var(--white);padding:1.5rem;text-align:center}.resumen-card h4{color:#fff;color:var(--white);font-size:1rem;margin-bottom:.5rem;opacity:.9}.resumen-card .valor{color:#dbe524;color:var(--pear);font-size:2.5rem;font-weight:700}@media (max-width:768px){.cotizaciones-container,.detalle-cotizacion,.reportes-dashboard{padding:1rem .5rem}.cotizaciones-header,.detalle-header{flex-direction:column;gap:1rem;text-align:center}.cotizaciones-header h2,.detalle-header h2{font-size:1.5rem}.cotizaciones-filtros{flex-direction:column;gap:1rem}.info-grid,.reportes-grid{grid-template-columns:1fr}.pdf-viewer{height:500px}}@media (max-width:480px){.cotizaciones-header h2,.detalle-header h2{font-size:1.3rem}.detalle-seccion h3,.reporte-card h3{font-size:1.2rem}.estadistica-valor{font-size:1.1rem}.resumen-card .valor{font-size:2rem}}body{background:#fff7de;font-family:Segoe UI,sans-serif;overflow-x:hidden;overflow-y:auto;padding:0;width:100vw}.nav-links a{color:#034d21;font-weight:700;text-decoration:none}.btn-ingresar{background-color:#034d21;border-radius:6px;color:#fff!important;padding:.5rem 1rem}.login-page,.page{padding:2rem}.login-page form{background-color:#4caf50;border-radius:1rem;color:#fff;display:flex;flex-direction:column;gap:1rem;max-width:400px;padding:2rem}.login-page input{border:none;border-radius:6px;padding:.5rem}.login-page button{background-color:#ff0;border:none;cursor:pointer;font-weight:700;padding:.5rem}.error{color:red}@media (max-width:768px){.navbar{align-items:flex-start;flex-direction:column}.navbar-links{flex-direction:column;margin-top:.5rem;width:100%}.navbar-logo img{max-width:120px}}.modulo-layout{display:flex;min-height:100vh}.modulo-content{background-color:#fdfdfd;flex:1 1;padding:2rem}#root,body,html{height:100%}body{margin:0}
/*# sourceMappingURL=main.f1021cf6.css.map*/