*,*: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-settings-section .admin-portfolio-panel{border-color:#648cc847}.admin-settings-form{display:flex;flex-direction:column;gap:1.25rem}.admin-settings-group{margin:0;padding:1rem 1rem 1.1rem;border:1px solid var(--border);border-radius:10px;background:#0000002e}.admin-settings-legend{padding:0 .25rem;font-size:.95rem;font-weight:600;color:var(--text)}.admin-settings-hint{margin:.35rem 0 0;font-size:.8rem;line-height:1.5;color:var(--text-muted)}.admin-settings-hint--spaced{margin-top:.75rem}.admin-settings-hint code{font-family:var(--mono);font-size:.75rem}.admin-settings-field{display:block;margin-top:.85rem;margin-bottom:.35rem;font-size:.85rem;font-weight:600;color:var(--text)}.admin-settings-input-narrow{max-width:8rem}.admin-settings-select{max-width:22rem;width:100%}.admin-portfolio-preview-trigger--clickable{cursor:zoom-in}.admin-portfolio-preview-trigger--hover-only{cursor:default}.admin-settings-check{display:flex;align-items:flex-start;gap:.5rem;font-size:.88rem;line-height:1.45;color:var(--text);cursor:pointer}.admin-settings-check input{margin-top:.2rem;accent-color:var(--teal);flex-shrink:0}.admin-settings-actions{display:flex;justify-content:flex-start}.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-list-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin:0 0 .75rem}.admin-list-pagination-meta{margin:0;font-size:.85rem;color:var(--text-muted)}.admin-list-pagination-controls{display:flex;align-items:center;gap:.5rem}.admin-list-pagination-page{font-size:.85rem;color:var(--text-muted);min-width:6.5rem;text-align:center}.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-deadline-short{display:none}.admin-pp-deadline-full{font-family:var(--mono);font-size:.78rem;word-break:break-word}.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-table--portfolio-list thead .admin-portfolio-th-preview,.admin-table--portfolio-list .admin-portfolio-preview-cell{display:none}.admin-table--portfolio-list tbody tr.admin-portfolio-list-row{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem .85rem}.admin-table--portfolio-list tbody tr.admin-portfolio-list-row>td{display:block;border-bottom:none;padding:.35rem 0}.admin-table--portfolio-list .admin-portfolio-name-cell{flex:1 1 14rem;min-width:0}.admin-table--portfolio-list .admin-portfolio-name-row{display:flex;align-items:center;gap:.5rem;width:100%}.admin-table--portfolio-list .admin-portfolio-name-input{flex:1 1 8rem;min-width:0;max-width:14rem;margin:0;font-family:var(--mono);font-size:.85rem}.admin-table--portfolio-list .admin-portfolio-status-cell{flex:0 0 auto}.admin-table--portfolio-list .admin-portfolio-actions{flex:1 1 auto;justify-content:flex-end;margin-left:auto}@media(max-width:900px){.admin-portfolio-table-wrap:has(.admin-table--portfolio-list){overflow-x:visible;border:none;background:transparent}.admin-table--portfolio-list{display:block}.admin-table--portfolio-list thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.admin-table--portfolio-list tbody{display:flex;flex-direction:column;gap:.65rem}.admin-table--portfolio-list tbody tr.admin-portfolio-list-row{display:flex;flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:0;padding:0;border:1px solid var(--border);border-radius:10px;background:#00000038;overflow:hidden}.admin-table--portfolio-list tbody tr.admin-portfolio-list-row>td{width:100%;padding:.55rem .75rem;border-bottom:1px solid rgba(255,255,255,.06)}.admin-table--portfolio-list tbody tr.admin-portfolio-list-row>td:last-child{border-bottom:none;padding-bottom:.65rem}.admin-table--portfolio-list tbody tr.admin-portfolio-list-row>td:before{display:block;font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.3rem}.admin-table--portfolio-list .admin-portfolio-name-cell{flex:none;padding-top:.7rem}.admin-table--portfolio-list .admin-portfolio-name-cell:before{display:none}.admin-table--portfolio-list .admin-portfolio-name-row{flex-direction:row;align-items:center;gap:.5rem}.admin-table--portfolio-list .admin-portfolio-name-input{width:100%;max-width:none;flex:1;font-size:.9rem}.admin-table--portfolio-list .admin-portfolio-open-link{flex-shrink:0;padding:.32rem .6rem;border-radius:6px;border:1px solid rgba(0,168,150,.35);background:#00a8961f;font-size:.78rem;text-decoration:none}.admin-table--portfolio-list .admin-portfolio-status-cell{flex:none;display:block}.admin-table--portfolio-list .admin-select-compact{width:100%;min-width:0}.admin-table--portfolio-list .admin-portfolio-actions{flex:none;display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-left:0;justify-content:stretch}.admin-table--portfolio-list .admin-portfolio-actions .btn-sm{width:100%;justify-content:center;min-height:2.4rem;padding:.5rem .55rem}.admin-table--portfolio-list .admin-portfolio-actions .btn-primary{grid-column:1 / -1}.admin-table--portfolio-list .admin-table-empty{padding:1rem;border:1px solid var(--border);border-radius:10px}.admin-manager-toolbar{flex-direction:column;align-items:stretch;gap:.5rem}.admin-manager-toolbar-hint{margin:0;order:2}.admin-manager-view-toggle{width:100%}.admin-manager-view-toggle .btn-sm{flex:1;justify-content:center}}@media(min-width:901px){.admin-table--portfolio-list .admin-portfolio-status-cell:before,.admin-table--portfolio-list .admin-portfolio-actions:before{display:none}}.admin-manager-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;margin-bottom:.75rem}.admin-manager-toolbar-hint{margin:0;font-size:.8rem;color:var(--text-muted)}.admin-manager-view-toggle{display:inline-flex;align-items:center;gap:.35rem;flex-wrap:wrap}.admin-manager-view-toggle-label{font-size:.85rem;color:var(--text-muted)}.admin-pp-table--list thead .admin-portfolio-th-preview,.admin-pp-table--list .admin-pp-cell--thumb{display:none}.admin-pp-table--list tbody tr.admin-pp-row td,.admin-portfolio-preview-cell{vertical-align:middle}.admin-portfolio-preview-wrap{position:relative;display:inline-block}.admin-portfolio-preview-trigger{position:relative;display:block;padding:0;margin:0;border:none;background:transparent;cursor:inherit;border-radius:8px;line-height:0}.admin-portfolio-preview-trigger:hover .admin-portfolio-preview-img,.admin-portfolio-preview-trigger:focus-visible .admin-portfolio-preview-img{border-color:#00c4b08c;box-shadow:0 0 0 2px #00a89640}.admin-portfolio-preview-trigger:focus-visible{outline:none}.admin-portfolio-preview-zoom-hint{position:absolute;right:.35rem;bottom:.35rem;padding:.12rem .4rem;border-radius:4px;font-size:.62rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:#e8f5f2;background:#0000009e;opacity:0;transition:opacity .15s ease;pointer-events:none}.admin-portfolio-preview-trigger:hover .admin-portfolio-preview-zoom-hint,.admin-portfolio-preview-trigger:focus-visible .admin-portfolio-preview-zoom-hint{opacity:1}.admin-portfolio-preview-popover{position:fixed;z-index:120;padding:.35rem;border-radius:10px;border:1px solid rgba(0,196,176,.45);background:var(--navy-deep);box-shadow:0 16px 48px #0000008c;pointer-events:none}.admin-portfolio-preview-popover img{display:block;width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover;object-position:top center;border-radius:7px}.admin-portfolio-preview-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#040a12e0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:zoom-out}.admin-portfolio-preview-lightbox-figure{margin:0;max-width:min(1280px,96vw);max-height:92vh;display:flex;flex-direction:column;align-items:center;gap:.65rem;cursor:default}.admin-portfolio-preview-lightbox-figure img{display:block;max-width:min(1280px,96vw);max-height:calc(92vh - 2rem);width:auto;height:auto;object-fit:contain;border-radius:10px;border:1px solid var(--border);box-shadow:0 20px 60px #00000073}.admin-portfolio-preview-lightbox-caption{margin:0;font-size:.85rem;color:var(--text-muted)}.admin-portfolio-preview-lightbox-caption code{font-family:var(--mono);font-size:.82rem;color:var(--text)}.admin-portfolio-preview-lightbox-close{position:absolute;top:1rem;right:1rem;width:2.5rem;height:2.5rem;border:1px solid var(--border);border-radius:8px;background:#00000059;color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer}.admin-portfolio-preview-lightbox-close:hover{background:#ffffff14;border-color:#00a89666}.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-name-cell{min-width:10rem}.admin-portfolio-name-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.admin-portfolio-name-input{flex:1 1 10rem;min-width:0;max-width:18rem;padding:.4rem .55rem;font-family:var(--mono);font-size:.85rem}.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-gen-panel{margin-top:.25rem}.admin-gen-status{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem}.admin-gen-pill{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:999px;font-size:.78rem;font-weight:600;border:1px solid var(--border)}.admin-gen-pill--ok{color:#0d7a4a;background:#0d7a4a14;border-color:#0d7a4a40}.admin-gen-pill--bad{color:#b42318;background:#b4231814;border-color:#b4231840}.admin-gen-path{flex-basis:100%;margin:.25rem 0 0;font-size:.8rem;color:var(--text-muted);word-break:break-all}.admin-gen-retest{margin-left:auto}.admin-gen-form{border-top:none;padding-top:0}.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}}@media(max-width:767px){.admin-pp-table-wrap{overflow-x:visible;border:none;background:transparent}.admin-pp-table{display:block}.admin-pp-table thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.admin-pp-table tbody{display:flex;flex-direction:column;gap:1rem}.admin-pp-table tbody tr.admin-pp-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-areas:"thumb thumb thumb" "slug slug slug" "access time deadline" "actions actions actions";gap:0;padding:0;overflow:hidden;border:1px solid var(--border);border-radius:12px;background:#00000038;box-shadow:0 4px 20px #0000002e}.admin-pp-table tbody tr.admin-pp-empty-row{display:block;padding:1rem;border:1px solid var(--border);border-radius:12px;background:#00000026}.admin-pp-table tbody tr.admin-pp-row td,.admin-pp-table tbody tr.admin-pp-empty-row td{display:block;padding:0;border:none}.admin-pp-table tbody tr.admin-pp-row td:before{content:attr(data-label);display:block;font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.2rem}.admin-pp-cell--thumb:before,.admin-pp-cell--slug:before{display:none}.admin-pp-cell--thumb{grid-area:thumb}.admin-pp-table .admin-pp-cell--thumb .admin-portfolio-preview-wrap{display:block;width:100%}.admin-pp-table .admin-pp-cell--thumb .admin-portfolio-preview-trigger{width:100%;border-radius:0}.admin-pp-table .admin-pp-cell--thumb .admin-portfolio-preview-img{width:100%;max-width:none;aspect-ratio:16 / 9;min-height:9.5rem;border:none;border-radius:0;border-bottom:1px solid rgba(255,255,255,.08);object-fit:cover;object-position:top center}.admin-pp-table .admin-pp-cell--thumb .admin-portfolio-preview-missing{display:flex;align-items:center;justify-content:center;width:100%;max-width:none;min-height:9.5rem;aspect-ratio:16 / 9;font-size:.8rem;color:var(--text-muted);background:linear-gradient(145deg,#1a30508c,#0a121cd9);border-bottom:1px solid rgba(255,255,255,.08)}.admin-pp-table .admin-pp-cell--thumb .admin-portfolio-preview-zoom-hint{opacity:1;bottom:.55rem;right:.55rem;padding:.2rem .5rem;font-size:.65rem;background:#000000b8}.admin-pp-cell--slug{grid-area:slug;min-width:0;padding:.75rem .85rem .55rem;border-bottom:1px solid rgba(255,255,255,.06)}.admin-pp-cell--slug .admin-portfolio-slug-row{margin-bottom:0;justify-content:space-between;align-items:center;gap:.65rem}.admin-pp-cell--slug .admin-portfolio-slug-code{font-size:1.05rem;font-weight:600;color:var(--text);word-break:break-word}.admin-pp-cell--slug .admin-portfolio-open-link{flex-shrink:0;padding:.28rem .55rem;border-radius:6px;border:1px solid rgba(0,168,150,.35);background:#00a8961f;text-decoration:none}.admin-pp-cell--slug .admin-portfolio-open-link:hover{background:#00a89638;text-decoration:none}.admin-pp-cell--access,.admin-pp-cell--time,.admin-pp-cell--deadline{min-width:0;padding:.55rem .65rem .65rem;border-bottom:1px solid rgba(255,255,255,.06);background:#0000001f}.admin-pp-cell--access{grid-area:access;border-right:1px solid rgba(255,255,255,.05)}.admin-pp-cell--time{grid-area:time;border-right:1px solid rgba(255,255,255,.05)}.admin-pp-cell--deadline{grid-area:deadline}.admin-pp-cell--access:before{content:"Access"}.admin-pp-cell--time:before{content:"Time left"}.admin-pp-cell--deadline:before{content:"Expires"}.admin-pp-cell--actions{grid-area:actions;padding:.65rem .85rem .85rem}.admin-pp-cell--actions:before{margin-bottom:.45rem}.admin-pp-url-hint{display:none}.admin-pp-remaining{white-space:normal}.admin-pp-remaining-stack{min-width:0}.admin-pp-remaining-primary{font-size:.82rem}.admin-pp-remaining-hint{display:none}.admin-pp-trash-note{margin-top:.25rem;font-size:.68rem}.admin-pp-deadlines{max-width:none}.admin-pp-deadline-full{display:none}.admin-pp-deadline-short{display:inline;font-family:var(--mono);font-size:.72rem;line-height:1.35;word-break:break-word}.admin-pp-actions{min-width:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem}.admin-pp-actions .btn-primary{grid-column:1 / -1}.admin-pp-actions .btn-sm{width:auto;padding:.48rem .55rem;font-size:.74rem;line-height:1.25;white-space:normal;-webkit-hyphens:auto;hyphens:auto}.admin-pp-toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem;align-items:stretch}.admin-pp-toolbar-label,.admin-pp-toolbar-spacer{display:none}.admin-pp-toolbar .btn-sm{width:100%;justify-content:center}.admin-portfolio-panel{padding:1rem .85rem 1.35rem}.admin-list-pagination{flex-direction:column;align-items:stretch;gap:.5rem}.admin-list-pagination-controls{justify-content:space-between}.admin-list-pagination-page{min-width:0;flex:1}.admin-pp-table--list tbody tr.admin-pp-row{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .55rem;padding:.6rem .75rem;grid-template-columns:unset;grid-template-areas:unset;overflow:visible}.admin-pp-table--list .admin-pp-cell--thumb{display:none!important}.admin-pp-table--list .admin-pp-cell--slug{flex:1 1 100%;padding:0;border:none}.admin-pp-table--list .admin-pp-cell--slug .admin-portfolio-slug-code{font-size:.92rem}.admin-pp-table--list .admin-pp-cell--slug .admin-portfolio-open-link{padding:.2rem .45rem;font-size:.72rem}.admin-pp-table--list .admin-pp-cell--access,.admin-pp-table--list .admin-pp-cell--time,.admin-pp-table--list .admin-pp-cell--deadline{flex:1 1 auto;min-width:0;padding:0;border:none;background:transparent}.admin-pp-table--list .admin-pp-cell--access,.admin-pp-table--list .admin-pp-cell--time{border-right:none}.admin-pp-table--list .admin-pp-cell--actions{flex:1 1 100%;padding:.4rem 0 0;border-top:1px solid rgba(255,255,255,.06)}.admin-pp-table--list .admin-pp-actions .btn-primary{grid-column:1 / -1}.admin-pp-toolbar .admin-manager-view-toggle{grid-column:1 / -1;justify-content:flex-end;width:100%}}
