@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary:#4361ee;--primary-dark:#2b35af;--primary-light:#4895ef;--accent:#4cc9f0;--surface:#0a0e27;--surface-light:#12183a;--surface-lighter:#1e2654;--text-primary:#f0f2ff;--text-secondary:#8e95c2;--text-muted:#5c6394;--border:#1a2048;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--gradient-1:linear-gradient(135deg, #2b35af 0%, #4361ee 50%, #4cc9f0 100%);--gradient-2:linear-gradient(135deg, #0a0e27 0%, #12086f 100%);--glass:#0a0e27d9;--glass-border:#4361ee33}[data-theme=light]{--primary:#4361ee;--primary-dark:#2b35af;--primary-light:#4361ee;--accent:#4895ef;--surface:#eef2ff;--surface-light:#dce4ff;--surface-lighter:#c2cef5;--text-primary:#0a0e27;--text-secondary:#3d4470;--text-muted:#7a82b0;--border:#c9d1f0;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--gradient-1:linear-gradient(135deg, #2b35af 0%, #4361ee 50%, #4cc9f0 100%);--gradient-2:linear-gradient(135deg, #eef2ff 0%, #d0d9ff 100%);--glass:#ffffffe0;--glass-border:#4361ee26}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--surface);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,system-ui,sans-serif;transition:background-color .3s,color .3s}.bg-mesh{z-index:0;background:var(--surface);position:fixed;inset:0;overflow:hidden}.bg-mesh:before{content:"";background:radial-gradient(circle,#4361ee26 0%,#0000 70%);border-radius:50%;width:600px;height:600px;animation:20s ease-in-out infinite float;position:absolute;top:-200px;right:-100px}.bg-mesh:after{content:"";background:radial-gradient(circle,#4cc9f01a 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:25s ease-in-out infinite reverse float;position:absolute;bottom:-150px;left:-100px}@keyframes float{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-30px)scale(1.05)}66%{transform:translate(-20px,20px)scale(.95)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #4361ee1a}50%{box-shadow:0 0 40px #4361ee33}}@keyframes meshMove{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes staggerFadeIn{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.animate-fade-in-up{animation:.6s ease-out forwards fadeInUp}.animate-slide-in{animation:.4s ease-out forwards slideIn}.stagger-1{animation:.5s cubic-bezier(.23,1,.32,1) 50ms both staggerFadeIn}.stagger-2{animation:.5s cubic-bezier(.23,1,.32,1) .12s both staggerFadeIn}.stagger-3{animation:.5s cubic-bezier(.23,1,.32,1) .19s both staggerFadeIn}.stagger-4{animation:.5s cubic-bezier(.23,1,.32,1) .26s both staggerFadeIn}.glass-card{-webkit-backdrop-filter:blur(24px);background:#0c122da6;border:1px solid #4361ee1f;border-radius:18px;transition:all .3s cubic-bezier(.23,1,.32,1);box-shadow:0 4px 24px #00000026,inset 0 1px #ffffff0a}.glass-card:hover{border-color:#4361ee4d;transform:translateY(-1px);box-shadow:0 8px 40px #4361ee1f,inset 0 1px #ffffff0f}[data-theme=light] .glass-card{background:#ffffffd9;border-color:#4361ee26;box-shadow:0 4px 20px #2b35af0f,0 1px 3px #0000000d,inset 0 1px #ffffffe6}[data-theme=light] .glass-card:hover{background:#fffffff2;border-color:#4361ee40;box-shadow:0 12px 40px #2b35af1a,0 2px 6px #0000000a}[data-theme=light] .bg-mesh{background:#eef2ff}[data-theme=light] .bg-mesh:before{background:radial-gradient(circle,#4361ee14 0%,#0000 70%)}[data-theme=light] .bg-mesh:after{background:radial-gradient(circle,#4cc9f00f 0%,#0000 70%)}[data-theme=light] .header{background:#ffffffe6;border-bottom-color:#e2e8f0}[data-theme=light] .custom-select option{background:#fff}.theme-toggle{background:var(--surface-light);border:1px solid var(--border);cursor:pointer;border-radius:14px;flex-shrink:0;align-items:center;width:52px;height:28px;padding:0 4px;transition:all .3s;display:flex;position:relative}.theme-toggle:hover{border-color:var(--primary)}.theme-toggle-thumb{background:var(--gradient-1);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 4px #0003}.theme-toggle[data-active=true] .theme-toggle-thumb{transform:translate(24px)}.theme-toggle-icons{pointer-events:none;justify-content:space-between;align-items:center;padding:0 7px;font-size:12px;display:flex;position:absolute;inset:0}.login-page{background:linear-gradient(160deg,#0a0e27 0%,#12086f 40%,#1a1050 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}[data-theme=light] .login-page{background:linear-gradient(160deg,#dce4ff 0%,#c5d0f8 40%,#eef2ff 100%)}.wave-container{z-index:0;width:100%;height:45%;position:absolute;bottom:0;left:0;overflow:hidden}.wave{width:200%;height:100%;position:absolute;bottom:0;left:0}.wave-1{animation:8s ease-in-out infinite alternate wave-drift}.wave-1 path{fill:#2b35af40}.wave-2{animation:10s ease-in-out infinite alternate-reverse wave-drift;left:-30%}.wave-2 path{fill:#4361ee33}.wave-3{animation:12s ease-in-out infinite alternate wave-drift;left:-15%}.wave-3 path{fill:#4895ef26}[data-theme=light] .wave-1 path{fill:#2b35af1f}[data-theme=light] .wave-2 path{fill:#4361ee1a}[data-theme=light] .wave-3 path{fill:#4895ef14}@keyframes wave-drift{0%{transform:translate(0)translateY(0)}to{transform:translate(-15%)translateY(-8px)}}.theme-btn{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:all .3s;display:flex;position:fixed;top:20px;right:20px}.theme-btn:hover{background:#ffffff26;transform:scale(1.1)rotate(15deg)}.theme-btn svg{stroke:#ffffffd9}[data-theme=light] .theme-btn{background:#fff9;border-color:#0000001a}[data-theme=light] .theme-btn svg{stroke:#2b35af}.login-glass-card{z-index:10;-webkit-backdrop-filter:blur(20px);background:#12183ab3;border:1px solid #4361ee33;border-radius:24px;width:100%;max-width:420px;padding:40px 36px;position:relative;box-shadow:0 20px 60px #0000004d,0 0 80px #4361ee14,inset 0 1px #ffffff0f}[data-theme=light] .login-glass-card{background:#ffffffd1;border-color:#4361ee26;box-shadow:0 20px 60px #00000014,0 0 80px #4361ee0f,inset 0 1px #ffffffe6}.animate-card{animation:.6s cubic-bezier(.23,1,.32,1) cardSlideIn}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(30px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.card-logo{justify-content:center;margin-bottom:20px;display:flex}.ecsc-logo{object-fit:contain;filter:drop-shadow(0 4px 20px #4361ee4d);width:72px;height:72px;animation:4s ease-in-out infinite logo-float}[data-theme=light] .ecsc-logo{filter:brightness(0)saturate()invert(15%)sepia(60%)saturate(5000%)hue-rotate(230deg)brightness(90%)contrast(95%)drop-shadow(0 4px 20px #4361ee33)}@keyframes logo-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.card-title{text-align:center;color:#4895ef;letter-spacing:-.3px;margin-bottom:6px;font-size:26px;font-weight:700}[data-theme=light] .card-title{color:#2b35af}.card-subtitle{text-align:center;color:#8e95c2;margin-bottom:28px;font-size:14px}[data-theme=light] .card-subtitle{color:#5c6394}.card-error{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef444440;border-radius:30px;margin-bottom:18px;padding:10px 14px;font-size:13px;animation:.4s shake}[data-theme=light] .card-error{color:#dc2626;background:#ef444414}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.input-group{margin-bottom:16px;position:relative}.input-group input{color:#f0f2ff;box-sizing:border-box;background:#12183a80;border:1.5px solid #4361ee33;border-radius:30px;outline:none;width:100%;padding:14px 48px 14px 46px;font-family:inherit;font-size:15px;transition:all .3s}.input-group input::placeholder{color:#5c6394}.input-group input:focus{background:#12183ab3;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee26}[data-theme=light] .input-group input{color:#0a0e27;background:#eef2ffcc;border-color:#c9d1f0}[data-theme=light] .input-group input::placeholder{color:#7a82b0}[data-theme=light] .input-group input:focus{background:#fff;border-color:#4361ee;box-shadow:0 0 0 3px #4361ee1a}.input-icon{pointer-events:none;opacity:.5;color:#8e95c2;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;left:16px;transform:translateY(-50%)}[data-theme=light] .input-icon{color:#5c6394}.eye-btn{cursor:pointer;opacity:.4;color:#8e95c2;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}[data-theme=light] .eye-btn{color:#5c6394}.eye-btn:hover{opacity:1}.sign-in-btn{color:#fff;letter-spacing:1.5px;cursor:pointer;background:linear-gradient(135deg,#2b35af,#4361ee);border:none;border-radius:30px;width:100%;margin-top:6px;padding:14px;font-family:inherit;font-size:15px;font-weight:700;transition:all .3s;position:relative;overflow:hidden}.sign-in-btn:after{content:"";background:linear-gradient(90deg,#0000,#ffffff1f,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.sign-in-btn:hover:after{left:100%}.sign-in-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #4361ee66}.sign-in-btn:active{transform:translateY(0)}.sign-in-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.card-footer-text{text-align:center;color:#5c6394;margin-top:20px;font-size:12px}.card-divider{background:#4361ee26;height:1px;margin:16px 0}.card-copyright{text-align:center;color:#5c6394;margin:0;font-size:12px}.login-container{z-index:1;background:var(--surface);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative}.login-card{width:100%;max-width:440px;padding:48px 40px;animation:.8s ease-out fadeInUp}.login-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:8px;display:flex}.login-logo-icon{background:var(--gradient-1);border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.login-logo-img{object-fit:contain;border-radius:14px;width:64px;height:64px}.login-title{text-align:center;color:var(--text-primary);letter-spacing:-.5px;font-size:28px;font-weight:700}.login-subtitle{text-align:center;color:var(--text-secondary);margin-top:8px;margin-bottom:36px;font-size:14px}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);letter-spacing:.3px;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input{background:var(--surface-light);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:12px 16px;font-family:inherit;font-size:15px;transition:all .2s}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4361ee26}.btn-primary{background:var(--gradient-1);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:8px;padding:12px;font-family:inherit;font-size:15px;font-weight:600;transition:all .3s;position:relative;overflow:hidden}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px #4361ee4d}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-msg{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.dashboard{z-index:1;background:linear-gradient(160deg,#070b1e 0%,#0a0e27 30%,#10123a 60%,#0d1030 100%) 0 0/200% 200%;flex-direction:column;min-height:100vh;animation:20s infinite meshMove;display:flex;position:relative}[data-theme=light] .dashboard{background:linear-gradient(160deg,#d0d9ff 0%,#e4eaff 25%,#f0f0ff 50%,#dce4ff 75%,#e8edff 100%) 0 0/200% 200%;animation:25s infinite meshMove}.dash-bg-shapes{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.dash-shape{opacity:.7;filter:blur(80px);border-radius:50%;animation:20s ease-in-out infinite dashFloat;position:absolute}@keyframes dashFloat{0%,to{transform:translate(0)scale(1)}25%{transform:translate(60px,-50px)scale(1.1)}50%{transform:translate(-40px,60px)scale(.9)}75%{transform:translate(50px,30px)scale(1.08)}}.dash-shape-1{background:#4361ee59;width:450px;height:450px;animation-duration:18s;top:-10%;right:-8%}.dash-shape-2{background:#4cc9f040;width:380px;height:380px;animation-duration:22s;animation-delay:-5s;bottom:5%;left:-10%}.dash-shape-3{background:#2b35af33;width:300px;height:300px;animation-duration:25s;animation-delay:-8s;top:25%;right:10%}.dash-shape-4{background:#4895ef33;width:220px;height:220px;animation-duration:20s;animation-delay:-3s;bottom:20%;right:30%}.dash-shape-5{background:#4361ee26;width:320px;height:320px;animation-duration:28s;animation-delay:-12s;top:50%;left:15%}.dash-shape-6{background:#4cc9f02e;width:250px;height:250px;animation-duration:24s;animation-delay:-7s;top:0%;left:30%}[data-theme=light] .dash-shape{filter:blur(60px);opacity:.9}[data-theme=light] .dash-shape-1{background:#2b35af40}[data-theme=light] .dash-shape-2{background:#4361ee33}[data-theme=light] .dash-shape-3{background:#4895ef38}[data-theme=light] .dash-shape-4{background:#2b35af2e}[data-theme=light] .dash-shape-5{background:#4361ee26}[data-theme=light] .dash-shape-6{background:#4cc9f033}.header{-webkit-backdrop-filter:blur(24px);z-index:50;background:#0a0e27bf;border-bottom:1px solid #4361ee1f;padding:0 24px;position:sticky;top:0}[data-theme=light] .header{background:#ffffffe0;border-bottom-color:#4361ee1f;box-shadow:0 2px 16px #2b35af0f,0 1px 3px #00000008}.header-inner{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;display:flex}.header-brand{align-items:center;gap:10px;display:flex}.header-logo{flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.header-logo-img{object-fit:contain;width:36px;height:36px}[data-theme=light] .header-logo-img{filter:brightness(0)saturate()invert(15%)sepia(60%)saturate(5000%)hue-rotate(230deg)brightness(90%)contrast(95%)}.header-title{color:var(--text-primary);letter-spacing:-.3px;font-size:18px;font-weight:700}@media (max-width:640px){.hide-mobile{display:none!important}}.header-user{align-items:center;gap:12px;display:flex}.header-user-info{text-align:right;display:none}@media (min-width:640px){.header-user-info{display:block}}.header-user-name{color:var(--text-primary);font-size:14px;font-weight:600}.header-user-id{color:var(--text-muted);font-size:12px}.header-icon-btn{border:1px solid var(--glass-border);background:var(--surface-light);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.header-icon-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.05)}.btn-logout{background:var(--surface-light);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-logout:hover{color:#fca5a5;background:#ef44441a;border-color:#ef44444d}.content-wrap{box-sizing:border-box;flex-direction:column;flex:1;gap:22px;width:100%;max-width:1200px;margin:0 auto;padding:28px 24px;display:flex;overflow:hidden}.welcome-banner{background:linear-gradient(135deg,#2b35af33 0%,#4361ee1a 50%,#4cc9f014 100%);border:1px solid #4361ee26;padding:28px 32px;position:relative;overflow:hidden}.welcome-banner:before{content:"";pointer-events:none;background:radial-gradient(circle,#4361ee1a 0%,#0000 70%);border-radius:50%;width:250px;height:250px;position:absolute;top:-50%;right:-20%}[data-theme=light] .welcome-banner{background:linear-gradient(135deg,#2b35af14 0%,#4361ee0d 50%,#4cc9f008 100%);border-color:#4361ee1a}.selector-card{padding:20px 24px}.selector-row{flex-wrap:wrap;align-items:flex-end;gap:20px;display:flex}.selector-group{flex-direction:column;flex:none;gap:6px;display:flex}.selector-label{color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;font-size:11px;font-weight:600}.select-wrapper{display:inline-block;position:relative}.custom-select{appearance:none;background:var(--surface);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;border-radius:10px;outline:none;min-width:190px;padding:11px 42px 11px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:all .25s}.custom-select:hover{border-color:var(--primary);background:var(--surface-light);box-shadow:0 2px 8px #4361ee14}.custom-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4361ee26}.custom-select option{background:var(--surface);color:var(--text-primary);padding:10px}.select-arrow{color:var(--primary-light);pointer-events:none;font-size:13px;transition:color .2s;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.select-wrapper:hover .select-arrow{color:var(--primary)}.selector-info{background:#4361ee14;border:1px solid #4361ee26;border-radius:10px;align-items:center;gap:10px;margin-left:auto;padding:11px 18px;display:flex}@media (max-width:640px){.selector-row{flex-direction:column;align-items:stretch}.custom-select{width:100%}.selector-info{margin-left:0}}[data-theme=light] .custom-select{background:#ffffffe6;border-color:#4361ee26}[data-theme=light] .custom-select:hover{background:#fff;box-shadow:0 3px 12px #2b35af14}[data-theme=light] .selector-info{background:#4361ee0f;border-color:#4361ee1f}[data-theme=light] .folder-card:hover{background:#fffffff2;border-color:#4361ee40;box-shadow:0 8px 32px #2b35af14}[data-theme=light] .btn-download{color:#2b35af;background:#4361ee0f;border-color:#4361ee26}[data-theme=light] .btn-download:hover{color:#fff;background:#4361ee;border-color:#4361ee;box-shadow:0 4px 16px #4361ee40}[data-theme=light] .btn-open{color:#0c7bb3;background:#4cc9f00f;border-color:#4cc9f033}[data-theme=light] .btn-open:hover{color:#fff;background:#4895ef;border-color:#4895ef;box-shadow:0 4px 16px #4895ef40}[data-theme=light] .search-box input{background:#ffffffe6;border-color:#4361ee1f}[data-theme=light] .search-box input:focus{background:#fff;box-shadow:0 0 0 3px #4361ee14}[data-theme=light] .breadcrumb-back:hover{background:#4361ee0f}[data-theme=light] .btn-logout:hover{color:#dc2626;background:#ef44440f}.files-section-inner{flex:1}.files-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.files-count{color:var(--text-muted);font-size:14px}.files-count span{color:var(--primary-light);font-weight:600}.search-box{position:relative}.search-box input{background:var(--surface-light);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;outline:none;width:220px;padding:8px 16px 8px 36px;font-family:inherit;font-size:13px;transition:all .2s}.search-box input:focus{border-color:var(--primary);width:280px}.search-box input::placeholder{color:var(--text-muted)}.search-box .search-icon{color:var(--text-muted);pointer-events:none;font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.files-grid{grid-template-columns:1fr;gap:10px;width:100%;display:grid}@media (min-width:768px){.files-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}.file-card{cursor:default;opacity:0;align-items:center;gap:12px;min-width:0;padding:14px 16px;animation:.4s ease-out forwards fadeInUp;display:flex;overflow:hidden}.file-card:first-child{animation-delay:50ms}.file-card:nth-child(2){animation-delay:.1s}.file-card:nth-child(3){animation-delay:.15s}.file-card:nth-child(4){animation-delay:.2s}.file-card:nth-child(5){animation-delay:.25s}.file-card:nth-child(6){animation-delay:.3s}.file-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.file-icon.pdf{background:#ef44441a}.file-icon.doc{background:#3b82f61a}.file-icon.sheet{background:#10b9811a}.file-icon.slide{background:#f59e0b1a}.file-icon.image{background:#a855f71a}.file-icon.video{background:#ec48991a}.file-icon.other{background:#4361ee1a}.file-info{flex:1;min-width:0}.file-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.file-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.btn-download{color:var(--primary-light);cursor:pointer;background:#4361ee1a;border:1px solid #4361ee33;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-download:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 12px #4361ee4d}.btn-open{color:var(--accent);cursor:pointer;background:#4cc9f01a;border:1px solid #4cc9f033;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-open:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #4cc9f04d}.file-actions{flex-shrink:0;gap:8px;display:flex}.breadcrumb-bar{align-items:center;gap:12px;padding:12px 18px;display:flex}.breadcrumb-back{background:var(--surface-light);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;flex-shrink:0;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.breadcrumb-back:hover{border-color:var(--primary);color:var(--primary-light);background:#4361ee1a}.breadcrumb-trail{flex:1;align-items:center;gap:0;display:flex;overflow-x:auto}.breadcrumb-item{white-space:nowrap;align-items:center;display:flex}.breadcrumb-sep{color:var(--text-muted);opacity:.5;margin:0 6px;font-size:14px}.breadcrumb-link{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.breadcrumb-link:hover{background:var(--surface-light);color:var(--primary-light)}.breadcrumb-link.active{color:var(--text-primary);cursor:default;font-weight:600}.folder-card{transition:all .25s;cursor:pointer!important}.folder-card:hover{background:#4361ee0f;border-color:#4361ee4d;transform:translateY(-2px);box-shadow:0 4px 16px #4361ee1f}.file-icon.folder{background:#f59e0b1f;font-size:24px}.folder-arrow{color:var(--text-muted);flex-shrink:0;font-size:16px;transition:all .2s}.folder-card:hover .folder-arrow{color:var(--primary-light);transform:translate(3px)}.file-separator{align-items:center;gap:12px;margin:8px 0 12px;display:flex}.file-separator span{color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;font-size:11px;font-weight:600}.file-separator:after{content:"";background:var(--border);flex:1;height:1px}@media (max-width:640px){.file-actions{flex-direction:column;gap:4px}.btn-open,.btn-download{text-align:center;justify-content:center;padding:6px 10px;font-size:12px}}.loading-spinner{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 0;display:flex}.spinner{border:3px solid var(--surface-lighter);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.loading-text{color:var(--text-muted);font-size:14px}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state-icon{opacity:.5;margin-bottom:12px;font-size:48px}.empty-state-title{color:var(--text-secondary);margin-bottom:4px;font-size:16px;font-weight:600}.empty-state-desc{font-size:13px}.footer{text-align:center;color:var(--text-muted);letter-spacing:.3px;z-index:1;border-top:1px solid #4361ee14;padding:20px 16px;font-size:12px;position:relative}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-lighter);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.admin-stats{grid-template-columns:repeat(5,1fr);gap:14px;display:grid}@media (max-width:768px){.admin-stats{grid-template-columns:repeat(2,1fr)}}.admin-stat-card{text-align:center;background:#162032;border:1px solid #4361ee4d;border-radius:16px;padding:24px 16px;position:relative;overflow:hidden}.admin-stat-card:before{content:"";background:var(--gradient-1);height:3px;position:absolute;top:0;left:0;right:0}.admin-stat-number{background:var(--gradient-1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:800;line-height:1}.admin-stat-label{color:var(--text-muted);margin-top:6px;font-size:13px;font-weight:500}.admin-tabs{background:#162032;border:1px solid #4361ee40;border-radius:14px;gap:4px;padding:6px;display:flex}.admin-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .25s}.admin-tab:hover{color:var(--text-primary);background:#1e2d44}.admin-tab.active{color:#fff;background:var(--gradient-1);box-shadow:0 4px 12px #4361ee59}.admin-section{background:#162032;border:1px solid #4361ee33;border-radius:16px;padding:28px}.admin-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.admin-toolbar-left{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-section .form-input,.admin-section .custom-select{color:var(--text-primary)!important;background:#0d1a2a!important;border:1px solid #4361ee40!important}.admin-section .form-input:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px #4361ee26!important}.admin-section .form-input::placeholder{color:var(--text-muted)!important}.admin-add-form{background:#0d1a2a;border:1px solid #4361ee33;border-radius:14px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;padding:18px;display:flex}.admin-add-form .form-input,.admin-add-form .custom-select{flex:1;min-width:140px}.admin-add-form .btn-primary{flex-shrink:0;width:auto!important;padding:10px 24px!important;font-size:14px!important}.admin-table-wrap{border:1px solid #4361ee33;border-radius:12px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:14px}.admin-table thead{background:#0d1a2a}.admin-table thead th{text-align:left;color:var(--primary-light);text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid #4361ee33;padding:14px 18px;font-size:11px;font-weight:700}.admin-table tbody td{color:var(--text-primary);border-bottom:1px solid #4361ee14;padding:14px 18px}.admin-table tbody tr{transition:background .15s}.admin-table tbody tr:hover{background:#4361ee14}.admin-table tbody tr:last-child td{border-bottom:none}.admin-badge{color:var(--primary-light);letter-spacing:.3px;background:#4361ee33;border-radius:8px;padding:4px 12px;font-size:13px;font-weight:700;display:inline-block}.admin-year-badge{color:var(--accent);background:#4cc9f02e;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.admin-actions{gap:6px;display:flex}.admin-action-btn{color:var(--text-secondary);cursor:pointer;background:#0d1a2a;border:1px solid #4361ee33;border-radius:8px;padding:6px 10px;font-family:inherit;font-size:13px;transition:all .2s}.admin-action-btn:hover{border-color:var(--primary);background:#4361ee1f;transform:translateY(-1px)}.admin-action-btn.save{color:var(--success);background:#10b98114;border-color:#10b9814d}.admin-action-btn.save:hover{background:#10b98126}.admin-action-btn.danger:hover{color:var(--danger);background:#ef44441f;border-color:#ef444466}.admin-pagination{border-top:1px solid #4361ee1f;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding-top:20px;display:flex}.admin-page-btn{color:var(--text-secondary);cursor:pointer;background:#0d1a2a;border:1px solid #4361ee33;border-radius:10px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.admin-page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--text-primary);background:#4361ee1f}.admin-page-btn:disabled{opacity:.35;cursor:not-allowed}.admin-dropzone{text-align:center;cursor:pointer;color:var(--text-secondary);background:#0d1a2a;border:2px dashed #4361ee59;border-radius:20px;padding:50px 20px;transition:all .3s}.admin-dropzone:hover{border-color:var(--primary);background:#4361ee14;transform:translateY(-2px)}.admin-csv-example{color:var(--text-secondary);background:#0d1a2a;border:1px solid #4361ee26;border-radius:14px;margin-bottom:24px;padding:18px 20px;font-size:13px}.admin-csv-example pre{color:var(--accent);background:#162032;border:1px solid #4361ee1f;border-radius:10px;margin-top:10px;padding:14px;font-size:12px;overflow-x:auto}.admin-csv-example code{color:var(--primary-light);background:#4361ee33;border-radius:4px;padding:2px 8px;font-size:12px}.admin-toolbar .btn-primary{flex-shrink:0;width:auto!important;padding:10px 20px!important;font-size:14px!important}[data-theme=light] .admin-stat-card,[data-theme=light] .admin-tabs{background:#fff;border-color:#d4d8e8}[data-theme=light] .admin-tab:hover{background:#f1f5f9}[data-theme=light] .admin-section{background:#fff;border-color:#d4d8e8}[data-theme=light] .admin-section .form-input,[data-theme=light] .admin-section .custom-select{color:#0f172a!important;background:#f8fafc!important;border-color:#d4d8e8!important}[data-theme=light] .admin-table thead{background:#f1f5f9}[data-theme=light] .admin-table-wrap{border-color:#d4d8e8}[data-theme=light] .admin-table tbody tr:hover{background:#4361ee0a}[data-theme=light] .admin-add-form,[data-theme=light] .admin-action-btn{background:#f8fafc;border-color:#d4d8e8}[data-theme=light] .admin-dropzone{background:#f8fafc;border-color:#c4c8d8}[data-theme=light] .admin-dropzone:hover{background:#4361ee0d}[data-theme=light] .admin-csv-example{background:#f8fafc;border-color:#d4d8e8}[data-theme=light] .admin-csv-example pre{background:#fff;border-color:#d4d8e8}.profile-btn{border:1px solid var(--glass-border);background:var(--surface-light);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.profile-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.05)}.profile-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.profile-modal{background:var(--surface);border:1px solid var(--glass-border);border-radius:20px;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0006}.profile-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.profile-modal-header h2{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.profile-close{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.profile-close:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.profile-msg{border-radius:10px;margin:12px 24px 0;padding:10px 14px;font-size:13px;font-weight:500}.profile-msg.success{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.profile-msg.error{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.profile-section{border-bottom:1px solid var(--border);padding:20px 24px}.profile-section:last-child{border-bottom:none}.profile-section-title{color:var(--text-primary);margin:0 0 14px;font-size:15px;font-weight:700}.profile-readonly{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.profile-readonly-label{color:var(--text-muted);font-size:13px}.profile-readonly-value{color:var(--text-primary);font-size:14px;font-weight:600}.profile-field{margin-bottom:14px}.profile-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.profile-input{background:var(--surface-light);border:1px solid var(--glass-border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.profile-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4361ee26}.profile-hint{color:var(--text-muted);margin-top:4px;font-size:12px;display:block}.profile-save-btn{background:var(--gradient-1);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:4px;padding:11px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.profile-save-btn:hover{opacity:.9;transform:translateY(-1px)}.profile-save-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}[data-theme=light] .profile-modal{background:#fff;box-shadow:0 20px 60px #00000026}[data-theme=light] .profile-input{color:#0f172a;background:#f1f5f9;border-color:#d4d8e8}[data-theme=light] .profile-overlay{background:#0006}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
