@import"https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=DM+Sans:wght@300;400;500&display=swap";:root{--bg: #0b1220;--panel: #0f172a;--panel-soft: color-mix(in srgb, var(--panel) 94%, transparent);--text: #e5e7eb;--muted: #94a3b8;--border: #1f2937;--brand: #4f46e5;--brand-ink: #ffffff;--radius-lg: 16px;--radius-md: 12px;--space: clamp(16px, 2.6vw, 24px);--maxw: 1120px;--shadow: 0 1px 2px rgba(2, 6, 23, .6), 0 2px 6px rgba(2, 6, 23, .5);--shadow-lg: 0 6px 18px rgba(2, 6, 23, .6);--focus: 3px solid var(--brand)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}p{margin:0 0 .75rem}.muted{color:var(--muted)}:focus-visible{outline:var(--focus);outline-offset:2px}.container{max-width:var(--maxw);margin:0 auto;padding-left:max(var(--space, 16px),env(safe-area-inset-left));padding-right:max(var(--space, 16px),env(safe-area-inset-right))}.page-offset{padding-top:80px}.btn{display:inline-flex;align-items:center;justify-content:center;height:42px;padding:0 14px;border-radius:12px;cursor:pointer;background:var(--panel);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow);transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .06s ease,box-shadow .2s ease}.btn:hover{background:var(--brand);color:var(--brand-ink);border-color:transparent;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn.primary{background:var(--panel);color:var(--text);border:1px solid var(--border)}.btn.primary:hover{background:var(--brand);color:var(--brand-ink);border-color:transparent}.btn.ghost{background:var(--panel)}@keyframes navbar-slide-down{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.navbar{animation:navbar-slide-down .6s ease forwards;width:100%;position:fixed;top:0;left:0;z-index:1000;background:linear-gradient(90deg,#0b1220,#141a2d);border-bottom:1px solid var(--border);box-shadow:0 4px 24px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar-inner{height:64px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding-left:max(var(--space, 16px),env(safe-area-inset-left));padding-right:max(var(--space, 16px),env(safe-area-inset-right))}.brand{font-weight:700;letter-spacing:.3px;font-size:1.1rem;color:var(--text)}.navbar-links{display:flex;gap:28px;align-items:center}.navbar-link{position:relative;color:var(--text);font-size:1.05rem;font-weight:600;text-decoration:none;padding-bottom:6px;transition:color .25s ease,transform .25s ease}.navbar-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:var(--brand);transition:width .3s ease,left .3s ease}.navbar-link:hover:after,.navbar-link.active:after{width:100%;left:0}.navbar-link:hover,.navbar-link.active{color:var(--brand);transform:translateY(-2px)}html{overflow-y:scroll;scrollbar-width:none}html::-webkit-scrollbar{display:none}.hero{padding:clamp(48px,10vw,96px) 0;display:grid;gap:var(--space);align-items:center}@media (min-width: 900px){.hero{grid-template-columns:1.1fr 1fr}}.eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:#8aa5ff}.hero-title{margin:6px 0 8px;font-size:clamp(28px,4vw,44px);line-height:1.15}.hero-sub{color:var(--muted);max-width:60ch}.hero-cta{display:flex;gap:12px;margin-top:14px}.panel{background:var(--panel-soft);border:1px solid var(--border);border-radius:var(--radius-lg);padding:calc(var(--space) * .9);box-shadow:var(--shadow)}.media{aspect-ratio:16 / 9;border-radius:14px;background:linear-gradient(135deg,color-mix(in srgb,#4f46e5 18%,var(--panel)) 0%,var(--panel) 100%);display:grid;place-items:center}.media-meta{text-align:center}.kicker{font-size:12px;color:#8aa5ff;text-transform:uppercase;letter-spacing:.14em}.media-title{font-weight:700}.section{padding:clamp(48px,8vw,88px) 0}.section-alt{background:#0d1528}.section-head{display:grid;gap:6px;margin-bottom:calc(var(--space) * 1.1)}.section-eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:#8aa5ff}.section-title{font-size:clamp(22px,3vw,32px);margin:0}.grid{display:grid;gap:calc(var(--space) * .9)}.two,.three{grid-template-columns:1fr}@media (min-width: 800px){.two{grid-template-columns:1fr 1fr}}@media (min-width: 1050px){.three{grid-template-columns:1fr 1fr 1fr}}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space);box-shadow:var(--shadow);transition:transform .08s ease,box-shadow .2s ease,border-color .2s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:color-mix(in srgb,var(--brand) 25%,var(--border))}.card-title{margin:0 0 6px}.thumb{aspect-ratio:16 / 9;border-radius:12px;background:#1b2236;margin-bottom:10px}.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.chip{display:inline-block;font-size:12px;padding:4px 8px;border:1px solid var(--border);border-radius:999px;color:var(--muted)}.footer{border-top:1px solid var(--border);padding:32px 0;color:var(--muted)}.footer-row{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}.footer-links{display:flex;gap:16px;flex-wrap:wrap}@media (max-width: 640px){:root{--space: clamp(12px, 5vw, 18px)}.section{padding:clamp(32px,8vw,64px) 0}}@media (max-width: 640px){.brand{display:none!important}.navbar-inner{justify-content:center}.navbar-links{gap:10px}}.hero-text{display:grid;gap:10px}.hero-card{align-self:stretch}.hero-stats{display:grid;grid-template-columns:1fr;gap:10px;margin-top:18px}@media (min-width: 520px){.hero-stats{grid-template-columns:1fr 1fr 1fr}}.stat{background:color-mix(in srgb,var(--panel) 82%,transparent);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px}.stat-value{font-weight:800;letter-spacing:.2px;line-height:1.1}.stat-label{margin-top:2px;font-size:.9rem;color:var(--muted)}.hero-feature{display:grid;gap:14px}.hero-feature-top{display:grid;gap:6px}.tagline{color:var(--muted);font-size:.95rem}.hero-feature-media{border-radius:14px;overflow:hidden;border:1px solid var(--border);background:#1b2236;aspect-ratio:16 / 9}.hero-feature-media img{width:100%;height:100%;object-fit:cover}.hero-feature-actions{display:flex;flex-wrap:wrap;gap:12px}.card-link{display:grid;gap:10px}.card-body{display:grid;gap:6px}.thumb{overflow:hidden}.thumb img{width:100%;height:100%;object-fit:cover}.home-cta{display:grid;gap:14px;align-items:center}@media (min-width: 760px){.home-cta{grid-template-columns:1fr auto}}.hero-cta{flex-wrap:wrap}.music-hero{padding-left:1.1em}.recently-played-list{list-style:none;margin:0;padding:0 1.1em}.recently-played-row{display:grid;grid-template-columns:24px 40px 1fr auto;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--border);transition:background .15s ease}.recently-played-row:first-child{border-top:1px solid var(--border)}.recently-played-row:hover{background:color-mix(in srgb,var(--brand) 6%,transparent)}.recently-played-index{font-size:.85rem;color:var(--muted);text-align:right}.recently-played-art{width:40px;height:40px;border-radius:4px;object-fit:cover}.recently-played-body{display:grid;gap:2px;min-width:0}.recently-played-track{font-size:.95rem;font-weight:500;color:var(--text);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recently-played-track:hover{color:var(--brand);text-decoration:underline}.recently-played-artist{font-size:.85rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recently-played-time{font-size:.82rem;color:var(--muted);white-space:nowrap;padding-right:1.25rem}.recently-played-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px}.pagination-btn{background:var(--panel-soft);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 14px;cursor:pointer;transition:border-color .2s ease,background .2s ease}.pagination-btn:hover:not(:disabled){border-color:color-mix(in srgb,var(--brand) 40%,var(--border));background:color-mix(in srgb,var(--brand) 8%,transparent)}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-label{font-size:.9rem;color:var(--muted)}.music-stats{margin-bottom:40px;padding-left:1.1em;padding-right:1.1em}.music-stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.music-stats-heading{margin:0;font-size:clamp(1.2rem,2.5vw,1.5rem)}.period-toggle{display:flex;gap:8px}.period-btn{background:var(--panel-soft);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:5px 14px;font-size:.875rem;cursor:pointer;transition:border-color .2s ease,color .2s ease,background .2s ease}.period-btn.active{border-color:var(--brand);color:var(--text);background:color-mix(in srgb,var(--brand) 12%,transparent)}.period-btn:hover:not(.active){border-color:color-mix(in srgb,var(--brand) 40%,var(--border));color:var(--text)}.stat-grid{display:grid;gap:clamp(12px,2vw,16px);grid-template-columns:1fr}@media (min-width: 760px){.stat-grid{grid-template-columns:repeat(3,1fr)}}.stat-block{background:var(--panel-soft);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.stat-block-title{margin:0 0 12px;font-size:.95rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.stat-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}.stat-row{display:grid;grid-template-columns:20px 40px 1fr auto;align-items:center;gap:10px}.stat-index{font-size:.85rem;color:var(--muted);text-align:right}.stat-name{font-size:.9rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-count{font-size:.82rem;color:var(--muted);white-space:nowrap}.pagination-btn--active{background-color:var(--brand);color:var(--brand-ink);border-color:var(--brand)}:root{--skeleton-base: #111827;--skeleton-shine: #1f2937;--modal-exit-ms: .22s;--border: rgba(255, 255, 255, .12);--muted-fg: rgba(255, 255, 255, .7);--card: rgba(255, 255, 255, .04);--chip-bg: transparent;--chip-active: #e6e6e6;--media-bg: rgba(255, 255, 255, .03)}.projects-page{--gap: 1rem}.container{max-width:1100px;margin:0 auto;padding:0 1rem}.pad-y{padding:2rem 0}.projects-header{text-align:center;margin-bottom:28px}.projects-header h2{font-size:clamp(1.6rem,3vw,2rem);margin-bottom:6px}.projects-header p{max-width:640px;margin:0 auto;font-size:1.05rem;color:var(--muted, #94a3b8)}.projects-hero{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--gap);align-items:end;padding:2.5rem 0 1rem}.projects-hero h1{font-size:clamp(1.8rem,2.5vw,2.6rem);margin:0 0 .25rem}.projects-hero .hero-text p{color:var(--muted-fg);margin:0}.hero-actions{display:flex;flex-direction:column;gap:.75rem}.input-group{position:relative;display:flex}.input-group input[type=search]{flex:1;padding:.7rem .9rem;border-radius:.75rem;border:1px solid var(--border, #1f2937);background:transparent;color:inherit}.input-group .ghost{position:absolute;right:.25rem;top:.25rem;height:2rem;width:2rem;border-radius:.5rem}.filters-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{border:1px solid var(--border);background:var(--chip-bg);padding:.35rem .6rem;border-radius:999px;font-size:.9rem;color:inherit}.chip.active{background:var(--chip-active);color:#111;border-color:var(--chip-active)}.chip.pill.disabled{opacity:.85;cursor:default}.sort{display:inline-flex;align-items:center;gap:.5rem}.sort select{padding:.4rem .6rem;border-radius:.6rem;border:1px solid var(--border);background:transparent;color:inherit}.projects-grid{--gap: clamp(14px, 2vw, 20px);display:grid;gap:var(--gap);grid-template-columns:1fr;margin-top:18px;padding:0 clamp(16px,4vw,40px);list-style:none}@media (min-width: 700px){.projects-grid{grid-template-columns:1fr 1fr}}@media (min-width: 1100px){.projects-grid{grid-template-columns:1fr 1fr 1fr}}.project-card{background:var(--card, #0f172a);border:1px solid var(--border, #1f2937);border-radius:16px;box-shadow:0 1px 2px #02061799,0 2px 6px #02061780;overflow:hidden;display:grid;grid-template-rows:auto 1fr;cursor:pointer;transition:transform .08s ease,box-shadow .2s ease,border-color .2s ease;outline:none;opacity:0;animation:card-in .38s ease forwards}.project-card:hover,.project-card:focus-visible,.project-card:focus-within{transform:translateY(-2px);border-color:color-mix(in srgb,var(--brand, #4f46e5) 25%,var(--border, #1f2937));box-shadow:0 6px 18px #02061799}.card-link{display:grid;grid-template-rows:auto 1fr;color:inherit;text-decoration:none;height:100%}.project-media{margin:0;background:var(--media-bg, #0d1325);position:relative;overflow:hidden;aspect-ratio:16 / 9}.project-media img,.project-placeholder{display:block;width:100%;height:100%;object-fit:cover;transform:translateZ(0);transition:transform .25s ease,opacity .25s ease}.project-card:hover .project-media img,.project-card:focus-visible .project-media img,.project-card:focus-within .project-media img{transform:scale(1.02)}.project-placeholder{background:linear-gradient(135deg,#151c2f,#0f172a);display:grid;place-items:center;color:#94a3b8}.project-placeholder-text{font-size:.9rem;opacity:.9}.no-image{display:grid;place-items:center;height:100%;color:#94a3b8;font-size:.9rem}.project-body{padding:clamp(14px,2vw,18px);display:grid;gap:.45rem}.project-title{margin:2px 0 6px;font-size:1.05rem;line-height:1.3;color:#e5e7eb}.project-desc{color:var(--muted-fg, #94a3b8);margin:0;font-size:.95rem}.tags-inline{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.25rem}.tag{padding:4px 8px;border-radius:999px;background:#ffffff0f;color:#cbd5e1;font-size:.85rem;border:1px solid var(--border)}.tag.more{opacity:.7}@media (max-width: 480px){.project-body{padding:12px}.project-title{font-size:1rem}}@keyframes card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.projects-grid .project-card:nth-child(1){animation-delay:30ms}.projects-grid .project-card:nth-child(2){animation-delay:60ms}.projects-grid .project-card:nth-child(3){animation-delay:90ms}.projects-grid .project-card:nth-child(4){animation-delay:.12s}.projects-grid .project-card:nth-child(5){animation-delay:.15s}.projects-grid .project-card:nth-child(6){animation-delay:.18s}.projects-grid .project-card:nth-child(7){animation-delay:.21s}.projects-grid .project-card:nth-child(8){animation-delay:.24s}.projects-grid .project-card:nth-child(9){animation-delay:.27s}.projects-grid .project-card:nth-child(10){animation-delay:.3s}.projects-grid .project-card:nth-child(11){animation-delay:.33s}.projects-grid .project-card:nth-child(12){animation-delay:.36s}.modal-overlay{position:fixed;inset:0;background:#0f0f14b3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:24px;z-index:1000}.modal{width:min(1024px,100%);max-height:90vh;background:var(--surface-1, #0b1222);color:var(--text, #e5e7eb);border:1px solid rgba(148,163,184,.15);border-radius:16px;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column;overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(148,163,184,.12)}.modal-title{margin:0;font-size:1.125rem}.modal-close{appearance:none;border:0;background:transparent;color:inherit;font-size:24px;line-height:1;cursor:pointer;padding:6px;border-radius:8px}.modal-close:hover,.modal-close:focus-visible{background:#94a3b824;outline:none}.modal-body{padding:12px 16px 16px;overflow:auto}.modal-figure{margin:0}.modal-media-shell{position:relative;display:grid;place-items:center;background:#0d0f13;border-radius:12px;overflow:hidden;aspect-ratio:16 / 9}.modal-media{max-width:100%;max-height:70vh;width:100%;height:100%;object-fit:contain;background:#0d0f13}.modal-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:2;border:0;background:#0006;color:#fff;width:40px;height:40px;border-radius:999px;cursor:pointer;font-size:22px;display:grid;place-items:center;transition:background .2s}.modal-arrow:hover,.modal-arrow:focus-visible{background:#0009;outline:none}.modal-arrow.left{left:8px}.modal-arrow.right{right:8px}.modal-caption{padding:10px 4px 0}.modal-caption-top{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.modal-slide-idx{font-size:.875rem;color:var(--muted, #94a3b8)}.modal-caption-title{font-weight:600}.modal-caption-text{margin:6px 0 0;color:var(--muted, #cbd5e1)}.modal-dots{display:flex;gap:6px;justify-content:center;padding:10px 0 0}.modal-dots .dot{width:10px;height:10px;border-radius:999px;border:0;background:var(--border, #334155);cursor:pointer;transition:background .2s ease}.modal-dots .dot.active{background:var(--brand, #4f46e5)}.modal-project-desc{margin-top:16px;color:#d1d5db}.modal-meta{margin-top:16px;display:grid;gap:12px}.meta-block h5{margin:0 0 6px;font-size:.95rem;color:#e5e7eb}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}.link-list{margin:0;padding-left:18px;list-style:none}.skeleton{position:relative;overflow:hidden;background:var(--skeleton-base)}.skeleton:after{content:"";position:absolute;inset:0;transform:translate(-100%);animation:skeleton-shimmer 1.1s linear infinite;background:linear-gradient(90deg,#fff0,#ffffff0f,#fff0)}@keyframes skeleton-shimmer{to{transform:translate(100%)}}.skeleton-card .project-media{background:transparent}.skeleton-media{width:100%;aspect-ratio:16 / 9;border-radius:0}.skeleton-line{height:10px;border-radius:6px;margin:8px 0;background:var(--skeleton-base)}.skeleton-title{height:14px;width:70%}.skeleton-line.short{width:40%}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes overlay-out{0%{opacity:1}to{opacity:0}}@keyframes dialog-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dialog-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(6px) scale(.985)}}.modal-overlay[data-state=open]{animation:overlay-in .16s ease forwards}.modal-overlay[data-state=closing]{animation:overlay-out var(--modal-exit-ms) ease forwards}.modal[data-state=open]{animation:dialog-in .2s cubic-bezier(.2,.8,.2,1) forwards}.modal[data-state=closing]{animation:dialog-out var(--modal-exit-ms) cubic-bezier(.2,.8,.2,1) forwards}@keyframes fade-swap-in{0%{opacity:0;transform:scale(.995)}to{opacity:1;transform:scale(1)}}.fade-swap{animation:fade-swap-in .18s ease forwards}.projects-footer{padding:1rem 0 3rem}.empty-state{padding:2rem 0;display:grid;gap:.75rem;justify-items:start}.project-detail .breadcrumb{display:flex;gap:.5rem;align-items:center;padding:1rem 0 .5rem;color:var(--muted-fg)}.project-detail .detail-header{padding-bottom:.5rem}.project-detail .detail-header .lead{color:var(--muted-fg)}.detail-media{position:relative;color:inherit;padding:2rem 0 1rem;isolation:isolate}.detail-media:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 60% at 50% 35%,rgba(255,255,255,.06),transparent 70%);mix-blend-mode:overlay;opacity:.4;z-index:0}.media-viewer{position:relative;border-radius:1rem;overflow:hidden;max-width:1100px;margin:0 auto;box-shadow:0 10px 30px #0009;z-index:1}.media-viewer img,.media-viewer video{display:block;width:100%;height:auto;max-height:78vh;object-fit:contain}.viewer-arrows{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 .25rem;pointer-events:none}.viewer-arrows .circle{pointer-events:auto;height:2.5rem;width:2.5rem;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:#0000008c;color:#fff;font-size:1.4rem;display:grid;place-items:center;transition:background .2s ease,transform .2s ease}.viewer-arrows .circle:hover{background:#ffffff26;transform:scale(1.04)}.thumbs{position:relative;max-width:1100px;margin:.9rem auto 0;padding:.25rem 24px .75rem;display:flex;gap:.65rem;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.thumbs::-webkit-scrollbar{display:none}.thumbs:before,.thumbs:after{content:"";position:sticky;top:0;width:24px;height:100%;flex:0 0 24px;pointer-events:none;z-index:2}.thumbs:before{left:0;background:linear-gradient(to right,#0b0f17,transparent)}.thumbs:after{right:0;background:linear-gradient(to left,#0b0f17,transparent)}.thumb{scroll-snap-align:center;flex:0 0 140px;aspect-ratio:16 / 9;border:2px solid transparent;border-radius:.55rem;overflow:hidden;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;background:#10151f}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb:hover{transform:translateY(-3px)}.thumb.active{border-color:#0af;box-shadow:0 0 10px #00aaff73}.thumb-video{display:grid;place-items:center;width:100%;height:100%;opacity:.85;font-size:1.4rem;color:#cfeaff}.caption{margin-top:.6rem;font-weight:600;text-align:center;color:inherit}.blurb{margin:.25rem auto 0;max-width:760px;font-size:.95rem;text-align:center;color:var(--muted-fg);line-height:1.5}.detail-body{padding:2rem 0 2.5rem}.long-text{max-width:820px;margin:0 auto;white-space:pre-line;line-height:1.65;font-size:1.05rem}.links{display:flex;justify-content:center;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.button,.ghost{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .8rem;border-radius:.6rem;border:1px solid var(--border);text-decoration:none;color:inherit}.button{background:#e6e6e6;color:#111;border-color:#e6e6e6}.ghost{background:transparent;border-color:var(--border)}.related{padding:2rem 0 4rem}.related h2{text-align:center;margin-bottom:1.25rem}.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.related-card{border:1px solid var(--border);border-radius:.8rem;overflow:hidden;text-decoration:none;color:inherit;background:var(--card);transition:transform .2s ease,box-shadow .2s ease}.related-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000004d}.related-card .thumb-wrap{aspect-ratio:16 / 9;background:#ffffff0f}.related-card img{width:100%;height:100%;object-fit:cover;display:block}.related-card .meta{padding:.75rem}.related-card h3{margin:0 0 .25rem;font-size:1rem}.related-card p{margin:0;font-size:.9rem;color:var(--muted-fg)}.error{background:#ff00000f;border:1px solid rgba(255,0,0,.35);padding:.75rem 1rem;border-radius:.75rem}@media (max-width: 860px){.projects-hero{grid-template-columns:1fr;align-items:start}}@media (prefers-contrast: more){.project-card{border-color:#334155}.project-title{color:#fff}}@media (prefers-reduced-motion: reduce){.project-card,.project-media img{transition:none!important}.skeleton:after{animation:none}.projects-grid .project-card{animation:none;opacity:1}.modal-overlay{-webkit-backdrop-filter:none;backdrop-filter:none}.modal-arrow{transition:none}.fade-swap{animation:none}}:root{--media-edge: clamp(18px, 2.2vw, 24px)}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.photography{animation:page-in .28s cubic-bezier(.2,.8,.2,1) both}.photos-header{width:min(100%,1440px);margin-inline:auto;padding:clamp(12px,3vw,20px) var(--media-edge) 8px}.photos-header-row{display:flex;align-items:center;justify-content:space-between;gap:clamp(8px,2vw,16px);flex-wrap:wrap}.photos-header-row>:first-child{flex:1 1 420px;min-width:240px}.photos-header h2{margin:0 0 4px;font-size:clamp(1.35rem,2.6vw,1.9rem);line-height:1.2}.photos-header .muted{margin:0;color:var(--muted, #94a3b8);line-height:1.35}.view-switch{--w: clamp(220px, 32vw, 270px);--h: 34px;--pad: 3px;--thumb-w: 110px;--thumb-h: 28px;--dur: .28s;--ease: cubic-bezier(.2, .7, .2, 1);appearance:none;background:none;border:0;cursor:pointer;padding:0;outline:none;display:inline-block}.view-switch .track{position:relative;width:var(--w);height:var(--h);border-radius:999px;background:color-mix(in srgb,#000 12%,transparent);border:1px solid var(--border, #1f2937);box-shadow:inset 0 0 0 1px #ffffff05}.view-switch .thumb{position:absolute;z-index:0;width:var(--thumb-w);height:var(--thumb-h);top:50%;left:24%;transform:translate(-50%,-50%);border-radius:999px;background:color-mix(in srgb,var(--brand, #6366f1) 75%,#ffffff 10%);box-shadow:0 2px 12px #00000059,inset 0 0 0 1px #ffffff40;transition:left var(--dur) var(--ease),transform .12s ease}.view-switch.is-on .thumb{left:76%}.view-switch .label{position:absolute;z-index:1;top:50%;transform:translate(-50%,-50%);font-weight:800;font-size:.92rem;line-height:1;color:#cbd5e1;white-space:nowrap;pointer-events:none}.view-switch .label.off{left:24%}.view-switch .label.on{left:76%}.view-switch:not(.is-on) .label.off,.view-switch.is-on .label.on{color:#f1f5f9}.view-switch:focus-visible .track{outline:2px solid var(--brand, #6366f1);outline-offset:2px}.view-switch:hover .thumb{transform:translate(-50%,-50%) scale(1.03)}.view-switch:active .thumb{transform:translate(-50%,-50%) scale(.98)}.view-stage{position:relative;transition:height .32s cubic-bezier(.2,.7,.2,1);will-change:height;overflow:hidden}.view-panel{position:absolute;inset:0;opacity:0;transform:translateY(8px) scale(.985);pointer-events:none;transition:opacity .28s cubic-bezier(.2,.7,.2,1),transform .28s cubic-bezier(.2,.7,.2,1)}.view-panel.is-active{position:relative;opacity:1;transform:none;pointer-events:auto}.carousel,.viewport,.carousel-head-row{width:min(100%,1440px)}.carousel{--carousel-height: clamp(360px, 60vh, 650px);margin:0 auto}.stack{display:grid;gap:clamp(16px,2vw,22px);justify-content:center}.carousel-head-row{margin:6px auto 20px;padding-inline:var(--media-edge);display:flex;align-items:center;justify-content:space-between}.carousel-title{margin:0;font-size:clamp(1rem,2vw,1.2rem)}.dots.compact{display:flex;gap:6px}.dot{height:6px;width:6px;border-radius:999px;border:0;cursor:pointer;background:var(--border, #455066);transition:background .2s ease,transform .2s ease}.dot:hover{transform:scale(1.15)}.dot.active{background:var(--brand, #4f46e5)}.carousel-shell{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(10px,2vw,18px);justify-content:center}.arrow{height:30px;width:30px;display:grid;place-items:center;border-radius:999px;background:color-mix(in srgb,var(--panel, #0f172a) 70%,transparent);border:1px solid var(--border, #1f2937);color:var(--text, #e5e7eb);cursor:pointer;transition:transform .08s ease,border-color .2s ease,background .2s ease;z-index:2}.arrow:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--brand, #4f46e5) 25%,var(--border, #1f2937));background:color-mix(in srgb,var(--panel, #0f172a) 85%,transparent)}.viewport{overflow:hidden;border-radius:10px;border:1px solid var(--border, #1f2937);background:var(--panel, #0f172a);padding:0;height:var(--carousel-height);min-height:0;box-sizing:border-box}.track{display:flex;transition:transform .35s ease;height:100%}.slide{flex:0 0 100%;height:100%}.tiles{display:grid;grid-auto-rows:100%;gap:clamp(6px,1vw,10px);height:100%}.tiles-3{grid-template-columns:repeat(3,minmax(0,1fr))}.tiles-1{grid-template-columns:1fr}.tile{margin:0;height:100%;border-radius:8px;overflow:hidden;border:1px solid var(--border, #1f2937);background:#0d1325}.tile img{width:100%;height:100%;display:block;object-fit:cover;opacity:0;transform:scale(.998);animation:tile-in .2s ease forwards}@keyframes tile-in{to{opacity:1;transform:scale(1)}}.full-bleed{position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;width:100vw;max-width:100vw;padding-inline:clamp(8px,1.6vw,18px);column-gap:clamp(8px,1.6vw,18px);column-count:1}.album-grid.stylised{padding:0 var(--media-edge)}.album-item{position:relative;break-inside:avoid;margin:0 0 clamp(8px,1.6vw,18px);border-radius:8px;overflow:hidden;border:1px solid var(--border, #1f2937);background:var(--panel, #0f172a);box-shadow:var(--shadow, 0 1px 2px rgba(2, 6, 23, .6), 0 2px 6px rgba(2, 6, 23, .5))}.album-item img{opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease;display:block;width:100%;height:auto}.album-item.is-loaded img{opacity:1;transform:translateY(0)}.page-container{overflow-x:visible}@media (max-width: 720px){.tiles-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 520px){.tiles-3{grid-template-columns:1fr}}@media (min-width: 700px){.full-bleed{column-count:2}}@media (min-width: 1000px){.full-bleed{column-count:3}}@media (min-width: 1400px){.full-bleed{column-count:4}}@media (min-width: 1800px){.full-bleed{column-count:5}}@media (max-width: 480px){.view-switch{--w: 200px;--thumb-w: 100px;--thumb-h: 26px}.view-switch .label{font-size:.88rem}.tiles{gap:6px}}.carousel--landscape{--carousel-height: clamp(240px, 45vh, 520px)}@media (max-width: 700px){.carousel--landscape{--carousel-height: clamp(160px, 34vh, 320px)}.carousel-head-row .dots,.dots{display:none!important}.carousel-shell{grid-template-columns:1fr!important;position:relative}.carousel-shell>.viewport{grid-area:1 / 1;margin-inline:auto}.carousel-shell>.arrow{grid-area:1 / 1;align-self:center;justify-self:center;z-index:3;width:28px;height:28px;background:#00000059;border-color:#ffffff24}.carousel-shell>.arrow.left{justify-self:start;margin-left:6px}.carousel-shell>.arrow.right{justify-self:end;margin-right:6px}.carousel-shell>.arrow:hover,.carousel-shell>.arrow:focus-visible{background:#00000080}.carousel--portrait .viewport{width:min(22vw,120px)}.carousel--landscape .viewport{width:min(84vw,360px);height:calc(min(84vw,360px)*.5625)}.tiles-1{justify-items:center}.tiles-1 .tile{width:100%}.carousel--landscape .tile img{object-fit:contain;background:#0d1325}.carousel-head-row{justify-content:center;text-align:center;gap:6px;margin-left:0!important}.carousel-head-row .carousel-title{text-align:center;width:100%}}@media (max-width: 420px){.carousel--landscape{--carousel-height: 140px}.carousel--portrait{--carousel-height: 450px}.carousel--portrait .viewport{width:min(66vw,360px)}.carousel--landscape .viewport{width:min(88vw,320px);height:calc(min(88vw,320px)*.5625)}}@media (prefers-reduced-motion: reduce){.photography{animation:none!important}.track,.arrow,.view-stage,.view-panel{transition:none!important}.tile img{animation:none!important;opacity:1!important;transform:none!important}.album-item img{transition:none!important;opacity:1!important;transform:none!important}}.tile-button,.album-item-button{appearance:none;border:0;background:none;padding:0;margin:0;width:100%;display:block;cursor:pointer}.tile-button:focus-visible,.album-item-button:focus-visible{outline:2px solid var(--brand, #4f46e5);outline-offset:2px;border-radius:8px}.tile-button img,.album-item-button img{cursor:pointer}.photo-modal-backdrop{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;padding:clamp(14px,3vw,24px);background:#000000a8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.photo-modal{width:min(1040px,100%);max-height:min(88vh,900px);overflow:hidden;border-radius:16px;border:1px solid var(--border, #1f2937);background:color-mix(in srgb,var(--panel, #0f172a) 92%,#000 8%);box-shadow:0 18px 60px #0000008c;display:grid;grid-template-columns:1fr;position:relative}@media (min-width: 900px){.photo-modal{grid-template-columns:1.4fr .8fr}}.photo-modal-close{position:absolute;top:10px;right:10px;height:38px;width:38px;border-radius:999px;border:1px solid var(--border, #1f2937);background:color-mix(in srgb,var(--panel, #0f172a) 70%,transparent);color:var(--text, #e5e7eb);cursor:pointer;display:grid;place-items:center;font-size:22px;line-height:1;transition:transform .08s ease,border-color .2s ease,background .2s ease;z-index:2}.photo-modal-close:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--brand, #4f46e5) 25%,var(--border, #1f2937));background:color-mix(in srgb,var(--panel, #0f172a) 85%,transparent)}.photo-modal-media{background:#0d1325;display:grid;place-items:center}.photo-modal-media img{width:100%;height:100%;max-height:88vh;object-fit:contain;display:block}.photo-modal-meta{padding:clamp(14px,2.2vw,18px);border-top:1px solid var(--border, #1f2937)}@media (min-width: 900px){.photo-modal-meta{border-top:0;border-left:1px solid var(--border, #1f2937)}}.photo-modal-title-row{display:grid;gap:6px;margin-bottom:14px}.photo-modal-title{font-weight:800;font-size:1.1rem;line-height:1.2}.photo-modal-category{font-size:.9rem;color:var(--muted, #94a3b8)}.photo-modal-details{display:grid;grid-template-columns:1fr;gap:10px;margin:0}@media (min-width: 520px){.photo-modal-details{grid-template-columns:1fr 1fr}}.photo-modal-details dt{font-size:.85rem;color:var(--muted, #94a3b8);margin:0}.photo-modal-details dd{margin:0;font-weight:700}.photo-modal-empty{margin-top:8px}.photo-modal-backdrop{padding:1rem}.photo-modal{width:min(960px,100%);max-height:calc(100dvh - 2rem);display:flex;flex-direction:column;overflow:hidden;border-radius:18px}.photo-modal-close{position:absolute;top:12px;right:12px;z-index:5}.photo-modal-media{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.photo-modal-media img{max-width:100%;max-height:100%;object-fit:contain}.photo-modal-meta{flex:0 0 auto;max-height:40dvh;overflow:auto;padding:1rem}.photo-modal-title-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline}@media (max-width: 600px){.photo-modal-backdrop{padding:.75rem}.photo-modal{max-height:calc(100dvh - 1.5rem);border-radius:16px}.photo-modal-meta{max-height:45dvh;padding:.9rem}.photo-modal-title{font-size:1.25rem}}.page-container .muted{color:var(--secondary-text)}.contact-list{list-style:none;padding:0;margin:16px auto 0;font-size:1.05rem;display:grid;gap:8px;max-width:560px;text-align:left}.page-container.contact{padding-left:clamp(1rem,4vw,2rem);padding-right:clamp(1rem,4vw,2rem)}.contact-hero{margin-bottom:16px}.contact-hero h2{margin:0 0 6px;font-size:clamp(1.6rem,3vw,2rem)}.contact-hero p{margin:0}.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(12px,2vw,16px);margin:16px 0 24px}@media (min-width: 760px){.contact-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.contact-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:14px;border-radius:var(--radius-lg);background:var(--panel-soft);border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .08s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.contact-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:color-mix(in srgb,var(--brand) 25%,var(--border));background:color-mix(in srgb,var(--panel) 92%,transparent)}.contact-icon{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:#0d1528;color:var(--brand);border:1px solid var(--border)}.contact-body h3{margin:0 0 2px;font-size:1.05rem}.contact-body p{margin:0}.contact-arrow{opacity:.7}.contact-form.panel{margin-top:8px}.contact-form-grid{display:grid;gap:12px;grid-template-columns:1fr 1fr}.field span{font-size:.95rem;color:var(--muted)}.field input,.field textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#0d1528;color:var(--text)}.field-full{grid-column:1 / -1}.actions{display:flex;gap:10px}.cv-panel{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.cv-copy{display:grid;gap:4px}#selected-work .grid.three{--gap: clamp(16px, 3vw, 24px);display:grid;gap:var(--gap);grid-template-columns:1fr}@media (min-width: 720px){#selected-work .grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1100px){#selected-work .grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}}#selected-work .card{background:var(--panel, #0f172a);border:1px solid var(--border, #1f2937);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow, 0 1px 2px rgba(2, 6, 23, .6), 0 2px 6px rgba(2, 6, 23, .5));padding:clamp(14px,2vw,18px);display:flex;flex-direction:column;min-height:100%;transition:transform .08s ease,box-shadow .2s ease,border-color .2s ease}#selected-work .card:hover,#selected-work .card:focus-within{transform:translateY(-2px);border-color:color-mix(in srgb,var(--brand, #4f46e5) 25%,var(--border, #1f2937));box-shadow:0 6px 18px #02061799;outline:none}#selected-work .thumb{margin:0 0 14px;width:100%;aspect-ratio:16 / 9;border-radius:12px;overflow:hidden;background:#0d1325}#selected-work .thumb img{display:block;width:100%;height:100%;object-fit:cover;object-position:center}#selected-work .card-title{margin:2px 0 8px;font-size:clamp(1.05rem,2.2vw,1.2rem);line-height:1.3;color:#e5e7eb}#selected-work .muted{color:var(--muted, #94a3b8);margin:0 0 12px}#selected-work .chips{margin-top:auto;display:flex;flex-wrap:wrap;gap:8px}#selected-work .chip{display:inline-block;padding:6px 10px;border-radius:999px;background:#111827;border:1px solid #243244;color:#cbd5e1;font-size:.85rem;line-height:1}@media (prefers-reduced-motion: reduce){#selected-work .card{transition:none!important}}@keyframes contact-page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.contact{animation:contact-page-in .28s cubic-bezier(.2,.8,.2,1) both}@keyframes contact-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.contact-grid .contact-card{opacity:0;animation:contact-card-in .36s ease forwards}.contact-grid .contact-card:nth-of-type(1){animation-delay:40ms}.contact-grid .contact-card:nth-of-type(2){animation-delay:90ms}.contact-grid .contact-card:nth-of-type(3){animation-delay:.14s}.contact-grid .contact-card:nth-of-type(4){animation-delay:.19s}.contact-form.panel,.cv-panel{opacity:0;animation:contact-card-in .36s ease forwards}.contact-form.panel{animation-delay:.18s}.cv-panel{animation-delay:.22s}.contact-card{position:relative}.contact-card .contact-arrow{transition:transform .2s ease,opacity .2s ease}.contact-card:hover .contact-arrow{transform:translate(2px);opacity:1}.contact-icon{transition:transform .2s ease,background .2s ease,border-color .2s ease}.contact-card:hover .contact-icon{transform:scale(1.03);background:color-mix(in srgb,var(--brand, #4f46e5) 18%,#0d1528);border-color:color-mix(in srgb,var(--brand, #4f46e5) 25%,var(--border, #1f2937))}.field input,.field textarea{transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.field input:focus,.field textarea:focus{outline:none;border-color:color-mix(in srgb,var(--brand, #4f46e5) 30%,var(--border, #1f2937));box-shadow:0 0 0 3px color-mix(in srgb,var(--brand, #4f46e5) 18%,transparent);background:#0e1831}@media (prefers-reduced-motion: reduce){.contact,.contact-grid .contact-card,.contact-form.panel,.cv-panel{animation:none!important;transition:none!important;opacity:1!important;transform:none!important}}canvas{width:100vw;height:100vh;display:block}.badge{position:fixed;right:12px;top:12px;padding:10px 12px;border-radius:14px;background:#10d4ff24;border:1px solid rgba(16,212,255,.3);font-weight:600;font-size:11px;color:#ccefff;pointer-events:none;-webkit-user-select:none;user-select:none}.rcp-root{display:grid;width:345px;gap:12px;padding:14px;border-radius:12px;border:1px solid rgba(0,0,0,.12);background:#fff;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;-webkit-user-select:none;user-select:none;box-sizing:border-box}.rcp-root-dark{background:#2a2a2a;color:#fff;border-color:#ffffff1f}.rcp-sat{position:relative;width:100%;border-radius:12px;overflow:hidden;touch-action:none;box-sizing:border-box}.rcp-sat-white{pointer-events:none;position:absolute;inset:0;background:linear-gradient(90deg,#fff,#fff0);border-radius:12px}.rcp-sat-black{pointer-events:none;position:absolute;inset:0;background:linear-gradient(0deg,#000,#0000);border-radius:12px}.rcp-thumb{pointer-events:none;position:absolute;width:14px;height:14px;transform:translate(-7px,-7px);border-radius:50%;border:2px solid #ffffff;box-shadow:0 0 0 1px #00000059;box-sizing:border-box}.rcp-hue{position:relative;width:100%;height:12px;margin-top:6px;margin-bottom:4px;border-radius:999px;overflow:hidden;touch-action:none;box-sizing:border-box;background:linear-gradient(90deg,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.rcp-hue-thumb{position:absolute;top:50%;width:12px;height:12px;transform:translate(-6px,-50%);border-radius:50%;border:2px solid #ffffff;box-shadow:0 0 0 1px #00000059;box-sizing:border-box}.rcp-fields{display:grid;gap:8px;padding-top:4px;padding-left:2px;padding-right:2px;width:100%;box-sizing:border-box;min-width:0}.rcp-field{display:grid;gap:6px;min-width:0}.rcp-field-label{font-size:11px;opacity:.85}.rcp-hex-input-single{width:100%;height:30px;border-radius:6px;border:1px solid rgba(0,0,0,.25);background:#0000000f;padding:0 10px;font-size:13px;font:inherit;color:inherit;outline:none;box-sizing:border-box;max-width:100%;min-width:0}.rcp-root-dark .rcp-hex-input-single{background:#1e1e1e;border-color:#3a3a3a;color:#fff}.rcp-rgb{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%;min-width:0;box-sizing:border-box}.rcp-input{width:100%;height:30px;border-radius:6px;border:1px solid rgba(0,0,0,.25);background:#0000000f;padding:0 10px;font-size:13px;font:inherit;color:inherit;outline:none;box-sizing:border-box;max-width:100%;min-width:0}.rcp-root-dark .rcp-input{background:#1e1e1e;border-color:#3a3a3a;color:#fff}.aboutme{padding-top:40px}.aboutme-container{max-width:1120px;margin:0 auto;padding-left:clamp(16px,2.6vw,24px);padding-right:clamp(16px,2.6vw,24px)}.aboutme-section{padding:clamp(48px,8vw,22px) 0}.aboutme-section-alt{background:#0d1528}.aboutme-head{display:grid;gap:6px;margin-bottom:clamp(16px,2.6vw,24px)}.aboutme-eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:#8aa5ff}.aboutme-title{margin:0;font-size:clamp(22px,3vw,32px)}.aboutme-sub{margin:0;color:#94a3b8;max-width:70ch}.aboutme-hero-grid{display:grid;gap:clamp(16px,2.6vw,24px);align-items:start;margin-top:clamp(14px,2vw,18px)}@media (min-width: 900px){.aboutme-hero-grid{grid-template-columns:1.25fr .75fr}}.aboutme-panel{background:color-mix(in srgb,#0f172a 94%,transparent);border:1px solid #1f2937;border-radius:16px;padding:clamp(14px,2.2vw,18px);box-shadow:0 1px 2px #02061799,0 2px 6px #02061780}.aboutme-panel-title{margin:0 0 10px}.aboutme-panel-subtitle{margin:0 0 10px;font-size:1rem}.aboutme-stats{display:grid;grid-template-columns:1fr;gap:10px}@media (min-width: 520px){.aboutme-stats{grid-template-columns:1fr 1fr 1fr}}.aboutme-stat{background:color-mix(in srgb,#0f172a 82%,transparent);border:1px solid #1f2937;border-radius:12px;padding:12px 14px}.aboutme-stat-value{font-weight:800;letter-spacing:.2px;line-height:1.1;color:#e5e7eb}.aboutme-stat-label{margin-top:2px;font-size:.9rem;color:#94a3b8}.aboutme-divider{height:1px;background:#1f2937;margin:14px 0}.aboutme-list{margin:0;padding-left:18px;display:grid;gap:8px;color:#94a3b8}.aboutme-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.aboutme-chip{display:inline-block;font-size:12px;padding:4px 8px;border:1px solid #1f2937;border-radius:999px;color:#94a3b8}.aboutme-photo-frame{border-radius:14px;overflow:hidden;border:1px solid #1f2937;background:#1b2236;aspect-ratio:4 / 5}.aboutme-photo-frame img{width:100%;height:100%;object-fit:cover;object-position:79% center;display:block}.aboutme-photo-caption{margin-top:10px;color:#94a3b8;font-size:.95rem}.aboutme-grid{display:grid;gap:clamp(16px,2.6vw,24px);grid-template-columns:1fr}@media (min-width: 900px){.aboutme-grid{grid-template-columns:1fr 1fr 1fr}}.aboutme-card{background:#0f172a;border:1px solid #1f2937;border-radius:16px;padding:clamp(16px,2.6vw,24px);box-shadow:0 1px 2px #02061799,0 2px 6px #02061780}.aboutme-card-title{margin:0 0 6px;color:#e5e7eb}.aboutme-card-body{margin:0;color:#94a3b8}.aboutme-cta{margin-top:clamp(18px,2.6vw,24px);background:color-mix(in srgb,#0f172a 94%,transparent);border:1px solid #1f2937;border-radius:16px;padding:clamp(14px,2.2vw,18px);box-shadow:0 1px 2px #02061799,0 2px 6px #02061780;display:grid;gap:14px;align-items:center}@media (min-width: 760px){.aboutme-cta{grid-template-columns:1fr auto}}.aboutme-cta-title{font-weight:800;color:#e5e7eb}.aboutme-cta-sub{color:#94a3b8;margin-top:4px}.aboutme-cta-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}.aboutme-hobbies-grid{display:grid;gap:clamp(16px,2.6vw,24px);grid-template-columns:1fr;margin-top:clamp(14px,2vw,18px)}@media (min-width: 760px){.aboutme-hobbies-grid{grid-template-columns:1fr 1fr}}.aboutme-hobby-card{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;background:#0f172a;border:1px solid #1f2937;border-radius:16px;padding:clamp(14px,2.2vw,18px);box-shadow:0 1px 2px #02061799,0 2px 6px #02061780;transition:transform .08s ease,border-color .2s ease}.aboutme-hobby-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,#4f46e5 25%,#1f2937)}.aboutme-hobby-icon{width:32px;height:32px;display:grid;place-items:center;color:var(--brand)}.aboutme-hobby-icon svg{width:100%;height:100%;fill:currentColor}.aboutme-hobby-title{font-weight:700;margin-bottom:4px;color:#e5e7eb}.aboutme-hobby-body{color:#94a3b8;font-size:.95rem}:root{--panel-border: rgba(255, 255, 255, .14);--panel-bg: rgba(255, 255, 255, .04);--btn-bg: rgba(255, 255, 255, .06);--btn-border: rgba(255, 255, 255, .18);--text-muted: rgba(255, 255, 255, .75)}.explain-ui{width:min(100%,1400px);margin-inline:auto;padding:18px;display:grid;gap:14px}.explain-ui-header{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}.explain-ui-title h1{margin:0;font-size:2rem}.explain-ui-title p{margin:6px 0 0;color:var(--text-muted)}.explain-ui-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{border:1px solid var(--btn-border);background:var(--btn-bg);padding:10px 12px;border-radius:12px;cursor:pointer;transition:transform .06s ease;color:inherit}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:active:not(:disabled){transform:translateY(1px)}.btn.danger{border-color:#ff505059}.explain-ui-main{display:grid;grid-template-columns:1.45fr .55fr;gap:14px;min-height:72vh}.panel{border:1px solid var(--panel-border);background:var(--panel-bg);border-radius:16px;padding:12px}.panel-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.panel-group{display:grid;gap:8px}.panel-label{font-size:.9rem;color:var(--text-muted)}.segmented{display:inline-flex;border:1px solid var(--panel-border);border-radius:12px;overflow:hidden;width:fit-content}.segmented-btn{border:none;background:transparent;padding:10px 12px;cursor:pointer;opacity:.85;color:inherit}.segmented-btn.active{background:#ffffff1a;opacity:1}.panel-hint{margin-top:10px;font-size:.9rem;color:var(--text-muted)}.canvas{margin-top:14px;border-radius:16px;border:1px solid var(--panel-border);background:#00000047;min-height:62vh;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none}.canvas.drag-over{outline:2px solid rgba(255,255,255,.35);outline-offset:-2px}.canvas-stage{position:absolute;top:0;left:0}.canvas-image{display:block;pointer-events:none}.canvas-empty{height:100%;display:grid;place-items:center;padding:20px}.canvas-empty-inner{text-align:center;max-width:460px}.canvas-empty-title{font-size:1.1rem;font-weight:650}.canvas-empty-subtitle{margin-top:6px;color:var(--text-muted)}.pin{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:999px;border:1px solid rgba(255,255,255,.35);background:#0000008c;cursor:pointer;display:grid;place-items:center;font-weight:750;color:inherit}.pin.selected{outline:2px solid rgba(255,255,255,.7)}.explain-ui-right{display:grid;gap:14px;align-content:start}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-title{font-weight:750}.panel-empty{margin-top:10px;color:var(--text-muted);font-size:.95rem}.form{display:grid;gap:10px;margin-top:10px}.field{display:grid;gap:6px}.field-label{font-size:.9rem;color:var(--text-muted)}.input,.textarea,.select{width:100%;border-radius:12px;border:1px solid var(--panel-border);background:#00000040;padding:10px;color:inherit}.textarea{resize:vertical}.meta{display:grid;gap:6px;font-size:.9rem;color:var(--text-muted)}.pin-list{margin-top:10px;display:grid;gap:8px}.pin-list-item{text-align:left;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0000002e;padding:10px;cursor:pointer;color:inherit}.pin-list-item.active{border-color:#ffffff59}.pin-list-title{font-weight:650}.pin-list-sub{margin-top:4px;color:var(--text-muted);font-size:.9rem}.toolbar-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.badge{border:1px solid var(--panel-border);background:#00000029;border-radius:999px;padding:6px 10px;font-size:.9rem;color:var(--text-muted)}@media (max-width: 980px){.explain-ui-main{grid-template-columns:1fr}}.pin{border-color:color-mix(in srgb,var(--pin-colour) 70%,rgba(255,255,255,.35));background:color-mix(in srgb,var(--pin-colour) 45%,rgba(0,0,0,.55));box-shadow:0 0 0 2px color-mix(in srgb,var(--pin-colour) 45%,transparent)}.pin.selected{outline:2px solid color-mix(in srgb,var(--pin-colour) 75%,rgba(255,255,255,.7));box-shadow:0 0 0 4px color-mix(in srgb,var(--pin-colour) 30%,transparent)}.colour-row{display:grid;grid-template-columns:1fr max-content;gap:10px;align-items:center}.colour-swatch{width:44px;height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:var(--swatch-colour)}.colour-input{height:38px;width:44px;padding:0;border:none;background:transparent;cursor:pointer}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.mxp-root{display:flex;flex-direction:column;height:100%;background:#0b0f14;color:#e2e8f0;font-family:DM Sans,sans-serif;border-radius:12px;overflow:hidden;border:1px solid #1e2733}.mxp-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0d1117;border-bottom:1px solid #1e2733;flex-wrap:wrap;gap:12px}.mxp-title-block{display:flex;flex-direction:column;gap:2px}.mxp-label{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.2em;color:#4a5568;text-transform:uppercase}.mxp-title{font-family:Space Mono,monospace;font-size:18px;font-weight:700;margin:0;color:#f8fafc;letter-spacing:-.02em}.mxp-legend{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.mxp-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#94a3b8;font-family:Space Mono,monospace}.mxp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.mxp-reset-btn{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;padding:5px 14px;border-radius:4px;border:1px solid #2d3748;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s ease;text-transform:uppercase}.mxp-reset-btn:hover{background:#1e2733;color:#e2e8f0;border-color:#4a5568}.mxp-status{display:flex;align-items:center;gap:10px;padding:10px 24px;font-size:13px;font-family:Space Mono,monospace;border-bottom:1px solid #1e2733}.mxp-status--loading{color:#94a3b8;background:#0d1117}.mxp-status--error{color:#fc8181;background:#1a0f0f}.mxp-status--running{color:#f59e0b;background:#0d1117}.mxp-status--done{color:#34d399;background:#0d160f}.mxp-status--info{color:#60a5fa;background:#0d1117}.mxp-spinner{width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:mxp-spin .7s linear infinite;flex-shrink:0;display:inline-block}.mxp-spinner--small{width:8px;height:8px;border-width:1.5px}@keyframes mxp-spin{to{transform:rotate(360deg)}}.mxp-map-wrap{flex:1;position:relative}.mxp-map{width:100%;height:100%;min-height:1000px}.mxp-map .leaflet-container{background:#0b0f14}.mxp-trip-stats{display:flex;align-items:center;gap:0;padding:10px 24px;border-bottom:1px solid #1e2733;transition:background .4s ease}.mxp-trip-stats--live{background:#0d1117}.mxp-trip-stats--exact{background:#0d160f}.mxp-trip-stat{display:flex;flex-direction:column;gap:2px;padding:0 20px 0 0}.mxp-trip-label{font-family:Space Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:#4a5568;transition:color .3s ease}.mxp-trip-stats--exact .mxp-trip-label{color:#2d6a4f}.mxp-trip-value{font-family:Space Mono,monospace;font-size:16px;font-weight:700;letter-spacing:-.02em;transition:color .4s ease;color:#f59e0b}.mxp-trip-stats--exact .mxp-trip-value{color:#34d399}.mxp-trip-unit{font-size:12px;font-weight:400;opacity:.6}.mxp-trip-divider{width:1px;height:32px;background:#1e2733;margin:0 20px 0 0}.mxp-trip-badge{margin-left:auto;display:flex;align-items:center;gap:6px;font-family:Space Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#f59e0b;opacity:.7}.mxp-trip-badge--done{color:#34d399;opacity:1}.mxp-trip-empty{color:#2d3748}.mxp-mode-toggle{display:flex;gap:8px}.mxp-mode-btn{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;padding:6px 16px;border-radius:4px;border:1px solid #2d3748;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s ease;text-transform:uppercase}.mxp-mode-btn:hover{background:#1e2733;color:#e2e8f0;border-color:#4a5568}.mxp-mode-btn--active{border-color:#6366f1;color:#e2e8f0;background:#6366f11f}.mxp-planner-panel{display:flex;align-items:center;gap:24px;padding:12px 24px;border-bottom:1px solid #1e2733;background:#0d1117;flex-wrap:wrap}.mxp-planner-field{display:flex;flex-direction:column;gap:6px}.mxp-planner-range-row{display:flex;align-items:center;gap:10px}.mxp-range{width:140px;accentColor:#6366f1}.mxp-planner-miles{font-family:Space Mono,monospace;font-size:13px;color:#e2e8f0;min-width:40px}.mxp-planner-toggle{display:flex;gap:6px}.mxp-planner-btn{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;padding:5px 12px;border-radius:4px;border:1px solid #2d3748;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s ease;text-transform:uppercase}.mxp-planner-btn--active{border-color:#a78bfa;color:#e2e8f0;background:#a78bfa1f}.mxp-planner-stats{display:flex;align-items:center;gap:0}.mxp-planner-stat{display:flex;flex-direction:column;gap:2px;padding:0 20px 0 0}.mxp-planner-actions{display:flex;align-items:center;gap:10px;margin-left:auto}.mxp-planner-find-btn{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;padding:7px 18px;border-radius:4px;border:none;background:#6366f1;color:#fff;cursor:pointer;text-transform:uppercase;transition:opacity .15s ease;display:flex;align-items:center;gap:6px}.mxp-planner-find-btn:disabled{opacity:.45;cursor:not-allowed}.mxp-planner-find-btn:hover:not(:disabled){opacity:.85}.ad-wrapper{display:flex;flex-direction:column;gap:24px}.ad-section-header{display:flex;justify-content:space-between;align-items:center}.ad-section-header h2{font-size:1.1rem;font-weight:600;color:var(--text)}.ad-header-right{display:flex;align-items:center;gap:12px}.ad-refresh-time{font-size:.8rem;color:var(--muted)}.ad-refresh-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);padding:6px 12px;font-size:.85rem;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s}.ad-refresh-btn:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}.ad-refresh-btn:disabled{opacity:.5;cursor:default}.ad-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.ad-stat-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow)}.ad-stat-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.ad-stat-num{font-size:2rem;font-weight:700;color:var(--brand);line-height:1}.ad-charts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.ad-chart-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}.ad-chart-header{display:flex;justify-content:space-between;align-items:center}.ad-chart-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.ad-chart-empty{height:120px;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--muted)}.ad-functions-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}.ad-card-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.ad-fn-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}.ad-fn-row:last-child{border-bottom:none;padding-bottom:0}.ad-fn-info{display:flex;flex-direction:column;gap:3px}.ad-fn-name{font-size:.9rem;color:var(--text);font-weight:500}.ad-fn-time{font-size:.75rem;color:var(--muted)}.ad-fn-error{font-size:.75rem;color:#e05555;max-width:400px}.ad-badge{font-size:.75rem;padding:3px 10px;border-radius:20px;font-weight:600;flex-shrink:0}.ad-badge--ok{background:color-mix(in srgb,#4ade80 15%,transparent);color:#4ade80}.ad-badge--error{background:color-mix(in srgb,#e05555 15%,transparent);color:#e05555}.ad-badge--unknown{background:color-mix(in srgb,var(--muted) 15%,transparent);color:var(--muted)}.ad-links-row{display:flex;gap:16px;flex-wrap:wrap}.ad-console-link{font-size:.85rem;color:var(--brand);text-decoration:none;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .15s,background .15s}.ad-console-link:hover{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 8%,transparent)}@media (max-width: 1024px){.ad-stats-row{grid-template-columns:repeat(2,1fr)}.ad-charts-grid{grid-template-columns:1fr}}@media (max-width: 600px){.ad-stats-row{grid-template-columns:repeat(2,1fr)}}.cd-wrapper{display:flex;flex-direction:column;gap:16px;margin-top:32px}.cd-header{display:flex;justify-content:space-between;align-items:center}.cd-header h2{font-size:1.1rem;font-weight:600;color:var(--text)}.cd-totals-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.cd-total-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:4px}.cd-total-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.cd-total-value{font-size:1.8rem;font-weight:700;color:var(--brand);line-height:1.1}.cd-total-note{font-size:.75rem;color:var(--muted)}.cd-chart-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}.cd-chart-header{display:flex;justify-content:space-between;align-items:center}.cd-card-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.cd-period-tabs{display:flex;gap:4px}.cd-period-btn{font-size:.8rem;padding:4px 10px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--muted);cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s,background .15s}.cd-period-btn:hover{border-color:var(--brand);color:var(--text)}.cd-period-btn--active{background:color-mix(in srgb,var(--brand) 12%,transparent);border-color:var(--brand);color:var(--brand)}.cd-chart-empty{height:200px;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--muted)}.cd-metrics-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}.cd-metric-row{display:grid;grid-template-columns:200px 1fr 80px;align-items:center;gap:16px}.cd-metric-info{display:flex;flex-direction:column;gap:2px}.cd-metric-label{font-size:.9rem;color:var(--text)}.cd-metric-count{font-size:.78rem;color:var(--muted)}.cd-metric-bar-wrap{display:flex;flex-direction:column;gap:4px}.cd-metric-bar{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.cd-metric-fill{height:100%;border-radius:99px;transition:width .3s ease}.cd-metric-fill--warn{background:#e05555!important}.cd-metric-free{font-size:.72rem;color:var(--muted)}.cd-metric-cost{font-size:.9rem;font-weight:600;color:var(--text);text-align:right}.cd-disclaimer{font-size:.78rem;color:var(--muted);display:flex;align-items:center;flex-wrap:wrap}.cd-loading{padding:24px 0;font-size:.9rem}@media (max-width: 1024px){.cd-totals-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.cd-totals-row{grid-template-columns:1fr 1fr}.cd-metric-row{grid-template-columns:1fr 60px;grid-template-rows:auto auto}.cd-metric-bar-wrap{grid-column:1 / -1}.cd-period-tabs{flex-wrap:wrap}}.ap-page{max-width:1400px;margin:40px auto;padding:0 24px 80px}.ap-loading{padding:40px;color:var(--muted)}.ap-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.ap-page-actions{display:flex;gap:8px}.ap-list{display:flex;flex-direction:column;gap:10px}.ap-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--panel);box-shadow:var(--shadow)}.ap-card--row{display:flex;justify-content:space-between;align-items:center;padding:14px 18px}.ap-card--form{padding:28px;margin-bottom:24px}.ap-card--form h2{margin-bottom:20px;font-size:1.1rem;color:var(--text)}.ap-card-info{display:flex;flex-direction:column;gap:4px}.ap-card-info strong{color:var(--text)}.ap-tech-preview{font-size:.8rem;color:var(--muted)}.ap-card-actions{display:flex;gap:8px;align-items:center}.ap-page-actions button,.ap-form-actions button{padding:8px 16px;border-radius:var(--radius-md);font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.ap-page-actions button:first-child,.ap-form-actions button:first-child{background:var(--brand);color:var(--brand-ink);border:1px solid var(--brand)}.ap-page-actions button:first-child:hover,.ap-form-actions button:first-child:hover{background:color-mix(in srgb,var(--brand) 85%,#fff)}.ap-page-actions button.ghost,.ap-form-actions button.ghost,.ap-card-actions button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.ap-page-actions button.ghost:hover,.ap-form-actions button.ghost:hover,.ap-card-actions button.ghost:hover{border-color:var(--brand);color:var(--brand)}.ap-card-actions button{padding:6px 12px;border-radius:var(--radius-md);font-size:.85rem;font-family:inherit;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text);transition:background .15s,border-color .15s,color .15s}.ap-delete-btn{color:#e05555!important;border-color:#e05555!important}.ap-delete-btn:hover{background:#e05555!important;color:#fff!important}.ap-form{display:flex;flex-direction:column;gap:16px}.ap-field{display:flex;flex-direction:column;gap:6px}.ap-field label{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.ap-form input[type=text],.ap-form input[type=email],.ap-form textarea,.ap-section input[type=text],.ap-media-fields input[type=text],.ap-row input[type=text]{width:100%;box-sizing:border-box;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;color:var(--text);font-size:.9rem;font-family:inherit;transition:border-color .15s;resize:vertical}.ap-form input[type=text]:focus,.ap-form input[type=email]:focus,.ap-form textarea:focus,.ap-section input[type=text]:focus,.ap-media-fields input[type=text]:focus,.ap-row input[type=text]:focus{outline:var(--focus);border-color:var(--brand)}.ap-form-actions{display:flex;gap:8px;padding-top:8px}.ap-section{border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--bg)}.ap-section-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.ap-add-btn{font-size:.8rem;padding:4px 10px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--text);cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s}.ap-add-btn:hover{border-color:var(--brand);color:var(--brand)}.ap-empty{font-size:.85rem;color:var(--muted);margin:0}.ap-row{display:flex;gap:8px;align-items:center}.ap-row input{flex:1;margin:0}.ap-remove-btn{background:transparent;border:none;color:#e05555;cursor:pointer;font-size:.85rem;padding:4px 8px;border-radius:4px;flex-shrink:0;font-family:inherit;transition:background .15s,color .15s}.ap-remove-btn:hover{background:#e05555;color:#fff}.ap-media-carousel{display:flex;flex-direction:column;gap:12px}.ap-media-carousel-preview{position:relative;background:var(--bg);border-radius:var(--radius-md);overflow:hidden;aspect-ratio:16 / 9;max-height:320px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}.ap-media-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.ap-media-preview img,.ap-media-preview-video{width:100%;height:100%;object-fit:contain;display:block}.ap-media-preview--empty{color:var(--muted);font-size:.85rem}.ap-media-carousel-arrows{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:#0000008c;border-radius:20px;padding:4px 12px}.ap-arrow{background:transparent;border:none;color:#fff;font-size:1.4rem;cursor:pointer;line-height:1;padding:0 4px;opacity:.8;transition:opacity .15s}.ap-arrow:disabled{opacity:.2;cursor:default}.ap-arrow:hover:not(:disabled){opacity:1}.ap-media-counter{font-size:.8rem;color:#fff;min-width:40px;text-align:center}.ap-media-badge{position:absolute;top:8px;right:8px;background:#0009;color:#fff;font-size:.7rem;padding:2px 8px;border-radius:4px}.ap-media-fields{display:flex;flex-direction:column;gap:8px}.ap-media-item-header{display:flex;justify-content:space-between;align-items:center}.ap-media-index{font-size:.8rem;color:var(--muted);font-weight:600}.ap-media-thumbs{display:flex;gap:8px;flex-wrap:wrap;padding-bottom:4px}.ap-media-thumb{width:56px;height:56px;border-radius:6px;overflow:hidden;border:2px solid var(--border);background:var(--bg);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s}.ap-media-thumb img{width:100%;height:100%;object-fit:cover;display:block}.ap-media-thumb--active{border-color:var(--brand)}.ap-thumb-icon{font-size:1.2rem;color:var(--muted)}.ap-upload-btn{font-size:.8rem;padding:4px 10px;border-radius:6px;background:color-mix(in srgb,var(--brand) 15%,transparent);border:1px solid var(--brand);color:var(--brand);cursor:pointer;font-family:inherit;transition:background .15s}.ap-upload-btn:hover:not(:disabled){background:color-mix(in srgb,var(--brand) 25%,transparent)}.ap-upload-btn:disabled{opacity:.4;cursor:default}.ap-paste-hint{font-size:.72rem;color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}.ap-media-paste-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:#fff;border-radius:var(--radius-md)}.ap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}@media (max-width: 600px){.ap-grid{grid-template-columns:1fr}}.ap-tile{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel);overflow:hidden;cursor:pointer;transition:border-color .2s,box-shadow .2s;display:flex;flex-direction:column}.ap-tile:hover,.ap-tile--editing{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand)}.ap-tile-image{width:100%;height:180px;background-color:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;flex-shrink:0}.ap-tile-info{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--panel);min-height:48px}.ap-tile-title{font-size:.9rem;font-weight:600;color:var(--text);line-height:1.3;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ap-tile-image--empty{border-bottom:1px solid var(--border)}.ap-tile-image-placeholder{font-size:2rem;color:var(--border)}.ap-tile-info{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-top:1px solid var(--border);background:var(--panel)}.ap-tile-title{font-size:.9rem;font-weight:600;color:var(--text);line-height:1.3;word-break:break-word;flex:1}.ap-tile-actions{display:flex;gap:8px;flex-shrink:0}.ap-tile-actions button{padding:5px 12px;border-radius:var(--radius-md);font-size:.8rem;font-family:inherit;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text);transition:background .15s,border-color .15s,color .15s}.ap-tile-actions button:hover{border-color:var(--brand);color:var(--brand)}.ap-tile-actions .ap-delete-btn{border-color:#e05555!important;color:#e05555!important;background:transparent!important}.ap-tile-actions .ap-delete-btn:hover{background:#e05555!important;color:#fff!important}.aph-page{max-width:1100px;margin:40px auto;padding:0 24px 80px}.aph-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.aph-back{background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);padding:8px 16px;font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s}.aph-back:hover{border-color:var(--brand);color:var(--brand)}.aph-dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:40px 24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:20px;background:var(--panel)}.aph-dropzone:hover,.aph-dropzone--active{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 5%,var(--panel))}.aph-dropzone-icon{font-size:2rem}.aph-dropzone-text{font-size:1rem;font-weight:600;color:var(--text)}.aph-dropzone-sub{font-size:.85rem;color:var(--muted)}.aph-progress-list{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.aph-progress-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);font-size:.85rem}.aph-progress-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}.aph-progress-status--converting,.aph-progress-status--uploading{color:var(--muted)}.aph-progress-status--done{color:#4ade80}.aph-progress-status--error{color:#e05555}.aph-tabs{display:flex;gap:8px;margin-bottom:20px}.aph-tab{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.aph-tab:hover{border-color:var(--brand);color:var(--text)}.aph-tab--active{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 10%,transparent);color:var(--text)}.aph-tab-count{background:var(--border);color:var(--muted);font-size:.75rem;padding:1px 7px;border-radius:20px}.aph-tab--active .aph-tab-count{background:var(--brand);color:var(--brand-ink)}.aph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.aph-photo-card{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--panel);box-shadow:var(--shadow);display:flex;flex-direction:column}.aph-photo-img-wrap{aspect-ratio:1 / 1;overflow:hidden;background:var(--bg)}.aph-photo-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.aph-photo-card:hover .aph-photo-img-wrap img{transform:scale(1.04)}.aph-photo-footer{padding:8px 10px;display:flex;justify-content:space-between;align-items:center;gap:8px}.aph-photo-name{font-size:.75rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.aph-delete-btn{background:transparent;border:1px solid transparent;color:#e05555;font-size:.75rem;padding:3px 8px;border-radius:4px;cursor:pointer;font-family:inherit;flex-shrink:0;transition:background .15s,border-color .15s}.aph-delete-btn:hover{background:#e05555;color:#fff;border-color:#e05555}.aph-delete-confirm{display:flex;gap:4px;flex-shrink:0}.aph-delete-confirm button{font-size:.75rem;padding:3px 8px;border-radius:4px;cursor:pointer;font-family:inherit;border:1px solid var(--border);background:var(--brand);color:var(--brand-ink)}.aph-delete-confirm button.ghost{background:transparent;color:var(--text)}.aph-loading{padding:40px 0;color:var(--muted)}.aph-search-bar{position:relative;margin-bottom:16px}.aph-search-bar input{width:100%;box-sizing:border-box;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 36px 10px 14px;color:var(--text);font-size:.9rem;font-family:inherit;transition:border-color .15s}.aph-search-bar input:focus{outline:var(--focus);border-color:var(--brand)}.aph-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;padding:0 4px;line-height:1}.aph-search-clear:hover{color:var(--text)}.aph-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.aph-toolbar .aph-search-bar{flex:1;margin-bottom:0}.aph-sort{display:flex;align-items:center;gap:8px;flex-shrink:0}.aph-sort label{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.aph-sort select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:.85rem;font-family:inherit;padding:7px 10px;cursor:pointer}.aph-sort select:focus{outline:var(--focus);border-color:var(--brand)}.admin-shell{display:flex;min-height:calc(100vh - 60px);width:100%}.admin-sidebar{width:220px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 16px;gap:8px;position:sticky;top:60px;height:calc(100vh - 60px);box-sizing:border-box}.admin-sidebar-header{display:flex;flex-direction:column;gap:4px;padding:0 8px 16px;border-bottom:1px solid var(--border);margin-bottom:8px}.admin-sidebar-title{font-size:1rem;font-weight:700;color:var(--text)}.admin-sidebar-email{font-size:.75rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}.admin-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--muted);font-size:.9rem;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s,color .15s;width:100%}.admin-nav-item:hover{background:color-mix(in srgb,var(--brand) 8%,transparent);color:var(--text)}.admin-nav-item--active{background:color-mix(in srgb,var(--brand) 12%,transparent);color:var(--brand);font-weight:600}.admin-nav-icon{font-size:1rem;width:20px;text-align:center}.admin-signout{background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--muted);padding:8px 12px;font-size:.85rem;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s;text-align:left}.admin-signout:hover{border-color:#e05555;color:#e05555}.admin-content{flex:1;padding:32px 40px 80px;overflow-y:auto;min-width:0}.admin-content-header{margin-bottom:24px}.admin-content-header h1{font-size:1.5rem;font-weight:700;color:var(--text)}.admin-quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:40px}.admin-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:24px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);cursor:pointer;transition:border-color .15s,box-shadow .15s;font-family:inherit;text-align:left;width:100%;box-sizing:border-box}.admin-card:hover{border-color:var(--brand);box-shadow:var(--shadow-lg)}.admin-card-icon{font-size:1.6rem}.admin-card-title{font-size:1rem;font-weight:600;color:var(--text)}.admin-card-desc{font-size:.85rem;color:var(--muted)}@media (max-width: 768px){.admin-shell{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;padding:12px 16px;gap:8px}.admin-sidebar-header{width:100%;border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:0}.admin-nav{flex-direction:row;flex:none}.admin-content{padding:20px 16px 60px}}:root{--ss-bg: #000000;--ss-panel: #1A1A1A;--ss-brand: #45A29E;--ss-text: #45A29E;--ss-muted: #888;--ss-border: #45A29E;--ss-dark-text: #1A1A1A}.ss-shell{inset:0;z-index:9999;background:var(--ss-bg);color:var(--ss-text);display:flex;flex-direction:column;overflow-y:auto;font-family:Poppins,Arial,sans-serif}.ss-nav{display:flex;align-items:center;justify-content:space-between;padding:5px 20px;height:70px;background:var(--ss-panel);border-bottom:1px solid var(--ss-border);position:sticky;top:0;z-index:10}.ss-logo{font-size:1.2rem;font-weight:700;color:var(--ss-brand);text-decoration:none}.ss-nav-links{display:flex;align-items:center;gap:32px}.ss-nav-links a{position:relative;color:var(--ss-brand);text-decoration:none;font-size:1rem;font-weight:500}.ss-nav-links a:after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--ss-brand);border-radius:2px;transform-origin:right;transform:scaleX(0);transition:transform .3s}.ss-nav-links a:hover:after,.ss-nav-links a.active:after{transform-origin:left;transform:scaleX(1)}.ss-nav-btn{background:transparent;border:2px solid var(--ss-brand);color:var(--ss-brand);padding:6px 18px;border-radius:6px;font-size:1rem;font-family:inherit;cursor:pointer;transition:background .2s,color .2s}.ss-nav-btn:hover{background:var(--ss-brand);color:var(--ss-dark-text)}.ss-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:40px 24px 100px}.ss-footer{text-align:center;padding:10px;font-size:.85rem;color:var(--ss-brand);background:var(--ss-panel);border-top:1px solid var(--ss-border);position:fixed;bottom:0;width:100%}.ss-page-title{font-size:1.8rem;font-weight:700;margin:0 0 4px;color:var(--ss-brand)}.ss-page-sub{color:var(--ss-muted);font-size:.9rem;margin:0 0 32px}.ss-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-top:24px}.ss-album-card{background:var(--ss-panel);border:1px solid var(--ss-border);border-radius:8px;overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}.ss-album-card:hover{transform:translateY(-3px);box-shadow:0 0 12px #45a29e66}.ss-album-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.ss-album-card-info{padding:12px}.ss-album-card-info h3{font-size:.95rem;margin:0 0 4px;color:var(--ss-brand)}.ss-album-card-info p{font-size:.8rem;color:var(--ss-muted);margin:0}.ss-form-wrap{max-width:420px;margin:60px auto 0;background:transparent;border:2px solid var(--ss-brand);border-radius:20px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:40px}.ss-form-wrap h2{font-size:2rem;color:var(--ss-brand);text-align:center;margin:0 0 24px}.ss-field{display:flex;flex-direction:column;gap:0;margin-bottom:28px;position:relative;border-bottom:2px solid var(--ss-brand)}.ss-field label{font-size:.85rem;font-weight:500;color:var(--ss-brand);margin-bottom:4px}.ss-field input{background:transparent;border:none;outline:none;padding:8px 4px;color:var(--ss-brand);font-size:.95rem;font-family:inherit;width:100%}.ss-field input::placeholder{color:#45a29e66}.ss-btn{width:100%;height:45px;background:var(--ss-brand);color:var(--ss-dark-text);border:none;border-radius:6px;font-size:1rem;font-family:inherit;font-weight:500;cursor:pointer;transition:opacity .15s;margin-top:8px}.ss-btn:hover{opacity:.85}.ss-btn:disabled{opacity:.5;cursor:default}.ss-btn-ghost{width:100%;height:45px;background:transparent;color:var(--ss-brand);border:2px solid var(--ss-brand);border-radius:6px;font-size:1rem;font-family:inherit;cursor:pointer;transition:background .2s,color .2s;margin-top:10px}.ss-btn-ghost:hover{background:var(--ss-brand);color:var(--ss-dark-text)}.ss-error{color:#e05555;font-size:.85rem;margin-top:10px;text-align:center}.ss-success{color:var(--ss-brand);font-size:.85rem;margin-top:10px;text-align:center}.ss-link-row{text-align:center;margin-top:20px;font-size:.9rem;color:var(--ss-brand)}.ss-link-row a{color:var(--ss-brand);text-decoration:none;font-weight:600}.ss-link-row a:hover{text-decoration:underline}.ss-album-detail{display:grid;grid-template-columns:280px 1fr;gap:40px;margin-top:24px}@media (max-width: 700px){.ss-album-detail{grid-template-columns:1fr}}.ss-album-detail>img{width:100%;border-radius:8px;border:1px solid var(--ss-border)}.ss-album-meta h2{margin:0 0 12px;font-size:1.8rem;color:var(--ss-brand)}.ss-album-meta p{color:var(--ss-muted);margin:6px 0;font-size:.9rem}.ss-songs-table{width:100%;border-collapse:collapse;margin-top:20px;font-size:.9rem;background:var(--ss-panel);border:1px solid var(--ss-border);border-radius:6px;overflow:hidden}.ss-songs-table th{text-align:left;color:var(--ss-brand);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--ss-border)}.ss-songs-table td{padding:8px 12px;border-bottom:1px solid rgba(69,162,158,.15);color:var(--ss-muted)}.ss-songs-table tr:last-child td{border-bottom:none}.ss-reviews{margin-top:48px}.ss-reviews h2{color:var(--ss-brand);margin-bottom:20px}.ss-review-card{background:var(--ss-panel);border:1px solid var(--ss-border);border-radius:8px;padding:16px;margin-bottom:12px}.ss-review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.ss-review-user{font-weight:600;font-size:.95rem;color:var(--ss-brand);text-decoration:underline}.ss-review-date{font-size:.75rem;color:gray}.ss-stars{color:var(--ss-brand);font-size:1.3rem;margin-bottom:6px}.ss-review-comment{font-size:.9rem;color:var(--ss-muted)}.ss-review-form{background:var(--ss-panel);border:1px solid var(--ss-border);border-radius:8px;padding:24px;margin-bottom:32px}.ss-review-form h3{margin:0 0 16px;color:var(--ss-brand)}.ss-star-row{display:flex;flex-direction:row-reverse;justify-content:flex-end;gap:4px;margin-bottom:16px;font-size:0}.ss-star-row button{background:none;border:none;font-size:2rem;cursor:pointer;color:#555;transition:color .1s;padding:0;line-height:1}.ss-star-row button.active,.ss-star-row button:hover,.ss-star-row button:hover~button{color:var(--ss-brand)}.ss-review-form textarea{width:100%;box-sizing:border-box;background:var(--ss-bg);border:1px solid var(--ss-border);border-radius:4px;padding:10px 12px;color:var(--ss-muted);font-size:.9rem;font-family:inherit;resize:vertical;margin-bottom:12px}.ss-review-form textarea:focus{outline:none;border-color:var(--ss-brand)}.ss-ranking-row{display:flex;align-items:center;gap:20px;background:var(--ss-panel);border:1px solid var(--ss-border);border-radius:8px;padding:16px;margin-bottom:12px;text-decoration:none;color:inherit;transition:box-shadow .2s}.ss-ranking-row:hover{box-shadow:0 0 10px #45a29e59}.ss-rank-number{font-size:1.4rem;font-weight:700;color:var(--ss-brand);min-width:36px}.ss-ranking-row img{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--ss-border);flex-shrink:0}.ss-ranking-info{flex:1}.ss-ranking-info h3{margin:0 0 4px;font-size:1rem;color:var(--ss-brand)}.ss-ranking-info p{margin:0;font-size:.85rem;color:var(--ss-muted)}.ss-ranking-rating{font-size:1rem;font-weight:600;color:var(--ss-brand)}.ss-profile-card{background:var(--ss-panel);border:1px solid var(--ss-border);border-radius:8px;padding:28px;max-width:520px}.ss-profile-card h2{margin:0 0 20px;color:var(--ss-brand)}.ss-profile-field{margin-bottom:20px}.ss-profile-field label{display:block;font-size:.85rem;color:var(--ss-brand);margin-bottom:6px}.ss-profile-field input,.ss-profile-field select{width:100%;box-sizing:border-box;background:var(--ss-bg);border:1px solid var(--ss-border);border-radius:4px;padding:10px 12px;color:var(--ss-muted);font-size:.9rem;font-family:inherit}.ss-profile-field input:focus,.ss-profile-field select:focus{outline:none;border-color:var(--ss-brand)}.ss-profile-field select option{background:var(--ss-panel);color:var(--ss-muted)}.ss-new-album-form{max-width:640px}.ss-new-album-form h1{margin:0 0 28px;color:var(--ss-brand)}.ss-new-album-form h3{color:var(--ss-brand)}.ss-new-album-form textarea{width:100%;box-sizing:border-box;background:var(--ss-bg);border:1px solid var(--ss-border);border-radius:4px;padding:10px 12px;color:var(--ss-muted);font-size:.9rem;font-family:inherit;resize:vertical}.ss-new-album-form textarea:focus{outline:none;border-color:var(--ss-brand)}.ss-songs-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.ss-song-row{display:grid;grid-template-columns:36px 1fr 120px auto;gap:8px;align-items:center}.ss-song-row input{background:var(--ss-bg);border:1px solid var(--ss-border);border-radius:4px;padding:8px 10px;color:var(--ss-muted);font-family:inherit;font-size:.9rem}.ss-song-row input:focus{outline:none;border-color:var(--ss-brand)}.ss-remove-song-btn{background:transparent;border:none;color:#e05555;cursor:pointer;font-size:1rem;padding:4px 8px}.ss-add-song-btn{background:transparent;border:1px solid var(--ss-border);border-radius:6px;color:var(--ss-brand);padding:7px 14px;font-family:inherit;font-size:.9rem;cursor:pointer;margin-bottom:24px;transition:background .2s,color .2s}.ss-add-song-btn:hover{background:var(--ss-brand);color:var(--ss-dark-text)}.ss-file-input{color:var(--ss-muted);font-family:inherit;font-size:.9rem}.ss-muted{color:var(--ss-muted);font-size:.9rem}.ss-loading{padding:60px;text-align:center;color:var(--ss-muted)}.ss-login-prompt{color:var(--ss-muted);margin-bottom:24px}.ss-login-prompt a{color:var(--ss-brand);text-decoration:none}.ss-login-prompt a:hover{text-decoration:underline}@media (max-width: 992px){.ss-nav-links{gap:20px}}@media (max-width: 768px){.ss-main{padding:24px 16px 100px}.ss-album-detail{grid-template-columns:1fr}.ss-song-row{grid-template-columns:36px 1fr 90px auto}}@media (max-width: 576px){.ss-nav-links{gap:14px;font-size:.85rem}.ss-form-wrap{padding:28px 20px;margin:40px auto 0}.ss-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}#root{max-width:none;margin:0;padding:0;text-align:initial}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}@media (max-width: 600px){.card{padding:1rem}}.read-the-docs{color:#888}.thumb{margin:0 0 14px;width:100%;aspect-ratio:16 / 9;border-radius:12px;overflow:hidden;background:#0d1325}.thumb img{width:100%;height:100%;object-fit:cover;display:block;transform:translateZ(0);transition:transform .25s ease,opacity .25s ease;animation:img-in .18s ease both}.card:hover .thumb img,.card:focus-within .thumb img{transform:scale(1.02)}@keyframes global-page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes global-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}main,.App,#root>*:first-child{animation:global-page-in .28s cubic-bezier(.2,.8,.2,1) both}.card{opacity:0;animation:global-card-in .38s ease forwards;padding:2em}.card:nth-of-type(1){animation-delay:30ms}.card:nth-of-type(2){animation-delay:60ms}.card:nth-of-type(3){animation-delay:90ms}.card:nth-of-type(4){animation-delay:.12s}.card:nth-of-type(5){animation-delay:.15s}.card:nth-of-type(6){animation-delay:.18s}.card:nth-of-type(7){animation-delay:.21s}.card:nth-of-type(8){animation-delay:.24s}.card:nth-of-type(9){animation-delay:.27s}.card:nth-of-type(10){animation-delay:.3s}@keyframes img-in{0%{opacity:0;transform:scale(.995)}to{opacity:1;transform:scale(1)}}@keyframes home-page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.home{animation:home-page-in .28s cubic-bezier(.2,.8,.2,1) both}@keyframes hero-in{0%{opacity:0;transform:translateY(8px);filter:blur(2px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.home .hero-text>*{opacity:0;animation:hero-in .42s ease forwards}.home .hero-text>*:nth-child(1){animation-delay:40ms}.home .hero-text>*:nth-child(2){animation-delay:90ms}.home .hero-text>*:nth-child(3){animation-delay:.14s}.home .hero-text>*:nth-child(4){animation-delay:.19s}@keyframes home-card-pop-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.home .hero-card{opacity:0;animation:home-card-pop-in .42s cubic-bezier(.2,.8,.2,1) forwards;animation-delay:.16s}@keyframes home-section-head-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.home .section-head{opacity:0;animation:home-section-head-in .34s ease forwards;animation-delay:.12s}@keyframes home-grid-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.home .grid.three .card{opacity:0;animation:home-grid-card-in .38s ease forwards}.home .grid.three .card:nth-of-type(1){animation-delay:60ms}.home .grid.three .card:nth-of-type(2){animation-delay:.12s}.home .grid.three .card:nth-of-type(3){animation-delay:.18s}.footer{margin-top:clamp(16px,4vw,40px)}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.page-offset{flex:1;display:flex;flex-direction:column}@media (prefers-reduced-motion: reduce){main,.App,#root>*:first-child,.card,.thumb img,.home,.home .hero-text>*,.home .hero-card,.home .section-head,.home .grid.three .card{animation:none!important;transition:none!important;opacity:1!important;transform:none!important;filter:none!important}}
