:root{--bg: #f5ece1;--bg-card: #fdf8f2;--bg-nav: #f5ece1eb;--border: #dfd3bf;--border-hover: #4e3827;--text: #4e3827;--text-muted: #7b644d;--text-dim: #7b6f53;--text-faint: #937055;--surface: #f0e5d6;--skill-hover: #4e382712;--shadow: #4e382714;--dot-color: #ddbea8;--stat-bg: #f5ece1e0;--accent-warm: #937055;--accent-cool: #5b7a8a;--accent-grad: linear-gradient(90deg, #937055, #ddbea8, #5b7a8a)}[data-theme=dark]{--bg: #141412;--bg-card: #1e1d1b;--bg-nav: #141412eb;--border: #2e2c28;--border-hover: #f0ede6;--text: #f0ede6;--text-muted: #a09d97;--text-dim: #706d66;--text-faint: #4a4844;--skill-hover: #f0ede60f;--shadow: #0000004d;--dot-color: #2e2c28;--stat-bg: #141412d9;--accent-warm: #c8a882;--accent-cool: #8ba5b8;--accent-grad: linear-gradient(90deg, #c8a882, #8ba5b8, #9baa8c);--surface: #242320}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:125%}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s cubic-bezier(.22,.68,0,1.2),transform .6s cubic-bezier(.22,.68,0,1.2)}.reveal.revealed{opacity:1;transform:translateY(0)}.d1{transition-delay:80ms}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.container{max-width:1440px;margin:0 auto;padding:0 24px}.section{padding:48px 24px}.section-two-col{display:grid;grid-template-columns:200px 1fr;align-items:start;gap:40px}.section-header{margin-bottom:28px}.section-title{color:var(--text);font-family:"DM Serif Display",serif;font-size:2rem;margin-top:6px}.overline{font-size:.68rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.navbar{position:fixed;top:0;left:0;right:0;z-index:50;background:var(--bg-nav);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);transition:background .3s,border-color .3s}.navbar-inner{display:flex;justify-content:space-between;align-items:center;height:52px}.logo{font-family:"DM Serif Display",serif;font-size:1.1rem;color:var(--text)}.logo-dot{color:var(--accent-warm)}.nav-links{display:flex;align-items:center;gap:24px}.nav-btn{font-family:DM Sans,sans-serif;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);background:transparent;border:none;cursor:pointer;padding:4px 0;position:relative;transition:color .2s}.nav-btn:hover,.nav-btn.active{color:var(--text)}.nav-btn.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--text)}.theme-toggle{width:32px;height:32px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-dim);cursor:pointer;flex-shrink:0;display:flex;justify-content:center;align-items:center;transition:all .2s}.theme-toggle:hover{border-color:var(--text);color:var(--text);background:var(--skill-hover)}.navbar-controls{display:none;align-items:center;gap:8px}.hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:32px;height:32px;background:transparent;border:1px solid var(--border);border-radius:3px;cursor:pointer;padding:0;transition:all .2s}.hamburger:hover{border-color:var(--text);background:var(--skill-hover)}.hamburger span{display:block;width:18px;height:1.5px;background:var(--text);transition:all .2s}.mobile-menu{display:none;position:fixed;top:52px;left:0;right:0;background:var(--bg-nav);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-direction:column;padding:8px 0;z-index:49}.mobile-menu.open{display:flex}.mobile-menu .nav-btn{padding:14px 24px;text-align:left;font-size:.75rem;border-radius:0}.mobile-menu .nav-btn.active:after{display:none}.hero-section{padding:80px 24px 60px}.hero-grid{display:grid;grid-template-columns:1fr auto;align-items:center;gap:48px}.hero-title{font-family:"DM Serif Display",serif;font-size:clamp(2.6rem,6vw,4.2rem);line-height:1.08;letter-spacing:-.01em;color:var(--text);margin:20px 0 24px}.hero-title-em{font-style:italic;color:var(--text-dim)}.hero-bio{font-size:.95rem;line-height:1.75;color:var(--text-muted);max-width:680px;margin-bottom:20px}.hero-bio strong{color:var(--text);font-weight:500}.hero-ctas{display:flex;flex-wrap:wrap;gap:12px}.btn-primary{display:inline-flex;align-items:center;padding:10px 22px;background:var(--text);color:var(--bg);font-family:DM Sans,sans-serif;font-size:.8rem;letter-spacing:.08em;border-radius:3px;transition:opacity .2s}.btn-primary:hover{opacity:.85}.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:.8rem;letter-spacing:.08em;border-radius:3px;transition:border-color .2s}.btn-outline:hover{border-color:var(--text)}.dot-pattern{background-image:radial-gradient(circle,var(--dot-color) 1px,transparent 1px);background-size:22px 22px}.stat-box{width:300px;height:150px;border-radius:4px;flex-shrink:0;display:flex;justify-content:center;align-items:center;margin-bottom:20px}.stat-inner{text-align:center;background:var(--stat-bg);border-radius:4px;padding:20px}.stat-num{font-family:"DM Serif Display",serif;font-size:2.8rem;line-height:1}.accent-warm{color:var(--accent-warm)}.accent-cool{color:var(--accent-cool)}.stat-divider-width{width:28px;height:1px;background:var(--border);margin:14px auto}.stat-divider-height{width:1px;height:28px;background:var(--border);margin:auto 14px}.hero-photo-wrap{position:relative;flex-shrink:0}.hero-photo-accent{position:absolute;width:220px;height:280px;top:0;left:0;border-radius:10px;background:var(--accent-grad);opacity:.2;transform:translate(12px,10px) rotate(3deg);z-index:0}.hero-photo-frame{position:relative;z-index:1;width:220px;height:280px;border-radius:9px;background:linear-gradient(135deg,#c8a882,#8ba5b8,#9baa8c);padding:2px;box-shadow:0 12px 48px #00000024}.hero-photo-frame-inner{width:100%;height:100%;border-radius:8px;overflow:hidden}.hero-photo-img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.hero-photo-badge{position:absolute;bottom:-14px;left:50%;transform:translate(-50%);z-index:2;display:flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;padding:5px 14px;font-size:.68rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;box-shadow:0 2px 16px var(--shadow)}.hero-photo-badge-dot{width:6px;height:6px;border-radius:50%;background:#9baa8c;flex-shrink:0;animation:badgepulse 2.4s ease-in-out infinite}@keyframes badgepulse{0%,to{opacity:1;box-shadow:0 0 #9baa8c80}50%{opacity:.4;box-shadow:0 0 0 4px #9baa8c00}}.skills-wrap,.skills-grid{display:flex;flex-wrap:wrap;gap:8px;padding-top:4px}.skill-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border:1px solid var(--border);border-radius:2px;font-size:.75rem;letter-spacing:.03em;color:var(--text-muted);background:transparent;transition:all .18s}.skill-pill:hover{border-color:var(--text);color:var(--text);background:var(--skill-hover)}.card{border:1px solid var(--border);background:var(--bg-card);border-radius:4px;transition:box-shadow .25s,transform .25s,background .3s,border-color .3s}.card:hover{box-shadow:0 6px 28px var(--shadow);transform:translateY(-2px)}.exp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:16px}.exp-card{padding:24px}.exp-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.exp-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px}.exp-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.exp-title{font-family:"DM Serif Display",serif;font-size:1.3rem;color:var(--text);margin-bottom:2px}.exp-subtitle{font-size:.82rem;color:var(--text-dim)}.exp-tag{display:inline-flex;align-items:center;gap:5px;font-size:.68rem;letter-spacing:.06em;border:1px solid var(--border);color:var(--text-dim);border-radius:2px;padding:3px 8px;white-space:nowrap;flex-shrink:0;margin-left:12px}.exp-points{display:flex;flex-direction:column;gap:8px;list-style:none}.exp-point{display:flex;gap:10px;font-size:.82rem;line-height:1.6;color:var(--text-muted)}.exp-point-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:7px}.proj-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.proj-card{padding:24px;position:relative;overflow:hidden}.proj-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent-grad);transform:scaleX(0);transform-origin:left;transition:transform .35s}.proj-card:hover:after{transform:scaleX(1)}.proj-screenshot{margin:-24px -24px 20px;height:160px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden;border-radius:4px 4px 0 0}.proj-screenshot-img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.proj-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.proj-num{font-family:"DM Serif Display",serif;font-size:1.8rem;line-height:1;color:var(--border)}.proj-title{font-family:"DM Serif Display",serif;font-size:1.2rem;color:var(--text);margin-bottom:8px}.proj-stack{font-size:.72rem;font-weight:500;letter-spacing:.04em;color:var(--accent-cool);margin-bottom:12px}.proj-desc{font-size:.82rem;line-height:1.65;color:var(--text-muted)}.proj-link-hint{display:flex;align-items:center;gap:6px;margin-top:16px;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim)}.contact-blurb{font-size:.82rem;line-height:1.7;color:var(--text-dim)}.contact-list{display:flex;flex-direction:column;gap:10px}.contact-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border:1px solid var(--border);background:var(--bg-card);border-radius:4px;transition:all .2s}.contact-row:hover{border-color:var(--border-hover);transform:translate(4px)}.contact-icon-box{width:34px;height:34px;border:1px solid var(--border);border-radius:3px;flex-shrink:0;display:flex;justify-content:center;align-items:center;color:var(--text-muted)}.contact-value{font-size:.88rem;font-weight:500;color:var(--text)}.contact-arrow{margin-left:auto;font-size:.9rem;color:var(--text-faint)}.footer{padding:32px 24px 24px;border-top:1px solid var(--border);transition:border-color .3s}.footer-inner{display:flex;flex-direction:column;gap:16px}.footer-top{display:flex;justify-content:space-between;align-items:center}.footer-brand{display:flex;flex-direction:column;gap:2px}.footer-name{font-family:"DM Serif Display",serif;font-size:.9rem;color:var(--text-dim)}.footer-role{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint)}.footer-socials{display:flex;align-items:center;gap:6px}.footer-social-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);transition:all .2s}.footer-social-link:hover{border-color:var(--text);color:var(--text);background:var(--skill-hover)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border)}.footer-built{font-size:.65rem;letter-spacing:.08em;color:var(--text-faint)}.footer-copy{font-size:.65rem;color:var(--text-faint)}.nav-socials{display:flex;align-items:center;gap:4px;margin-left:8px;padding-left:16px;border-left:1px solid var(--border)}.nav-social-link{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:3px;color:var(--text-dim);transition:color .2s}.nav-social-link:hover{color:var(--text)}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border)}.card-clickable{display:block;text-decoration:none;color:inherit;cursor:pointer}.card-arrow{display:inline-flex;align-items:center;gap:4px;margin-top:16px;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);transition:color .2s,gap .2s}.card-clickable:hover .card-arrow{color:var(--text);gap:8px}.detail-main{padding-top:52px;min-height:100vh}.page-enter{animation:page-enter-fade .42s cubic-bezier(.22,.68,0,1) both}.page-enter .container>.detail-hero{animation:page-enter-rise .52s cubic-bezier(.22,.68,0,1) both;animation-delay:40ms}.page-enter .container>.detail-section:nth-of-type(2){animation:page-enter-rise .56s cubic-bezier(.22,.68,0,1) both;animation-delay:.1s}.page-enter .container>.detail-section:nth-of-type(3){animation:page-enter-rise .6s cubic-bezier(.22,.68,0,1) both;animation-delay:.14s}@keyframes page-enter-fade{0%{opacity:0}to{opacity:1}}@keyframes page-enter-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.about-intro{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:start}.about-profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:8px;box-shadow:0 6px 24px var(--shadow)}.about-profile-img{width:100%;height:280px;object-fit:cover;border-radius:8px;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.detail-hero{padding:56px 0 40px;border-bottom:1px solid var(--border);margin-bottom:48px}.detail-hero-inner{margin-bottom:28px}.detail-hero-name{font-family:"DM Serif Display",serif;font-size:clamp(2rem,5vw,3rem);line-height:1.1;color:var(--text);margin:10px 0 6px}.detail-hero-subtitle{font-size:.9rem;color:var(--text-muted);margin-bottom:2px}.detail-hero-role{font-size:.75rem;letter-spacing:.08em;color:var(--text-dim);text-transform:uppercase;margin-bottom:2px}.detail-hero-client{font-size:.8rem;color:var(--text-dim);margin-bottom:0}.detail-hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}.detail-hero-meta{display:flex;align-items:center;gap:12px;margin:8px 0 0}.detail-proj-num{display:block;font-family:"DM Serif Display",serif;font-size:3.5rem;color:var(--text-faint);line-height:1;margin-bottom:4px}.detail-status-badge{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:2px 8px;border-radius:2px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted)}.detail-hero-accent-bar{height:2px;border-radius:1px;margin-top:32px}.detail-hero-accent-bar--grad{background:var(--accent-grad)}.detail-section{margin-bottom:52px}.detail-screenshots{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.detail-screenshot-img{width:100%;height:200px;object-fit:cover;border-radius:6px;border:1px solid var(--border);display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s,border-color .2s}.detail-screenshot-img:hover{opacity:.95;transform:scale(1.02);box-shadow:0 12px 32px var(--shadow);border-color:var(--text-dim)}.detail-section-label{display:block;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.detail-body{font-size:.9rem;line-height:1.8;color:var(--text-muted);max-width:960px}.detail-highlights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.detail-highlight-card{border:1px solid var(--border);background:var(--bg-card);border-radius:4px;padding:20px;border-left-width:3px;border-left-style:solid}.detail-highlight-value{font-family:"DM Serif Display",serif;font-size:1.8rem;line-height:1;color:var(--text);margin-bottom:8px}.detail-highlight-label{color:var(--text-dim)}.detail-points .exp-point{font-size:.875rem;line-height:1.75;color:var(--text-muted)}.detail-point-dot--cool{width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:7px;background:var(--accent-cool)}.detail-outcome{border-left:3px solid var(--accent-warm);border-left-style:solid;padding:20px 24px;background:var(--bg-card);border-radius:0 4px 4px 0;font-size:.9rem;line-height:1.8;color:var(--text-muted);font-style:italic;max-width:960px}.detail-back-link{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);text-decoration:none;transition:color .2s}.detail-back-link:hover{color:var(--text)}.detail-github-link{margin-top:8px}.detail-github-btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none}@media(max-width:700px){html{font-size:118.75%}.about-intro{grid-template-columns:1fr;gap:14px}.about-profile-card{max-width:280px}.hero-grid{grid-template-columns:1fr}.stat-box{display:none}.section-two-col{grid-template-columns:1fr;gap:24px}.exp-grid{grid-template-columns:1fr}.nav-links{display:none}.navbar-controls{display:flex}.detail-highlights-grid{grid-template-columns:repeat(2,1fr)}.detail-hero-name{font-size:2rem}}@media(prefers-reduced-motion:reduce){.page-enter,.page-enter .container>.detail-hero,.page-enter .container>.detail-section:nth-of-type(2),.page-enter .container>.detail-section:nth-of-type(3){animation:none}}.exp-employer-context{display:flex;align-items:center;gap:10px;margin-bottom:32px;padding:12px 16px;background:var(--surface);border-radius:8px;border:1px solid var(--border)}.exp-employer-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.exp-employer-label{font-size:.85rem;color:var(--text-muted)}.exp-employer-label strong{color:var(--text)}.exp-other{margin-top:56px}.emp-timeline{margin-top:20px;display:flex;flex-direction:column}.emp-item{display:flex;gap:16px}.emp-item-left{display:flex;flex-direction:column;align-items:center;padding-top:4px}.emp-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.emp-item-line{width:1px;flex:1;background:var(--border);margin-top:6px}.emp-item:last-child .emp-item-line{display:none}.emp-item-right{padding-bottom:28px}.emp-item-meta{display:flex;align-items:center;gap:10px;margin-bottom:2px}.emp-company{font-size:.95rem;font-weight:600;color:var(--text)}.emp-type-badge{font-size:.6rem;padding:2px 7px;border-radius:999px;border:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.emp-role{font-size:.85rem;color:var(--text-muted);margin-bottom:2px}.emp-period{font-size:.65rem}.emp-points{list-style:none;padding:0;margin-top:10px;display:flex;flex-direction:column;gap:8px}.emp-points li{font-size:.8rem;color:var(--text-muted);line-height:1.55;padding-left:16px;position:relative}.emp-points li:before{content:"";position:absolute;left:0;top:.58em;width:6px;height:6px;border-radius:50%;background:var(--accent-cool);color:var(--text-dim)}.emp-points li.emp-point-sub{margin-left:14px;padding-left:14px;font-size:.74rem;color:var(--text-dim)}.emp-points li.emp-point-sub:before{width:5px;height:5px;top:.6em;background:var(--text-faint)}.cert-list{display:flex;flex-direction:column;gap:12px}.cert-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border-radius:8px;border:1px solid var(--border)}.cert-accent{width:3px;height:36px;border-radius:2px;flex-shrink:0}.cert-info{flex:1}.cert-title{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:2px}.cert-issuer{font-size:.78rem;color:var(--text-muted)}.cert-year{font-size:.65rem;flex-shrink:0}.cert-item-btn{width:100%;text-align:left;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:border-color .15s,box-shadow .15s}.cert-item-btn:hover{border-color:var(--text-muted);box-shadow:0 2px 8px #0000000f}.cert-chevron{flex-shrink:0;color:var(--text-dim);margin-left:4px}.cert-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.cert-modal{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.cert-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.cert-modal-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:2px}.cert-modal-issuer{font-size:.78rem;color:var(--text-muted)}.cert-modal-close{flex-shrink:0;background:none;border:1px solid var(--border);border-radius:6px;padding:6px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s}.cert-modal-close:hover{border-color:var(--text-muted);color:var(--text)}.cert-modal-body{flex:1;overflow-y:auto;min-height:0}.cert-modal-img{width:100%;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}@media(max-width:700px){.cert-modal-backdrop{padding:12px}.cert-modal-embed{min-height:360px}}@keyframes sv-enter{0%{opacity:0;transform:scale(.98) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.sv-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px 64px}.sv-modal{display:flex;flex-direction:column;width:100%;max-width:1440px;gap:12px;animation:sv-enter .4s cubic-bezier(.22,1,.36,1) forwards}.sv-header{display:flex;align-items:center;justify-content:space-between}.sv-title{font-size:.9rem;color:#dcd9d2;font-weight:500;letter-spacing:.02em}.sv-header-right{display:flex;align-items:center;gap:16px}.sv-counter{font-size:.62rem;color:#6a6762}.sv-close{background:none;border:1px solid #2e2c28;border-radius:6px;padding:5px;cursor:pointer;color:#706d66;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s}.sv-close:hover{border-color:#706d66;color:#c8c5bf}.sv-body{position:relative;display:flex;align-items:center;justify-content:center}.sv-img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:8px;border:1px solid rgba(255,255,255,.08);display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none;box-shadow:0 24px 80px #0009}.sv-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff0a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.12);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#c8c5bf;transition:background .2s,border-color .2s,transform .2s;z-index:1;flex-shrink:0}.sv-arrow:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-50%) scale(1.05)}.sv-arrow-prev{left:-54px}.sv-arrow-next{right:-54px}.sv-dots{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}.sv-dot{width:6px;height:6px;border-radius:50%;background:#fff3;border:none;cursor:pointer;padding:0;transition:background .15s,transform .15s}.sv-dot:hover{background:#fff6}.sv-dot-active{background:#c8a882;transform:scale(1.4)}@media(max-width:700px){.sv-backdrop{padding:16px}.sv-arrow-prev{left:4px}.sv-arrow-next{right:4px}.sv-arrow{width:36px;height:36px;background:#00000080;border-color:#ffffff1a}}
