.app{flex:1;padding:1.5rem}.app--centered{display:flex;align-items:center;justify-content:center;min-height:100vh}.app__title{color:var(--color-text);font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.app__text{color:var(--color-text);margin:0 0 1rem;font-size:1rem}.app__card{background:var(--color-card);border-radius:12px;padding:1.5rem;max-width:24rem;width:100%;border:1px solid var(--color-border);box-shadow:0 1px 3px #0000000f}.login-card{box-shadow:0 4px 12px #0000000f}.page-card{background:var(--color-card);border-radius:12px;padding:1.5rem 1.75rem;max-width:56rem;width:100%;border:1px solid var(--color-border);box-shadow:0 1px 3px #0000000f}.page-card__title{color:var(--color-text);font-size:1.35rem;font-weight:700;margin:0 0 1.25rem;letter-spacing:-.02em;border-bottom:2px solid var(--color-button);padding-bottom:.5rem}.error-message{padding:1.25rem;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin:1rem 0}.error-message__text{margin:0 0 .75rem;color:#991b1b;font-size:.95rem}.error-message__retry{width:auto;padding:.5rem 1rem;font-size:.9rem}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:2rem}.loading-spinner__dot{width:8px;height:8px;border-radius:50%;background:var(--color-button);animation:loading-bounce .6s ease-in-out infinite alternate}.loading-spinner__dot:nth-child(2){animation-delay:.15s}.loading-spinner__dot:nth-child(3){animation-delay:.3s}@keyframes loading-bounce{0%{transform:translateY(0);opacity:.6}to{transform:translateY(-6px);opacity:1}}.empty-state{padding:2rem 1.5rem;text-align:center}.empty-state__text{margin:0;color:var(--color-text-muted);font-size:.95rem}.form-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}.form-row__label{font-weight:500;color:var(--color-text);font-size:.95rem}.form-row .app__input{width:auto;min-width:10rem;margin-bottom:0}.app__button{background-color:var(--color-button);color:#fff;border:none;padding:.75rem 1.25rem;font-size:1rem;font-weight:600;border-radius:8px;transition:background-color .2s ease;width:100%}.app__button:hover{background-color:var(--color-button-hover)}.app__button:active{background-color:var(--color-button-active)}.app__button:disabled{opacity:.6;cursor:not-allowed}.app__input{width:100%;padding:.75rem;font-size:1rem;font-family:inherit;border:1px solid var(--color-border);border-radius:8px;background:var(--color-card);color:var(--color-text);margin-bottom:1rem}.app__input::placeholder{color:var(--color-text-muted)}.app__input:focus{outline:2px solid var(--color-button);outline-offset:2px}.app__label{display:block;color:var(--color-text);font-size:.875rem;font-weight:500;margin-bottom:.25rem}.app__footer{margin-top:1rem;font-size:.875rem;color:var(--color-text);opacity:.9}.app__link{color:var(--color-accent);text-decoration:none}.app__link:hover{color:var(--color-accent-hover);text-decoration:underline}.layout{min-height:100vh;display:flex;flex-direction:column}.layout__header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.6rem 1.25rem;background:var(--color-bg-header);border-bottom:1px solid var(--color-border);box-shadow:0 1px 2px #0000000a}.layout__brand{font-weight:700;font-size:1rem;color:var(--color-accent);letter-spacing:-.02em}.layout__nav{display:flex;flex-wrap:wrap;align-items:center;gap:.15rem}.layout__link{padding:.45rem .7rem;border-radius:8px;text-decoration:none;color:var(--color-text);font-weight:500;font-size:.9rem;transition:background .15s ease,color .15s ease}.layout__link:hover{background:var(--color-border-light);color:var(--color-accent)}.layout__link--active{background:#0596691f;color:var(--color-button)}.layout__right{display:flex;align-items:center;gap:.75rem}.layout__locales{display:flex;gap:.25rem}.layout__locale-btn{padding:.35rem .5rem;font-size:.8rem;font-weight:500;border:1px solid var(--color-border);border-radius:6px;background:var(--color-card);color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.layout__locale-btn:hover{background:var(--color-border-light);color:var(--color-text)}.layout__locale-btn--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.layout__logout{padding:.45rem .9rem;font-size:.85rem;width:auto;min-width:auto;background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.layout__logout:hover{background:#0ea5e91a;color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.layout__main{flex:1;padding:1.25rem 1.5rem}.table-wrap{overflow-x:auto;margin-top:.5rem;border-radius:10px;border:1px solid var(--color-border);background:var(--color-card)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--color-border-light)}.data-table th{font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);background:var(--color-border-light)}.data-table td{color:var(--color-text);font-size:.95rem}.data-table tbody tr:hover{background:#f8faf9}.data-table tbody tr:last-child td{border-bottom:none}.dashboard__address{margin-bottom:.5rem!important;color:var(--color-text-muted);font-size:.9rem}.dashboard__greeting{margin-bottom:1rem!important;font-size:1.05rem}.attendance__date-row{margin-bottom:1.25rem}.attendance-view{margin-top:.5rem}.attendance-summary{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.25rem;padding:.85rem 1rem;margin-bottom:1.5rem;background:var(--color-border-light);border-radius:10px;border:1px solid var(--color-border)}.attendance-summary__label{font-weight:600;color:var(--color-text)}.attendance-summary__present{color:#059669;font-weight:500}.attendance-summary__absent{color:#b45309;font-weight:500}.attendance-section{margin-bottom:1.5rem}.attendance-section:last-child{margin-bottom:0}.attendance-section__title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--color-text);padding-bottom:.35rem;border-bottom:2px solid var(--color-border)}.attendance-section--present .attendance-section__title{border-bottom-color:#05966959;color:#047857}.attendance-section--absent .attendance-section__title{border-bottom-color:#b4530959;color:#b45309}.attendance-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.attendance-list__item{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;padding:.6rem .85rem;border-radius:8px;background:var(--color-card);border:1px solid var(--color-border)}.attendance-list__item--present{border-left:3px solid #059669}.attendance-list__item--absent{border-left:3px solid #b45309}.attendance-list__item--absent.attendance-list__item--sick{border-left-color:#d97706}.attendance-list__item--absent.attendance-list__item--vacation{border-left-color:#0ea5e9}.attendance-list__name{font-weight:500;color:var(--color-text);min-width:0}.attendance-list__comment{font-size:.9rem;color:var(--color-text-muted);width:100%;margin-top:.15rem;padding-left:0}.attendance-badge{display:inline-block;padding:.2rem .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:6px}.attendance-badge--present{background:#05966926;color:#047857}.attendance-badge--absent{background:#b4530926;color:#b45309}.attendance-badge--sick{background:#d9770626;color:#b45309}.attendance-badge--vacation{background:#0ea5e926;color:#0284c7}.attendance-empty{margin:0;padding:.75rem;color:var(--color-text-muted);font-size:.95rem}.attendance-view__hint{margin:0 0 1rem;color:var(--color-text-muted);font-size:.95rem}.attendance-list--edit .attendance-list__item{flex-wrap:wrap;gap:.5rem .75rem}.attendance-list__group{font-weight:400;color:var(--color-text-muted);font-size:.9em}.attendance-actions{display:flex;flex-wrap:wrap;gap:.35rem}.attendance-actions--inline{margin-left:auto}.attendance-btn{padding:.35rem .6rem;font-size:.8rem;font-weight:600;border:1px solid var(--color-border);border-radius:6px;background:var(--color-card);color:var(--color-text);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.attendance-btn:hover:not(:disabled){filter:brightness(.97)}.attendance-btn:disabled{opacity:.7;cursor:not-allowed}.attendance-btn--small{padding:.25rem .45rem;font-size:.75rem}.attendance-btn--present{border-color:#059669;color:#047857;background:#0596691a}.attendance-btn--present:hover:not(:disabled),.attendance-btn--present.attendance-btn--active{background:#059669;color:#fff;border-color:#059669}.attendance-btn--absent{border-color:#b45309;color:#b45309;background:#b453091a}.attendance-btn--absent:hover:not(:disabled),.attendance-btn--absent.attendance-btn--active{background:#b45309;color:#fff;border-color:#b45309}.attendance-btn--sick{border-color:#d97706;color:#b45309;background:#d977061a}.attendance-btn--sick:hover:not(:disabled),.attendance-btn--sick.attendance-btn--active{background:#d97706;color:#fff;border-color:#d97706}.attendance-btn--vacation{border-color:#0ea5e9;color:#0284c7;background:#0ea5e91a}.attendance-btn--vacation:hover:not(:disabled),.attendance-btn--vacation.attendance-btn--active{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.attendance-comment-input{width:100%;max-width:20rem;padding:.4rem .6rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-card);color:var(--color-text)}.attendance-comment-input::placeholder{color:var(--color-text-muted)}.attendance-list__item--editable{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.attendance-list__item--editable .attendance-list__comment{width:100%;margin-top:0;padding-left:0}.attendance-section--unmarked .attendance-section__title{border-bottom-color:var(--color-border);color:var(--color-text-muted)}.payments-success{margin:0 0 1rem;padding:.6rem .85rem;background:#0596691f;color:#047857;border-radius:8px;font-weight:500}.payments-form{margin-bottom:1.5rem;padding:1rem 0;border-top:1px solid var(--color-border)}.payments-form .form-row{margin-bottom:1rem}.payments-form select.app__input{width:100%;max-width:20rem}.payments-advances{margin-bottom:1.5rem}.payments-advances__title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--color-text);padding-bottom:.35rem;border-bottom:2px solid var(--color-border)}.payments-divider{border:none;border-top:1px solid var(--color-border);margin:1.25rem 0}:root{--color-bg: #f0f7f4;--color-bg-header: #fff;--color-text: #334155;--color-text-muted: #64748b;--color-button: #059669;--color-button-hover: #047857;--color-button-active: #065f46;--color-accent: #0ea5e9;--color-accent-hover: #0284c7;--color-card: #fff;--color-border: #e2e8f0;--color-border-light: #f1f5f9}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer}button:focus-visible{outline:2px solid var(--color-button);outline-offset:2px}a{color:var(--color-button)}a:focus-visible{outline:2px solid var(--color-button);outline-offset:2px}
