*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:20px}.header{text-align:center;padding:40px 20px;color:#fff}.header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.header p{font-size:1.1rem;opacity:.9}.search-card{background:#fff;border-radius:20px;padding:30px;box-shadow:0 20px 60px #00000026;margin-bottom:30px}.search-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;align-items:end}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.9rem;color:#666;margin-bottom:8px;font-weight:500}.form-group input,.form-group select{padding:14px 16px;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;transition:all .3s ease;background:#fafafa}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.btn{padding:14px 28px;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover{background:#e0e0e0}.btn-danger{background:#ff6b6b;color:#fff}.btn-danger:hover{background:#ee5a5a}.btn-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-success:hover{transform:translateY(-2px);box-shadow:0 10px 30px #4caf5066}.btn-success:disabled{opacity:.6;cursor:not-allowed;transform:none}.results-section{margin-top:30px}.section-title{color:#fff;font-size:1.5rem;margin-bottom:10px;display:flex;align-items:center;gap:10px}.flight-count{font-size:.9rem;opacity:.8;font-weight:400}.route-info{color:#fffc;font-size:.95rem;margin-bottom:20px}.flights-grid{display:grid;gap:15px}.flight-card{background:#fff;border-radius:16px;padding:20px 25px;display:grid;grid-template-columns:1fr auto;gap:25px;align-items:center;box-shadow:0 4px 20px #00000014;transition:all .3s ease}.flight-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #0000001f}.flight-main{display:flex;align-items:center;gap:20px}.flight-departure,.flight-arrival{text-align:center;min-width:100px}.flight-departure .time,.flight-arrival .time{font-size:1.6rem;font-weight:700;color:#333}.flight-departure .airport-name,.flight-arrival .airport-name{font-size:.85rem;color:#667eea;margin-top:4px;font-weight:500}.flight-departure .city-name,.flight-arrival .city-name{font-size:.8rem;color:#999;margin-top:2px}.flight-route{flex:1;display:flex;flex-direction:column;align-items:center;padding:0 15px}.flight-route .airline-info{display:flex;align-items:center;gap:10px;margin-bottom:8px}.flight-route .airline-name{font-weight:600;color:#333;font-size:.95rem}.flight-route .flight-no{font-size:.85rem;color:#888;background:#f5f5f5;padding:2px 8px;border-radius:4px}.flight-route .route-line{width:100%;display:flex;flex-direction:column;align-items:center}.flight-route .duration{font-size:.8rem;color:#888;margin-bottom:6px}.flight-route .line{width:100%;height:2px;background:linear-gradient(90deg,#667eea,#764ba2);position:relative}.flight-route .line:before{content:"✈";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:0 10px;color:#667eea}.flight-route .aircraft{font-size:.75rem;color:#aaa;margin-top:6px}.flight-price{text-align:right;min-width:100px}.flight-price .current{font-size:1.8rem;font-weight:700;color:#ff6b6b}.flight-price .original{font-size:.9rem;color:#aaa;text-decoration:line-through}.flight-price .discount{display:inline-block;background:#fff3e0;color:#ff9800;padding:2px 8px;border-radius:10px;font-size:.8rem;margin-top:5px}.flight-price .source{font-size:.75rem;color:#ccc;margin-top:5px}.track-section{margin-top:30px}.track-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 10px 40px #0000001a}.track-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;align-items:end}.date-mode-group{grid-column:span 1}.date-mode-switch{display:flex;gap:8px}.mode-btn{flex:1;padding:12px 16px;border:2px solid #e0e0e0;background:#fafafa;border-radius:10px;font-size:.9rem;font-weight:500;color:#666;cursor:pointer;transition:all .3s ease}.mode-btn:hover{border-color:#667eea;color:#667eea}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:transparent;color:#fff}.track-info{flex:1}.detail-item{display:inline-flex;align-items:center;margin-right:15px}.days-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.tracks-list{margin-top:30px}.tracks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.tracks-header .section-title{margin-bottom:0}.track-item{background:#fff;border-radius:12px;padding:20px;margin-bottom:15px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 15px #00000014}.track-item .route{font-size:1.1rem;font-weight:600;color:#333}.track-item .details{font-size:.9rem;color:#888;margin-top:5px}.track-item .status{display:flex;align-items:center;gap:15px}.track-item .status-badge{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:500}.status-active{background:#e8f5e9;color:#4caf50}.loading{text-align:center;padding:60px 20px;color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;padding:60px 20px;color:#fff;background:#ffffff1a;border-radius:16px;margin-top:20px}.error-state .error-icon{font-size:4rem;margin-bottom:20px}.error-state h3{font-size:1.3rem;margin-bottom:10px}.error-state p{opacity:.9;max-width:400px;margin:0 auto}.empty-state{text-align:center;padding:60px 20px;color:#fff}.empty-state .icon{font-size:4rem;margin-bottom:20px}.empty-state h3{font-size:1.3rem;margin-bottom:10px}.empty-state p{opacity:.8}.toast{position:fixed;bottom:30px;right:30px;background:#333;color:#fff;padding:15px 25px;border-radius:12px;box-shadow:0 10px 30px #0003;animation:slideIn .3s ease;z-index:1000}.toast.success{background:#4caf50}.toast.error{background:#ff6b6b}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.header-title{text-align:left}.header-auth{flex-shrink:0}.user-info{display:flex;align-items:center;gap:15px}.username{color:#fff;font-weight:500}.btn-outline{background:transparent;border:2px solid rgba(255,255,255,.5);color:#fff}.btn-outline:hover{background:#ffffff1a;border-color:#fff}.btn-full{width:100%}.link-btn{background:none;border:none;color:#667eea;cursor:pointer;font-size:inherit;font-weight:600;padding:0}.link-btn:hover{text-decoration:underline}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:20px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:modalIn .3s ease}@keyframes modalIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #eee}.modal-header h2{font-size:1.3rem;color:#333}.modal-close{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#333}.auth-form{padding:25px}.auth-form .form-group{margin-bottom:20px}.auth-switch{text-align:center;margin-top:20px;color:#666;font-size:.9rem}.auth-notice{background:#fff3e0;border-radius:10px;padding:15px;margin-bottom:20px;text-align:center}.auth-notice p{color:#e65100;font-size:.95rem}.form-group input:disabled,.form-group select:disabled,.mode-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.header-content{flex-direction:column;text-align:center}.header-title{text-align:center}.header h1{font-size:1.8rem}.search-form{grid-template-columns:1fr}.flight-card{grid-template-columns:1fr;text-align:center}.flight-main{flex-direction:column;gap:15px}.flight-departure,.flight-arrival{min-width:auto}.flight-route{padding:10px 0;width:100%}.flight-price{text-align:center;margin-top:15px;min-width:auto}.track-item{flex-direction:column;text-align:center;gap:15px}}
