:root{--bg-deep: #0a0a0f;--bg-primary: #101018;--bg-surface: #16161f;--bg-elevated: #1c1c28;--accent-primary: #7c3aed;--accent-secondary: #a78bfa;--accent-glow: rgba(124, 58, 237, .35);--gradient-accent: linear-gradient(135deg, #7c3aed 0%, #3b82f6 100%);--gradient-accent-hover: linear-gradient(135deg, #6d28d9 0%, #2563eb 100%);--text-primary: #f0f0f5;--text-secondary: #a1a1b5;--text-muted: #6b6b80;--border-subtle: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .12);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 8px 24px rgba(0, 0, 0, .4);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px var(--accent-glow);--font-heading: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--transition-fast: .2s var(--ease-out-expo);--transition-normal: .35s var(--ease-out-expo);--transition-slow: .6s var(--ease-out-expo);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--netflix-red: var(--accent-primary);--netflix-black: var(--bg-deep);--background-black: var(--bg-deep);--text-white: var(--text-primary);--text-gray: var(--text-secondary);--gray-dark: #333;--gray-light: var(--text-secondary);--font-primary: var(--font-body)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-deep);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.15}button{cursor:pointer;border:none;background:none;font-family:inherit}a{text-decoration:none;color:inherit}img{display:block;max-width:100%}::-webkit-scrollbar{width:6px;background-color:var(--bg-deep)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}.container{max-width:1400px;margin:0 auto;padding:0 4%}.glass{background:#16161f99;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle)}.gradient-text{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow),0 0 60px #7c3aed26}}.profile-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-deep);position:relative;overflow:hidden;animation:fadeIn .6s var(--ease-out-expo)}.profile-gate:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.08) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.gate-title{font-family:var(--font-heading);font-size:3.2rem;font-weight:600;margin-bottom:2.5rem;text-align:center;color:var(--text-primary);letter-spacing:-.5px;position:relative;z-index:1}.profile-list{display:flex;gap:2.5rem;flex-wrap:wrap;justify-content:center;max-width:1200px;position:relative;z-index:1}.profile-item{display:flex;flex-direction:column;align-items:center;cursor:pointer;max-width:200px;transition:transform .35s var(--ease-out-expo)}.profile-item:hover{transform:scale(1.08) translateY(-4px)}.profile-item:hover .profile-name{color:var(--text-primary)}.profile-avatar{width:150px;height:150px;border-radius:var(--radius-md);margin-bottom:1rem;border:3px solid transparent;transition:border-color .3s var(--ease-out-expo),box-shadow .3s var(--ease-out-expo);object-fit:cover}.profile-item:hover .profile-avatar{border-color:var(--accent-primary);box-shadow:0 0 24px var(--accent-glow),var(--shadow-md)}.profile-name{font-family:var(--font-heading);font-size:1.4rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;transition:color .25s var(--ease-out-expo)}.profile-desc{font-size:.85rem;color:var(--text-muted);text-align:center;line-height:1.3}.manage-btn{margin-top:4rem;border:1px solid var(--border-light);color:var(--text-secondary);padding:.6rem 1.8rem;font-size:1rem;font-weight:500;text-transform:uppercase;letter-spacing:2px;border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative;z-index:1}.manage-btn:hover{color:var(--text-primary);border-color:var(--accent-primary);box-shadow:0 0 16px var(--accent-glow)}@media(max-width:768px){.gate-title{font-size:2.2rem}.profile-list{flex-direction:column;align-items:center}.profile-avatar{width:120px;height:120px}}.nav{position:fixed;top:0;width:100%;height:72px;z-index:100;padding:0 24px;transition:all .5s var(--ease-out-expo);background:linear-gradient(to bottom,rgba(10,10,15,.8) 0%,transparent 100%)}.nav-black{background:#0a0a0fd9;backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--border-subtle);box-shadow:0 4px 30px #0006}.nav-contents{display:flex;justify-content:space-between;align-items:center;height:100%;width:100%;max-width:1400px;margin:0 auto}.nav-logo{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:3px;margin-right:30px;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:opacity var(--transition-fast)}.nav-logo:hover{opacity:.85}.nav-avatar{width:36px;height:36px;cursor:pointer;border-radius:var(--radius-sm);border:2px solid transparent;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.nav-avatar:hover{border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-glow)}@media(max-width:768px){.nav{height:60px;padding:0 16px}.nav-logo{font-size:1.1rem;letter-spacing:2px;margin-right:12px}.nav-links{font-size:.8rem}}.hero{height:520px;position:relative;object-fit:contain;color:#fff;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#0a0a0fd9,#0a0a0f80 40%,#7c3aed14);z-index:1}.hero-contents{position:relative;z-index:2;margin-left:4%;padding-top:160px;max-width:600px;animation:fadeInUp .8s var(--ease-out-expo) both}.hero-title{font-family:var(--font-heading);font-size:3.5rem;font-weight:800;padding-bottom:.5rem;letter-spacing:-.5px;line-height:1.1}.hero-description{max-width:480px;line-height:1.5;padding-top:1rem;font-size:1rem;color:var(--text-secondary);font-weight:400;animation:fadeInUp .8s var(--ease-out-expo) .15s both}.hero-buttons{display:flex;gap:.75rem;margin-top:.5rem;animation:fadeInUp .8s var(--ease-out-expo) .3s both}.hero-button{cursor:pointer;color:var(--text-primary);outline:none;border:none;font-weight:600;font-size:.95rem;border-radius:var(--radius-sm);padding:.65rem 1.8rem;transition:all var(--transition-fast);position:relative;overflow:hidden}.hero-button:first-child{background:var(--gradient-accent);box-shadow:0 4px 20px var(--accent-glow)}.hero-button:first-child:hover{background:var(--gradient-accent-hover);box-shadow:0 6px 28px var(--accent-glow);transform:translateY(-2px)}.hero-button:last-child{background:#ffffff14;border:1px solid var(--border-light);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.hero-button:last-child:hover{background:#ffffff24;border-color:#ffffff40;transform:translateY(-2px)}.hero-fadeBottom{height:10rem;background:linear-gradient(180deg,transparent 0%,var(--bg-deep) 100%);position:absolute;bottom:0;width:100%;z-index:2}@media(max-width:768px){.hero{height:380px}.hero-contents{margin-left:5%;padding-top:100px}.hero-title{font-size:2.2rem}.hero-description{max-width:90%;font-size:.85rem}.hero-buttons{flex-direction:column;gap:.5rem}}.card{position:relative;width:100%;cursor:pointer;border-radius:var(--radius-md);overflow:hidden;transition:transform .4s var(--ease-out-expo),box-shadow .4s var(--ease-out-expo);background:var(--bg-surface)}.card:hover{transform:scale(1.06) translateY(-4px);z-index:10;box-shadow:var(--shadow-lg),0 0 25px var(--accent-glow)}.card-image{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:transform .6s var(--ease-out-expo)}.card:hover .card-image{transform:scale(1.04)}.card-image.portrait{aspect-ratio:2/3}.card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(10,10,15,.95) 0%,rgba(10,10,15,.6) 50%,transparent 100%);padding:16px 12px 12px;opacity:0;transform:translateY(8px);transition:opacity .35s var(--ease-out-expo),transform .35s var(--ease-out-expo)}.card:hover .card-overlay{opacity:1;transform:translateY(0)}.card-title{font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:6px}.card-meta{display:flex;gap:6px}.card-tag{font-size:.65rem;font-weight:500;background:#7c3aed33;color:var(--accent-secondary);padding:2px 8px;border-radius:var(--radius-full);border:1px solid rgba(124,58,237,.15)}.row{margin-left:4%;color:#fff;margin-bottom:2.5rem;position:relative}.row-title{font-family:var(--font-heading);margin-bottom:.75rem;font-size:1.4rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px;position:relative;display:inline-block}.row-title:after{content:"";position:absolute;bottom:-4px;left:0;width:32px;height:3px;background:var(--gradient-accent);border-radius:var(--radius-full)}.row-container{position:relative}.row-container:hover .slider-arrow{opacity:1}.slider-arrow{position:absolute;top:0;bottom:0;width:48px;z-index:100;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all .3s var(--ease-out-expo);background:linear-gradient(to right,rgba(10,10,15,.7),transparent)}.slider-arrow.right{background:linear-gradient(to left,rgba(10,10,15,.7),transparent)}.slider-arrow:hover{background:linear-gradient(to right,rgba(10,10,15,.9),transparent)}.slider-arrow.right:hover{background:linear-gradient(to left,rgba(10,10,15,.9),transparent)}.slider-arrow.left{left:0;border-top-right-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm)}.slider-arrow.right{right:0;border-top-left-radius:var(--radius-sm);border-bottom-left-radius:var(--radius-sm)}.slider-arrow svg{width:32px;height:32px;color:var(--text-secondary);transition:color var(--transition-fast),transform var(--transition-fast)}.slider-arrow:hover svg{color:var(--accent-secondary);transform:scale(1.2)}.row-posters{display:flex;overflow-y:hidden;overflow-x:scroll;padding:16px 0;gap:14px;scroll-behavior:smooth}.row-posters::-webkit-scrollbar{display:none}.row-posters{-ms-overflow-style:none;scrollbar-width:none}.row-poster-container{width:260px;flex:none;transition:transform .4s var(--ease-out-expo)}.row-poster-container.portrait{width:180px}.row-poster-container:hover{z-index:100}.admin-dashboard{padding:2rem;color:var(--text-primary);max-width:1000px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-bottom:1px solid var(--border-subtle);padding-bottom:1rem}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.stat-card{background:var(--bg-surface);padding:1.5rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:box-shadow var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md),0 0 16px var(--accent-glow)}.stat-number{font-family:var(--font-heading);font-size:2.8rem;font-weight:800;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.role-list{list-style:none;margin-top:1rem}.role-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.role-item:last-child{border-bottom:none}.clear-btn{margin-top:3rem;background:var(--gradient-accent);color:#fff;padding:.6rem 1.5rem;border-radius:var(--radius-sm);font-weight:700;transition:all var(--transition-fast);box-shadow:0 4px 16px var(--accent-glow)}.clear-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--accent-glow)}.admin-projects,.admin-project-form-page{padding:2rem 3rem;color:var(--text-primary);max-width:1100px;margin:0 auto;min-height:100vh;animation:fadeIn .3s ease}.admin-projects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle)}.header-left{display:flex;align-items:center;gap:1rem}.header-left h1{font-family:var(--font-heading);font-size:1.6rem;font-weight:700}.admin-back-btn{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-subtle);padding:6px 14px;border-radius:var(--radius-sm);font-size:13px;transition:all var(--transition-fast)}.admin-back-btn:hover{color:var(--text-primary);border-color:var(--border-light)}.project-count{background:var(--bg-elevated);color:var(--text-muted);padding:4px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600}.admin-add-btn{display:flex;align-items:center;gap:6px;background:var(--gradient-accent);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);font-weight:700;font-size:14px;transition:all var(--transition-fast);box-shadow:0 4px 16px var(--accent-glow)}.admin-add-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--accent-glow)}.category-stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.25rem}.category-stat-chip{display:flex;align-items:center;gap:6px;background:var(--bg-elevated);border:1px solid var(--border-subtle);padding:6px 14px;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);font-size:13px}.category-stat-chip:hover{border-color:var(--accent-primary)}.category-stat-chip.active{background:#7c3aed26;border-color:var(--accent-primary)}.chip-name{color:var(--text-secondary)}.category-stat-chip.active .chip-name{color:var(--accent-secondary)}.chip-count{background:var(--bg-surface);color:var(--text-muted);padding:1px 7px;border-radius:var(--radius-full);font-size:11px;font-weight:700}.admin-projects-toolbar{display:flex;gap:12px;margin-bottom:1.5rem}.search-wrapper{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:0 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-glow)}.search-wrapper svg{color:var(--text-muted);flex-shrink:0}.admin-search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);height:42px;font-size:14px}.admin-filter-select{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);padding:0 14px;height:42px;font-size:14px;cursor:pointer;transition:border-color var(--transition-fast)}.admin-filter-select:focus{outline:none;border-color:var(--accent-primary)}.admin-projects-list{display:flex;flex-direction:column;gap:6px}.admin-project-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--transition-fast)}.admin-project-row:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm)}.project-row-thumb{width:56px;height:56px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.project-row-thumb img{width:100%;height:100%;object-fit:cover}.thumb-placeholder{width:100%;height:100%;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;color:#fff}.project-row-info{flex:1;min-width:0}.project-row-info h3{font-family:var(--font-heading);font-size:15px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-row-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.meta-cat{font-size:12px;color:var(--accent-secondary);font-weight:500}.meta-tech{font-size:11px;color:var(--text-muted);background:var(--bg-elevated);padding:1px 8px;border-radius:var(--radius-full)}.meta-tech.more{color:var(--text-muted);font-style:italic}.project-row-actions{display:flex;gap:6px;flex-shrink:0}.action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-secondary);transition:all var(--transition-fast)}.action-btn:hover{border-color:var(--border-light);color:var(--text-primary)}.action-btn.delete:hover{border-color:#f87171;color:#f87171;background:#f8717114}.admin-projects-empty{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.admin-projects-empty svg{margin-bottom:1rem;opacity:.3}.admin-projects-empty button{margin-top:1rem;color:var(--accent-secondary);font-size:13px}.admin-projects-empty button:hover{text-decoration:underline}.admin-projects-loading{text-align:center;padding:6rem 2rem;color:var(--text-muted)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.admin-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.admin-modal{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:2rem;max-width:420px;width:90%;box-shadow:var(--shadow-lg);animation:scaleUp .2s var(--ease-out-expo)}.admin-modal h2{font-family:var(--font-heading);font-size:1.2rem;margin-bottom:.75rem}.admin-modal p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:1.5rem}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-cancel{padding:10px 20px;border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-subtle);font-weight:600;font-size:14px;transition:all var(--transition-fast)}.modal-cancel:hover{color:var(--text-primary);border-color:var(--border-light)}.modal-confirm{padding:10px 20px;border-radius:var(--radius-sm);background:#ef4444;color:#fff;font-weight:700;font-size:14px;transition:all var(--transition-fast)}.modal-confirm:hover{background:#dc2626}.modal-confirm:disabled,.modal-cancel:disabled{opacity:.5;cursor:not-allowed}.admin-project-form{display:flex;flex-direction:column;gap:1.5rem}.form-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px 16px;border-radius:var(--radius-sm);font-size:14px}.form-section{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.5rem}.form-section-title{font-family:var(--font-heading);font-size:1rem;font-weight:700;margin-bottom:1.25rem;color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-input,.form-textarea,.form-select{width:100%;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 14px;font-size:14px;font-family:var(--font-body);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-glow)}.form-textarea{resize:vertical;min-height:120px;line-height:1.6}.form-row{display:flex;gap:1rem;align-items:flex-start}.flex-1{flex:1}.toggle-custom-cat{margin-top:6px;font-size:12px;color:var(--accent-secondary);background:none;border:none;cursor:pointer;padding:0}.toggle-custom-cat:hover{text-decoration:underline}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;font-size:14px!important;color:var(--text-primary)!important;padding-top:1rem}.checkbox-label input[type=checkbox]{accent-color:var(--accent-primary);width:16px;height:16px}.chip-input-wrapper{display:flex;flex-direction:column;gap:8px}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;gap:4px;background:#7c3aed1f;border:1px solid rgba(124,58,237,.25);color:var(--accent-secondary);padding:4px 10px;border-radius:var(--radius-full);font-size:13px;font-weight:500}.chip button{background:none;border:none;color:var(--accent-secondary);cursor:pointer;padding:1px;display:flex;opacity:.6;transition:opacity var(--transition-fast)}.chip button:hover{opacity:1}.chip-input-row{display:flex;gap:8px}.chip-input-row .form-input{flex:1}.chip-add-btn{width:42px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.chip-add-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.work-items-list{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.work-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:14px;color:var(--text-secondary)}.work-item .grip-icon{color:var(--text-muted);flex-shrink:0;opacity:.4}.work-item span{flex:1}.work-item button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;opacity:0;transition:opacity var(--transition-fast)}.work-item:hover button{opacity:1}.work-item button:hover{color:#f87171}.thumbnail-area{display:flex;flex-direction:column;gap:8px}.thumbnail-preview{position:relative;width:200px;height:120px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-subtle)}.thumbnail-preview img{width:100%;height:100%;object-fit:cover}.remove-thumb{position:absolute;top:6px;right:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#000000b3;border:1px solid rgba(255,255,255,.1);border-radius:50%;color:#fff;cursor:pointer;transition:all var(--transition-fast)}.remove-thumb:hover{background:#ef4444cc}.thumbnail-dropzone{width:200px;height:120px;border:2px dashed var(--border-light);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.thumbnail-dropzone:hover{border-color:var(--accent-primary);color:var(--accent-secondary);background:#7c3aed0a}.thumbnail-dropzone p{font-size:12px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.gallery-item{display:flex;flex-direction:column;gap:6px}.gallery-item-img{position:relative;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-subtle);aspect-ratio:16 / 10}.gallery-item-img img{width:100%;height:100%;object-fit:cover}.gallery-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;opacity:0;transition:opacity var(--transition-fast)}.gallery-item:hover .gallery-remove{opacity:1}.gallery-caption-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-secondary);padding:4px 8px;font-size:12px;font-family:var(--font-body)}.gallery-caption-input:focus{outline:none;border-color:var(--accent-primary)}.gallery-add-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:2px dashed var(--border-light);border-radius:var(--radius-sm);aspect-ratio:16 / 10;cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.gallery-add-card:hover{border-color:var(--accent-primary);color:var(--accent-secondary);background:#7c3aed0a}.gallery-add-card p{font-size:12px}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding:1.5rem 0;border-top:1px solid var(--border-subtle)}.form-cancel-btn{padding:12px 24px;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-weight:600;font-size:14px;transition:all var(--transition-fast)}.form-cancel-btn:hover{color:var(--text-primary);border-color:var(--border-light)}.form-save-btn{padding:12px 28px;background:var(--gradient-accent);color:#fff;border-radius:var(--radius-sm);font-weight:700;font-size:14px;transition:all var(--transition-fast);box-shadow:0 4px 16px var(--accent-glow)}.form-save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--accent-glow)}.form-save-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.admin-nav-tabs{display:flex;gap:4px;margin-bottom:2rem;background:var(--bg-surface);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-subtle)}.admin-nav-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;background:transparent;text-decoration:none}.admin-nav-tab:hover{color:var(--text-primary);background:var(--bg-elevated)}.admin-nav-tab.active{background:var(--gradient-accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.admin-quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.quick-stat{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.2rem;transition:box-shadow var(--transition-fast)}.quick-stat:hover{box-shadow:var(--shadow-sm)}.quick-stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:6px}.quick-stat-value{font-family:var(--font-heading);font-size:1.8rem;font-weight:800;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.seed-section{margin-top:2rem;padding:1.5rem;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.seed-section h3{font-family:var(--font-heading);font-size:1rem;margin-bottom:.5rem}.seed-section p{color:var(--text-secondary);font-size:13px;margin-bottom:1rem}.seed-btn{background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-primary);padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;transition:all var(--transition-fast);cursor:pointer}.seed-btn:hover{border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-glow)}.seed-btn:disabled{opacity:.5;cursor:not-allowed}.seed-success{color:#4ade80;font-size:13px;margin-top:8px}.seed-error{color:#f87171;font-size:13px;margin-top:8px}@media(max-width:720px){.admin-projects,.admin-project-form-page{padding:1.5rem 1rem}.admin-projects-header{flex-direction:column;gap:12px;align-items:flex-start}.admin-projects-toolbar,.form-row{flex-direction:column}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}.admin-settings-page{padding:2rem 3rem;color:var(--text-primary);max-width:1200px;margin:0 auto;min-height:100vh}.settings-layout{display:grid;grid-template-columns:240px 1fr;gap:2rem;margin-top:2rem}.settings-sidebar{display:flex;flex-direction:column;gap:.5rem}.settings-sidebar button{text-align:left;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:600;font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.settings-sidebar button:hover{border-color:var(--border-light);color:var(--text-primary)}.settings-sidebar button.active{background:#7c3aed1a;border-color:var(--accent-primary);color:var(--accent-secondary)}.settings-content{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:2rem}.settings-section h2{font-family:var(--font-heading);font-size:1.4rem;margin-bottom:.5rem}.settings-section h3{font-family:var(--font-heading);font-size:1.1rem;margin-bottom:1rem;color:var(--text-secondary)}.section-desc{color:var(--text-muted);font-size:14px;margin-bottom:1.5rem}.items-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.complex-item-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header h4{font-family:var(--font-heading);font-size:1.1rem}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover{border-color:var(--border-light);color:var(--text-primary)}.icon-btn.danger:hover{border-color:#ef4444;color:#ef4444;background:#ef44441a}.add-item-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:var(--bg-elevated);border:1px dashed var(--border-light);border-radius:var(--radius-md);color:var(--text-muted);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.add-item-btn:hover{border-color:var(--accent-primary);color:var(--accent-secondary);background:#7c3aed0d}.align-center{align-items:center}.align-start{align-items:flex-start}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.divider{border:0;height:1px;background:var(--border-subtle);margin:2rem 0}.admin-bullet-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.bullet-row{display:flex;align-items:center;gap:8px}.success-text{color:#4ade80;font-size:14px;font-weight:600}.error-text{color:#ef4444;font-size:14px;font-weight:600}@media(max-width:768px){.settings-layout{grid-template-columns:1fr}.settings-sidebar{flex-direction:row;overflow-x:auto;padding-bottom:8px}.settings-sidebar button{white-space:nowrap}}.project-details{background-color:var(--bg-deep);min-height:100vh;color:var(--text-primary)}.project-banner{height:70vh;width:100%;background-size:cover;background-position:center;position:relative}.project-banner-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg-deep) 0%,transparent 50%,rgba(10,10,15,.6) 100%)}.project-banner-content{position:absolute;bottom:10%;left:4%;width:90%;max-width:800px;animation:fadeInUp .7s var(--ease-out-expo) both}.project-title{font-family:var(--font-heading);font-size:3.5rem;font-weight:800;margin-bottom:1rem;text-shadow:2px 2px 8px rgba(0,0,0,.8);letter-spacing:-.5px}.project-meta{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem;font-size:1rem;font-weight:600}.match-score{color:#34d399}.year{color:var(--text-muted)}.quality{border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:2px 8px;font-size:.8rem;color:var(--text-secondary)}.project-actions{display:flex;gap:1rem;align-items:center}.btn-visit{background:var(--gradient-accent);color:#fff;padding:.75rem 2.5rem;border-radius:var(--radius-sm);font-weight:700;font-size:1.1rem;text-decoration:none;display:inline-flex;align-items:center;transition:all var(--transition-fast);box-shadow:0 4px 20px var(--accent-glow)}.btn-visit:hover{background:var(--gradient-accent-hover);transform:translateY(-2px);box-shadow:0 6px 28px var(--accent-glow)}.btn-visit.disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-back-hero{background:#ffffff14;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text-primary);padding:.75rem 2rem;border-radius:var(--radius-sm);font-weight:600;font-size:1.1rem;border:1px solid var(--border-light);cursor:pointer;transition:all var(--transition-fast)}.btn-back-hero:hover{background:#ffffff24;border-color:#ffffff40;transform:translateY(-2px)}.project-content{padding:4%;max-width:1400px;margin:0 auto}.project-info-grid{display:grid;grid-template-columns:2fr 1fr;gap:3rem;margin-bottom:3rem}.section-header{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem;border-bottom:1px solid var(--border-subtle);padding-bottom:.5rem}.project-description{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);white-space:pre-line}.project-tagline{font-size:1.2rem;font-style:italic;color:var(--accent-secondary);margin-bottom:1rem;font-weight:500}.project-work-list{margin-top:2.5rem}.project-work-list ul{list-style-type:none;padding-left:0;color:var(--text-secondary);margin-top:1rem}.project-work-list li{margin-bottom:.8rem;font-size:1.05rem;line-height:1.5;padding-left:1.2rem;position:relative}.project-work-list li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent-primary)}.project-sidebar{display:flex;flex-direction:column;gap:1.5rem}.sidebar-section{display:flex;flex-direction:column;gap:.4rem;padding:1rem;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.sidebar-label{color:var(--text-muted);font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:1px}.sidebar-value{color:var(--text-primary);font-weight:500}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{color:var(--accent-secondary);font-size:.85rem;background:#7c3aed14;padding:2px 10px;border-radius:var(--radius-full);border:1px solid rgba(124,58,237,.15)}.tech-tag:not(:last-child):after{content:""}.project-gallery{margin-top:2rem}.gallery-masonry{column-count:3;column-gap:1.25rem}.masonry-item{break-inside:avoid;margin-bottom:1.25rem;cursor:pointer;position:relative;overflow:hidden;border-radius:var(--radius-md);background-color:var(--bg-surface);transition:transform .35s var(--ease-out-expo),box-shadow .35s var(--ease-out-expo);border:1px solid var(--border-subtle)}.masonry-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg),0 0 20px var(--accent-glow)}.masonry-image-wrapper{position:relative;overflow:hidden}.masonry-item img{width:100%;display:block;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:transform .5s var(--ease-out-expo)}.masonry-item:hover img{transform:scale(1.05)}.masonry-overlay{position:absolute;inset:0;background:#0a0a0f80;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s var(--ease-out-expo)}.masonry-item:hover .masonry-overlay{opacity:1}.view-text{color:#fff;font-weight:600;border:1px solid rgba(255,255,255,.4);padding:.5rem 1.5rem;border-radius:var(--radius-full);background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);font-size:.9rem}.masonry-caption{padding:.85rem 1rem;color:var(--text-secondary);font-size:.9rem;font-weight:500;border-top:1px solid var(--border-subtle)}.lightbox-overlay{position:fixed;inset:0;background-color:#000000f2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s var(--ease-out-expo)}.lightbox-content{max-width:90vw;max-height:90vh;position:relative;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 0 60px #000c}.lightbox-caption{margin-top:1rem;color:var(--text-primary);font-family:var(--font-heading);font-size:1.1rem;font-weight:500;text-align:center}.lightbox-counter{margin-top:.5rem;color:var(--text-muted);font-size:.85rem}.lightbox-close{position:absolute;top:2rem;right:2rem;color:var(--text-secondary);opacity:.7;transition:all var(--transition-fast);background:transparent;padding:.5rem;cursor:pointer;z-index:1001}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);color:var(--text-secondary);opacity:.5;transition:opacity .2s,transform .2s,color .2s;background:transparent;border:none;cursor:pointer;padding:1rem;z-index:1001}.lightbox-nav:hover,.lightbox-close:hover{opacity:1;color:var(--accent-secondary)}.lightbox-nav.prev{left:2rem}.lightbox-nav.next{right:2rem}.lightbox-nav:active{transform:translateY(-50%) scale(.95)}@media(max-width:1024px){.gallery-masonry{column-count:2}}@media(max-width:640px){.gallery-masonry{column-count:1}.lightbox-nav{padding:.5rem}.lightbox-nav.prev{left:.5rem}.lightbox-nav.next{right:.5rem}}.project-not-found{height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-deep);color:var(--text-primary)}.error-content{text-align:center}.btn-back{margin-top:1rem;padding:.6rem 1.8rem;background:var(--gradient-accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;font-weight:600;transition:all var(--transition-fast);box-shadow:0 4px 16px var(--accent-glow)}.btn-back:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--accent-glow)}@media(max-width:768px){.project-banner{height:50vh}.project-title{font-size:2.2rem}.project-info-grid{grid-template-columns:1fr;gap:2rem}.project-actions{flex-direction:column;align-items:flex-start}.btn-visit,.btn-back-hero{width:100%;justify-content:center;text-align:center}}.login-container{height:100vh;width:100vw;background-color:var(--bg-deep);display:flex;justify-content:center;align-items:center;color:var(--text-primary);position:relative}.login-container:before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.1) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.login-content{background:#16161fcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:48px 48px 36px;border-radius:var(--radius-lg);min-height:380px;display:flex;flex-direction:column;gap:18px;width:100%;max-width:420px;border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-title{font-family:var(--font-heading);font-size:28px;font-weight:700;margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:14px}.login-input{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);color:var(--text-primary);height:48px;line-height:48px;padding:0 18px;width:100%;font-size:15px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-glow)}.login-error{color:#f97316;font-size:13px}.login-btn{background:var(--gradient-accent);border-radius:var(--radius-sm);font-size:15px;font-weight:700;margin:20px 0 10px;width:100%;color:#fff;border:0;cursor:pointer;padding:14px;transition:all var(--transition-fast);box-shadow:0 4px 16px var(--accent-glow)}.login-btn:hover{background:var(--gradient-accent-hover);transform:translateY(-2px);box-shadow:0 6px 24px var(--accent-glow)}.back-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;margin-top:16px;transition:color var(--transition-fast)}.back-btn:hover{text-decoration:underline;color:var(--text-primary)}.about-page{background-color:var(--bg-deep);min-height:100vh;color:var(--text-primary)}.about-hero{height:70vh;display:flex;align-items:center;padding-left:4%;background:linear-gradient(to right,var(--bg-deep) 35%,transparent 100%),url(/assets/grotesk_hero-v-180OUK.png) no-repeat center center/cover;position:relative}.about-hero:after{content:"";position:absolute;bottom:0;left:0;right:0;height:200px;background:linear-gradient(to top,var(--bg-deep),transparent);pointer-events:none}.about-hero-content{max-width:600px;z-index:10;padding-top:100px;animation:fadeInUp .8s var(--ease-out-expo) both}.about-title{font-family:var(--font-heading);font-size:3.5rem;margin-bottom:1.5rem;font-weight:800;letter-spacing:-.5px;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-bio{font-size:1.1rem;line-height:1.7;margin-bottom:2rem;color:var(--text-secondary)}.about-skills{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}.skill-badge{border:1px solid rgba(124,58,237,.25);padding:.45rem 1rem;border-radius:var(--radius-full);background:#7c3aed14;color:var(--accent-secondary);font-size:.85rem;font-weight:500;transition:all var(--transition-fast)}.skill-badge:hover{background:#7c3aed2e;border-color:#7c3aed66;box-shadow:0 0 12px var(--accent-glow);transform:translateY(-2px)}.about-socials{display:flex;gap:1.5rem;padding-bottom:30px}.social-link{color:var(--text-primary);font-weight:600;text-decoration:none;font-size:1rem;opacity:.8;transition:all var(--transition-fast);border-bottom:2px solid var(--accent-primary);padding-bottom:2px}.social-link:hover{opacity:1;color:var(--accent-secondary);border-bottom-color:var(--accent-secondary)}.about-rows{padding-bottom:3rem;margin-top:50px;position:relative;z-index:10}@media(max-width:768px){.about-hero{height:auto;padding:100px 20px 40px;background:var(--bg-deep)}.about-title{font-size:2.5rem}.about-hero-content{max-width:100%}}.experience-page{background-color:var(--bg-deep);min-height:100vh;color:var(--text-primary);padding-bottom:4rem}.experience-container{max-width:800px;margin:0 auto;padding:100px 20px 20px}.experience-header h1{font-family:var(--font-heading);font-size:3rem;font-weight:800;margin-bottom:2rem;border-bottom:1px solid var(--border-subtle);padding-bottom:1rem;letter-spacing:-.5px;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.experience-section{margin-bottom:3.5rem;animation:fadeInUp .6s var(--ease-out-expo) both}.experience-section h2{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:var(--accent-secondary);margin-bottom:1.5rem;border-left:3px solid;border-image:var(--gradient-accent) 1;padding-left:1rem}.experience-section h3{font-family:var(--font-heading);font-size:1.3rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;margin-top:1.5rem}.experience-section p{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);margin-bottom:1rem}.experience-section ul{list-style-type:none;padding-left:0;color:var(--text-secondary);margin-bottom:1.5rem}.experience-section li{margin-bottom:.6rem;line-height:1.6;padding-left:1.2rem;position:relative}.experience-section li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent-primary)}.experience-role,.job-meta{font-size:.95rem;color:var(--text-muted);font-style:italic;margin-bottom:1rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.tenure-badge{display:inline-flex;align-items:center;background:#7c3aed1f;color:var(--accent-secondary);border:1px solid rgba(124,58,237,.22);border-radius:var(--radius-full);font-size:.75rem;font-style:normal;font-weight:600;padding:2px 10px;letter-spacing:.3px}.roles-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media(max-width:768px){.roles-grid{grid-template-columns:1fr}.experience-header h1{font-size:2.2rem}}
