.app-footer{text-align:center;color:#888;font-size:.9em;margin:2em 0 1em}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px;background:#f0f4f1;color:#1a2e1f;min-height:100vh}nav{background:#1b4332;color:#fff;padding:0 1.5rem;height:52px;display:flex;align-items:center;gap:1.25rem;box-shadow:0 2px 6px #00000040}nav .brand{font-weight:700;font-size:1.1rem;letter-spacing:.02em;margin-right:.5rem}nav a{color:#ffffffd9;text-decoration:none;font-size:.95rem}nav a:hover,nav a.router-link-active{color:#fff;text-decoration:underline}nav .sep{color:#ffffff4d}nav .nav-right{margin-left:auto;display:flex;align-items:center;gap:1rem}nav .username{font-size:.85rem;opacity:.7}nav .small-link{font-size:.82rem;opacity:.75}nav .locale-picker{display:flex;align-items:center;gap:.5rem;color:#ffffffd9;font-size:.85rem}nav .locale-picker select{min-width:110px;padding:.25rem .5rem}nav .btn-logout{background:#ffffff1f;border:1px solid rgba(255,255,255,.35);color:#fff;padding:.3rem .85rem;border-radius:4px;cursor:pointer;font-size:.88rem}nav .btn-logout:hover{background:#ffffff38}.cal-link{display:inline-flex;align-items:center;gap:.4rem;color:#2d6a4f;font-size:.9rem;text-decoration:none;border:1px solid #2d6a4f;padding:.3rem .75rem;border-radius:4px}.cal-link:hover{background:#e8f5e9}main{max-width:1100px;margin:2rem auto;padding:0 1.25rem}h1{font-size:1.6rem;color:#1b4332;margin-bottom:1.25rem}h2{font-size:1.35rem;color:#1b4332;margin-bottom:1rem}h3{font-size:1.1rem;color:#2d6a4f;margin-bottom:.75rem}.controls{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1.25rem}.controls label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#444}input[type=text],input[type=number],input[type=date],input[type=password],input[type=email],select,textarea{padding:.45rem .75rem;border:1px solid #c5d5c9;border-radius:5px;font-size:.95rem;background:#fff;color:#1a2e1f;transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:#2d6a4f;box-shadow:0 0 0 3px #2d6a4f1f}select{cursor:pointer;min-width:140px}button,.btn{padding:.45rem 1.1rem;background:#2d6a4f;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:.92rem;transition:background .15s}button:hover,.btn:hover{background:#1b4332}button:disabled{opacity:.5;cursor:not-allowed}button.danger{background:#b91c1c}button.danger:hover{background:#991b1b}button.secondary{background:#6b7280}button.secondary:hover{background:#4b5563}button.sm{padding:.3rem .75rem;font-size:.84rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;background:#fff;border-radius:7px;overflow:hidden;box-shadow:0 1px 4px #00000014}thead tr{background:#1b4332;color:#fff}th{padding:.6rem .9rem;text-align:left;font-weight:600;font-size:.9rem;white-space:nowrap}td{padding:.55rem .9rem;border-bottom:1px solid #e9f0eb;font-size:.93rem}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f0f8f3}td.best4{background:#d1fae5;font-weight:600}td.absent{color:#9ca3af;font-style:italic}td.total{font-weight:700}tr.absent-row td{color:#9ca3af;font-style:italic}.card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 4px #00000014;margin-bottom:1.5rem}.login-wrap{max-width:380px;margin:5rem auto 0}.login-title{text-align:center;margin-bottom:1.5rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.88rem;color:#555;margin-bottom:.3rem}.field input{width:100%}.legend{font-size:.82rem;color:#6b7280;margin-top:.6rem}.error{color:#b91c1c;font-size:.9rem;margin:.5rem 0}.success{color:#16a34a;font-weight:600}.loading{color:#6b7280;padding:2rem 0;text-align:center}a{color:#2d6a4f;text-decoration:none}a:hover{text-decoration:underline}.back-link{display:inline-block;margin-bottom:1rem;font-size:.9rem}.row-gap{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:1rem}.row-gap label{display:flex;flex-direction:column;gap:.25rem;font-size:.88rem;color:#555}
