:root{color-scheme:light;--bg: #f5f4f1;--bg-soft: #fbfaf8;--panel: rgba(255, 255, 255, .92);--line: rgba(20, 20, 20, .08);--line-strong: rgba(20, 20, 20, .16);--text: #111111;--muted: rgba(17, 17, 17, .5);--muted-strong: rgba(17, 17, 17, .72);--shadow: 0 22px 54px rgba(17, 17, 17, .08);--admin-shadow: 0 1px 2px rgba(17, 17, 17, .04), 0 18px 48px rgba(17, 17, 17, .06);--ring: 0 0 0 4px rgba(17, 17, 17, .08);--danger: #b42318;--danger-soft: rgba(180, 35, 24, .08);--radius: 30px;font-family:Helvetica Neue,PingFang SC,Noto Sans SC,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:var(--text);background:radial-gradient(circle at top,rgba(255,255,255,.8),transparent 20%),linear-gradient(180deg,#faf9f7,#f4f2ee)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background-image:radial-gradient(rgba(0,0,0,.1) .7px,transparent .7px);background-size:32px 32px;opacity:.2}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:linear-gradient(135deg,#ffffffb8,#f4f2ee5c)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{-webkit-tap-highlight-color:transparent}.site-header{position:fixed;inset:0 0 auto 0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 2.2rem;border-bottom:1px solid rgba(17,17,17,.04);background:#fffc;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand-mark{font-size:1.35rem;font-weight:800;letter-spacing:.18rem}.site-nav,.site-header-right,.admin-actions{display:flex;align-items:center;gap:.8rem}.site-nav a,.ghost-button,.nav-pill,.row-actions button,.admin-entry{display:inline-flex;align-items:center;justify-content:center;min-height:2.6rem;padding:.55rem 1rem;border:1px solid transparent;border-radius:999px;color:var(--muted-strong);background:transparent;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .2s ease}.site-nav a:hover,.ghost-button:hover,.nav-pill:hover,.row-actions button:hover,.admin-entry:hover{border-color:var(--line);background:#1111110a}.site-location{color:var(--muted);font-size:.92rem}.ghost-button{min-width:3.7rem;border-color:var(--line);background:#ffffffe6}.nav-pill.active,.primary-button{border-color:#111;color:#fff;background:#111}.primary-button,.ghost-button,.row-actions button,.nav-pill{box-shadow:0 1px 1px #1111110a}.primary-button:hover,.ghost-button:hover,.row-actions button:hover,.nav-pill:hover{transform:translateY(-1px)}.primary-button:active,.ghost-button:active,.row-actions button:active,.nav-pill:active{transform:translateY(0)}.hero{position:relative;min-height:100svh;padding:7.5rem 2rem 2rem;overflow:hidden}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(17,17,17,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(17,17,17,.04) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:radial-gradient(circle at center,rgba(0,0,0,.95),transparent 85%);mask-image:radial-gradient(circle at center,rgba(0,0,0,.95),transparent 85%)}.hero-disk{position:absolute;top:0;left:0;width:15rem;height:15rem;border-radius:50%;background:#111;opacity:.9;filter:blur(.2px);pointer-events:none;z-index:0}.hero-disk-disabled{display:none}.hero-content{position:relative;z-index:1;width:min(1180px,calc(100% - 1rem));margin:0 auto;display:flex;min-height:calc(100svh - 10rem);flex-direction:column;justify-content:center;align-items:center;text-align:center}.hero-content-base,.hero-content-reveal{display:flex;flex-direction:column;align-items:center;justify-content:center}.hero-content-base{position:relative;z-index:1}.hero-content-reveal{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;color:#fff;pointer-events:none}.hero-content-tilt{position:relative;z-index:1;min-height:calc(100svh - 10rem);display:flex;align-items:center;justify-content:center;transform-style:preserve-3d;transition:transform .08s linear;will-change:transform}.hero-content p,.section-header p,.contact-strip p,.admin-login p,.admin-header p{margin:0 0 1rem;font-size:.8rem;letter-spacing:.22rem;color:var(--muted)}.hero-content h1{margin:0;max-width:12ch;font-size:clamp(4rem,10vw,7rem);line-height:.96;letter-spacing:-.06em}.hero-content p,.hero-content h1,.hero-content span,.hero-content strong,.hero-content a{transition:color .18s ease}.hero-headline-stage{position:relative;margin:.2rem 0 .5rem;pointer-events:none;transform-style:preserve-3d;transition:transform .08s linear}.hero-headline-motion{position:relative}.hero-headline-base,.hero-headline-reveal{display:flex;align-items:baseline;justify-content:center;flex-wrap:wrap;gap:.8rem}.hero-headline-reveal{position:absolute;top:0;right:0;bottom:0;left:0;color:#fff;pointer-events:none}.hero-headline-stage em{font-size:clamp(2.8rem,8vw,5rem);font-style:italic;font-weight:300;letter-spacing:-.05em}.hero-content span,.section-header span,.lead-copy,.content-card span,.detail-header span,.skill-panel p{color:var(--muted);line-height:1.7}.hero-meta{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:1rem 2rem;align-items:center;justify-content:center}.hero-meta strong{max-width:48rem;font-weight:500;color:var(--muted-strong)}.hero-meta a,.text-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:600}.hero-content-reveal p,.hero-content-reveal h1,.hero-content-reveal span,.hero-content-reveal strong,.hero-content-reveal a{color:#fff}.page-shell{width:min(1180px,calc(100% - 3rem));margin:0 auto}.page-top-space{padding-top:8rem}.intro-grid,.contact-strip,.admin-grid,.media-grid,.visit-panels,.stats-row{display:grid;gap:1.5rem}.intro-grid{grid-template-columns:1.2fr .8fr;padding:4rem 0 2rem;align-items:start}.intro-copy{padding-right:2rem}.section-header{max-width:740px}.section-header h2,.detail-header h1,.contact-strip h2,.admin-header h1,.admin-login h1{margin:0;font-size:clamp(2.4rem,5vw,4.1rem);line-height:1.02;letter-spacing:-.05em}.section-header i{display:block;width:3.3rem;height:.2rem;margin:1.15rem 0 1.25rem;border-radius:999px;background:#11111161}.info-panel,.content-card,.editor-panel,.list-panel,.media-panel,.stat-card,.visit-filter-panel,.admin-login,.skill-panel{background:var(--panel);border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.info-panel{padding:1.75rem;border-radius:var(--radius)}.info-panel div+div{margin-top:1rem}.info-action{width:fit-content;margin-top:.9rem}.info-panel small,.meta-grid small,.tag-list small,.content-card-footer small{color:var(--muted)}.info-panel p,.meta-grid strong,.contact-mini{display:flex;align-items:center;gap:.5rem}.skills-section,.preview-section,.detail-page,.contact-strip,.admin-shell{padding:2.4rem 0 4.3rem}.detail-page.page-top-space{padding-top:8rem}.skill-stack{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem;margin-top:2rem;perspective:1600px}.skill-panel{position:relative;padding:0;border-radius:2rem;overflow:hidden;transform-style:preserve-3d;transition:border-color .25s ease,box-shadow .25s ease;cursor:pointer;outline:none}.skill-panel:before{content:"";position:absolute;inset:-45% auto auto -15%;width:18rem;height:18rem;border-radius:999px;background:radial-gradient(circle,rgba(17,17,17,.08),transparent 65%);opacity:0;transform:scale(.72);transition:opacity .35s ease,transform .35s ease;pointer-events:none}.skill-panel:hover{border-color:#11111124;box-shadow:0 24px 70px #1111111f}.skill-panel:focus-visible{box-shadow:0 0 0 4px #1111111f,var(--shadow)}.skill-panel:hover:before{opacity:1;transform:scale(1)}.skill-card-inner{position:relative;display:grid;width:100%;transform-style:preserve-3d;transition:transform .72s cubic-bezier(.16,1,.3,1)}.skill-panel-flipped .skill-card-inner{transform:rotateY(180deg)}.skill-card-face{position:relative;grid-area:1 / 1;display:flex;flex-direction:column;padding:1.8rem 2rem 1.6rem;backface-visibility:hidden}.skill-card-front{transform:rotateY(0)}.skill-card-back{color:#fff;background:#111;transform:rotateY(180deg)}.skill-card-back .skill-panel-head{border-bottom-color:#ffffff29}.skill-card-back .skill-badge{color:#111;background:#fff}.skill-card-back h3,.skill-card-back p,.skill-card-back .skill-flip-hint{color:#fff}.skill-card-back ul{display:grid;gap:1rem;margin:1.5rem 0 0;padding:0;list-style:none}.skill-card-back li{position:relative;padding-left:1.1rem;color:#ffffffc7;line-height:1.75}.skill-card-back li:before{content:"";position:absolute;left:0;top:.78rem;width:.38rem;height:.38rem;border-radius:999px;background:#fff}.skill-panel-head{position:relative;display:flex;align-items:center;gap:1.1rem;padding-bottom:1.4rem;border-bottom:1px solid rgba(17,17,17,.06)}.skill-panel-head h3{margin:0 0 .2rem;font-size:2rem;letter-spacing:-.04em}.skill-badge{flex:0 0 auto;display:grid;place-items:center;width:3.2rem;height:3.2rem;border-radius:1rem;background:#1c1c1c;color:#fff;font-weight:700}.skill-level{position:relative;display:flex;align-items:center;gap:1rem;padding-top:1.25rem}.skill-level:before{content:"";position:absolute;left:0;right:4.2rem;height:.48rem;border-radius:999px;background:#1111110f}.skill-level i{position:relative;width:calc(100% - 4.2rem);height:.48rem;border-radius:999px;background:linear-gradient(90deg,#111,#11111185);transform-origin:left center}.skill-level span{margin-left:auto;font-size:.78rem;font-weight:800;letter-spacing:.12em;color:#11111194}.skill-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;padding-top:1.6rem}.skill-metrics strong{display:block;margin-bottom:.45rem;font-size:clamp(2rem,4vw,3.4rem);letter-spacing:-.05em}.skill-metrics span{color:var(--muted)}.skill-keywords{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.25rem;padding-top:0}.skill-keywords span{padding:.46rem .68rem;border-radius:999px;border:1px solid rgba(17,17,17,.08);background:#11111109;color:var(--muted-strong);font-size:.78rem;font-weight:700}.skill-flip-hint{margin-top:.85rem;color:#1111116b;font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.skill-cloud,.tag-list,.preview-header-row,.meta-grid,.contact-actions{display:flex;flex-wrap:wrap;gap:.9rem}.skill-cloud{margin-top:1.2rem}.skill-cloud span,.tag-list small{padding:.58rem .9rem;border-radius:999px;border:1px solid rgba(17,17,17,.08);background:#ffffffa6;color:var(--muted-strong)}.preview-header-row{align-items:end;justify-content:space-between}.card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.7rem;margin-top:2rem}.project-grid .content-card:nth-child(2n){transform:translateY(2.3rem)}.project-experience-list{display:grid;gap:1.25rem;margin-top:2rem;perspective:1600px}.project-experience-card{position:relative;overflow:hidden;border-radius:2.1rem;border:1px solid rgba(255,255,255,.82);background:#ffffffd1;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.project-experience-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent,rgba(17,17,17,.04),transparent),radial-gradient(circle at 85% 20%,rgba(17,17,17,.07),transparent 34%);opacity:0;transform:translate(-20%);transition:opacity .35s ease,transform .45s ease}.project-experience-card:hover:before{opacity:1;transform:translate(0)}.project-experience-link{position:relative;display:grid;grid-template-columns:7rem minmax(0,1fr) auto;gap:1.4rem;align-items:stretch;padding:1.6rem}.project-experience-index{display:grid;place-items:center;min-height:11rem;border-radius:1.5rem;background:#111;color:#fff;font-size:clamp(2.8rem,6vw,4.5rem);font-weight:900;letter-spacing:-.08em}.project-experience-main{min-width:0}.project-experience-topline{display:flex;flex-wrap:wrap;gap:.75rem 1rem;align-items:center;color:var(--muted);font-size:.86rem}.project-experience-topline strong{color:#111}.project-experience-main h3{margin:.65rem 0;font-size:clamp(2rem,3.2vw,3.3rem);line-height:1.02;letter-spacing:-.055em}.project-experience-main p{max-width:760px;margin:0;color:var(--muted-strong);line-height:1.75}.project-experience-tech,.project-experience-highlights{display:flex;flex-wrap:wrap;gap:.65rem}.project-experience-tech{margin-top:1.1rem}.project-experience-tech small{padding:.45rem .68rem;border-radius:999px;background:#1111110f;color:#111111b8;font-weight:700}.project-experience-highlights{margin-top:1rem}.project-experience-highlights span{padding:.55rem .75rem;border-radius:.9rem;border:1px solid rgba(17,17,17,.08);background:#ffffffb3;color:var(--muted-strong);font-size:.86rem;font-weight:700}.project-experience-action{display:flex;flex-direction:column;align-items:center;justify-content:space-between;min-width:3.2rem;color:#111}.project-experience-action svg{padding:.55rem;width:2.7rem;height:2.7rem;border-radius:999px;background:#1111110f}.project-experience-action span{writing-mode:vertical-rl;color:var(--muted);font-size:.78rem;font-weight:800;letter-spacing:.12em}.content-card{border-radius:2.1rem}.content-card-link,.editor-panel,.list-panel{display:block;padding:1.7rem}.content-card-cover{width:100%;height:13rem;object-fit:cover;margin-bottom:1rem;border-radius:1.4rem;background:#1111110d}.content-card-top,.admin-header,.admin-list-item,.checkbox-row,.content-card-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.content-card-top strong{font-size:clamp(2.4rem,5vw,4rem);line-height:1;color:#11111114}.content-card h3{margin:.95rem 0 .8rem;font-size:clamp(1.8rem,2vw,2.35rem);letter-spacing:-.04em}.content-card .tag-list{margin-bottom:1rem}.content-card-footer{margin-top:2rem}.contact-strip{grid-template-columns:1.25fr auto;align-items:center;padding-top:3rem;border-top:1px solid rgba(17,17,17,.08)}.contact-mini{padding:.8rem 1rem;border:1px solid rgba(17,17,17,.08);border-radius:999px;background:#ffffffb3}.detail-header{max-width:840px;padding-bottom:2rem}.detail-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.detail-actions a{display:inline-flex;align-items:center;min-height:2.8rem;padding:0 1rem;border:1px solid rgba(17,17,17,.1);border-radius:999px;background:#ffffffbf;color:var(--text);font-weight:800;text-decoration:none;box-shadow:0 14px 34px #1111110f;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.detail-actions a:hover{background:#111;color:#fff;transform:translateY(-2px);box-shadow:0 18px 44px #1111111f}.detail-cover{width:min(100%,860px);max-height:440px;object-fit:cover;margin-bottom:2rem;border-radius:2rem;box-shadow:var(--shadow)}.detail-content-grid{display:grid;grid-template-columns:minmax(0,1fr) 220px;align-items:start;gap:clamp(1rem,2vw,1.8rem)}.detail-toc{position:sticky;top:8.5rem;max-height:calc(100svh - 10rem);padding:1.15rem;overflow:hidden;border:1px solid rgba(17,17,17,.08);border-radius:24px;background:#ffffffb8;box-shadow:0 22px 50px #1111110f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.detail-toc-head{display:grid;gap:.8rem;margin-bottom:.85rem}.detail-toc-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.mobile-toc-trigger,.mobile-toc-backdrop,.toc-close-button{display:none}.detail-toc small{display:block;color:var(--muted);font-size:.75rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.toc-level-switch{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;padding:.25rem;border-radius:999px;background:#1111110b}.toc-level-switch button{min-height:1.9rem;border:0;border-radius:999px;background:transparent;color:var(--muted-strong);font-size:.78rem;font-weight:800;cursor:pointer;transition:background-color .16s ease,color .16s ease,box-shadow .16s ease}.toc-level-switch button:hover,.toc-level-switch button.active{background:#111;color:#fff;box-shadow:0 8px 18px #1111111f}.detail-toc nav{display:grid;gap:.35rem;max-height:calc(100svh - 17rem);overflow-y:auto;overscroll-behavior:contain;padding-right:.25rem;scrollbar-width:thin}.detail-toc nav::-webkit-scrollbar{width:6px}.detail-toc nav::-webkit-scrollbar-track{background:transparent}.detail-toc nav::-webkit-scrollbar-thumb{border-radius:999px;background:#1111112e}.toc-link{display:block;padding:.45rem .65rem;border-radius:999px;color:var(--muted-strong);font-size:.92rem;line-height:1.35;text-decoration:none;transition:color .16s ease,background .16s ease,transform .16s ease}.toc-link:hover{color:var(--text);background:#1111110f;transform:translate(4px)}.toc-level-2{margin-left:.7rem}.toc-level-3{margin-left:1.4rem;font-size:.84rem}.meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));margin:1.5rem 0}.markdown-body{color:var(--muted-strong);line-height:1.9}.markdown-body h1,.markdown-body h2,.markdown-body h3{scroll-margin-top:8rem}.markdown-body h1,.markdown-body h2,.markdown-body h3{color:var(--text);margin-top:2.1rem}.markdown-body pre{overflow-x:auto;padding:1rem;border-radius:18px;background:#1111110d}.related-content{display:grid;gap:1.3rem;margin-top:clamp(3rem,6vw,5.5rem);padding-top:2rem;border-top:1px solid rgba(17,17,17,.08)}.related-content>div:first-child{display:grid;gap:.35rem}.related-content small{color:var(--muted);font-weight:800;letter-spacing:.16em;text-transform:uppercase}.related-content h2{margin:0;font-size:clamp(2.1rem,4vw,4rem);letter-spacing:-.06em}.related-content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.related-content-card{display:grid;gap:.9rem;min-height:17rem;padding:1.3rem;border:1px solid rgba(17,17,17,.08);border-radius:28px;background:radial-gradient(circle at 85% 18%,rgba(17,17,17,.09),transparent 30%),#ffffffc7;color:var(--text);text-decoration:none;box-shadow:0 20px 48px #11111112;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.related-content-card:hover{transform:translateY(-6px);border-color:#1111112e;box-shadow:0 28px 70px #1111111c}.related-content-card h3{margin:0;font-size:clamp(1.6rem,2.6vw,2.5rem);line-height:1.05;letter-spacing:-.055em}.related-content-card p{margin:0;color:var(--muted-strong);line-height:1.75}.related-content-card div{display:flex;flex-wrap:wrap;gap:.5rem;align-self:end}.related-content-card div small{padding:.45rem .65rem;border-radius:999px;background:#1111110f;color:#111111b8;font-size:.78rem;letter-spacing:0;text-transform:none}.admin-auth-shell,.admin-shell{min-height:100svh;padding:2rem clamp(1rem,3vw,3rem)}.admin-auth-shell{display:grid;place-items:center}.admin-login,.editor-panel,.list-panel,.media-panel,.visit-filter-panel,.stat-card{border-radius:22px}.admin-login{width:min(460px,100%);padding:2rem}.admin-login,.editor-panel{display:grid;gap:.9rem}.admin-shell{width:min(1360px,100%);margin:0 auto;display:grid;grid-template-columns:minmax(10.5rem,12.5rem) minmax(0,1fr);gap:1.1rem;align-items:start}.admin-header{position:sticky;top:1rem;z-index:10;padding:.8rem;border:1px solid rgba(17,17,17,.08);border-radius:22px;background:#ffffffd1;box-shadow:var(--admin-shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:grid;align-content:start;gap:.8rem}.admin-header p{font-size:.68rem;letter-spacing:.24em}.admin-header h1{font-size:clamp(1.55rem,2.2vw,2.15rem);letter-spacing:-.055em;word-break:break-word}.admin-actions{display:grid;gap:.18rem;margin-top:.4rem;padding:.25rem;border:1px solid rgba(17,17,17,.06);border-radius:18px;background:#11111109}.admin-login input,.editor-panel input,.editor-panel textarea,.editor-panel select,.visit-filter-panel input{width:100%;min-height:2.85rem;padding:.78rem .95rem;border-radius:12px;border:1px solid var(--line);background:#ffffffe6;color:var(--text);outline:none;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.admin-login input:hover,.editor-panel input:hover,.editor-panel textarea:hover,.editor-panel select:hover,.visit-filter-panel input:hover{border-color:#1111112e;background:#fffffff5}.admin-login input:focus,.editor-panel input:focus,.editor-panel textarea:focus,.editor-panel select:focus,.visit-filter-panel input:focus{border-color:#11111157;box-shadow:var(--ring)}.admin-grid,.media-grid{grid-template-columns:1fr;align-items:start;min-width:0}.editor-panel{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;padding:1.35rem;box-shadow:var(--admin-shadow)}.editor-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;overflow:auto;padding:clamp(1rem,3vw,2.2rem);background:#11111157;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.editor-modal{width:min(1180px,100%);margin:0 auto;background:#fffffff5}.editor-panel h2,.editor-panel textarea,.editor-panel .checkbox-row,.editor-panel .feature-toggle,.editor-panel .upload-dropzone,.editor-panel .markdown-editor-grid,.editor-actions,.muted-copy{grid-column:1 / -1}.editor-panel textarea{min-height:18rem;resize:vertical}.admin-toast{position:fixed;top:1.2rem;right:1.2rem;z-index:80;max-width:min(24rem,calc(100vw - 2rem));padding:.9rem 1.05rem;border-radius:16px;border:1px solid rgba(17,17,17,.08);background:#ffffffe6;color:var(--text);box-shadow:0 18px 50px #1111111f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);font-weight:800}.admin-toast-success{border-color:#1287502e;background:#eafaf1f0;color:#0f6b42}.admin-toast-error{border-color:#b423182e;background:#fff1f0f0;color:var(--danger)}.admin-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:grid;place-items:center;padding:1rem;background:#11111157;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-dialog{display:grid;gap:.75rem;width:min(28rem,100%);padding:1.4rem;border:1px solid rgba(255,255,255,.8);border-radius:24px;background:#fffffff0;box-shadow:0 28px 80px #11111138}.admin-dialog small{color:var(--muted);font-weight:900;letter-spacing:.16em}.admin-dialog h2,.admin-dialog p{margin:0}.admin-dialog p{color:var(--muted-strong);line-height:1.7}.admin-dialog-danger{border-color:#b4231829}.dialog-actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:flex-end;margin-top:.35rem}.editor-panel input:required,.editor-panel textarea:required{border-color:#11111124;background:linear-gradient(90deg,rgba(180,35,24,.08),transparent .42rem),#ffffffe6}.feature-toggle{display:grid;grid-template-columns:auto 1fr;gap:.15rem .9rem;align-items:center;padding:.95rem 1rem;border:1px solid rgba(17,17,17,.08);border-radius:18px;background:#ffffffb8;cursor:pointer;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.feature-toggle input{position:absolute;opacity:0;pointer-events:none}.feature-toggle>span{position:relative;grid-row:span 2;width:3.2rem;height:1.8rem;border-radius:999px;background:#1111111f;transition:background .18s ease}.feature-toggle>span:after{content:"";position:absolute;top:.22rem;left:.24rem;width:1.36rem;height:1.36rem;border-radius:999px;background:#fff;box-shadow:0 4px 14px #11111129;transition:transform .18s ease}.feature-toggle strong{line-height:1.1}.feature-toggle small{color:var(--muted);line-height:1.4}.feature-toggle.is-active{border-color:#1111112e;background:#1111110a;box-shadow:0 12px 30px #1111110f}.feature-toggle.is-active>span{background:#111}.feature-toggle.is-active>span:after{transform:translate(1.34rem)}.upload-dropzone{display:grid;gap:.3rem;padding:1.05rem 1rem;border:1px dashed rgba(17,17,17,.18);border-radius:18px;background:#ffffffad;color:var(--text);cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease}.upload-dropzone:hover{border-color:#1111115c;background:#fffffff0;transform:translateY(-1px)}.upload-dropzone input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.upload-dropzone strong{font-size:1rem}.upload-dropzone span{overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap}.markdown-editor-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1rem}.markdown-editor-pane,.markdown-preview-pane{min-width:0}.markdown-editor-pane>span,.markdown-preview-pane>span{display:block;margin-bottom:.55rem;color:var(--muted);font-size:.82rem;font-weight:900;letter-spacing:.08em}.markdown-preview-pane{min-height:18rem;max-height:42rem;overflow:auto;padding:1rem;border:1px solid var(--line);border-radius:14px;background:#ffffffdb}.markdown-preview-pane .markdown-body{font-size:.95rem;line-height:1.75}.markdown-preview-pane .markdown-body h1{font-size:1.7rem}.markdown-preview-pane .markdown-body h2{font-size:1.35rem}.markdown-preview-pane .markdown-body h3{font-size:1.1rem}.list-panel{display:grid;gap:.85rem;align-content:start;box-shadow:var(--admin-shadow)}.list-panel-header{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}.list-panel-header>div{display:grid;gap:.25rem}.list-panel-header span{color:var(--muted)}.admin-search{width:100%;min-height:2.85rem;padding:.78rem .95rem;border-radius:14px;border:1px solid var(--line);background:#ffffffe6;outline:none}.admin-search:focus{border-color:#11111157;box-shadow:var(--ring)}.list-panel h2,.media-panel h2{margin:0 0 .2rem}.media-panel{display:grid;gap:1rem;padding:1.2rem;box-shadow:var(--admin-shadow)}.media-item{display:grid;grid-template-columns:7rem minmax(0,1fr) auto;gap:1rem;align-items:center;padding:1rem;border-radius:16px;border:1px solid rgba(17,17,17,.06);background:#ffffff94;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.media-item:hover{border-color:#11111124;background:#ffffffe0;transform:translateY(-1px)}.media-item img{width:7rem;height:5rem;object-fit:cover;border-radius:14px;background:#1111110d}.media-item strong,.media-item span,.media-item small{display:block}.media-item span{overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap}.media-item small,.muted-copy{color:var(--muted)}.admin-list-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1rem;align-items:center;padding:1rem;border-radius:14px;background:#ffffff94;border:1px solid rgba(17,17,17,.06);transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.admin-list-item>div:first-child{display:grid;gap:.35rem;min-width:0}.admin-list-item:hover{border-color:#11111124;background:#ffffffe6;transform:translateY(-1px)}.admin-list-item strong{line-height:1.25}.admin-list-item span{display:block;overflow:hidden;color:var(--muted);font-size:.92rem;line-height:1.4;text-overflow:ellipsis;white-space:nowrap}.error-text{color:#d64e4e}.row-actions{display:flex;flex-wrap:wrap;gap:.6rem}.row-actions a{display:inline-flex;align-items:center;justify-content:center;min-height:2.45rem;padding:.55rem 1rem;border:1px solid var(--line);border-radius:12px;background:#ffffffb8;color:var(--text);font-weight:700}.pagination-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:flex-end;padding-top:.4rem}.pagination-row button{min-height:2.4rem;padding:.5rem .85rem;border:1px solid var(--line);border-radius:12px;background:#ffffffc2;color:var(--text);cursor:pointer}.pagination-row button:disabled{cursor:not-allowed;opacity:.42}.pagination-row span{color:var(--muted-strong);font-weight:800}.admin-actions .nav-pill{min-height:2.45rem;border-color:transparent;background:transparent;box-shadow:none;justify-content:flex-start;padding-inline:.8rem}.admin-actions .nav-pill.active{border-color:#11111114;background:#fff;color:var(--text);box-shadow:0 1px 2px #11111114,0 8px 20px #1111110f}.primary-button{min-height:2.7rem;padding:.62rem 1rem;border-radius:12px;font-weight:700}.ghost-button,.row-actions button{min-height:2.45rem;border-radius:12px;background:#fffc}.row-actions .danger-button{border-color:#b4231829;color:var(--danger);background:var(--danger-soft)}.row-actions .danger-button:hover{border-color:#b4231847;background:#b423181f}.editor-actions{display:flex;flex-wrap:wrap;gap:.75rem}.stats-row{grid-template-columns:repeat(2,minmax(0,1fr))}.visit-grid{display:grid;gap:1.5rem}.visit-filter-panel{display:grid;grid-template-columns:minmax(220px,1fr) repeat(2,minmax(150px,.45fr)) auto;gap:1rem;align-items:end;padding:1.2rem}.visit-filter-panel label{display:grid;gap:.45rem}.visit-filter-panel span{color:var(--muted);font-size:.82rem}.visit-filter-actions{display:flex;gap:.65rem}.visit-panels{grid-template-columns:1fr}.stat-card{padding:1.5rem}.stat-card strong{display:block;margin-top:.5rem;font-size:2rem}.loading-state{padding:6rem 0;color:var(--muted)}.empty-state{display:grid;gap:.7rem;margin-top:2rem;padding:1.4rem;border-radius:22px;border:1px solid rgba(17,17,17,.06);background:#ffffffb8;color:var(--muted-strong)}.empty-state strong{color:var(--text)}@media (max-width: 900px){.site-header,.site-nav,.hero-meta,.preview-header-row,.admin-header,.admin-actions,.site-header-right{flex-wrap:wrap}.intro-grid,.card-grid,.skill-stack,.admin-grid,.media-grid,.visit-panels,.contact-strip,.meta-grid,.detail-content-grid,.related-content-grid,.stats-row,.visit-filter-panel,.skill-metrics{grid-template-columns:1fr}.detail-toc{position:relative;top:auto;order:-1}.project-grid .content-card:nth-child(2n){transform:none}.project-experience-link{grid-template-columns:1fr}.project-experience-index{min-height:5.5rem}.project-experience-action{flex-direction:row;justify-content:flex-start}.project-experience-action span{writing-mode:initial}.hero-content h1{font-size:clamp(3rem,16vw,5rem)}.hero-headline-base,.hero-headline-reveal{gap:.45rem}.page-shell{width:min(100% - 1.5rem,1180px)}.hero{padding-inline:1rem}.hero-disk{display:none}.hero-content-tilt{transform:none!important}.media-item{grid-template-columns:1fr}.admin-shell{padding-inline:1rem;grid-template-columns:1fr}.admin-header{position:static}.admin-actions{display:flex;flex-wrap:wrap;justify-content:flex-start}.editor-panel,.admin-list-item{grid-template-columns:1fr}}@media (max-width: 640px){.site-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.55rem;padding:.7rem .8rem}.brand-mark{font-size:1.15rem;letter-spacing:.1rem}.site-nav{justify-content:center;gap:.15rem;min-width:0}.site-nav a{min-height:2.15rem;padding:.35rem .42rem;font-size:.9rem}.site-header-right{justify-content:flex-end;gap:0}.ghost-button{min-width:3rem;min-height:2.25rem;padding:.35rem .7rem}.page-top-space,.detail-page.page-top-space{padding-top:6.4rem}.detail-toc{position:fixed;inset:auto .85rem .85rem;z-index:50;max-height:72svh;padding:1rem;border-radius:20px;opacity:0;pointer-events:none;transform:translateY(calc(100% + 1.5rem));transition:transform .22s ease,opacity .22s ease}.detail-toc-open{opacity:1;pointer-events:auto;transform:translateY(0)}.detail-toc nav{max-height:calc(72svh - 7rem)}.mobile-toc-trigger{position:fixed;right:1rem;bottom:1rem;z-index:45;display:inline-flex;align-items:center;justify-content:center;min-height:2.8rem;padding:0 1rem;border:1px solid rgba(17,17,17,.12);border-radius:999px;background:#111;color:#fff;font-weight:900;box-shadow:0 18px 44px #11111138}.mobile-toc-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;display:block;border:0;background:#1111112e;opacity:0;pointer-events:none;transition:opacity .18s ease}.mobile-toc-backdrop-open{opacity:1;pointer-events:auto}.toc-close-button{display:inline-flex;align-items:center;justify-content:center;min-height:2rem;padding:0 .75rem;border:1px solid rgba(17,17,17,.08);border-radius:999px;background:#ffffffd1;color:var(--muted-strong);font-size:.82rem;font-weight:800}.toc-link{padding:.42rem .5rem;font-size:.9rem}.toc-level-2{margin-left:.45rem}.toc-level-3{margin-left:.85rem}.skill-card-face{padding:1.45rem 1.45rem 1.25rem}.skill-panel-head{align-items:flex-start;gap:.9rem;padding-bottom:1.15rem}.skill-panel-head h3{font-size:clamp(1.65rem,8vw,2.2rem);line-height:1.12}.skill-badge{width:2.85rem;height:2.85rem;border-radius:.9rem}.skill-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;padding-top:1.35rem}.skill-metrics strong{font-size:clamp(1.8rem,9vw,2.55rem)}.skill-metrics span{font-size:.86rem}.skill-keywords{gap:.45rem;margin-top:1rem}.skill-flip-hint{margin-top:.65rem}.skill-keywords span{padding:.38rem .55rem;font-size:.72rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.hero-disk{display:none}.hero-content-tilt{transform:none!important}}
