:root{--primary: #1a56db;--primary-dark: #1341a8;--primary-light: #e8f0fe;--text: #111827;--text-secondary: #6b7280;--border: #e5e7eb;--bg: #f9fafb;--white: #ffffff;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--status-none-bg: #f3f4f6;--status-none-text: #6b7280;--status-first-bg: #bbf7d0;--status-first-text: #14532d;--status-last-bg: #fef08a;--status-last-text: #854d0e;--status-left-bg: #fecaca;--status-left-text: #991b1b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}a{color:var(--primary);text-decoration:none}.status-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.status-badge.none{background:var(--status-none-bg);color:var(--status-none-text)}.status-badge.first_call{background:var(--status-first-bg);color:var(--status-first-text)}.status-badge.last_call{background:var(--status-last-bg);color:var(--status-last-text)}.status-badge.left{background:var(--status-left-bg);color:var(--status-left-text)}.page-container{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--primary);color:var(--white);padding:0 1.5rem;height:56px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}.header h1{font-size:1.2rem;font-weight:700;letter-spacing:-.01em}.header-right{display:flex;align-items:center;gap:.75rem}.header-user{font-size:.875rem;opacity:.9}.main-content{flex:1;padding:1.5rem;max-width:1200px;margin:0 auto;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:background .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--white);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-danger{background:#dc2626;color:var(--white)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.4)}.btn-ghost:hover:not(:disabled){background:#ffffff1a}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.btn-first{background:var(--status-first-bg);color:var(--status-first-text);border:1px solid #86efac}.btn-first:hover:not(:disabled){background:#86efac}.btn-last{background:var(--status-last-bg);color:var(--status-last-text);border:1px solid #fde047}.btn-last:hover:not(:disabled){background:#fde047}.btn-left{background:var(--status-left-bg);color:var(--status-left-text);border:1px solid #fca5a5}.btn-left:hover:not(:disabled){background:#fca5a5}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text)}.form-input,.form-select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:var(--white);color:var(--text);width:100%;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1a56db26}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a56db,#0d3c91);padding:1rem}.auth-card{background:var(--white);border-radius:12px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 20px 40px #0003}.auth-logo{text-align:center;margin-bottom:1.5rem}.auth-logo h2{font-size:1.6rem;font-weight:700;color:var(--primary)}.auth-logo p{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form .btn-primary{margin-top:.5rem;padding:.625rem 1rem;font-size:1rem}.auth-error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;border-radius:var(--radius);padding:.625rem .875rem;font-size:.875rem}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:1.5rem}.tab-btn{padding:.625rem 1.25rem;background:none;border:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-btn:hover{color:var(--primary)}.buses-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.bus-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.bus-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.125rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.75rem;transition:box-shadow .2s}.bus-card:hover{box-shadow:var(--shadow-md)}.bus-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.bus-name{font-weight:700;font-size:1.05rem;color:var(--text)}.bus-count{font-size:.8rem;color:var(--text-secondary)}.bus-count-btn{background:none;border:none;padding:0;font-size:.8rem;color:var(--primary);cursor:pointer;text-align:left}.bus-count-btn:hover{text-decoration:underline}.bus-students{margin:.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-height:180px;overflow-y:auto}.bus-student-row{display:flex;justify-content:space-between;padding:.25rem .125rem;font-size:.8rem;border-bottom:1px solid #f3f4f6}.bus-student-row:last-child{border-bottom:none}.bus-student-homeroom{color:var(--text-secondary);font-size:.75rem}.bus-students-loading,.bus-students-empty{padding:.5rem;font-size:.8rem;color:var(--text-secondary);text-align:center}.bus-card-actions{display:flex;gap:.375rem;flex-wrap:wrap}.bus-card-actions .btn{flex:1;min-width:70px;font-size:.75rem;padding:.35rem .5rem}.bus-card-actions .btn.active-status{outline:2px solid currentColor;outline-offset:1px}.students-toolbar{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap;align-items:center}.students-toolbar .form-input,.students-toolbar .form-select{width:auto;min-width:160px}.table-wrapper{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse;background:var(--white);font-size:.875rem}thead th{background:var(--bg);padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}tbody td{padding:.75rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg)}.inactive-row{opacity:.5}.action-btns{display:flex;gap:.375rem;align-items:center}.inline-edit-row td{background:var(--primary-light)}.inline-edit-inputs{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.inline-edit-inputs .form-input,.inline-edit-inputs .form-select{width:auto;min-width:120px;padding:.3rem .6rem}.teacher-filter{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.teacher-filter label{font-weight:500;font-size:.9rem}.teacher-filter .form-select{width:auto;min-width:200px}.student-list{display:flex;flex-direction:column;gap:.5rem}.student-row{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:var(--shadow)}.student-name{font-weight:500;font-size:.95rem}.student-bus{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.bus-label{font-size:.875rem;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--white);border-radius:12px;padding:2rem;width:100%;max-width:480px;box-shadow:0 20px 40px #0003}.modal h3{font-size:1.15rem;font-weight:700;margin-bottom:1.25rem}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.google-signin-container{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:.5rem}.divider{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.8rem;margin:.25rem 0;width:100%}.divider:before,.divider:after{content:"";flex:1;border-top:1px solid var(--border)}@media (max-width: 640px){.main-content{padding:1rem}.bus-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.header h1{font-size:1rem}.auth-card{padding:1.5rem}.student-row,.buses-header{flex-direction:column;align-items:flex-start}}.loading-state,.empty-state{padding:3rem;text-align:center;color:var(--text-secondary);font-size:.95rem}.spinner{display:inline-block;width:2rem;height:2rem;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:.75rem}@keyframes spin{to{transform:rotate(360deg)}}.conn-indicator{width:8px;height:8px;border-radius:50%;display:inline-block}.conn-indicator.connected{background:#22c55e}.conn-indicator.disconnected{background:#ef4444}
