.guided-tour-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#334155,#3498db);z-index:10000;display:flex;align-items:center;justify-content:center;animation:overlayFadeIn .5s ease-out;cursor:pointer}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.guided-tour-container{width:100%;max-width:900px;height:100vh;max-height:100vh;display:flex;flex-direction:column;padding:1.5rem 1.5rem 2rem;position:relative;overflow-y:auto;box-sizing:border-box}.tour-skip-btn{position:absolute;top:1rem;right:1rem;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.875rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tour-skip-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.tour-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;transition:all .5s ease;min-height:0}.tour-content.animating{opacity:.5;transform:scale(.98)}.tour-illustration-container{width:100%;max-width:400px;height:250px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative}.tour-illustration{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.illustration-svg{width:100%;height:100%;border-radius:16px;overflow:visible}.school-bus{animation:busEnter 1s ease-out forwards}@keyframes busEnter{0%{transform:translate(-100px);opacity:0}to{transform:translate(0);opacity:1}}.school-bus .wheel{animation:wheelSpin .5s linear infinite;transform-box:fill-box;transform-origin:center center}.road-line{animation:roadMove 1s linear infinite}@keyframes roadMove{0%{stroke-dashoffset:0}to{stroke-dashoffset:-50}}.cloud{animation:cloudFloat 20s ease-in-out infinite}.cloud-1{animation-delay:0s}.cloud-2{animation-delay:-10s}@keyframes cloudFloat{0%,to{transform:translate(0)}50%{transform:translate(30px)}}.child-head{animation:childBob 2s ease-in-out infinite}.child-head:nth-child(1){animation-delay:0s}.child-head:nth-child(2){animation-delay:.3s}.child-head:nth-child(3){animation-delay:.6s}@keyframes childBob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.headlight{animation:headlightGlow 2s ease-in-out infinite}@keyframes headlightGlow{0%,to{opacity:.8}50%{opacity:1;filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}}.floating-icons{position:absolute;inset:0;pointer-events:none}.floating-icon{position:absolute;width:50px;height:50px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #00000026;animation:floatIcon 3s ease-in-out infinite}.floating-icon svg{width:24px;height:24px}.floating-icon.location{top:10%;right:5%;color:#f44336;animation-delay:0s}.floating-icon.bell{top:60%;left:0;color:#ffd93d;animation-delay:.5s}.floating-icon.shield{bottom:10%;right:15%;color:#4caf50;animation-delay:1s}.floating-icon.child-icon{top:20%;left:5%;color:#334155;animation-delay:.3s}@keyframes floatIcon{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-10px) rotate(5deg)}75%{transform:translateY(5px) rotate(-5deg)}}.add-child-illustration .bg-circle-1,.add-child-illustration .bg-circle-2{animation:pulseCircle 3s ease-in-out infinite}.add-child-illustration .bg-circle-2{animation-delay:.5s}@keyframes pulseCircle{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.add-child-illustration .profile-card{animation:cardFloat 4s ease-in-out infinite}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.add-child-illustration .form-line{animation:lineSlideIn .8s ease-out forwards;opacity:0;transform:translate(-20px)}.add-child-illustration .line-1{animation-delay:.3s}.add-child-illustration .line-2{animation-delay:.5s}@keyframes lineSlideIn{to{opacity:1;transform:translate(0)}}.add-child-illustration .add-button{animation:buttonPulse 2s ease-in-out infinite}@keyframes buttonPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.add-child-illustration .deco-dot{animation:dotBounce 2s ease-in-out infinite}.add-child-illustration .dot-1{animation-delay:0s}.add-child-illustration .dot-2{animation-delay:.3s}.add-child-illustration .dot-3{animation-delay:.6s}@keyframes dotBounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.track-bus-illustration .route-path,.create-route-illustration .drawing-route{stroke-dashoffset:500;animation:drawRoute 2s ease-out forwards}@keyframes drawRoute{to{stroke-dashoffset:0}}.track-bus-illustration .stop,.create-route-illustration .waypoint{opacity:0;transform:scale(0);animation:stopPopIn .5s ease-out forwards}.track-bus-illustration .stop-1,.create-route-illustration .wp-1{animation-delay:.5s}.track-bus-illustration .stop-2,.create-route-illustration .wp-2{animation-delay:1s}.track-bus-illustration .stop-3,.create-route-illustration .wp-3{animation-delay:1.5s}.track-bus-illustration .school{animation-delay:2s}@keyframes stopPopIn{to{opacity:1;transform:scale(1)}}.track-bus-illustration .bus-marker{animation:busMove 4s ease-in-out infinite}@keyframes busMove{0%{transform:translate(0)}33%{transform:translate(70px,-40px)}66%{transform:translate(140px,-60px)}to{transform:translate(0)}}.track-bus-illustration .eta-badge{animation:etaSlideIn .8s ease-out forwards;animation-delay:1s;opacity:0;transform:translateY(20px)}@keyframes etaSlideIn{to{opacity:1;transform:translateY(0)}}.operator-welcome-illustration .dash-card{opacity:0;transform:translateY(20px);animation:cardSlideUp .6s ease-out forwards}.operator-welcome-illustration .card-1{animation-delay:.2s}.operator-welcome-illustration .card-2{animation-delay:.4s}.operator-welcome-illustration .card-3{animation-delay:.6s}@keyframes cardSlideUp{to{opacity:1;transform:translateY(0)}}.operator-welcome-illustration .mini-map{animation:mapFadeIn .8s ease-out forwards;animation-delay:.8s;opacity:0}@keyframes mapFadeIn{to{opacity:1}}.operator-welcome-illustration .route-preview{stroke-dasharray:200;stroke-dashoffset:200;animation:drawPreview 1.5s ease-out forwards;animation-delay:1s}@keyframes drawPreview{to{stroke-dashoffset:0}}.create-route-illustration .cursor-pointer{animation:cursorMove 3s ease-in-out infinite}@keyframes cursorMove{0%,to{transform:translate(0)}50%{transform:translate(50px,-30px)}}.create-route-illustration .cursor-ring{animation:ringPulse 1.5s ease-out infinite}@keyframes ringPulse{0%{r:15;opacity:.5}to{r:30;opacity:0}}.manage-students-illustration .student-card{opacity:0;animation:studentCardIn .6s ease-out forwards}.manage-students-illustration .card-1{animation-delay:.1s}.manage-students-illustration .card-2{animation-delay:.3s}.manage-students-illustration .card-3{animation-delay:.5s}@keyframes studentCardIn{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.manage-students-illustration .conn-line{stroke-dasharray:100;stroke-dashoffset:100;animation:drawLine .8s ease-out forwards;animation-delay:.8s}@keyframes drawLine{to{stroke-dashoffset:0}}.driver-welcome-illustration .steering-wheel{animation:wheelRotate 10s linear infinite;transform-origin:center}@keyframes wheelRotate{0%{transform:rotate(-10deg)}50%{transform:rotate(10deg)}to{transform:rotate(-10deg)}}.driver-welcome-illustration .phone-mount{animation:phoneFloat 3s ease-in-out infinite}@keyframes phoneFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.driver-mode-illustration .route-item{opacity:0;transform:translate(-20px);animation:itemSlideIn .5s ease-out forwards}.driver-mode-illustration .item-1{animation-delay:.2s}.driver-mode-illustration .item-2{animation-delay:.4s}.driver-mode-illustration .item-3{animation-delay:.6s}@keyframes itemSlideIn{to{opacity:1;transform:translate(0)}}.driver-mode-illustration .route-item.active{animation:activePulse 2s ease-in-out infinite;animation-delay:1s}@keyframes activePulse{0%,to{box-shadow:0 0 #3498db66}50%{box-shadow:0 0 0 10px #3498db00}}.check-in-illustration .checkin-card{animation:cardBounceIn .6s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes cardBounceIn{0%{opacity:0;transform:scale(.3) translateY(50px)}to{opacity:1;transform:scale(1) translateY(0)}}.check-in-illustration .check-button{cursor:pointer;transition:transform .2s ease}.check-in-illustration .check-button:hover{transform:scale(1.1)}.check-in-illustration .ripple{opacity:0;animation:rippleEffect 2s ease-out infinite}.check-in-illustration .ripple-1{animation-delay:0s}.check-in-illustration .ripple-2{animation-delay:.5s}@keyframes rippleEffect{0%{r:20;opacity:.6}to{r:50;opacity:0}}.check-in-illustration .notification-sent{opacity:0;animation:notifSlideUp .5s ease-out forwards;animation-delay:1s}@keyframes notifSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tour-text-content{text-align:center;color:#fff;max-width:500px;animation:textFadeIn .8s ease-out;flex-shrink:0}@keyframes textFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tour-title{font-size:2rem;font-weight:700;margin:0 0 .25rem;text-shadow:0 2px 10px rgba(0,0,0,.2)}.tour-subtitle{font-size:1.1rem;font-weight:400;margin:0 0 .5rem;opacity:.9}.tour-description{font-size:1rem;line-height:1.6;opacity:.85;margin:0}.tour-navigation{display:flex;flex-direction:column;align-items:center;gap:1rem;padding-top:.5rem;flex-shrink:0}.tour-progress{display:flex;gap:.75rem}.progress-dot{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:transparent;cursor:pointer;transition:all .3s ease;padding:0}.progress-dot:hover{border-color:#fff;transform:scale(1.2)}.progress-dot.active{background:#fff;border-color:#fff;transform:scale(1.2)}.progress-dot.completed{background:#ffffff80;border-color:#ffffff80}.tour-nav-buttons{display:flex;gap:1rem}.tour-btn{padding:.75rem 1.75rem;border-radius:30px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.tour-btn-primary{background:#fff;color:#334155}.tour-btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0003}.tour-btn-secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.tour-btn-secondary:hover{background:#ffffff4d}.tour-dont-show{display:flex;align-items:center;gap:.5rem;color:#ffffffb3;font-size:.875rem;cursor:pointer}.tour-dont-show input[type=checkbox]{width:16px;height:16px;cursor:pointer}.tour-dont-show:hover{color:#fff}.tour-content.fade-up .tour-illustration-container{animation:fadeUp .6s ease-out}.tour-content.slide-right .tour-illustration-container{animation:slideRight .6s ease-out}.tour-content.route-draw .tour-illustration-container{animation:scaleIn .6s ease-out}.tour-content.bounce-in .tour-illustration-container{animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55)}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.guided-tour-container{padding:1rem}.tour-illustration-container{height:200px}.tour-title{font-size:1.75rem}.tour-subtitle{font-size:1rem}.tour-description{font-size:.875rem}.tour-btn{padding:.75rem 1.5rem;font-size:.875rem}.floating-icon{width:40px;height:40px}.floating-icon svg{width:20px;height:20px}}@media(max-width:480px){.tour-skip-btn{top:.5rem;right:.5rem;padding:.4rem .8rem;font-size:.75rem}.tour-illustration-container{height:180px}.tour-title{font-size:1.5rem}.tour-nav-buttons{flex-direction:column;width:100%}.tour-btn{width:100%}}.tour-help-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#334155,#3498db);border:none;color:#fff;font-size:1.125rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 10px #3498db4d}.tour-help-btn:hover{transform:scale(1.1);box-shadow:0 4px 15px #3498db80}.tour-help-btn svg{width:20px;height:20px}.qr-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.qr-modal{background:#fff;border-radius:16px;padding:2rem;max-width:320px;width:100%;text-align:center;animation:modalSlideIn .2s ease-out}.qr-modal-title{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 1.5rem}.qr-code-container{display:flex;justify-content:center;margin-bottom:1rem;background:#fff;padding:.5rem;border-radius:8px;position:relative;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.qr-code-container:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.03) 50%,transparent 60%);background-size:200% 200%;animation:shimmer 2s linear infinite;z-index:1}@keyframes shimmer{0%{background-position:200% 200%}to{background-position:-200% -200%}}.qr-watermark-overlay{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:2}.qr-watermark{position:absolute;font-size:8px;color:#0000000f;white-space:nowrap;font-family:monospace;animation:watermarkMove 3s ease-in-out infinite alternate;user-select:none;-webkit-user-select:none}.qr-watermark:nth-child(1){top:15%;left:10%;animation-delay:0s}.qr-watermark:nth-child(2){top:45%;right:10%;animation-delay:.5s}.qr-watermark:nth-child(3){bottom:20%;left:20%;animation-delay:1s}@keyframes watermarkMove{0%{transform:translate(0) translateY(0);opacity:.4}50%{opacity:.8}to{transform:translate(10px) translateY(5px);opacity:.4}}.qr-modal-card-id{font-size:1rem;font-weight:600;color:#333;margin:0 0 .5rem;font-family:monospace}.qr-modal-hint{font-size:.85rem;color:#666;margin:0 0 1.5rem}.qr-modal-buttons{display:flex;gap:.75rem;width:100%}.qr-modal-print,.qr-modal-close{flex:1;padding:.75rem 1rem;font-size:.9rem}.billing-summary-card{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);margin:1rem 0;overflow:hidden}.billing-summary-card.loading{opacity:.7}.billing-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--background-secondary);border-bottom:1px solid var(--border-color)}.billing-title{display:flex;align-items:center;gap:.5rem}.billing-title svg{color:var(--primary-color)}.billing-title h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.billing-period{font-size:.85rem;color:var(--text-secondary)}.billing-loading{padding:2rem;text-align:center;color:var(--text-secondary)}.billing-children-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;padding:1rem}.parent-dashboard-grid .billing-children-grid{grid-template-columns:1fr 1fr}@media(min-width:1400px){.parent-dashboard-grid .billing-children-grid{grid-template-columns:repeat(3,1fr)}}.billing-child-card{background:var(--background-secondary);border-radius:8px;padding:.75rem;text-align:center}.billing-child-card .child-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem;font-size:.95rem}.billing-child-card .child-days{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.billing-child-card .child-amount{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.billing-child-card .child-amount.zero{color:var(--text-secondary);font-weight:500}.billing-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--background-secondary);border-top:1px solid var(--border-color);gap:1rem}.billing-total{display:flex;flex-direction:column}.total-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.total-amount{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.total-amount.zero{color:var(--text-secondary)}.billing-pay-btn{padding:.6rem 1.5rem;text-decoration:none;white-space:nowrap}.weekly-hero{background:linear-gradient(135deg,var(--primary-color) 0%,#1a5f4a 100%);border-radius:16px;padding:1.5rem;color:#fff;margin-bottom:1.5rem}.weekly-hero.loading,.weekly-hero.error{display:flex;align-items:center;justify-content:center;min-height:200px}.hero-loading,.hero-error{font-size:1rem;opacity:.8}.hero-period{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.2)}.period-label{font-size:1.1rem;font-weight:600}.period-dates{font-size:.85rem;opacity:.8}.hero-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}.hero-stat{text-align:center;padding:.75rem;border-radius:12px;background:#ffffff1a;border:none;color:#fff;font-family:inherit;position:relative}.hero-stat.clickable{cursor:pointer;transition:all .2s ease}.hero-stat.clickable:hover{background:#fff3;transform:translateY(-2px)}.hero-stat.clickable.expanded{background:#ffffff40;box-shadow:0 4px 12px #0003}.hero-stat.highlight{background:#fff3;border:1px solid rgba(255,255,255,.3)}.hero-stat.highlight.clickable:hover{background:#ffffff4d}.expand-icon{position:absolute;bottom:4px;right:8px;font-size:.6rem;opacity:.6}.stat-value{display:block;font-size:1.4rem;font-weight:700;margin-bottom:.25rem}.stat-value.earned{color:#a8e6cf}.stat-value.collected{color:#88d8b0}.stat-value.outstanding{color:#ffeaa7}.stat-label{display:block;font-size:.8rem;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.stat-sublabel{display:block;font-size:.75rem;opacity:.7;margin-top:.25rem}.stat-drilldown{background:#0003;border-radius:12px;padding:1rem;margin-bottom:1rem;animation:slideDown .2s ease}.stat-drilldown h4{font-size:.85rem;font-weight:600;margin:0 0 .75rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.drilldown-list{list-style:none;padding:0;margin:0}.drilldown-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.drilldown-item:last-child{border-bottom:none}.drilldown-main{display:flex;flex-direction:column;gap:.15rem}.drilldown-name{font-size:.9rem;font-weight:500}.drilldown-meta{font-size:.75rem;opacity:.7}.drilldown-values{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem}.drilldown-rides{font-size:.75rem;opacity:.7}.drilldown-amount{font-size:.9rem;font-weight:600;color:#a8e6cf}.drilldown-amount.outstanding{color:#ffeaa7}.drilldown-link{display:block;text-align:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);font-size:.85rem;color:#ffffffe6;text-decoration:none}.drilldown-link:hover{color:#fff;text-decoration:underline}.drilldown-empty{font-size:.9rem;opacity:.7;text-align:center;margin:0;padding:.5rem 0}.drilldown-summary{background:#ffffff0d;border-radius:8px;padding:.75rem}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.1)}.summary-row.total{font-weight:600;padding-top:.75rem;margin-top:.25rem;border-top:1px solid rgba(255,255,255,.2);border-bottom:none}.hero-parents-owing{background:#00000026;border-radius:12px;padding:1rem;margin-bottom:1rem}.hero-parents-owing h4{font-size:.85rem;font-weight:600;margin:0 0 .75rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.parents-list{list-style:none;padding:0;margin:0}.parent-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.parent-item:last-child{border-bottom:none}.parent-name{font-size:.9rem;font-weight:500}.parent-balance{font-size:.9rem;font-weight:600;color:#ffeaa7}.view-all-link{display:block;text-align:center;margin-top:.75rem;font-size:.85rem;color:#ffffffe6;text-decoration:none}.view-all-link:hover{color:#fff;text-decoration:underline}.hero-drafts-alert{display:flex;align-items:center;gap:.75rem;background:#ffeaa733;border:1px solid rgba(255,234,167,.4);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.alert-icon{font-size:1.2rem}.alert-text{flex:1;font-size:.9rem}.alert-action{color:#ffeaa7;font-weight:600;text-decoration:none;font-size:.9rem}.alert-action:hover{text-decoration:underline}.hero-actions{display:flex;gap:.75rem;margin-top:1rem}.hero-btn{flex:1;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;text-align:center;text-decoration:none;transition:all .2s ease}.hero-btn-primary{background:#fff;color:var(--primary-color)}.hero-btn-primary:hover{background:#f0f0f0;transform:translateY(-1px)}.hero-btn-secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.hero-btn-secondary:hover{background:#ffffff4d;transform:translateY(-1px)}@media(max-width:600px){.weekly-hero{padding:1.25rem}.hero-period{flex-direction:column;align-items:flex-start;gap:.25rem}.hero-stats-grid{grid-template-columns:1fr;gap:.75rem}.hero-stat{display:flex;justify-content:space-between;align-items:center;text-align:left;padding:.75rem 1rem}.hero-stat .expand-icon{position:static;margin-left:.5rem}.stat-value{font-size:1.2rem;order:2}.stat-label{order:1}.stat-sublabel{display:none}.drilldown-item{flex-direction:column;align-items:flex-start;gap:.5rem}.drilldown-values{flex-direction:row;gap:1rem;width:100%;justify-content:space-between}.hero-actions{flex-direction:column}}.quick-actions-section{margin-bottom:1.5rem}.quick-actions-grid{display:flex;gap:.75rem;flex-wrap:wrap}.quick-action-card{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--card-bg);border-radius:10px;border:1px solid var(--border-color);text-decoration:none;transition:all .2s ease;white-space:nowrap}.quick-action-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.quick-action-card.color-primary{border-left:3px solid var(--primary-color)}.quick-action-card.color-primary .action-icon{color:var(--primary-color)}.quick-action-card.color-green{border-left:3px solid #10b981}.quick-action-card.color-green .action-icon{color:#10b981}.quick-action-card.color-blue{border-left:3px solid #3b82f6}.quick-action-card.color-blue .action-icon{color:#3b82f6}.quick-action-card.color-purple{border-left:3px solid #8b5cf6}.quick-action-card.color-purple .action-icon{color:#8b5cf6}.action-icon{display:flex;align-items:center;justify-content:center}.action-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}@media(max-width:480px){.quick-actions-grid{flex-direction:column}.quick-action-card{justify-content:center}}.ai-chat-button{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;color:#fff;cursor:pointer;box-shadow:0 4px 16px #6366f166;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:1000}.ai-chat-button:hover{transform:scale(1.05);box-shadow:0 6px 24px #6366f180}.ai-chat-button.hidden{opacity:0;pointer-events:none;transform:scale(.8)}.ai-badge{position:absolute;top:-2px;right:-2px;background:#10b981;color:#fff;font-size:.6rem;font-weight:700;padding:2px 5px;border-radius:8px}.ai-chat-panel{position:fixed;top:16px;bottom:16px;right:16px;width:420px;max-width:calc(100vw - 32px);background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:1001;opacity:0;transform:translate(20px);pointer-events:none;transition:all .3s ease}.ai-chat-panel.open{opacity:1;transform:translate(0);pointer-events:auto}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border-radius:16px 16px 0 0}.header-left{display:flex;align-items:center;gap:.5rem;font-weight:600}.header-actions{display:flex;gap:.5rem}.clear-btn,.close-btn{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.clear-btn:hover,.close-btn:hover{background:#ffffff4d}.ai-chat-setup{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.setup-icon{font-size:3rem;margin-bottom:1rem}.ai-chat-setup h3{margin:0 0 .5rem;color:var(--text-primary)}.ai-chat-setup p{margin:0 0 1.5rem;color:var(--text-secondary)}.setup-note{font-size:.8rem;color:var(--text-secondary);margin-top:1rem!important}.ai-chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.ai-welcome{text-align:center;padding:1rem}.ai-welcome h3{font-size:1.1rem;margin:0 0 .5rem}.ai-welcome p{font-size:.9rem;color:var(--text-secondary);margin:0 0 1rem}.quick-prompts{display:flex;flex-direction:column;gap:.5rem}.quick-prompts button{background:#f3f4f6;border:1px solid #e5e7eb;padding:.6rem 1rem;border-radius:8px;font-size:.85rem;cursor:pointer;text-align:left;transition:all .2s}.quick-prompts button:hover{background:#e5e7eb;border-color:#d1d5db}.message{max-width:85%;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-content{padding:.75rem 1rem;border-radius:12px;font-size:.9rem;line-height:1.5}.message.user .message-content{white-space:pre-wrap;background:#6366f1;color:#fff;border-bottom-right-radius:4px}.message.assistant .message-content{background:#f3f4f6;color:var(--text-primary);border-bottom-left-radius:4px}.message.error .message-content{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.markdown-content{font-size:.9rem;line-height:1.6}.markdown-content p{margin:0 0 .75rem}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:.5rem 0;padding-left:1.25rem}.markdown-content li{margin:.25rem 0}.markdown-content strong{font-weight:600}.markdown-content code{background:#00000014;padding:.15rem .4rem;border-radius:4px;font-size:.85em;font-family:SF Mono,Monaco,monospace}.markdown-content pre{background:#00000014;padding:.75rem;border-radius:6px;overflow-x:auto;margin:.5rem 0}.markdown-content pre code{background:none;padding:0}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin:.75rem 0 .5rem;font-weight:600;line-height:1.3}.markdown-content h1{font-size:1.25rem}.markdown-content h2{font-size:1.1rem}.markdown-content h3{font-size:1rem}.markdown-content h4{font-size:.95rem}.markdown-content table{width:100%;border-collapse:collapse;margin:.5rem 0;font-size:.85rem}.markdown-content th,.markdown-content td{border:1px solid rgba(0,0,0,.15);padding:.4rem .6rem;text-align:left}.markdown-content th{background:#0000000d;font-weight:600}.markdown-content blockquote{margin:.5rem 0;padding:.5rem .75rem;border-left:3px solid #6366f1;background:#6366f10d;border-radius:0 4px 4px 0}.markdown-content hr{border:none;border-top:1px solid rgba(0,0,0,.15);margin:.75rem 0}.message-actions{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(0,0,0,.1);display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.actions-label{font-size:.75rem;color:var(--text-secondary);margin-right:.25rem}.action-badge{background:#6366f11a;color:#4f46e5;font-size:.7rem;padding:2px 6px;border-radius:4px;text-transform:capitalize}.message.loading .typing-indicator{display:flex;gap:4px;padding:.75rem 1rem;background:#f3f4f6;border-radius:12px 12px 12px 4px}.typing-indicator span{width:8px;height:8px;background:#9ca3af;border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}.typing-indicator span:nth-child(3){animation-delay:0s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.ai-chat-input{display:flex;gap:.5rem;padding:1rem;border-top:1px solid #e5e7eb}.ai-chat-input input{flex:1;padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:24px;font-size:.9rem;outline:none;transition:border-color .2s}.ai-chat-input input:focus{border-color:#6366f1}.ai-chat-input button{width:44px;height:44px;border-radius:50%;background:#6366f1;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.ai-chat-input button:hover:not(:disabled){background:#4f46e5}.ai-chat-input button:disabled{background:#d1d5db;cursor:not-allowed}@media(max-width:600px){.ai-chat-panel{bottom:0;right:0;left:0;width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0}.ai-chat-header{border-radius:0}.ai-chat-button{bottom:16px;right:16px}}@media(prefers-color-scheme:dark){.ai-chat-panel{background:#1f2937}.message.assistant .message-content{background:#374151;color:#f3f4f6}.quick-prompts button{background:#374151;border-color:#4b5563;color:#f3f4f6}.quick-prompts button:hover{background:#4b5563}.ai-chat-input{border-top-color:#374151}.ai-chat-input input{background:#374151;border-color:#4b5563;color:#f3f4f6}}.operator-dashboard{max-width:1000px;margin:0 auto;padding:1rem}.operator-header{margin-bottom:1.5rem}.operator-header h1{font-size:1.5rem;margin:0 0 .5rem;color:var(--text-primary)}.dashboard-intro{font-size:1rem;color:var(--text-secondary);margin:0;line-height:1.5}.today-date{font-size:.95rem;color:var(--text-secondary);margin:0}.summary-cards-section{margin-bottom:1.5rem}.summary-cards-row{display:flex;gap:.5rem}.summary-card-simple{flex:1;display:flex;align-items:center;gap:.5rem;padding:.75rem .875rem;background:var(--card-bg);border-radius:10px;text-decoration:none;color:inherit;border:1px solid var(--border-color);transition:box-shadow .2s,border-color .2s}.summary-card-simple:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #00000014}.summary-card-simple .summary-card-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-card-simple-content{flex:1;min-width:0;display:flex;flex-direction:column}.summary-card-title{font-size:.7rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.summary-card-number{font-size:.85rem;font-weight:600;color:var(--text-primary)}.summary-card-simple .summary-card-arrow{color:var(--text-muted);font-size:.9rem;flex-shrink:0}.summary-card-simple:hover .summary-card-arrow{color:var(--primary-color)}.summary-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.summary-card{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--card-bg);border-radius:12px;text-decoration:none;color:inherit;border:1px solid var(--border-color);transition:box-shadow .2s,transform .2s;position:relative}.summary-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.summary-card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-card-icon.routes-icon{background:#e3f2fd;color:#1976d2}.summary-card-icon.students-icon{background:#f3e5f5;color:#7b1fa2}.summary-card-icon.buses-icon{background:#fff3e0;color:#f57c00}.summary-card-icon.schools-icon{background:#e8f5e9;color:#388e3c}.summary-card-icon.payments-icon{background:#fce4ec;color:#c2185b}.summary-card-icon.drivers-icon{background:#e8eaf6;color:#3f51b5}.summary-card-content{flex:1;min-width:0}.summary-card-content h3{margin:0 0 .25rem;font-size:.9rem;font-weight:600;color:var(--text-primary)}.summary-card-stats{display:flex;flex-direction:column;gap:.125rem}.stat-primary{font-size:.85rem;font-weight:600;color:var(--text-primary)}.stat-secondary{font-size:.75rem;color:var(--text-secondary)}.summary-card-total{font-size:.7rem;color:var(--text-muted);margin-top:.25rem}.summary-card-badge{display:inline-block;font-size:.65rem;padding:.15rem .5rem;border-radius:10px;margin-top:.35rem;font-weight:500}.summary-card-badge.in-progress{background:#cce5ff;color:#004085}.summary-card-badge.pending{background:#f8d7da;color:#721c24}.summary-card-arrow{position:absolute;top:50%;right:.75rem;transform:translateY(-50%);color:var(--text-muted);font-size:1rem}.summary-card:hover .summary-card-arrow{color:var(--text-secondary)}.quick-actions-section{margin-bottom:1rem}.quick-action-row{display:flex;gap:.5rem}.quick-action-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:.75rem .5rem;background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;text-decoration:none;color:var(--text-primary);transition:background .2s;font-size:.85rem}.quick-action-btn:hover{background:var(--card-bg-hover)}.quick-action-btn.alert{background:#fff3cd;border-color:#ffc107;color:#856404}.quick-action-btn.alert:hover{background:#ffeeba}.quick-action-btn.payment{background:#f3e5f5;border-color:#ce93d8;color:#6a1b9a}.quick-action-btn.payment:hover{background:#e1bee7}.quick-action-label{font-weight:500;white-space:nowrap}.add-student-section{margin-bottom:1rem}.add-student-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--card-bg);border:2px dashed var(--border-color);border-radius:12px;text-decoration:none;color:inherit;transition:border-color .2s,background .2s}.add-student-card:hover{border-color:var(--primary-color);background:var(--background-secondary)}.add-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary-color);border-radius:10px;font-size:1.5rem;font-weight:600;flex-shrink:0}.add-student-content{flex:1;min-width:0}.add-student-content h3{margin:0 0 .125rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.add-student-content p{margin:0;font-size:.85rem;color:var(--text-secondary)}.add-arrow{color:var(--text-muted);font-size:1.25rem;flex-shrink:0}.add-student-card:hover .add-arrow{color:var(--primary-color)}.record-cash-section{margin-bottom:1.5rem}.record-cash-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:16px;text-decoration:none;color:#fff;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #4caf504d}.record-cash-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.record-cash-icon{width:48px;height:48px;border-radius:12px;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.record-cash-icon svg{width:28px;height:28px}.record-cash-content{flex:1}.record-cash-content h3{margin:0 0 .25rem;font-size:1.1rem;font-weight:700}.record-cash-content p{margin:0;font-size:.85rem;opacity:.9}.record-cash-arrow svg{width:24px;height:24px;opacity:.7}.checkin-hero-section{margin-bottom:1.5rem}.checkin-hero-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#28a745,#20c997);border-radius:16px;text-decoration:none;color:#fff;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #28a7454d}.checkin-hero-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #28a74566}.checkin-hero-icon{width:48px;height:48px;border-radius:12px;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checkin-hero-icon svg{width:28px;height:28px}.checkin-hero-content{flex:1;min-width:0}.checkin-hero-content h2{margin:0 0 .25rem;font-size:1.25rem;font-weight:700}.checkin-hero-content p{margin:0;font-size:.9rem;opacity:.9}.checkin-hero-badge{padding:.5rem .875rem;background:#ffffff40;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap}.checkin-hero-arrow{width:24px;height:24px;flex-shrink:0;opacity:.8}.checkin-hero-arrow svg{width:24px;height:24px}@media(max-width:480px){.checkin-hero-card{flex-wrap:wrap;gap:.75rem}.checkin-hero-content{flex:1 1 calc(100% - 60px);order:1}.checkin-hero-icon{order:0}.checkin-hero-badge{order:2;flex:1 1 100%;text-align:center;margin-top:.25rem}.checkin-hero-arrow{display:none}}.checkin-section{margin-bottom:1.5rem}.btn-checkin{display:block;width:100%;padding:1rem;background:var(--success-color);color:#fff;text-align:center;text-decoration:none;border-radius:10px;font-size:1.1rem;font-weight:600;transition:background .2s}.btn-checkin:hover{filter:brightness(.9)}.todays-routes-section{margin-bottom:1.5rem}.todays-routes-section h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.routes-progress-list{display:flex;flex-direction:column;gap:.5rem}.route-progress-item{display:block;background:var(--card-bg);border-radius:10px;padding:.875rem 1rem;text-decoration:none;color:inherit;border:1px solid var(--border-color);transition:box-shadow .2s,transform .2s}.route-progress-item:hover{box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.route-progress-item.complete{background:#f8fff9;border-color:#c3e6cb}.route-progress-item.in_progress{background:#f8fbff;border-color:#b8daff}.route-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.route-progress-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.route-complete-check{color:var(--success-color);font-weight:700;font-size:1rem}.route-progress-bar{height:8px;background:var(--background-secondary);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.route-progress-fill{height:100%;border-radius:4px;transition:width .3s ease;background:#6c757d}.route-progress-fill.in_progress{background:#007bff}.route-progress-fill.complete{background:#28a745}.route-progress-footer{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}.route-progress-status{color:var(--text-secondary);font-weight:500}.route-progress-item.complete .route-progress-status{color:var(--success-color)}.route-progress-item.in_progress .route-progress-status{color:var(--info-color)}.route-progress-time{color:var(--text-muted)}.unread-messages-link{display:block;text-align:center;padding:.75rem;background:#fff3cd;color:#856404;border-radius:8px;text-decoration:none;font-weight:500;margin-top:1rem}.unread-messages-link:hover{background:#ffeeba}.driver-dashboard{max-width:500px;margin:0 auto;padding:1rem}.driver-dashboard .dashboard-header{text-align:center;margin-bottom:2rem}.driver-dashboard .dashboard-header h1{font-size:1.5rem;margin:0 0 .5rem}.driver-dashboard .dashboard-intro{font-size:1rem;color:var(--text-secondary);margin:0;line-height:1.5}.driver-route-section h2{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1rem;text-align:center}.driver-route-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:var(--shadow)}.driver-route-card.primary{border:2px solid var(--success-color)}.driver-route-card.secondary{opacity:.8;border:1px solid var(--border-color)}.driver-route-card.empty{text-align:center;color:var(--text-secondary);padding:2rem}.driver-route-card .route-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.driver-route-card .route-card-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.route-time-badge{font-size:.75rem;padding:.25rem .75rem;background:var(--background-secondary);border-radius:20px;color:var(--text-secondary)}.route-card-details{display:flex;gap:1rem;color:var(--text-secondary);margin-bottom:1.5rem}.btn-start-route{width:100%;padding:1rem;font-size:1.25rem;font-weight:600;background:var(--success-color);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.btn-start-route:hover{filter:brightness(.9)}.driver-no-routes{text-align:center;padding:2rem;color:var(--text-secondary)}.driver-no-routes .btn{margin-top:1rem}.parent-dashboard{max-width:500px;margin:0 auto;padding:1rem}.parent-dashboard .dashboard-header{margin-bottom:1.5rem}.parent-dashboard .dashboard-header h1{font-size:1.5rem;margin:0 0 .5rem}.parent-dashboard .dashboard-intro{font-size:1rem;color:var(--text-secondary);margin:0;line-height:1.5}.children-status-section{margin-bottom:2rem}.no-children-card{text-align:center;padding:2rem;background:var(--background-secondary);border-radius:16px;border:2px dashed var(--border-color)}.no-children-icon{width:60px;height:60px;margin:0 auto 1rem;background:var(--card-bg-hover);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--text-muted)}.no-children-card h2{margin:0 0 .5rem;font-size:1.25rem;color:var(--text-primary)}.no-children-card p{color:var(--text-secondary);margin-bottom:1.5rem}.child-status-card{display:flex;flex-direction:column;gap:.875rem;padding:1.25rem;background:var(--card-bg);border-radius:16px;margin-bottom:1rem;box-shadow:var(--shadow);border-left:4px solid var(--text-muted);position:relative}.child-status-card.status-waiting{border-left-color:var(--text-muted)}.child-status-card.status-on_bus{border-left-color:var(--info-color);background:var(--info-light)}.child-status-card.status-at_school,.child-status-card.status-home{border-left-color:var(--success-color);background:var(--success-light)}.child-status-card.status-absent{border-left-color:var(--warning-color);background:var(--warning-light)}.child-card-top{display:flex;align-items:center;gap:.875rem}.child-avatar{flex-shrink:0}.child-avatar img{width:52px;height:52px;border-radius:50%;object-fit:cover}.avatar-placeholder{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#334155,#3498db);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.child-status-info{flex:1;min-width:0}.child-status-headline{font-size:1rem;font-weight:600;margin:0 0 .125rem;color:var(--text-primary)}.child-status-detail{font-size:.85rem;color:var(--text-secondary);margin:0}.child-card-badges{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end}.absent-badge{padding:.2rem .5rem;background:var(--warning-color);color:#fff;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.balance-badge{padding:.2rem .5rem;background:var(--danger-light);color:var(--danger-color);border-radius:4px;font-size:.75rem;font-weight:600}.btn-qr-primary{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;font-size:1rem;font-weight:600;border-radius:10px}.btn-qr-primary svg{flex-shrink:0}.child-card-secondary-actions{display:flex;gap:.5rem;align-items:center}.child-card-secondary-actions .btn-mark-absent,.child-card-secondary-actions .btn-cancel-absence{flex:1;padding:.625rem .875rem;font-size:.875rem;border-radius:8px}.btn-mark-absent{background:var(--background-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-mark-absent:hover{background:var(--card-bg-hover)}.btn-cancel-absence{background:transparent;color:var(--warning-color);border:1px solid var(--warning-color)}.btn-cancel-absence:hover{background:var(--warning-light)}.child-overflow-wrapper{position:relative}.child-overflow-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:background .2s}.child-overflow-btn:hover{background:var(--card-bg-hover)}.child-overflow-menu{position:absolute;bottom:100%;right:0;margin-bottom:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 16px #00000026;min-width:160px;z-index:100;overflow:hidden}.child-overflow-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;min-height:44px;color:var(--text-primary);text-decoration:none;font-size:.9rem;transition:background .15s;border:none;background:none;width:100%;text-align:left;cursor:pointer}.child-overflow-item:hover{background:var(--background-secondary)}.child-overflow-item svg{color:var(--text-secondary);flex-shrink:0}.btn-track{flex-shrink:0;padding:.5rem 1rem;background:var(--info-color);color:#fff;border:none;border-radius:8px;font-weight:500;text-decoration:none;font-size:.9rem}.btn-track:hover{filter:brightness(.85)}.manage-children-links{display:flex;gap:.75rem;margin-top:.5rem}.manage-children-links .btn{flex:1;padding:.75rem 1rem;border-radius:8px;text-decoration:none;font-weight:500;font-size:.9rem;text-align:center;transition:background .2s,border-color .2s}.manage-children-links .btn-secondary{background:var(--background-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.manage-children-links .btn-secondary:hover{background:var(--card-bg-hover)}.manage-children-links .btn-outline{background:transparent;color:var(--info-color);border:1px solid var(--info-color)}.manage-children-links .btn-outline:hover{background:var(--info-color);color:#fff}.notifications-preview{background:var(--background-secondary);border-radius:12px;padding:1rem}.notifications-preview h3{font-size:.9rem;color:var(--text-secondary);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.notification-preview-list{list-style:none;padding:0;margin:0}.notification-preview-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-color);font-size:.9rem;color:var(--text-primary)}.notification-preview-list li:last-child{border-bottom:none}.notification-preview-list li.unread strong{color:var(--info-color)}.notification-time{font-size:.8rem;color:var(--text-muted)}.view-all-link{display:block;text-align:center;margin-top:.75rem;color:var(--info-color);font-size:.9rem;text-decoration:none}.view-all-link:hover{text-decoration:underline}@media(max-width:480px){.summary-cards-row{flex-direction:column}.summary-card-simple{padding:.625rem .75rem}.summary-cards-grid{grid-template-columns:1fr}.quick-action-row{flex-direction:column}.quick-action-btn{padding:.875rem;min-height:44px}.child-card-top{flex-wrap:wrap}.child-card-badges{flex-direction:row;flex-wrap:wrap;gap:.375rem}.child-overflow-menu{right:-.5rem}.btn-track{width:100%;text-align:center;margin-top:.5rem}.manage-children-links{flex-direction:column}}.data-management-bar{margin-bottom:1rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--radius);border:1px solid var(--border-color)}.data-management-actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.data-management-actions .btn{display:inline-flex;align-items:center;gap:.35rem}.data-management-actions .btn svg{flex-shrink:0}.delete-confirm-modal .warning-text{color:var(--danger-color);margin-bottom:1rem;padding:.75rem;background:var(--danger-bg, rgba(220, 53, 69, .1));border-radius:var(--radius);font-size:.95rem}.delete-confirm-modal .form-group{margin-bottom:1rem}.delete-confirm-modal .form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary)}.delete-confirm-modal .form-group input{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:var(--radius);font-size:1rem;background:var(--bg-primary);color:var(--text-primary)}.delete-confirm-modal .form-group input:focus{outline:none;border-color:var(--danger-color)}@media(max-width:600px){.data-management-actions{flex-direction:column;align-items:stretch}.data-management-actions .btn{justify-content:center}}.qr-grid-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.qr-grid-modal{background:#fff;border-radius:16px;padding:1.5rem;max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.qr-grid-header{text-align:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.qr-grid-header h2{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 .25rem}.qr-grid-count{font-size:.875rem;color:#666;margin:0}.qr-grid-preview{flex:1;overflow-y:auto;padding:.5rem;background:#f9fafb;border-radius:8px;margin-bottom:1rem}.qr-grid-container{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.qr-grid-card{border:1px solid #ddd;border-radius:8px;padding:.75rem;text-align:center;background:#fff}.grid-card-name{font-size:.875rem;font-weight:700;color:#1a1a1a;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-card-grade{font-size:.7rem;color:#666;margin-bottom:.5rem}.grid-card-photo{width:50px;height:50px;border-radius:50%;object-fit:cover;margin-bottom:.5rem;border:2px solid #e5e7eb}.grid-card-initials{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#334155,#3498db);color:#fff;font-size:1.125rem;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto .5rem}.grid-card-qr{display:flex;justify-content:center;margin-bottom:.375rem}.grid-card-id{font-family:Courier New,monospace;font-size:.7rem;font-weight:600;color:#333;letter-spacing:.5px}.qr-grid-actions{display:flex;gap:1rem;justify-content:center;padding-top:.5rem}.qr-grid-actions .btn{min-width:120px}@media(max-width:500px){.qr-grid-container{grid-template-columns:1fr}.qr-grid-modal{padding:1rem}}@media print{.qr-grid-overlay,.qr-grid-modal,.qr-grid-actions{display:none!important}}.printable-qr-wrapper{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.print-card{width:3.5in;padding:.5in;text-align:center;border:2px dashed #ccc;border-radius:12px;background:#fff}.print-card-name{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem}.print-card-grade{font-size:.875rem;color:#666;margin:0 0 1rem}.print-card-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;margin-bottom:1rem;border:3px solid #e5e7eb}.print-card-initials{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#334155,#3498db);color:#fff;font-size:1.75rem;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.print-card-qr{display:flex;justify-content:center;margin-bottom:.75rem;background:#fff;padding:.5rem}.print-card-id{font-family:Courier New,monospace;font-size:1rem;font-weight:600;color:#333;letter-spacing:1px;margin:0 0 .5rem}.print-card-footer{font-size:.7rem;color:#999;margin-top:.75rem}.print-actions{display:flex;gap:1rem;justify-content:center}@media print{.print-actions{display:none!important}.print-card{border:2px solid #ccc;break-inside:avoid;page-break-inside:avoid}}.page-intro{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-intro-content{flex:1;min-width:250px}.page-intro-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.page-intro h1{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.help-toggle{width:24px;height:24px;border-radius:50%;border:2px solid var(--text-secondary);background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.help-toggle:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light, rgba(79, 70, 229, .1))}.help-toggle.active{border-color:var(--primary);background:var(--primary);color:#fff}.page-intro-description{font-size:1rem;color:var(--text-secondary);margin:0;line-height:1.5;max-width:600px}.page-intro-help{margin-top:1rem;padding:1rem;background:var(--bg-secondary, #f8f9fa);border-radius:8px;border-left:3px solid var(--primary);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.page-intro-help p{margin:0;font-size:.9rem;color:var(--text-primary);line-height:1.6}.page-intro-help ul{margin:.5rem 0 0;padding-left:1.25rem}.page-intro-help li{font-size:.9rem;color:var(--text-primary);line-height:1.6;margin-bottom:.25rem}.page-intro-help li:last-child{margin-bottom:0}.page-intro-actions{display:flex;gap:.5rem;flex-wrap:wrap}@media(max-width:600px){.page-intro{flex-direction:column}.page-intro-actions{width:100%}.page-intro-actions .btn{flex:1}}.progress-steps{display:flex;align-items:center;justify-content:center;margin-bottom:2rem;padding:1rem 0}.progress-step .step-number{width:36px;height:36px;border-radius:50%;background:var(--border-color, #e0e0e0);color:var(--text-secondary, #666);display:flex;align-items:center;justify-content:center;font-weight:600;transition:all .3s ease}.progress-step.active .step-number{background:var(--primary-color, #14b8a6);color:#fff;box-shadow:0 0 15px #14b8a666}.progress-step .step-label{font-size:.875rem;color:var(--text-secondary, #666)}.progress-step.active .step-label{color:var(--primary-color, #14b8a6);font-weight:500}.progress-line{width:60px;height:2px;background:var(--border-color, #e0e0e0);margin:0 1rem}@media(max-width:480px){.progress-line{width:30px}}.guardian-manager{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:1rem;margin-bottom:1rem}.guardian-manager.loading{color:var(--text-secondary, #64748b);font-size:.9rem;text-align:center;padding:2rem}.guardian-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.guardian-manager-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary, #1e293b)}.guardian-error{background:var(--danger-light, #fee2e2);color:var(--danger-color, #dc2626);padding:.5rem .75rem;border-radius:4px;font-size:.85rem;margin-bottom:1rem}.guardian-form,.guardian-edit-form{background:var(--background, #f8fafc);border-radius:6px;padding:1rem;margin-bottom:1rem}.guardian-form .form-row,.guardian-edit-form .form-row{margin-bottom:.75rem}.guardian-form .form-row label,.guardian-edit-form .form-row label{display:block;font-size:.85rem;font-weight:500;color:var(--text-primary, #1e293b);margin-bottom:.25rem}.guardian-form .form-row select,.guardian-edit-form .form-row select{width:100%;padding:.5rem;border:1px solid var(--border-color, #e2e8f0);border-radius:4px;font-size:.9rem;background:var(--card-bg, #fff);color:var(--text-primary, #1e293b)}.guardian-form .checkbox-row,.guardian-edit-form .checkbox-row{display:flex;align-items:center}.guardian-form .checkbox-row label,.guardian-edit-form .checkbox-row label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.guardian-form .checkbox-row input[type=checkbox],.guardian-edit-form .checkbox-row input[type=checkbox]{width:16px;height:16px;cursor:pointer}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.guardian-list{display:flex;flex-direction:column;gap:.75rem}.no-guardians{color:var(--text-secondary, #64748b);font-size:.9rem;text-align:center;padding:1rem}.guardian-card{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem;border:1px solid var(--border-color, #e2e8f0);border-radius:6px;background:var(--card-bg, #fff)}.guardian-card.primary{border-color:var(--primary-color, #3b82f6);background:var(--color-primary-light, rgba(59, 130, 246, .05))}.guardian-info{flex:1}.guardian-name{font-weight:600;font-size:.95rem;color:var(--text-primary, #1e293b);display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.primary-badge{background:var(--primary-color, #3b82f6);color:#fff;font-size:.65rem;font-weight:600;padding:.1rem .4rem;border-radius:3px;text-transform:uppercase;letter-spacing:.03em}.guardian-details{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;color:var(--text-secondary, #64748b);margin-bottom:.25rem}.guardian-details .relationship{text-transform:capitalize}.guardian-details .email:before,.guardian-details .phone:before{content:"|";margin-right:.5rem;color:var(--border-color, #e2e8f0)}.guardian-permissions{display:flex;gap:.35rem;margin-top:.25rem}.permission-tag{background:var(--success-light, #dcfce7);color:var(--success-color, #16a34a);font-size:.65rem;font-weight:500;padding:.1rem .35rem;border-radius:3px}.guardian-actions{display:flex;gap:.25rem}.guardian-actions .btn-link{background:none;border:none;color:var(--primary-color, #3b82f6);font-size:.8rem;cursor:pointer;padding:.25rem .5rem}.guardian-actions .btn-link:hover{text-decoration:underline}.guardian-actions .btn-link.danger{color:var(--danger-color, #dc2626)}@media(max-width:480px){.guardian-card{flex-direction:column}.guardian-actions{margin-top:.5rem;width:100%;justify-content:flex-end}.guardian-details{flex-direction:column;gap:.25rem}.guardian-details .email:before,.guardian-details .phone:before{display:none}}.undo-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background-color:#323232;color:#fff;padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:16px;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:slideUp .3s ease-out;min-width:200px;max-width:calc(100vw - 48px)}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.undo-toast-message{font-size:14px;font-weight:500;flex:1}.undo-toast-button{background:none;border:none;color:#4fc3f7;font-size:14px;font-weight:600;cursor:pointer;padding:4px 8px;margin:-4px -8px;border-radius:4px;transition:background-color .2s ease;text-transform:uppercase;letter-spacing:.5px}.undo-toast-button:hover{background-color:#4fc3f71a}.undo-toast-button:active{background-color:#4fc3f733}@media(max-width:480px){.undo-toast{bottom:16px;left:16px;right:16px;transform:none;max-width:none}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}}.shift-status-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.shift-status-header{display:flex;align-items:center;gap:.5rem}.shift-indicator{width:10px;height:10px;border-radius:50%;background:var(--text-muted)}.shift-indicator.active{background:var(--success-color);box-shadow:0 0 8px var(--success-color);animation:shiftPulse 1.5s ease-in-out infinite}@keyframes shiftPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.shift-label{font-weight:600;color:var(--text-primary)}.shift-details{display:flex;gap:1.5rem;font-size:.9rem;color:var(--text-secondary)}.btn-clock{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease}.btn-clock-in{background:var(--success-color);color:#fff}.btn-clock-in:hover:not(:disabled){filter:brightness(.9)}.btn-clock-out{background:var(--warning-color);color:#fff}.btn-clock-out:hover:not(:disabled){filter:brightness(.9)}.btn-clock:disabled{opacity:.6;cursor:not-allowed}.driver-status-bar{flex-shrink:0}.route-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--card-bg);border-bottom:1px solid var(--border-color)}.route-info h1{margin:0;font-size:1.5rem;color:var(--text-primary)}.bus-info{margin:.25rem 0 0;color:var(--text-secondary);font-size:.9rem}.header-actions{display:flex;align-items:center;gap:1rem}.btn-scan-qr{padding:.5rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;background:var(--info-color);color:#fff;transition:background .2s ease}.btn-scan-qr:hover{filter:brightness(.85)}.btn-scan-qr:active{transform:scale(.98)}.status-indicator{display:flex;align-items:center;gap:.5rem;color:var(--success-color);font-weight:500}.status-dot{width:12px;height:12px;border-radius:50%;background:var(--success-color)}.status-dot.pulsing{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.shift-status-bar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:var(--success-light);border-bottom:1px solid var(--success-color)}.shift-bar-info{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--success-color);font-weight:500}.shift-bar-indicator{width:8px;height:8px;border-radius:50%;background:var(--success-color);animation:pulse 1.5s ease-in-out infinite}.btn-clock-out-small{padding:.35rem .75rem;font-size:.8rem;font-weight:600;border:none;border-radius:4px;cursor:pointer;background:var(--warning-color);color:#fff;transition:background .2s ease}.btn-clock-out-small:hover:not(:disabled){filter:brightness(.9)}.btn-clock-out-small:disabled{opacity:.6;cursor:not-allowed}.progress-bar-container{padding:1rem;background:var(--card-bg);border-bottom:1px solid var(--border-color)}.progress-text{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.progress-bar{height:8px;background:var(--background-secondary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--success-color);transition:width .3s ease}.driver-student-list{flex:1;min-height:0;overflow-y:auto;padding:.5rem}.driver-student-list .empty-state{text-align:center;padding:3rem;color:var(--text-secondary)}.student-row{display:flex;align-items:center;gap:1rem;padding:1rem;margin:.5rem 0;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.student-row:active{transform:scale(.98)}.student-row.checking-in{opacity:.6;pointer-events:none}.student-waiting{background:var(--card-bg);border-left:4px solid var(--text-muted)}.student-waiting .student-status-icon{color:var(--text-muted)}.student-on-bus{background:var(--success-light);border-left:4px solid var(--success-color)}.student-on-bus .student-status-icon{color:var(--success-color)}.student-dropped{background:var(--background-secondary);border-left:4px solid var(--text-muted);opacity:.7}.student-dropped .student-status-icon{color:var(--success-color)}.student-status-icon{font-size:1.5rem;width:2rem;text-align:center}.student-details{flex:1}.student-name{font-weight:600;font-size:1.1rem;color:var(--text-primary)}.student-address{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.completed-badge{font-size:.75rem;padding:.25rem .5rem;background:var(--text-muted);color:#fff;border-radius:4px}.payment-badge{font-size:.7rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;white-space:nowrap}.payment-badge.unpaid{background:#ff6b6b;color:#fff}.payment-badge.paid{background:var(--success-color);color:#fff}.driver-mode-page{max-width:600px;margin:0 auto;height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.page-description{color:var(--text-secondary);margin-top:.5rem}.driver-name-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--color-primary-light, #e3f2fd);color:var(--color-primary, #1976d2);padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.95rem;margin-top:.5rem}.driver-name-badge .driver-icon{font-size:1.1rem}.driver-mode-container{display:flex;flex-direction:column;gap:1.5rem;padding:1rem}.selection-form{display:flex;flex-direction:column;gap:1rem}.action-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0}.clock-in-reminder{color:var(--warning-color, #f59e0b);font-size:.9rem;font-weight:500;margin:0;text-align:center}.btn-start{font-size:1.25rem;padding:1rem 3rem;border-radius:50px;border:none;cursor:pointer;font-weight:600;background:var(--success-color);color:#fff;transition:all .2s ease}.btn-start:hover:not(:disabled){filter:brightness(.9);transform:scale(1.02)}.btn-start:disabled{background:var(--text-muted);cursor:not-allowed}.footer-actions{padding:1rem;background:var(--card-bg);border-top:1px solid var(--border-color);display:flex;gap:.75rem;flex-shrink:0;margin-top:auto}.btn-check-missing{flex:1;padding:1rem;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;background:var(--warning-color);color:#fff;transition:background .2s ease}.btn-check-missing:hover:not(:disabled){filter:brightness(.9)}.btn-check-missing:disabled{opacity:.6;cursor:not-allowed}.btn-end-route{flex:1;padding:1rem;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;background:var(--danger-color);color:#fff;transition:background .2s ease}.btn-end-route:hover{filter:brightness(.9)}.assignment-notice{background:var(--color-primary-light, #e3f2fd);padding:.5rem .75rem;border-radius:6px;margin-bottom:.75rem}.assignment-notice small{color:var(--text-secondary);font-size:.85rem}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}.btn-link:hover{color:var(--color-primary-dark, #1565c0)}.data-mode-banner{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:6px;font-size:.8rem;font-weight:500}.data-mode-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.data-mode-label{font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:.7rem}.data-mode-description{color:inherit;opacity:.85;font-size:.75rem;font-weight:400}.data-mode-live{background:var(--success-light, #d1fae5);color:var(--success-dark, #065f46);border:1px solid var(--success-color, #10b981)}.data-mode-dot-live{background:var(--success-color, #10b981);animation:pulse-live 2s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.5}}.data-mode-simulation{background:#fef3c7;color:#92400e;border:2px solid #f59e0b}.data-mode-dot-simulation{background:#dc2626;animation:pulse-sim 1s ease-in-out infinite}@keyframes pulse-sim{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.data-mode-demo{background:#dbeafe;color:#1e40af;border:2px solid #3b82f6}.data-mode-dot-demo{background:#3b82f6;animation:pulse-demo 1.5s ease-in-out infinite}@keyframes pulse-demo{0%,to{opacity:1}50%{opacity:.4}}@media(max-width:640px){.data-mode-description{display:none}}.sim-controls-bar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--card-bg, #ffffff);border-bottom:2px solid #f59e0b;gap:1rem;flex-wrap:wrap;z-index:10}.sim-controls-left{display:flex;align-items:center;gap:.5rem}.sim-badge{display:inline-flex;align-items:center;gap:.35rem;background:#f59e0b;color:#000;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .5rem;border-radius:4px}.sim-badge-dot{width:8px;height:8px;border-radius:50%;background:#dc2626;animation:sim-pulse 1.2s ease-in-out infinite}@keyframes sim-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.sim-label{font-size:.85rem;font-weight:500;color:var(--text-primary, #1e293b)}.sim-controls-center{display:flex;align-items:center;gap:.75rem}.sim-play-btn{min-width:80px}.sim-speed-pills{display:flex;gap:.25rem}.sim-speed-pill{padding:.2rem .5rem;border:1px solid var(--border-color, #e2e8f0);border-radius:4px;background:var(--background, #f8fafc);color:var(--text-secondary, #64748b);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.sim-speed-pill:hover{border-color:var(--primary-color, #334155);color:var(--primary-color, #334155)}.sim-speed-pill.active{background:var(--primary-color, #334155);border-color:var(--primary-color, #334155);color:#fff}.sim-controls-right{display:flex;align-items:center;gap:.75rem}.sim-route-counts{display:flex;gap:.5rem;font-size:.75rem}.sim-count{padding:.15rem .4rem;border-radius:3px;font-weight:500}.sim-count-active{background:var(--success-light, #d1fae5);color:var(--success-color, #10b981)}.sim-count-pending{background:var(--warning-light, #fef3c7);color:var(--warning-color, #f59e0b)}.sim-count-completed{background:var(--background, #f8fafc);color:var(--text-secondary, #64748b)}@media(max-width:768px){.sim-controls-bar{padding:.4rem .75rem;gap:.5rem}.sim-label,.sim-route-counts{display:none}}.payment-methods-page,.checkout-page{max-width:600px}.page-header{margin-bottom:2rem}.page-header h1{margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);margin:0}.card-brand-icon{width:32px;height:32px}.card-brand-icon.visa{color:#1a1f71}.card-brand-icon.mastercard{color:#eb001b}.card-brand-icon.amex{color:#006fcf}.card-brand-icon.default{color:var(--text-secondary)}.saved-cards-section{margin-bottom:2rem}.no-cards-message{background:var(--card-bg);padding:3rem 2rem;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}.no-cards-icon{color:var(--text-secondary);margin-bottom:1rem}.no-cards-message h3{margin-bottom:.5rem}.no-cards-message p{color:var(--text-secondary);margin:0}.cards-list{display:flex;flex-direction:column;gap:1rem}.card-item{background:var(--card-bg);padding:1rem 1.25rem;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:1rem}.card-item.default{border:2px solid var(--primary-color)}.card-info{display:flex;align-items:center;gap:1rem;flex:1}.card-details{display:flex;flex-direction:column;gap:.25rem}.card-number{font-weight:500;font-family:monospace}.card-expiry{font-size:.875rem;color:var(--text-secondary)}.default-badge{background:var(--primary-color);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:var(--radius-sm);font-weight:500}.add-card-section{margin-top:1.5rem}.add-card-form-container{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.add-card-form-container h3{margin-bottom:1rem}.cancel-btn{margin-top:1rem;width:100%}.stripe-card-form{display:flex;flex-direction:column;gap:1rem}.card-element-container{padding:1rem;background:var(--background);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.card-element-container label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.card-error{color:#fa755a;font-size:.875rem;padding:.5rem;background:#fa755a1a;border-radius:var(--radius-sm)}.btn-block{width:100%}.checkout-content{display:flex;flex-direction:column;gap:1.5rem}.checkout-section{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.checkout-section h3{margin-bottom:1rem;font-size:1rem;color:var(--text-secondary)}.form-select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--background);color:var(--text-primary);font-size:1rem;cursor:pointer}.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.service-plans{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.plan-option{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.plan-option:hover{background:var(--card-bg-hover)}.plan-option.selected{border-color:var(--primary-color);background:rgba(var(--primary-rgb),.05)}.plan-option input[type=radio]{width:18px;height:18px;accent-color:var(--primary-color)}.plan-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.plan-name{font-weight:500}.plan-price{font-size:1.25rem;font-weight:600;color:var(--primary-color)}.plan-frequency{font-size:.75rem;color:var(--text-secondary)}.custom-amount{padding-top:1rem;border-top:1px solid var(--border-color)}.custom-amount label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.amount-input-wrapper{display:flex;align-items:center;background:var(--background);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.currency-prefix{padding:.75rem 1rem;background:var(--bg-secondary);color:var(--text-secondary);font-weight:500}.amount-input-wrapper input{flex:1;padding:.75rem 1rem;border:none;background:transparent;font-size:1rem;color:var(--text-primary)}.amount-input-wrapper input:focus{outline:none}.saved-methods{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.75rem}.method-option{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.method-option:hover{background:var(--card-bg-hover)}.method-option.selected{border-color:var(--primary-color);background:rgba(var(--primary-rgb),.05)}.method-option input[type=radio]{width:18px;height:18px;accent-color:var(--primary-color)}.method-info{display:flex;align-items:center;gap:.75rem;flex:1}.card-brand{font-weight:500;text-transform:capitalize}.card-last4{font-family:monospace;color:var(--text-secondary)}.default-tag{font-size:.75rem;background:var(--primary-color);color:#fff;padding:.125rem .5rem;border-radius:var(--radius-sm)}.method-option.new-card{border-style:dashed;border-color:var(--border-color)}.method-option.new-card.selected{border-color:var(--primary-color);border-style:solid}.payment-summary{background:var(--bg-secondary)}.summary-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.summary-row:last-child{border-bottom:none}.summary-row .amount{font-size:1.25rem;font-weight:600;color:var(--primary-color)}.btn-proceed{width:100%;padding:1rem;font-size:1.125rem}.checkout-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.btn-pay{width:100%;padding:.875rem}.payment-success{background:var(--card-bg);padding:3rem 2rem;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}.success-icon{color:#10b981;margin-bottom:1.5rem}.payment-success h2{margin-bottom:.5rem}.payment-success p{color:var(--text-secondary);margin-bottom:2rem}.success-actions{display:flex;flex-direction:column;gap:.75rem}@media(max-width:480px){.card-item{flex-direction:column;align-items:flex-start}.card-item .btn{width:100%}.success-actions{flex-direction:column}}.page-subtitle{color:var(--text-secondary);margin-top:.25rem}.header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.cash-payment-form-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.cash-payment-form-container h3{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary)}.cash-payment-form .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.cash-payment-form .form-group{display:flex;flex-direction:column;gap:.25rem}.cash-payment-form label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.cash-payment-form input,.cash-payment-form select,.cash-payment-form textarea{padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:.95rem;transition:border-color .2s}.cash-payment-form input:focus,.cash-payment-form select:focus,.cash-payment-form textarea:focus{outline:none;border-color:var(--primary-color)}.cash-payment-form textarea{resize:vertical;min-height:60px}.cash-payment-form .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.method-cell{display:flex;flex-direction:column;gap:.25rem}.method-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;width:fit-content}.method-cash{background:var(--success-light);color:var(--success-color)}.method-card{background:var(--info-light);color:var(--info-color)}.received-by-text{font-size:.75rem;color:var(--text-muted)}.payment-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color)}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.summary-icon svg{width:24px;height:24px}.summary-succeeded .summary-icon{background:var(--success-light);color:var(--success-color)}.summary-pending .summary-icon{background:var(--warning-light);color:var(--warning-color)}.summary-failed .summary-icon{background:var(--danger-light);color:var(--danger-color)}.summary-content{display:flex;flex-direction:column}.summary-label{font-size:.85rem;color:var(--text-secondary)}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.summary-amount{font-size:.85rem;color:var(--text-muted)}.filters-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1rem;margin-bottom:1.5rem}.filters-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:150px}.filter-group label{font-size:.85rem;color:var(--text-secondary)}.filter-group select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--input-bg);color:var(--text-primary);font-size:.9rem}.filter-results{margin-top:.75rem;font-size:.85rem;color:var(--text-muted)}.payments-table-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.payments-table{width:100%;border-collapse:collapse}.payments-table th,.payments-table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.payments-table th{background:var(--table-header-bg);font-weight:600;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.payments-table tbody tr:hover{background:var(--hover-bg)}.payments-table tbody tr:last-child td{border-bottom:none}.date-cell{white-space:nowrap;font-size:.9rem}.description-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.parent-cell{font-weight:500}.amount-cell{font-weight:600;font-family:var(--font-mono)}.actions-cell{white-space:nowrap}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:500}.status-succeeded{background:var(--success-light);color:var(--success-color)}.status-pending{background:var(--warning-light);color:var(--warning-color)}.status-failed{background:var(--danger-light);color:var(--danger-color)}.status-refunded{background:var(--info-light);color:var(--info-color)}.btn-icon{width:16px;height:16px;margin-right:.25rem}.btn-sm{padding:.375rem .75rem;font-size:.85rem}.loading-spinner-sm{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.payments-cards{display:none}.payment-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1rem;margin-bottom:1rem}.payment-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.payment-date{font-size:.85rem;color:var(--text-secondary)}.payment-card-body{margin-bottom:.75rem}.payment-description{color:var(--text-primary);margin-bottom:.25rem}.payment-amount{font-size:1.25rem;font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.payment-card-actions{padding-top:.75rem;border-top:1px solid var(--border-color)}.btn-full-width{width:100%}.empty-state{text-align:center;padding:3rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px}.empty-state-icon{width:64px;height:64px;margin:0 auto 1rem;color:var(--text-muted)}.empty-state-icon svg{width:100%;height:100%}.empty-state h3{margin:0 0 .5rem;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin:0}.unpaid-students-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem}.unpaid-students-section .section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.unpaid-students-section .section-header h2{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.section-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;background:var(--warning-light);color:var(--warning-color);border-radius:12px;font-size:.75rem;font-weight:600}.unpaid-students-list{display:flex;flex-direction:column;gap:.75rem}.unpaid-student-card{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;background:var(--background-secondary);border-radius:10px;border:1px solid var(--border-color)}.unpaid-student-info{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.unpaid-student-name{font-weight:600;color:var(--text-primary);font-size:.95rem}.unpaid-student-amount{font-weight:700;color:var(--danger-color);font-size:1rem;font-family:var(--font-mono)}.unpaid-student-details{text-align:right}.last-payment{font-size:.8rem;color:var(--text-secondary)}.last-payment.no-payment{color:var(--text-muted);font-style:italic}.unpaid-student-card .btn{flex-shrink:0}@media(max-width:768px){.payments-table-container{display:none}.payments-cards{display:block}.filters-row{flex-direction:column}.filter-group{width:100%}.payment-summary-grid{grid-template-columns:1fr}.header-row{flex-direction:column}.header-row .btn{width:100%}.cash-payment-form .form-row{grid-template-columns:1fr}.unpaid-student-card{flex-wrap:wrap;gap:.5rem}.unpaid-student-info{flex:1 1 100%;flex-direction:row;justify-content:space-between;align-items:center}.unpaid-student-details{flex:1 1 auto;text-align:left}.unpaid-student-card .btn{flex:1 1 100%;justify-content:center}}@media(max-width:480px){.summary-card{padding:1rem}.summary-value{font-size:1.25rem}}.page-subtitle{color:var(--text-secondary, #64748b);font-size:.95rem;margin-top:.25rem}.report-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--card-bg, #fff);border-radius:8px;border:1px solid var(--border-color, #e2e8f0)}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.75rem;font-weight:500;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.03em}.filter-group input,.filter-group select{padding:.5rem .75rem;border:1px solid var(--border-color, #e2e8f0);border-radius:6px;font-size:.9rem;background:var(--background, #f8fafc);color:var(--text-primary, #1e293b);min-width:150px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:var(--primary-color, #3b82f6)}.report-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:1rem;text-align:center}.summary-card.warning{border-color:var(--warning-color, #d97706);background:var(--warning-light, #fef3c7)}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1e293b);margin-bottom:.25rem}.summary-card.warning .summary-value{color:var(--warning-color, #d97706)}.summary-label{font-size:.75rem;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.05em}.children-overview{margin-bottom:1.5rem}.children-overview h3{font-size:1rem;margin-bottom:.75rem;color:var(--text-primary, #1e293b)}.children-cards{display:flex;flex-wrap:wrap;gap:.75rem}.child-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:6px;padding:.75rem 1rem;min-width:200px}.child-name{font-weight:600;color:var(--text-primary, #1e293b);margin-bottom:.25rem}.child-details{font-size:.8rem;color:var(--text-secondary, #64748b);display:flex;flex-direction:column;gap:.15rem}.report-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color, #e2e8f0);padding-bottom:.5rem}.report-tabs .tab{background:none;border:none;padding:.5rem 1rem;font-size:.9rem;color:var(--text-secondary, #64748b);cursor:pointer;border-radius:4px;transition:all .15s ease}.report-tabs .tab:hover{background:var(--background, #f8fafc)}.report-tabs .tab.active{background:var(--primary-color, #3b82f6);color:#fff}.report-section{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:1rem}.report-section h3{font-size:1rem;margin:0 0 1rem;color:var(--text-primary, #1e293b)}.empty-state{text-align:center;padding:2rem;color:var(--text-secondary, #64748b)}.attendance-list{display:flex;flex-direction:column;gap:.5rem}.attendance-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:6px;background:var(--background, #f8fafc)}.attendance-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.attendance-item.pickup .attendance-icon{background:var(--success-light, #dcfce7);color:var(--success-color, #16a34a)}.attendance-item.dropoff .attendance-icon{background:var(--info-light, #dbeafe);color:var(--info-color, #3b82f6)}.attendance-details{flex:1;min-width:0}.attendance-main{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.attendance-main .student-name{font-weight:600;color:var(--text-primary, #1e293b)}.attendance-main .event-type{font-size:.75rem;padding:.1rem .4rem;border-radius:3px}.event-type.pickup{background:var(--success-light, #dcfce7);color:var(--success-color, #16a34a)}.event-type.dropoff{background:var(--info-light, #dbeafe);color:var(--info-color, #3b82f6)}.attendance-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;color:var(--text-secondary, #64748b);margin-top:.25rem}.attendance-meta span:not(:last-child):after{content:"|";margin-left:.5rem;color:var(--border-color, #e2e8f0)}.invoice-list{display:flex;flex-direction:column;gap:.75rem}.invoice-item{padding:1rem;border-radius:6px;background:var(--background, #f8fafc);border:1px solid var(--border-color, #e2e8f0)}.invoice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.invoice-number{font-weight:600;color:var(--text-primary, #1e293b)}.invoice-status{font-size:.7rem;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase;font-weight:600}.invoice-period{font-size:.85rem;color:var(--text-secondary, #64748b);margin-bottom:.5rem}.invoice-amounts{display:flex;flex-direction:column;gap:.25rem}.amount-row{display:flex;justify-content:space-between;font-size:.9rem}.amount-label{color:var(--text-secondary, #64748b)}.amount-value{font-weight:500;color:var(--text-primary, #1e293b)}.amount-value.paid{color:var(--success-color, #16a34a)}.amount-value.due{color:var(--danger-color, #dc2626)}.invoice-due-date{margin-top:.5rem;font-size:.8rem;color:var(--warning-color, #d97706);font-weight:500}.payment-list{display:flex;flex-direction:column;gap:.5rem}.payment-item{padding:.75rem;border-radius:6px;background:var(--background, #f8fafc)}.payment-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.payment-amount{font-weight:600;font-size:1rem;color:var(--text-primary, #1e293b)}.payment-status{font-size:.7rem;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase;font-weight:600}.payment-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;color:var(--text-secondary, #64748b)}.payment-meta span:not(:last-child):after{content:"|";margin-left:.5rem;color:var(--border-color, #e2e8f0)}.status-paid{background:var(--success-light, #dcfce7);color:var(--success-color, #16a34a)}.status-pending{background:var(--warning-light, #fef3c7);color:var(--warning-color, #d97706)}.status-partial{background:var(--info-light, #dbeafe);color:var(--info-color, #3b82f6)}.status-void,.status-failed{background:var(--danger-light, #fee2e2);color:var(--danger-color, #dc2626)}@media(max-width:640px){.report-filters{flex-direction:column}.filter-group input,.filter-group select{min-width:100%}.report-summary{grid-template-columns:repeat(3,1fr)}.summary-card{padding:.75rem .5rem}.summary-value{font-size:1.25rem}.attendance-item{flex-direction:column}.attendance-icon{align-self:flex-start}}.drivers-list{display:flex;flex-direction:column;gap:1rem}.driver-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;overflow:hidden}.driver-header{display:flex;align-items:center;gap:1rem;padding:1rem;cursor:pointer;transition:background .15s ease}.driver-header:hover{background:var(--background, #f8fafc)}.driver-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary-color, #3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;flex-shrink:0}.driver-info{flex:1;min-width:0}.driver-info h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary, #1e293b)}.driver-email{margin:.25rem 0 0;font-size:.85rem;color:var(--text-secondary, #64748b)}.driver-phone{margin:.15rem 0 0;font-size:.8rem;color:var(--text-secondary, #64748b)}.driver-stats{display:flex;gap:1rem}.driver-stats .stat{font-size:.85rem;color:var(--text-secondary, #64748b)}.driver-stats .stat strong{color:var(--text-primary, #1e293b)}.driver-actions{display:flex;gap:.5rem}.btn-small{padding:.35rem .75rem;font-size:.8rem}.expand-icon{width:24px;height:24px;color:var(--text-secondary, #64748b);transition:transform .2s ease}.expand-icon.expanded{transform:rotate(180deg)}.expand-icon svg{width:100%;height:100%}.driver-details{padding:1rem;border-top:1px solid var(--border-color, #e2e8f0);background:var(--background, #f8fafc);display:grid;gap:1rem}.details-section h4{margin:0 0 .5rem;font-size:.85rem;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.03em}.details-section p{margin:.25rem 0;font-size:.9rem;color:var(--text-primary, #1e293b)}.assignment-tags{display:flex;flex-wrap:wrap;gap:.5rem}.assignment-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500}.assignment-tag.bus{background:var(--info-light, #dbeafe);color:var(--info-color, #3b82f6)}.assignment-tag.route{background:var(--success-light, #dcfce7);color:var(--success-color, #16a34a)}.assignment-tag .primary-badge{font-size:.7rem;padding:.1rem .3rem;background:#0000001a;border-radius:3px}.assignment-tag .remove-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;line-height:1;color:inherit;opacity:.6;padding:0;margin-left:.25rem}.assignment-tag .remove-btn:hover{opacity:1}.no-assignments{font-size:.85rem;color:var(--text-secondary, #64748b);font-style:italic}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--card-bg, #fff);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal.modal-small{max-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.modal-header h2{margin:0;font-size:1.25rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary, #64748b);padding:0;line-height:1}.modal-close:hover{color:var(--text-primary, #1e293b)}.modal form{padding:1.5rem}.modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal .form-group{margin-bottom:1rem}.modal .form-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem;color:var(--text-secondary, #64748b)}.modal .form-group input,.modal .form-group select{width:100%;padding:.6rem .75rem;border:1px solid var(--border-color, #e2e8f0);border-radius:6px;font-size:.95rem;background:var(--background, #f8fafc);color:var(--text-primary, #1e293b)}.modal .form-group input:focus,.modal .form-group select:focus{outline:none;border-color:var(--primary-color, #3b82f6)}.modal .form-group small{display:block;margin-top:.35rem;font-size:.8rem;color:var(--text-secondary, #64748b)}.checkbox-group label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto!important}.modal .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color, #e2e8f0)}.empty-state{text-align:center;padding:3rem;color:var(--text-secondary, #64748b);background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px}.loading-state{text-align:center;padding:3rem;color:var(--text-secondary, #64748b)}@media(max-width:768px){.driver-header{flex-wrap:wrap}.driver-stats{width:100%;order:3;margin-top:.5rem}.driver-actions{order:4;width:100%;margin-top:.5rem;justify-content:flex-start}.expand-icon{order:2;margin-left:auto}.modal .form-row{grid-template-columns:1fr}}:root{--primary-color: #2c3e50;--primary-dark: #1a252f;--primary-light: #34495e;--secondary-color: #3498db;--secondary-dark: #2980b9;--accent-color: #3498db;--success-color: #27ae60;--success-light: #d5f5e3;--warning-color: #f39c12;--warning-light: #fef9e7;--danger-color: #e74c3c;--danger-light: #fdedec;--info-color: #3498db;--info-light: #ebf5fb;--background: #f5f7fa;--background-secondary: #ecf0f1;--bg-secondary: #ecf0f1;--card-bg: #ffffff;--card-bg-hover: #f8f9fa;--text-primary: #2c3e50;--text-secondary: #7f8c8d;--text-muted: #95a5a6;--border-color: #dce1e4;--border-light: #ecf0f1;--shadow: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 16px rgba(52, 152, 219, .2);--shadow-card: 0 1px 3px rgba(0, 0, 0, .06), 0 2px 8px rgba(0, 0, 0, .04);--radius: 8px;--radius-md: 6px;--radius-sm: 4px;--radius-lg: 12px;--radius-full: 9999px;--gradient-primary: linear-gradient(135deg, #2c3e50 0%, #3498db 100%);--gradient-secondary: linear-gradient(135deg, #3498db 0%, #2980b9 100%);--gradient-success: linear-gradient(135deg, #27ae60 0%, #2ecc71 100%);--gradient-warning: linear-gradient(135deg, #f39c12 0%, #f1c40f 100%);--gradient-info: linear-gradient(135deg, #3498db 0%, #5dade2 100%);--gradient-subtle: linear-gradient(180deg, #ffffff 0%, #f5f7fa 100%);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--primary-color: #ecf0f1;--primary-dark: #bdc3c7;--primary-light: #ffffff;--secondary-color: #5dade2;--secondary-dark: #3498db;--accent-color: #5dade2;--success-color: #2ecc71;--success-light: rgba(39, 174, 96, .15);--warning-color: #f1c40f;--warning-light: rgba(243, 156, 18, .15);--danger-color: #e74c3c;--danger-light: rgba(231, 76, 60, .15);--info-color: #5dade2;--info-light: rgba(52, 152, 219, .15);--background: #1a252f;--background-secondary: #2c3e50;--bg-secondary: #2c3e50;--card-bg: #2c3e50;--card-bg-hover: #34495e;--text-primary: #ecf0f1;--text-secondary: #bdc3c7;--text-muted: #95a5a6;--border-color: #34495e;--border-light: #2c3e50;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 16px rgba(93, 173, 226, .3);--shadow-card: 0 1px 3px rgba(0, 0, 0, .2), 0 2px 8px rgba(0, 0, 0, .15);--gradient-primary: linear-gradient(135deg, #34495e 0%, #3498db 100%);--gradient-subtle: linear-gradient(180deg, #2c3e50 0%, #1a252f 100%)}body,.navbar,.card-bg,.form-container,.data-table,.stat-card,.modal-content{transition:background-color var(--transition-normal),color var(--transition-normal),border-color var(--transition-normal)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.6}.app-container{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.page-container,.dashboard,.add-child-container,.profile-container,.checkin-container{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h1{font-size:1.75rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}.filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filters select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius);font-size:.875rem}.navbar{background:var(--gradient-primary);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 4px 20px #3498db4d;position:relative;z-index:100}.navbar-brand a{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none;text-shadow:0 2px 4px rgba(0,0,0,.1)}.navbar-menu{display:flex;gap:.5rem;align-items:center}.nav-link{color:#ffffffe6;text-decoration:none;font-weight:500;transition:all var(--transition-fast);position:relative;padding:.5rem .75rem;border-radius:var(--radius-sm);display:flex;align-items:center;gap:.5rem;background:transparent;border:none;cursor:pointer;font-size:inherit;font-family:inherit}.nav-link svg{width:18px;height:18px;flex-shrink:0}.nav-link:hover{color:#fff;background:#ffffff26}.nav-link.active{color:#fff;background:#ffffff40;font-weight:600}.nav-link.nav-primary{font-weight:600}.nav-divider{width:1px;height:24px;background:#ffffff4d;margin:0 .5rem}.nav-link.secondary{opacity:.8;font-size:.9em}.nav-link.secondary:hover{opacity:1}.nav-link .badge{position:relative;top:auto;right:auto;background:var(--danger-color);color:#fff;font-size:.7rem;padding:2px 6px;border-radius:10px;margin-left:.25rem}.nav-submenu{position:relative}.nav-submenu .submenu-trigger{display:flex;align-items:center;gap:.5rem}.nav-submenu .dropdown-arrow{width:16px;height:16px;transition:transform .2s ease;margin-left:auto}.nav-submenu.open .dropdown-arrow{transform:rotate(180deg)}.nav-submenu .submenu-items{display:none;position:absolute;top:100%;left:0;min-width:160px;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.5rem 0;z-index:200;margin-top:.25rem}.nav-submenu.open .submenu-items{display:block}.nav-submenu .submenu-item{color:var(--text-color);padding:.6rem 1rem;border-radius:0;white-space:nowrap}.nav-submenu .submenu-item:hover{background:var(--bg-secondary);color:var(--primary-color)}.nav-submenu .submenu-item.active{background:#3498db1a;color:var(--primary-color);font-weight:600}.nav-submenu .submenu-item svg{width:16px;height:16px;color:var(--text-muted)}.nav-submenu .submenu-item.active svg,.nav-submenu .submenu-item:hover svg{color:var(--primary-color)}.nav-submenu.has-active .submenu-trigger{background:#ffffff26}.nav-with-dropdowns{display:flex;align-items:center;gap:1.5rem}.nav-dropdown{position:relative}.dropdown-trigger{display:flex;align-items:center;gap:.25rem;background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit;padding:.5rem .75rem;color:#ffffffe6;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.dropdown-trigger:hover{color:#fff;background:#ffffff26}.dropdown-arrow{width:18px;height:18px;transition:transform .2s ease;fill:currentColor}.nav-dropdown.open .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.75rem;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;min-width:180px;padding:.5rem;opacity:0;visibility:hidden;transform:translate(-50%) translateY(-10px);transition:all .2s ease;z-index:1000}.nav-dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--text-primary);text-decoration:none;border-radius:8px;transition:all .15s ease;font-weight:500}.dropdown-item:hover{background:var(--bg-secondary);color:var(--primary-color)}.dropdown-item svg{width:20px;height:20px;opacity:.7}.dropdown-item:hover svg{opacity:1}.navbar-user{display:flex;align-items:center;gap:1rem}.user-name{color:#ffffffe6;font-weight:500}.navbar-user .role-badge,.mobile-user-section .role-badge{margin-bottom:0;font-size:.625rem;padding:.25rem .625rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.mobile-user-section .user-info{display:flex;align-items:center;gap:.75rem}.footer{background:var(--background-secondary);border-top:1px solid var(--border-color);padding:1.5rem 2rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.hamburger-btn{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:transparent;border:none;cursor:pointer;padding:.5rem;z-index:1001}.hamburger-line{display:block;width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-menu-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999}.mobile-user-section{display:none}.desktop-only{display:flex}@media(max-width:1024px){.checkin-container,.tracking-container{grid-template-columns:1fr}.recent-boardings{order:-1}}@media(max-width:768px){.hamburger-btn{display:flex}.mobile-menu-overlay{display:block}.navbar{flex-wrap:nowrap;gap:0;position:relative}.navbar-menu{position:fixed;top:0;right:-280px;width:280px;height:100vh;background:var(--card-bg);flex-direction:column;padding:5rem 1.5rem 2rem;gap:0;z-index:1000;box-shadow:var(--shadow-lg);transition:right .3s ease;overflow-y:auto}.navbar-menu.mobile-open{right:0}.navbar-menu .nav-link{display:flex;padding:1rem 0;border-bottom:1px solid var(--border-color);font-size:1rem;color:var(--text-color)}.navbar-menu .nav-link:hover{color:var(--primary-color);background:transparent}.navbar-menu .nav-link.active{color:var(--primary-color);background:#3498db14;border-radius:var(--radius-sm);padding:1rem .75rem;margin:0 -.75rem}.navbar-menu .nav-link svg{color:var(--text-muted)}.navbar-menu .nav-link.active svg,.navbar-menu .nav-link:hover svg{color:var(--primary-color)}.nav-submenu{width:100%}.nav-submenu .submenu-trigger{width:100%;justify-content:flex-start;padding:1rem 0;border-bottom:1px solid var(--border-color);color:var(--text-color)}.nav-submenu .submenu-trigger:hover{color:var(--primary-color);background:transparent}.nav-submenu .dropdown-arrow{margin-left:auto}.nav-submenu .submenu-items{position:static;box-shadow:none;margin:0;padding:0;background:var(--bg-secondary);border-radius:0;max-height:0;overflow:hidden;transition:max-height .3s ease}.nav-submenu.open .submenu-items{display:block;max-height:200px}.nav-submenu .submenu-item{padding:.875rem 1rem .875rem 2.5rem;border-radius:0;border-bottom:1px solid var(--border-color)}.nav-submenu .submenu-item:last-child{border-bottom:none}.nav-divider{width:100%;height:1px;margin:.75rem 0;background:var(--border-color)}.navbar-menu .nav-link.nav-primary{font-weight:600}.mobile-user-section{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.mobile-user-section .user-name{font-weight:500;color:var(--text-primary)}.desktop-only{display:none}.main-content{padding:1rem}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;gap:1rem;align-items:flex-start}.stats-grid{grid-template-columns:1fr}.data-table th,.data-table td{padding:.75rem;font-size:.875rem}.checkin-search .form-group{flex-direction:column}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transform:scale(0);transition:opacity .3s,transform .3s}.btn:active:after{opacity:1;transform:scale(2);transition:opacity 0s,transform 0s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px #3498db59}.btn-primary:hover{box-shadow:0 6px 25px #3498db80;transform:translateY(-2px)}.btn-secondary{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--background-secondary);border-color:var(--primary-color);color:var(--primary-color)}.btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 4px 15px #10b98159}.btn-success:hover{box-shadow:0 6px 25px #10b98180;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff;box-shadow:0 4px 15px #ef444459}.btn-danger:hover{box-shadow:0 6px 25px #ef444480;transform:translateY(-2px)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff;box-shadow:0 4px 15px #f59e0b59}.btn-warning:hover{box-shadow:0 6px 25px #f59e0b80;transform:translateY(-2px)}.btn-small{padding:.5rem 1rem;font-size:.8rem}.btn-qr{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 15px #6366f159}.btn-qr:hover{box-shadow:0 6px 25px #6366f180;transform:translateY(-2px)}.btn-large{padding:1rem 2rem;font-size:1rem}.btn-logout{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-logout:hover{background:#ffffff40;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.btn{padding:.875rem 1.5rem;min-height:44px}.btn-small{padding:.625rem 1rem;min-height:44px}.btn-large{padding:1rem 2rem;min-height:48px}}.form-container{background:var(--card-bg);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow-card);max-width:600px;border:1px solid var(--border-light)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.875rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-fast);background:var(--card-bg);color:var(--text-primary)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--primary-light)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #3498db26}.form-group input::placeholder{color:var(--text-muted)}.form-group input.input-uppercase{text-transform:uppercase;letter-spacing:2px;font-family:monospace}select,.form-group select,select.form-control{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-color)}select option,.form-group select option,select.form-control option{background:var(--card-bg);color:var(--text-primary);padding:.5rem}[data-theme=dark] select,[data-theme=dark] .form-group select,[data-theme=dark] select.form-control{background:var(--card-bg);background-color:#1e293b;color:var(--text-primary);color:#f1f5f9;border-color:var(--border-color)}[data-theme=dark] select option,[data-theme=dark] .form-group select option,[data-theme=dark] select.form-control option{background:#1e293b;background-color:#1e293b;color:#f1f5f9}[data-theme=dark] select option:disabled{color:#64748b}.form-group small{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:.8rem}.field-wrapper{position:relative;display:flex;align-items:center}.field-wrapper input,.field-wrapper select,.field-wrapper textarea{flex:1;padding-right:2.5rem}.field-valid-icon{position:absolute;right:12px;color:var(--success-color);font-size:1rem;pointer-events:none}.field-valid-icon:after{content:"✓"}.field-error{display:block;margin-top:.35rem;color:var(--danger-color);font-size:.8rem;font-weight:500}.field-hint{display:block;margin-top:.35rem;color:var(--text-secondary);font-size:.8rem}.field-hint .hint-link{color:var(--primary-color);text-decoration:none}.field-hint .hint-link:hover{text-decoration:underline}.label-badge{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;background:var(--primary-color);color:#fff;font-size:.65rem;font-weight:600;border-radius:1rem;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.field-invalid{border-color:var(--danger-color)!important}.field-invalid:focus{box-shadow:0 0 0 4px #ef444426!important}.field-valid{border-color:var(--success-color)!important}.field-valid:focus{box-shadow:0 0 0 4px #10b98126!important}.required-marker{color:var(--danger-color)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:.75rem}.checkbox-label,.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.radio-group{display:flex;gap:1.5rem}.form-card{background:var(--card-bg);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow-card);border:1px solid var(--border-light);max-width:700px}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-light)}.form-section:last-of-type{border-bottom:none;margin-bottom:1rem}.form-section h2{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.form-section-description{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem}.input-with-prefix{display:flex;align-items:center}.input-prefix{background:var(--bg-tertiary);padding:.875rem 1rem;border:2px solid var(--border-color);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);color:var(--text-secondary);font-weight:600}.input-with-prefix input{border-radius:0 var(--radius-md) var(--radius-md) 0!important;flex:1}.info-list{list-style:none;padding:0;margin:0}.info-list li{padding:.75rem 0;border-bottom:1px solid var(--border-light);color:var(--text-secondary);font-size:.9rem}.info-list li:last-child{border-bottom:none}.info-list li strong{color:var(--text-primary)}.waypoint-controls{display:flex;gap:.75rem;margin-bottom:.75rem}.waypoint-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.waypoint-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-primary);color:#fff;border-radius:50%;font-size:.75rem;font-weight:600;flex-shrink:0}.waypoint-name{flex:2;min-width:100px}.waypoint-coord{flex:1;min-width:80px;font-family:monospace;font-size:.85rem}.waypoint-row .btn-danger{padding:.4rem .6rem;font-size:1rem;line-height:1}@media(max-width:768px){.form-group input,.form-group select,.form-group textarea{padding:1rem;min-height:48px;font-size:16px}.form-row{grid-template-columns:1fr;gap:1rem}.form-container,.form-card{padding:1.5rem}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.waypoint-row{flex-wrap:wrap}.waypoint-controls{flex-direction:column}.waypoint-controls .btn{width:100%}.waypoint-name{flex:1 1 100%;order:1}.waypoint-number{order:0}.waypoint-coord{flex:1 1 40%;order:2}.waypoint-row .btn-danger{order:0;margin-left:auto}}@media(max-width:480px){.form-container,.form-card{padding:1rem}}.empty-state{text-align:center;padding:3rem;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow)}.empty-state h3{margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.student-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.student-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.student-header{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.student-header-info{flex:1}.student-header h3{font-size:1.125rem}.school-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem}.school-card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border-color);overflow:hidden;transition:all .2s ease}.school-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.school-card-header{padding:1.25rem;background:linear-gradient(135deg,#14b8a61a,#06b6d40d);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.school-card-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.school-card-header .student-count{font-size:.75rem;font-weight:600;padding:.375rem .75rem;background:#14b8a626;color:var(--primary-color);border-radius:50px;border:1px solid rgba(20,184,166,.3)}.school-card-body{padding:1.25rem}.school-card-body p{margin:.5rem 0;color:var(--text-secondary);font-size:.875rem}.school-address{font-weight:500;color:var(--text-primary)!important}.school-location{color:var(--text-muted)!important;font-size:.8125rem!important}.school-contact{display:flex;gap:.5rem;align-items:center}.school-contact .contact-icon{font-weight:600;color:var(--text-muted);min-width:40px}.school-card-actions{padding:1rem 1.25rem;border-top:1px solid var(--border-color);display:flex;gap:.75rem;justify-content:flex-end}.role-cards.selectable .role-card{cursor:pointer;position:relative}.role-cards.selectable .role-card.selected{border-color:var(--primary-color);background:#14b8a61a;box-shadow:var(--shadow-glow)}.role-card .role-check{position:absolute;top:1rem;right:1rem;width:28px;height:28px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem}.btn-large{padding:1rem 2rem;font-size:1.1rem;width:100%;max-width:300px;margin:1rem auto;display:block}.register-choice .auth-footer{color:var(--text-secondary)}.register-choice .auth-footer a{color:var(--primary-color);font-weight:600}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--card-bg);border-radius:var(--radius);padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal h2{margin-bottom:1.5rem}.modal-content{background:var(--card-bg);border-radius:var(--radius);padding:1.5rem;max-width:90%;max-height:90vh;overflow-y:auto}.modal-content.print-modal{background:#fff;padding:2rem;max-width:450px}.confirm-modal-overlay{animation:fadeIn .2s ease-out}.confirm-modal{background:var(--card-bg);border-radius:var(--radius);padding:2rem;width:100%;max-width:400px;text-align:center;animation:scaleIn .2s ease-out}.confirm-modal-icon{font-size:3rem;margin-bottom:1rem}.confirm-modal-title{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-primary)}.confirm-modal-message{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.confirm-modal-actions{display:flex;gap:1rem;justify-content:center}.confirm-modal-actions .btn{min-width:100px}@media(max-width:768px){.modal,.confirm-modal{max-width:calc(100% - 2rem);margin:1rem;padding:1.5rem}.confirm-modal-actions{flex-direction:column}.confirm-modal-actions .btn{width:100%;min-width:auto}}@media(max-width:480px){.modal{padding:1rem;max-height:85vh}.confirm-modal{padding:1rem}.confirm-modal-icon{font-size:2.5rem}.confirm-modal-title{font-size:1.1rem}}.table-container{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--card-bg);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);border:1px solid var(--border-light)}.data-table th,.data-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--border-light)}.data-table th{background:var(--background-secondary);font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--background-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.data-table td small{display:block;color:var(--text-secondary);font-size:.8rem;margin-top:.25rem}.data-table .actions{display:flex;gap:.5rem}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge-sm{padding:.25rem .625rem;font-size:.6875rem}.status-active,.status-completed,.status-on-route{background:var(--success-light);color:#059669}.status-inactive,.status-default{background:#f1f5f9;color:#64748b}.status-pending,.status-in-progress{background:#3b82f626;color:#2563eb}.status-maintenance,.status-delayed{background:#f59e0b26;color:#d97706}.status-cancelled{background:#ef444426;color:#dc2626}.status-pickup{background:#22c55e26;color:#16a34a}.status-dropoff{background:#8b5cf626;color:#7c3aed}.status-archived{background:#6b728026;color:#6b7280;text-decoration:line-through}.status-scheduled{background:#3b82f626;color:#2563eb}.status-not-running{background:#9ca3af1a;color:#9ca3af}.route-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.route-badge.pending{background:#f59e0b33;color:var(--warning-color)}.route-badge.active{background:#22c55e33;color:var(--success-color)}.student-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.25rem}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color);font-size:.875rem}.info-row:last-child{border-bottom:none}.info-row .label{color:var(--text-secondary)}.student-selector{background:var(--card-bg);padding:1rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}.student-selector select{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:var(--radius)}.role-badge{display:inline-block;padding:.375rem .875rem;border-radius:50px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.role-badge.parent{background:#06b6d426;color:var(--accent-color);border:1px solid rgba(6,182,212,.3)}.role-badge.operator{background:#8b5cf626;color:var(--secondary-color);border:1px solid rgba(139,92,246,.3)}.back-link{display:inline-block;color:var(--text-secondary);text-decoration:none;font-size:.875rem;margin-bottom:1rem;transition:color .2s ease}.back-link:hover{color:var(--primary-color)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.375rem}.status-dot-success{background-color:var(--success-color);box-shadow:0 0 4px var(--success-color)}.status-dot-gray{background-color:#9ca3af}.status-dot-warning{background-color:var(--warning-color)}.text-success{color:var(--success-color)}.text-warning{color:var(--warning-color)}.text-muted{color:var(--text-secondary)}.text-danger{color:var(--error-color)}.checkin-status{display:flex;align-items:center}.alert{padding:1rem 1.25rem;border-radius:var(--radius-md);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;font-weight:500}.alert-error{background:var(--danger-light);color:#dc2626;border:1px solid #fecaca}.alert-success{background:var(--success-light);color:#059669;border:1px solid #a7f3d0}.alert-warning{background:var(--warning-light);color:#d97706;border:1px solid #fde68a}.alert-info{background:var(--info-light);color:#2563eb;border:1px solid #bfdbfe}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.75rem;z-index:9999;max-width:400px}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);border-left:4px solid var(--text-secondary);animation:slideInRight .3s ease-out}.toast-exit{animation:slideOutRight .3s ease-out forwards}@keyframes slideOutRight{to{opacity:0;transform:translate(100%)}}.toast-success{border-left-color:var(--success-color)}.toast-success .toast-icon{color:var(--success-color)}.toast-error{border-left-color:var(--danger-color)}.toast-error .toast-icon{color:var(--danger-color)}.toast-warning{border-left-color:var(--warning-color)}.toast-warning .toast-icon{color:var(--warning-color)}.toast-info{border-left-color:var(--accent-color)}.toast-info .toast-icon{color:var(--accent-color)}.toast-icon{font-size:1.25rem;font-weight:700;flex-shrink:0}.toast-message{flex:1;font-size:.9375rem;color:var(--text-primary)}.toast-close{background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.toast-close:hover{color:var(--text-primary)}@media(max-width:768px){.toast-container{left:1rem;right:1rem;bottom:1rem;max-width:none}}.skeleton{background:linear-gradient(90deg,var(--background) 25%,var(--card-bg-hover) 50%,var(--background) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:1rem;margin-bottom:.5rem;width:100%}.skeleton-title{height:1.5rem;margin-bottom:.75rem;width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0}.skeleton-card{height:150px;width:100%}.skeleton-button{height:32px;width:80px;border-radius:var(--radius)}.skeleton-stat{height:2.5rem;width:50px;margin:0 auto .5rem}.skeleton-table-row td{padding:1rem}.skeleton-container{pointer-events:none}.student-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.student-avatar img{width:100%;height:100%;object-fit:cover}.student-avatar.avatar-initials{display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;font-weight:600;font-size:1rem}.student-avatar.avatar-sm{width:32px;height:32px;font-size:.75rem}.student-avatar.avatar-lg{width:80px;height:80px;font-size:1.5rem}.card-id{font-size:.75rem;color:var(--text-secondary);background:var(--background);padding:.25rem .5rem;border-radius:4px}.student-details p{font-size:.875rem;margin-bottom:.5rem;color:var(--text-secondary)}.student-details strong{color:var(--text-primary)}.card-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.search-bar-container{margin-bottom:1.5rem}.search-bar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.search-input-wrapper{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:1rem;opacity:.6}.search-input{width:100%;padding:.625rem 2.5rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary);font-size:.875rem;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #14b8a61a}.search-input::placeholder{color:var(--text-muted)}.search-clear-input{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;opacity:.7;transition:opacity .2s}.search-clear-input:hover{opacity:1;color:var(--text-primary)}.search-filters{display:flex;flex-wrap:wrap;gap:.5rem}.search-filter-select{padding:.625rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-bg);color:var(--text-primary);font-size:.875rem;min-width:140px;cursor:pointer}.search-filter-select:focus{outline:none;border-color:var(--primary-color)}.search-filter-searchable{min-width:180px}.search-clear-btn{white-space:nowrap}.search-results-count{margin-top:.75rem;font-size:.875rem;color:var(--text-secondary)}@media(max-width:768px){.search-bar{flex-direction:column;align-items:stretch}.search-input-wrapper,.search-filters{width:100%}.search-filter-select,.search-filter-searchable{flex:1;min-width:0;width:100%}.search-clear-btn{width:100%}}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading{text-align:center;padding:3rem;color:var(--text-secondary)}.no-data{color:var(--text-secondary);font-style:italic}.demo-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.demo-modal{background:var(--card-bg, #ffffff);border-radius:12px;width:100%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.demo-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.demo-header h3{margin:0;font-size:1.1rem}.demo-body{padding:1.25rem;overflow-y:auto;flex:1}.demo-description{color:var(--text-secondary, #64748b);font-size:.9rem;margin:0 0 1.25rem;line-height:1.5}.demo-select .form-group{margin-bottom:1.25rem}.demo-select .btn{width:100%}.demo-plan-summary{background:var(--background, #f8fafc);border-radius:8px;padding:1rem;margin-bottom:1rem}.plan-row{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.9rem}.plan-row+.plan-row{border-top:1px solid var(--border-color, #e2e8f0)}.plan-label{color:var(--text-secondary, #64748b)}.plan-value{font-weight:600}.demo-steps-preview{margin-bottom:1.25rem}.demo-steps-preview h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #64748b);margin:0 0 .75rem}.steps-list{list-style:none;padding:0;margin:0;max-height:200px;overflow-y:auto}.step-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;color:var(--text-primary, #1e293b)}.step-item+.step-item{border-top:1px solid var(--border-light, rgba(0,0,0,.05))}.step-icon{flex-shrink:0;width:1.25rem;text-align:center}.demo-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color, #e2e8f0)}.demo-progress{margin-bottom:1rem}.demo-progress-header{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.5rem}.demo-progress-percent{font-weight:700;color:var(--primary-color, #334155)}.demo-progress-bar{height:10px;background:var(--border-color, #e2e8f0);border-radius:5px;overflow:hidden}.demo-progress-fill{height:100%;background:var(--success-color, #10b981);border-radius:5px;transition:width .4s ease}.demo-action-feed{max-height:300px;overflow-y:auto;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:.5rem;background:var(--background, #f8fafc)}.action-entry{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem .5rem;font-size:.85rem;border-radius:4px}.action-entry+.action-entry{border-top:1px solid var(--border-light, rgba(0,0,0,.05))}.action-entry.action-running{color:var(--warning-color, #f59e0b);font-weight:500}.action-entry.action-success{color:var(--success-color, #10b981)}.action-entry.action-skipped{color:var(--text-secondary, #64748b);font-style:italic}.action-entry.action-error{color:var(--danger-color, #ef4444)}.action-entry.action-warning{color:var(--warning-color, #f59e0b)}.action-entry.action-complete{color:var(--success-color, #10b981);font-weight:600}.action-icon{flex-shrink:0;width:1.25rem;text-align:center}.action-message{flex:1}.action-time{flex-shrink:0;font-size:.75rem;color:var(--text-secondary, #64748b)}@media(max-width:600px){.demo-modal{max-width:100%;max-height:90vh;border-radius:8px}.demo-actions{flex-direction:column}.demo-actions .btn{width:100%}}.theme-toggle{position:relative}.theme-toggle-btn{width:36px;height:36px;border-radius:50%;background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.theme-toggle-btn:hover{background:#ffffff40;transform:scale(1.05)}.theme-icon{font-size:1.1rem}.theme-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:150px;z-index:1000;overflow:hidden;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.theme-dropdown-header{padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.theme-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--text-primary);transition:background var(--transition-fast);text-align:left}.theme-option:hover{background:var(--background-secondary)}.theme-option.active{background:#3498db1a;color:var(--primary-color)}.theme-option-icon{font-size:1rem}.theme-option-label{flex:1}.theme-option-check{color:var(--primary-color);font-weight:600}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);padding:.5rem 1rem;cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-fast);font-size:.9rem}.user-menu-trigger:hover{background:#ffffff40}.user-menu-gear{width:18px;height:18px}.user-menu-name{font-weight:500}.user-menu-arrow{width:16px;height:16px;transition:transform var(--transition-fast)}.user-menu-arrow.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;z-index:1000;overflow:hidden;animation:dropdownFadeIn .15s ease-out}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--text-primary);text-decoration:none;transition:background var(--transition-fast)}.user-menu-item:hover{background:var(--background-secondary)}.user-menu-item svg{width:18px;height:18px;color:var(--text-secondary)}.user-menu-logout{color:var(--danger-color)}.user-menu-logout svg{color:var(--danger-color)}.user-menu-divider{height:1px;background:var(--border-color);margin:.25rem 0}.user-menu-section-label{padding:.5rem 1rem .25rem;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.user-menu-theme-options{display:flex;gap:.25rem;padding:.25rem .75rem .5rem}.user-menu-theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:none;cursor:pointer;transition:all var(--transition-fast)}.user-menu-theme-btn:hover{background:var(--background-secondary);border-color:var(--primary-color)}.user-menu-theme-btn.active{background:#3498db1a;border-color:var(--primary-color)}.theme-btn-icon{font-size:1rem}.theme-btn-label{font-size:.65rem;color:var(--text-secondary);font-weight:500}.user-menu-theme-btn.active .theme-btn-label{color:var(--primary-color)}.role-switcher{position:relative}.role-switcher-trigger{display:flex;align-items:center;gap:.5rem;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);padding:.5rem .875rem;cursor:pointer;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s;color:var(--text-primary);font-size:.875rem}.role-switcher-trigger:hover{border-color:var(--primary-color);background:var(--card-bg-hover)}.role-switcher-icon{font-size:1.1rem}.role-switcher-label{font-weight:500}.role-switcher-arrow{font-size:.625rem;color:var(--text-secondary);margin-left:.25rem}.role-switcher-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;z-index:1000;overflow:hidden}.role-switcher-header{padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.role-switcher-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;cursor:pointer;transition:all .2s;color:var(--text-primary);text-align:left;font-size:.875rem}.role-switcher-option:hover:not(.active):not(:disabled){background:var(--card-bg-hover)}.role-switcher-option.active{background:#14b8a61a;color:var(--primary-color)}.role-switcher-option:disabled{cursor:default}.role-option-icon{font-size:1.1rem}.role-option-label{flex:1}.role-option-check{color:var(--primary-color);font-weight:700}.onboarding-checklist{background:var(--card-bg);border-radius:var(--radius);padding:1.5rem;margin-bottom:2rem;border:1px solid var(--primary-color);box-shadow:var(--shadow-glow)}.onboarding-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.onboarding-title h2{font-size:1.25rem;margin-bottom:.25rem;color:var(--text-primary)}.onboarding-subtitle{color:var(--text-secondary);font-size:.875rem}.onboarding-progress{text-align:right;min-width:150px}.progress-text{font-size:.75rem;color:var(--text-secondary);display:block;margin-bottom:.5rem}.progress-bar{height:6px;background:var(--background);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:3px;transition:width .3s ease}.checklist-items{display:flex;flex-direction:column;gap:.75rem}.checklist-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background);border-radius:var(--radius-sm);transition:all .2s ease}.checklist-item:hover{background:var(--card-bg-hover)}.checklist-item.completed{opacity:.7}.checklist-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:var(--card-bg);font-size:1.5rem;flex-shrink:0}.checklist-item.completed .checklist-icon{background:var(--success-color)}.check-mark{color:#fff;font-weight:700}.checklist-content{flex:1}.checklist-content h3{font-size:.9375rem;font-weight:600;margin-bottom:.25rem;color:var(--text-primary)}.checklist-item.completed .checklist-content h3{text-decoration:line-through;color:var(--text-secondary)}.checklist-content p{font-size:.8125rem;color:var(--text-secondary)}.checklist-action{flex-shrink:0}.completed-badge{color:var(--success-color);font-size:.75rem;font-weight:600}@media(max-width:768px){.onboarding-header{flex-direction:column}.onboarding-progress{text-align:left;width:100%}.checklist-item{flex-wrap:wrap}.checklist-action{width:100%;margin-top:.5rem}.checklist-action .btn{width:100%}}.celebration-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:celebration-fade-in .3s ease-out;cursor:pointer}.celebration-overlay.exiting{animation:celebration-fade-out .3s ease-out forwards}.celebration-overlay.celebration-checkin{background:#10b98126}.celebration-overlay.celebration-route{background:#3498db33}.celebration-overlay.celebration-welcome{background:#f093fb26}.celebration-overlay.celebration-badge{background:#f59e0b26}@keyframes celebration-fade-in{0%{opacity:0}to{opacity:1}}@keyframes celebration-fade-out{0%{opacity:1}to{opacity:0}}.celebration-toast{background:var(--card-bg);border-radius:var(--radius-lg);padding:2rem 3rem;text-align:center;box-shadow:var(--shadow-lg),0 0 40px #3498db4d;z-index:10001;animation:celebration-pop .4s cubic-bezier(.34,1.56,.64,1);max-width:90vw}.celebration-checkin .celebration-toast{border:3px solid var(--success-color)}.celebration-route .celebration-toast{border:3px solid var(--primary-color)}.celebration-welcome .celebration-toast{border:3px solid #f093fb}.celebration-badge .celebration-toast{border:3px solid var(--warning-color)}@keyframes celebration-pop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.celebration-icon-wrapper{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;animation:icon-bounce .6s ease-out}.celebration-checkin .celebration-icon-wrapper{background:var(--success-light)}.celebration-route .celebration-icon-wrapper{background:var(--info-light)}.celebration-welcome .celebration-icon-wrapper{background:#f093fb33}.celebration-badge .celebration-icon-wrapper{background:var(--warning-light)}.celebration-icon{font-size:2.5rem}.celebration-checkin .celebration-icon{color:var(--success-color);font-weight:700}.celebration-route .celebration-icon{font-size:2rem}.celebration-badge .celebration-icon-wrapper{animation:badge-glow .8s ease-out}@keyframes icon-bounce{0%{transform:scale(0) rotate(-20deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}@keyframes badge-glow{0%{transform:scale(0);box-shadow:0 0 #f59e0bb3}50%{transform:scale(1.1);box-shadow:0 0 30px #f59e0b80}to{transform:scale(1);box-shadow:0 0 15px #f59e0b4d}}.celebration-text{margin-bottom:.5rem}.celebration-message{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.celebration-submessage{font-size:1rem;color:var(--text-secondary);margin:0}.celebration-dismiss-hint{display:block;margin-top:1rem;font-size:.75rem;color:var(--text-muted)}.celebration-content{text-align:center;color:#fff;z-index:10001;animation:celebration-pop .4s cubic-bezier(.34,1.56,.64,1)}.celebration-dismiss{display:block;margin-top:1.5rem;font-size:.8rem;opacity:.6}.confetti-container{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:9999}.confetti-piece.confetti-burst{position:absolute;left:var(--start-x, 50%);top:var(--start-y, 30%);width:var(--size);height:var(--size);background:var(--color);border-radius:2px;animation:confetti-burst 1.2s cubic-bezier(.25,.46,.45,.94) var(--delay) forwards;box-shadow:0 2px 4px #0000001a}@keyframes confetti-burst{0%{transform:translate(0) rotate(0) scale(1);opacity:1}50%{transform:translate(var(--vx),var(--vy)) rotate(calc(var(--rotation) * .5)) scale(1);opacity:1}to{transform:translate(var(--vx),calc(var(--vy) + var(--gravity))) rotate(var(--rotation)) scale(.5);opacity:0}}.confetti-piece.confetti-confetti{position:absolute;left:var(--x);top:var(--y);width:var(--size);height:var(--size);background:var(--color);border-radius:2px;animation:confetti-fall var(--fall-duration) ease-out var(--delay) forwards}@keyframes confetti-fall{0%{transform:translateY(0) translate(0) rotate(0);opacity:1}to{transform:translateY(100vh) translate(var(--drift)) rotate(var(--rotation));opacity:0}}.confetti-piece.confetti-fireworks{position:absolute;left:var(--start-x, 50%);top:var(--start-y, 40%);width:var(--size);height:var(--size);background:var(--color);border-radius:50%;animation:firework-burst 1s ease-out var(--delay) forwards;box-shadow:0 0 8px var(--color),0 0 16px var(--color)}@keyframes firework-burst{0%{transform:translate(0) scale(1);opacity:1}70%{transform:translate(var(--x),var(--y)) scale(1);opacity:.8}to{transform:translate(calc(var(--x) * 1.2),calc(var(--y) * 1.2)) scale(0);opacity:0}}.confetti-piece.confetti-badge{position:absolute;left:50%;top:45%;width:var(--size);height:var(--size);background:var(--color);border-radius:50%;animation:sparkle 1s ease-out var(--delay) forwards;box-shadow:0 0 6px var(--color)}@keyframes sparkle{0%{transform:translate(0) scale(0);opacity:1}30%{transform:translate(calc(var(--x) * .3),calc(var(--y) * .3)) scale(var(--scale, 1));opacity:1}70%{transform:translate(calc(var(--x) * .8),calc(var(--y) * .8)) scale(var(--scale, 1));opacity:.7}to{transform:translate(var(--x),var(--y)) scale(0);opacity:0}}.toast.toast-celebration{background:var(--gradient-primary);color:#fff;border:none;box-shadow:0 8px 32px #3498db66}.toast.toast-celebration .toast-icon{font-size:1.5rem;animation:toast-icon-bounce .5s ease-out}@keyframes toast-icon-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.btn{transition:all .25s cubic-bezier(.4,0,.2,1)}.btn:hover:not(:disabled){transform:translateY(-2px) scale(1.02)}.btn:active:not(:disabled){transform:translateY(0) scale(.98);transition-duration:.1s}.btn-primary:hover:not(:disabled){box-shadow:0 8px 25px #3498db73,0 0 20px #3498db33}.btn-secondary:hover:not(:disabled){box-shadow:0 4px 15px #0000001a}.btn-success:hover:not(:disabled){box-shadow:0 8px 25px #10b98173,0 0 20px #10b98133}.btn-danger:hover:not(:disabled){box-shadow:0 8px 25px #ef444473,0 0 20px #ef444433}.btn-warning:hover:not(:disabled){box-shadow:0 8px 25px #f59e0b73,0 0 20px #f59e0b33}.btn{position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.btn:active:before{width:200%;height:200%}.btn svg,.btn-icon svg{transition:transform .2s ease}.btn:hover svg,.btn-icon:hover svg{transform:scale(1.1)}.page-container,.dashboard,.add-child-container,.profile-container,.checkin-container,.routes-page,.students-page,.messages-page,.tracking-container{animation:pageSlideIn .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{animation:fadeSlideIn .35s cubic-bezier(.4,0,.2,1) .05s both}.stats-grid{animation:fadeSlideIn .35s cubic-bezier(.4,0,.2,1) .1s both}.quick-actions{animation:fadeSlideIn .35s cubic-bezier(.4,0,.2,1) .15s both}.recent-notifications{animation:fadeSlideIn .35s cubic-bezier(.4,0,.2,1) .2s both}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stat-card,.card-grid>div,.auth-card,.form-container,.table-container,.notification-item,.student-card,.route-card,.bus-card,.school-card{transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1)}.stat-card:hover,.card-grid>div:hover,.student-card:hover,.route-card:hover,.bus-card:hover,.school-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px #0000001f,0 4px 12px #00000014}.stat-card a,.card-grid>div a{transition:color .2s ease,transform .2s ease}.stat-card:hover a,.card-grid>div:hover a{color:var(--primary-color);transform:translate(4px)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--background);background-image:radial-gradient(ellipse at 20% 20%,rgba(20,184,166,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(139,92,246,.1) 0%,transparent 50%)}.auth-card{background:var(--card-bg);padding:2.5rem;border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border-color);width:100%;max-width:420px}.auth-card h1{text-align:center;margin-bottom:.5rem}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem}.auth-form{margin-top:1.5rem}.auth-form .btn{width:100%;margin-top:.5rem}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--text-secondary)}.auth-footer a{color:var(--primary-color);text-decoration:none}.auth-divider{display:flex;align-items:center;margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.auth-divider span{padding:0 1rem;color:var(--text-secondary);font-size:.875rem}.google-signin-wrapper{margin-bottom:1rem}.google-signin-button{display:flex;justify-content:center}.register-choice{text-align:center;max-width:900px;padding:2rem}.register-choice h1{color:var(--text-primary);font-size:2.5rem;margin-bottom:.5rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.register-choice .auth-subtitle{color:var(--text-secondary);font-size:1.125rem;margin-bottom:2.5rem}.role-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem}.role-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:2rem;text-decoration:none;color:var(--text-primary);box-shadow:var(--shadow-lg);transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.role-card:hover{transform:translateY(-4px);border-color:var(--primary-color);box-shadow:var(--shadow-glow)}.role-icon{font-size:3.5rem;margin-bottom:1rem;transition:transform .3s ease}.role-card:hover .role-icon{transform:scale(1.15)}.role-card h2{margin-bottom:.75rem;color:var(--text-primary);font-size:1.5rem}.role-card p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.9375rem;line-height:1.6}.role-benefits{list-style:none;padding:0;margin:0 0 1.5rem;text-align:left;width:100%}.role-benefits li{padding:.5rem 0 .5rem 1.75rem;position:relative;color:var(--text-secondary);font-size:.875rem}.role-benefits li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;background:var(--primary-color);border-radius:50%;box-shadow:0 0 10px #14b8a680}.role-card .btn{margin-top:auto;width:100%}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:var(--text-primary);font-size:2rem;font-weight:700;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.greeting-emoji{font-size:1.75rem;animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(10deg)}75%{transform:rotate(-10deg)}}.dashboard-subtitle{color:var(--text-secondary);margin-top:.5rem;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);padding:1.75rem;border-radius:var(--radius);box-shadow:var(--shadow-card);text-align:center;transition:all var(--transition-normal);border:1px solid var(--border-light);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-fast)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-card:hover:before{opacity:1}.stat-card h3{font-size:2.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.stat-card p{color:var(--text-secondary);margin-bottom:1rem;font-weight:500}.stat-card a{color:var(--primary-color);text-decoration:none;font-size:.875rem;font-weight:600;transition:all var(--transition-fast)}.stat-card a:hover{color:var(--primary-dark)}.quick-actions{margin-bottom:2rem}.quick-actions h2{margin-bottom:1rem}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap}.recent-notifications h2{margin-bottom:1rem}.notification-list{list-style:none;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.notification-item{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background:#eff6ff}.notification-content strong{display:block;margin-bottom:.25rem}.notification-content p{color:var(--text-secondary);font-size:.875rem}.notification-time{font-size:.75rem;color:var(--text-secondary)}.view-all-link{display:block;text-align:center;margin-top:1rem;color:var(--primary-color);text-decoration:none}.parent-dashboard{max-width:1600px}.parent-dashboard-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:900px){.parent-dashboard-grid{grid-template-columns:1fr 1fr;align-items:start}.parent-dashboard-grid .children-status-section{grid-row:span 2}}@media(min-width:1400px){.parent-dashboard-grid{grid-template-columns:minmax(300px,1.2fr) minmax(280px,1fr) minmax(280px,1fr)}.parent-dashboard-grid .children-status-section{grid-row:auto}}.parent-dashboard-grid .billing-summary-card,.parent-dashboard-grid .recent-activity-card{margin:0}.parent-dashboard-grid .children-status-section{display:flex;flex-direction:column;gap:1rem}@media(min-width:900px){.parent-dashboard-grid .child-status-card{padding:1rem}.parent-dashboard-grid .btn-qr-primary{padding:.6rem 1rem;font-size:.9rem}}.landing-page{min-height:100vh;background:var(--background);color:var(--text-primary);overflow-x:hidden}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;max-width:1400px;margin:0 auto;animation:fadeInDown .6s ease-out}.landing-logo{font-size:1.75rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;cursor:pointer;transition:transform .3s ease}.landing-logo:hover{transform:scale(1.05)}.landing-nav-links{display:flex;gap:1rem}.landing-nav-links .btn{animation:fadeIn .6s ease-out;animation-fill-mode:both}.landing-nav-links .btn:nth-child(1){animation-delay:.2s}.landing-nav-links .btn:nth-child(2){animation-delay:.3s}.hero{background:var(--background);background-image:radial-gradient(ellipse at 30% 0%,rgba(20,184,166,.2) 0%,transparent 50%),radial-gradient(ellipse at 70% 100%,rgba(139,92,246,.15) 0%,transparent 50%);color:var(--text-primary);padding-bottom:6rem;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23334155' fill-opacity='0.15'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.3}.hero-content{max-width:900px;margin:0 auto;text-align:center;padding:6rem 2rem 4rem;position:relative;z-index:1}.hero-badge{display:inline-block;padding:.5rem 1rem;background:#14b8a61a;border:1px solid rgba(20,184,166,.3);border-radius:50px;font-size:.875rem;color:var(--primary-light);margin-bottom:2rem;animation:fadeInUp .6s ease-out .2s both,borderGlow 3s ease-in-out infinite}.hero h1{font-size:3.5rem;margin-bottom:1.5rem;line-height:1.1;font-weight:700;letter-spacing:-.02em;animation:fadeInUp .7s ease-out .3s both}.hero h1 .highlight{background:linear-gradient(135deg,#14b8a6,#06b6d4,#8b5cf6,#14b8a6);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 4s ease infinite}.hero p{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2.5rem;max-width:600px;margin-left:auto;margin-right:auto;animation:fadeInUp .7s ease-out .4s both}.hero-buttons{display:flex;gap:1rem;justify-content:center;animation:fadeInUp .7s ease-out .5s both}.hero-buttons .btn-primary{position:relative;overflow:hidden}.hero-buttons .btn-primary:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 3s infinite}.hero-stats{display:flex;justify-content:center;gap:4rem;margin-top:4rem;padding-top:3rem;border-top:1px solid var(--border-color);animation:fadeIn .8s ease-out .7s both}.hero-stat{text-align:center;animation:fadeInUp .6s ease-out both}.hero-stat:nth-child(1){animation-delay:.8s}.hero-stat:nth-child(2){animation-delay:.9s}.hero-stat:nth-child(3){animation-delay:1s}.hero-stat-value{font-size:2rem;font-weight:700;color:var(--primary-color);transition:transform .3s ease,color .3s ease}.hero-stat:hover .hero-stat-value{transform:scale(1.1);color:var(--primary-light)}.hero-stat-label{font-size:.875rem;color:var(--text-secondary);transition:color .3s ease}.hero-stat:hover .hero-stat-label{color:var(--text-primary)}.how-it-works,.benefits,.features,.cta-section{padding:6rem 2rem;max-width:1200px;margin:0 auto}.section-badge{display:inline-block;padding:.375rem .875rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:50px;font-size:.75rem;color:var(--secondary-color);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;transition:all .3s ease}.section-badge:hover{background:#8b5cf633;transform:scale(1.05)}.how-it-works h2,.benefits h2,.features h2,.cta-section h2{text-align:center;margin-bottom:1rem;font-size:2.5rem;font-weight:700}.section-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:4rem;max-width:600px;margin-left:auto;margin-right:auto}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.step{text-align:center;padding:2rem;background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border-color);transition:all .3s ease}.step:hover{border-color:var(--primary-color);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.step-number{width:60px;height:60px;background:var(--gradient-primary);color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 1.5rem;box-shadow:0 0 30px #14b8a64d;transition:all .3s ease}.step:hover .step-number{animation:glowPulse 1.5s ease-in-out infinite;transform:scale(1.1)}.step h3{margin-bottom:.75rem;font-size:1.25rem}.step p{color:var(--text-secondary);font-size:.9375rem}.benefits{background:var(--background-secondary);padding:6rem 2rem;margin:0;max-width:none}.benefits>*{max-width:1200px;margin-left:auto;margin-right:auto}.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:2rem}.benefit-card{background:var(--card-bg);padding:2.5rem;border-radius:var(--radius);border:1px solid var(--border-color);transition:all .3s ease}.benefit-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-glow)}.benefit-icon{font-size:3rem;margin-bottom:1.5rem;transition:transform .3s ease}.benefit-card:hover .benefit-icon{transform:scale(1.2);animation:float 2s ease-in-out infinite}.benefit-card h3{margin-bottom:1.25rem;font-size:1.375rem;color:var(--text-primary)}.benefit-card ul{list-style:none;padding:0}.benefit-card li{padding:.625rem 0 .625rem 1.75rem;position:relative;color:var(--text-secondary);font-size:.9375rem}.benefit-card li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;background:var(--primary-color);border-radius:50%;box-shadow:0 0 10px #14b8a680;transition:all .3s ease}.benefit-card li:hover:before{transform:translateY(-50%) scale(1.5);box-shadow:0 0 20px #14b8a6cc}.benefit-card li{transition:transform .2s ease,color .2s ease}.benefit-card li:hover{transform:translate(5px);color:var(--text-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.feature{background:var(--card-bg);padding:2rem;border-radius:var(--radius);border:1px solid var(--border-color);text-align:left;transition:all .3s ease}.feature:hover{border-color:var(--primary-color);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.feature-icon{width:48px;height:48px;background:#14b8a61a;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:1.5rem;transition:all .3s ease}.feature:hover .feature-icon{background:#14b8a633;transform:scale(1.1) rotate(5deg);box-shadow:0 0 20px #14b8a64d}.feature h4{color:var(--text-primary);margin-bottom:.5rem;font-size:1.125rem}.feature p{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.cta-section{text-align:center;background:var(--background-secondary);padding:6rem 2rem;margin:0;max-width:none;background-image:radial-gradient(ellipse at 50% 50%,rgba(20,184,166,.1) 0%,transparent 70%);position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(20,184,166,.05) 0%,transparent 50%);animation:pulse 8s ease-in-out infinite}.cta-section h2{margin-bottom:1rem;position:relative}.cta-section p{color:var(--text-secondary);margin-bottom:2.5rem;font-size:1.125rem;position:relative}.cta-buttons{display:flex;gap:1rem;justify-content:center;position:relative}.cta-buttons .btn-primary{animation:pulse 2s ease-in-out infinite}.cta-buttons .btn-primary:hover{animation:none}.landing-footer{background:var(--background);color:var(--text-secondary);text-align:center;padding:3rem 2rem;border-top:1px solid var(--border-color)}@media(max-width:768px){.hero h1{font-size:2.25rem}.hero p{font-size:1rem}.hero-stats{flex-direction:column;gap:1.5rem}.hero-buttons,.cta-buttons{flex-direction:column;align-items:center}.landing-nav{flex-direction:column;gap:1rem}.how-it-works h2,.benefits h2,.features h2,.cta-section h2{font-size:1.75rem}}.profile-container{max-width:600px}.profile-info{background:var(--card-bg);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;margin-bottom:1.5rem}.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;margin:0 auto 1rem}.profile-role{color:var(--primary-color);text-transform:capitalize;font-weight:500}.profile-email{color:var(--text-secondary)}.profile-container .form-container{margin-bottom:1.5rem}.profile-container h3{margin-bottom:1rem}.profile-container hr{border:none;border-top:1px solid var(--border-color);margin:1.5rem 0}.form-note{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.form-hint{display:block;color:var(--text-secondary);font-size:.75rem;margin-top:.25rem}.form-warning{display:block;color:#f59e0b;font-size:.75rem;margin-top:.5rem}.inline-toggle{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius);cursor:pointer}.inline-toggle .toggle-label{flex:1;margin-right:1rem}.account-info{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.role-management{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem}.role-management h3{margin-bottom:.5rem}.current-roles{margin-top:1.5rem}.current-roles h4{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.role-badges-list{display:flex;flex-wrap:wrap;gap:.5rem}.role-badges-list .role-badge{font-size:.875rem;padding:.5rem 1rem}.role-badges-list .role-badge.active{border:2px solid var(--primary-color);box-shadow:var(--shadow-glow)}.add-role-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.add-role-section h4{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.add-role-grid{display:flex;flex-direction:column;gap:.75rem}.add-role-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--background);border-radius:var(--radius-sm);transition:background .2s}.add-role-card:hover{background:var(--card-bg-hover)}.add-role-icon{font-size:1.5rem}.add-role-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.add-role-info strong{font-size:.9375rem}.add-role-info small{font-size:.75rem;color:var(--text-secondary)}.no-roles-message{color:var(--text-secondary);font-size:.875rem;text-align:center;padding:1rem}.notification-preferences{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem}.notification-preferences h3{margin-bottom:.5rem}.pref-section{margin-top:1.5rem}.pref-section h4{font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:1rem}.pref-toggles{display:flex;flex-direction:column;gap:.75rem}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--background);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s}.toggle-row:hover{background:var(--card-bg-hover)}.toggle-label{display:flex;flex-direction:column;gap:.25rem}.toggle-label strong{font-size:.9375rem}.toggle-label small{color:var(--text-secondary);font-size:.75rem}.toggle-switch{position:relative;width:48px;height:26px;background:var(--border-color);border:none;border-radius:13px;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle-switch.active{background:var(--primary-color)}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-knob{transform:translate(22px)}.checkin-container{display:grid;grid-template-columns:1fr 300px;gap:2rem}.checkin-search{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem}.checkin-search h2{margin-bottom:1rem}.checkin-search .form-group{display:flex;gap:1rem}.quick-select{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.quick-select label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.quick-select select{width:100%;max-width:400px}.quick-select-hint{display:block;margin-top:.5rem;font-size:.75rem;color:var(--text-secondary)}.card-input{flex:1;font-size:1.25rem!important;text-transform:uppercase;letter-spacing:2px}.student-info-card{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.student-details-large{margin:1.5rem 0}.detail-row{display:flex;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.detail-row .label{width:100px;color:var(--text-secondary)}.detail-row .value{font-weight:500}.card-id-display{font-family:monospace;font-size:1.25rem;letter-spacing:2px;color:var(--primary-color)}.checkin-form{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.recent-boardings{background:var(--card-bg);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);height:fit-content}.recent-boardings h3{margin-bottom:1rem}.boarding-list{list-style:none}.boarding-item{padding:.75rem 0;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:.25rem}.boarding-item:last-child{border-bottom:none}.boarding-type{font-size:.75rem;padding:.125rem .5rem;border-radius:4px;width:fit-content}.boarding-type.pickup{background:#dbeafe;color:#1d4ed8}.boarding-type.dropoff{background:#dcfce7;color:#16a34a}.sound-controls{display:flex;gap:.5rem;align-items:center}.sound-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-full);transition:all .2s}.sound-toggle.sound-on{background:var(--success-light);color:var(--success-color);border:1px solid var(--success-color)}.sound-toggle.sound-off{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.sound-indicator{width:10px;height:10px;border-radius:50%;background:var(--text-muted);transition:all .2s}.sound-indicator.active{background:var(--success-color);box-shadow:0 0 8px var(--success-color)}.card-id-prominent{background:linear-gradient(135deg,#334155,#3498db);border-radius:var(--radius);padding:2rem;margin:1.5rem 0;text-align:center;color:#fff}.card-id-label{display:block;font-size:.875rem;opacity:.9;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:1px}.card-id-box{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.card-id-box .card-id-value{font-size:2rem;font-weight:700;font-family:Monaco,Menlo,monospace;letter-spacing:3px;background:#fff3;padding:.75rem 1.5rem;border-radius:var(--radius-sm);border:2px dashed rgba(255,255,255,.4)}.copy-btn{background:#fff;color:var(--primary-color);border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all .2s}.copy-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.copy-btn.copied{background:var(--success-color);color:#fff}.card-id-instruction{font-size:.9rem;opacity:.95;margin:0;font-weight:500}@media(max-width:768px){.checkin-container{grid-template-columns:1fr;gap:1rem}.checkin-search .form-group{flex-direction:column}.quick-select select{max-width:100%}.card-input{font-size:1rem!important}.detail-row{flex-direction:column;gap:.25rem}.detail-row .label{width:auto;font-size:.75rem}.card-id-box{flex-direction:column;gap:.75rem}.card-id-box .card-id-value{font-size:1.5rem;padding:.5rem 1rem}}@media(max-width:480px){.checkin-search,.student-info-card,.recent-boardings{padding:1rem}.card-id-prominent{padding:1.5rem 1rem}.card-id-box .card-id-value{font-size:1.25rem;letter-spacing:2px}}.tracking-container{display:grid;grid-template-columns:1fr 350px;gap:2rem}.map-container{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);min-height:400px;height:400px;overflow:hidden}.map-view{width:100%;height:100%;min-height:400px;border-radius:var(--radius)}.map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;background:var(--background-secondary);border-radius:var(--radius);color:var(--text-secondary)}.map-placeholder{height:100%;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--background-secondary);border-radius:var(--radius)}.map-placeholder h3{color:var(--text-primary);margin-bottom:.5rem}.last-updated{font-size:.875rem;color:var(--text-secondary)}.tracking-status{display:flex;align-items:center;gap:1rem}.connection-status{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.connection-status:before{content:"";width:8px;height:8px;border-radius:50%}.connection-status.connected{background:#22c55e33;color:var(--success-color)}.connection-status.connected:before{background:var(--success-color);animation:pulse-dot 1.5s ease-in-out infinite}.connection-status.disconnected{background:#f59e0b33;color:var(--warning-color)}.connection-status.disconnected:before{background:var(--warning-color)}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@media(min-width:1024px){.map-container{height:500px}}.route-info-panel{display:flex;flex-direction:column;gap:1rem}.route-info-panel h2{margin-bottom:.5rem}.info-card{background:var(--card-bg);padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.info-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.info-card h3{font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.75rem}.no-route-card{text-align:center;padding:2rem}.no-route-card h3{font-size:1.25rem;text-transform:none;color:var(--text-primary)}.no-route-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.no-route-steps{text-align:left;background:var(--background);padding:1.25rem;border-radius:var(--radius-sm);margin:1.5rem 0}.no-route-steps h4{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.no-route-steps ol{margin:0;padding-left:1.25rem}.no-route-steps li{margin-bottom:.5rem;line-height:1.5}.no-route-steps li:last-child{margin-bottom:0}.no-route-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.no-route-container{display:flex;flex-direction:column;gap:1.5rem}.setup-progress{display:flex;align-items:center;justify-content:center;gap:0;padding:1rem;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow)}.setup-progress .progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.5}.setup-progress .progress-step.completed,.setup-progress .progress-step.current{opacity:1}.setup-progress .step-circle{width:32px;height:32px;border-radius:50%;background:var(--background);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.setup-progress .progress-step.completed .step-circle{background:var(--success-color);border-color:var(--success-color);color:#fff}.setup-progress .progress-step.current .step-circle{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.setup-progress .progress-step span{font-size:.75rem;color:var(--text-secondary)}.setup-progress .progress-step.current span{color:var(--primary-color);font-weight:600}.progress-connector{width:60px;height:2px;background:var(--border-color);margin:0 .5rem 1.5rem}.no-route-card-enhanced{text-align:center;padding:2rem}.no-route-illustration{margin-bottom:1.5rem}.bus-waiting-svg{width:120px;height:100px}.no-route-card-enhanced h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:.5rem;text-transform:none}.no-route-subtitle{color:var(--text-secondary);margin-bottom:1.5rem}.card-id-prominent{background:var(--background);padding:1.25rem;border-radius:var(--radius);margin-bottom:1.5rem}.card-id-label{display:block;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.card-id-box{display:flex;align-items:center;justify-content:center;gap:1rem}.card-id-box .card-id-value{font-size:1.5rem;font-weight:700;font-family:SF Mono,Consolas,monospace;color:var(--primary-color);letter-spacing:2px}.copy-btn{padding:.5rem 1rem;font-size:.875rem;border-radius:6px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;transition:all .2s}.copy-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.copy-btn.copied{background:var(--success-color);border-color:var(--success-color);color:#fff}.no-route-steps-enhanced{text-align:left;background:var(--background);padding:1.25rem;border-radius:var(--radius);margin-bottom:1.5rem}.no-route-steps-enhanced h4{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.step-item{display:flex;gap:1rem;margin-bottom:1rem}.step-item:last-child{margin-bottom:0}.step-item .step-number{width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.step-item .step-content strong{display:block;color:var(--text-primary);margin-bottom:.25rem}.step-item .step-content p{font-size:.875rem;color:var(--text-secondary);margin:0}.no-route-actions-enhanced{margin-bottom:1rem}.timeline-note{font-size:.875rem;color:var(--text-muted);font-style:italic}.messages-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.messages-list{display:flex;flex-direction:column;gap:1rem}.message-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s}.message-card:hover,.message-card.expanded{box-shadow:var(--shadow-lg)}.message-card.unread{border-left:4px solid var(--primary-color)}.message-clickable{display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;cursor:pointer;transition:background .2s}.message-clickable:hover{background:var(--card-bg-hover)}.message-expand-icon{color:var(--text-secondary);font-size:.75rem;padding:.25rem}.message-card .message-actions{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border-color);margin-top:0}.message-icon{font-size:1.5rem}.message-content{flex:1}.message-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.5rem}.message-header h3{font-size:1rem}.message-time{font-size:.75rem;color:var(--text-secondary)}.message-body{color:var(--text-secondary);font-size:.875rem;margin-bottom:.75rem;line-height:1.5}.message-body.truncated{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tap-to-read{font-size:.75rem;color:var(--primary-color);font-style:italic}.message-meta{display:flex;gap:.5rem}.type-badge{font-size:.7rem;padding:.125rem .5rem;border-radius:4px;background:var(--background);text-transform:capitalize}.priority-badge{font-size:.7rem;padding:.125rem .5rem;border-radius:4px}.priority-high,.priority-urgent{background:#fef2f2;color:var(--danger-color)}.message-actions{display:flex;flex-direction:column;gap:.5rem}.mode-toggle{display:flex;background:var(--background);border-radius:var(--radius);padding:.25rem;margin-bottom:1.5rem;width:fit-content}.toggle-btn{padding:.5rem 1.5rem;border:none;background:transparent;border-radius:6px;cursor:pointer;font-weight:500;color:var(--text-secondary);transition:all .2s}.toggle-btn.active{background:var(--card-bg);color:var(--primary-color);box-shadow:var(--shadow)}.add-child-container{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:2rem}.add-child-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2.5rem;width:100%;max-width:600px;border:1px solid var(--border-color)}.add-child-header{text-align:center;margin-bottom:2rem}.add-child-header h1{margin-bottom:.5rem;color:var(--text-primary)}.add-child-header p{color:var(--text-secondary)}.progress-steps{display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem}.progress-step .step-number{width:36px;height:36px;border-radius:50%;background:var(--border-color);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:600;transition:all .2s}.progress-step.active .step-number{background:var(--gradient-primary);color:#fff;box-shadow:0 0 15px #14b8a666}.progress-step .step-label{font-size:.875rem;color:var(--text-secondary)}.progress-step.active .step-label{color:var(--primary-color);font-weight:500}.progress-line{width:60px;height:2px;background:var(--border-color);margin:0 1rem 1.5rem}.form-step h2{margin-bottom:1.5rem;font-size:1.25rem;color:var(--text-primary)}.success-card{text-align:center}.success-icon{width:80px;height:80px;background:var(--success-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 1.5rem;box-shadow:0 0 30px #22c55e66;animation:scaleIn .5s ease-out}.success-card h1{color:var(--text-primary);margin-bottom:.5rem}.success-message{color:var(--text-secondary);margin-bottom:2rem}.success-highlight{font-size:1.125rem;color:var(--primary-color);font-weight:500}.next-steps-enhanced{text-align:left;background:var(--background);padding:1.5rem;border-radius:var(--radius);margin-bottom:1.5rem}.next-steps-enhanced h3{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.timeline-estimate{text-align:center;font-size:.875rem;color:var(--text-muted);font-style:italic;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.card-id-instruction{font-size:.875rem;color:var(--text-muted);margin-top:.75rem}.card-id-display-large{background:var(--background);padding:1.5rem;border-radius:var(--radius);margin-bottom:2rem;border:1px solid var(--border-color)}.card-id-display-large .label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.card-id-display-large .card-id-value{display:block;font-size:2rem;font-family:monospace;font-weight:700;color:var(--primary-color);letter-spacing:4px;margin-bottom:.5rem}.card-id-display-large small{color:var(--text-secondary)}.next-steps{text-align:left;background:#14b8a61a;padding:1.5rem;border-radius:var(--radius);margin-bottom:2rem;border:1px solid rgba(20,184,166,.2)}.next-steps h3{margin-bottom:1rem;font-size:1rem;color:var(--text-primary)}.next-steps ol{margin:0;padding-left:1.25rem}.next-steps li{margin-bottom:.5rem;color:var(--text-secondary)}.success-actions{display:flex;flex-direction:column;gap:1rem}.empty-state .empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state .benefits-list{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin:1.5rem 0}.empty-state .benefits-list span{color:var(--success-color);font-size:.875rem}.empty-state-illustrated{padding:3rem 2rem;max-width:500px;margin:2rem auto}.empty-illustration-wrapper{margin-bottom:1.5rem}.empty-illustration{width:100%;max-width:180px;height:auto;margin:0 auto;display:block}.empty-state-illustrated h3{font-size:1.35rem;color:var(--text-primary);margin-bottom:.75rem;font-weight:600}.empty-state-illustrated p{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1.25rem}.empty-state-illustrated .benefits-list{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;justify-content:center;margin-bottom:1.5rem;padding:0}.empty-state-illustrated .benefits-list span{color:var(--success-color);font-size:.9rem;font-weight:500}.empty-state-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1.5rem}.empty-state-actions .btn-large{padding:.875rem 2rem;font-size:1rem;font-weight:600}@media(max-width:480px){.empty-state-illustrated{padding:2rem 1.5rem;margin:1rem}.empty-illustration{max-width:140px}.empty-state-illustrated h3{font-size:1.2rem}.empty-state-illustrated p{font-size:.95rem}.empty-state-illustrated .benefits-list{flex-direction:column;align-items:center;gap:.5rem}.empty-state-actions{flex-direction:column}.empty-state-actions .btn{width:100%}}@media(max-width:768px){.add-child-card{padding:1.5rem}.progress-line{width:30px}.success-actions{flex-direction:column}.card-id-display-large .card-id-value{font-size:1.5rem;letter-spacing:2px}}.photo-upload-section{margin-bottom:1.5rem}.photo-upload-section>label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.photo-upload-container{display:flex;justify-content:center;margin-bottom:.5rem}.photo-placeholder{width:120px;height:120px;border:2px dashed var(--border-color);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.photo-placeholder:hover{border-color:var(--primary-color);color:var(--primary-color);background:#14b8a61a}.photo-placeholder .photo-icon{font-size:2rem}.photo-preview{position:relative;width:120px;height:120px}.photo-preview img{width:100%;height:100%;object-fit:cover;border-radius:50%;border:3px solid var(--primary-color)}.remove-photo-btn{position:absolute;top:0;right:0;width:28px;height:28px;border-radius:50%;background:var(--danger-color);color:#fff;border:none;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform .2s}.remove-photo-btn:hover{transform:scale(1.1)}.photo-upload-section small{display:block;text-align:center;color:var(--text-secondary);font-size:.75rem}.student-found-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.student-found-name h3{font-size:1.25rem;margin-bottom:.25rem}.student-found-name .card-id-display{font-size:.875rem;color:var(--text-secondary);font-family:monospace}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg);margin-top:var(--space-xl)}.settings-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all .2s ease}.settings-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.settings-card-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-md);color:var(--primary-color)}.settings-card-icon svg{width:24px;height:24px}.settings-card-content{flex:1;min-width:0}.settings-card-content h3{margin:0 0 var(--space-xs) 0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.settings-card-content p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.settings-badge{display:inline-block;margin-top:var(--space-xs);padding:.2rem .5rem;background:var(--danger-color);color:#fff;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.settings-card-arrow{flex-shrink:0;color:var(--text-tertiary);transition:transform .2s ease}.settings-card-arrow svg{width:20px;height:20px}.settings-card:hover .settings-card-arrow{transform:translate(4px);color:var(--primary-color)}.page-subtitle{margin:var(--space-xs) 0 0 0;color:var(--text-secondary);font-size:1rem}[data-theme=dark] .settings-card{background:var(--card-bg)}[data-theme=dark] .settings-card:hover{box-shadow:0 4px 12px #0000004d}@media(max-width:600px){.settings-grid{grid-template-columns:1fr;gap:var(--space-md)}.settings-card{padding:var(--space-md)}.settings-card-icon{width:40px;height:40px}.settings-card-icon svg{width:20px;height:20px}}.fleet-map-container{display:flex;height:calc(100vh - 64px);overflow:hidden}.fleet-sidebar{width:320px;min-width:320px;background:var(--card-bg, #ffffff);border-right:1px solid var(--border-color, #e2e8f0);display:flex;flex-direction:column;overflow-y:auto}.fleet-sidebar-header{padding:1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.fleet-sidebar-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.fleet-sidebar-header h3{margin:0;font-size:1.1rem}.fleet-sidebar-summary{display:flex;gap:.75rem}.summary-item{display:flex;flex-direction:column;align-items:center;flex:1}.summary-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1e293b)}.summary-label{font-size:.7rem;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.05em}.summary-item.highlight .summary-value{color:var(--success-color, #10b981)}.fleet-sidebar-filters{padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.sidebar-search{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color, #e2e8f0);border-radius:6px;background:var(--background, #f8fafc);color:var(--text-primary, #1e293b);font-size:.85rem;margin-bottom:.5rem}.sidebar-search:focus{outline:none;border-color:var(--primary-color, #334155)}.sidebar-search::placeholder{color:var(--text-secondary, #64748b)}.sidebar-filter-row{display:flex;gap:.5rem}.sidebar-select{flex:1;padding:.35rem .5rem;border:1px solid var(--border-color, #e2e8f0);border-radius:6px;background:var(--background, #f8fafc);color:var(--text-primary, #1e293b);font-size:.75rem;cursor:pointer}.sidebar-result-count{margin-top:.5rem;font-size:.75rem;color:var(--text-secondary, #64748b)}.fleet-sidebar-routes{padding:.75rem;flex:1;overflow-y:auto}.route-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.route-item{padding:.75rem;border-radius:8px;border:1px solid var(--border-color, #e2e8f0);cursor:pointer;transition:all .15s ease}.route-item:hover{border-color:var(--primary-color, #334155);background:var(--color-surface-hover, rgba(0, 0, 0, .02))}.route-item.selected{border-color:var(--primary-color, #334155);background:var(--color-primary-light, rgba(59, 130, 246, .08))}.route-item.active{border-left:3px solid var(--success-color, #10b981)}.route-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.15rem}.route-name{font-weight:600;font-size:.9rem}.route-description{font-size:.75rem;color:var(--text-secondary, #64748b);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-item-details{display:flex;gap:.5rem;align-items:center;font-size:.75rem;color:var(--text-secondary, #64748b);margin-bottom:.15rem}.route-item-meta{display:flex;gap:.5rem;align-items:center;font-size:.7rem;color:var(--text-secondary, #64748b)}.route-type-tag{background:var(--background, #f8fafc);padding:.1rem .4rem;border-radius:3px;font-size:.65rem;text-transform:uppercase;letter-spacing:.03em}.capacity-badge-sm{padding:.1rem .35rem;border-radius:3px;font-weight:600;font-size:.7rem}.capacity-badge-sm.capacity-low{background-color:var(--success-light, #dcfce7);color:var(--success-color, #16a34a)}.capacity-badge-sm.capacity-medium{background-color:var(--warning-light, #fef3c7);color:var(--warning-color, #d97706)}.capacity-badge-sm.capacity-high{background-color:var(--danger-light, #fee2e2);color:var(--danger-color, #dc2626)}.capacity-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-weight:600;font-size:.85rem}.capacity-low{background-color:var(--success-light, #dcfce7);color:var(--success-color, #16a34a)}.capacity-medium{background-color:var(--warning-light, #fef3c7);color:var(--warning-color, #d97706)}.capacity-high{background-color:var(--danger-light, #fee2e2);color:var(--danger-color, #dc2626)}.no-routes{color:var(--text-secondary, #64748b);font-size:.85rem;text-align:center;padding:1rem}.fleet-map-main{flex:1;display:flex;flex-direction:column;min-width:0}.fleet-map-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--card-bg, #ffffff);border-bottom:1px solid var(--border-color, #e2e8f0)}.fleet-map-header h2{margin:0;font-size:1.1rem}.fleet-map-title-row,.fleet-map-actions{display:flex;align-items:center;gap:1rem}.fleet-map-stats{display:flex;gap:1rem}.fleet-stat{font-size:.85rem;color:var(--text-secondary, #64748b)}.fleet-stat strong{color:var(--text-primary, #1e293b);margin-right:.25rem}.fleet-map-wrapper{flex:1;position:relative}.fleet-map-wrapper>div{height:100%!important}.fleet-sidebar-detail{border-right:1px solid var(--border-color, #e2e8f0)}.sidebar-detail-header{padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.sidebar-back-btn{background:none;border:none;color:var(--primary-color, #334155);cursor:pointer;font-size:.85rem;padding:.25rem 0;display:flex;align-items:center;gap:.25rem}.sidebar-back-btn:hover{text-decoration:underline}.sidebar-detail-title{padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.sidebar-detail-title h3{margin:0 0 .25rem;font-size:1rem}.fleet-detail-meta{display:flex;gap:.5rem;align-items:center;font-size:.8rem;color:var(--text-secondary, #64748b)}.fleet-detail-bus{display:flex;gap:.75rem;align-items:center;padding:.75rem 1rem;background:var(--background, #f8fafc);font-size:.85rem}.bus-live-indicator{background:var(--success-color, #10b981);color:#fff;font-size:.7rem;padding:.1rem .4rem;border-radius:4px;font-weight:600;text-transform:uppercase}.fleet-detail-progress{padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.progress-header{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.5rem}.progress-percent{font-weight:700;color:var(--primary-color, #334155)}.progress-bar{height:8px;background:var(--border-color, #e2e8f0);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--success-color, #10b981);border-radius:4px;transition:width .3s ease}.fleet-actions-section{padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.route-actions-description{margin:0;font-size:.85rem;color:var(--text-secondary, #64748b);line-height:1.4}.route-actions-info{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.info-label{color:var(--text-secondary, #64748b)}.info-value{font-weight:500}.fleet-actions-buttons{display:flex;gap:.5rem;flex-wrap:wrap;padding:1rem}.fleet-actions-buttons .btn{flex:1;text-align:center;min-width:0}.fleet-detail-students{padding:.75rem 1rem;flex:1}.student-group{margin-bottom:1rem}.student-group-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.student-group-title.on-bus{color:var(--success-color, #10b981)}.student-group-title.dropped-off{color:var(--info-color, #3b82f6)}.student-group-title.waiting{color:var(--text-secondary, #64748b)}.student-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.85rem}.student-row.on-bus{color:var(--success-color, #10b981)}.student-row.dropped-off{color:var(--text-secondary, #64748b)}.student-row small{color:var(--text-secondary, #64748b);font-size:.75rem}.delay-badge{background:var(--danger-light, #fee2e2);color:var(--danger-color, #dc2626);padding:.1rem .4rem;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase;animation:pulse-delay 1.5s ease-in-out infinite}@keyframes pulse-delay{0%,to{opacity:1}50%{opacity:.7}}.route-item-meta .driver-name{color:var(--text-primary, #1e293b);font-weight:500}.fleet-delay-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--danger-light, #fee2e2);color:var(--danger-color, #dc2626);font-size:.85rem;font-weight:500;border-bottom:1px solid var(--border-color, #e2e8f0)}.fleet-delay-warning .delay-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--danger-color, #dc2626);color:#fff;border-radius:50%;font-size:.75rem;font-weight:700}.fleet-driver-info{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--background, #f8fafc);font-size:.85rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.fleet-driver-info .driver-label{color:var(--text-secondary, #64748b)}.fleet-driver-info .driver-name{font-weight:500;color:var(--text-primary, #1e293b)}.fleet-driver-info .driver-phone{margin-left:auto;color:var(--primary-color, #3b82f6);text-decoration:none;font-size:.8rem}.fleet-driver-info .driver-phone:hover{text-decoration:underline}@media(max-width:768px){.fleet-map-container{flex-direction:column;height:auto}.fleet-sidebar{width:100%;min-width:unset;max-height:280px;border-right:none;border-bottom:1px solid var(--border-color, #e2e8f0)}.fleet-sidebar-filters{padding:.5rem .75rem}.fleet-map-main{min-height:400px}.fleet-map-stats{display:none}.fleet-sidebar-detail{border-right:none;border-bottom:1px solid var(--border-color, #e2e8f0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px #14b8a64d}50%{box-shadow:0 0 40px #14b8a680}}@keyframes borderGlow{0%,to{border-color:var(--border-color)}50%{border-color:var(--primary-color)}}.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.animate-on-scroll.visible{opacity:1;transform:translateY(0)}.animate-delay-1{transition-delay:.1s}.animate-delay-2{transition-delay:.2s}.animate-delay-3{transition-delay:.3s}.animate-delay-4{transition-delay:.4s}.animate-delay-5{transition-delay:.5s}.stat-card:after,.auth-card:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease;pointer-events:none}.stat-card:hover:after,.auth-card:hover:after{left:100%}.notification-item{transition:background-color .2s ease,transform .2s ease}.notification-item:hover{background-color:var(--background-secondary);transform:translate(4px)}.dropdown-menu,.user-menu-dropdown,.theme-dropdown,.role-switcher-dropdown{transform-origin:top center}.nav-dropdown.open .dropdown-menu,.user-menu-dropdown,.theme-dropdown,.role-switcher-dropdown{animation:dropdownSlideIn .25s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item,.user-menu-item,.theme-option,.role-switcher-option{opacity:0;animation:dropdownItemFadeIn .2s ease forwards}.dropdown-item:nth-child(1),.user-menu-item:nth-child(1){animation-delay:.05s}.dropdown-item:nth-child(2),.user-menu-item:nth-child(2){animation-delay:.1s}.dropdown-item:nth-child(3),.user-menu-item:nth-child(3){animation-delay:.15s}.dropdown-item:nth-child(4),.user-menu-item:nth-child(4){animation-delay:.2s}.dropdown-item:nth-child(5),.user-menu-item:nth-child(5){animation-delay:.25s}@keyframes dropdownItemFadeIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.dropdown-item,.user-menu-item{transition:background-color .15s ease,color .15s ease,transform .15s ease}.dropdown-item:hover,.user-menu-item:hover{transform:translate(4px)}.dropdown-arrow,.user-menu-arrow{transition:transform .25s cubic-bezier(.4,0,.2,1)}.page-transition-enter{opacity:0;transform:translateY(10px)}.page-transition-enter-active{opacity:1;transform:translateY(0);transition:opacity .25s ease-out,transform .25s ease-out}.page-transition-exit{opacity:1;transform:translateY(0)}.page-transition-exit-active{opacity:0;transform:translateY(-10px);transition:opacity .2s ease-in,transform .2s ease-in}.page-container,.dashboard,.add-child-container,.profile-container{animation:pageSlideIn .3s ease-out}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.student-card,.school-card,.role-card,.route-card,.bus-card{transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1)}.student-card:hover,.school-card:hover,.role-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 12px 40px #0000001f,0 4px 12px #00000014}.data-table tbody tr{transition:background-color .15s ease,transform .15s ease}.data-table tbody tr:hover{background-color:var(--background-secondary);transform:scale(1.005)}.loading-bus{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.bus-bounce{font-size:3rem;animation:busBounceDrive 1.2s ease-in-out infinite}@keyframes busBounceDrive{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-12px) rotate(-3deg)}50%{transform:translateY(0) rotate(0)}75%{transform:translateY(-8px) rotate(3deg)}}.bus-road{width:80px;height:4px;background:var(--border-color);border-radius:2px;position:relative;overflow:hidden}.bus-road:after{content:"";position:absolute;top:50%;left:-20px;width:10px;height:2px;background:var(--text-muted);border-radius:1px;animation:roadDash .6s linear infinite}@keyframes roadDash{to{transform:translate(100px)}}.loading-bus-text{color:var(--text-secondary);font-size:.9rem;animation:loadingPulse 1.5s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.6}50%{opacity:1}}.dropdown-menu,.user-menu-dropdown{animation:dropdownSlideDown .25s cubic-bezier(.34,1.56,.64,1);transform-origin:top center}@keyframes dropdownSlideDown{0%{opacity:0;transform:translate(-50%) translateY(-8px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.user-menu-dropdown{animation:userMenuSlide .2s cubic-bezier(.34,1.56,.64,1);transform-origin:top right}@keyframes userMenuSlide{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{transition:background-color .15s ease,transform .15s ease,padding-left .15s ease}.dropdown-item:hover{padding-left:1.25rem}.form-group input,.form-group select,.form-group textarea{transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{transform:scale(1.01)}.field-wrapper:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--primary-color);transition:width .3s ease,left .3s ease;border-radius:1px}.animated-checkmark{width:80px;height:80px;margin:0 auto 1.5rem}.animated-checkmark svg{width:100%;height:100%}.checkmark-circle{stroke:var(--success-color);stroke-width:3;fill:none;stroke-dasharray:166;stroke-dashoffset:166;animation:checkmarkCircle .6s cubic-bezier(.65,0,.45,1) forwards}.checkmark-check{stroke:var(--success-color);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:checkmarkDraw .3s cubic-bezier(.65,0,.45,1) .5s forwards}.success-icon{animation:successPop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes successPop{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.alert{animation:alertSlideIn .3s ease-out}@keyframes alertSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.toast-enter{animation:toastSlideIn .3s cubic-bezier(.34,1.56,.64,1)}.toast-exit{animation:toastSlideOut .2s ease-in forwards}@keyframes toastSlideOut{to{opacity:0;transform:translate(100%) scale(.9)}}.card-grid>*,.boarding-list>*{animation:staggerFadeIn .4s ease-out both}.card-grid>*:nth-child(1){animation-delay:.05s}.card-grid>*:nth-child(2){animation-delay:.1s}.card-grid>*:nth-child(3){animation-delay:.15s}.card-grid>*:nth-child(4){animation-delay:.2s}.card-grid>*:nth-child(5){animation-delay:.25s}.card-grid>*:nth-child(6){animation-delay:.3s}@keyframes staggerFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@keyframes focusRing{0%{box-shadow:0 0 #3498db66}to{box-shadow:0 0 0 4px #3498db26}}.sound-indicator.active{animation:indicatorPulse 2s ease-in-out infinite}@keyframes indicatorPulse{0%,to{box-shadow:0 0 4px var(--success-color)}50%{box-shadow:0 0 12px var(--success-color)}}.loading-spinner{width:60px;height:40px;position:relative;border:none;border-radius:0;animation:none}.loading-spinner:before{content:"";position:absolute;width:50px;height:30px;background:var(--gradient-primary);border-radius:8px 8px 4px 4px;left:5px;top:0;animation:busBounce .6s ease-in-out infinite}.loading-spinner:after{content:"";position:absolute;bottom:0;width:12px;height:12px;background:var(--text-secondary);border-radius:50%;left:10px;animation:wheelSpin .4s linear infinite,wheelBounce .6s ease-in-out infinite;box-shadow:28px 0 0 var(--text-secondary)}@keyframes busBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes wheelSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes wheelBounce{0%,to{bottom:0}50%{bottom:8px}}.loading-spinner .bus-window{position:absolute;width:8px;height:10px;background:#fffc;border-radius:2px;top:6px}.loading-dots{display:flex;gap:6px;align-items:center;justify-content:center}.loading-dots span{width:10px;height:10px;background:var(--primary-color);border-radius:50%;animation:dotBounce .6s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.1s}.loading-dots span:nth-child(3){animation-delay:.2s}@keyframes dotBounce{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(-10px);opacity:.6}}.loading-container{background:var(--background)}.loading-container p{animation:pulse 1.5s ease-in-out infinite;color:var(--text-secondary)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-inline{display:inline-flex;align-items:center;gap:8px}.loading-inline .spinner-small{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.form-group input,.form-group select,.form-group textarea,.search-input{transition:border-color .25s ease,box-shadow .25s ease,background-color .25s ease;position:relative}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #3498db26;animation:inputFocusPulse .3s ease}@keyframes inputFocusPulse{0%{box-shadow:0 0 #3498db66}to{box-shadow:0 0 0 4px #3498db26}}.field-wrapper{position:relative}.field-wrapper:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--gradient-primary);transition:width .3s ease,left .3s ease;border-radius:2px}.field-wrapper:focus-within:after{width:100%;left:0}.form-group label{transition:color .25s ease,transform .25s ease}.form-group:focus-within label{color:var(--primary-color)}.form-group input::placeholder,.form-group textarea::placeholder{transition:opacity .25s ease,transform .25s ease}.form-group input:focus::placeholder,.form-group textarea:focus::placeholder{opacity:.5;transform:translate(4px)}.field-valid{animation:validPulse .3s ease}@keyframes validPulse{0%{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 6px #10b98133}to{box-shadow:0 0 0 4px #10b98126}}.field-invalid{animation:invalidShake .4s ease}@keyframes invalidShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}input[type=checkbox],input[type=radio]{transition:transform .15s ease}input[type=checkbox]:checked,input[type=radio]:checked{animation:checkPop .2s ease}@keyframes checkPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.animated-checkmark{display:inline-flex;align-items:center;justify-content:center}.animated-checkmark svg{width:52px;height:52px}.animated-checkmark .checkmark-circle{stroke:var(--success-color);stroke-width:2;fill:none;stroke-dasharray:166;stroke-dashoffset:166;animation:checkmarkCircle .6s cubic-bezier(.65,0,.45,1) forwards}.animated-checkmark .checkmark-check{stroke:var(--success-color);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:checkmarkDraw .3s cubic-bezier(.65,0,.45,1) .5s forwards}@keyframes checkmarkCircle{to{stroke-dashoffset:0}}@keyframes checkmarkDraw{to{stroke-dashoffset:0}}.animated-checkmark-filled{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--success-light);animation:checkmarkBgPop .4s cubic-bezier(.34,1.56,.64,1) forwards}.animated-checkmark-filled svg{width:32px;height:32px}.animated-checkmark-filled .checkmark-check{stroke:var(--success-color);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:24;stroke-dashoffset:24;animation:checkmarkDraw .25s cubic-bezier(.65,0,.45,1) .3s forwards}@keyframes checkmarkBgPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.animated-checkmark-sm{display:inline-flex;align-items:center;justify-content:center}.animated-checkmark-sm svg{width:20px;height:20px}.animated-checkmark-sm .checkmark-check{stroke:var(--success-color);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:16;stroke-dashoffset:16;animation:checkmarkDraw .2s cubic-bezier(.65,0,.45,1) forwards}.toast{animation:toastSlideIn .3s cubic-bezier(.34,1.56,.64,1) forwards}.toast.toast-exit{animation:toastSlideOut .25s ease forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.9)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
