*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}a{color:inherit}a,a:hover{text-decoration:none}.page-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.container{max-width:1200px;margin:0 auto;background:#fff;border-radius:15px;box-shadow:0 20px 40px rgba(0,0,0,.1);overflow:hidden}.header{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;padding:30px;text-align:center}.header h1{font-size:2.5rem;margin-bottom:10px;color:#333}.header p{font-size:1.1rem;opacity:.9;margin-bottom:15px}.content{padding:40px}.nav-links{margin-top:15px}.setup-link{display:inline-block;background:linear-gradient(135deg,#28a745,#20c997);padding:10px 20px;border-radius:25px;font-weight:600;font-size:.9em;transition:all .3s ease;box-shadow:0 4px 15px rgba(40,167,69,.3)}.setup-link,.setup-link:hover{color:#fff;text-decoration:none}.setup-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(40,167,69,.4)}.link{color:#007bff;text-decoration:none;font-weight:600}.link:hover{text-decoration:underline}.upload-section{background:#f8f9fa;border-radius:10px;padding:30px;margin-bottom:40px;border:2px dashed #dee2e6;transition:all .3s ease}.upload-section:hover{border-color:#4facfe;background:#f0f8ff}.upload-form{text-align:center}.file-input-wrapper{position:relative;display:inline-block;margin-bottom:20px}.file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.file-input-label{display:inline-block;padding:15px 30px;background:#4facfe;color:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:1.1rem}.file-input-label:hover{background:#3a8bfd;transform:translateY(-2px)}.selected-file{margin:15px 0;padding:10px;background:#e9ecef;border-radius:5px;font-style:italic}.auto-delete-simple{text-align:center;margin-bottom:20px;padding:10px;background:#f8f9fa;border-radius:5px;border-left:4px solid #ffc107}.auto-delete-text{font-size:.9rem;color:#495057}.status.enabled{color:#28a745;font-weight:600}.status.disabled{color:#dc3545;font-weight:600}.btn{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;padding:15px 30px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;width:100%}.btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px rgba(0,123,255,.3)}.btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.upload-btn{background:#28a745;color:#fff;border:none;padding:15px 40px;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .3s ease;margin-left:15px}.upload-btn:hover{background:#218838;transform:translateY(-2px)}.upload-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none}.download-btn{background:#17a2b8;color:#fff;border:none;padding:8px 16px;border-radius:5px;cursor:pointer;font-size:.9rem;transition:all .3s ease;margin-right:8px}.download-btn:hover{background:#138496;transform:translateY(-1px)}.copy-btn{background:#ffc107;color:#212529;border:none;padding:8px 16px;border-radius:5px;cursor:pointer;font-size:.9rem;transition:all .3s ease;margin:0 4px}.copy-btn:hover{background:#e0a800;transform:translateY(-1px)}.oauth2callback .copy-btn{background:#28a745;color:#fff;font-size:.8em;padding:8px 12px}.oauth2callback .copy-btn:hover{background:#218838}.delete-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:5px;cursor:pointer;font-size:.9rem;transition:all .3s ease;margin:0 4px}.delete-btn:hover{background:#c82333;transform:translateY(-1px)}.retry-btn{background:#dc3545;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:1em;transition:background .3s ease}.retry-btn:hover{background:#c82333}.home-btn{background:#007bff;color:#fff;border:none;padding:15px 30px;border-radius:8px;cursor:pointer;font-size:1em;transition:background .3s ease}.home-btn:hover{background:#0056b3}.files-section h2{color:#333;margin-bottom:20px;font-size:1.8rem}.files-table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 5px 15px rgba(0,0,0,.1)}.files-table th{background:#4facfe;color:#fff;padding:15px;text-align:left;font-weight:600}.files-table td{padding:15px;border-bottom:1px solid #dee2e6}.files-table tr:hover{background:#f8f9fa}.actions-cell{white-space:nowrap}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333}.form-group input{width:100%;padding:12px 15px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#007bff}.step{background:#f8f9fa;border-radius:10px;padding:20px;margin-top:10px;border-left:4px solid #007bff}.step,.step h3{margin-bottom:10px}.step h3{color:#007bff;font-size:1.2em}.step ul{margin-left:20px;color:#555}.step li{margin-bottom:5px}.instructions{margin-top:25px;padding:20px;background:#f8f9fa;border-radius:8px}.instructions h4{color:#333;margin-bottom:15px}.instructions ol{margin-left:20px;color:#555}.instructions li{margin-bottom:8px}.loading{font-size:1.1rem}.loading,.no-files{text-align:center;padding:40px;color:#666}.no-files{font-style:italic}.success{background:#d4edda;border:1px solid #c3e6cb;border-radius:10px;padding:30px;margin-bottom:20px}.success h3{color:#155724;margin-bottom:15px;font-size:1.5em}.error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:10px;padding:30px;margin-bottom:20px;text-align:center}.error h3{color:#721c24;margin-bottom:15px;font-size:1.5em}.error p{color:#721c24;margin-bottom:20px}.result{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;padding:20px;margin-top:20px}.result h3{color:#155724;margin-bottom:15px}.result ol{margin-left:20px;color:#155724}.result li{margin-bottom:5px}.spinner{border:4px solid #f3f3f3;border-top-color:#007bff;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 10px}.oauth2callback .spinner{width:50px;height:50px;margin:0 auto 20px}.token-section{margin:20px 0}.token-item{margin-bottom:20px}.token-item label{display:block;font-weight:600;color:#155724;margin-bottom:8px}.token-value{display:flex;align-items:center;gap:10px}.token-value code{flex:1 1;background:#f8f9fa;padding:10px;border-radius:5px;font-family:Courier New,monospace;word-break:break-all;font-size:.9em}.actions{text-align:center;margin-top:30px}code{background:#f1f3f4;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace}.toast{position:fixed;top:20px;right:20px;padding:15px 20px;border-radius:8px;color:#fff;font-weight:600;z-index:1000;animation:slideIn .3s ease-out;box-shadow:0 4px 12px rgba(0,0,0,.15)}.toast-success{background:linear-gradient(135deg,#28a745,#20c997)}.toast-error{background:linear-gradient(135deg,#dc3545,#e74c3c)}.toast-info{background:linear-gradient(135deg,#17a2b8,#20c997)}@keyframes slideIn{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.setup .container{max-width:800px;padding:0;background:#fff;border-radius:20px;box-shadow:0 25px 50px rgba(0,0,0,.15);overflow:hidden}.setup .header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px;text-align:center;position:relative}.setup .header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="%23ffffff" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>') repeat;opacity:.3}.setup .header>*{position:relative;z-index:1}.setup-icon{font-size:3rem;margin-bottom:15px;display:block}.setup .header h1{font-size:2.5rem;margin-bottom:10px;font-weight:700;color:#fff}.setup .header p{font-size:1.1rem;opacity:.9;margin:0}.setup-progress{padding:30px 40px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;margin-bottom:20px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .5s ease}.progress-steps{justify-content:space-between}.progress-step,.progress-steps{display:flex;align-items:center}.progress-step{width:40px;height:40px;border-radius:50%;background:#e9ecef;color:#6c757d;justify-content:center;font-weight:600;font-size:1rem;transition:all .3s ease}.progress-step.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:scale(1.1);box-shadow:0 4px 15px rgba(102,126,234,.3)}.setup-content{padding:40px}.setup-step-card{background:#fff;border:1px solid #e9ecef;border-radius:15px;margin-bottom:25px;overflow:hidden;transition:all .3s ease;box-shadow:0 5px 15px rgba(0,0,0,.08)}.setup-step-card:hover{transform:translateY(-2px);box-shadow:0 10px 25px rgba(0,0,0,.12)}.setup-step-card.success-card{border-color:#28a745;background:linear-gradient(135deg,#d4edda,#c3e6cb)}.step-header{padding:25px 30px;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;align-items:center;gap:20px}.success-card .step-header{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.step-icon{font-size:2.5rem;width:60px;height:60px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(0,0,0,.1)}.step-icon.success{background:#fff;color:#28a745}.step-header h3{margin:0 0 5px;font-size:1.4rem;color:#2d3436}.success-card .step-header h3{color:#fff}.step-header p{margin:0;color:#6c757d;font-size:.95rem}.success-card .step-header p{color:hsla(0,0%,100%,.9)}.step-content{padding:30px}.instruction-list{display:flex;flex-direction:column;gap:25px}.instruction-item{display:flex;align-items:flex-start;gap:20px;padding:20px;background:#f8f9fa;border-radius:12px;border-left:4px solid #667eea}.instruction-number{width:30px;height:30px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.instruction-item strong{display:block;margin-bottom:5px;color:#2d3436;font-size:1.05rem}.instruction-item p{margin:0;color:#636e72;line-height:1.5}.external-link{color:#667eea;text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:5px;transition:all .3s ease}.external-link:hover{color:#5a67d8;text-decoration:underline}.external-link span{font-size:.8rem}.highlight{background:#fff3cd;color:#856404;padding:2px 6px}.code-snippet,.highlight{border-radius:4px;font-weight:600}.code-snippet{background:#2d3436;color:#00b894;padding:4px 8px;font-family:Courier New,monospace;font-size:.9rem}.api-enable-card{justify-content:space-between;padding:25px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:2px solid #e9ecef}.api-enable-card,.api-info{display:flex;align-items:center}.api-info{gap:15px}.api-icon{font-size:2rem;width:50px;height:50px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(0,0,0,.1)}.api-info strong{display:block;margin-bottom:5px;color:#2d3436;font-size:1.1rem}.api-info p{margin:0;color:#6c757d;font-size:.9rem}.enable-btn{background:linear-gradient(135deg,#00b894,#00cec9);padding:12px 24px;border-radius:25px;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;box-shadow:0 4px 15px rgba(0,184,148,.3)}.enable-btn,.enable-btn:hover{color:#fff;text-decoration:none}.enable-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,184,148,.4)}.oauth-form{gap:25px}.form-group,.form-row,.oauth-form{display:flex;flex-direction:column}.form-group label{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-weight:600;color:#2d3436;font-size:1rem}.label-icon{font-size:1.2rem}.form-input{padding:15px 20px;border:2px solid #e9ecef;border-radius:12px;font-size:1rem;transition:all .3s ease;background:#fff}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1);transform:translateY(-1px)}.form-input::placeholder{color:#adb5bd}.auth-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:18px 30px;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 6px 20px rgba(102,126,234,.3)}.auth-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px rgba(102,126,234,.4)}.auth-btn:disabled{background:#adb5bd;cursor:not-allowed;transform:none;box-shadow:none}.btn-icon{font-size:1.2rem}.btn-spinner{width:20px;height:20px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.alert{display:flex;align-items:flex-start;gap:15px;padding:20px;border-radius:12px;margin-bottom:25px}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-icon{font-size:1.5rem;flex-shrink:0}.alert-content strong{display:block;margin-bottom:5px;font-size:1.05rem}.alert-content p{margin:0;line-height:1.5}.success-message{text-align:center}.success-message>p{font-size:1.1rem;margin-bottom:25px;color:#2d3436}.auth-instructions{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.auth-step{gap:15px;padding:15px 20px;background:#fff;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.1)}.auth-step,.auth-step-number{display:flex;align-items:center}.auth-step-number{width:30px;height:30px;border-radius:50%;background:#28a745;color:#fff;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.final-note{display:flex;align-items:center;gap:15px;padding:20px;background:hsla(0,0%,100%,.8);border-radius:10px;border:2px dashed #28a745}.note-icon{font-size:1.5rem;flex-shrink:0}.final-note p{margin:0;color:#2d3436;font-size:1rem}.setup-footer{padding:30px 40px;background:#f8f9fa;border-top:1px solid #e9ecef;text-align:center}.back-home-link{gap:10px;background:linear-gradient(135deg,#6c757d,#495057);font-size:1rem;box-shadow:0 4px 15px hsla(208,7%,46%,.3)}.back-home-link:hover{box-shadow:0 6px 20px hsla(208,7%,46%,.4);background:linear-gradient(135deg,#5a6268,#3d4043)}@media (max-width:768px){.setup .container{max-width:95%;margin:10px}.setup .header{padding:30px 20px}.setup .header h1{font-size:2rem}.setup-progress{padding:20px}.progress-step{width:35px;height:35px;font-size:.9rem}.setup-content{padding:20px}.step-header{padding:20px;flex-direction:column;text-align:center;gap:15px}.step-icon{font-size:2rem;width:50px;height:50px}.step-content{padding:20px}.instruction-item{gap:15px}.api-enable-card,.instruction-item{flex-direction:column;text-align:center}.api-enable-card{gap:20px}.auth-step,.final-note{flex-direction:column;gap:10px;text-align:center}.setup-footer{padding:20px}}.oauth2callback .container{max-width:700px;padding:40px}.oauth2callback .header h1{font-size:2.5em}.guide .container{max-width:1000px}.guide .header{background:linear-gradient(135deg,#6c5ce7,#a29bfe)}.tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #dee2e6}.tab{flex:1 1;padding:15px 20px;background:none;cursor:pointer;font-size:1rem;font-weight:600;color:#6c757d;transition:all .3s ease;border:none;border-bottom:3px solid transparent}.tab:hover{background:#e9ecef;color:#495057}.tab.active{background:#fff;color:#6c5ce7;border-bottom-color:#6c5ce7}.tab-content{padding:40px}.section h2{color:#2d3436;margin-bottom:20px;font-size:1.8rem;border-bottom:2px solid #6c5ce7;padding-bottom:10px}.section h3{color:#636e72;margin:25px 0 15px;font-size:1.3rem}.section ul{margin:15px 0;padding-left:25px}.section li{margin-bottom:8px;line-height:1.6}.code-block{background:#2d3436;color:#ddd;padding:20px;border-radius:8px;margin:15px 0;overflow-x:auto;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5}.code-block pre{margin:0;white-space:pre-wrap}.api-endpoints{margin:30px 0}.api-endpoint{background:#f8f9fa;border:1px solid #dee2e6;border-radius:10px;margin-bottom:25px;overflow:hidden}.endpoint-header{background:#e9ecef;padding:15px 20px;display:flex;align-items:center;gap:15px}.method{padding:5px 12px;border-radius:20px;font-size:.8rem;font-weight:700;text-transform:uppercase;color:#fff}.method-get{background:#28a745}.method-post{background:#007bff}.method-delete{background:#dc3545}.endpoint-path{font-family:Courier New,monospace;background:#2d3436;color:#ddd;padding:8px 12px;border-radius:5px;font-size:.9rem}.endpoint-description{padding:15px 20px;margin:0;color:#6c757d;font-style:italic}.endpoint-details{padding:0 20px 20px}.endpoint-details h4{color:#495057;margin:20px 0 10px;font-size:1rem}.error-codes{background:#fff3cd;border:1px solid #ffeaa7;border-radius:10px;padding:20px;margin:30px 0}.error-codes h3{color:#856404;margin-top:0}.error-codes ul{margin:15px 0;padding-left:25px}.error-codes li{margin-bottom:8px;color:#856404}.example{margin-bottom:30px}.example h3{color:#6c5ce7;margin-bottom:15px}.tips{background:#e8f5e8;border:1px solid #c3e6cb;border-radius:10px;padding:20px;margin:30px 0}.tips h3{color:#155724;margin-top:0}.tips ul{margin:15px 0;padding-left:25px}.tips li{margin-bottom:8px;color:#155724;line-height:1.6}.back-home-link{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;text-decoration:none;padding:12px 24px;border-radius:25px;font-weight:600;font-size:.95rem;transition:all .3s ease;box-shadow:0 4px 15px rgba(108,92,231,.3);border:2px solid transparent}.back-home-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(108,92,231,.4);text-decoration:none;color:#fff;background:linear-gradient(135deg,#5a4fcf,#8b7ff7)}.back-home-link:active{transform:translateY(0);box-shadow:0 2px 10px rgba(108,92,231,.3)}@media (max-width:768px){.tabs{flex-direction:column}.tab{border-bottom:1px solid #dee2e6;border-right:none}.tab.active{border-bottom-color:#dee2e6;border-left:3px solid #6c5ce7}.endpoint-header{flex-direction:column;align-items:flex-start;gap:10px}.code-block{font-size:.8rem;padding:15px}.back-home-link{font-size:.9rem;padding:10px 20px}}