.app{display:flex;flex-direction:column;min-height:100vh;background:#0f0f0f}.header{background:#1a1a1a;border-bottom:1px solid #333;padding:1rem 0;position:sticky;top:0;z-index:100}.header-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:600;margin:0;color:#e0e0e0;text-decoration:none;transition:color .2s}.logo:hover{color:#4caf50}.header-actions{display:flex;align-items:center;gap:1rem}.admin-link{padding:.5rem 1rem;background:transparent;border:1px solid #4caf50;border-radius:4px;font-size:.9rem;font-weight:600;color:#4caf50;text-decoration:none;transition:all .2s ease;display:flex;align-items:center;gap:.25rem}.admin-link:hover{background:#4caf501a}.logout-btn{padding:.5rem 1rem;background:transparent;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease;color:#e0e0e0}.logout-btn:hover{background:#2a2a2a;border-color:#666}.home-page{flex:1;padding:2rem 1rem;background:#0f0f0f}.container{max-width:1200px;margin:0 auto}.error-banner{background:#4a1a1a;border:1px solid #8b3a3a;border-radius:6px;padding:1rem;color:#ff6b6b;margin-bottom:2rem;font-weight:500;display:flex;justify-content:space-between;align-items:center;gap:1rem}.error-banner-close{background:none;border:none;color:#ff6b6b;cursor:pointer;padding:.25rem;font-size:1.2rem;opacity:.8;transition:opacity .2s;flex-shrink:0}.error-banner-close:hover{opacity:1}.login-prompt-box{background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:3rem 2rem;text-align:center;box-shadow:0 1px 3px #0000004d;margin-top:2rem}.login-prompt-box h2{color:#e0e0e0;margin-bottom:1rem;font-size:1.5rem}.login-prompt-box p{color:#999;margin-bottom:2rem;line-height:1.6}.login-prompt-btn{padding:1rem 2rem;background:#333;color:#e0e0e0;border:1px solid #555;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.login-prompt-btn:hover{background:#444;border-color:#666}.anonymous-limits-info{background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:2rem;margin-top:2rem;box-shadow:0 1px 3px #0000004d}.anonymous-limits-info h2{color:#e0e0e0;margin-bottom:1.5rem;font-size:1.3rem}.limits-display{display:flex;flex-direction:column;gap:1rem}.limits-display .limit-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#0f0f0f;border:1px solid #2a2a2a;border-radius:6px}.limits-display .limit-label{color:#999;font-size:.95rem}.limits-display .limit-value{color:#e0e0e0;font-weight:600;font-size:1rem}@media (max-width: 640px){.home-page{padding:1rem}.login-prompt-box{padding:2rem 1.5rem}.anonymous-limits-info{padding:1.5rem}.limits-display .limit-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.upload-section{background:#1a1a1a;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000004d;border:1px solid #333}.upload-success{background:#1a4d2e;border:1px solid #2d7a4a;border-radius:6px;padding:1.5rem;margin-bottom:1.5rem;color:#4caf50}.success-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.success-icon{font-size:1.5rem}.success-title{font-size:1.1rem;font-weight:600;color:#4caf50}.success-content{display:flex;flex-direction:column;gap:1rem}.file-link-container{display:flex;flex-direction:column;gap:.5rem}.file-link-label{font-size:.9rem;font-weight:500;color:#81c784}.file-link-row{display:flex;gap:.5rem}.file-link-input{flex:1;padding:.75rem;background:#0f0f0f;border:1px solid #2d7a4a;border-radius:4px;color:#e0e0e0;font-size:.9rem;font-family:monospace;cursor:text}.file-link-input:focus{outline:none;border-color:#4caf50}.copy-button{padding:.75rem 1.25rem;background:#2d7a4a;color:#e0e0e0;border:1px solid #4caf50;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.copy-button:hover{background:#3a8f5a}.success-actions{display:flex;gap:.75rem;flex-wrap:wrap}.view-button,.new-upload-button{padding:.75rem 1.5rem;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;border:none;display:inline-flex;align-items:center;gap:.5rem}.view-button{background:#2d7a4a;color:#e0e0e0;border:1px solid #4caf50}.view-button:hover{background:#3a8f5a}.new-upload-button{background:transparent;color:#81c784;border:1px solid #2d7a4a}.new-upload-button:hover{background:#4caf501a}.anonymous-warning{margin:0;padding:.75rem;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:4px;color:#ffc107;font-size:.85rem;line-height:1.4}.upload-error{background:#4d1a1a;border:1px solid #7a2d2d;border-radius:6px;padding:1rem;margin-bottom:1.5rem;color:#ef4444;display:flex;align-items:center;gap:.75rem}.upload-error .error-icon{font-size:1.2rem;flex-shrink:0}.upload-error .error-dismiss{margin-left:auto;background:none;border:none;color:#ef4444;cursor:pointer;padding:.25rem;opacity:.8;font-size:1.2rem;transition:opacity .2s}.upload-error .error-dismiss:hover{opacity:1}.upload-area{border:2px dashed #444;border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#0f0f0f;min-height:200px;display:flex;align-items:center;justify-content:center}.upload-area:hover{border-color:#666;background:#161616}.upload-area.active{border-color:#888;background:#1a1a1a}.upload-area.uploading{cursor:not-allowed;opacity:.6}.upload-content{pointer-events:none}.upload-icon{font-size:3rem;display:block;margin-bottom:1rem}.upload-text{font-size:1.1rem;font-weight:500;margin-bottom:.5rem;color:#e0e0e0}.upload-subtext{color:#888;font-size:.9rem}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#e0e0e0;border-radius:50%;animation:spin .8s linear infinite}.upload-options{margin-top:1.5rem;display:flex;gap:1rem;flex-wrap:wrap}.option-group{display:flex;flex-direction:column;gap:.75rem;flex:1;min-width:300px}.option-group label{font-size:.9rem;font-weight:500;color:#e0e0e0}.expiration-tabs{display:flex;gap:.5rem;border-bottom:1px solid #444}.expiration-tab{padding:.5rem 1rem;background:none;border:none;border-bottom:2px solid transparent;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:-1px}.expiration-tab:hover:not(:disabled){color:#e0e0e0}.expiration-tab.active{color:#e0e0e0;border-bottom-color:#4caf50}.expiration-tab:disabled{opacity:.5;cursor:not-allowed}.expiration-select{padding:.6rem;border:1px solid #444;border-radius:4px;font-size:.9rem;background:#0f0f0f;color:#e0e0e0;cursor:pointer;transition:border-color .2s ease}.expiration-select:hover{border-color:#666}.expiration-select:focus{outline:none;border-color:#888;box-shadow:0 0 0 2px #8888881a}.expiration-select:disabled{opacity:.6;cursor:not-allowed}.custom-date-picker{display:flex;flex-direction:column;gap:.75rem}.date-time-inputs{display:flex;gap:.75rem}.date-input,.time-input{padding:.6rem;border:1px solid #444;border-radius:4px;background:#0f0f0f;color:#e0e0e0;font-size:.9rem;transition:border-color .2s ease}.date-input{flex:1}.time-input{width:120px}.date-input:focus,.time-input:focus{outline:none;border-color:#888}.date-input:disabled,.time-input:disabled{opacity:.6;cursor:not-allowed}.custom-timespan-picker{display:flex;flex-direction:column;gap:.75rem}.timespan-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.75rem}.timespan-field{display:flex;flex-direction:column;gap:.4rem}.timespan-label{font-size:.8rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px}.timespan-input{padding:.6rem;border:1px solid #444;border-radius:4px;background:#0f0f0f;color:#e0e0e0;font-size:.95rem;font-weight:500;text-align:center;transition:border-color .2s ease}.timespan-input:focus{outline:none;border-color:#888}.timespan-input:disabled{opacity:.6;cursor:not-allowed}.timespan-input.invalid{border-color:#ef4444;background:#ef44440d}.timespan-input.invalid:focus{border-color:#ef4444;box-shadow:0 0 0 2px #ef444433}.timespan-input::-webkit-outer-spin-button,.timespan-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.timespan-input[type=number]{-moz-appearance:textfield}.expiry-limit-notice{background:#2196f30d;border:1px solid rgba(33,150,243,.2);border-radius:4px;padding:.5rem .75rem;display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#64b5f6}.notice-icon{font-size:1rem;flex-shrink:0}.expiry-limit-notice.error{background:#ef44440d;border-color:#ef44444d;color:#ef4444;font-weight:600}.expiration-preview{background:#4caf500d;border:1px solid rgba(76,175,80,.2);border-radius:4px;padding:.75rem}.preview-text{color:#e0e0e0;font-size:.9rem;margin:0}.preview-hours{color:#888;font-size:.85rem;margin:.25rem 0 0}@media (max-width: 640px){.file-link-row{flex-direction:column}.copy-button{width:100%}.success-actions{flex-direction:column}.view-button,.new-upload-button{width:100%;justify-content:center}}.files-list{background:#1a1a1a;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000004d;margin-top:2rem;border:1px solid #333}.files-list h2{margin-bottom:1.5rem;font-size:1.3rem;color:#e0e0e0}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.file-card{border:1px solid #333;border-radius:6px;padding:1.5rem;background:#0f0f0f;transition:all .2s ease;display:flex;flex-direction:column}.file-card:hover{border-color:#555;box-shadow:0 2px 8px #00000080;background:#161616}.file-icon{font-size:2.5rem;margin-bottom:1rem}.file-info{flex:1;margin-bottom:1rem}.file-name{font-size:1rem;font-weight:600;color:#e0e0e0;margin-bottom:.5rem;word-break:break-word;max-height:3em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.file-size{font-size:.85rem;color:#999;margin-bottom:.25rem}.file-date{font-size:.8rem;color:#666;margin-bottom:.25rem}.file-expiration{font-size:.8rem;color:#ff6b6b;font-weight:500}.file-actions{display:flex;gap:.5rem}.file-link,.file-delete{flex:1;padding:.6rem;border:1px solid #444;background:transparent;border-radius:4px;cursor:pointer;font-size:1.1rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center;text-decoration:none;min-height:36px;color:#e0e0e0}.file-link:hover{background:#2a2a2a;border-color:#666}.file-delete:hover:not(:disabled){background:#4a2a2a;border-color:#ff6b6b}.file-delete:disabled{opacity:.6;cursor:not-allowed}.files-empty{background:#1a1a1a;border-radius:8px;padding:3rem 2rem;text-align:center;color:#666;box-shadow:0 1px 3px #0000004d;margin-top:2rem;border:1px solid #333}@media (max-width: 640px){.files-list{padding:1.5rem}.files-grid{grid-template-columns:1fr}.file-card{padding:1rem}}.storage-stats{background:#1a1a1a;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000004d;margin-top:2rem;border:1px solid #333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.stat-card{padding:1.5rem;border:1px solid #333;border-radius:6px;background:#0f0f0f}.stat-card h3{margin-bottom:1rem;font-size:.95rem;font-weight:600;color:#e0e0e0;text-transform:uppercase;letter-spacing:.5px}.storage-bar{height:8px;background:#333;border-radius:4px;overflow:hidden;margin-bottom:.75rem}.storage-bar-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease}.storage-text{font-size:.9rem;color:#999;margin:0}.limits-info{display:flex;flex-direction:column;gap:.75rem}.limit-item{display:flex;justify-content:space-between;font-size:.9rem;padding:.5rem 0}.limit-label{color:#999;font-weight:500}.limit-value{color:#e0e0e0;font-weight:600}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#e0e0e0;border-radius:50%;animation:spin .8s linear infinite}.loading-container p{color:#999;font-size:.9rem}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000080;background:#1a1a1a;border:1px solid #333;color:#e0e0e0;animation:slideIn .3s ease-out;min-width:300px}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;flex-shrink:0;font-weight:700;font-size:16px}.toast-message{flex:1;font-size:14px;line-height:1.4}.toast-close{background:none;border:none;cursor:pointer;padding:4px;color:inherit;opacity:.6;font-size:18px;line-height:1;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-success{border-left:4px solid #4caf50;background:#1a4d2e;border-color:#2d7a4a}.toast-success .toast-icon{background:#2d7a4a;color:#4caf50}.toast-error{border-left:4px solid #ef4444;background:#4d1a1a;border-color:#7a2d2d}.toast-error .toast-icon{background:#7a2d2d;color:#ef4444}.toast-warning{border-left:4px solid #f59e0b;background:#4d3a1a;border-color:#7a5d2d}.toast-warning .toast-icon{background:#7a5d2d;color:#f59e0b}.toast-info{border-left:4px solid #3b82f6;background:#1a2d4d;border-color:#2d4a7a}.toast-info .toast-icon{background:#2d4a7a;color:#3b82f6}@media (max-width: 768px){.toast-container{top:10px;right:10px;left:10px;max-width:none}.toast{min-width:auto}}.admin-page{flex:1;padding:2rem 1rem;background:#0f0f0f;min-height:100vh}.admin-header{max-width:1200px;margin:0 auto 2rem;text-align:center}.admin-header h1{color:#e0e0e0;font-size:2rem;margin-bottom:.5rem}.admin-header p{color:#888;font-size:1rem}.admin-tabs{max-width:1200px;margin:0 auto 2rem;display:flex;gap:1rem;border-bottom:2px solid #333}.admin-tabs .tab{padding:1rem 2rem;background:none;border:none;color:#888;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent;margin-bottom:-2px}.admin-tabs .tab:hover{color:#e0e0e0}.admin-tabs .tab.active{color:#e0e0e0;border-bottom-color:#4caf50}.settings-section,.users-section{max-width:1200px;margin:0 auto}.settings-info{background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:1rem;margin-bottom:2rem;color:#888;font-size:.9rem}.limits-card,.user-search-card,.user-details-card{background:#1a1a1a;border:1px solid #333;border-radius:8px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000004d}.limits-card h2,.user-search-card h2,.user-details-card h2{color:#e0e0e0;font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid #333}.limits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.limit-field{display:flex;flex-direction:column;gap:.5rem}.limit-field label{color:#e0e0e0;font-size:.9rem;font-weight:500}.limit-field input{padding:.75rem;background:#0f0f0f;border:1px solid #444;border-radius:4px;color:#e0e0e0;font-size:1rem;transition:border-color .2s}.limit-field input:focus{outline:none;border-color:#4caf50}.limit-field .hint{color:#888;font-size:.85rem;font-style:italic}.save-button-container{display:flex;justify-content:center;margin-top:2rem}.save-button{padding:1rem 3rem;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s}.save-button:hover:not(:disabled){background:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px #4caf504d}.save-button:disabled{opacity:.6;cursor:not-allowed}.search-type{display:flex;gap:2rem;margin-bottom:1rem}.search-type label{display:flex;align-items:center;gap:.5rem;color:#e0e0e0;cursor:pointer}.search-type input[type=radio]{cursor:pointer}.search-input-group{display:flex;gap:1rem}.search-input-group input{flex:1;padding:.75rem;background:#0f0f0f;border:1px solid #444;border-radius:4px;color:#e0e0e0;font-size:1rem}.search-input-group input:focus{outline:none;border-color:#4caf50}.search-input-group button{padding:.75rem 2rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.search-input-group button:hover:not(:disabled){background:#45a049}.search-input-group button:disabled{opacity:.6;cursor:not-allowed}.user-info{margin-bottom:2rem}.info-row{display:flex;padding:.75rem 0;border-bottom:1px solid #333}.info-row:last-child{border-bottom:none}.info-row .label{color:#888;font-weight:600;min-width:120px}.info-row .value{color:#e0e0e0;font-family:monospace}.user-actions h3{color:#e0e0e0;font-size:1.2rem;margin-bottom:1rem}.permission-toggles{display:flex;flex-direction:column;gap:1rem}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#0f0f0f;border:1px solid #444;border-radius:6px;transition:border-color .2s}.permission-item:hover{border-color:#555}.permission-info{display:flex;flex-direction:column;gap:.25rem}.permission-info strong{color:#e0e0e0;font-size:1rem}.permission-info span{color:#888;font-size:.9rem}.permission-info span.danger{color:#ef4444}.toggle-button{padding:.5rem 1.5rem;background:#333;color:#888;border:1px solid #444;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.toggle-button:hover{background:#3a3a3a}.toggle-button.active{background:#2d7a4a;color:#4caf50;border-color:#4caf50}.toggle-button.active.danger{background:#7a2d2d;color:#ef4444;border-color:#ef4444}.error{background:#4d1a1a;border:1px solid #7a2d2d;border-radius:6px;padding:1rem;color:#ef4444;text-align:center}@media (max-width: 768px){.admin-page{padding:1rem}.admin-tabs{flex-direction:column;gap:0;border-bottom:none}.admin-tabs .tab{border-bottom:1px solid #333;border-left:3px solid transparent;margin-bottom:0;text-align:left}.admin-tabs .tab.active{border-left-color:#4caf50;border-bottom-color:#333}.limits-grid{grid-template-columns:1fr}.search-input-group{flex-direction:column}.permission-item{flex-direction:column;gap:1rem;align-items:stretch}.toggle-button{width:100%}}.auth-callback{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}.callback-content{background:#1a1a1a;border-radius:8px;padding:3rem;text-align:center;max-width:400px;width:90%;box-shadow:0 2px 10px #00000080;border:1px solid #333}.spinner{width:50px;height:50px;border:4px solid #333;border-top-color:#e0e0e0;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.callback-content p{margin:.5rem 0;color:#e0e0e0}.callback-content.success{color:#4caf50}.success-icon{display:block;font-size:3rem;margin-bottom:1rem}.callback-content.error{color:#ff6b6b}.error-icon{display:block;font-size:3rem;margin-bottom:1rem}.error-message{font-size:.9rem;color:#999;margin:1rem 0!important}.redirect-text{font-size:.9rem;color:#888}.retry-link{display:inline-block;margin-top:1.5rem;padding:.75rem 1.5rem;background:#ff6b6b;color:#fff;border-radius:4px;text-decoration:none;transition:background .2s ease}.retry-link:hover{background:#ff5252}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0f0f0f;color:#e0e0e0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
