body{margin:0;padding:0}.sidebar{position:fixed;left:0;top:64px;width:280px;height:calc(100vh - 64px);background:#1a1a2ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);padding:1.5rem 0;overflow-y:auto;z-index:90;transition:transform .3s ease}.sidebar-header{padding:0 1.5rem 1rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.sidebar-title{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.sidebar-close{display:none;background:transparent;border:none;color:#a0a0b0;font-size:1.5rem;cursor:pointer;width:32px;height:32px;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.sidebar-close:hover{background:#ffffff1a;color:#fff}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:89}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;padding:0 1rem}.sidebar-link{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:10px;text-decoration:none;color:#fff;transition:all .3s ease;cursor:pointer}.sidebar-link:hover{background:#ffffff14;border-color:#667eea4d;transform:translate(4px)}.sidebar-link-content{display:flex;align-items:center;gap:.875rem;flex:1}.sidebar-icon{font-size:1.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.sidebar-name{font-size:1rem;font-weight:600}.sidebar-divider{height:1px;background:#ffffff1a;margin:1rem 0}.admin-link{border:1px solid rgba(102,126,234,.3);background:#667eea1a}.admin-link:hover{background:#667eea33;border-color:#667eea80}.admin-badge{padding:.25rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;font-size:.75rem;font-weight:600;color:#fff}.sidebar-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:all .3s ease}.sidebar-status-dot.online{background-color:#4ade80;box-shadow:0 0 8px #4ade80;animation:pulse 2s infinite}.sidebar-status-dot.offline{background-color:#ef4444;box-shadow:0 0 8px #ef4444}.sidebar-status-dot.checking{background-color:#fbbf24;box-shadow:0 0 8px #fbbf24;animation:pulse 1.5s infinite}.sidebar-status-dot.unknown{background-color:#9ca3af;box-shadow:0 0 8px #9ca3af}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff0d}.sidebar::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#667eea80}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close{display:flex}.sidebar-overlay{display:block}}@media(max-width:768px){.sidebar{width:100%;max-width:320px;box-shadow:4px 0 12px #0000004d}}.login-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal{background:#1e1e32f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2.5rem;width:90%;max-width:420px;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.close-button{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#a0a0b0;font-size:1.5rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.close-button:hover{background:#ffffff1a;color:#fff}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem}.login-subtitle{color:#a0a0b0;font-size:.95rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.google-login-container{display:flex;justify-content:center;align-items:center;padding:1rem 0}.login-info{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.info-text{text-align:center;color:#a0a0b0;font-size:.875rem;margin:0;line-height:1.5}.access-denied-message{text-align:center;padding:1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;margin-bottom:1rem}.denied-icon{font-size:3rem;display:block;margin-bottom:.5rem}.access-denied-message h3{color:#ef4444;font-size:1.25rem;margin:0 0 .5rem}.access-denied-message p{color:#fca5a5;font-size:.875rem;margin:0;word-break:break-word}.request-access-button{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.request-access-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.request-access-button:active:not(:disabled){transform:translateY(0)}.request-access-button:disabled{opacity:.6;cursor:not-allowed}.success-message{padding:1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:10px;color:#22c55e;font-size:.875rem;text-align:center;margin-bottom:1rem;line-height:1.5}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:#e0e0e0}.form-input{padding:.875rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.95rem;transition:all .3s ease}.form-input:focus{outline:none;background:#ffffff14;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input::placeholder{color:#606080}.error-message{padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.875rem;text-align:center;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.login-submit-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.5rem}.login-submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-submit-button:active:not(:disabled){transform:translateY(0)}.login-submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.login-modal{padding:2rem 1.5rem}.login-header h2{font-size:1.5rem}}.name-input-group{margin-bottom:1.25rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.torrent-list-container{margin-top:2rem;width:100%}.torrent-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.torrent-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.torrent-update{font-size:.875rem;color:#7070a0}.remove-completed-button{padding:.5rem 1rem;background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease}.remove-completed-button:hover:not(:disabled){background:#ef44444d;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.remove-completed-button:disabled{opacity:.5;cursor:not-allowed}.torrent-error,.torrent-loading,.torrent-empty{text-align:center;padding:2rem;background:#ffffff0d;border-radius:12px;color:#a0a0b0}.torrent-list{display:flex;flex-direction:column;gap:1rem}.torrent-item{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;transition:all .3s ease}.torrent-item:hover{background:#ffffff14;border-color:#667eea4d}.torrent-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.torrent-name{flex:1;font-size:.95rem;font-weight:500;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.torrent-state{display:flex;align-items:center;gap:.375rem;font-size:.875rem;padding:.25rem .75rem;border-radius:6px;white-space:nowrap}.torrent-state.downloading{background:#3b82f633;color:#3b82f6}.torrent-state.seeding{background:#22c55e33;color:#22c55e}.torrent-state.stalled{background:#fbbf2433;color:#fbbf24}.torrent-state.paused{background:#9ca3af33;color:#9ca3af}.torrent-state-icon{font-size:1rem}.torrent-state-text{font-weight:500}.torrent-progress-bar{position:relative;height:24px;background:#ffffff0d;border-radius:8px;overflow:hidden;margin-bottom:.75rem}.torrent-progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.torrent-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.8rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);z-index:1}.torrent-stats{display:flex;flex-wrap:wrap;gap:1rem}.torrent-stat{display:flex;align-items:center;gap:.375rem;font-size:.875rem}.stat-label{color:#a0a0b0;font-weight:500}.stat-value{color:#fff;font-weight:600}@media(max-width:768px){.torrent-header{flex-direction:column;align-items:flex-start;gap:.5rem}.torrent-item-header{flex-direction:column;gap:.5rem}.torrent-stats{gap:.75rem}.torrent-stat{flex:1 1 calc(50% - .375rem);min-width:120px}}.storage-info-container{margin-top:2rem;width:100%}.storage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.storage-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.header-controls{display:flex;align-items:center;gap:1rem}.storage-update{font-size:.875rem;color:#7070a0}.refresh-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.refresh-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.refresh-button:active:not(:disabled){transform:translateY(0)}.refresh-button:disabled{opacity:.6;cursor:not-allowed;background:linear-gradient(135deg,#a0a0c0,#c0a0d0)}.storage-error,.storage-loading{text-align:center;padding:2rem;background:#ffffff0d;border-radius:12px;color:#a0a0b0}.storage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.storage-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;transition:all .3s ease}.storage-card-wide{grid-column:1 / -1}.storage-card:hover{background:#ffffff14;border-color:#667eea4d}.storage-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.05)}.storage-icon{font-size:1.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.storage-card-title{font-size:1.1rem;font-weight:600;color:#fff;margin:0}.storage-card-content{display:flex;flex-direction:column;gap:.875rem}.storage-stat{display:flex;justify-content:space-between;align-items:center;gap:1rem}.stat-label{font-size:.9rem;color:#a0a0b0;font-weight:500}.stat-value{font-size:.95rem;color:#fff;font-weight:600;text-align:right;word-break:break-word}.storage-id{font-family:Courier New,monospace;font-size:.85rem;color:#667eea}.storage-progress-container{margin-bottom:1.5rem}.storage-progress-bar{height:32px;background:#ffffff1a;border-radius:8px;overflow:hidden;position:relative;margin-top:.5rem}.storage-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:8px;position:relative}.storage-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.9rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);z-index:1}.storage-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.storage-progress-fill.warning{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.storage-progress-fill.critical{background:linear-gradient(90deg,#ef4444,#dc2626)}.storage-note{grid-column:1 / -1;background:#667eea1a;border-color:#667eea4d}.storage-note-text{margin:0;font-size:.9rem;color:#a0a0b0;text-align:center;line-height:1.5}@media(max-width:768px){.storage-header{flex-direction:column;align-items:flex-start;gap:.5rem}.header-controls{width:100%;justify-content:space-between;margin-top:.5rem}.storage-grid{grid-template-columns:1fr}.storage-card{padding:1rem}}.admin-panel{background:#1e1e3299;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;margin-bottom:2rem}.admin-panel h2{margin:0 0 1.5rem;font-size:1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-tabs{display:flex;gap:1rem;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.tab-button{padding:.75rem 1.5rem;background:transparent;border:none;color:#a0a0b0;font-size:1rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .3s ease}.tab-button:hover{color:#e0e0e0}.tab-button.active{color:#667eea;border-bottom-color:#667eea}.admin-section{min-height:200px}.empty-message{text-align:center;color:#a0a0b0;padding:2rem;font-size:.95rem}.requests-list,.users-list{display:flex;flex-direction:column;gap:1rem}.request-card,.user-card{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;transition:all .3s ease}.request-card:hover,.user-card:hover{background:#ffffff14;border-color:#fff3}.request-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.1)}.request-name{font-weight:600;color:#e0e0e0;margin-bottom:.25rem}.request-email,.user-email{color:#a0a0b0;font-size:.9rem}.request-time,.user-time{color:gray;font-size:.85rem;margin-top:.25rem}.request-actions{display:flex;gap:.75rem}.approve-button,.deny-button,.revoke-button{padding:.5rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.approve-button{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.approve-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.deny-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.deny-button:hover{background:#ef44444d;transform:translateY(-2px)}.revoke-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.revoke-button:hover{background:#ef44444d;transform:translateY(-2px)}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-email{font-weight:600;color:#e0e0e0}@media(max-width:768px){.request-card,.user-card{flex-direction:column;align-items:flex-start;gap:1rem}.request-actions{width:100%}.approve-button,.deny-button,.revoke-button{flex:1}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#fff;margin:0;padding:0}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}.navbar{position:sticky;top:0;z-index:100;background:#1a1a2ee6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);padding:1rem 0}.nav-container{width:100%;padding:0 1.5rem;display:flex;align-items:center;gap:1rem}.hamburger-button{display:none;flex-direction:column;justify-content:space-around;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:4px;z-index:10}.hamburger-line{width:100%;height:3px;background:#fff;border-radius:2px;transition:all .3s ease}.nav-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;flex:1}.nav-actions{display:flex;gap:.75rem}.nav-button{padding:.5rem 1.25rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;background:#ffffff0d;color:#fff}.nav-button.login{background:linear-gradient(135deg,#667eea,#764ba2);border:none}.nav-button.login:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.nav-button.logout:hover{background:#ffffff1a;border-color:#ffffff4d}.main-content{margin-left:280px;min-height:calc(100vh - 64px);padding-top:64px;transition:margin-left .3s ease}.content-container{max-width:1400px;width:100%;margin:0 auto;padding:2rem}header{text-align:center;margin-bottom:3rem}h1{font-size:3rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.subtitle{font-size:1.2rem;color:#a0a0b0;font-weight:300}.last-update{font-size:.875rem;color:#7070a0;margin-top:.5rem}footer{text-align:center;margin-top:3rem;color:#7070a0;font-size:.9rem}footer a{color:#667eea;text-decoration:none;transition:color .3s ease}footer a:hover{color:#764ba2}@media(max-width:1024px){.hamburger-button{display:flex}.main-content{margin-left:0}}@media(max-width:768px){.nav-title{font-size:1.25rem}.nav-container{padding:0 1rem}.content-container{padding:1.5rem 1rem}h1{font-size:2rem}.subtitle{font-size:1rem}}.hero-gradient{position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(102,126,234,.1) 0%,transparent 50%);pointer-events:none;z-index:-1}
