@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--bg-gradient:linear-gradient(135deg, #07050f 0%, #0d0a1a 50%, #150f2b 100%);--bg-color:#07050f;--color-primary:#8b5cf6;--color-primary-hover:#7c3aed;--color-secondary:#06b6d4;--color-accent:#ec4899;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--text-main:#f3f4f6;--text-muted:#9ca3af;--text-inverse:#fff;--glass-bg:#14102473;--glass-border:#ffffff14;--glass-border-hover:#8b5cf64d;--glass-shadow:0 8px 32px 0 #00000080;--font-family-title:"Outfit", sans-serif;--font-family-body:"Plus Jakarta Sans", sans-serif;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--border-radius-sm:8px;--border-radius-md:16px;--border-radius-lg:24px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-main);font-family:var(--font-family-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-title);letter-spacing:-.02em;font-weight:700}.glowing-bg-orbs{z-index:-1;pointer-events:none;width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:hidden}.orb{filter:blur(150px);opacity:.15;border-radius:50%;position:absolute}.orb-1{background:var(--color-primary);width:45vw;height:45vw;animation:20s infinite alternate floatOrb;top:-10%;right:10%}.orb-2{background:var(--color-secondary);width:50vw;height:50vw;animation:25s infinite alternate-reverse floatOrb;bottom:-10%;left:10%}@keyframes floatOrb{0%{transform:translate(0)scale(1)}to{transform:translate(5%,5%)scale(1.1)}}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--border-radius-md);box-shadow:var(--glass-shadow);transition:var(--transition-smooth);padding:2rem}.glass-card:hover{border-color:var(--glass-border-hover)}.navbar{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);z-index:100;background:#0a0816b3;justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex;position:sticky;top:0}.brand{cursor:pointer;align-items:center;gap:.75rem;display:flex}.brand-logo{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 0 15px #8b5cf666}.brand-name{background:linear-gradient(135deg, #fff 30%, var(--text-muted) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.5rem;font-weight:800}.nav-links{gap:1rem;display:flex}.nav-btn{color:var(--text-muted);font-family:var(--font-family-body);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:500;display:flex}.nav-btn:hover,.nav-btn.active{color:var(--text-main);background:#ffffff0d}.nav-btn.active{color:#fff;background:#8b5cf626;box-shadow:inset 0 0 0 1px #ffffff1a}.portal-selector{flex-direction:column;justify-content:center;align-items:center;gap:2.5rem;min-height:75vh;display:flex}.portal-title-area{text-align:center}.portal-title-area h1{background:linear-gradient(135deg,#fff 40%,#a78bfa 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:3rem}.portal-title-area p{color:var(--text-muted);font-size:1.125rem}.portals-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;width:100%;max-width:960px;display:grid}.portal-card{cursor:pointer;border-radius:var(--border-radius-lg);text-align:center;flex-direction:column;align-items:center;gap:1.25rem;padding:2.5rem 2rem;display:flex;position:relative;overflow:hidden}.portal-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));opacity:0;width:100%;height:4px;transition:var(--transition-smooth);position:absolute;top:0;left:0}.portal-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px #8b5cf626}.portal-card:hover:before{opacity:1}.portal-icon{width:70px;height:70px;color:var(--color-primary);transition:var(--transition-smooth);background:#8b5cf61a;border-radius:20px;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.portal-card:hover .portal-icon{background:var(--color-primary);color:var(--text-inverse);box-shadow:0 0 20px #8b5cf666}.portal-card.organizer:hover .portal-icon{background:var(--color-secondary);color:var(--text-inverse);box-shadow:0 0 20px #06b6d466}.portal-card.organizer .portal-icon{color:var(--color-secondary);background:#06b6d41a}.portal-card.lookup:hover .portal-icon{background:var(--color-accent);color:var(--text-inverse);box-shadow:0 0 20px #ec489966}.portal-card.lookup .portal-icon{color:var(--color-accent);background:#ec48991a}.btn{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-hover) 100%);color:var(--text-inverse);font-family:var(--font-family-body);border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition-smooth);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;display:flex;box-shadow:0 4px 15px #8b5cf633}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf659}.btn:active{transform:translateY(0)}.btn-secondary{border:1px solid var(--glass-border);color:var(--text-main);box-shadow:none;background:#ffffff14}.btn-secondary:hover{color:#fff;box-shadow:none;background:#ffffff26;border-color:#fff3}.btn-accent{background:linear-gradient(135deg, var(--color-accent) 0%, #d946ef 100%);box-shadow:0 4px 15px #ec489940}.btn-accent:hover{box-shadow:0 6px 20px #ec489966}.btn-cyan{background:linear-gradient(135deg, var(--color-secondary) 0%, #0891b2 100%);box-shadow:0 4px 15px #06b6d440}.btn-cyan:hover{box-shadow:0 6px 20px #06b6d466}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important;transform:none!important}.dropzone{border-radius:var(--border-radius-md);text-align:center;cursor:pointer;transition:var(--transition-smooth);background:#ffffff05;border:2px dashed #ffffff26;flex-direction:column;align-items:center;gap:1rem;padding:3rem 2rem;display:flex}.dropzone:hover,.dropzone.drag-active{border-color:var(--color-primary);background:#8b5cf60d}.dropzone-icon{color:var(--text-muted);transition:var(--transition-smooth)}.dropzone:hover .dropzone-icon{color:var(--color-primary);transform:translateY(-4px)}.file-input{display:none}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-muted);font-size:.875rem;font-weight:600}.form-control{border:1px solid var(--glass-border);border-radius:var(--border-radius-sm);color:#fff;font-family:var(--font-family-body);transition:var(--transition-smooth);background:#ffffff0d;padding:.75rem 1rem;font-size:.95rem}.form-control:focus{border-color:var(--color-primary);background:#ffffff14;outline:none;box-shadow:0 0 0 3px #8b5cf640}.ai-status-bar{border-radius:var(--border-radius-sm);background:#8b5cf61a;border:1px solid #8b5cf633;align-items:center;gap:.75rem;margin-bottom:2rem;padding:.75rem 1.25rem;display:flex}.loader-spinner{border:2px solid #ffffff1a;border-top-color:var(--color-primary);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.profile-card{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;display:flex}.profile-avatar{object-fit:cover;border:3px solid var(--color-primary);border-radius:50%;width:140px;height:140px;box-shadow:0 0 20px #8b5cf64d}.profile-name{margin-bottom:.25rem;font-size:1.75rem;font-weight:800}.profile-role{color:var(--color-secondary);background:#06b6d41a;border-radius:20px;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.95rem;font-weight:600;display:inline-block}.profile-bio{color:var(--text-muted);max-width:400px;font-size:.95rem;line-height:1.5}.gallery-section{margin-top:2rem}.gallery-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;display:grid}.gallery-item{border-radius:var(--border-radius-md);border:1px solid var(--glass-border);aspect-ratio:4/3;cursor:pointer;transition:var(--transition-smooth);background:#ffffff05;position:relative;overflow:hidden;box-shadow:0 4px 10px #0003}.gallery-item:hover{border-color:#fff3;transform:scale(1.02);box-shadow:0 8px 25px #0006}.gallery-img{object-fit:cover;width:100%;height:100%;transition:var(--transition-smooth)}.gallery-item:hover .gallery-img{transform:scale(1.05)}.gallery-item-overlay{opacity:0;transition:var(--transition-smooth);background:linear-gradient(#0000 0%,#000c 100%);justify-content:space-between;align-items:flex-end;padding:1.25rem 1rem;display:flex;position:absolute;bottom:0;left:0;right:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-info{flex-direction:column;gap:.25rem;display:flex}.gallery-item-uploader{color:var(--text-muted);font-size:.75rem}.gallery-item-date{color:#fff6;font-size:.7rem}.lightbox-modal{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#05030cf2;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.lightbox-content{flex-direction:column;align-items:center;max-width:90vw;max-height:85vh;display:flex;position:relative}.lightbox-img-wrapper{display:inline-block;position:relative}.lightbox-img{border-radius:var(--border-radius-sm);max-width:90vw;max-height:75vh;display:block;box-shadow:0 10px 40px #0009}.face-highlight-box{pointer-events:none;border:3px solid #10b981;border-radius:4px;animation:2s infinite alternate pulseBox;position:absolute;box-shadow:0 0 15px #10b981,inset 0 0 8px #10b98180}@keyframes pulseBox{0%{opacity:.8;transform:scale(1)}to{opacity:1;transform:scale(1.02)}}.lightbox-close{border:1px solid var(--glass-border);color:#fff;cursor:pointer;width:36px;height:36px;transition:var(--transition-smooth);background:#ffffff14;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:-45px;right:0}.lightbox-close:hover{background:#fff3;transform:rotate(90deg)}.lightbox-meta{text-align:center;align-items:center;gap:1.5rem;margin-top:1rem;display:flex}.upload-queue{flex-direction:column;gap:.75rem;margin-top:2rem;display:flex}.queue-title{color:var(--text-main);margin-bottom:.5rem;font-size:1.1rem}.queue-item{border:1px solid var(--glass-border);border-radius:var(--border-radius-sm);background:#ffffff08;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.queue-item-info{flex:1;align-items:center;gap:.75rem;display:flex}.queue-thumbnail{object-fit:cover;border-radius:6px;width:40px;height:40px}.queue-filename{text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:.875rem;overflow:hidden}.queue-status{border-radius:12px;padding:.15rem .5rem;font-size:.8rem;font-weight:600}.queue-status.pending{color:var(--text-muted);background:#ffffff14}.queue-status.processing{color:#c084fc;background:#8b5cf626}.queue-status.completed{color:#34d399;background:#10b98126}.queue-status.failed{color:#f87171;background:#ef444426}.webcam-container{aspect-ratio:4/3;border-radius:var(--border-radius-md);border:2px solid var(--glass-border);background:#000;width:100%;max-width:400px;margin:0 auto 1.5rem;position:relative;overflow:hidden}.webcam-video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.webcam-overlay{pointer-events:none;border:2px solid #0000;width:100%;height:100%;position:absolute;top:0;left:0}.webcam-face-indicator{border:2px dashed #ffffff4d;border-radius:50%;width:200px;height:250px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.webcam-actions{justify-content:center;gap:1rem;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{text-align:center;padding:1.5rem}.stat-val{background:linear-gradient(135deg, var(--color-primary) 30%, var(--color-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.25rem;font-size:2.25rem;font-weight:800}.stat-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.search-container{gap:1rem;max-width:600px;margin-bottom:2rem;display:flex}.search-input-wrapper{flex:1;position:relative}.search-input-icon{color:var(--text-muted);position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.search-input{width:100%;padding-left:2.5rem}.contributors-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.contributor-list-card{cursor:pointer;transition:var(--transition-smooth);text-align:left;align-items:center;gap:1.25rem;padding:1.25rem;display:flex}.contributor-list-card:hover{border-color:var(--glass-border-hover);transform:translateY(-4px)}.contributor-list-avatar{object-fit:cover;border:2px solid var(--color-secondary);border-radius:50%;width:60px;height:60px}.contributor-list-info h3{margin-bottom:.15rem;font-size:1.1rem}.contributor-list-info p{color:var(--text-muted);font-size:.8rem}.layout-grid{grid-template-columns:repeat(12,1fr);gap:2rem;display:grid}.sidebar-col{flex-direction:column;grid-column:span 4;gap:2rem;display:flex}.main-col{grid-column:span 8}.dashboard-actions{flex-wrap:wrap;gap:1rem;display:flex}.navbar-username{color:var(--text-muted);align-self:center;margin-right:1rem;font-size:.85rem}@media (width<=768px){.navbar{padding:1rem}.nav-links{gap:.25rem}.nav-btn{padding:.5rem .75rem;font-size:.85rem}.nav-btn span{display:none}.portal-title-area h1{font-size:2.25rem}.main-content{padding:1rem}.layout-grid{grid-template-columns:1fr;gap:1.5rem}.sidebar-col{grid-column:span 12;gap:1.5rem}.main-col{grid-column:span 12}.dashboard-actions{flex-direction:column;gap:.75rem;width:100%}.dashboard-actions .btn{width:100%}.navbar-username{display:none}}
