.home{--bg:var(--dt-bg);--bg-deeper:var(--dt-bg-deeper);--surface:var(--dt-surface);--surface-2:var(--dt-surface-2);--line:var(--dt-line);--line-strong:var(--dt-line-strong);--ink:var(--dt-ink);--muted:var(--dt-muted);--dim:var(--dt-dim);--accent:var(--dt-accent);--accent-soft:var(--dt-accent-soft);--accent-line:var(--dt-accent-line);--font-display:"Fraunces", "Noto Serif SC", Georgia, serif;--font-serif:"Noto Serif SC", "Fraunces", Georgia, serif;--font-sans:"Geist", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"Geist Mono", "JetBrains Mono", ui-monospace, SFMono, monospace;background:var(--bg);color:var(--ink);font-family:var(--font-serif);grid-template-columns:clamp(320px,26vw,420px) minmax(0,1fr);align-items:stretch;min-height:100vh;margin-top:0;display:grid;position:relative}.home *,.home :before,.home :after{box-sizing:border-box}.home:before{content:"";z-index:0;pointer-events:none;background:linear-gradient(90deg, var(--line) 1px, transparent 1px), linear-gradient(180deg, var(--line) 1px, transparent 1px);opacity:.5;background-size:64px 64px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(#000 40%,#0000 100%);mask-image:radial-gradient(#000 40%,#0000 100%)}.home:after{content:"";z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px 256px;position:fixed;inset:0}.home-sidebar{z-index:2;border-right:1px solid var(--line);background:var(--bg);flex-direction:column;gap:3rem;height:100vh;padding:5rem clamp(2rem,3vw,4rem) 3.5rem;display:flex;position:sticky;top:0}.home-identity{flex-direction:column;gap:1.4rem;display:flex}.home-name{margin:0;line-height:1}.home-name__zh{letter-spacing:-.01em;color:var(--ink);font-family:Noto Serif SC,serif;font-size:3rem;font-weight:700;display:block}.home-name__en{font-variation-settings:"opsz" 16;letter-spacing:.01em;color:var(--muted);opacity:.75;margin-top:.55rem;font-family:Fraunces,serif;font-size:1.1rem;font-style:italic;font-weight:400;display:block}.home-role{font-family:var(--font-mono);color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:.74rem;font-weight:500}.home-lede{color:var(--muted);max-width:22em;margin:0;font-family:Noto Serif SC,serif;font-size:.95rem;font-weight:400;line-height:1.7}.home-nav{flex-direction:column;flex:1;gap:0;margin-top:.5rem;display:flex}.home-nav__link{font-family:var(--font-mono);letter-spacing:.08em;color:var(--dim);cursor:pointer;align-items:center;gap:.85rem;padding:.6rem 0;font-size:.78rem;font-weight:500;text-decoration:none;transition:color .25s;display:flex;position:relative}.home-nav__bar{background:var(--accent);flex-shrink:0;width:0;height:1.5px;transition:width .3s cubic-bezier(.33,1,.68,1);display:block}.home-nav__num{font-variant-numeric:tabular-nums;opacity:.6;font-size:.7rem;transition:opacity .25s}.home-nav__label{transition:letter-spacing .25s}.home-nav__link:hover{color:var(--ink)}.home-nav__link:hover .home-nav__bar{background:var(--muted);width:16px}.home-nav__link.is-active{color:var(--accent)}.home-nav__link.is-active .home-nav__bar{background:var(--accent);width:32px}.home-nav__link.is-active .home-nav__num{opacity:1}.home-nav__link.is-active:hover .home-nav__bar{width:32px}.home-pages{border-top:1px solid var(--line);flex-direction:column;gap:.4rem;margin-top:.5rem;padding-top:1rem;display:flex}.home-page-link{font-family:var(--font-mono);letter-spacing:.12em;color:var(--dim);padding:.4rem 0;font-size:.72rem;font-weight:500;text-decoration:none;transition:color .25s,letter-spacing .25s}.home-page-link:hover{color:var(--accent);letter-spacing:.16em}.home-socials{flex-wrap:wrap;align-items:center;gap:.65rem;display:flex}.home-social{border:1px solid var(--line);width:38px;height:38px;color:var(--muted);background:0 0;border-radius:9px;justify-content:center;align-items:center;text-decoration:none;transition:all .25s;display:inline-flex}.home-social svg{flex-shrink:0;width:1rem;height:1rem}.home-social:hover{color:var(--accent);border-color:var(--accent-line);background:var(--accent-soft);transform:translateY(-2px)}.home-main{z-index:2;flex-direction:column;gap:5.5rem;min-width:0;max-width:72vw;padding:5rem clamp(2rem,5vw,5rem) 8rem;display:flex;position:relative}.home-section{min-width:0;scroll-margin-top:2rem}.home-section__head{align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.home-section__num{font-family:var(--font-mono);color:var(--dim);letter-spacing:.06em;font-variant-numeric:tabular-nums;font-size:.7rem;font-weight:500}.home-section__title{font-family:var(--font-mono);color:var(--ink);letter-spacing:.18em;font-size:.78rem;font-weight:600}.home-section__rule{background:linear-gradient(90deg, var(--accent-line), transparent);flex:1;height:1px}.home-section__body{color:var(--muted);font-family:Noto Serif SC,Fraunces,serif;font-size:1rem;line-height:1.75}.home-section__body p{margin:0 0 1rem}.home-section__body p:last-child{margin-bottom:0}.home-section__body strong{color:var(--ink);font-weight:600}.home-section__body em{color:var(--accent);font-style:normal;font-family:var(--font-mono);letter-spacing:.01em;font-size:.95em;font-weight:500}.home-section__lede{color:var(--dim);border-left:1.5px solid var(--accent-line);padding-left:1rem;font-family:Noto Serif SC,serif;font-size:.95rem;font-style:italic;margin:0 0 1.75rem!important}.home-now-list{flex-direction:column;gap:1rem;margin:0;padding:0;list-style:none;display:flex}.home-now-item{border:1px solid var(--line);color:var(--ink);background:var(--surface);border-radius:10px;grid-template-rows:auto auto;grid-template-columns:minmax(140px,auto) 1fr;gap:.35rem 1.5rem;padding:1.05rem 1.35rem;text-decoration:none;transition:all .25s;display:grid}.home-now-item:hover{border-color:var(--accent-line);background:var(--surface-2);transform:translate(4px)}.home-now-item__name{font-family:var(--font-mono);color:var(--accent);letter-spacing:.01em;font-size:.92rem;font-weight:600}.home-now-item__meta{font-family:var(--font-mono);color:var(--dim);justify-self:end;align-items:center;gap:.7rem;font-size:.74rem;display:inline-flex}.home-now-item__stars{color:var(--muted)}.home-now-item__lang{color:var(--muted);align-items:center;font-size:.9rem;display:inline-flex}.home-now-item__desc{color:var(--muted);grid-column:1/-1;font-family:Noto Serif SC,serif;font-size:.93rem;line-height:1.6}.home-stages{flex-direction:column;gap:2.75rem;margin:0;padding:0;list-style:none;display:flex;position:relative}.home-stages:before{content:"";background:linear-gradient(180deg, transparent, var(--line-strong) 8%, var(--line-strong) 92%, transparent);width:1px;position:absolute;top:.6rem;bottom:.5rem;left:.65rem}.home-stage{padding-left:2.5rem;position:relative}.home-stage:before{content:"";background:var(--bg);border:1.5px solid var(--accent);z-index:1;width:.55rem;height:.55rem;box-shadow:0 0 0 4px var(--bg);border-radius:50%;position:absolute;top:.6rem;left:.4rem}.home-stage__head{flex-wrap:wrap;align-items:baseline;gap:.85rem;margin-bottom:.5rem;display:flex}.home-stage__num{font-family:var(--font-mono);color:var(--accent);letter-spacing:.06em;font-size:.7rem;font-weight:500}.home-stage__name{color:var(--ink);letter-spacing:-.005em;margin:0;font-family:Noto Serif SC,serif;font-size:1.32rem;font-weight:600}.home-stage__range{font-family:var(--font-mono);color:var(--dim);letter-spacing:.03em;font-variant-numeric:tabular-nums;margin-left:auto;font-size:.72rem}.home-stage__desc{color:var(--muted);font-family:Noto Serif SC,serif;font-size:.96rem;line-height:1.6;margin:0 0 .7rem!important}.home-stage__outputs{font-family:var(--font-mono);color:var(--muted);letter-spacing:.01em;flex-wrap:wrap;align-items:center;gap:0 .45rem;font-size:.78rem;line-height:1.6;display:flex;margin:0 0 .85rem!important}.home-stage__outputs-label{color:var(--dim);letter-spacing:.12em;text-transform:uppercase;margin-right:.4rem;font-size:.66rem}.home-stage__output{color:var(--ink)}.home-stage__sep{color:var(--dim);opacity:.5;margin:0 .4rem}.home-stage__learned{color:var(--muted);border-left:2px solid var(--accent);opacity:.92;padding:.65rem 0 .65rem 1rem;font-family:Noto Serif SC,serif;font-size:.93rem;font-style:italic;line-height:1.7;position:relative;margin:0!important}.home-work-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(.875rem,1.2vw,1.25rem);margin-bottom:1.5rem;display:grid}.work-card{border:1px solid var(--line);background:var(--surface);color:inherit;border-radius:11px;flex-direction:column;gap:.7rem;min-height:175px;padding:1.25rem;text-decoration:none;transition:all .25s;display:flex;position:relative;overflow:hidden}.work-card:before{content:"";background:radial-gradient(circle at top right, var(--accent-soft), transparent 60%);opacity:0;pointer-events:none;transition:opacity .3s;position:absolute;inset:0}.work-card:hover{border-color:var(--accent-line);background:var(--surface-2);transform:translateY(-2px);box-shadow:0 10px 30px #00000040}.work-card:hover:before{opacity:1}.work-card__head{justify-content:space-between;align-items:center;gap:.75rem;display:flex;position:relative}.work-card__name{font-family:var(--font-mono);color:var(--accent);letter-spacing:.005em;margin:0;font-size:.96rem;font-weight:600}.work-card__stars{font-family:var(--font-mono);color:var(--muted);letter-spacing:.01em;font-size:.78rem;font-weight:500}.work-card__desc{color:var(--muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin:0;font-family:Noto Serif SC,serif;font-size:.9rem;line-height:1.6;display:-webkit-box;position:relative;overflow:hidden}.work-card__meta{font-family:var(--font-mono);color:var(--dim);letter-spacing:.02em;align-items:center;gap:.7rem;font-size:.7rem;display:flex;position:relative}.work-card__lang{color:var(--muted);align-items:center;font-size:.95rem;display:inline-flex}.work-card__category{border:1px solid var(--line);border-radius:4px;padding:.18rem .55rem;font-size:.66rem}.home-work-more{text-align:right;font-family:var(--font-mono);font-size:.82rem;margin:0!important}.home-work-more a{color:var(--muted);letter-spacing:.01em;text-decoration:none;transition:color .2s,letter-spacing .2s}.home-work-more a:hover{color:var(--accent);letter-spacing:.03em}.home-writing-list{margin:0;padding:0;list-style:none}.home-writing-item{border-top:1px solid var(--line);color:inherit;grid-template-columns:95px 1fr auto;align-items:baseline;gap:1.25rem;padding:1rem 0;text-decoration:none;transition:padding .25s;display:grid}.home-writing-list li:last-child .home-writing-item{border-bottom:1px solid var(--line)}.home-writing-item:hover{padding-left:.5rem}.home-writing-item__date{font-family:var(--font-mono);color:var(--dim);font-variant-numeric:tabular-nums;letter-spacing:.02em;font-size:.74rem}.home-writing-item__title{color:var(--ink);font-family:Noto Serif SC,serif;font-size:1rem;font-weight:500;transition:color .25s}.home-writing-item:hover .home-writing-item__title{color:var(--accent)}.home-writing-item__time{font-family:var(--font-mono);color:var(--dim);letter-spacing:.02em;white-space:nowrap;font-size:.7rem}.home-elsewhere-list{margin:0;padding:0;list-style:none}.home-elsewhere-item{border-top:1px solid var(--line);color:inherit;grid-template-columns:110px 1fr;align-items:baseline;gap:1.5rem;padding:.95rem 0;text-decoration:none;transition:all .25s;display:grid}.home-elsewhere-list li:last-child .home-elsewhere-item{border-bottom:1px solid var(--line)}.home-elsewhere-item:hover{padding-left:.5rem}.home-elsewhere-item__name{font-family:var(--font-mono);color:var(--dim);letter-spacing:.06em;text-transform:uppercase;font-size:.74rem;transition:color .2s}.home-elsewhere-item__url{font-family:var(--font-mono);color:var(--ink);word-break:break-all;font-size:.85rem;transition:color .2s}.home-elsewhere-item:hover .home-elsewhere-item__url,.home-elsewhere-item:hover .home-elsewhere-item__name{color:var(--accent)}.home-footer{border-top:1px solid var(--line);font-family:var(--font-mono);color:var(--dim);letter-spacing:.04em;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:3rem;padding-top:2rem;font-size:.72rem;display:flex}.home-footer span:nth-child(2n){opacity:.5}@media (width<=1024px){.home{grid-template-columns:minmax(0,1fr)}.home-sidebar{border-right:none;border-bottom:1px solid var(--line);flex-direction:column;gap:2rem;height:auto;padding:3rem 2.5rem 2rem;position:relative}.home-name__zh{font-size:2.5rem}.home-nav{flex-flow:wrap;gap:.4rem 1.75rem;margin-top:0}.home-nav__link{padding:.3rem 0}.home-nav__bar{display:none}.home-nav__link.is-active{color:var(--accent)}.home-main{gap:4.5rem;min-width:0;max-width:100%;padding:3.5rem 2.5rem 6rem}}@media (width<=768px){.home-sidebar{gap:1.75rem;padding:2.5rem 1.5rem 1.5rem}.home-name__zh{font-size:2.2rem}.home-name__en{font-size:1rem}.home-lede{font-size:.9rem}.home-nav{scrollbar-width:none;flex-wrap:nowrap;gap:1.5rem;margin:0 -1.5rem;padding:0 1.5rem .4rem;overflow-x:auto}.home-nav::-webkit-scrollbar{display:none}.home-nav__link{flex-shrink:0}.home-main{gap:3.75rem;padding:2.5rem 1.5rem 4rem}.home-section__head{margin-bottom:1.5rem}.home-stages{gap:2.25rem}.home-stage__head{flex-direction:column;align-items:flex-start;gap:.3rem}.home-stage__range{margin-left:0}.home-work-grid{grid-template-columns:1fr}.home-now-item{grid-template-columns:1fr;gap:.4rem}.home-now-item__meta{justify-self:start}.home-writing-item{grid-template-columns:1fr auto;gap:.35rem .75rem}.home-writing-item__date{grid-area:1/1}.home-writing-item__time{grid-area:1/2}.home-writing-item__title{grid-area:2/1/auto/-1}.home-elsewhere-item{grid-template-columns:1fr;gap:.25rem}}@media (width<=480px){.home-name__zh{font-size:1.95rem}.home-name__en{font-size:.95rem}.home-socials .home-social:nth-child(n+5){display:none}}@media (prefers-reduced-motion:reduce){.home *,.home :before,.home :after{transition:none!important;animation:none!important}}.projects{min-height:100vh;color:var(--dt-ink);background:0 0;padding:0 0 4rem}.projects *,.projects :before,.projects :after{box-sizing:border-box}.projects-shell{width:min(1120px,100% - 2rem);margin:0 auto}.projects-hero{max-width:720px;padding:clamp(2.5rem,6vh,4rem) 0 1rem}.projects-hero p,.section-heading p{color:var(--dt-accent);font-family:var(--dt-font-mono);letter-spacing:.18em;text-transform:uppercase;margin:0 0 .7rem;font-size:.7rem;font-weight:700}.page-header__heading{font-family:var(--dt-font-display);letter-spacing:-.025em;color:var(--dt-ink);margin:0 0 .8rem;font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:900;line-height:1.12}.page-header__lede{font-family:var(--dt-font-sans);color:var(--dt-muted);max-width:56ch;font-size:.95rem;line-height:1.65}.page-header__link{color:var(--dt-accent);font-family:var(--dt-font-mono);align-items:center;gap:.35rem;margin-left:.4rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:letter-spacing .25s;display:inline-flex}.page-header__link:hover{letter-spacing:.04em}.project-card-actions a,.project-card-actions button{color:var(--dt-accent);font-family:var(--dt-font-mono);align-items:center;gap:.4rem;font-weight:600;text-decoration:none;display:inline-flex}.featured-projects,.project-browser{border-top:1px solid var(--dt-line);padding:2.5rem 0}.section-heading{margin-bottom:1.5rem}.section-heading h2{color:var(--dt-ink);font-family:var(--dt-font-display);letter-spacing:-.02em;margin:0;font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:900;line-height:1.15}.browser-heading{justify-content:space-between;align-items:end;gap:2rem;display:flex}.featured-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;display:grid}.project-card{background:var(--dt-surface);border:none;border-radius:10px;flex-direction:column;min-height:280px;padding:1.2rem 1.15rem;transition:all .25s;display:flex}.project-card.featured{min-height:300px}.project-card:hover{background:var(--dt-surface-2);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.project-card-top{color:var(--dt-accent);font-family:var(--dt-font-mono);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;gap:1rem;margin-bottom:.85rem;font-size:.65rem;font-weight:700;display:flex}.project-card-top em{color:var(--dt-dim);align-items:center;gap:.25rem;font-style:normal;display:inline-flex}.project-card h3{font-family:var(--dt-font-display);color:var(--dt-accent);margin:0 0 .35rem;font-size:1.05rem;font-weight:800;line-height:1.2}.project-card h4{font-family:var(--dt-font-sans);color:var(--dt-ink);margin:0 0 .6rem;font-size:.95rem;font-weight:600;line-height:1.32}.project-card p{font-family:var(--dt-font-sans);color:var(--dt-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.82rem;line-height:1.55;display:-webkit-box;overflow:hidden}.project-built{flex-wrap:wrap;gap:.3rem;margin-top:.85rem;display:flex}.project-built span{border:1px solid var(--dt-line);color:var(--dt-dim);font-family:var(--dt-font-sans);border-radius:999px;padding:.12rem .45rem;font-size:.62rem;font-weight:550}.project-card-actions{flex-wrap:wrap;align-items:center;gap:.7rem;margin-top:auto;padding-top:.9rem;display:flex}.project-card-actions button{border:1px solid var(--dt-line);cursor:pointer;font-family:var(--dt-font-mono);color:var(--dt-accent);letter-spacing:.02em;background:0 0;border-radius:6px;padding:.4rem .9rem;font-size:.72rem;font-weight:700;transition:background .2s,border-color .2s}.project-card-actions button:hover{background:var(--dt-accent-soft);border-color:var(--dt-accent-line)}.project-tools{flex-wrap:wrap;justify-content:flex-end;gap:.6rem;display:flex}.search-box{border:1px solid var(--dt-line);background:var(--dt-surface);min-height:38px;color:var(--dt-dim);font-family:var(--dt-font-mono);border-radius:8px;align-items:center;gap:.5rem;padding:0 .75rem;font-size:.78rem;display:flex}.search-box input,.project-tools select{color:var(--dt-ink);font-family:var(--dt-font-mono);background:0 0;border:0;outline:0;min-width:200px;font-size:.78rem}.project-tools select{border:1px solid var(--dt-line);background:var(--dt-surface);min-width:120px;min-height:38px;font-family:var(--dt-font-mono);border-radius:8px;padding:0 .7rem;font-size:.76rem}.project-directory{gap:1rem;display:grid}.directory-group{border-top:1px solid var(--dt-line)}.directory-group-heading{justify-content:space-between;align-items:baseline;gap:1rem;padding:.9rem 0 .5rem;display:flex}.directory-group-heading h3{font-family:var(--dt-font-display);color:var(--dt-ink);margin:0;font-size:1rem;font-weight:800;line-height:1.25}.directory-group-heading span{font-family:var(--dt-font-mono);color:var(--dt-dim);letter-spacing:.04em;font-size:.7rem;font-weight:600}.directory-list{background:0 0;border:none;border-radius:10px;overflow:hidden}.directory-item{border-bottom:1px solid #ffffff0a;border-radius:6px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.85rem;min-height:64px;padding:0 .8rem;transition:background .2s;display:grid}.directory-item:last-child{border-bottom:0}.directory-main{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;grid-template-columns:minmax(110px,.3fr) minmax(150px,.38fr) minmax(0,1fr);align-items:baseline;gap:.7rem;padding:.75rem 0;display:grid}.directory-main span,.directory-main strong,.directory-main em{min-width:0}.directory-main span{font-family:var(--dt-font-display);color:var(--dt-ink);font-size:.88rem;font-weight:800}.directory-main strong{font-family:var(--dt-font-mono);color:var(--dt-ink);font-size:.82rem;font-weight:650}.directory-main em{font-family:var(--dt-font-sans);color:var(--dt-muted);-webkit-line-clamp:1;-webkit-box-orient:vertical;font-size:.78rem;font-style:normal;line-height:1.5;display:-webkit-box;overflow:hidden}.directory-item:hover{background:var(--dt-accent-soft)}.directory-meta{font-family:var(--dt-font-mono);color:var(--dt-dim);white-space:nowrap;align-items:center;gap:.6rem;font-size:.7rem;font-weight:600;display:flex}.directory-meta span{gap:.25rem;display:inline-flex}.directory-meta a{color:var(--dt-accent);text-decoration:none}.project-state{background:var(--dt-surface);min-height:220px;color:var(--dt-muted);text-align:center;font-family:var(--dt-font-mono);border:none;border-radius:10px;place-items:center;gap:.7rem;padding:2rem;font-size:.82rem;display:grid}.project-state svg{color:var(--dt-accent);font-size:1.5rem}.project-state button{border:1px solid var(--dt-line);min-height:36px;color:var(--dt-accent);font-family:var(--dt-font-mono);cursor:pointer;background:0 0;border-radius:6px;padding:0 1rem;font-size:.75rem;font-weight:700}.spinner{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.data-footer{border-top:1px solid var(--dt-line);color:var(--dt-dim);font-family:var(--dt-font-mono);letter-spacing:.04em;text-align:center;padding-top:1.5rem;font-size:.7rem}@media (width<=980px){.browser-heading{flex-direction:column;align-items:flex-start}.project-tools{justify-content:flex-start;width:100%}.featured-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.directory-item{grid-template-columns:1fr;gap:.15rem;padding:0 .7rem .7rem}.directory-main{grid-template-columns:1fr;gap:.25rem;padding-bottom:.25rem}.directory-meta{justify-content:flex-start}}@media (width<=560px){.projects{padding-top:4rem}.projects-shell{width:min(100% - 1.25rem,1120px)}.projects-hero h1{font-size:clamp(1.6rem,7vw,2.4rem)}.featured-grid{grid-template-columns:1fr}.search-box,.project-tools select{width:100%}.search-box input{width:100%;min-width:0}}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#080b12b8;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.project-modal{border:1px solid var(--border-color);background:var(--card-bg);width:min(760px,100%);max-height:min(860px,88vh);color:var(--text-primary);border-radius:8px;overflow-y:auto;box-shadow:0 32px 90px #00000047}.project-modal::-webkit-scrollbar{width:6px}.project-modal::-webkit-scrollbar-thumb{background:#64748b59;border-radius:999px}.project-modal-header,.project-modal-story,.story-grid,.built-section,.project-facts,.project-modal-actions{border-bottom:1px solid var(--border-color);padding:1.25rem}.project-modal-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.project-modal-header p,.story-grid span,.built-section>span{color:var(--primary-color);margin:0 0 .7rem;font-size:.78rem;font-weight:850}.project-modal-header h2{color:var(--text-primary);letter-spacing:0;margin:0;font-size:clamp(2rem,5vw,4.4rem);font-weight:820;line-height:1}.archive-note{color:var(--text-secondary);align-items:center;gap:.35rem;margin-top:1rem;font-size:.85rem;font-weight:800;display:inline-flex}.modal-close{border:1px solid var(--border-color);width:42px;height:42px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.modal-close:hover{color:var(--text-primary);border-color:var(--primary-color)}.project-modal-story h3{color:var(--text-primary);margin:0 0 .8rem;font-size:clamp(1.5rem,3vw,2.25rem);line-height:1.18}.project-modal-story p,.story-grid p{color:var(--text-secondary);margin:0;line-height:1.75}.story-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:0;padding:0;display:grid}.story-grid section{padding:1.25rem}.story-grid section:first-child{border-right:1px solid var(--border-color)}.built-section div{flex-wrap:wrap;gap:.5rem;display:flex}.built-section em{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:999px;padding:.28rem .66rem;font-size:.8rem;font-style:normal;font-weight:800}.built-section.muted{background:#94a3b80f}.project-facts{grid-template-columns:repeat(3,minmax(0,1fr));padding:0;display:grid}.project-facts div{text-align:center;border-right:1px solid var(--border-color);padding:1.1rem}.project-facts div:last-child{border-right:0}.project-facts strong{color:var(--text-primary);justify-content:center;align-items:center;gap:.35rem;margin-bottom:.35rem;font-size:1.15rem;display:inline-flex}.project-facts span{color:var(--text-secondary);font-size:.78rem;font-weight:800;display:block}.project-modal-actions{border-bottom:0;flex-wrap:wrap;gap:.8rem;display:flex}.project-modal-actions a{border:1px solid var(--border-color);min-height:42px;color:var(--primary-color);border-radius:8px;align-items:center;gap:.5rem;padding:0 .9rem;font-weight:850;text-decoration:none;display:inline-flex}.project-modal-actions a:hover{border-color:var(--primary-color);color:var(--text-primary)}@media (width<=640px){.modal-backdrop{align-items:flex-end;padding:.75rem}.project-modal{max-height:92vh}.story-grid{grid-template-columns:1fr}.story-grid section:first-child{border-right:0;border-bottom:1px solid var(--border-color)}.project-facts div{padding:.9rem .45rem}.project-facts strong{font-size:1rem}}.blog{min-height:100vh;color:var(--dt-ink);background:0 0;padding:0 0 4rem}.blog *,.blog :before,.blog :after{box-sizing:border-box}.blog-shell{width:min(1120px,100% - 2rem);margin:0 auto}.blog-hero{max-width:720px;padding:clamp(2.5rem,6vh,4rem) 0 1rem}.blog-hero p{color:var(--dt-accent);font-family:var(--dt-font-mono);letter-spacing:.18em;text-transform:uppercase;margin:0 0 .7rem;font-size:.7rem;font-weight:700}.blog-hero h1{font-family:var(--dt-font-display);letter-spacing:-.025em;color:var(--dt-ink);margin:0 0 .8rem;font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:900;line-height:1.12}.blog-hero-copy{color:var(--dt-muted);font-family:var(--dt-font-sans);flex-wrap:wrap;align-items:center;gap:.6rem 1.2rem;font-size:.92rem;line-height:1.65;display:flex}.blog-hero-copy a,.blog-link{color:var(--dt-accent);font-family:var(--dt-font-mono);align-items:center;gap:.35rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:letter-spacing .25s;display:inline-flex}.blog-hero-copy a:hover,.blog-link:hover{letter-spacing:.04em}.blog-list{border-top:1px solid var(--dt-line)}.blog-item-link{color:inherit;text-decoration:none;display:block}.blog-item{border-bottom:1px solid #ffffff0a;border-radius:8px;grid-template-columns:48px minmax(0,1fr) auto;align-items:start;gap:1rem;padding:1.15rem .5rem;transition:background .22s;display:grid}.blog-item:hover{background:var(--dt-surface)}.blog-index{color:var(--dt-accent);opacity:.3;font-family:var(--dt-font-display);padding-top:.15rem;font-size:1.4rem;font-weight:900;line-height:1;transition:opacity .25s}.blog-item:hover .blog-index{opacity:.7}.blog-main{min-width:0}.blog-meta{color:var(--dt-dim);font-family:var(--dt-font-mono);letter-spacing:.03em;flex-wrap:wrap;gap:.6rem 1rem;margin-bottom:.5rem;font-size:.68rem;font-weight:600;display:flex}.blog-date,.blog-read-time{align-items:center;gap:.3rem;display:inline-flex}.blog-date svg,.blog-read-time svg{opacity:.6;font-size:.6rem}.blog-title{font-family:var(--dt-font-display);color:var(--dt-ink);margin:0 0 .4rem;font-size:1.08rem;font-weight:800;line-height:1.28;transition:color .22s}.blog-item:hover .blog-title{color:var(--dt-accent)}.blog-excerpt{max-width:56ch;color:var(--dt-muted);font-family:var(--dt-font-sans);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.82rem;line-height:1.58;display:-webkit-box;overflow:hidden}.blog-tags{flex-wrap:wrap;gap:.3rem;margin-top:.7rem;display:flex}.blog-tags .blog-category-badge,.blog-tags .blog-tag-badge{border:1px solid var(--dt-line);color:var(--dt-dim);background:0 0;border-radius:999px;align-items:center;gap:.2rem;padding:.12rem .42rem;font-size:.62rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.blog-tags .blog-category-badge{color:var(--dt-accent);border-color:var(--dt-accent-line)}.blog-tags .blog-tag-badge:hover{color:var(--dt-muted);border-color:var(--dt-accent-line)}.blog-link{white-space:nowrap;opacity:0;align-self:center;font-size:.75rem;transition:opacity .25s,transform .25s;transform:translate(-4px)}.blog-item:hover .blog-link{opacity:1;transform:translate(0)}.blog-footer{color:var(--dt-dim);font-family:var(--dt-font-mono);letter-spacing:.04em;text-align:center;padding-top:1.5rem;font-size:.7rem}.last-updated{color:var(--dt-dim);margin:0}.blog-state{background:var(--dt-surface);min-height:220px;color:var(--dt-muted);text-align:center;font-family:var(--dt-font-mono);border:none;border-radius:10px;place-items:center;gap:.7rem;padding:2rem;font-size:.82rem;display:grid}.blog-state h3{color:var(--dt-ink);margin:0}.blog-state p{margin:0}.loading-spinner{border:2px solid var(--dt-line);border-top-color:var(--dt-accent);border-radius:50%;width:30px;height:30px;animation:1s linear infinite spin}.retry-btn{border:1px solid var(--dt-line);min-height:36px;color:var(--dt-accent);font-family:var(--dt-font-mono);cursor:pointer;background:0 0;border-radius:6px;padding:0 1rem;font-size:.75rem;font-weight:700;transition:background .2s}.retry-btn:hover{background:var(--dt-accent-soft)}@media (width<=980px){.blog{padding-top:4rem}.blog-shell{width:min(100% - 1.25rem,1120px)}.blog-hero h1{font-size:clamp(1.6rem,6vw,2.4rem)}.blog-item{grid-template-columns:1fr;gap:.5rem;padding:1rem .5rem}.blog-index{font-size:1.15rem}.blog-link{opacity:1;align-self:start;transform:none}}@media (width<=560px){.blog-hero h1{font-size:clamp(1.4rem,7vw,2rem)}}.btn-visual-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));box-shadow:0 4px 15px #2563eb4d}.btn-visual-primary:hover{box-shadow:0 6px 20px #2563eb66}.btn-visual-success{box-shadow:0 4px 15px #10b9814d}.btn-visual-success:hover{box-shadow:0 6px 20px #10b98166}.btn-visual-warning{box-shadow:0 4px 15px #f59e0b4d}.btn-visual-warning:hover{box-shadow:0 6px 20px #f59e0b66}.btn-visual-destructive{box-shadow:0 4px 15px #ef44444d}.btn-hover-lift{transition:transform .3s,box-shadow .3s}.btn-hover-lift:hover{transform:translateY(-2px)}.btn-pill{border-radius:9999px}@keyframes btn-shine{0%{background-position:-200%}to{background-position:200%}}.btn-shine{position:relative;overflow:hidden}.btn-shine:before{content:"";background:linear-gradient(105deg,#0000 35%,#ffffff40 50%,#0000 65%) 0 0/200% 100%;animation:2.5s ease-in-out infinite paused btn-shine;position:absolute;inset:0}.btn-shine:hover:before{animation-play-state:running}.prism-code-block{border:1px solid var(--border-color);background-color:var(--bg-color);border-radius:12px;margin:16px 0;transition:all .3s;overflow:hidden;box-shadow:0 4px 12px #0000001a}.prism-code-block:hover{border-color:var(--accent-color);box-shadow:0 6px 20px #00000026}.prism-code-header{background:linear-gradient(135deg, var(--border-color), #8080801a);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;min-height:48px;padding:12px 16px;display:flex}.prism-code-info{align-items:center;gap:12px;display:flex}.prism-language-badge{background:var(--accent-color);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600;box-shadow:0 2px 4px #0000001a}.prism-code-lines{color:var(--text-color);opacity:.7;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:12px}.prism-code-actions{gap:8px;display:flex}.prism-action-button{color:var(--text-color);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:6px;justify-content:center;align-items:center;min-width:32px;height:32px;padding:6px 10px;font-size:14px;transition:all .2s;display:flex}.prism-action-button:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color);background:#fff3;transform:translateY(-1px)}.prism-action-button:disabled{opacity:.5;cursor:not-allowed}.prism-action-button:active:not(:disabled){transform:translateY(0)}.prism-loading-skeleton{background:linear-gradient(90deg, var(--border-color) 25%, #8080801a 50%, var(--border-color) 75%);background-size:200% 100%;border-radius:8px;margin:8px 0;padding:16px;animation:1.5s infinite prism-loading}@keyframes prism-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.prism-loading-text{text-align:center;color:var(--text-color);opacity:.7;padding:20px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:14px}.prism-code-content pre[class*=language-]{background:var(--bg-color);color:var(--text-color);white-space:pre;word-wrap:normal;-webkit-overflow-scrolling:touch;margin:0;padding:20px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:14px;line-height:1.6;overflow-x:auto}.prism-code-content code[class*=language-]{font-size:inherit;color:inherit;white-space:pre;word-wrap:normal;background:0 0;border:none;padding:0;font-family:inherit}.prism-code-block .token.comment,.prism-code-block .token.prolog,.prism-code-block .token.doctype,.prism-code-block .token.cdata{color:#6a737d;font-style:italic}.prism-code-block .token.punctuation{color:#e1e4e8}.prism-code-block .token.property,.prism-code-block .token.tag,.prism-code-block .token.boolean,.prism-code-block .token.number,.prism-code-block .token.constant,.prism-code-block .token.symbol,.prism-code-block .token.deleted{color:#79b8ff}.prism-code-block .token.selector,.prism-code-block .token.attr-name,.prism-code-block .token.string,.prism-code-block .token.char,.prism-code-block .token.builtin,.prism-code-block .token.inserted{color:#9ecbff}.prism-code-block .token.operator,.prism-code-block .token.entity,.prism-code-block .token.url,.prism-code-block .language-css .token.string,.prism-code-block .style .token.string{color:#b392f0}.prism-code-block .token.atrule,.prism-code-block .token.attr-value,.prism-code-block .token.keyword{color:#f97583}.prism-code-block .token.function,.prism-code-block .token.class-name{color:#b392f0}.prism-code-block .token.regex,.prism-code-block .token.important,.prism-code-block .token.variable{color:#ffab70}@media (width<=768px){.prism-code-header{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 12px}.prism-code-actions{align-self:flex-end}.prism-code-content pre[class*=language-]{padding:16px;font-size:13px}.prism-language-badge{padding:3px 8px;font-size:11px}}.app:not(.dark) .prism-code-block{background-color:#fff;border-color:#e1e4e8;box-shadow:0 2px 8px #0000000d}.app:not(.dark) .prism-code-header{background:linear-gradient(135deg,#f6f8fa,#e1e4e8);border-bottom-color:#e1e4e8}.app:not(.dark) .prism-code-content pre[class*=language-]{color:#24292e;background-color:#fff}.prism-code-content pre[class*=language-]::-webkit-scrollbar{width:8px;height:8px}.prism-code-content pre[class*=language-]::-webkit-scrollbar-track{background:var(--border-color);border-radius:4px}.prism-code-content pre[class*=language-]::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:4px}.prism-code-content pre[class*=language-]::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}.markdown-content{color:var(--text-color);max-width:none;font-size:1rem;line-height:1.7}.markdown-title{color:var(--text-color);background:linear-gradient(135deg, var(--primary-color), var(--accent-color));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:2rem 0 1.5rem;font-size:2.5rem;font-weight:800;line-height:1.2}.markdown-heading{color:var(--text-color);border-bottom:2px solid var(--border-color);margin:2rem 0 1rem;padding-bottom:.5rem;font-size:1.8rem;font-weight:700;line-height:1.3}.markdown-subheading{color:var(--text-color);margin:1.5rem 0 .8rem;font-size:1.4rem;font-weight:600;line-height:1.4}.markdown-paragraph{color:var(--text-light);margin:2rem 0;line-height:1.8}.markdown-list,.markdown-ordered-list{margin:1.5rem 0;padding-left:2rem}.markdown-list-item{color:var(--text-light);margin:.8rem 0;line-height:1.6}.markdown-list-item::marker{color:var(--primary-color);font-weight:700}.markdown-list.contains-task-list{margin:1.2rem 0;padding-left:0;list-style:none}.task-list-item{color:var(--text-light);background:0 0;border-radius:4px;align-items:flex-start;min-height:20px;margin:.8rem 0;padding:.25rem 0;line-height:1.6;transition:all .15s;display:flex}.task-list-item:hover{background:var(--hover-bg)}.task-list-item input[type=checkbox]{border:1.5px solid var(--border-color);cursor:pointer;appearance:none;background-color:#fff;border-radius:3px;flex-shrink:0;width:16px;height:16px;margin-top:2px;margin-right:.75rem;transition:all .15s;position:relative}.task-list-item input[type=checkbox]:hover{border-color:var(--primary-color)}.task-list-item input[type=checkbox]:checked{background-color:var(--primary-color);border-color:var(--primary-color);position:relative}.task-list-item input[type=checkbox]:checked:after{content:"✓";color:#fff;font-size:11px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.task-list-item input[type=checkbox]:checked+*{color:var(--text-secondary);opacity:.7;text-decoration:line-through}.task-list-item>:not(input[type=checkbox]){white-space:pre-line;word-break:break-word;flex:1;min-width:0;margin-top:2px;line-height:1.2}.task-list-item p{margin:0;line-height:1.2}.app.dark .task-list-item{color:var(--text-light)}.app.dark .task-list-item input[type=checkbox]{background-color:#1e293b;border-color:#475569}.app.dark .task-list-item input[type=checkbox]:hover{border-color:var(--primary-color)}.app.dark .task-list-item input[type=checkbox]:checked{background-color:var(--primary-color);border-color:var(--primary-color)}.markdown-inline-code{color:var(--primary-color);background:#2563eb14;border:1px solid #2563eb33;border-radius:3px;padding:.1rem .3rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.85em;font-weight:500}.markdown-link{color:var(--primary-color);border-bottom:1px solid #0000;text-decoration:none;transition:all .3s}.markdown-link:hover{color:var(--primary-dark);border-bottom-color:var(--primary-color)}.markdown-quote{border-left:4px solid var(--primary-color);color:var(--text-light);background:#2563eb0d;border-radius:0 8px 8px 0;margin:1.5rem 0;padding:1rem 1.5rem;font-style:italic}.markdown-table-wrapper{box-shadow:var(--shadow);border-radius:8px;margin:1.5rem 0;overflow-x:auto}.markdown-table{border-collapse:collapse;background:var(--bg-color);border:1px solid var(--border-color);width:100%}.markdown-table-header{background:var(--bg-light);color:var(--text-color);text-align:left;border-bottom:2px solid var(--border-color);padding:1rem;font-weight:600}.markdown-table-cell{border-bottom:1px solid var(--border-color);color:var(--text-light);padding:1rem}.markdown-table tr:nth-child(2n){background:#00000005}.app.dark .markdown-pre{background:#1e293b;border-color:#334155}.app.dark .markdown-code-block{color:#e2e8f0}.app.dark .markdown-inline-code{color:#60a5fa;background:#60a5fa1a;border-color:#60a5fa4d}@media (width<=768px){.markdown-content{font-size:.95rem}.markdown-title{font-size:2rem}.markdown-heading{font-size:1.5rem}.markdown-subheading{font-size:1.2rem}.markdown-pre{padding:1rem;font-size:.85rem}.markdown-table-wrapper{font-size:.9rem}.markdown-table-header,.markdown-table-cell{padding:.75rem .5rem}}.markdown-pre::-webkit-scrollbar{height:8px}.markdown-pre::-webkit-scrollbar-track{background:var(--bg-light);border-radius:4px}.markdown-pre::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.markdown-pre::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.blog-post{min-height:100vh;color:var(--dt-ink);background:0 0;padding:0 0 4rem}.blog-post *,.blog-post :before,.blog-post :after{box-sizing:border-box}.container{width:min(820px,100% - 2rem);margin:0 auto;padding:0 1rem}@media (width>=1440px){.container{max-width:900px}}.blog-post-nav{padding:clamp(2rem,5vh,3.5rem) 0 1rem}.back-button{color:var(--dt-dim);font-family:var(--dt-font-mono);letter-spacing:.03em;border:1px solid var(--dt-line);background:0 0;border-radius:6px;align-items:center;gap:.35rem;padding:.35rem .85rem;font-size:.72rem;font-weight:700;text-decoration:none;transition:all .22s;display:inline-flex}.back-button:hover{color:var(--dt-accent);border-color:var(--dt-accent-line);background:var(--dt-accent-soft)}.blog-post-loading,.blog-post-error{justify-content:center;align-items:center;min-height:60vh;display:flex}.loading-container,.error-container{text-align:center;padding:2rem}.loading-spinner{border:2px solid var(--dt-line);border-top-color:var(--dt-accent);border-radius:50%;width:30px;height:30px;margin:0 auto 1rem;animation:1s linear infinite spin}.error-container h2{color:var(--dt-ink);font-family:var(--dt-font-display);margin-bottom:.5rem}.error-container p{color:var(--dt-muted);font-family:var(--dt-font-mono);margin-bottom:1.5rem;font-size:.82rem}.blog-post-header{margin-bottom:2.5rem}.blog-post-cover{border-radius:10px;width:100%;height:320px;margin-bottom:1.5rem;position:relative;overflow:hidden}.cover-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.cover-overlay{background:linear-gradient(#0000,#0a0e1ae6);height:45%;position:absolute;bottom:0;left:0;right:0}.meta-primary{margin-bottom:1.2rem}.blog-post-title{font-family:var(--dt-font-display);letter-spacing:-.025em;color:var(--dt-ink);margin:0 0 .7rem;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900;line-height:1.15}.blog-post-excerpt{font-family:var(--dt-font-sans);color:var(--dt-muted);max-width:60ch;margin:0;font-size:.95rem;line-height:1.62}.meta-secondary{border-top:1px solid var(--dt-line);flex-wrap:wrap;align-items:center;gap:1.2rem;padding-top:.9rem;display:flex}.meta-info{flex-wrap:wrap;gap:1rem;display:flex}.meta-item{color:var(--dt-dim);font-family:var(--dt-font-mono);letter-spacing:.02em;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;display:inline-flex}.meta-item svg{color:var(--dt-accent);opacity:.7;font-size:.62rem}.meta-tags{flex-wrap:wrap;gap:.3rem;display:flex}.meta-tags .blogpost-category-badge{color:var(--dt-accent);border:1px solid var(--dt-accent-line);background:#ffb86b14;border-radius:999px;padding:.15rem .55rem;font-size:.65rem;font-weight:700;text-decoration:none}.meta-tags .blogpost-tag-badge{border:1px solid var(--dt-line);color:var(--dt-dim);border-radius:999px;padding:.12rem .45rem;font-size:.62rem;font-weight:600;text-decoration:none;transition:all .2s}.meta-tags .blogpost-tag-badge:hover{color:var(--dt-muted);border-color:var(--dt-accent-line)}.blog-post-actions{gap:.6rem;margin-top:1.2rem;display:flex}.action-button{color:var(--dt-dim);border:1px solid var(--dt-line);font-family:var(--dt-font-mono);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:.35rem;padding:.35rem .85rem;font-size:.7rem;font-weight:700;text-decoration:none;transition:all .22s;display:inline-flex}.action-button:hover{color:var(--dt-accent);border-color:var(--dt-accent-line);background:var(--dt-accent-soft)}.blog-post-content{border-top:1px solid var(--dt-line);font-family:var(--dt-font-sans);color:var(--dt-ink);padding:2rem 0;font-size:.92rem;line-height:1.78}.blog-post-content h1,.blog-post-content h2,.blog-post-content h3,.blog-post-content h4{font-family:var(--dt-font-display);letter-spacing:-.02em;color:var(--dt-ink);margin-top:2em;margin-bottom:.6em;font-weight:800;line-height:1.25}.blog-post-content h1{font-size:1.6rem}.blog-post-content h2{font-size:1.35rem}.blog-post-content h3{font-size:1.15rem}.blog-post-content h4{font-size:1rem}.blog-post-content p{color:var(--dt-ink);margin:0 0 1em}.blog-post-content a{color:var(--dt-accent);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .2s}.blog-post-content a:hover{border-bottom-color:var(--dt-accent)}.blog-post-content code{font-family:var(--dt-font-mono);color:var(--dt-accent);background:#ffffff0d;border-radius:4px;padding:.15em .35em;font-size:.85em}.blog-post-content pre{background:var(--dt-surface);border:1px solid var(--dt-line);border-radius:8px;margin:1.2em 0;padding:1.2rem;overflow-x:auto}.blog-post-content pre code{color:var(--dt-ink);background:0 0;padding:0;font-size:.82rem}.blog-post-content blockquote{border-left:3px solid var(--dt-accent);color:var(--dt-muted);background:#ffb86b08;border-radius:0 6px 6px 0;margin:1.2em 0;padding:.6rem 1rem;font-style:italic}.blog-post-content ul,.blog-post-content ol{margin:.8em 0;padding-left:1.5rem}.blog-post-content li{color:var(--dt-ink);margin-bottom:.35em}.blog-post-content img{border-radius:8px;max-width:100%;margin:1.2em 0}.blog-post-content hr{border:none;border-top:1px solid var(--dt-line);margin:2em 0}.blog-post-content table{border-collapse:collapse;width:100%;margin:1.2em 0}.blog-post-content th,.blog-post-content td{border:1px solid var(--dt-line);text-align:left;padding:.6rem .8rem;font-size:.88rem}.blog-post-content th{background:var(--dt-surface);font-family:var(--dt-font-mono);color:var(--dt-accent);letter-spacing:.03em;font-size:.78rem;font-weight:700}.blog-post-footer{border-top:1px solid var(--dt-line);margin-top:2.5rem;padding-top:1.5rem}.footer-content{justify-content:space-between;align-items:flex-start;gap:2rem;display:flex}.author-info{flex:1;max-width:480px}.author-info h3{font-family:var(--dt-font-display);color:var(--dt-ink);margin:0 0 .5rem;font-size:1rem;font-weight:800}.author-info p{font-family:var(--dt-font-sans);color:var(--dt-muted);margin:0 0 .8rem;font-size:.82rem;line-height:1.6}.author-links{gap:.5rem;display:flex}.author-link{color:var(--dt-dim);border:1px solid var(--dt-line);font-family:var(--dt-font-mono);background:0 0;border-radius:6px;align-items:center;gap:.3rem;padding:.3rem .7rem;font-size:.7rem;font-weight:600;text-decoration:none;transition:all .22s;display:inline-flex}.author-link:hover{color:var(--dt-accent);border-color:var(--dt-accent-line);background:var(--dt-accent-soft)}.article-navigation{flex-shrink:0}.nav-button{color:var(--dt-accent);border:1px solid var(--dt-accent-line);font-family:var(--dt-font-mono);background:0 0;border-radius:6px;align-items:center;gap:.35rem;padding:.45rem .95rem;font-size:.75rem;font-weight:700;text-decoration:none;transition:all .22s;display:inline-flex}.nav-button:hover{background:var(--dt-accent-soft)}@media (width<=1024px){.blog-post-cover{height:260px}.footer-content{flex-direction:column;align-items:stretch}.article-navigation{margin-top:1rem}}@media (width<=768px){.blog-post-nav{padding-top:4rem}.blog-post-cover{border-radius:8px;height:200px}.blog-post-title{font-size:1.5rem}.meta-secondary{flex-direction:column;align-items:flex-start;gap:.8rem}.meta-info{flex-direction:column;gap:.5rem}.blog-post-actions{flex-direction:column}.action-button{justify-content:center}.blog-post-content{padding:1.5rem 0;font-size:.88rem}.footer-content{gap:1.2rem}.author-links{justify-content:flex-start}}@media (width<=480px){.blog-post-title{font-size:1.3rem}.blog-post-content h1{font-size:1.35rem}.blog-post-content h2{font-size:1.2rem}}.tl-section{grid-template-columns:200px 1fr;align-items:start;gap:0;padding:0 0 6rem;display:grid;position:relative}.tl-dial-col{z-index:30;justify-content:flex-start;align-items:flex-start;height:100vh;padding-top:clamp(2rem,5vh,3.5rem);padding-left:clamp(1rem,2.5vw,2rem);display:flex;position:sticky;top:0}.tl-dial{flex-direction:column;gap:1.2rem;display:flex;position:relative}.tl-dial__page-title{font-family:var(--dt-font-mono);letter-spacing:.2em;color:var(--dt-accent);text-transform:uppercase;font-size:.72rem;font-weight:700}.tl-dial__heading{font-family:var(--dt-font-mono);letter-spacing:.28em;color:var(--dt-dim);text-transform:uppercase;margin-bottom:.3rem;padding-left:.1rem;font-size:.6rem;font-weight:700}.tl-dial__track{flex-direction:column;gap:1.4rem;display:flex;position:relative}.tl-dial__track:before{content:"";background:linear-gradient(180deg, transparent 0%, var(--dt-line) 12%, var(--dt-line) 88%, transparent 100%);z-index:0;width:1px;position:absolute;top:.4rem;bottom:.4rem;left:.95rem}.tl-dial__item{cursor:pointer;color:var(--dt-dim);font-family:var(--dt-font-mono);text-align:left;z-index:1;background:0 0;border:none;grid-template-columns:auto 28px 1fr;align-items:center;gap:.5rem;padding:0;transition:color .3s;display:grid;position:relative}.tl-dial__item:hover{color:var(--dt-muted)}.tl-dial__item.is-active{color:var(--dt-accent)}.tl-dial__num{letter-spacing:.18em;font-variant-numeric:tabular-nums;background:var(--dt-bg);z-index:1;width:1.5rem;padding:.1rem .18rem;font-size:.7rem;font-weight:700}.tl-dial__bar{opacity:.4;background:currentColor;justify-self:start;width:16px;height:1px;transition:width .35s cubic-bezier(.2,.8,.2,1),opacity .3s}.tl-dial__item.is-active .tl-dial__bar{opacity:1;width:32px;box-shadow:0 0 8px #ffb86b66}.tl-dial__label{font-family:var(--dt-font-display);letter-spacing:.003em;white-space:nowrap;opacity:.65;font-size:.82rem;font-weight:700;transition:opacity .3s}.tl-dial__item:hover .tl-dial__label,.tl-dial__item.is-active .tl-dial__label{opacity:1}.tl-dial__footer{font-family:var(--dt-font-mono);letter-spacing:.16em;color:var(--dt-dim);font-variant-numeric:tabular-nums;margin-top:.5rem;padding-left:.2rem;font-size:.62rem}.tl-dial__home{font-family:var(--dt-font-mono);color:var(--dt-dim);letter-spacing:.04em;padding-left:.2rem;font-size:.65rem;text-decoration:none;transition:color .25s}.tl-dial__home:hover{color:var(--dt-accent)}.tl-panels{scroll-snap-type:y mandatory;width:100%;max-width:1120px;height:100vh;margin:0;padding:0 clamp(1.2rem,3.5vw,2.5rem) 0 clamp(.5rem,1vw,1rem);overflow:hidden}.tl-panel{scroll-snap-align:start;scroll-snap-stop:always;grid-template-columns:auto 1fr;align-items:start;gap:clamp(2rem,3.5vw,3.5rem);height:100vh;padding:clamp(2rem,5vh,3rem) 0;display:grid;position:relative;overflow:hidden}.tl-panel:after{content:attr(data-stagenum);font-family:var(--dt-font-display);letter-spacing:-.06em;color:#0000;-webkit-text-stroke:1px #ffb86b0d;text-stroke:1px #ffb86b0d;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;white-space:nowrap;font-size:clamp(6rem,14vw,12rem);font-weight:900;line-height:.85;position:absolute;top:clamp(1.5rem,4vh,2.5rem);right:-.3rem}.tl-panel+.tl-panel:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--dt-line-strong) 30%, var(--dt-line-strong) 70%, transparent 100%);opacity:.4;height:1px;position:absolute;top:0;left:0;right:25%}.tl-panel__anchor{z-index:1;flex-direction:column;gap:.6rem;max-width:280px;padding-top:.3rem;display:flex;position:relative}.tl-panel__anchor-num{font-family:var(--dt-font-mono);color:var(--dt-accent);letter-spacing:.24em;font-size:.7rem;font-weight:700}.tl-panel__title{font-family:var(--dt-font-display);letter-spacing:-.025em;color:var(--dt-ink);margin:0;font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:900;line-height:1.08}.tl-panel__meta{font-family:var(--dt-font-mono);flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.tl-panel__period{letter-spacing:.05em;color:var(--dt-muted);font-variant-numeric:tabular-nums;font-size:.78rem}.tl-panel__theme{border:1px solid var(--dt-line-strong);letter-spacing:.03em;color:var(--dt-muted);border-radius:999px;padding:.15rem .55rem;font-size:.68rem;font-weight:600}.tl-panel__context{color:var(--dt-muted);border-left:2px solid var(--dt-accent-line);margin:.4rem 0 0;padding:.4rem 0 .4rem .8rem;font-family:Noto Serif SC,serif;font-size:.85rem;line-height:1.65}.tl-panel__content{z-index:1;flex-direction:column;gap:1rem;min-width:0;display:flex;position:relative}.tl-section-label{font-family:var(--dt-font-mono);letter-spacing:.2em;text-transform:uppercase;border-bottom:1px solid var(--dt-line);align-items:center;gap:.45rem;margin-bottom:.2rem;padding-bottom:.4rem;font-size:.62rem;font-weight:700;display:flex}.tl-section-label--world{color:var(--dt-dim)}.tl-section-label--me{color:var(--dt-accent)}.tl-section-label:before{content:"";opacity:.55;background:currentColor;border-radius:50%;width:7px;height:7px}.tl-items-row{flex-flow:wrap;gap:.75rem;display:flex}.tl-event{background:#96c8ff0a;border:none;border-radius:10px;flex:240px;min-width:220px;max-width:340px;padding:.75rem .9rem;transition:background .25s,transform .2s}.tl-event:hover{background:#96c8ff14;transform:translateY(-1px)}.tl-event__date{font-family:var(--dt-font-mono);letter-spacing:.05em;color:var(--dt-dim);font-variant-numeric:tabular-nums;margin-bottom:.15rem;font-size:.65rem;display:block}.tl-event__title{font-family:var(--dt-font-mono);color:var(--dt-ink);letter-spacing:.003em;margin:0;font-size:.92rem;font-weight:650;line-height:1.3}.tl-event__desc{font-family:var(--dt-font-sans);color:var(--dt-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:.2rem 0 0;font-size:.8rem;line-height:1.5;display:-webkit-box;overflow:hidden}.tl-project{background:var(--dt-surface);min-width:240px;max-width:360px;color:inherit;border:none;border-radius:10px;flex-direction:column;flex:260px;gap:.3rem;padding:.8rem .95rem;text-decoration:none;transition:all .25s;display:flex;position:relative}.tl-project:hover{background:var(--dt-surface-2);transform:translateY(-2px);box-shadow:0 8px 24px #00000059}.tl-project--hero{border-left:3px solid var(--dt-accent);background:linear-gradient(135deg,#ffb86b14,#ffb86b05)}.tl-project--highlight{background:#ffb86b08}.tl-project__head{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.tl-project__date{font-family:var(--dt-font-mono);letter-spacing:.05em;color:var(--dt-dim);font-variant-numeric:tabular-nums;font-size:.62rem}.tl-project__stars{font-family:var(--dt-font-mono);color:var(--dt-accent);font-size:.66rem}.tl-project__badge{font-family:var(--dt-font-mono);color:#0a0e1a;background:var(--dt-accent);letter-spacing:.05em;border-radius:3px;padding:.1rem .4rem;font-size:.55rem;font-weight:700}.tl-project__title{font-family:var(--dt-font-mono);color:var(--dt-accent);letter-spacing:.002em;margin:.05rem 0 0;font-size:1rem;font-weight:650;line-height:1.28}.tl-project__desc{font-family:var(--dt-font-sans);color:var(--dt-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:.15rem 0 0;font-size:.82rem;line-height:1.52;display:-webkit-box;overflow:hidden}.tl-project__tags{flex-wrap:wrap;gap:.25rem;margin-top:.2rem;display:flex}.tl-tag{border:1px solid var(--dt-line);color:var(--dt-dim);font-family:var(--dt-font-sans);white-space:nowrap;border-radius:999px;padding:.08rem .45rem;font-size:.6rem;font-weight:550}.tl-panel__insight{color:var(--dt-muted);border-left:2px solid var(--dt-accent);background:#ffb86b08;border-radius:0 6px 6px 0;margin:.5rem 0 0;padding:.55rem .85rem .55rem 1rem;font-family:Noto Serif SC,serif;font-size:.85rem;font-style:italic;line-height:1.6}@media (width<=1080px){.tl-section{grid-template-columns:170px 1fr}.tl-dial-col{padding-left:.8rem}.tl-dial__label{font-size:.75rem}.tl-panel__anchor{max-width:220px}}@media (width<=760px){.tl-section{grid-template-columns:1fr}.tl-dial-col{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--dt-line);z-index:50;background:#0a0e1af0;height:auto;padding:.5rem .8rem;position:sticky;top:0}.tl-dial{flex-direction:column;gap:.3rem;width:100%}.tl-dial__heading,.tl-dial__footer{display:none}.tl-dial__track{flex-direction:row;gap:.3rem;padding-bottom:.1rem;overflow-x:auto}.tl-dial__track:before{display:none}.tl-dial__item{text-align:center;flex-direction:column;flex-shrink:0;grid-template-rows:auto auto;grid-template-columns:auto;gap:.15rem;padding:.2rem .45rem}.tl-dial__num{background:0 0;width:auto;padding:0}.tl-dial__bar{justify-self:center;width:18px;height:1px}.tl-dial__item.is-active .tl-dial__bar{width:28px}.tl-dial__label{opacity:1;font-size:.6rem}.tl-panels{max-width:100%;padding:0 .8rem}.tl-panel{grid-template-columns:1fr;gap:1.2rem;height:auto;min-height:80vh;padding:1.5rem 0}.tl-panel__anchor{max-width:100%}.tl-panel__content{overflow-y:visible}.tl-items-row{flex-direction:column}.tl-event,.tl-project{flex:auto;max-width:100%}.tl-panel:after{font-size:clamp(4rem,18vw,7rem);top:1rem;right:-.25rem}}@media (prefers-reduced-motion:reduce){.tl-dial__bar,.tl-dial__label,.tl-event,.tl-project{transition:none}}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}:root,:host{--color-primary:#2563eb;--color-primary-foreground:#fff;--color-accent:#8b5cf6;--color-accent-foreground:#fff;--color-success:#22c55e;--color-warning:#f59e0b;--color-destructive:#ef4444;--color-destructive-foreground:#fff;--color-background:#fff;--color-foreground:#1e293b;--color-muted-foreground:#94a3b8;--color-input:#e2e8f0;--color-ring:#2563eb;--color-secondary:#64748b;--color-secondary-foreground:#fff;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.z-\[1000\]{z-index:1000}.container{width:100%}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.h-screen{height:100vh}.max-h-full{max-height:100%}.w-full{width:100%}.w-screen{width:100vw}.max-w-\[400px\]{max-width:400px}.max-w-\[600px\]{max-width:600px}.max-w-\[800px\]{max-width:800px}.max-w-\[1200px\]{max-width:1200px}.max-w-full{max-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-none{border-radius:0}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-input{border-color:var(--color-input)}.border-transparent{border-color:#0000}.bg-background{background-color:var(--color-background)}.bg-destructive{background-color:var(--color-destructive)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.text-center{text-align:center}.text-destructive-foreground{color:var(--color-destructive-foreground)}.text-foreground{color:var(--color-foreground)}.text-muted-foreground{color:var(--color-muted-foreground)}.text-primary{color:var(--color-primary)}.text-primary-foreground{color:var(--color-primary-foreground)}.text-secondary-foreground{color:var(--color-secondary-foreground)}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}@media (hover:hover){.hover\:bg-accent:hover{background-color:var(--color-accent)}.hover\:bg-destructive\/80:hover{background-color:#ef4444cc}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/80:hover{background-color:color-mix(in oklab,var(--color-destructive)80%,transparent)}}.hover\:bg-destructive\/90:hover{background-color:#ef4444e6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--color-destructive)90%,transparent)}}.hover\:bg-primary\/80:hover{background-color:#2563ebcc}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in oklab,var(--color-primary)80%,transparent)}}.hover\:bg-primary\/90:hover{background-color:#2563ebe6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--color-primary)90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:#64748bcc}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--color-secondary)80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--color-accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--color-ring)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}@layer base{:root{--radius:.5rem}}@layer components;.badge-base{letter-spacing:.025em;border:1px solid var(--border-color);background:var(--bg-light);color:var(--text-color);cursor:default;white-space:nowrap;border-radius:18px;align-items:center;padding:6px 12px;font-size:.75rem;font-weight:600;transition:all .2s;display:inline-flex}.badge-default{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.badge-secondary{background:var(--bg-light);color:var(--text-color);border-color:var(--border-color)}.badge-destructive{color:#fff;background:#ef4444;border-color:#ef4444}.badge-outline{color:var(--text-color);border-color:var(--border-color);background:0 0}.badge-success{color:#fff;background:#10b981;border-color:#10b981}.badge-warning{color:#fff;background:#f59e0b;border-color:#f59e0b}.badge-info{color:#fff;background:#3b82f6;border-color:#3b82f6}.badge-base:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.badge-default:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.badge-secondary:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.badge-destructive:hover{background:#dc2626;border-color:#dc2626}.badge-outline:hover{background:var(--bg-color);border-color:var(--text-color)}.badge-success:hover{background:#059669;border-color:#059669}.badge-warning:hover{background:#d97706;border-color:#d97706}.badge-info:hover{background:#2563eb;border-color:#2563eb}.badge-number{justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-family:ui-monospace,SFMono,Monaco,Cascadia Code,Roboto Mono,Consolas,Liberation Mono,Courier New,monospace;font-size:.7rem;display:flex}.badge-with-icon{align-items:center;gap:4px;display:flex}.badge-icon{justify-content:center;align-items:center;width:14px;height:14px;display:flex}.app.dark .badge-secondary{background:var(--bg-light);color:var(--text-color);border-color:var(--border-color)}.app.dark .badge-outline{color:var(--text-color);border-color:var(--border-color)}.app.dark .badge-secondary:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.badge-base:focus{box-shadow:0 0 0 2px var(--ring),0 0 0 0px var(--ring-offset);outline:none}.badge-base.disabled{opacity:.5;cursor:not-allowed;transform:none}.badge-base.disabled:hover{box-shadow:none;transform:none}:root{--dt-bg:#0a0e1a;--dt-bg-deeper:#06090f;--dt-surface:#0f1424;--dt-surface-2:#161d33;--dt-line:#96c8ff14;--dt-line-strong:#96c8ff2e;--dt-ink:#e8edf5;--dt-muted:#8a96ab;--dt-dim:#5e6a7e;--dt-accent:#ffb86b;--dt-accent-soft:#ffb86b1a;--dt-accent-line:#ffb86b59;--dt-font-display:"Fraunces","Noto Serif SC",Georgia,serif;--dt-font-serif:"Noto Serif SC","Fraunces",Georgia,serif;--dt-font-sans:-apple-system,BlinkMacSystemFont,sans-serif;--dt-font-mono:"Geist Mono","JetBrains Mono",ui-monospace,SFMono,monospace;--site-bg:#f5f7fb;--site-surface:#ffffffc7;--site-surface-solid:#fff;--site-ink:#121826;--site-muted:#5d687c;--site-line:#1218261f;--site-accent:#2563eb;--site-accent-soft:#60a5fa;--site-shadow:0 18px 60px #12182614;--primary-color:#2563eb;--primary-dark:#1d4ed8;--secondary-color:#64748b;--accent-color:#8b5cf6;--text-color:#1e293b;--text-light:#64748b;--bg-color:#fff;--bg-light:#f8fafc;--border-color:#e2e8f0;--shadow:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--card-bg:#fffffff2;--hover-bg:#f8fafccc;--text-primary:#1e293b;--text-secondary:#64748b;--warning-bg:#fbbf241a;--warning-text:#d97706;--radius:.5rem;--ring:0 0 0 3px #ffb86b66;--ring-offset:var(--dt-bg)}*{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden}body{font-family:var(--dt-font-sans);color:var(--dt-ink);background:var(--dt-bg);background-image:linear-gradient(90deg,var(--dt-line)1px,transparent 1px),linear-gradient(180deg,var(--dt-line)1px,transparent 1px);background-size:64px 64px;line-height:1.6}body:before{content:"";z-index:9999;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px 256px;position:fixed;inset:0}.app{min-height:100vh;position:relative}.app-content,.main-content{width:100%;min-height:100vh;position:relative}.page-content{min-height:calc(100vh - 80px);padding-top:0}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-light)}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.float-animation{animation:3s ease-in-out infinite float}.pulse-animation{animation:2s ease-in-out infinite pulse}@media (width<=768px){.app{font-size:14px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
