:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:30px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.app-actions{gap:.5rem;display:flex}.app-actions button{cursor:pointer;color:#fff;border:none;border-radius:8px;align-items:center;padding:8px 20px;font-size:.9rem;font-weight:500;display:flex}.app-actions button:first-child{background:#2563eb}.app-actions button:last-child{background:#26711d}.calendar{padding:1rem 2rem}.calendar-grid{border:1px solid #e0e0e0;border-radius:8px;grid-template-columns:repeat(7,1fr);display:grid;overflow:hidden}.calendar-day-label{text-align:center;background:#f5f5f5;border-bottom:1px solid #e0e0e0;padding:.5rem;font-size:.8rem;font-weight:700}.calendar-cell{border-bottom:1px solid #e0e0e0;border-right:1px solid #e0e0e0;min-height:100px;padding:.5rem}.calendar-cell.faded{color:#bbb;background:#fafafa}.calendar-cell.today .day-number{color:#fff;background:#1976d2;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.day-holidays{flex-wrap:wrap;gap:2px;margin-top:4px;display:flex}.holiday-avatar{color:#fff;background:#1976d2;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;display:flex}.calendar-header{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.app-main{gap:1rem;padding:1rem 2rem;display:flex}.holiday-panel{border:1px solid #e0e0e0;border-radius:8px;width:260px;min-width:260px;height:fit-content;padding:1rem}.holiday-panel h3{margin:0 0 1rem;font-size:1rem}.holiday-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.holiday-item{align-items:center;gap:.75rem;display:flex}.holiday-avatar-large{color:#fff;background:#1976d2;border-radius:50%;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;font-size:1rem;display:flex}.person-name{margin:0;font-size:.9rem;font-weight:700}.person-title{color:#666;margin:0;font-size:.8rem}.holiday-dates{color:#999;margin:0;font-size:.75rem}.no-holidays{color:#999;font-size:.9rem}.calendar-cell.selected{background:#e3f2fd;border:2px solid #1976d2}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:420px;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.modal-header h2{margin:0 0 .25rem}.modal-header p{color:#666;margin:0;font-size:.85rem}.modal-close{cursor:pointer;color:#666;background:0 0;border:none;font-size:1.2rem}.form-group{margin-bottom:1.25rem}.form-group label{margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}.form-group select{border:1px solid #e0e0e0;border-radius:6px;width:100%;padding:.6rem;font-size:.9rem}.date-inputs{gap:.5rem;margin-bottom:.75rem;display:flex}.date-inputs input{border:1px solid #e0e0e0;border-radius:6px;flex:1;padding:.6rem;font-size:.9rem}.type-buttons{flex-wrap:wrap;gap:.5rem;display:flex}.type-btn{background:var(--type-color);color:#fff;cursor:pointer;opacity:.6;border:2px solid #0000;border-radius:6px;padding:.5rem 1rem;font-size:.85rem}.type-btn.active{opacity:1;border-color:#000}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.btn-cancel{cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:.6rem 1.25rem}.btn-submit{color:#fff;cursor:pointer;background:#1976d2;border:none;border-radius:6px;padding:.6rem 1.25rem}.picture-upload{flex-direction:column;align-items:center;margin-bottom:1.5rem;display:flex}.picture-circle{background:#f0f0f0;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;display:flex;position:relative;overflow:visible}.picture-placeholder{opacity:.4;font-size:2.5rem}.picture-preview{object-fit:cover;border-radius:50%;width:90px;height:90px}.picture-btn{cursor:pointer;background:#6c63ff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex;position:absolute;bottom:0;right:0}.picture-label{margin:.5rem 0 .1rem;font-size:.9rem;font-weight:600}.picture-hint{color:#999;margin:0;font-size:.75rem}.input-wrapper{border:1px solid #e0e0e0;border-radius:8px;align-items:center;gap:.5rem;padding:0 .75rem;display:flex}.input-icon{opacity:.5;font-size:.9rem}.input-wrapper input{border:none;outline:none;flex:1;padding:.65rem 0;font-size:.9rem}.profile-page{background:#f9f9f9;min-height:100vh}.profile-title{padding:1.5rem 2rem .5rem}.profile-title h2{margin:0 0 .25rem}.profile-title p{color:#888;margin:0;font-size:.85rem}.profile-body{gap:1.5rem;padding:1.5rem 2rem;display:flex}.back-btn{cursor:pointer;color:#1976d2;background:0 0;border:none;font-size:.95rem}.profile-left{text-align:center;background:#fff;border:1px solid #e0e0e0;border-radius:12px;flex-direction:column;align-items:center;width:260px;min-width:260px;padding:1.5rem;display:flex}.profile-avatar-large{color:#fff;background:#1976d2;border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;margin-bottom:.75rem;font-size:2rem;display:flex;overflow:hidden}.profile-avatar-large img{object-fit:cover;width:100%;height:100%}.profile-left h3{margin:0 0 .25rem}.profile-role{color:#888;margin:0 0 1rem;font-size:.85rem}.profile-info{text-align:left;color:#555;flex-direction:column;gap:.5rem;width:100%;margin:0 0 1.25rem;padding:0;font-size:.85rem;list-style:none;display:flex}.allowance{text-align:left;width:100%;margin-bottom:1.25rem}.allowance h4{margin:0 0 .75rem;font-size:.9rem}.allowance-row{color:#555;justify-content:space-between;margin-bottom:.3rem;font-size:.85rem;display:flex}.remaining{color:#f44336;font-weight:700}.progress-bar{background:#e0e0e0;border-radius:4px;height:8px;margin:.5rem 0 .25rem;overflow:hidden}.progress-fill{background:#1976d2;border-radius:4px;height:100%}.progress-label{color:#888;margin:0;font-size:.75rem}.profile-actions{gap:.5rem;width:100%;margin-bottom:.75rem;display:flex}.btn-add-holiday{color:#fff;cursor:pointer;background:#1976d2;border:none;border-radius:6px;flex:1;padding:.5rem;font-size:.8rem}.btn-away{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:6px;flex:1;padding:.5rem;font-size:.8rem}.btn-delete{color:#fff;cursor:pointer;background:#f44336;border:none;border-radius:6px;width:100%;padding:.5rem;font-size:.8rem}.profile-right{background:#fff;border:1px solid #e0e0e0;border-radius:12px;flex:1;padding:1.5rem}.profile-right h3{margin:0 0 .25rem}.profile-right>p{color:#888;margin:0 0 1rem;font-size:.85rem}.tabs{gap:.5rem;margin-bottom:1.25rem;display:flex}.tab-btn{cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:20px;padding:.4rem 1rem;font-size:.85rem}.tab-btn.active{color:#fff;background:#1976d2;border-color:#1976d2}.holiday-card{border:1px solid #e0e0e0;border-radius:8px;gap:1rem;margin-bottom:.75rem;padding:1rem;display:flex}.holiday-card-date{flex-direction:column;align-items:center;min-width:40px;display:flex}.month{text-transform:uppercase;color:#888;font-size:.7rem}.day-num{font-size:1.4rem;font-weight:700}.holiday-card-badges{gap:.4rem;margin-bottom:.3rem;display:flex}.status-badge{color:#fff;border-radius:4px;padding:.2rem .5rem;font-size:.7rem}.type-badge{color:#fff;background:#ff9800;border-radius:4px;padding:.2rem .5rem;font-size:.7rem}.holiday-card-dates{margin:0 0 .2rem;font-size:.85rem}.holiday-card-days{color:#888;margin:0;font-size:.8rem}.profile-summary{border-top:1px solid #e0e0e0;gap:1rem;margin-top:1.5rem;padding-top:1rem;display:flex}.summary-card{text-align:center;border:1px solid #e0e0e0;border-radius:8px;flex:1;padding:.75rem}.summary-num{margin:0;font-size:1.5rem;font-weight:700}.summary-label{color:#888;margin:0;font-size:.75rem}
