:root{--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827;--green: #10b981;--red: #ef4444;--amber: #f59e0b;--radius: 12px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,system-ui,sans-serif;background:var(--gray-50);color:var(--gray-900);font-size:15px}.container{max-width:540px;margin:0 auto;padding:0 16px 80px}.header{background:var(--blue-600);color:#fff;padding:18px 16px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}.header h1{margin:0;font-size:17px;font-weight:600}.header .right{font-size:13px;opacity:.9}.card{background:#fff;border-radius:var(--radius);padding:16px;margin:12px 0;box-shadow:0 1px 3px #0000000d}button{background:var(--blue-600);color:#fff;border:0;padding:14px 20px;border-radius:var(--radius);font-size:16px;font-weight:600;width:100%;cursor:pointer}button.secondary{background:#fff;color:var(--blue-600);border:1px solid var(--blue-100)}button.success{background:var(--green)}button.danger{background:var(--red)}input,select,textarea{width:100%;padding:14px 16px;border:1px solid var(--gray-200);border-radius:var(--radius);font-size:16px;background:#fff}.label{font-size:13px;color:var(--gray-700);font-weight:500;margin:14px 0 6px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gray-200);display:flex;padding:8px 0;justify-content:space-around;max-width:540px;margin:0 auto}.bottom-nav a{flex:1;text-align:center;padding:8px;color:var(--gray-500);text-decoration:none;font-size:11px;font-weight:500}.bottom-nav a.active{color:var(--blue-600)}.bottom-nav .icon{font-size:22px;display:block}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--blue-50),white);padding:16px}.login-page .card{width:100%;max-width:420px}.row{display:flex;gap:8px;align-items:center}.row>*{flex:1}.student-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--gray-100)}.student-row .name{flex:1;font-weight:500}.status-btn{width:36px;height:36px;border-radius:50%;border:2px solid var(--gray-200);background:#fff;margin:0 4px;padding:0;font-size:16px;cursor:pointer;transition:all .15s}.status-btn.active.present{background:var(--green);border-color:var(--green);color:#fff}.status-btn.active.absent{background:var(--red);border-color:var(--red);color:#fff}.status-btn.active.late{background:var(--amber);border-color:var(--amber);color:#fff}.empty{text-align:center;padding:60px 20px;color:var(--gray-500)}.title{font-size:20px;font-weight:700;color:var(--gray-900);margin:0 0 16px}.error{background:#fee2e2;color:#991b1b;padding:12px;border-radius:var(--radius);margin-top:12px;font-size:13px}
