*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:DM Sans,system-ui,sans-serif;font-optical-sizing:auto;-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text)}#root{min-height:100vh}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--navy: #1a3050;--navy-deep: #0f1c2e;--teal: #00a896;--teal-bright: #00c4b0;--text: #e8eef5;--text-muted: #8fa3b8;--bg: #0a121c;--surface: rgba(26, 48, 80, .35);--border: rgba(0, 168, 150, .2);--mono: "JetBrains Mono", ui-monospace, monospace}.app{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(0,168,150,.12),transparent),radial-gradient(ellipse 80% 50% at 100% 50%,rgba(26,48,80,.4),transparent),var(--bg)}.app:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;z-index:0}.header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;max-width:1120px;margin:0 auto;width:100%;border-bottom:1px solid var(--border);background:#0a121cbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{display:flex;align-items:center;text-decoration:none;color:inherit}.brand img{height:44px;width:auto;display:block}.nav-actions{display:flex;align-items:center;justify-content:flex-end;flex:1;min-width:0}.nav-actions-links{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.header-mobile-right,.header-menu-toggle{display:none}.header-menu-bars{display:flex;flex-direction:column;justify-content:center;gap:.22rem;width:1.25rem;height:1rem}.header-menu-bars span{display:block;height:2px;background:currentColor;border-radius:1px;transition:transform .2s ease,opacity .2s ease}.header-menu-bars--open span:nth-child(1){transform:translateY(.4rem) rotate(45deg)}.header-menu-bars--open span:nth-child(2){opacity:0}.header-menu-bars--open span:nth-child(3){transform:translateY(-.4rem) rotate(-45deg)}.auth-wrap{display:flex;align-items:center;gap:.5rem}.auth-loading{color:var(--text-muted);font-size:.875rem;min-width:1.25rem}.auth-banner{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.65rem 1rem;background:#b43c3ceb;color:#fff;font-size:.875rem}.auth-banner-dismiss{background:transparent;border:none;color:inherit;font-size:1.25rem;line-height:1;cursor:pointer;padding:0 .25rem}.auth-user-menu{position:relative;display:flex;align-items:center}.auth-user-trigger{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .4rem .25rem .25rem;margin:0;font-family:inherit;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:999px;cursor:pointer;color:var(--text);transition:background .15s ease,border-color .15s ease}.auth-user-trigger:hover{background:#ffffff14;border-color:#ffffff29}.auth-avatar{border-radius:50%;object-fit:cover;flex-shrink:0}.auth-login{font-size:.875rem;font-weight:600;color:var(--text);max-width:9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-chevron{flex-shrink:0;color:var(--text-muted);transition:transform .15s ease}.auth-chevron--open{transform:rotate(180deg)}.auth-dropdown{position:absolute;right:0;top:calc(100% + 6px);min-width:11rem;padding:.35rem 0;background:var(--surface-elevated, #141a1f);border:1px solid rgba(255,255,255,.12);border-radius:10px;box-shadow:0 12px 40px #00000073;z-index:50}.auth-dropdown-item{display:block;width:100%;padding:.55rem 1rem;margin:0;font-family:inherit;font-size:.875rem;font-weight:500;text-align:left;text-decoration:none;color:var(--text);background:transparent;border:none;cursor:pointer;transition:background .12s ease}.auth-dropdown-item:hover,.auth-dropdown-item:focus-visible{background:#00d4c71f;outline:none}button.auth-dropdown-item{color:var(--text-muted)}button.auth-dropdown-item:hover,button.auth-dropdown-item:focus-visible{color:var(--text)}.btn-github{display:inline-flex;align-items:center;gap:.45rem;background:#24292f;color:#f0f6fc;border:1px solid rgba(255,255,255,.12)}.btn-github:hover{background:#2f363d;box-shadow:0 4px 16px #00000059}.auth-github-icon{flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.55rem 1.1rem;font-family:inherit;font-size:.875rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.btn:active{transform:scale(.98)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid transparent}.btn-ghost:hover{color:var(--text);border-color:var(--border)}.btn-primary{background:linear-gradient(135deg,var(--teal) 0%,var(--teal-bright) 100%);color:var(--navy-deep);box-shadow:0 0 #00a89666}.btn-primary:hover{box-shadow:0 4px 24px #00a89659}main{position:relative;z-index:1;flex:1;max-width:1120px;margin:0 auto;width:100%;padding:0 1.5rem 4rem}.hero{padding:3.5rem 0 4rem;text-align:center}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .85rem;border-radius:999px;font-family:var(--mono);font-size:.75rem;font-weight:500;color:var(--teal);background:#00a8961a;border:1px solid var(--border);margin-bottom:1.5rem}.hero-badge kbd{font-family:inherit;padding:.15rem .4rem;border-radius:4px;background:#00000040;border:1px solid rgba(255,255,255,.08)}.hero h1{margin:0 0 1rem;font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.15;letter-spacing:-.02em;color:var(--text)}.hero h1 span{background:linear-gradient(120deg,var(--teal-bright),#5eead4);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-lead{margin:0 auto 2rem;max-width:36rem;font-size:1.125rem;line-height:1.65;color:var(--text-muted)}.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:3rem}.hero-meta{font-family:var(--mono);font-size:.8rem;color:var(--text-muted);opacity:.9}.section{padding:3rem 0;border-top:1px solid var(--border)}.section h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--text)}.section-intro{margin:0 0 2rem;max-width:40rem;color:var(--text-muted);line-height:1.6}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}.feature-card{padding:1.5rem;border-radius:12px;background:var(--surface);border:1px solid var(--border);transition:border-color .2s ease,transform .2s ease}.feature-card:hover{border-color:#00a89673;transform:translateY(-2px)}.feature-icon{font-family:var(--mono);font-size:.75rem;font-weight:500;color:var(--teal);margin-bottom:.75rem}.feature-card h3{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:var(--text)}.feature-card p{margin:0;font-size:.9rem;line-height:1.55;color:var(--text-muted)}.cta-band{margin-top:1rem;padding:2.5rem 1.5rem;border-radius:16px;text-align:center;background:linear-gradient(145deg,#1a305080,#0f1c2ecc);border:1px solid var(--border)}.cta-band h2{margin:0 0 .75rem;font-size:1.35rem}.cta-band p{margin:0 0 1.25rem;color:var(--text-muted);max-width:32rem;margin-left:auto;margin-right:auto}.footer{position:relative;z-index:1;margin-top:auto;padding:2rem 1.5rem;border-top:1px solid var(--border);text-align:center}.footer p{margin:0;font-size:.85rem;color:var(--text-muted)}.footer a{color:var(--teal);text-decoration:none}.footer a:hover{text-decoration:underline}.not-found-page{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 1.5rem;min-height:70vh}.not-found-code{margin:0;font-family:var(--mono);font-size:clamp(3.5rem,12vw,5rem);font-weight:700;color:var(--teal);line-height:1;opacity:.85}.not-found-title{margin:1rem 0 .75rem;font-size:1.5rem;font-weight:700;color:var(--text)}.not-found-lead{margin:0 0 2rem;max-width:22rem;color:var(--text-muted);line-height:1.55}.not-found-home{text-decoration:none}.admin-header{justify-content:flex-start}.admin-header-split{justify-content:space-between;max-width:1120px;margin-left:auto;margin-right:auto;width:100%}.admin-portfolio-btn{flex-shrink:0}.admin-portfolio-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 1.1rem;padding:.35rem;border-radius:10px;border:1px solid var(--border);background:#0000002e}.admin-portfolio-tab{flex:1 1 10rem;text-align:center}.admin-pp-embedded{margin-top:.25rem}.admin-header-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.5rem}.admin-pp-section .admin-portfolio-panel{border-color:#00b4a038}.admin-pp-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem}.admin-pp-toolbar-label{font-size:.85rem;color:var(--text-muted)}.admin-pp-toolbar-spacer{flex:1;min-width:.25rem}.admin-pp-success{margin:0 0 .75rem;font-size:.9rem;color:#9dd4c4}.admin-pp-badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;text-transform:none;letter-spacing:.02em}.admin-pp-badge--preview{background:#00b48c38;color:#b8f0e0}.admin-pp-badge--expired{background:#dc8c2833;color:#f0d4a8}.admin-pp-badge--archived{background:#78788c59;color:#d4d4e0}.admin-pp-muted{margin:.25rem 0 0;font-size:.78rem;line-height:1.4;color:var(--text-muted)}.admin-pp-trash-note{margin-top:.35rem}.admin-pp-remaining{font-variant-numeric:tabular-nums;font-size:.85rem;white-space:nowrap;vertical-align:top}.admin-pp-remaining-stack{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;min-width:7.5rem}.admin-pp-remaining-primary{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.92rem;line-height:1.25;color:var(--text)}.admin-pp-remaining-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--text-muted)}.admin-pp-remaining-hint{margin:0;font-size:.72rem;font-weight:400;line-height:1.35;color:var(--text-muted)}.admin-pp-remaining-stack--green .admin-pp-remaining-dot{background:#22c55e;box-shadow:0 0 0 2px #22c55e40}.admin-pp-remaining-stack--green .admin-pp-remaining-primary{color:#86efac}.admin-pp-remaining-stack--green .admin-pp-remaining-hint{color:#86efacbf}.admin-pp-remaining-stack--yellow .admin-pp-remaining-dot{background:#eab308;box-shadow:0 0 0 2px #eab30847}.admin-pp-remaining-stack--yellow .admin-pp-remaining-primary{color:#fde047}.admin-pp-remaining-stack--yellow .admin-pp-remaining-hint{color:#fde047c7}.admin-pp-remaining-stack--red .admin-pp-remaining-dot{background:#ef4444;box-shadow:0 0 0 2px #ef444447}.admin-pp-remaining-stack--red .admin-pp-remaining-primary{color:#fca5a5}.admin-pp-remaining-stack--red .admin-pp-remaining-hint{color:#fca5a5d1}.admin-pp-remaining-stack--expired .admin-pp-remaining-dot{background:#6b7280;box-shadow:none}.admin-pp-remaining-stack--expired .admin-pp-remaining-primary{color:#9ca3af}.admin-pp-remaining-stack--neutral .admin-pp-remaining-dot{background:var(--text-muted);box-shadow:none}.admin-pp-remaining-stack--neutral .admin-pp-remaining-primary{color:var(--text-muted);font-weight:500}.admin-pp-deadlines{font-size:.78rem;line-height:1.45;max-width:14rem;word-break:break-word}.admin-pp-deadline-label{display:inline;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-right:.25rem}.admin-pp-url-hint{margin:.35rem 0 0;font-size:.72rem;line-height:1.4;color:var(--text-muted)}.admin-pp-url-hint code{font-family:var(--mono);font-size:.68rem;word-break:break-all}.admin-pp-actions{display:flex;flex-direction:column;align-items:stretch;gap:.35rem;min-width:8.5rem}.admin-pp-actions .btn-sm{width:100%;text-align:center}.admin-portfolio-section{margin:0 0 2.5rem}.admin-portfolio-panel{width:100%;padding:1.5rem 1.5rem 2rem;border-radius:12px;background:var(--navy-deep);border:1px solid var(--border);box-shadow:0 8px 32px #00000040}.admin-portfolio-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.admin-portfolio-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--text)}.admin-portfolio-collapse{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .25rem;flex-shrink:0}.admin-portfolio-collapse:hover{color:var(--text)}.admin-portfolio-lead{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted);line-height:1.5}.admin-portfolio-lead code{font-family:var(--mono);font-size:.8rem}.admin-portfolio-capture-mode{margin-bottom:1.25rem;padding:.85rem 1rem;border-radius:10px;border:1px solid var(--border);background:#0003}.admin-portfolio-capture-title{margin:0 0 .5rem;font-size:.95rem;font-weight:600;color:var(--text)}.admin-portfolio-capture-hint{margin:0 0 .75rem;font-size:.8rem;line-height:1.5;color:var(--text-muted)}.admin-portfolio-capture-hint code{font-family:var(--mono);font-size:.75rem}.admin-portfolio-capture-options{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.admin-portfolio-capture-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text);cursor:pointer}.admin-portfolio-capture-label input{accent-color:var(--teal)}.admin-portfolio-capture-warn{margin:.65rem 0 0;font-size:.78rem;color:#e8c48a}.admin-portfolio-table-wrap{margin-bottom:1.5rem;overflow-x:auto}.admin-table--portfolio th,.admin-table--portfolio td{padding:.45rem .65rem;font-size:.875rem;vertical-align:middle}.admin-table--portfolio thead th{padding-top:.55rem;padding-bottom:.55rem}.admin-portfolio-th-preview,.admin-portfolio-th-status,.admin-portfolio-th-actions{width:1%;white-space:nowrap}.admin-portfolio-preview-cell{vertical-align:middle}.admin-portfolio-preview-img{display:block;width:200px;max-width:min(200px,28vw);height:auto;aspect-ratio:16 / 9;object-fit:cover;object-position:top center;border-radius:8px;border:1px solid var(--border);background:#0003}.admin-portfolio-preview-missing{display:inline-block;font-size:.8rem;color:var(--text-muted);line-height:1.3;max-width:200px}.admin-portfolio-slug-cell{min-width:10rem}.admin-portfolio-slug-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.35rem}.admin-portfolio-slug-code{font-size:.8rem;word-break:break-all}.admin-portfolio-open-link{flex-shrink:0;font-size:.78rem;font-weight:600;color:var(--teal-bright);text-decoration:none}.admin-portfolio-open-link:hover{text-decoration:underline}.admin-input-rename{width:100%;max-width:18rem;min-width:0;padding:.4rem .55rem;font-size:.85rem}.admin-portfolio-status-cell{white-space:nowrap}.admin-select-compact{min-width:6.5rem}.admin-portfolio-actions{display:flex;flex-wrap:nowrap;gap:.3rem;align-items:center;justify-content:flex-end;white-space:nowrap}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.admin-select{font-family:inherit;font-size:.85rem;padding:.35rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.admin-input-inline{min-width:8rem;max-width:12rem}.admin-portfolio-upload{margin-top:.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.admin-portfolio-upload-title{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:var(--text)}.admin-portfolio-upload-hint{margin:0 0 1rem;font-size:.85rem;color:var(--text-muted)}.admin-portfolio-upload-row{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.35rem;max-width:24rem}.admin-shell{position:relative;z-index:1;max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem;width:100%}.admin-shell--wide{max-width:1200px}.admin-loading{display:flex;align-items:center;justify-content:center;gap:.65rem;text-align:center;color:var(--text-muted);padding:3rem}.admin-busy-banner{display:flex;align-items:center;gap:.65rem;margin:0 0 1rem;padding:.65rem .85rem;border-radius:8px;border:1px solid var(--border);background:#00a89614;color:var(--text-muted);font-size:.9rem;line-height:1.45}.admin-busy-spinner{display:inline-block;width:1.1rem;height:1.1rem;border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;flex-shrink:0;animation:admin-busy-spin .75s linear infinite}.admin-busy-spinner--inline{vertical-align:middle}@keyframes admin-busy-spin{to{transform:rotate(360deg)}}.admin-portfolio-tr-busy{opacity:.78}.admin-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--text)}.admin-lead{margin:0 0 1.5rem;color:var(--text-muted);line-height:1.55}.admin-password-form{max-width:20rem;display:flex;flex-direction:column;gap:.5rem}.admin-label{font-size:.85rem;font-weight:600;color:var(--text-muted)}.admin-input{padding:.6rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit;font-size:1rem}.admin-input:focus{outline:none;border-color:var(--teal)}.admin-form-error{margin:0;font-size:.85rem;color:#f87171}.admin-submit{margin-top:.5rem;align-self:flex-start}.admin-hint{margin-top:2rem;font-size:.9rem}.admin-hint a{color:var(--teal);text-decoration:none}.admin-hint a:hover{text-decoration:underline}.admin-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border);background:var(--surface)}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th,.admin-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.admin-table th{font-weight:600;color:var(--text-muted);background:#00000026}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table-empty{color:var(--text-muted);text-align:center}.admin-table-date{font-family:var(--mono);font-size:.8rem;color:var(--text-muted)}.portfolio-gallery-main{padding-top:2rem;padding-bottom:3rem}.portfolio-gallery-intro{margin-bottom:2rem;text-align:center;max-width:36rem;margin-left:auto;margin-right:auto}.portfolio-gallery-intro h1{margin:0 0 .75rem;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--text);letter-spacing:-.02em}.portfolio-gallery-lead{margin:0;font-size:1rem;line-height:1.6;color:var(--text-muted)}.portfolio-gallery-loading,.portfolio-gallery-empty,.portfolio-gallery-error{text-align:center;color:var(--text-muted);padding:2rem 1rem}.portfolio-gallery-error{color:#f0a8a8}.portfolio-gallery-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.portfolio-gallery-grid--admin{gap:1.1rem}.portfolio-gallery-intro-tools{margin-top:.65rem;display:flex;justify-content:center}.portfolio-gallery-layout-edit-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0;padding:.2rem .55rem;font-size:.7rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:#ffffff61;background:transparent;border:1px solid transparent;border-radius:999px;cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.portfolio-gallery-layout-edit-toggle:hover{color:#ffffff9e;border-color:#ffffff1f;background:#ffffff0a}.portfolio-gallery-layout-edit-toggle[aria-pressed=true]{color:var(--teal-bright);border-color:#00b49659;background:#00b4961a}.portfolio-gallery-layout-edit-toggle:focus-visible{outline:2px solid var(--teal-bright);outline-offset:2px}.portfolio-gallery-order-saving{margin:.5rem 0 0;text-align:center;font-size:.8rem;color:var(--text-muted)}.portfolio-gallery-li{display:flex;flex-direction:column;gap:.35rem;min-width:0}.portfolio-gallery-li--admin .portfolio-gallery-card{flex:1 1 auto}.portfolio-gallery-admin-bar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:1.5rem;padding:0 .15rem;opacity:.55;transition:opacity .2s ease}.portfolio-gallery-li--admin:hover .portfolio-gallery-admin-bar,.portfolio-gallery-li--admin:focus-within .portfolio-gallery-admin-bar{opacity:1}.portfolio-gallery-drag{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .35rem;border-radius:6px;color:var(--text-muted);cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.portfolio-gallery-drag:hover{color:var(--text);background:#ffffff0f}.portfolio-gallery-drag:active{cursor:grabbing}.portfolio-gallery-drag-icon{display:block;opacity:.9}.portfolio-gallery-admin-edit{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#ffffff73;text-decoration:none;padding:.2rem .45rem;border-radius:6px;border:1px solid transparent}.portfolio-gallery-admin-edit:hover{color:var(--teal-bright);border-color:#00b49659;background:#00b49614}.portfolio-gallery-li--dragging .portfolio-gallery-card{opacity:.55}.portfolio-gallery-li--drop-target .portfolio-gallery-card{outline:2px dashed rgba(0,180,150,.65);outline-offset:2px}.portfolio-gallery-card{display:block;padding:0;border-radius:12px;background:#0b171ee6;border:1px solid var(--border);text-decoration:none;color:inherit;overflow:hidden;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;min-height:100%;box-shadow:0 8px 28px #00000059}.portfolio-gallery-card:hover{border-color:#00a89680;transform:translateY(-2px);box-shadow:0 14px 36px #00000073}.portfolio-gallery-card:focus-visible{outline:2px solid var(--teal-bright);outline-offset:3px}.portfolio-gallery-media{position:relative;aspect-ratio:16 / 9;width:100%;background:#0a121c}.portfolio-gallery-screen{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;max-width:none;border-radius:0;border:none;box-shadow:none;z-index:0;background:#0a121c}.portfolio-gallery-screen img{display:block;width:100%;height:100%;object-fit:cover;object-position:top center}.portfolio-gallery-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 80% 70% at 50% 40%,#1a305080,#0a121c);z-index:0}.portfolio-gallery-avatar{width:72px;height:72px;border-radius:50%;border:2px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--text);font-family:var(--mono)}.portfolio-gallery-overlay{position:absolute;left:0;right:0;bottom:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.35rem .6rem .45rem;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.45) 55%,transparent 100%)}.portfolio-gallery-card-title{margin:0;font-size:.8125rem;font-weight:600;color:var(--text);line-height:1.25;letter-spacing:.01em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.portfolio-gallery-card-open{flex-shrink:0;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--teal-bright);opacity:.95}.portfolio-gallery-card:hover .portfolio-gallery-card-open{color:#5eead4}@media(max-width:640px){.header{flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem 0;padding-inline:1rem}.brand{flex:1 1 auto;min-width:0;max-width:calc(100% - 7.5rem)}.brand img{height:36px}.header-mobile-right{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.header-mobile-right .btn-github{padding:.45rem .65rem;font-size:.75rem;gap:.35rem}.header-mobile-right .auth-github-icon{width:16px;height:16px}.header-mobile-right .auth-login{max-width:5rem}.header-menu-toggle{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:2.5rem;height:2.5rem;padding:0;margin:0;font-family:inherit;background:#ffffff0a;border:1px solid var(--border);border-radius:8px;cursor:pointer;color:var(--text);transition:background .15s ease,border-color .15s ease}.header-menu-toggle:hover{background:#ffffff14;border-color:#00a89659}.header-menu-toggle:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.nav-actions{flex:1 1 100%;flex-direction:column;align-items:stretch;max-height:0;overflow:hidden;opacity:0;transition:max-height .25s ease,opacity .2s ease,padding .2s ease;padding:0}.nav-actions--open{max-height:min(70vh,420px);opacity:1;padding-top:.75rem;margin-top:.25rem;border-top:1px solid var(--border)}.nav-actions-links{flex-direction:column;align-items:stretch;width:100%;gap:.5rem}.nav-actions-links .btn{justify-content:center}.nav-actions-auth-desktop{display:none}}@media(max-width:640px)and (prefers-reduced-motion:reduce){.nav-actions,.header-menu-bars span{transition:none}}
