*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4f46e5;--primary-mid: #7c3aed;--primary-hot: #ec4899;--primary-hover: #6366f1;--primary-light: rgba(79, 70, 229, .15);--primary-glow: rgba(124, 58, 237, .5);--gradient-primary: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #ec4899 100%);--gradient-primary-hover: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #f472b6 100%);--accent: #22d3ee;--accent-2: #14b8a6;--accent-hover: #06b6d4;--accent-light: rgba(34, 211, 238, .2);--gradient-accent: linear-gradient(135deg, #22d3ee 0%, #14b8a6 100%);--dark: #0f172a;--dark-2: #111827;--dark-3: #1e293b;--dark-surface: rgba(15, 23, 42, .95);--bg: linear-gradient(180deg, #faf5ff 0%, #f5f3ff 40%, #fdf2f8 100%);--bg-solid: #f8f4fc;--bg-soft: #f1eaff;--surface: #ffffff;--surface-elevated: #ffffff;--text: #0f172a;--text-muted: #475569;--text-subtle: #64748b;--text-on-dark: #f8fafc;--border: rgba(139, 92, 246, .2);--border-focus: var(--primary-mid);--success: #10b981;--success-light: rgba(16, 185, 129, .2);--error: #ef4444;--error-2: #dc2626;--error-light: rgba(239, 68, 68, .15);--gradient-error: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--warn: #f59e0b;--warn-light: rgba(245, 158, 11, .2);--radius: 14px;--radius-sm: 10px;--radius-lg: 18px;--radius-xl: 24px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--shadow: 0 4px 14px rgba(79, 70, 229, .12);--shadow-md: 0 8px 24px rgba(79, 70, 229, .15), 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 20px 40px rgba(79, 70, 229, .18), 0 4px 12px rgba(0, 0, 0, .08);--shadow-hover: 0 24px 48px rgba(124, 58, 237, .22), 0 8px 16px rgba(0, 0, 0, .08);--glow: 0 0 30px rgba(124, 58, 237, .35);--glow-accent: 0 0 24px rgba(34, 211, 238, .4);--glow-pink: 0 0 24px rgba(236, 72, 153, .35);--transition: .25s ease;--transition-slow: .35s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg-solid);background:var(--bg);background-attachment:fixed;color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-mid);text-decoration:none}button{cursor:pointer;font-family:inherit;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition)}button:disabled{cursor:not-allowed;opacity:.7}input,textarea{font-family:inherit;transition:border-color var(--transition),box-shadow var(--transition)}h1,.text-h1{font-size:2rem;font-weight:700;line-height:1.2;letter-spacing:-.02em}h2,.text-h2{font-size:1.5rem;font-weight:600;line-height:1.3}h3,.text-h3{font-size:1.25rem;font-weight:600}.text-body{font-size:1rem;color:var(--text-muted)}.text-small{font-size:.875rem;color:var(--text-muted)}.text-caption{font-size:.75rem;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.05em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:12px 24px;font-size:.9375rem;font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition)}.btn:hover:not(:disabled){transform:scale(1.02)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 20px var(--primary-glow)}.btn-primary:hover:not(:disabled){background:var(--gradient-primary-hover);box-shadow:var(--glow)}.btn-secondary{background:transparent;color:var(--primary-mid);border:2px solid var(--primary-mid);box-shadow:0 0 #7c3aed4d}.btn-secondary:hover:not(:disabled){background:var(--primary-light);box-shadow:0 0 20px #7c3aed59}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg-soft);border-color:var(--primary-mid);box-shadow:0 0 12px var(--primary-light)}.btn-danger{background:transparent;color:var(--error);border:1px solid var(--error)}.btn-danger:hover:not(:disabled){background:var(--error-light);box-shadow:0 0 12px #ef444440}.app-loading{display:flex;align-items:center;justify-content:center;min-height:200px;padding:var(--space-6)}.app-loading .spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--primary-mid);border-right-color:var(--primary-hot);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.msg-error{padding:var(--space-3) var(--space-4);background:var(--error-light);color:var(--error);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;margin-bottom:var(--space-3);border:1px solid rgba(239,68,68,.3);box-shadow:0 2px 8px #ef444426}.app-layout{display:flex;min-height:100vh;background:var(--bg-solid);background:linear-gradient(180deg,#faf5ff,#f5f3ff 40%,#fdf2f8);background-attachment:fixed}.app-sidebar-wrap{flex-shrink:0;width:260px;background:linear-gradient(180deg,var(--dark) 0%,var(--dark-2) 100%);border-right:1px solid rgba(124,58,237,.3);display:flex;flex-direction:column;box-shadow:4px 0 24px #00000026;transition:width var(--transition-slow)}.app-main-wrap{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.app-content{flex:1;padding:var(--space-6);overflow:auto;animation:contentFadeIn .35s ease-out}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app-navbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--surface);border-bottom:2px solid transparent;border-image:linear-gradient(90deg,var(--primary),var(--primary-mid),var(--primary-hot)) 1;flex-shrink:0;box-shadow:0 4px 20px #4f46e51f}.app-navbar-brand{display:flex;align-items:center;gap:var(--space-3);font-weight:800;font-size:1.25rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.app-navbar-actions{display:flex;align-items:center;gap:var(--space-4)}.app-navbar-email{font-size:.9rem;color:var(--text-muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-navbar .btn-ghost{padding:8px 16px;font-size:.9rem}.app-navbar .btn-ghost:hover{color:var(--error);border-color:var(--error);box-shadow:0 0 12px #ef444433}.app-sidebar{width:100%;padding:var(--space-5) var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.app-sidebar-nav{display:flex;flex-direction:column;gap:var(--space-2)}.app-sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:#f8fafcbf;font-weight:500;font-size:.9375rem;text-decoration:none;border-radius:var(--radius-sm);margin:0 var(--space-2);transition:all var(--transition);border:1px solid transparent}.app-sidebar-link:hover{background:#7c3aed26;color:var(--accent);border-color:#22d3ee4d;box-shadow:0 0 20px #22d3ee26}.app-sidebar-link.active{background:linear-gradient(135deg,#7c3aed59,#ec489933);color:var(--accent);font-weight:700;border-color:var(--accent);box-shadow:0 0 24px #22d3ee40,inset 0 1px #ffffff1a}.app-sidebar-link .nav-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.landing-page{min-height:100vh;background:var(--bg-solid)}.landing-hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);background:linear-gradient(145deg,#4f46e5,#7c3aed,#ec4899 70%,#f472b6);position:relative;overflow:hidden}.landing-hero:before,.landing-hero:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:blobFloat 12s ease-in-out infinite;pointer-events:none}.landing-hero:before{width:400px;height:400px;top:-100px;left:-100px;background:#22d3ee66;animation-delay:0s}.landing-hero:after{width:350px;height:350px;bottom:-80px;right:-80px;background:#ec489966;animation-delay:-6s}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.landing-hero-content{position:relative;z-index:2;max-width:760px;margin:0 auto;animation:heroFadeIn .8s ease-out}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.landing-hero h1{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;margin-bottom:var(--space-5);line-height:1.1;letter-spacing:-.04em;background:linear-gradient(180deg,#fff,#ffffffeb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 40px rgba(255,255,255,.3)}.landing-hero .subheading{font-size:1.35rem;color:#ffffffe6;margin-bottom:var(--space-10);line-height:1.6;max-width:540px;margin-left:auto;margin-right:auto;text-shadow:0 2px 12px rgba(0,0,0,.15)}.landing-hero-cta{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:wrap}.landing-hero-cta .btn{min-width:160px;padding:16px 32px;font-size:1.05rem;border-radius:var(--radius);box-shadow:0 8px 32px #00000040}.landing-hero-cta .btn-primary{background:linear-gradient(135deg,#fff,#f0f0f0);color:var(--primary-mid);box-shadow:0 8px 32px #0003,0 0 0 1px #ffffff4d}.landing-hero-cta .btn-primary:hover{background:linear-gradient(135deg,#fff,#e8e8e8);box-shadow:0 12px 40px #00000040,0 0 30px #fff3;transform:scale(1.05)}.landing-hero-cta .btn-secondary{background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.6)}.landing-hero-cta .btn-secondary:hover{background:#ffffff40;border-color:#fff;box-shadow:0 0 24px #ffffff4d;transform:scale(1.05)}.landing-section{padding:var(--space-16) var(--space-6);max-width:1100px;margin:0 auto;background:linear-gradient(180deg,var(--bg-solid) 0%,#faf5ff 50%,var(--bg-soft) 100%)}.landing-section-title{text-align:center;font-size:2rem;font-weight:700;margin-bottom:var(--space-10);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.landing-features{display:flex;flex-wrap:wrap;gap:var(--space-6);justify-content:center}.landing-feature-card{flex:1 1 280px;max-width:340px;padding:var(--space-8);background:var(--surface);border-radius:var(--radius-lg);border:2px solid transparent;background-clip:padding-box;box-shadow:var(--shadow-md),0 0 0 1px #7c3aed1a;position:relative;overflow:hidden;transition:transform var(--transition-slow),box-shadow var(--transition-slow)}.landing-feature-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:2px;background:linear-gradient(135deg,var(--primary),var(--primary-mid),var(--primary-hot),var(--accent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;transition:opacity var(--transition)}.landing-feature-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--glow),var(--shadow-hover)}.landing-feature-card:hover:before{opacity:1}.landing-feature-icon{width:56px;height:56px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin-bottom:var(--space-5);background:var(--gradient-primary);color:#fff;box-shadow:0 8px 24px var(--primary-glow);transition:transform var(--transition)}.landing-feature-card:hover .landing-feature-icon{transform:scale(1.08)}.landing-feature-card h3{font-size:1.2rem;margin-bottom:var(--space-3);color:var(--text);font-weight:700}.landing-feature-card p{font-size:.9375rem;color:var(--text-muted);line-height:1.6}.landing-how{background:linear-gradient(180deg,var(--dark) 0%,var(--dark-2) 100%);padding:var(--space-16) var(--space-6);position:relative}.landing-how .landing-section-title{background:linear-gradient(180deg,#fff,#ffffffd9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-how-list{list-style:none;max-width:580px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-5)}.landing-how-list li{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-6) var(--space-6);background:#ffffff0f;border-radius:var(--radius-lg);border:1px solid rgba(124,58,237,.3);box-shadow:0 4px 20px #0003;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.landing-how-list li:hover{transform:translate(8px);border-color:var(--accent);box-shadow:0 8px 32px #22d3ee33}.landing-how-step{width:48px;height:48px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0;box-shadow:0 4px 16px var(--primary-glow)}.landing-how-list li span:last-child{color:var(--text-on-dark);font-weight:500;font-size:1rem}.landing-footer{padding:var(--space-8) var(--space-6);text-align:center;color:var(--text-muted);font-size:.9rem;background:linear-gradient(180deg,var(--dark-2) 0%,var(--dark) 100%);border-top:1px solid rgba(124,58,237,.2)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:linear-gradient(145deg,#4f46e5,#7c3aed 40%,#ec4899);position:relative;overflow:hidden}.auth-page:before,.auth-page:after{content:"";position:absolute;border-radius:50%;filter:blur(100px);opacity:.4;animation:blobFloat 14s ease-in-out infinite;pointer-events:none}.auth-page:before{width:350px;height:350px;top:-80px;left:-80px;background:#22d3ee80;animation-delay:0s}.auth-page:after{width:300px;height:300px;bottom:-60px;right:-60px;background:#ec489980;animation-delay:-7s}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,-20px) scale(1.1)}}.auth-card{position:relative;z-index:2;width:100%;max-width:440px;background:#ffffff1f;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--space-8);animation:authCardIn .5s ease-out;border:2px solid transparent;background-clip:padding-box;box-shadow:0 24px 48px #0003,inset 0 1px #fff3}.auth-card:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:calc(var(--radius-xl) + 2px);padding:2px;background:linear-gradient(135deg,#fff9,#fff3,#7c3aed99,#ec489980);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}@keyframes authCardIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-card h1{font-size:1.85rem;font-weight:800;margin-bottom:var(--space-2);color:var(--text);letter-spacing:-.02em}.auth-card>p{color:var(--text-muted);margin-bottom:var(--space-6);font-size:.9375rem;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.auth-form label{display:flex;flex-direction:column;gap:var(--space-2);font-size:.9rem;font-weight:600;color:var(--text)}.auth-form .input-wrap{position:relative;display:flex;align-items:center}.auth-form input{width:100%;padding:14px 44px 14px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;background:#ffffffe6;transition:border-color var(--transition),box-shadow var(--transition)}.auth-form input:focus{outline:none;border-color:var(--primary-mid);box-shadow:0 0 0 4px #7c3aed40,0 0 20px #ec489926}.auth-form input::placeholder{color:var(--text-subtle)}.auth-form .password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;padding:4px;color:var(--text-muted);cursor:pointer;font-size:1.1rem;line-height:1;transition:color var(--transition)}.auth-form .password-toggle:hover{color:var(--primary-mid)}.auth-form .auth-error{padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,#ef444433,#dc262626);color:var(--error);border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;border:1px solid rgba(239,68,68,.4);box-shadow:0 2px 12px #ef444433}.auth-form button[type=submit]{padding:14px 24px;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:700;margin-top:var(--space-2);transition:transform var(--transition),box-shadow var(--transition);box-shadow:0 8px 24px var(--primary-glow)}.auth-form button[type=submit]:hover:not(:disabled){transform:scale(1.02);box-shadow:var(--glow)}.auth-form button[type=submit]:active:not(:disabled){transform:scale(.98)}.auth-form button[type=submit]:disabled{opacity:.85;cursor:not-allowed}.auth-form .btn-loading{display:inline-flex;align-items:center;justify-content:center;gap:8px}.auth-form .btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.auth-footer{margin-top:var(--space-6);text-align:center;font-size:.9rem;color:var(--text-muted)}.auth-footer a{font-weight:700;color:var(--primary-mid)}.auth-footer a:hover{color:var(--primary-hot);text-decoration:underline}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.page-title{font-size:1.85rem;font-weight:800;margin:0;letter-spacing:-.02em;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-grid{display:flex;flex-wrap:wrap;gap:var(--space-5);margin-bottom:var(--space-6)}.dashboard-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-6);min-width:200px;flex:1 1 220px;max-width:320px;border:2px solid transparent;background-clip:padding-box;box-shadow:var(--shadow-md);position:relative;overflow:hidden;transition:transform var(--transition-slow),box-shadow var(--transition-slow)}.dashboard-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dashboard-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--glow),var(--shadow-hover)}.dashboard-card .card-icon{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:var(--space-4);box-shadow:0 8px 20px #0000001f;transition:transform var(--transition)}.dashboard-card:hover .card-icon{transform:scale(1.08)}.dashboard-card .card-icon.storage{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.dashboard-card.storage-card:before{background:linear-gradient(90deg,#4f46e5,#7c3aed)}.dashboard-card .card-icon.files{background:linear-gradient(135deg,#22d3ee,#14b8a6);color:#fff}.dashboard-card.files-card:before{background:linear-gradient(90deg,#22d3ee,#14b8a6)}.dashboard-card .card-icon.time{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.dashboard-card.time-card:before{background:linear-gradient(90deg,#10b981,#059669)}.dashboard-card .card-icon.activity{background:linear-gradient(135deg,#f59e0b,#ec4899);color:#fff}.dashboard-card.activity-card:before{background:linear-gradient(90deg,#f59e0b,#ec4899)}.dashboard-card .label{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--space-1);font-weight:600}.dashboard-card .value{font-size:1.6rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.storage-bar-wrap{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);border:2px solid rgba(124,58,237,.15);box-shadow:var(--shadow-md),0 0 0 1px #4f46e514;transition:box-shadow var(--transition)}.storage-bar-wrap:hover{box-shadow:var(--glow),var(--shadow-md)}.storage-bar-wrap .label{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);font-size:.9375rem;font-weight:600;color:var(--text)}.storage-bar-wrap .label span:last-child{color:var(--text-muted);font-weight:500}.storage-bar-track{height:14px;background:var(--bg-soft);border-radius:7px;overflow:hidden}.storage-bar-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed 35%,#ec4899);border-radius:7px;transition:width var(--transition-slow);animation:storagePulse 2.5s ease-in-out infinite}@keyframes storagePulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.08)}}.activity-section{margin-top:var(--space-8)}.activity-section h2{font-size:1.2rem;font-weight:700;margin-bottom:var(--space-4);color:var(--text)}.activity-list{list-style:none;background:var(--surface);border-radius:var(--radius-lg);border:2px solid rgba(124,58,237,.12);box-shadow:var(--shadow-md);overflow:hidden}.activity-list li{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-4);transition:background var(--transition),box-shadow var(--transition)}.activity-list li:last-child{border-bottom:none}.activity-list li:hover{background:linear-gradient(90deg,var(--primary-light) 0%,transparent 100%);box-shadow:inset 4px 0 0 var(--primary-mid)}.activity-badge{font-size:.75rem;padding:6px 12px;border-radius:var(--radius-sm);font-weight:700;background:var(--gradient-primary);color:#fff;flex-shrink:0;box-shadow:0 2px 8px var(--primary-glow)}.activity-filename{color:var(--text-muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.activity-date{font-size:.875rem;color:var(--text-subtle);flex-shrink:0}.files-list{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);border:2px solid rgba(124,58,237,.15);box-shadow:var(--shadow-md),0 0 0 1px #ffffff80;overflow:hidden}.files-list table{width:100%;border-collapse:collapse}.files-list th,.files-list td{padding:var(--space-4) var(--space-5);text-align:left;border-bottom:1px solid var(--border)}.files-list th{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:linear-gradient(180deg,var(--bg-soft) 0%,rgba(249,249,255,.8) 100%)}.files-list tr:last-child td{border-bottom:none}.files-list tbody tr{transition:background var(--transition),box-shadow var(--transition)}.files-list tbody tr:hover{background:linear-gradient(90deg,#7c3aed14,#ec48990d);box-shadow:inset 4px 0 0 var(--primary-mid)}.files-list .file-cell{display:flex;align-items:center;gap:var(--space-3)}.files-list .file-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;background:linear-gradient(135deg,var(--primary-light) 0%,var(--accent-light) 100%);color:var(--primary-mid);box-shadow:0 2px 8px #4f46e533}.files-list .file-name{font-weight:600;color:var(--text)}.files-list .file-meta{color:var(--text-muted);font-size:.875rem}.files-list .file-actions{display:flex;gap:var(--space-2)}.files-list .file-actions .btn{padding:8px 14px;font-size:.8125rem}.files-empty{padding:var(--space-12);text-align:center;color:var(--text-muted);font-size:.9375rem}.history-list{background:var(--surface);border-radius:var(--radius-lg);border:2px solid rgba(124,58,237,.12);box-shadow:var(--shadow-md);overflow:hidden}.history-list ul{list-style:none}.history-list li{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--space-4);transition:background var(--transition),transform var(--transition)}.history-list li:last-child{border-bottom:none}.history-list li:hover{background:var(--bg-soft);transform:translate(4px)}.history-list .action-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;transition:transform var(--transition)}.history-list li:hover .action-icon{transform:scale(1.1)}.history-list .action-icon.upload{background:linear-gradient(135deg,#10b98133,#10b98159);color:var(--success);box-shadow:0 2px 12px #10b98140}.history-list .action-icon.download{background:linear-gradient(135deg,var(--primary-light) 0%,rgba(124,58,237,.3) 100%);color:var(--primary-mid);box-shadow:0 2px 12px var(--primary-glow)}.history-list .action-icon.delete{background:linear-gradient(135deg,var(--error-light) 0%,rgba(239,68,68,.25) 100%);color:var(--error);box-shadow:0 2px 12px #ef444433}.history-list .action-badge{font-size:.8125rem;font-weight:700;padding:6px 12px;border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px var(--primary-glow)}.history-list .history-filename{flex:1;min-width:0;color:var(--text);overflow:hidden;text-overflow:ellipsis}.history-list .history-date{font-size:.875rem;color:var(--text-subtle);flex-shrink:0}.history-list .history-empty{padding:var(--space-12);text-align:center;color:var(--text-muted);font-size:.9375rem;margin:0}.admin-stats{display:flex;flex-wrap:wrap;gap:var(--space-5);margin-bottom:var(--space-8)}.admin-stats .stat{padding:var(--space-6);border-radius:var(--radius-lg);min-width:180px;flex:1 1 180px;border:2px solid transparent;box-shadow:var(--shadow-md);transition:transform var(--transition-slow),box-shadow var(--transition-slow)}.admin-stats .stat:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--glow),var(--shadow-hover)}.admin-stats .stat.gradient-1{background:linear-gradient(135deg,#fff,#4f46e51f,#7c3aed14);border-color:#4f46e540}.admin-stats .stat.gradient-2{background:linear-gradient(135deg,#fff,#22d3ee1f,#14b8a614);border-color:#22d3ee40}.admin-stats .stat.gradient-3{background:linear-gradient(135deg,#fff,#10b9811f,#05966914);border-color:#10b98140}.admin-stats .stat.gradient-4{background:linear-gradient(135deg,#fff,#ec48991f,#f59e0b14);border-color:#ec489940}.admin-stats .stat .label{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:600}.admin-stats .stat .value{font-size:1.85rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.admin-section-title{font-size:1.2rem;font-weight:700;margin-bottom:var(--space-4);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-table-wrap{background:var(--surface);border-radius:var(--radius-lg);border:2px solid rgba(124,58,237,.15);box-shadow:var(--shadow-md);overflow:hidden}.admin-table-wrap .files-list{background:var(--surface);border:none;box-shadow:none}.admin-table-wrap .files-list tbody tr:nth-child(2n){background:linear-gradient(90deg,rgba(124,58,237,.04) 0%,transparent 100%)}.admin-table-wrap .files-list tbody tr:hover{background:linear-gradient(90deg,#7c3aed1a,#ec48990f)}.admin-badge{display:inline-block;padding:6px 12px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;background:var(--gradient-primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow),0 0 20px #7c3aed4d;text-transform:uppercase;letter-spacing:.05em}.admin-badge.no{background:var(--bg-soft);color:var(--text-muted);box-shadow:none}.files-drag-zone{border:2px dashed rgba(124,58,237,.4);border-radius:var(--radius-lg);padding:var(--space-10);text-align:center;background:linear-gradient(135deg,#4f46e50f,#ec48990a);margin-bottom:var(--space-6);transition:all var(--transition);position:relative}.files-drag-zone:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:calc(var(--radius-lg) + 2px);padding:2px;background:linear-gradient(135deg,var(--primary),var(--primary-mid),var(--primary-hot),var(--accent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--transition);pointer-events:none}.files-drag-zone:hover{border-color:var(--primary-mid);box-shadow:0 0 24px #7c3aed33}.files-drag-zone.drag-over{border-color:var(--accent);background:linear-gradient(135deg,#22d3ee26,#7c3aed1f);box-shadow:0 0 32px #22d3ee59,0 0 0 2px #22d3ee4d}.files-drag-zone.drag-over:before{opacity:.5}.files-drag-zone p{color:var(--text-muted);font-size:.9375rem;margin:0}.files-drag-zone .drag-icon{font-size:2.75rem;margin-bottom:var(--space-3);opacity:.9;filter:drop-shadow(0 4px 12px var(--primary-glow))}.page-header .btn-primary{padding:14px 28px;font-size:1rem;font-weight:700;box-shadow:0 8px 28px var(--primary-glow),0 0 0 1px #fff3}.page-header .btn-primary:hover{box-shadow:var(--glow),0 12px 32px var(--primary-glow);transform:scale(1.05)}.upload-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(145deg,#0f172ad9,#4f46e566,#ec48994d);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-6);animation:backdropIn .25s ease-out}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.upload-modal{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-8);min-width:420px;max-width:520px;width:100%;animation:modalIn .35s ease-out;border:2px solid transparent;background-clip:padding-box;box-shadow:var(--shadow-hover),0 0 0 1px #ffffff80;position:relative;overflow:hidden}.upload-modal:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:calc(var(--radius-xl) + 2px);padding:2px;background:linear-gradient(135deg,var(--primary),var(--primary-mid),var(--primary-hot),var(--accent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.7;animation:borderGlow 3s ease-in-out infinite;pointer-events:none}@keyframes borderGlow{0%,to{opacity:.5}50%{opacity:.9}}@keyframes modalIn{0%{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.upload-modal h3{font-size:1.35rem;font-weight:800;margin-bottom:var(--space-6);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.upload-drop-zone{border:2px dashed rgba(124,58,237,.4);border-radius:var(--radius-lg);padding:var(--space-10);text-align:center;background:linear-gradient(135deg,#4f46e50f,#ec48990a);margin-bottom:var(--space-5);transition:all var(--transition);cursor:pointer;position:relative}.upload-drop-zone:hover{border-color:var(--primary-mid);background:var(--primary-light);box-shadow:0 0 24px #7c3aed33}.upload-drop-zone.drag-over{border-color:var(--accent);background:linear-gradient(135deg,#22d3ee33,#7c3aed26);box-shadow:0 0 32px #22d3ee66,0 0 0 2px #22d3ee4d}.upload-drop-zone .drop-icon{font-size:3.25rem;margin-bottom:var(--space-3);opacity:.9;filter:drop-shadow(0 4px 12px var(--primary-glow))}.upload-drop-zone p{color:var(--text-muted);font-size:.9375rem;margin:0}.upload-drop-zone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.upload-preview{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:linear-gradient(135deg,var(--primary-light) 0%,var(--accent-light) 100%);border-radius:var(--radius);margin-bottom:var(--space-5);border:2px solid rgba(124,58,237,.2);box-shadow:0 4px 16px #4f46e51f}.upload-preview-icon{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;box-shadow:0 4px 12px var(--primary-glow)}.upload-preview-info{flex:1;min-width:0}.upload-preview-name{font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-preview-size{font-size:.875rem;color:var(--text-muted)}.upload-progress-wrap{margin-bottom:var(--space-5);display:none}.upload-progress-wrap.visible{display:block;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upload-progress-wrap .label{display:flex;justify-content:space-between;margin-bottom:var(--space-2);font-size:.875rem;font-weight:600;color:var(--text-muted)}.upload-progress-track{height:10px;background:var(--bg-soft);border-radius:5px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed 35%,#ec4899);border-radius:5px;transition:width var(--transition-slow);animation:progressPulse 1.2s ease-in-out infinite}@keyframes progressPulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}.upload-success{text-align:center;padding:var(--space-8);display:none}.upload-success.visible{display:block;animation:successPulse .6s ease-out}@keyframes successPulse{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.upload-success .success-icon{font-size:4rem;margin-bottom:var(--space-4);filter:drop-shadow(0 8px 24px rgba(16,185,129,.4));animation:successBounce .5s ease-out .2s both}@keyframes successBounce{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.upload-success p{font-size:1.1rem;font-weight:700;color:var(--success);margin:0}.upload-modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.upload-modal-actions .btn{padding:12px 20px;font-size:.9375rem;font-weight:600}
