:root{--cyan: #22d3ee;--indigo: #6366f1;--coral: #fb7185;--grad: linear-gradient(110deg, var(--cyan), var(--indigo) 45%, var(--coral));--font-disp: "Syne", sans-serif;--font-body: "Manrope", sans-serif;--font-mono: "JetBrains Mono", monospace;--maxw: 1080px}html[data-theme=dark]{--bg: #070a14;--bg-soft: #0d1322;--surface: rgba(255, 255, 255, .04);--surface-2: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .09);--text: #eef2ff;--muted: #9aa6c2;--nav-bg: rgba(7, 10, 20, .7);--blob-op: .18;--grain-op: .045}html[data-theme=light]{--cyan: #0e7490;--bg: #f5f7fc;--bg-soft: #e9edf7;--surface: rgba(13, 19, 34, .035);--surface-2: rgba(13, 19, 34, .06);--border: rgba(13, 19, 34, .12);--text: #0d1322;--muted: #51618a;--nav-bg: rgba(245, 247, 252, .78);--blob-op: .1;--grain-op: .03}*{margin:0;padding:0;box-sizing:border-box}:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}.skip-link{position:absolute;left:-9999px;top:12px;z-index:100;padding:10px 16px;border-radius:8px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);text-decoration:none;font-weight:600;font-size:.9rem}.skip-link:focus{left:16px}html{scroll-behavior:smooth;scroll-padding-top:90px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease}.mesh{position:fixed;inset:0;z-index:-2;overflow:hidden;background:var(--bg);transition:background .4s ease}.blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:var(--blob-op);will-change:transform;transition:opacity .4s ease}.blob.b1{width:50vw;height:50vw;background:var(--indigo);top:-10%;left:-8%;animation:drift1 22s ease-in-out infinite}.blob.b2{width:45vw;height:45vw;background:var(--cyan);top:30%;right:-12%;animation:drift2 26s ease-in-out infinite}.blob.b3{width:40vw;height:40vw;background:var(--coral);bottom:-15%;left:25%;animation:drift3 30s ease-in-out infinite}@keyframes drift1{50%{transform:translate(12vw,14vh) scale(1.15)}}@keyframes drift2{50%{transform:translate(-14vw,10vh) scale(.9)}}@keyframes drift3{50%{transform:translate(8vw,-12vh) scale(1.1)}}.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:var(--grain-op);transition:opacity .4s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.progress{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--grad);z-index:60;transition:width .1s linear}.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%}.cursor-dot{width:6px;height:6px;background:var(--cyan);transform:translate(-50%,-50%)}.cursor-ring{width:34px;height:34px;border:1.5px solid var(--indigo);transform:translate(-50%,-50%);transition:width .2s ease,height .2s ease,border-color .2s ease,background .2s ease}.cursor-ring.hover{width:56px;height:56px;border-color:var(--cyan);background:#22d3ee14}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}section{padding:110px 0}nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;backdrop-filter:blur(12px);background:var(--nav-bg);border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease}nav.scrolled{border-color:var(--border)}.logo{font-family:var(--font-disp);font-weight:800;font-size:1.15rem;letter-spacing:-.02em;text-decoration:none;color:var(--text)}.logo span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.nav-right{display:flex;align-items:center;gap:24px}.nav-links{display:flex;gap:26px;list-style:none}.nav-menu{display:contents}.nav-extra{display:inline-flex;align-items:center;gap:16px}.nav-dd{position:relative}.nav-dropdown{position:absolute;top:100%;left:50%;margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:2px;width:max-content;max-width:460px;padding:8px;border:1px solid var(--border);border-radius:14px;background:var(--bg-soft);box-shadow:0 22px 55px #00000073;opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%) translateY(8px);transition:opacity .18s ease,transform .18s ease;z-index:60}.nav-dropdown:before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}.nav-dd:hover .nav-dropdown,.nav-dd:focus-within .nav-dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%) translateY(0)}.ndd-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:var(--muted);text-decoration:none;font-size:.85rem;line-height:1.2;white-space:nowrap;transition:color .15s ease,background .15s ease}.ndd-item:after{content:none}.ndd-item:hover{color:var(--text);background:var(--surface)}.ndd-item svg{width:16px;height:16px;flex:0 0 16px;color:var(--cyan)}.ndd-dot{width:10px;height:10px;flex:0 0 10px;margin:0 3px;border-radius:50%;background:var(--dot, var(--muted))}@media(max-width:1023px){.nav-dropdown{display:none}}.nav-links a{position:relative;color:var(--muted);text-decoration:none;font-size:.92rem;font-weight:500;transition:color .2s ease}.nav-links a:after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--grad);transition:width .25s ease}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-links a.active:after{width:100%}.theme-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:1.05rem;display:grid;place-items:center;transition:border-color .2s ease,transform .2s ease}.theme-btn:hover{border-color:var(--cyan);transform:translateY(-2px)}.lang-toggle{display:inline-flex;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface);height:38px}.lang-toggle button{font-family:var(--font-mono);font-size:.78rem;font-weight:500;padding:0 11px;background:none;border:none;color:var(--muted);cursor:pointer;transition:color .2s ease,background .2s ease}.lang-toggle button.active{color:#070a14;background:var(--cyan)}.lang-toggle button:not(.active):hover{color:var(--text)}.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.6rem;cursor:pointer}.nav-social{display:inline-flex;align-items:center;gap:2px}.nav-social a{display:grid;place-items:center;width:34px;height:34px;color:var(--muted);border-radius:8px;transition:color .2s ease,transform .2s ease}.nav-social a:hover{color:var(--cyan);transform:translateY(-2px)}.nav-social svg{width:18px;height:18px}.logo,.nav-right{flex:none}.nav-center{display:none}.nav-search-sm{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--muted);cursor:pointer;transition:color .2s ease,border-color .2s ease,transform .2s ease}.nav-search-sm:hover{color:var(--text);border-color:var(--cyan);transform:translateY(-2px)}.nav-search-sm svg{width:17px;height:17px}.nav-search{display:inline-flex;align-items:center;gap:10px;width:100%;max-width:360px;height:40px;padding:0 10px 0 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--muted);cursor:text;transition:border-color .2s ease,background .2s ease}.nav-search:hover{border-color:var(--cyan);background:var(--surface-2)}.nav-search svg{width:17px;height:17px;flex:none}.nav-search-label{flex:1;text-align:left;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-search-key{font-family:var(--font-mono);font-size:.72rem;line-height:1;color:var(--muted);flex:none;border:1px solid var(--border);border-radius:5px;padding:3px 6px;background:var(--bg-soft)}@media(min-width:1180px){.nav-center{flex:1 1 auto;display:flex;justify-content:center;min-width:0;padding:0 16px}.nav-search-sm{display:none}}body.search-lock{overflow:hidden}.search-overlay{position:fixed;inset:0;z-index:200;display:flex;justify-content:center;align-items:flex-start;padding:12vh 20px 20px;background:#060a1499;backdrop-filter:blur(6px);opacity:0;transition:opacity .18s ease}html[data-theme=light] .search-overlay{background:#141a2873}.search-overlay.open{opacity:1}.search-overlay[hidden]{display:none}.search-panel{width:100%;max-width:600px;background:var(--bg-soft);border:1px solid var(--border);border-radius:16px;box-shadow:0 30px 80px #00000073;overflow:hidden;transform:translateY(-8px);transition:transform .18s ease}.search-overlay.open .search-panel{transform:none}.search-inputrow{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border)}.search-inputrow>svg{width:20px;height:20px;color:var(--muted);flex:none}.search-inputrow input{flex:1;min-width:0;background:none;border:none;outline:none;color:var(--text);font-family:inherit;font-size:1.05rem}.search-inputrow kbd{font-family:var(--font-mono);font-size:.7rem;color:var(--muted);border:1px solid var(--border);border-radius:5px;padding:3px 6px;background:var(--surface);flex:none}.search-results{list-style:none;margin:0;padding:8px;max-height:56vh;overflow-y:auto}.search-result{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;cursor:pointer}.search-result[aria-selected=true]{background:var(--surface-2)}.sr-badge{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.04em;text-transform:uppercase;padding:3px 7px;border-radius:6px;border:1px solid var(--border);flex:none;width:46px;text-align:center}.sr-badge--tool{color:var(--cyan);border-color:#22d3ee66}.sr-badge--post{color:var(--indigo);border-color:#6366f166}.sr-badge--code{color:#34d399;border-color:#34d39966}.sr-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.sr-title{color:var(--text);font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-title mark{background:#22d3ee38;color:inherit;border-radius:3px;padding:0 1px}.sr-sub{color:var(--muted);font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-go{color:var(--muted);opacity:0;transition:opacity .15s ease;flex:none}.search-result[aria-selected=true] .sr-go{opacity:1}.search-empty{padding:24px 18px 28px;text-align:center;color:var(--muted);font-size:.9rem}@media(max-width:600px){.search-overlay{padding:8vh 12px 12px}.search-inputrow input{font-size:1rem}.sr-sub{display:none}}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:90px;position:relative}.hero>.wrap{position:relative;z-index:1}.eyebrow{font-family:var(--font-mono);font-size:.85rem;color:var(--cyan);letter-spacing:.08em;margin-bottom:22px}.hero h1{font-family:var(--font-disp);font-weight:800;font-size:clamp(1.6rem,4vw,3.3rem);line-height:1.05;letter-spacing:-.03em;margin-bottom:18px;text-wrap:balance}.hero h1 .accent{white-space:nowrap}.hero-text{min-width:0}.hero h1 .accent{background:var(--grad);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 6s linear infinite}@keyframes shimmer{to{background-position:200% center}}.role-line{font-family:var(--font-mono);font-size:clamp(1rem,3vw,1.5rem);color:var(--text);margin-bottom:26px;min-height:1.6em}.role-line .typed{color:var(--cyan)}.role-line .caret{display:inline-block;width:2px;background:var(--coral);margin-left:2px;animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.hero p.lead{font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--muted);max-width:620px;margin-bottom:36px}.cta-row{display:flex;gap:16px;flex-wrap:wrap}.cta-row+.eyebrow{margin-top:36px}.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 26px;border-radius:12px;font-weight:600;font-size:.95rem;text-decoration:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn-primary{color:#070a14;background:var(--grad);background-size:160% auto}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 34px #6366f159}.btn-ghost{color:var(--text);border:1px solid var(--border);background:var(--surface)}.btn-ghost:hover{transform:translateY(-3px);border-color:var(--cyan)}.tech-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:50px}.tag{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);padding:6px 12px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}.hero-grid{display:grid;grid-template-columns:1fr .92fr;gap:48px;align-items:center}.hero-media{display:flex;justify-content:flex-end}.hero-photo{position:relative;width:100%;max-width:600px;aspect-ratio:4 / 3;border-radius:20px;overflow:hidden;border:1px solid var(--border);box-shadow:0 30px 70px #0006}.hero-photo:before{content:"";position:absolute;inset:-2px;z-index:-1;background:var(--grad);opacity:.5;filter:blur(26px);border-radius:24px}.hero-photo img{width:100%;height:100%;object-fit:cover;display:block;opacity:.82;filter:brightness(.8) saturate(.92);transition:opacity .4s ease,filter .4s ease}.hero-photo:hover img{opacity:1;filter:brightness(1) saturate(1)}.stats{padding:0 0 40px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 20px;text-align:center}.stat .num{font-family:var(--font-disp);font-weight:800;font-size:clamp(2rem,5vw,2.8rem);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}.stat .label{font-size:.82rem;color:var(--muted);margin-top:10px;letter-spacing:.02em}.sec-head{margin-bottom:48px}.sec-head .num{font-family:var(--font-mono);font-size:.85rem;color:var(--cyan)}.sec-head h2{font-family:var(--font-disp);font-weight:700;font-size:clamp(2rem,5vw,3rem);letter-spacing:-.02em;margin-top:8px}.about-grid{max-width:780px}.about-grid p{color:var(--muted);font-size:1.05rem;margin-bottom:18px}.about-grid p strong{color:var(--text)}.skills-group{margin-bottom:28px}.skills-group:last-child{margin-bottom:0}.skills-label{font-family:var(--font-mono);font-size:.78rem;color:var(--cyan);margin-bottom:12px;letter-spacing:.04em}.skills-tags{display:flex;flex-wrap:wrap;gap:10px}.tag[data-rating]{position:relative;cursor:default}.tag[data-rating]:after{content:attr(data-stars);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-soft);border:1px solid var(--border);border-radius:8px;padding:4px 10px;font-size:.82rem;letter-spacing:2px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease,transform .2s ease;transform:translate(-50%) translateY(4px)}.tag[data-rating]:hover:after{opacity:1;transform:translate(-50%) translateY(0)}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.service{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:26px 24px;transition:transform .3s ease,border-color .3s ease}.service:hover{transform:translateY(-4px);border-color:var(--surface-2)}.service .svc-num{font-family:var(--font-mono);font-size:.78rem;color:var(--cyan)}.service h3{font-family:var(--font-disp);font-size:1.15rem;margin:10px 0 8px}.service p{color:var(--muted);font-size:.92rem;line-height:1.55}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}.media-item{margin:0}.bf-num::-webkit-outer-spin-button,.bf-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.bf-num{-moz-appearance:textfield;appearance:textfield}.code-filters{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 24px}.code-chip{font-family:var(--font-mono);font-size:.8rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:7px 14px;cursor:pointer;transition:color .18s ease,border-color .18s ease,background .18s ease}.code-chip:hover{color:var(--text);border-color:var(--surface-2)}.code-chip.active{color:var(--bg);background:var(--cyan);border-color:var(--cyan);font-weight:600}html[data-theme=light] .code-chip.active{color:#fff}.code-lang{font-family:var(--font-mono);font-size:.72rem;font-weight:700;color:var(--cyan);background:var(--bg-soft);border:1px solid var(--border);border-radius:6px;padding:3px 9px;letter-spacing:.03em}.code-list{display:flex;flex-direction:column;gap:10px}.code-row{--row-accent: var(--cyan);display:flex;align-items:center;gap:16px;padding:15px 18px;background:var(--surface);border:1px solid var(--border);border-radius:14px;text-decoration:none;color:inherit;position:relative;overflow:hidden;transition:border-color .2s ease,transform .2s ease,background .2s ease,box-shadow .2s ease}.code-row[data-lang=C]{--row-accent: #4aa8ff}.code-row[data-lang="C++"]{--row-accent: #6e9cff}.code-row[data-lang=Verilog]{--row-accent: #ff5db1}.code-row[data-lang=VHDL]{--row-accent: #b07cff}.code-row[data-lang=Python]{--row-accent: #ffce4a}.code-row[data-lang=Rust]{--row-accent: #ff8a4a}.code-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--row-accent);opacity:.85}.code-row:hover{border-color:var(--row-accent);transform:translate(5px);background:var(--bg-soft);box-shadow:0 8px 26px #00000038}.code-row .code-lang{flex:none;width:84px;box-sizing:border-box;text-align:center;color:var(--row-accent)}.code-row-title{flex:1 1 auto;min-width:0;font-family:var(--font-disp);font-weight:600;font-size:1.06rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.code-row:hover .code-row-title{color:var(--row-accent)}.code-arrow{flex:none;width:20px;height:20px;color:var(--muted);transition:transform .2s ease,color .2s ease}.code-row:hover .code-arrow{color:var(--row-accent);transform:translate(5px)}.code-prose pre{position:relative}.copy-btn{position:absolute;top:8px;right:8px;font-family:var(--font-mono);font-size:.7rem;color:var(--muted);background:var(--bg-soft);border:1px solid var(--border);border-radius:7px;padding:4px 10px;cursor:pointer;opacity:.85;transition:opacity .18s ease,color .18s ease,border-color .18s ease}.copy-btn:hover,.copy-btn:focus-visible{opacity:1;color:var(--cyan);border-color:var(--cyan)}.copy-btn.is-copied{color:var(--cyan);border-color:var(--cyan);opacity:1}.gallery{max-width:820px;margin:0 auto}.gal-stagewrap{position:relative}.gal-stage{display:block;width:100%;aspect-ratio:4 / 3;padding:0;margin:0;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:var(--surface);cursor:zoom-in;font:inherit}.gal-stage img{width:100%;height:100%;object-fit:cover;display:block}.gal-cap{margin:14px 0 0;text-align:center;color:var(--muted);font-size:.92rem;line-height:1.45}.gal-counter{font-family:var(--font-mono);color:var(--cyan);font-size:.78rem;margin-right:10px;letter-spacing:.04em}.gal-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;cursor:pointer;background:#0d13229e;border:1px solid var(--border);color:#fff;font-size:1.6rem;line-height:1;padding:0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);box-shadow:0 6px 20px #0000004d;transition:background .2s ease,border-color .2s ease,color .2s ease}.gal-nav:hover{background:#0d1322d9;border-color:var(--cyan);color:var(--cyan)}.gal-prev{left:12px}.gal-next{right:12px}@media(max-width:560px){.gal-nav{width:40px;height:40px;font-size:1.4rem}}.media-thumb{display:block;width:100%;aspect-ratio:4 / 3;padding:0;margin:0;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface);cursor:zoom-in;font:inherit;transition:border-color .3s ease}.media-thumb:hover{border-color:var(--surface-2)}.media-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;will-change:transform}.media-thumb:hover img,.media-thumb:focus-visible img{transform:scale(1.08)}.media-item figcaption{margin-top:11px;color:var(--muted);font-size:.86rem;line-height:1.45}.cap-tr,html[data-lang=tr] .cap-en{display:none}html[data-lang=tr] .cap-tr{display:inline}.timeline{position:relative;padding-left:28px}.timeline:before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--grad);opacity:.5}.tl-item{position:relative;padding:0 0 38px 22px}.tl-item:last-child{padding-bottom:0}.tl-item:before{content:"";position:absolute;left:-28px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:3px solid var(--cyan)}.tl-head{display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px;align-items:baseline}.tl-role{font-family:var(--font-disp);font-weight:700;font-size:1.2rem}.tl-date{font-family:var(--font-mono);font-size:.82rem;color:var(--cyan)}.tl-company{color:var(--indigo);font-weight:600;font-size:.95rem;margin:2px 0 10px}html[data-theme=light] .tl-company{color:#4f46e5}.tl-item ul{list-style:none}.tl-item li{color:var(--muted);font-size:.95rem;padding:4px 0 4px 18px;position:relative}.tl-item li:before{content:"▸";position:absolute;left:0;color:var(--cyan)}.projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:18px}.card{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:transform .3s ease,border-color .3s ease}.card:hover{transform:translateY(-4px);border-color:var(--surface-2)}.card-visual{position:relative;height:132px;display:grid;place-items:center;background:linear-gradient(135deg,#22d3ee29,#6366f129,#fb718529);border-bottom:1px solid var(--border);overflow:hidden}.card-visual svg{width:100%;height:100%;opacity:.8}.card-visual.has-img{width:100%;padding:0;margin:0;border:none;border-bottom:1px solid var(--border);font:inherit;cursor:zoom-in}.card-visual.has-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;will-change:transform}.card-visual.has-img:hover img,.card-visual.has-img:focus-visible img{transform:scale(1.12)}.card-body{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}.card .ptype{font-family:var(--font-mono);font-size:.7rem;color:var(--cyan);text-transform:uppercase;letter-spacing:.05em}.card h3{font-family:var(--font-disp);font-size:1.08rem;line-height:1.25;margin:6px 0 8px}.card p{color:var(--muted);font-size:.86rem;line-height:1.5;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.card .stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.card .stack span{font-family:var(--font-mono);font-size:.66rem;color:var(--muted);padding:3px 8px;border:1px solid var(--border);border-radius:6px}.post-list{display:flex;flex-direction:column}.post-row{display:flex;gap:30px;align-items:center;padding:26px 4px;border-bottom:1px solid var(--border);text-decoration:none;color:inherit}.post-row:first-child{padding-top:6px}.post-row:hover{background:linear-gradient(90deg,var(--bg-soft),transparent 70%)}.post-row-text{flex:1;min-width:0}.post-row-meta{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);margin-bottom:11px}.post-avatar{border-radius:50%;flex:none;background:var(--bg-soft)}.post-author{font-weight:600;color:var(--text)}.post-dot{opacity:.55}.post-row-title{font-family:var(--font-disp);font-weight:700;font-size:clamp(1.18rem,2.3vw,1.5rem);line-height:1.24;margin:0 0 8px;transition:color .18s ease}.post-row:hover .post-row-title{color:var(--cyan)}.post-row-desc{color:var(--muted);font-size:.95rem;line-height:1.55;margin:0 0 16px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-row-foot{display:flex;align-items:center;gap:14px;font-size:.8rem;color:var(--muted)}.post-cat{padding:4px 12px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--border);font-size:.75rem;white-space:nowrap}.post-row-thumb{flex:none;width:196px;height:128px;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:var(--bg-soft)}.post-row-thumb img{width:100%;height:100%;object-fit:cover;display:block}@media(max-width:660px){.post-row{gap:16px;padding:20px 2px}.post-row-thumb{width:108px;height:86px;border-radius:10px}.post-row-desc{font-size:.9rem;margin-bottom:12px}}@media(max-width:420px){.post-row-desc{display:none}.post-row-thumb{width:92px;height:74px}}.zoom-overlay{position:fixed;inset:0;z-index:200;display:none;place-items:center;padding:5vh 5vw;background:#070a14c7;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;cursor:zoom-out;transition:opacity .25s ease}html[data-theme=light] .zoom-overlay{background:#141a2880}.zoom-overlay.open{display:grid;opacity:1}.zoom-overlay figure{margin:0;display:grid;gap:14px;justify-items:center}.zoom-overlay img{max-width:min(90vw,1000px);max-height:82vh;border-radius:16px;border:1px solid var(--border);box-shadow:0 30px 90px #0000008c;transform:scale(.9);transition:transform .3s ease}.zoom-overlay.open img{transform:scale(1)}.zoom-overlay figcaption{font-family:var(--font-mono);font-size:.82rem;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);padding:8px 16px;border-radius:10px}.zoom-close{position:absolute;top:22px;right:26px;width:44px;height:44px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:1.3rem;line-height:1;cursor:pointer;display:grid;place-items:center}.zoom-close:hover{border-color:var(--cyan);color:var(--cyan)}.contact{text-align:center}.contact .num{font-family:var(--font-mono);color:var(--cyan);font-size:.85rem}.contact h2{font-family:var(--font-disp);font-weight:800;font-size:clamp(2.2rem,6vw,4rem);letter-spacing:-.02em;margin:8px 0 18px}.contact h2 .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}.contact p{color:var(--muted);font-size:1.1rem;max-width:520px;margin:0 auto 34px}.social{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.social a{display:inline-flex;align-items:center;gap:9px;padding:12px 22px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);text-decoration:none;font-weight:600;font-size:.92rem;transition:transform .2s ease,border-color .2s ease,color .2s ease}.social a svg{width:18px;height:18px;flex:0 0 18px}.social a:hover{transform:translateY(-3px);border-color:var(--cyan);color:var(--cyan)}footer{text-align:center;padding:40px 24px;border-top:1px solid var(--border);color:var(--muted);font-size:.85rem}footer .font-mono{font-family:var(--font-mono)}.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}.reveal.in-view{opacity:1;transform:none}@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:40px}.hero-media{order:-1}.hero-photo{max-width:360px;aspect-ratio:5 / 4}}@media(max-width:1023px){nav{backdrop-filter:none}.nav-menu{display:flex;flex-direction:column;align-items:flex-start;gap:20px;position:fixed;top:0;right:0;height:100vh;height:100dvh;width:80%;max-width:320px;padding:92px 28px 28px;z-index:55;background:var(--bg-soft);border-left:1px solid var(--border);transform:translate(100%);transition:transform .3s ease;overflow-y:auto}.nav-menu.open{transform:none}.nav-links{flex-direction:column;gap:20px;width:100%}.nav-extra{display:flex;align-items:center;gap:18px;width:100%;margin-top:6px;padding-top:22px;border-top:1px solid var(--border)}.nav-toggle{display:block;z-index:60}}@media(max-width:760px){.stats-grid{grid-template-columns:repeat(2,1fr)}.about-grid{grid-template-columns:1fr;gap:30px}section{padding:80px 0}}@media(max-width:600px){nav{padding:14px 16px}}@media(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none}.blob{display:none}}.page-top{padding-top:96px}@media(max-width:600px){.page-top{padding-top:84px}}.sec-head h1{font-family:var(--font-disp);font-weight:700;font-size:clamp(2rem,5vw,3rem);letter-spacing:-.02em;margin-top:8px}.post-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;flex:1}.prose{max-width:760px}.prose>*+*{margin-top:1.05em}.prose h2{font-family:var(--font-disp);font-size:1.55rem;letter-spacing:-.01em;margin-top:1.9em}.prose h3{font-family:var(--font-disp);font-size:1.2rem;margin-top:1.6em}.prose p,.prose li{color:var(--muted);font-size:1.02rem}.prose strong{color:var(--text)}.prose a{color:var(--cyan)}.prose ul,.prose ol{padding-left:1.35em}.prose li+li{margin-top:.4em}.prose code{font-family:var(--font-mono);font-size:.85em;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:2px 6px}.prose pre{background:var(--bg-soft);border:1px solid var(--border);border-radius:12px;padding:18px;overflow-x:auto}.prose pre code{background:none;border:none;padding:0}.prose blockquote{border-left:3px solid var(--indigo);padding-left:16px}.prose img{max-width:100%;border-radius:12px;border:1px solid var(--border);cursor:zoom-in;transition:border-color .18s ease,box-shadow .18s ease}.prose img:hover{border-color:var(--cyan);box-shadow:0 6px 24px #0000002e}.tool-grid{display:grid;grid-template-columns:minmax(300px,420px) 1fr;gap:40px;align-items:start;margin-top:8px}.tool-back{margin-top:56px}@media(max-width:860px){.tool-grid{grid-template-columns:1fr}}.tool-form{display:flex;flex-direction:column;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px}.tool-field{display:flex;flex-direction:column;gap:6px}.tool-field label{font-family:var(--font-mono);font-size:.78rem;color:var(--cyan);letter-spacing:.04em}.tool-field select,.tool-field input,.tool-field textarea{background:var(--bg-soft);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px 12px;font-family:var(--font-body);font-size:.95rem;outline:none;transition:border-color .2s ease;width:100%}.tool-field textarea{resize:vertical}.tool-field select:focus,.tool-field input:focus,.tool-field textarea:focus{border-color:var(--cyan)}.tool-row{display:grid;grid-template-columns:1fr 110px;gap:10px}.tool-visual{display:flex;flex-direction:column;gap:24px;align-items:center}.tool-visual svg{width:100%;max-width:480px;height:auto}.tool-result{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px 28px;width:100%}.tool-result .value{font-family:var(--font-mono);font-weight:600;font-size:clamp(1.25rem,3vw,1.8rem);color:var(--text);line-height:1.3;word-break:break-word}.tool-result .sub{font-family:var(--font-mono);font-size:.82rem;color:var(--muted);margin-top:6px}.seg{display:flex;width:100%;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg-soft);flex-wrap:wrap}.seg button{flex:1 1 auto;font-family:var(--font-mono);font-size:.8rem;padding:11px 16px;background:none;border:none;color:var(--muted);cursor:pointer;transition:color .2s ease,background .2s ease}.seg button.active{color:#070a14;background:var(--cyan)}.seg button:not(.active):hover{color:var(--text)}a.service{display:block;text-decoration:none;color:inherit}.service .open-cue{font-family:var(--font-mono);font-size:.78rem;color:var(--cyan);margin-top:14px;display:inline-block}.res-rows{display:grid;gap:10px;text-align:left;margin-bottom:12px}.res-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;border-bottom:1px dashed var(--border);padding-bottom:8px}.res-row:last-child{border-bottom:none;padding-bottom:0}.res-row span{color:var(--muted);font-size:.9rem}.res-row b{font-family:var(--font-mono);color:var(--text);font-size:.95rem;text-align:right;font-weight:500}.code-table-wrap{width:100%;margin-top:28px}.code-table-wrap summary{cursor:pointer;font-family:var(--font-mono);font-size:.85rem;color:var(--cyan);padding:10px 0}.code-table-wrap table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.76rem;margin-top:10px}.code-table-wrap th,.code-table-wrap td{border:1px solid var(--border);padding:5px 8px;text-align:center;color:var(--muted)}.code-table-wrap th{color:var(--text);background:var(--surface-2);font-weight:600}.tool-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.tool-icon{width:46px;height:46px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--cyan);transition:border-color .3s ease,transform .3s ease}.tool-icon svg{width:26px;height:26px}.service:hover .tool-icon{border-color:var(--cyan);transform:translateY(-2px)}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:14px}.tools-grid .service{padding:18px 16px}.tools-grid .service h3{font-size:.95rem;line-height:1.3}.tools-grid .service p{font-size:.78rem;line-height:1.45}.tools-grid .tool-icon{width:38px;height:38px;border-radius:10px}.tools-grid .tool-icon svg{width:22px;height:22px}.tools-grid .tool-card-head{margin-bottom:10px}.tools-grid .open-cue{font-size:.72rem;margin-top:10px}.tools-grid .svc-num{font-size:.7rem}.ad-box{margin:44px 0 8px;min-height:250px;display:grid;place-items:center;border-radius:14px;overflow:hidden}.ad-bottom-wrap{margin:8px auto 40px;max-width:1280px}.ad-box--bottom{margin:0;min-height:120px;width:100%}.ad-box--rail{margin:0;width:160px;min-height:600px}.ad-rail{display:none}@media(min-width:1460px){.ad-rail{display:block;position:fixed;right:18px;top:104px;z-index:40;width:160px}.ad-bottom-wrap{max-width:var(--maxw)}}.ad-placeholder{border:1px dashed var(--border);background:var(--surface);color:var(--muted);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.03em}.support-note{position:fixed;right:18px;bottom:18px;z-index:90;max-width:320px;background:var(--bg-soft);border:1px solid var(--border);border-radius:14px;padding:16px 18px;box-shadow:0 18px 50px #00000059;transform:translateY(16px);opacity:0;transition:transform .4s ease,opacity .4s ease}.support-note.show{transform:none;opacity:1}.support-note p{font-size:.85rem;color:var(--muted);line-height:1.55;margin:0 0 12px}.support-note button{font-family:var(--font-mono);font-size:.75rem;padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:border-color .2s ease}.support-note button:hover{border-color:var(--cyan)}@media(max-width:600px){.support-note{right:12px;left:12px;bottom:12px;max-width:none}}.prose img{display:block}.prose p:has(>em:only-child){text-align:center;font-size:.85rem;margin-top:10px}.prose table{width:100%;border-collapse:collapse;font-size:.9rem}.prose th,.prose td{border:1px solid var(--border);padding:8px 12px;text-align:left;color:var(--muted)}.prose th{color:var(--text);background:var(--surface-2);font-weight:600}.tools-group{display:flex;align-items:center;gap:14px;font-family:var(--font-mono);font-size:.85rem;font-weight:500;color:var(--cyan);letter-spacing:.06em;margin:44px 0 16px}.tools-group:after{content:"";flex:1;height:1px;background:var(--border)}.tools-group:first-of-type{margin-top:28px}.prose .katex-display{margin:12px 0 18px;overflow-x:auto;overflow-y:hidden;padding:4px 0}.prose .katex{font-size:1.08em}.tools-nav{display:flex;flex-wrap:wrap;gap:10px;margin:4px 0 10px}.tools-nav a{font-family:var(--font-mono);font-size:.8rem;color:var(--muted);text-decoration:none;padding:8px 15px;border:1px solid var(--border);border-radius:999px;background:var(--surface);transition:color .2s ease,border-color .2s ease,transform .2s ease}.tools-nav a:hover{color:var(--cyan);border-color:var(--cyan);transform:translateY(-2px)}.tools-group{scroll-margin-top:96px}.tool-pn{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:34px 0 8px}.pn-card{display:flex;flex-direction:column;gap:6px;padding:16px 18px;border:1px solid var(--border);border-radius:14px;background:var(--surface);text-decoration:none;transition:border-color .2s ease,transform .2s ease}.pn-card:hover{border-color:var(--cyan);transform:translateY(-2px)}.pn-card.pn-next{text-align:right;align-items:flex-end}.pn-card.pn-empty{border:none;background:none;pointer-events:none}.pn-dir{font-family:var(--font-mono);font-size:.74rem;color:var(--muted);letter-spacing:.05em}.pn-card b{color:var(--text);font-size:.92rem;font-weight:600;line-height:1.35}@media(max-width:600px){.tool-pn{grid-template-columns:1fr}.pn-card.pn-empty{display:none}}.tools-rail{display:none}@media(min-width:1460px){.tools-rail{display:flex;flex-direction:column;gap:2px;position:fixed;left:18px;top:50%;transform:translateY(-50%);z-index:40;width:168px;padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface)}.rail-head{font-family:var(--font-mono);font-size:.72rem;color:var(--cyan);letter-spacing:.08em;text-transform:uppercase;text-decoration:none;padding:6px 8px 10px;border-bottom:1px solid var(--border);margin-bottom:6px}.rail-item{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:9px;color:var(--muted);text-decoration:none;font-size:.78rem;line-height:1.25;transition:color .2s ease,background .2s ease}.rail-item svg{width:16px;height:16px;flex:0 0 16px}.rail-item:hover{color:var(--text);background:var(--bg-soft)}.rail-item.active{color:var(--cyan);background:var(--bg-soft)}}.toc-rail{display:none}.prose :is(h2,h3){scroll-margin-top:92px}@media(min-width:1460px){.toc-rail{display:block;position:fixed;left:18px;top:100px;z-index:40;width:168px;max-height:78vh;overflow-y:auto;padding:12px 12px 14px;border:1px solid var(--border);border-radius:14px;background:var(--surface);scrollbar-width:thin}.toc-head{font-family:var(--font-mono);font-size:.7rem;color:var(--cyan);letter-spacing:.07em;text-transform:uppercase;padding-bottom:8px;margin-bottom:6px;border-bottom:1px solid var(--border)}.toc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1px}.toc-list a{display:block;color:var(--muted);text-decoration:none;font-size:.78rem;line-height:1.3;padding:5px 8px;border-radius:8px;border-left:2px solid transparent;transition:color .18s ease,background .18s ease,border-color .18s ease}.toc-list a:hover{color:var(--text);background:var(--bg-soft)}.toc-list a.active{color:var(--cyan);border-left-color:var(--cyan);background:var(--bg-soft);font-weight:600}.toc-sub a{padding-left:18px;font-size:.74rem}}.tools-nav a{display:inline-flex;align-items:center;gap:8px}.tools-nav a svg{width:15px;height:15px;flex:0 0 15px}@media(min-width:1460px){.tools-nav{display:none}}@media(max-width:760px){.tools-nav{flex-wrap:nowrap;overflow-x:auto;gap:8px;margin:2px 0 14px;padding-bottom:6px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.tools-nav::-webkit-scrollbar{display:none}.tools-nav a{flex:0 0 auto;font-size:.74rem;padding:7px 12px}.tools-nav a svg{width:14px;height:14px;flex-basis:14px}}.svc-art{display:block;width:96px;height:96px;margin:0 auto 8px;transition:transform .3s ease}.svc-art svg{width:100%;height:100%;display:block}.service:hover .svc-art{transform:translateY(-4px) scale(1.04)}.about-page section{padding:44px 0}.contact-page section{padding:44px 0}.cookie-note{position:fixed;left:50%;bottom:18px;z-index:95;width:calc(100% - 32px);max-width:640px;display:flex;align-items:center;gap:18px;background:var(--bg-soft);border:1px solid var(--border);border-radius:14px;padding:16px 20px;box-shadow:0 18px 50px #00000059;transform:translate(-50%,16px);opacity:0;pointer-events:none;transition:transform .4s ease,opacity .4s ease}.cookie-note.show{transform:translate(-50%);opacity:1;pointer-events:auto}.cookie-note p{margin:0;font-size:.86rem;color:var(--muted);flex:1}.cookie-actions{display:flex;gap:10px;flex:0 0 auto}.cookie-actions .btn{padding:9px 18px;font-size:.85rem}@media(max-width:600px){.cookie-note{flex-direction:column;align-items:stretch;text-align:center}}.tool-share-row{display:flex;justify-content:flex-end;margin:28px 0 4px;padding-top:20px;border-top:1px solid var(--border)}.tool-related{margin:40px 0 8px}.tool-related-head{font-family:var(--font-mono);font-size:.85rem;color:var(--cyan);letter-spacing:.06em;margin:0 0 14px}.tool-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px}.tool-related-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);text-decoration:none;color:inherit;transition:border-color .2s ease,transform .2s ease}.tool-related-card:hover{border-color:var(--cyan);transform:translateY(-2px)}.tool-related-card b{font-size:.9rem;font-weight:600;line-height:1.3}.share[data-astro-cid-ung7bpju]{position:relative;display:inline-block}.share-toggle[data-astro-cid-ung7bpju]{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font:inherit;font-size:.85rem;font-weight:600;color:var(--text);background:var(--bg-soft);border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:border-color .18s ease,color .18s ease,background .18s ease}.share-toggle[data-astro-cid-ung7bpju]:hover{border-color:var(--accent);color:var(--accent)}.share-pop[data-astro-cid-ung7bpju]{position:absolute;left:0;top:calc(100% + 8px);z-index:30;min-width:188px;display:flex;flex-direction:column;gap:2px;padding:8px;background:var(--bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 18px 44px #00000073;animation:sharePop .16s ease}.share-pop[data-astro-cid-ung7bpju][hidden]{display:none}@keyframes sharePop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.share-opt[data-astro-cid-ung7bpju]{display:flex;align-items:center;gap:10px;padding:9px 11px;font-size:.85rem;font-weight:500;text-align:left;color:var(--text);background:none;border:0;border-radius:9px;cursor:pointer;text-decoration:none;width:100%;transition:background .14s ease,color .14s ease}.share-opt[data-astro-cid-ung7bpju] svg[data-astro-cid-ung7bpju]{flex:none;opacity:.9}.share-opt[data-astro-cid-ung7bpju]:hover{background:var(--bg-soft);color:var(--accent)}.share-opt[data-astro-cid-ung7bpju].is-copied{color:var(--accent)}@media(max-width:520px){.share-pop[data-astro-cid-ung7bpju]{right:0;left:auto}}
