:root{--bg: #080a0e;--surface: #0e1117;--surface2: #141820;--border: #1e2535;--accent: #00e5ff;--accent2: #ff4d00;--purple: #a855f7;--magenta: #d946ef;--text: #e8eaf0;--muted: #8b95a8;--muted-warm: #c4a97d;--card-hover: #111827}*{margin:0;padding:0;box-sizing:border-box}html,body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:.4}.hero{position:relative;display:flex;flex-direction:column;justify-content:center;padding:40px 48px 0;overflow:hidden;border-bottom:1px solid var(--border)}.hero-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(168,85,247,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(168,85,247,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.hero-glow{position:absolute;border-radius:50%;pointer-events:none;filter:blur(100px)}.hero-glow-1{top:-150px;right:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(168,85,247,.15) 0%,transparent 70%);animation:glowFloat 8s ease-in-out infinite}.hero-glow-2{bottom:-100px;left:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(0,229,255,.08) 0%,transparent 70%);animation:glowFloat 10s ease-in-out infinite reverse}.hero-glow-3{top:30%;left:40%;width:400px;height:400px;background:radial-gradient(circle,rgba(217,70,239,.06) 0%,transparent 70%);animation:glowFloat 12s ease-in-out infinite 2s}@keyframes glowFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.1)}66%{transform:translate(-20px,15px) scale(.95)}}.hero-content{position:relative;z-index:2}.hero-label{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-warm);display:flex;align-items:center;gap:12px;margin-bottom:16px}.hero-label-line{width:40px;height:1px;background:linear-gradient(90deg,var(--purple),var(--accent))}.hero-label-dot{color:var(--purple);font-size:6px}.hero-titles{margin-bottom:24px}.hero-title-row{display:flex;align-items:center;gap:24px}.hero-title-main{font-family:Bebas Neue,sans-serif;font-size:clamp(64px,10vw,140px);letter-spacing:.02em;line-height:.95;color:var(--text);white-space:nowrap}.hero-title-outline{-webkit-text-stroke:1.5px var(--text);color:transparent!important;opacity:.4}.hero-title-accent{display:flex;align-items:center;gap:16px}.hero-star{font-size:clamp(24px,4vw,48px);color:var(--purple);animation:starSpin 6s linear infinite;display:inline-block}@keyframes starSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-title-badge{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--bg);background:linear-gradient(135deg,var(--purple),var(--magenta));padding:8px 20px;white-space:nowrap;align-self:center}.hero-title-row-2{margin-top:-8px}.hero-title-row-3{margin-top:-8px;gap:40px;align-items:flex-end}.hero-title-3d{font-family:Bebas Neue,sans-serif;font-size:clamp(80px,14vw,200px);line-height:.85;letter-spacing:.02em;background:linear-gradient(135deg,var(--accent) 0%,var(--purple) 50%,var(--magenta) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:14px;line-height:1.8;color:var(--muted);font-weight:300;padding-bottom:20px;max-width:360px}.hero-stats{display:flex;align-items:center;gap:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:0}.hero-stat{display:flex;align-items:center;gap:10px;padding:20px 32px;border-right:1px solid var(--border)}.hero-stat:last-child{border-right:none}.hero-stat-end{margin-left:auto}.hero-stat-icon{font-size:14px;color:var(--purple);animation:bounceArrow 2s ease-in-out infinite}@keyframes bounceArrow{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.hero-stat-text{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-warm)}.hero-stat-stars{font-size:10px;color:var(--purple);letter-spacing:2px}.counter{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--accent);background:#00e5ff14;border:1px solid rgba(0,229,255,.2);padding:4px 12px;border-radius:2px}.filters{padding:24px 48px;display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--border)}.filter-btn{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:6px 16px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;border-radius:2px;transition:all .2s}.filter-btn:hover,.filter-btn.active{border-color:var(--accent);color:var(--accent);background:#00e5ff0d}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1px;background:var(--border);margin-top:16px}.card{background:var(--surface);cursor:pointer;position:relative;overflow:hidden;transition:background .3s;animation:fadeUp .5s ease forwards;opacity:0}.card:nth-child(1){animation-delay:.05s}.card:nth-child(2){animation-delay:.1s}.card:nth-child(3){animation-delay:.15s}.card:nth-child(4){animation-delay:.2s}.card:nth-child(5){animation-delay:.25s}.card:nth-child(6){animation-delay:.3s}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.card:hover{background:var(--card-hover)}.card-viewer{width:100%;height:320px;position:relative;background:var(--surface2);overflow:hidden}.card-poster{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:linear-gradient(135deg,var(--surface2) 0%,#0d1420 100%);transition:background .3s}.card:hover .card-poster{background:linear-gradient(135deg,#111d2e,#0d1420)}.card-poster-icon{color:var(--accent);opacity:.3;transition:opacity .3s,transform .3s}.card:hover .card-poster-icon{opacity:.6;transform:scale(1.1)}.card-poster-label{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .3s}.card:hover .card-poster-label{opacity:1}.card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(8,10,14,.8) 0%,transparent 50%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;justify-content:flex-end;padding:16px;pointer-events:none}.card:hover .card-overlay{opacity:1}.view-btn{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;padding:8px 16px;background:var(--accent);color:#000;border:none;cursor:pointer;font-weight:600}.card-info{padding:20px 24px 24px;border-top:1px solid var(--border)}.card-category{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}.card-title{font-family:Bebas Neue,sans-serif;font-size:24px;letter-spacing:.03em;color:var(--text);margin-bottom:4px}.card-student{font-size:13px;color:var(--muted);font-weight:300}.card-tags{margin-top:12px;display:flex;gap:6px;flex-wrap:wrap}.tag{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border:1px solid #2a3448;color:#a0b0c8;border-radius:1px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060af2;z-index:900;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-overlay.active{opacity:1;pointer-events:all}.modal{width:90vw;max-width:1100px;height:85vh;background:var(--surface);border:1px solid var(--border);display:grid;grid-template-columns:1fr 320px;overflow:hidden;animation:modalIn .3s ease forwards}@keyframes modalIn{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.modal-viewer-wrap{position:relative;background:var(--surface2);overflow:hidden}.modal-panel{border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.modal-panel-header{padding:28px 24px 20px;border-bottom:1px solid var(--border)}.modal-category{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}.modal-title{font-family:Bebas Neue,sans-serif;font-size:32px;letter-spacing:.03em;line-height:1;margin-bottom:6px}.modal-student{font-size:13px;color:var(--muted)}.modal-desc{padding:20px 24px;flex:1;overflow-y:auto}.modal-desc p{font-size:13px;line-height:1.7;color:var(--muted);font-weight:300}.modal-desc-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted-warm);margin-bottom:10px}.modal-tags{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap}.modal-close{position:absolute;top:20px;right:20px;width:36px;height:36px;background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s}.modal-close:hover{border-color:var(--accent2);color:var(--accent2)}.card-like-row{display:flex;align-items:center;gap:8px;padding:12px 24px 0}.card-like-btn{background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s,transform .2s;padding:0;display:flex;align-items:center}.card-like-btn:hover,.card-like-btn.liked{color:#ff4d00}.card-like-count{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--muted);letter-spacing:.05em}.card-comment-icon{display:flex;align-items:center;color:var(--muted);margin-left:10px}.card-comment-count{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--muted);letter-spacing:.05em}@keyframes heartPop{0%{transform:scale(1)}30%{transform:scale(1.4)}60%{transform:scale(.9)}to{transform:scale(1)}}.like-animate{animation:heartPop .4s ease}.modal-like-bar{display:flex;align-items:center;gap:10px;padding:14px 24px;border-bottom:1px solid var(--border)}.modal-like-btn{background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s;padding:0;display:flex;align-items:center}.modal-like-btn:hover,.modal-like-btn.liked{color:#ff4d00}.modal-like-count{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text)}.comments-section{flex:1;display:flex;flex-direction:column;overflow:hidden;border-top:1px solid var(--border);min-height:0}.comments-header{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted-warm);padding:14px 24px 10px;flex-shrink:0}.comments-list{flex:1;overflow-y:auto;padding:0 24px;min-height:0}.comments-empty{font-size:12px;color:var(--muted);padding:16px 0;text-align:center}.comment-item{padding:10px 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.comment-meta-left{display:flex;align-items:center;gap:8px}.comment-author{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);font-weight:600}.comment-time{font-family:JetBrains Mono,monospace;font-size:9px;color:var(--muted);letter-spacing:.05em}.comment-text{font-size:13px;color:var(--text);line-height:1.5;font-weight:300}.comment-delete{background:none;border:none;color:var(--muted);cursor:pointer;font-size:11px;padding:2px 6px;transition:color .2s;line-height:1}.comment-delete:hover{color:var(--accent2)}.comment-input-row{display:flex;gap:8px;padding:12px 24px;border-top:1px solid var(--border);flex-shrink:0}.comment-input{flex:1;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:13px;outline:none;transition:border-color .2s}.comment-input:focus{border-color:var(--accent)}.comment-input::placeholder{color:var(--muted)}.comment-submit{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:8px 16px;background:var(--accent);border:1px solid var(--accent);color:#000;cursor:pointer;font-weight:600;transition:all .2s;white-space:nowrap}.comment-submit:hover{background:#33ebff}.comment-submit:disabled{opacity:.3;cursor:not-allowed}.comment-login-prompt{padding:16px 24px;text-align:center;border-top:1px solid var(--border);flex-shrink:0}.comment-login-prompt span{font-size:12px;color:var(--muted);cursor:pointer;transition:color .2s}.comment-login-prompt span:hover{color:var(--accent);text-decoration:underline}footer{padding:32px 48px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}footer p{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted-warm);letter-spacing:.05em}@media(max-width:1024px){.hero-title-row-3{flex-direction:column;align-items:flex-start;gap:16px}.hero-stats{flex-wrap:wrap}.hero-stat-end{margin-left:0}}@media(max-width:768px){.hero{padding:32px 24px 0}.hero-title-main{font-size:clamp(40px,12vw,80px)}.hero-title-3d{font-size:clamp(60px,18vw,120px)}.hero-title-outline{display:none}.hero-title-badge{font-size:8px;padding:6px 14px}.hero-title-row{flex-wrap:wrap;gap:12px}.hero-stats{flex-direction:column}.hero-stat{border-right:none;border-bottom:1px solid var(--border);width:100%}.hero-stat:last-child{border-bottom:none}.filters{padding:16px 24px}.gallery-grid{grid-template-columns:1fr}.modal{grid-template-columns:1fr;grid-template-rows:55% 45%}.modal-panel{border-left:none;border-top:1px solid var(--border)}footer{padding:24px}}.controls-hint{position:absolute;bottom:16px;left:16px;display:flex;gap:12px;flex-wrap:wrap;z-index:5;pointer-events:none}.controls-hint span{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#ffffff59;background:#0006;padding:4px 8px;border-radius:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.filters-right{margin-left:auto;display:flex;gap:8px}.upload-btn{border-color:var(--accent2)!important;color:var(--accent2)!important}.upload-btn:hover{background:#ff4d0014!important}.login-btn{border-color:var(--accent)!important;color:var(--accent)!important}.logout-btn{border-color:var(--muted)!important;color:var(--muted)!important}.user-badge{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);padding:5px 12px;border:1px solid rgba(0,229,255,.2);background:#00e5ff0f;border-radius:2px;white-space:nowrap}.auth-tabs{display:flex;border-bottom:1px solid var(--border)}.auth-tab{flex:1;padding:12px;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;background:transparent;border:none;color:var(--muted);cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-tab:hover{color:var(--text)}.auth-message{font-size:13px;font-family:JetBrains Mono,monospace;padding:8px 12px;border-radius:2px}.auth-error{color:var(--accent2);background:#ff4d0014;border:1px solid rgba(255,77,0,.2)}.auth-success{color:#22c55e;background:#22c55e14;border:1px solid rgba(34,197,94,.2)}.card-admin-actions{position:absolute;top:8px;left:8px;display:flex;gap:6px;z-index:5;opacity:0;transition:opacity .2s}.card:hover .card-admin-actions{opacity:1}.admin-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-edit{background:#00e5ff26;color:var(--accent)}.admin-edit:hover{background:#00e5ff4d;border-color:var(--accent)}.admin-delete{background:#ff4d0026;color:var(--accent2)}.admin-delete:hover{background:#ff4d004d;border-color:var(--accent2)}.card-drag-handle{position:absolute;top:8px;right:8px;z-index:10;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#00000080;border:1px solid var(--border);cursor:grab;color:var(--muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s,color .2s;padding:0}.card-drag-handle:hover{background:#ffffff26;color:var(--text)}.card-drag-handle:active{cursor:grabbing}.gallery-save-indicator{font-family:JetBrains Mono,monospace;font-size:11px;color:#22c55e;letter-spacing:.08em}.reorder-btn{opacity:.7}.reorder-btn.active{opacity:1;border-color:var(--accent);color:var(--accent)}.gallery-loading,.gallery-empty{grid-column:1 / -1;padding:80px 48px;text-align:center;font-family:JetBrains Mono,monospace;font-size:13px;color:var(--muted);letter-spacing:.05em;background:var(--surface)}.gallery-refreshing-indicator{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--accent);letter-spacing:.08em;opacity:.7;animation:refreshPulse 1.2s ease-in-out infinite}@keyframes refreshPulse{0%,to{opacity:.4}50%{opacity:.9}}.upload-modal{width:90vw;max-width:680px;max-height:90vh;background:var(--surface);border:1px solid var(--border);overflow-y:auto;animation:modalIn .3s ease forwards}.upload-header{padding:24px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--surface);z-index:2}.upload-title{font-family:Bebas Neue,sans-serif;font-size:28px;letter-spacing:.03em}.upload-body{padding:24px;display:flex;flex-direction:column;gap:20px}.upload-dropzone{width:100%;height:240px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,background .2s;position:relative;overflow:hidden;background:var(--surface2)}.upload-dropzone:hover{border-color:var(--accent);background:#00e5ff08}.upload-dropzone.has-file{border-style:solid;border-color:var(--accent);cursor:default}.upload-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--muted)}.upload-dropzone-content span{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.upload-file-name{position:absolute;bottom:8px;left:8px;font-family:JetBrains Mono,monospace;font-size:9px;color:var(--accent);background:#0009;padding:3px 8px;border-radius:2px;z-index:1}.upload-fields{display:flex;flex-direction:column;gap:14px}.upload-field label{display:block;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-warm);margin-bottom:6px}.upload-field input,.upload-field select,.upload-field textarea{width:100%;padding:10px 12px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;outline:none;transition:border-color .2s}.upload-field input:focus,.upload-field select:focus,.upload-field textarea:focus{border-color:var(--accent)}.upload-field select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b95a8' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.upload-field textarea{resize:vertical;min-height:60px}.upload-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--border)}.upload-cancel{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:10px 20px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .2s}.upload-cancel:hover{border-color:var(--text);color:var(--text)}.upload-submit{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:10px 20px;background:var(--accent);border:1px solid var(--accent);color:#000;cursor:pointer;font-weight:600;transition:all .2s}.upload-submit:hover{background:#33ebff}.upload-submit:disabled{opacity:.3;cursor:not-allowed}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border)}#top-bar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:24px;padding:0 76px;height:44px;background:#080a0eeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.topbar-brand{display:flex;align-items:center;gap:6px;font-family:Bebas Neue,sans-serif;font-size:16px;letter-spacing:.1em;color:var(--text);text-decoration:none;white-space:nowrap}.topbar-brand-dot{color:var(--accent);font-size:10px}.topbar-nav{display:flex;align-items:center;gap:4px;flex:1}.topbar-nav-link{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:4px 10px;border:1px solid transparent;transition:all .18s}.topbar-nav-link:hover{color:var(--text);border-color:var(--border)}.topbar-right{display:flex;align-items:center;margin-left:auto}.usermenu{position:relative}.usermenu-badge{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);padding:4px 10px 4px 5px;cursor:pointer;transition:border-color .18s;color:var(--text)}.usermenu-badge:hover{border-color:#00ff8860}.usermenu-avatar{width:26px;height:26px;border-radius:50%;background:var(--surface2);border:1px solid #00ff8840;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600;color:#0f8;flex-shrink:0}.usermenu-name{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.04em;color:var(--text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usermenu-login-btn{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;border:1px solid var(--border);padding:5px 12px;transition:all .18s}.usermenu-login-btn:hover{color:var(--accent);border-color:var(--accent)}.usermenu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--surface);border:1px solid var(--border);z-index:200;box-shadow:0 8px 24px #0006}.usermenu-dropdown-header{padding:12px 16px 10px;display:flex;flex-direction:column;gap:2px}.usermenu-dropdown-name{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;color:var(--text)}.usermenu-dropdown-role{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.usermenu-dropdown-divider{height:1px;background:var(--border);margin:2px 0}.usermenu-dropdown-item{display:flex;align-items:center;gap:8px;padding:9px 16px;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.04em;color:var(--muted);text-decoration:none;background:transparent;border:none;width:100%;cursor:pointer;transition:all .15s;text-align:left}.usermenu-dropdown-item:hover{background:var(--surface2);color:var(--text)}.usermenu-logout{color:#ff6b6b80}.usermenu-logout:hover{color:#ff6b6b;background:#ff6b6b0d}.profile-main{padding:40px 76px;max-width:680px}.profile-loading{display:flex;justify-content:center;padding:80px 0;gap:8px}.profile-wrap{display:flex;flex-direction:column;gap:28px}.profile-hero{display:flex;align-items:center;gap:18px;padding-bottom:24px;border-bottom:1px solid var(--border)}.profile-avatar{width:60px;height:60px;border-radius:50%;background:var(--surface2);border:2px solid #00ff8840;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace;font-size:20px;font-weight:600;color:#0f8;flex-shrink:0}.profile-hero-info{flex:1;display:flex;flex-direction:column;gap:4px}.profile-hero-name{font-family:Bebas Neue,sans-serif;font-size:28px;letter-spacing:.06em;color:var(--text);line-height:1}.profile-hero-role{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.profile-edit-trigger{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:transparent;border:1px solid var(--border);padding:6px 14px;cursor:pointer;transition:all .18s}.profile-edit-trigger:hover{color:#0f8;border-color:#00ff8860}.profile-view{display:flex;flex-direction:column;gap:20px}.profile-section{display:flex;flex-direction:column;gap:6px}.profile-section-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.profile-bio-text{font-family:DM Sans,sans-serif;font-size:14px;color:var(--text);line-height:1.6}.profile-links-row{display:flex;gap:12px;flex-wrap:wrap}.profile-form{display:flex;flex-direction:column;gap:20px}.profile-field{display:flex;flex-direction:column;gap:6px}.profile-label{display:flex;align-items:center;justify-content:space-between;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.profile-bio-count{font-size:10px;color:var(--muted);letter-spacing:0;text-transform:none}.profile-bio-count--limit{color:var(--accent2)}.profile-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;padding:10px 14px;outline:none;transition:border-color .2s;width:100%}.profile-input:focus{border-color:#00ff8860}.profile-textarea{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;padding:10px 14px;outline:none;transition:border-color .2s;width:100%;resize:vertical;line-height:1.6}.profile-textarea:focus{border-color:#00ff8860}.profile-textarea::placeholder,.profile-input::placeholder{color:var(--muted);opacity:.5}.profile-form-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:8px;border-top:1px solid var(--border)}.profile-cancel-btn{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:9px 20px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .18s}.profile-cancel-btn:hover{border-color:var(--text);color:var(--text)}.profile-save-btn{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:9px 20px;background:transparent;border:1px solid #00ff88;color:#0f8;cursor:pointer;transition:all .18s}.profile-save-btn:hover:not(:disabled){background:#00ff8815}.profile-save-btn.ok{background:#00ff8820}.profile-save-btn.error{border-color:var(--accent2);color:var(--accent2)}.profile-save-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:860px){#top-bar{padding:0 20px}.profile-main{padding:24px 20px}}.hero-nav{display:flex;gap:8px;margin-bottom:24px}.hero-nav-link{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;border:1px solid var(--border);padding:6px 14px;transition:all .2s}.hero-nav-link:hover{color:var(--accent);border-color:var(--accent)}.page-header{padding:24px 76px 20px;border-bottom:1px solid var(--border)}.page-header-inner{display:flex;align-items:center;gap:24px}.page-back-link{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;border:1px solid var(--border);padding:6px 14px;transition:all .2s}.page-back-link:hover{color:var(--accent);border-color:var(--accent)}.page-header-title-wrap{display:flex;align-items:baseline;gap:12px}.page-title{font-family:Bebas Neue,sans-serif;font-size:28px;letter-spacing:.08em;color:var(--text);line-height:1}.page-title-sub{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted);letter-spacing:.06em}.estudiantes-main{padding:32px 76px}.estudiantes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media(max-width:1200px){.estudiantes-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:860px){.estudiantes-grid{grid-template-columns:repeat(2,1fr)}.estudiantes-main{padding:24px 40px}.page-header{padding:20px 40px 16px}}@media(max-width:560px){.estudiantes-grid{grid-template-columns:1fr}.estudiantes-main{padding:20px 16px}.page-header{padding:16px 16px 12px}}.estudiantes-loading{display:flex;justify-content:center;align-items:center;gap:8px;padding:80px 0}.estudiantes-loading-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dotPulse 1.2s ease-in-out infinite}.estudiantes-loading-dot:nth-child(2){animation-delay:.2s}.estudiantes-loading-dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.estudiantes-empty{text-align:center;padding:80px 0;color:var(--muted);font-size:14px}.student-card{background:var(--surface);border:1px solid var(--border);padding:14px 20px;display:flex;flex-direction:column;gap:10px;transition:border-color .2s}.student-card:hover{border-color:#2e3a50}.student-card-header{display:flex;align-items:center;gap:14px}.student-avatar{width:36px;height:36px;border-radius:50%;background:var(--surface2);border:1px solid #00ff8840;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;color:#0f8;flex-shrink:0;letter-spacing:.05em}.student-card-info{display:flex;flex-direction:column;gap:4px;min-width:0}.student-name{font-family:Bebas Neue,sans-serif;font-size:20px;letter-spacing:.06em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1}.student-role-badge{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.student-chart-wrap{display:flex;flex-direction:column;align-items:center;position:relative}.student-chart-empty{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--muted);margin-top:8px;letter-spacing:.05em}.student-models{border-top:1px solid var(--border);padding-top:14px}.student-models-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.student-models-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.student-model-thumb{position:relative;aspect-ratio:1;background:var(--surface2);border:1px solid;overflow:hidden}.student-model-thumb-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.student-model-thumb-title{position:absolute;bottom:0;left:0;right:0;padding:3px 5px;background:#080a0ed9;font-family:JetBrains Mono,monospace;font-size:8px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-no-models{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--muted);letter-spacing:.05em;border-top:1px solid var(--border);padding-top:14px}.skills-editor{background:var(--surface);border:1px solid #00ff8830;padding:28px 32px;margin-bottom:40px}.skills-editor-title{display:flex;align-items:center;gap:8px;font-family:Bebas Neue,sans-serif;font-size:20px;letter-spacing:.08em;color:#0f8;margin-bottom:20px}.skills-editor-row{display:flex;align-items:center;gap:12px;margin-bottom:20px}.skills-editor-label{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);white-space:nowrap;min-width:80px}.skills-editor-select{flex:1;max-width:320px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:13px;padding:8px 12px;cursor:pointer;outline:none;transition:border-color .2s}.skills-editor-select:focus{border-color:#00ff8860}.skills-editor-sliders{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px 32px;margin-bottom:24px}.skills-slider-row{display:grid;grid-template-columns:130px 1fr 36px;align-items:center;gap:10px}.skills-slider-label{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.05em;color:var(--muted);white-space:nowrap}.skills-slider{-moz-appearance:none;appearance:none;-webkit-appearance:none;height:3px;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.skills-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#0f8;cursor:pointer;transition:transform .15s}.skills-slider::-webkit-slider-thumb:hover{transform:scale(1.25)}.skills-slider-value{font-family:JetBrains Mono,monospace;font-size:12px;color:#0f8;text-align:right}.skills-editor-footer{display:flex;justify-content:flex-end}.skills-save-btn{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:10px 24px;border:1px solid #00ff88;background:transparent;color:#0f8;cursor:pointer;transition:all .2s}.skills-save-btn:hover:not(:disabled){background:#00ff8815}.skills-save-btn.ok{border-color:#0f8;background:#00ff8820}.skills-save-btn.error{border-color:var(--accent2);color:var(--accent2)}.skills-save-btn.saving{opacity:.6;cursor:not-allowed}.skills-save-btn:disabled{opacity:.4;cursor:not-allowed}.skills-editor-links{border-top:1px solid var(--border);padding-top:16px;margin-bottom:4px;display:flex;flex-direction:column;gap:8px}.skills-editor-input{flex:1;max-width:400px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:JetBrains Mono,monospace;font-size:11px;padding:7px 12px;outline:none;transition:border-color .2s}.skills-editor-input:focus{border-color:#00ff8860}.skills-editor-input::placeholder{color:var(--muted)}.student-card-wrap{display:flex;flex-direction:column}.student-admin-actions{display:flex;gap:6px;padding:6px 10px;background:var(--surface2);border:1px solid var(--border);border-top:none}.student-admin-btn{display:inline-flex;align-items:center;gap:5px;font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.04em;text-transform:uppercase;padding:4px 8px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all .18s}.student-admin-btn--clear{color:#a8b4c4}.student-admin-btn--clear:hover{color:#fbbf24;border-color:#fbbf2460}.student-admin-btn--delete{color:#a8b4c4}.student-admin-btn--delete:hover{color:#ff4d00;border-color:#ff4d0060}.student-bio-card{background:var(--surface2);border:1px solid var(--border);border-top:none;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:38px}.student-bio-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.student-bio-link{display:inline-flex;align-items:center;gap:5px;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.04em;text-decoration:none;padding:3px 8px;border:1px solid transparent;transition:all .18s}.student-bio-link--artstation{color:#a8b4c4;border-color:#2a3040}.student-bio-link--artstation:hover{color:#13aff0;border-color:#13aff060}.student-bio-link--instagram{color:#a8b4c4;border-color:#2a3040}.student-bio-link--instagram:hover{color:#e1306c;border-color:#e1306c60}.student-bio-link--empty{font-family:JetBrains Mono,monospace;font-size:9px;color:#3a4455;letter-spacing:.04em}.student-bio-edit-btn{background:transparent;border:1px solid var(--border);color:var(--muted);padding:4px 7px;cursor:pointer;transition:all .18s;flex-shrink:0}.student-bio-edit-btn:hover{border-color:#00ff8860;color:#0f8}.student-bio-edit-form{display:flex;flex-direction:column;gap:6px;width:100%}.student-bio-input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:JetBrains Mono,monospace;font-size:10px;padding:5px 10px;outline:none;transition:border-color .2s}.student-bio-input:focus{border-color:#00ff8860}.student-bio-input::placeholder{color:#3a4455}.student-bio-edit-actions{display:flex;gap:6px;justify-content:flex-end}.student-bio-cancel-btn{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .18s}.student-bio-cancel-btn:hover{border-color:var(--text);color:var(--text)}.student-bio-save-btn{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;background:transparent;border:1px solid #00ff88;color:#0f8;cursor:pointer;transition:all .18s}.student-bio-save-btn:hover:not(:disabled){background:#00ff8815}.student-bio-save-btn.ok{background:#00ff8820}.student-bio-save-btn.error{border-color:var(--accent2);color:var(--accent2)}.student-bio-save-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.page-header{padding:20px 20px 16px}.estudiantes-main{padding:24px 20px}.estudiantes-grid{grid-template-columns:1fr}.skills-editor{padding:20px}.skills-editor-sliders{grid-template-columns:1fr}.hero-nav{margin-bottom:16px}}
