*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}#root{width:100%;min-height:100vh}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{background:#fffffff2;border-radius:20px;width:100%;max-width:450px;padding:3rem;animation:.5s fadeIn;box-shadow:0 20px 60px #0000004d}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{margin-bottom:.5rem;font-size:4rem}.login-header h2{color:#667eea;margin-bottom:.5rem;font-size:2rem}.login-header p{color:#666;font-size:1rem}.login-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:#333;font-size:.95rem;font-weight:600}.form-group input{border:2px solid #e0e0e0;border-radius:10px;padding:.9rem;font-size:1rem;transition:all .3s}.form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:10px;margin-top:1rem;padding:1rem;font-size:1.1rem;font-weight:600;transition:all .3s}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-btn:active{transform:translateY(0)}.login-footer{text-align:center;color:#666;border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:1.5rem;font-size:.9rem}.login-footer strong{color:#667eea}.audio-card{background:#fffffff2;border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;transition:all .3s;display:flex;box-shadow:0 4px 12px #0000001a}.audio-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #00000026}.audio-icon{text-align:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px;padding:1rem;font-size:3rem}.audio-info{flex:1}.audio-name{color:#333;word-break:break-word;margin-bottom:.75rem;font-size:1.1rem;font-weight:600}.audio-meta{flex-wrap:wrap;gap:.75rem;display:flex}.meta-item{color:#666;background:#f3f4f6;border-radius:6px;padding:.4rem .8rem;font-size:.85rem}.download-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;width:100%;padding:.9rem;font-size:1rem;font-weight:600;transition:all .3s}.download-btn:hover{background:#5568d3;transform:scale(1.02)}.download-btn:active{transform:scale(.98)}.audio-list-container{width:100%}.list-header{background:#fffffff2;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;display:flex;box-shadow:0 4px 12px #0000001a}.list-header h2{color:#333;font-size:1.5rem;font-weight:700}.refresh-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;padding:.7rem 1.2rem;font-size:1rem;font-weight:600;transition:all .3s}.refresh-btn:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.empty-state{text-align:center;background:#fffffff2;border-radius:12px;padding:4rem 2rem;box-shadow:0 4px 12px #0000001a}.empty-state p{color:#666;margin-bottom:.5rem;font-size:1.2rem}.empty-hint{color:#999;font-size:.95rem}.audio-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}@media (width<=768px){.list-header{flex-direction:column;align-items:stretch;gap:1rem}.audio-grid{grid-template-columns:1fr}}.app{flex-direction:column;min-height:100vh;display:flex}.header{background:#fffffff2;justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex;box-shadow:0 2px 10px #0000001a}.header h1{color:#667eea;font-size:1.8rem;font-weight:700}.logout-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:.7rem 1.5rem;font-size:1rem;font-weight:600;transition:all .3s}.logout-btn:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.main-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:2rem}.loading,.error{text-align:center;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;padding:2rem;font-size:1.2rem}.error{background:#ef444433;border:2px solid #ef444466}
