@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Serif+Display&display=swap";:root{--color-bg:#faf7f2;--color-bg-warm:#f4eee5;--color-surface:#fff;--color-surface-raised:#fffdf9;--color-primary:#c75b39;--color-primary-hover:#a84a2e;--color-primary-light:#faede8;--color-secondary:#5b8a72;--color-secondary-hover:#4a7360;--color-secondary-light:#eaf3ee;--color-accent:#d4a853;--color-accent-light:#fdf6e7;--color-danger:#c44536;--color-danger-hover:#a33829;--color-danger-light:#fce8e6;--color-success:#5b8a72;--color-success-hover:#4a7360;--color-text:#2d2a26;--color-text-secondary:#7a756e;--color-text-muted:#a9a29a;--color-border:#e8e2d9;--color-border-light:#f0ebe3;--color-overlay:#2d2a2673;--font-display:"DM Serif Display", Georgia, serif;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--shadow-sm:0 1px 3px #2d2a260f, 0 1px 2px #2d2a260a;--shadow-md:0 4px 12px #2d2a2614, 0 2px 4px #2d2a260a;--shadow-lg:0 12px 40px #2d2a261f, 0 4px 12px #2d2a260f;--shadow-inner:inset 0 1px 3px #2d2a260f;--ease-out:cubic-bezier(.22, 1, .36, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);font-size:15px;line-height:1.55}body:before{content:"";pointer-events:none;z-index:9999;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");position:fixed;inset:0}::selection{background:var(--color-primary-light);color:var(--color-primary)}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);z-index:10;justify-content:space-between;align-items:center;padding:.625rem 1.25rem;display:flex;position:relative}.app-topbar-left{align-items:center;gap:.625rem;display:flex}.app-topbar-left img{border-radius:4px;height:34px}.app-topbar-left span{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.01em;font-size:1.15rem}.app-topbar-right{align-items:center;gap:.75rem;font-size:.84rem;display:flex}.app-topbar-right .role{color:var(--color-text-muted);text-transform:capitalize;background:var(--color-bg-warm);letter-spacing:.02em;border-radius:99px;padding:.15rem .5rem;font-size:.78rem}.logout-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;font-size:.8rem;font-family:var(--font-body);color:var(--color-text-secondary);transition:all .2s var(--ease-out);padding:.3rem .75rem}.logout-btn:hover{background:var(--color-bg-warm);border-color:var(--color-text-muted);color:var(--color-text)}.app-tabs{background:var(--color-surface);border-bottom:2px solid var(--color-border-light);gap:0;padding:0 1.25rem;display:flex;overflow-x:auto}.app-tab{color:var(--color-text-secondary);letter-spacing:.01em;white-space:nowrap;transition:color .2s var(--ease-out), border-color .2s var(--ease-out);border-bottom:2.5px solid #0000;margin-bottom:-2px;padding:.8rem 1.25rem;font-size:.88rem;font-weight:500;text-decoration:none;position:relative}.app-tab:hover{color:var(--color-text)}.app-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.app-main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:1.25rem}.btn{border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:all .2s var(--ease-out);letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:.4rem;padding:.525rem 1.1rem;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn:not(:disabled):active{transform:scale(.97)}.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #c75b3940}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 14px #c75b394d}.btn--secondary{background:var(--color-bg-warm);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-border-light);border-color:var(--color-text-muted)}.btn--danger{background:var(--color-danger);color:#fff;box-shadow:0 2px 8px #c4453633}.btn--danger:hover:not(:disabled){background:var(--color-danger-hover);transform:translateY(-1px);box-shadow:0 4px 14px #c445364d}.btn--success{background:var(--color-success);color:#fff;box-shadow:0 2px 8px #5b8a7240}.btn--success:hover:not(:disabled){background:var(--color-success-hover);transform:translateY(-1px);box-shadow:0 4px 14px #5b8a724d}.btn--large{border-radius:var(--radius-lg);padding:.9rem 1.75rem;font-size:1.05rem}.form-group{margin-bottom:1rem}.form-group label{color:var(--color-text-secondary);letter-spacing:.025em;text-transform:uppercase;margin-bottom:.3rem;font-size:.8rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:.9rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);transition:border-color .2s var(--ease-out), box-shadow .2s var(--ease-out);outline:none;padding:.55rem .85rem}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-muted)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #c75b391a}.form-group input:disabled,.form-group select:disabled{background:var(--color-bg-warm);color:var(--color-text-muted);border-color:var(--color-border-light)}.form-row{gap:1rem;display:flex}.form-row .form-group{flex:1}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:box-shadow .2s var(--ease-out);margin-bottom:1rem;padding:1.35rem}.card-header{font-family:var(--font-display);color:var(--color-text);margin-bottom:.75rem;font-size:1.1rem;font-weight:400}.modal-overlay{background:var(--color-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .2s var(--ease-out);justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:var(--radius-xl);width:100%;max-width:540px;max-height:90vh;box-shadow:var(--shadow-lg);animation:slideUp .3s var(--ease-out);padding:1.75rem;position:relative;overflow-y:auto}.modal-title{font-family:var(--font-display);color:var(--color-text);border-bottom:1px solid var(--color-border-light);margin-bottom:1.25rem;padding-bottom:.75rem;font-size:1.25rem;font-weight:400}.modal-actions{border-top:1px solid var(--color-border-light);justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:1rem;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.kiosk-container{text-align:center;max-width:620px;animation:slideDown .4s var(--ease-out);margin:0 auto}.kiosk-container h1{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.02em;margin-bottom:.5rem;font-size:2rem}.kiosk-container h1:after{content:"";background:var(--color-primary);border-radius:99px;width:48px;height:3px;margin:.75rem auto 1.25rem;display:block}.kiosk-container h2{font-family:var(--font-display);color:var(--color-text);font-size:1.35rem;font-weight:400}.kiosk-buttons{flex-direction:column;gap:.875rem;max-width:420px;margin:0 auto;display:flex}.kiosk-buttons .btn{border-radius:var(--radius-lg);justify-content:center;padding:1.1rem 1.5rem;font-size:1.05rem}.kiosk-banner{background:var(--color-accent-light);border:1px solid var(--color-accent);border-radius:var(--radius-md);color:#8b6914;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1.15rem;font-size:.92rem;font-weight:500;display:flex}.kiosk-banner:before{content:"☀";font-size:1.1rem}.kiosk-avatar{object-fit:cover;border:3px solid var(--color-border);width:120px;height:120px;box-shadow:var(--shadow-md);border-radius:50%;margin:.5rem auto}.kiosk-info{text-align:left;background:var(--color-bg-warm);border-radius:var(--radius-md);border-left:3px solid var(--color-secondary);margin:1rem 0;padding:1rem}.kiosk-info p{color:var(--color-text-secondary);margin-bottom:.4rem;font-size:.92rem}.kiosk-info p strong{color:var(--color-text)}.grid-container{border-radius:var(--radius-lg);border:1px solid var(--color-border-light);width:100%;height:400px;box-shadow:var(--shadow-sm);overflow:hidden}.ag-theme-alpine{--ag-background-color:var(--color-surface);--ag-header-background-color:var(--color-bg-warm);--ag-odd-row-background-color:var(--color-surface-raised);--ag-row-hover-color:var(--color-primary-light);--ag-selected-row-background-color:var(--color-primary-light);--ag-font-family:var(--font-body);--ag-font-size:.85rem;--ag-header-font-weight:600;--ag-border-color:var(--color-border-light);--ag-header-foreground-color:var(--color-text-secondary);--ag-cell-horizontal-padding:14px}.staff-layout{animation:slideDown .3s var(--ease-out);grid-template-columns:1fr;gap:1rem;display:grid}.staff-tabs{gap:.5rem;margin-bottom:.5rem;display:flex}.staff-tab{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;font-size:.88rem;font-weight:500;font-family:var(--font-body);color:var(--color-text-secondary);transition:all .2s var(--ease-out);padding:.5rem 1.15rem}.staff-tab:hover{border-color:var(--color-text-muted);color:var(--color-text)}.staff-tab--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 2px 8px #c75b3933}.toolbar{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.75rem 1rem;display:flex}.toolbar input{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);outline:none;padding:.4rem .65rem;transition:border-color .2s}.toolbar input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #c75b3914}.toolbar h2{font-family:var(--font-display);color:var(--color-text);font-size:1.15rem;font-weight:400}.vm-list{flex-direction:column;gap:.5rem;display:flex}.vm-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .2s var(--ease-out);animation:slideDown .3s var(--ease-out);align-items:center;gap:1rem;padding:.85rem 1.1rem;display:flex}.vm-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.vm-card-name{min-width:150px;color:var(--color-text);font-weight:600}.vm-card-time{color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-size:.82rem}.vm-card select{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.82rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);cursor:pointer;outline:none;padding:.3rem .5rem;transition:border-color .2s}.vm-card select:focus{border-color:var(--color-primary)}.vm-positions{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.vm-position-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);text-align:center;min-width:80px;transition:all .2s var(--ease-out);box-shadow:var(--shadow-sm);padding:.6rem .9rem;font-size:.82rem}.vm-position-card .count{font-variant-numeric:tabular-nums;color:var(--color-text);font-size:1.1rem;font-weight:700}.vm-position-card .label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:.15rem;font-size:.75rem;font-weight:500}.dashboard-controls{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.85rem 1rem;display:flex}.dashboard-controls select{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);cursor:pointer;outline:none;padding:.4rem .65rem;transition:border-color .2s}.dashboard-controls select:focus{border-color:var(--color-primary)}.chart-container{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);margin-bottom:1rem;padding:1.25rem}.calendar-filters{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.85rem 1rem;display:flex}.calendar-filters select,.calendar-filters input[type=date]{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);outline:none;padding:.4rem .65rem;transition:border-color .2s}.calendar-filters select:focus,.calendar-filters input[type=date]:focus{border-color:var(--color-primary)}.calendar-filters label{color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:.35rem;font-size:.85rem;font-weight:500;display:flex}.terms-list{text-align:left;margin:1rem 0;padding-left:1.25rem}.terms-list li{color:var(--color-text-secondary);margin-bottom:.6rem;font-size:.9rem;line-height:1.55}.terms-list li strong{color:var(--color-danger)}.members-section{border-top:1px solid var(--color-border-light);margin-top:1.25rem;padding-top:1rem}.members-section h4{font-family:var(--font-display);color:var(--color-text);margin-bottom:.6rem;font-size:1rem;font-weight:400}.member-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.member-row input{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-size:.88rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);outline:none;flex:1;padding:.45rem .7rem;transition:border-color .2s}.member-row input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #c75b3914}.ql-container{min-height:120px;font-family:var(--font-body)!important;border-color:var(--color-border)!important;border-radius:0 0 var(--radius-md) var(--radius-md)!important}.ql-toolbar{border-color:var(--color-border)!important;border-radius:var(--radius-md) var(--radius-md) 0 0!important;background:var(--color-bg-warm)!important}.fc{font-size:.85rem;font-family:var(--font-body)!important}.fc .fc-toolbar-title{font-family:var(--font-display)!important;font-size:1.2rem!important;font-weight:400!important}.fc .fc-button{font-family:var(--font-body)!important;border-radius:var(--radius-sm)!important;font-size:.82rem!important}.fc .fc-button-primary{background:var(--color-primary)!important;border-color:var(--color-primary)!important}.fc .fc-button-primary:hover,.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--color-primary-hover)!important;border-color:var(--color-primary-hover)!important}.fc .fc-event-shift{background:var(--color-primary)!important;border-color:var(--color-primary)!important;border-radius:4px!important}.fc .fc-event-meal{background:var(--color-secondary)!important;border-color:var(--color-secondary)!important;border-radius:4px!important}.fc .fc-daygrid-day.fc-day-today{background:var(--color-primary-light)!important}.fc .fc-col-header-cell{background:var(--color-bg-warm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-size:.78rem;font-weight:600}.fc th,.fc td{border-color:var(--color-border-light)!important}.login-overlay{background:var(--color-bg);background:linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-warm) 50%, var(--color-bg) 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-overlay:before{content:"";pointer-events:none;background:radial-gradient(at 20%,#c75b390f 0%,#0000 60%),radial-gradient(at 80% 20%,#5b8a720d 0%,#0000 50%);position:absolute;inset:0}.login-card{border-radius:var(--radius-xl);border:1px solid var(--color-border-light);background:var(--color-surface);width:100%;max-width:400px;box-shadow:var(--shadow-lg);animation:slideUp .4s var(--ease-out);margin:0 auto;padding:2.25rem;position:relative}.login-brand{flex-direction:column;align-items:center;gap:.6rem;margin-bottom:2rem;display:flex}.login-brand img,.login-logo{object-fit:contain;width:auto;max-width:200px;height:52px}.login-brand h1{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.01em;font-size:1.35rem;font-weight:400}.login-form{flex-direction:column;gap:1rem;display:flex}.login-error{border-radius:var(--radius-md);background:var(--color-danger-light);color:var(--color-danger);animation:slideDown .2s var(--ease-out);border:1px solid #c4453626;padding:.75rem 1rem;font-size:.85rem}.login-hint{color:var(--color-text-secondary);text-align:center;font-size:.88rem;line-height:1.5}.login-btn{justify-content:center;width:100%;padding:.7rem 1rem;font-size:.95rem}.login-link{cursor:pointer;color:var(--color-text-muted);text-align:center;width:100%;font-size:.85rem;font-family:var(--font-body);background:0 0;border:none;margin-top:.25rem;transition:color .2s}.login-link:hover{color:var(--color-primary)}.password-wrap{position:relative}.password-wrap input{width:100%;padding-right:3.5rem}.toggle-pw{cursor:pointer;color:var(--color-text-muted);font-size:.75rem;font-family:var(--font-body);letter-spacing:.03em;text-transform:uppercase;background:0 0;border:none;font-weight:600;transition:color .2s;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.toggle-pw:hover{color:var(--color-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media (width<=640px){.app-main{padding:.75rem}.form-row{flex-direction:column;gap:0}.toolbar{padding:.5rem .75rem}.vm-card{flex-wrap:wrap;gap:.5rem}.vm-card-name{min-width:auto}.dashboard-controls,.calendar-filters{gap:.5rem}.kiosk-container h1{font-size:1.6rem}.modal{margin:.5rem;padding:1.25rem}}
